From 2ac332a2772ca736d0f5a474be2101bee65e01c3 Mon Sep 17 00:00:00 2001 From: Joe Polny Date: Wed, 23 Oct 2024 07:01:30 -0400 Subject: [PATCH 1/4] feat: latest ARC56 will full source info --- .../ConstantProductAMM.arc56_draft.json | 4862 ++- .../AbstractedAccount.arc56_draft.json | 4903 ++- .../arc72/artifacts/ARC72.arc56_draft.json | 2743 +- .../arc75/artifacts/ARC75.arc56_draft.json | 3271 +- .../Auction.arc56_draft.json | 2419 +- .../big_box/artifacts/BigBox.arc56_draft.json | 1851 +- .../artifacts/Calculator.arc56_draft.json | 635 +- .../artifacts/FactoryCaller.arc56_draft.json | 1090 +- .../artifacts/NFTFactory.arc56_draft.json | 598 +- .../CreatorVerifier.arc56_draft.json | 713 +- .../artifacts/MerkleTree.arc56_draft.json | 2316 +- .../artifacts/NonABIExample.arc56_draft.json | 556 +- .../artifacts/StakingPool.arc56_draft.json | 20397 ++++++++++- .../ValidatorRegistry.arc56_draft.json | 28600 +++++++++++++++- .../simple/artifacts/Simple.arc56_draft.json | 1142 +- .../ContactsApp.arc56_draft.json | 2722 +- src/lib/compiler.ts | 13 +- src/types/arc56.d.ts | 14 +- tests/contracts/artifacts/A.arc56_draft.json | 244 +- ...ABITestAccesStringInTuple.arc56_draft.json | 970 +- ...ynamicArrayElementInTuple.arc56_draft.json | 740 +- ...namicArrayInMiddleOfTuple.arc56_draft.json | 774 +- ...tAccessDynamicStringArray.arc56_draft.json | 768 +- ...taticArrayInBoxInVariable.arc56_draft.json | 396 +- .../ABITestAngularCasting.arc56_draft.json | 450 +- .../ABITestArrayInMethodCall.arc56_draft.json | 421 +- ...ITestArrayInObjectInState.arc56_draft.json | 383 +- .../ABITestArrayInTuple.arc56_draft.json | 336 +- .../ABITestArrayLength.arc56_draft.json | 319 +- .../ABITestArrayPop.arc56_draft.json | 417 +- .../ABITestArrayPopValue.arc56_draft.json | 500 +- .../ABITestArrayPush.arc56_draft.json | 381 +- .../ABITestArrayRef.arc56_draft.json | 381 +- .../ABITestArraySplice.arc56_draft.json | 536 +- .../ABITestArraySpliceValue.arc56_draft.json | 650 +- .../ABITestBiggerByteCasting.arc56_draft.json | 314 +- .../ABITestBoolFirstInTuple.arc56_draft.json | 355 +- .../ABITestBoolInNestedTuple.arc56_draft.json | 557 +- .../ABITestBoolInObj.arc56_draft.json | 556 +- .../ABITestBoolTuple.arc56_draft.json | 494 +- .../ABITestBoolTupleAccess.arc56_draft.json | 565 +- .../ABITestBoolTupleUpdate.arc56_draft.json | 558 +- ...BITestBooleanArgAndReturn.arc56_draft.json | 344 +- .../ABITestBooleanLastInObj.arc56_draft.json | 300 +- .../ABITestBytesCasting.arc56_draft.json | 335 +- .../ABITestBytesReturn.arc56_draft.json | 300 +- .../ABITestCastBytesFunction.arc56_draft.json | 256 +- ...ChainedPropertyAfterTuple.arc56_draft.json | 320 +- .../ABITestCustomTypes.arc56_draft.json | 1240 +- .../ABITestDisgusting.arc56_draft.json | 464 +- ...namicElementInStaticArray.arc56_draft.json | 490 +- .../ABITestDynamicArray.arc56_draft.json | 348 +- .../ABITestDynamicArrayArg.arc56_draft.json | 310 +- ...ITestDynamicArrayElements.arc56_draft.json | 564 +- ...namicArrayInMiddleOfTuple.arc56_draft.json | 608 +- ...TestDynamicArrayIteration.arc56_draft.json | 980 +- ...ABITestDynamicArrayLength.arc56_draft.json | 954 +- .../ABITestDynamicBoolArray.arc56_draft.json | 511 +- ...estDynamicBoolArrayAccess.arc56_draft.json | 574 +- ...estDynamicBoolArrayUpdate.arc56_draft.json | 575 +- .../ABITestDynamicTupleArray.arc56_draft.json | 344 +- .../ABITestEmptyDynamicArray.arc56_draft.json | 312 +- .../ABITestEmptyStaticArray.arc56_draft.json | 291 +- .../ABITestExtractUint.arc56_draft.json | 352 +- .../ABITestForEachReturn.arc56_draft.json | 609 +- .../ABITestForOfBreak.arc56_draft.json | 609 +- .../ABITestForOfContinue.arc56_draft.json | 609 +- ...BITestGlobalMethodInChain.arc56_draft.json | 304 +- ...eNestedStaticForEachInBox.arc56_draft.json | 719 +- ...rgeNestedStaticForOfInBox.arc56_draft.json | 719 +- .../ABITestMaxUfixed.arc56_draft.json | 302 +- ...tMixedStaticArrayElements.arc56_draft.json | 604 +- .../ABITestMultiBytesTuple.arc56_draft.json | 503 +- ...BITestMultiNestedArrayRef.arc56_draft.json | 326 +- .../ABITestNamedTuple.arc56_draft.json | 766 +- ...NestedArrayLengthInObject.arc56_draft.json | 305 +- ...rayLengthInObjectVariable.arc56_draft.json | 297 +- .../ABITestNestedArrayRef.arc56_draft.json | 322 +- .../ABITestNestedObject.arc56_draft.json | 356 +- .../ABITestNestedObjectType.arc56_draft.json | 356 +- .../ABITestNestedStaticArray.arc56_draft.json | 380 +- ...stNestedStaticArrayLength.arc56_draft.json | 315 +- ...BITestNestedStaticForEach.arc56_draft.json | 625 +- ...tNestedStaticForEachInBox.arc56_draft.json | 659 +- ...ITestNestedStructInBoxMap.arc56_draft.json | 383 +- .../ABITestNestedTuple.arc56_draft.json | 748 +- ...estNestedTypesInSignature.arc56_draft.json | 277 +- .../artifacts/ABITestNonE2E.arc56_draft.json | 599 +- ...eralDynamicElementInTuple.arc56_draft.json | 740 +- ...tNonLiteralNestedArrayRef.arc56_draft.json | 433 +- ...nLiteralStaticArrayAccess.arc56_draft.json | 372 +- ...iteralStaticArrayElements.arc56_draft.json | 434 +- .../ABITestObjectArrayRef.arc56_draft.json | 322 +- .../ABITestObjectInArgs.arc56_draft.json | 364 +- .../ABITestObjectRef.arc56_draft.json | 333 +- ...TestOpcodeParamFromObject.arc56_draft.json | 293 +- ...ABITestPartialStaticArray.arc56_draft.json | 291 +- ...ITestPlusEqualsArrayValue.arc56_draft.json | 378 +- ...ABITestPlusEqualsObjValue.arc56_draft.json | 378 +- ...stPlusEqualsObjValueInBox.arc56_draft.json | 425 +- ...BITestPostBoolTupleOffset.arc56_draft.json | 539 +- .../ABITestPushToArrayInBox.arc56_draft.json | 743 +- .../ABITestRawBytesFunction.arc56_draft.json | 332 +- .../ABITestRefTypes.arc56_draft.json | 410 +- .../ABITestReturnByte.arc56_draft.json | 329 +- ...ABITestReturnDynamicArray.arc56_draft.json | 368 +- ...turnDynamicArrayFromTuple.arc56_draft.json | 818 +- .../ABITestReturnStaticArray.arc56_draft.json | 309 +- .../ABITestReturnTuple.arc56_draft.json | 303 +- ...eturnTupleWithDyamicArray.arc56_draft.json | 652 +- ...TestSetStaticArrayElement.arc56_draft.json | 372 +- .../ABITestShortTypeNotation.arc56_draft.json | 376 +- ...rtenDynamicElementInTuple.arc56_draft.json | 1941 +- .../ABITestSimpleTuple.arc56_draft.json | 372 +- ...ABITestSmallerByteCasting.arc56_draft.json | 306 +- ...ABITestSpliceFirstElement.arc56_draft.json | 518 +- ...stSpliceFirstElementValue.arc56_draft.json | 603 +- .../ABITestSpliceLastElement.arc56_draft.json | 518 +- ...estSpliceLastElementValue.arc56_draft.json | 603 +- .../ABITestStaticArray.arc56_draft.json | 332 +- .../ABITestStaticArrayArg.arc56_draft.json | 320 +- ...stStaticArrayInStorageMap.arc56_draft.json | 600 +- ...stStaticArrayInStorageRef.arc56_draft.json | 600 +- .../ABITestStaticArrayLength.arc56_draft.json | 297 +- .../ABITestStaticBoolArray.arc56_draft.json | 494 +- ...TestStaticBoolArrayAccess.arc56_draft.json | 557 +- ...TestStaticBoolArrayUpdate.arc56_draft.json | 558 +- .../ABITestStaticByteCasting.arc56_draft.json | 258 +- .../ABITestStaticForEach.arc56_draft.json | 568 +- .../ABITestStaticForOf.arc56_draft.json | 568 +- ...ITestStaticStringArrayArg.arc56_draft.json | 428 +- .../ABITestStaticTypeInBox.arc56_draft.json | 292 +- ...agePropertyReferenceInBox.arc56_draft.json | 395 +- .../ABITestStorageRefAccount.arc56_draft.json | 664 +- .../ABITestStorageRefKey.arc56_draft.json | 622 +- .../ABITestStorageTypeHint.arc56_draft.json | 310 +- .../ABITestStringAccessor.arc56_draft.json | 349 +- .../ABITestStringArg.arc56_draft.json | 279 +- .../ABITestStringArray.arc56_draft.json | 255 +- .../ABITestStringInTuple.arc56_draft.json | 640 +- .../ABITestStringLength.arc56_draft.json | 306 +- .../ABITestStringReturn.arc56_draft.json | 309 +- ...reeDimensionalUint16Array.arc56_draft.json | 404 +- .../ABITestTupleArg.arc56_draft.json | 364 +- .../ABITestTupleInArray.arc56_draft.json | 372 +- .../ABITestTupleInTuple.arc56_draft.json | 332 +- .../ABITestTxnTypes.arc56_draft.json | 780 +- .../ABITestTypedConst.arc56_draft.json | 276 +- ...BITestTypedVarFromStorage.arc56_draft.json | 365 +- .../ABITestUint64Casting.arc56_draft.json | 355 +- .../ABITestUintCasting.arc56_draft.json | 444 +- .../ABITestUintNComparison.arc56_draft.json | 388 +- ...pdateArrayRefInBoxStorage.arc56_draft.json | 362 +- ...UpdateDynamicArrayElement.arc56_draft.json | 404 +- ...namicArrayInMiddleOfTuple.arc56_draft.json | 1071 +- ...UpdateDynamicArrayInTuple.arc56_draft.json | 2519 +- ...mentInTupleWithSameLength.arc56_draft.json | 1311 +- .../ABITestUpdateNamedTuple.arc56_draft.json | 1240 +- ...stUpdateNestedStaticArray.arc56_draft.json | 436 +- ...eNestedStaticArrayElement.arc56_draft.json | 420 +- ...teStaticArrayInStorageMap.arc56_draft.json | 798 +- ...teStaticArrayInStorageRef.arc56_draft.json | 798 +- ...FieldInDynamicObjectInBox.arc56_draft.json | 923 +- ...BITestUpdateStringInTuple.arc56_draft.json | 2541 +- ...TupleWithOnlyDynamicTypes.arc56_draft.json | 1947 +- tests/contracts/artifacts/AD.arc56_draft.json | 465 +- .../artifacts/ARC56Test.arc56_draft.json | 1100 +- .../ARC56TestNoTemplateVars.arc56_draft.json | 142 +- .../artifacts/AVM11.arc56_draft.json | 12 +- .../artifacts/AccountTest.arc56_draft.json | 2285 +- tests/contracts/artifacts/B.arc56_draft.json | 371 +- tests/contracts/artifacts/B2.arc56_draft.json | 315 +- .../artifacts/BigComment.arc56_draft.json | 532 +- .../artifacts/BinaryTest.arc56_draft.json | 1197 +- .../artifacts/BytecblockTest.arc56_draft.json | 9378 ++++- tests/contracts/artifacts/C.arc56_draft.json | 504 +- .../ContractWithCustomStruct.arc56_draft.json | 297 +- .../ContractWithLsigProgram.arc56_draft.json | 199 +- .../ContratWithLsigAddress.arc56_draft.json | 214 +- tests/contracts/artifacts/D.arc56_draft.json | 243 +- .../artifacts/DummyContract.arc56_draft.json | 142 +- tests/contracts/artifacts/E.arc56_draft.json | 813 +- .../ExternalContract.arc56_draft.json | 384 +- tests/contracts/artifacts/F.arc56_draft.json | 367 +- .../artifacts/FunctionsTest.arc56_draft.json | 727 +- tests/contracts/artifacts/G.arc56_draft.json | 523 +- .../artifacts/GeneralTest.arc56_draft.json | 15263 ++++++++- .../artifacts/IfTest.arc56_draft.json | 4486 ++- .../artifacts/IntcblockTest.arc56_draft.json | 4215 ++- .../artifacts/ItxnsTest.arc56_draft.json | 2431 +- .../artifacts/LoopsTest.arc56_draft.json | 2437 +- .../artifacts/MathTest.arc56_draft.json | 11123 +++++- .../MultiInheritance.arc56_draft.json | 619 +- .../MultiInheritanceProgram.arc56_draft.json | 509 +- .../artifacts/ProgramVersion.arc56_draft.json | 142 +- .../artifacts/SchemaContract.arc56_draft.json | 142 +- .../artifacts/StorageTest.arc56_draft.json | 5257 ++- .../artifacts/Templates.arc56_draft.json | 548 +- 198 files changed, 222273 insertions(+), 2509 deletions(-) diff --git a/examples/amm/tealscript_artifacts/ConstantProductAMM.arc56_draft.json b/examples/amm/tealscript_artifacts/ConstantProductAMM.arc56_draft.json index fefb552d5..0bd1d58e8 100644 --- a/examples/amm/tealscript_artifacts/ConstantProductAMM.arc56_draft.json +++ b/examples/amm/tealscript_artifacts/ConstantProductAMM.arc56_draft.json @@ -211,214 +211,4880 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "examples/amm/amm.algo.ts:8", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "examples/amm/amm.algo.ts:8", + "pc": [ + 1, + 2, + 3, + 4, + 5, + 6, + 7, + 8, + 9, + 10, + 11 + ] + }, + { + "teal": 3, + "source": "examples/amm/amm.algo.ts:8", + "pc": [ + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24 + ] + }, + { + "teal": 15, + "source": "examples/amm/amm.algo.ts:8", + "pc": [ + 25, + 26 + ] + }, + { + "teal": 16, + "source": "examples/amm/amm.algo.ts:8", + "pc": [ + 27 + ] + }, + { + "teal": 17, + "source": "examples/amm/amm.algo.ts:8", + "pc": [ + 28, + 29 + ] + }, + { + "teal": 18, + "source": "examples/amm/amm.algo.ts:8", + "pc": [ + 30 + ] + }, + { + "teal": 19, + "source": "examples/amm/amm.algo.ts:8", + "pc": [ + 31, + 32 + ] + }, + { + "teal": 20, + "source": "examples/amm/amm.algo.ts:8", + "pc": [ + 33 + ] + }, + { + "teal": 21, + "source": "examples/amm/amm.algo.ts:8", + "pc": [ + 34, + 35, + 36, + 37, + 38, + 39, + 40, + 41, + 42, + 43, + 44, + 45, + 46, + 47, + 48, + 49, + 50, + 51, + 52, + 53, + 54, + 55, + 56, + 57, + 58, + 59 + ] + }, + { + "teal": 25, + "source": "examples/amm/amm.algo.ts:8", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 60 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 30, + "source": "examples/amm/amm.algo.ts:19", + "pc": [ + 61, + 62, + 63 + ] + }, + { + "teal": 31, + "source": "examples/amm/amm.algo.ts:19", + "pc": [ + 64, + 65 + ] + }, + { + "teal": 32, + "source": "examples/amm/amm.algo.ts:19", + "pc": [ + 66 + ] + }, + { + "teal": 36, + "source": "examples/amm/amm.algo.ts:19", + "pc": [ + 67, + 68, + 69 + ] + }, + { + "teal": 40, + "source": "examples/amm/amm.algo.ts:20", + "pc": [ + 70, + 71, + 72 + ] + }, + { + "teal": 41, + "source": "examples/amm/amm.algo.ts:20", + "pc": [ + 73, + 74 + ] + }, + { + "teal": 42, + "source": "examples/amm/amm.algo.ts:20", + "pc": [ + 75 + ] + }, + { + "teal": 43, + "source": "examples/amm/amm.algo.ts:19", + "pc": [ + 76 + ] + }, + { + "teal": 47, + "source": "examples/amm/amm.algo.ts:23", + "pc": [ + 77, + 78, + 79 + ] + }, + { + "teal": 58, + "source": "examples/amm/amm.algo.ts:26", + "pc": [ + 80 + ] + }, + { + "teal": 59, + "source": "examples/amm/amm.algo.ts:26", + "pc": [ + 81, + 82 + ] + }, + { + "teal": 60, + "source": "examples/amm/amm.algo.ts:26", + "pc": [ + 83, + 84 + ] + }, + { + "teal": 64, + "source": "examples/amm/amm.algo.ts:27", + "pc": [ + 85, + 86, + 87, + 88, + 89, + 90 + ] + }, + { + "teal": 65, + "source": "examples/amm/amm.algo.ts:27", + "pc": [ + 91, + 92 + ] + }, + { + "teal": 66, + "source": "examples/amm/amm.algo.ts:27", + "pc": [ + 93, + 94 + ] + }, + { + "teal": 67, + "source": "examples/amm/amm.algo.ts:27", + "pc": [ + 95 + ] + }, + { + "teal": 68, + "source": "examples/amm/amm.algo.ts:27", + "pc": [ + 96 + ] + }, + { + "teal": 69, + "source": "examples/amm/amm.algo.ts:27", + "pc": [ + 97, + 98, + 99 + ] + }, + { + "teal": 70, + "source": "examples/amm/amm.algo.ts:27", + "pc": [ + 100 + ] + }, + { + "teal": 71, + "source": "examples/amm/amm.algo.ts:27", + "pc": [ + 101, + 102 + ] + }, + { + "teal": 72, + "source": "examples/amm/amm.algo.ts:27", + "pc": [ + 103, + 104 + ] + }, + { + "teal": 73, + "source": "examples/amm/amm.algo.ts:27", + "pc": [ + 105 + ] + }, + { + "teal": 74, + "source": "examples/amm/amm.algo.ts:27", + "pc": [ + 106 + ] + }, + { + "teal": 75, + "source": "examples/amm/amm.algo.ts:27", + "pc": [ + 107, + 108 + ] + }, + { + "teal": 79, + "source": "examples/amm/amm.algo.ts:28", + "pc": [ + 109, + 110, + 111, + 112, + 113 + ] + }, + { + "teal": 80, + "source": "examples/amm/amm.algo.ts:28", + "pc": [ + 114, + 115 + ] + }, + { + "teal": 84, + "source": "examples/amm/amm.algo.ts:29", + "pc": [ + 116, + 117, + 118, + 119, + 120, + 121 + ] + }, + { + "teal": 85, + "source": "examples/amm/amm.algo.ts:29", + "pc": [ + 122, + 123 + ] + }, + { + "teal": 89, + "source": "examples/amm/amm.algo.ts:30", + "pc": [ + 124, + 125 + ] + }, + { + "teal": 90, + "source": "examples/amm/amm.algo.ts:30", + "pc": [ + 126, + 127 + ] + }, + { + "teal": 94, + "source": "examples/amm/amm.algo.ts:31", + "pc": [ + 128, + 129 + ] + }, + { + "teal": 95, + "source": "examples/amm/amm.algo.ts:31", + "pc": [ + 130, + 131 + ] + }, + { + "teal": 99, + "source": "examples/amm/amm.algo.ts:32", + "pc": [ + 132, + 133 + ] + }, + { + "teal": 100, + "source": "examples/amm/amm.algo.ts:32", + "pc": [ + 134, + 135 + ] + }, + { + "teal": 103, + "source": "examples/amm/amm.algo.ts:26", + "pc": [ + 136, + 137 + ] + }, + { + "teal": 104, + "source": "examples/amm/amm.algo.ts:26", + "pc": [ + 138, + 139 + ] + }, + { + "teal": 107, + "source": "examples/amm/amm.algo.ts:26", + "pc": [ + 140 + ] + }, + { + "teal": 108, + "source": "examples/amm/amm.algo.ts:26", + "pc": [ + 141, + 142 + ] + }, + { + "teal": 109, + "source": "examples/amm/amm.algo.ts:23", + "pc": [ + 143 + ] + }, + { + "teal": 113, + "source": "examples/amm/amm.algo.ts:36", + "pc": [ + 144, + 145, + 146 + ] + }, + { + "teal": 121, + "source": "examples/amm/amm.algo.ts:37", + "pc": [ + 147 + ] + }, + { + "teal": 122, + "source": "examples/amm/amm.algo.ts:37", + "pc": [ + 148, + 149 + ] + }, + { + "teal": 123, + "source": "examples/amm/amm.algo.ts:37", + "pc": [ + 150, + 151 + ] + }, + { + "teal": 127, + "source": "examples/amm/amm.algo.ts:38", + "pc": [ + 152, + 153 + ] + }, + { + "teal": 128, + "source": "examples/amm/amm.algo.ts:38", + "pc": [ + 154, + 155 + ] + }, + { + "teal": 132, + "source": "examples/amm/amm.algo.ts:39", + "pc": [ + 156, + 157 + ] + }, + { + "teal": 133, + "source": "examples/amm/amm.algo.ts:39", + "pc": [ + 158, + 159 + ] + }, + { + "teal": 137, + "source": "examples/amm/amm.algo.ts:40", + "pc": [ + 160, + 161 + ] + }, + { + "teal": 138, + "source": "examples/amm/amm.algo.ts:40", + "pc": [ + 162, + 163 + ] + }, + { + "teal": 141, + "source": "examples/amm/amm.algo.ts:37", + "pc": [ + 164, + 165 + ] + }, + { + "teal": 142, + "source": "examples/amm/amm.algo.ts:37", + "pc": [ + 166, + 167 + ] + }, + { + "teal": 145, + "source": "examples/amm/amm.algo.ts:37", + "pc": [ + 168 + ] + }, + { + "teal": 146, + "source": "examples/amm/amm.algo.ts:36", + "pc": [ + 169 + ] + }, + { + "teal": 150, + "source": "examples/amm/amm.algo.ts:44", + "pc": [ + 170, + 171, + 172 + ] + }, + { + "teal": 154, + "source": "examples/amm/amm.algo.ts:45", + "pc": [ + 173, + 174 + ] + }, + { + "teal": 155, + "source": "examples/amm/amm.algo.ts:45", + "pc": [ + 175, + 176 + ] + }, + { + "teal": 156, + "source": "examples/amm/amm.algo.ts:45", + "pc": [ + 177, + 178 + ] + }, + { + "teal": 157, + "source": "examples/amm/amm.algo.ts:45", + "pc": [ + 179, + 180, + 181 + ] + }, + { + "teal": 158, + "source": "examples/amm/amm.algo.ts:44", + "pc": [ + 182 + ] + }, + { + "teal": 162, + "source": "examples/amm/amm.algo.ts:48", + "pc": [ + 183, + 184, + 185 + ] + }, + { + "teal": 166, + "source": "examples/amm/amm.algo.ts:49", + "pc": [ + 186, + 187 + ] + }, + { + "teal": 167, + "source": "examples/amm/amm.algo.ts:49", + "pc": [ + 188, + 189 + ] + }, + { + "teal": 168, + "source": "examples/amm/amm.algo.ts:49", + "pc": [ + 190 + ] + }, + { + "teal": 169, + "source": "examples/amm/amm.algo.ts:49", + "pc": [ + 191 + ] + }, + { + "teal": 170, + "source": "examples/amm/amm.algo.ts:48", + "pc": [ + 192 + ] + }, + { + "teal": 174, + "source": "examples/amm/amm.algo.ts:52", + "pc": [ + 193, + 194, + 195 + ] + }, + { + "teal": 177, + "source": "examples/amm/amm.algo.ts:52", + "pc": [ + 196, + 197 + ] + }, + { + "teal": 178, + "source": "examples/amm/amm.algo.ts:52", + "pc": [ + 198, + 199 + ] + }, + { + "teal": 182, + "source": "examples/amm/amm.algo.ts:53", + "pc": [ + 200, + 201 + ] + }, + { + "teal": 183, + "source": "examples/amm/amm.algo.ts:53", + "pc": [ + 202, + 203, + 204 + ] + }, + { + "teal": 184, + "source": "examples/amm/amm.algo.ts:53", + "pc": [ + 205 + ] + }, + { + "teal": 185, + "source": "examples/amm/amm.algo.ts:53", + "pc": [ + 206, + 207 + ] + }, + { + "teal": 186, + "source": "examples/amm/amm.algo.ts:53", + "pc": [ + 208, + 209 + ] + }, + { + "teal": 187, + "source": "examples/amm/amm.algo.ts:53", + "pc": [ + 210 + ] + }, + { + "teal": 188, + "source": "examples/amm/amm.algo.ts:53", + "pc": [ + 211 + ] + }, + { + "teal": 189, + "source": "examples/amm/amm.algo.ts:53", + "pc": [ + 212 + ] + }, + { + "teal": 190, + "source": "examples/amm/amm.algo.ts:53", + "pc": [ + 213 + ] + }, + { + "teal": 191, + "source": "examples/amm/amm.algo.ts:53", + "pc": [ + 214 + ] + }, + { + "teal": 194, + "source": "examples/amm/amm.algo.ts:53", + "errorMessage": "wideRatio failed", + "pc": [ + 215 + ] + }, + { + "teal": 195, + "source": "examples/amm/amm.algo.ts:53", + "pc": [ + 216, + 217 + ] + }, + { + "teal": 199, + "source": "examples/amm/amm.algo.ts:54", + "pc": [ + 218, + 219 + ] + }, + { + "teal": 200, + "source": "examples/amm/amm.algo.ts:54", + "pc": [ + 220, + 221, + 222 + ] + }, + { + "teal": 201, + "source": "examples/amm/amm.algo.ts:54", + "pc": [ + 223 + ] + }, + { + "teal": 202, + "source": "examples/amm/amm.algo.ts:54", + "pc": [ + 224, + 225 + ] + }, + { + "teal": 203, + "source": "examples/amm/amm.algo.ts:54", + "pc": [ + 226, + 227 + ] + }, + { + "teal": 204, + "source": "examples/amm/amm.algo.ts:54", + "pc": [ + 228 + ] + }, + { + "teal": 205, + "source": "examples/amm/amm.algo.ts:54", + "pc": [ + 229 + ] + }, + { + "teal": 206, + "source": "examples/amm/amm.algo.ts:54", + "pc": [ + 230 + ] + }, + { + "teal": 207, + "source": "examples/amm/amm.algo.ts:54", + "pc": [ + 231 + ] + }, + { + "teal": 208, + "source": "examples/amm/amm.algo.ts:54", + "pc": [ + 232 + ] + }, + { + "teal": 211, + "source": "examples/amm/amm.algo.ts:54", + "errorMessage": "wideRatio failed", + "pc": [ + 233 + ] + }, + { + "teal": 212, + "source": "examples/amm/amm.algo.ts:54", + "pc": [ + 234, + 235 + ] + }, + { + "teal": 216, + "source": "examples/amm/amm.algo.ts:56", + "pc": [ + 236, + 237 + ] + }, + { + "teal": 217, + "source": "examples/amm/amm.algo.ts:56", + "pc": [ + 238, + 239 + ] + }, + { + "teal": 218, + "source": "examples/amm/amm.algo.ts:56", + "pc": [ + 240 + ] + }, + { + "teal": 219, + "source": "examples/amm/amm.algo.ts:56", + "pc": [ + 241, + 242, + 243 + ] + }, + { + "teal": 220, + "source": "examples/amm/amm.algo.ts:56", + "pc": [ + 244, + 245 + ] + }, + { + "teal": 221, + "source": "examples/amm/amm.algo.ts:56", + "pc": [ + 246, + 247, + 248 + ] + }, + { + "teal": 224, + "source": "examples/amm/amm.algo.ts:56", + "pc": [ + 249, + 250 + ] + }, + { + "teal": 227, + "source": "examples/amm/amm.algo.ts:56", + "pc": [ + 251, + 252 + ] + }, + { + "teal": 231, + "source": "examples/amm/amm.algo.ts:58", + "pc": [ + 253, + 254 + ] + }, + { + "teal": 232, + "source": "examples/amm/amm.algo.ts:58", + "pc": [ + 255, + 256 + ] + }, + { + "teal": 233, + "source": "examples/amm/amm.algo.ts:58", + "pc": [ + 257 + ] + }, + { + "teal": 234, + "source": "examples/amm/amm.algo.ts:58", + "pc": [ + 258, + 259 + ] + }, + { + "teal": 235, + "source": "examples/amm/amm.algo.ts:58", + "pc": [ + 260, + 261, + 262 + ] + }, + { + "teal": 236, + "source": "examples/amm/amm.algo.ts:58", + "pc": [ + 263 + ] + }, + { + "teal": 237, + "source": "examples/amm/amm.algo.ts:58", + "pc": [ + 264 + ] + }, + { + "teal": 238, + "source": "examples/amm/amm.algo.ts:58", + "pc": [ + 265 + ] + }, + { + "teal": 239, + "source": "examples/amm/amm.algo.ts:58", + "pc": [ + 266 + ] + }, + { + "teal": 240, + "source": "examples/amm/amm.algo.ts:58", + "pc": [ + 267 + ] + }, + { + "teal": 243, + "source": "examples/amm/amm.algo.ts:58", + "errorMessage": "wideRatio failed", + "pc": [ + 268 + ] + }, + { + "teal": 246, + "source": "examples/amm/amm.algo.ts:52", + "pc": [ + 269, + 270 + ] + }, + { + "teal": 249, + "source": "examples/amm/amm.algo.ts:52", + "pc": [ + 271, + 272 + ] + }, + { + "teal": 250, + "source": "examples/amm/amm.algo.ts:52", + "pc": [ + 273 + ] + }, + { + "teal": 254, + "source": "examples/amm/amm.algo.ts:61", + "pc": [ + 274, + 275, + 276 + ] + }, + { + "teal": 261, + "source": "examples/amm/amm.algo.ts:63", + "pc": [ + 277, + 278 + ] + }, + { + "teal": 262, + "source": "examples/amm/amm.algo.ts:63", + "pc": [ + 279, + 280, + 281 + ] + }, + { + "teal": 263, + "source": "examples/amm/amm.algo.ts:63", + "pc": [ + 282 + ] + }, + { + "teal": 264, + "source": "examples/amm/amm.algo.ts:63", + "pc": [ + 283, + 284 + ] + }, + { + "teal": 265, + "source": "examples/amm/amm.algo.ts:63", + "pc": [ + 285 + ] + }, + { + "teal": 266, + "source": "examples/amm/amm.algo.ts:63", + "pc": [ + 286, + 287, + 288 + ] + }, + { + "teal": 267, + "source": "examples/amm/amm.algo.ts:62", + "pc": [ + 289 + ] + }, + { + "teal": 268, + "source": "examples/amm/amm.algo.ts:62", + "pc": [ + 290, + 291 + ] + }, + { + "teal": 269, + "source": "examples/amm/amm.algo.ts:64", + "pc": [ + 292, + 293 + ] + }, + { + "teal": 270, + "source": "examples/amm/amm.algo.ts:64", + "pc": [ + 294, + 295, + 296 + ] + }, + { + "teal": 271, + "source": "examples/amm/amm.algo.ts:64", + "pc": [ + 297 + ] + }, + { + "teal": 272, + "source": "examples/amm/amm.algo.ts:64", + "pc": [ + 298, + 299 + ] + }, + { + "teal": 273, + "source": "examples/amm/amm.algo.ts:64", + "pc": [ + 300 + ] + }, + { + "teal": 274, + "source": "examples/amm/amm.algo.ts:62", + "pc": [ + 301 + ] + }, + { + "teal": 275, + "source": "examples/amm/amm.algo.ts:62", + "pc": [ + 302 + ] + }, + { + "teal": 276, + "source": "examples/amm/amm.algo.ts:62", + "pc": [ + 303 + ] + }, + { + "teal": 277, + "source": "examples/amm/amm.algo.ts:62", + "pc": [ + 304 + ] + }, + { + "teal": 278, + "source": "examples/amm/amm.algo.ts:62", + "pc": [ + 305 + ] + }, + { + "teal": 281, + "source": "examples/amm/amm.algo.ts:62", + "errorMessage": "wideRatio failed", + "pc": [ + 306 + ] + }, + { + "teal": 282, + "source": "examples/amm/amm.algo.ts:61", + "pc": [ + 307 + ] + }, + { + "teal": 286, + "source": "examples/amm/amm.algo.ts:68", + "pc": [ + 308, + 309, + 310 + ] + }, + { + "teal": 290, + "source": "examples/amm/amm.algo.ts:69", + "pc": [ + 311, + 312 + ] + }, + { + "teal": 291, + "source": "examples/amm/amm.algo.ts:69", + "pc": [ + 313, + 314 + ] + }, + { + "teal": 292, + "source": "examples/amm/amm.algo.ts:69", + "pc": [ + 315 + ] + }, + { + "teal": 293, + "source": "examples/amm/amm.algo.ts:69", + "pc": [ + 316, + 317 + ] + }, + { + "teal": 294, + "source": "examples/amm/amm.algo.ts:69", + "pc": [ + 318, + 319 + ] + }, + { + "teal": 295, + "source": "examples/amm/amm.algo.ts:69", + "pc": [ + 320 + ] + }, + { + "teal": 296, + "source": "examples/amm/amm.algo.ts:69", + "pc": [ + 321 + ] + }, + { + "teal": 297, + "source": "examples/amm/amm.algo.ts:69", + "pc": [ + 322 + ] + }, + { + "teal": 298, + "source": "examples/amm/amm.algo.ts:69", + "pc": [ + 323 + ] + }, + { + "teal": 299, + "source": "examples/amm/amm.algo.ts:69", + "pc": [ + 324 + ] + }, + { + "teal": 302, + "source": "examples/amm/amm.algo.ts:69", + "errorMessage": "wideRatio failed", + "pc": [ + 325 + ] + }, + { + "teal": 303, + "source": "examples/amm/amm.algo.ts:68", + "pc": [ + 326 + ] + }, + { + "teal": 307, + "source": "examples/amm/amm.algo.ts:72", + "pc": [ + 327, + 328, + 329 + ] + }, + { + "teal": 310, + "source": "examples/amm/amm.algo.ts:72", + "pc": [ + 330, + 331 + ] + }, + { + "teal": 314, + "source": "examples/amm/amm.algo.ts:73", + "pc": [ + 332, + 333, + 334 + ] + }, + { + "teal": 315, + "source": "examples/amm/amm.algo.ts:73", + "pc": [ + 335, + 336 + ] + }, + { + "teal": 319, + "source": "examples/amm/amm.algo.ts:74", + "pc": [ + 337, + 338 + ] + }, + { + "teal": 320, + "source": "examples/amm/amm.algo.ts:74", + "pc": [ + 339, + 340 + ] + }, + { + "teal": 321, + "source": "examples/amm/amm.algo.ts:74", + "pc": [ + 341 + ] + }, + { + "teal": 322, + "source": "examples/amm/amm.algo.ts:74", + "pc": [ + 342, + 343 + ] + }, + { + "teal": 323, + "source": "examples/amm/amm.algo.ts:74", + "pc": [ + 344, + 345 + ] + }, + { + "teal": 324, + "source": "examples/amm/amm.algo.ts:74", + "pc": [ + 346, + 347 + ] + }, + { + "teal": 325, + "source": "examples/amm/amm.algo.ts:74", + "pc": [ + 348 + ] + }, + { + "teal": 326, + "source": "examples/amm/amm.algo.ts:74", + "pc": [ + 349, + 350 + ] + }, + { + "teal": 327, + "source": "examples/amm/amm.algo.ts:74", + "pc": [ + 351 + ] + }, + { + "teal": 328, + "source": "examples/amm/amm.algo.ts:74", + "pc": [ + 352, + 353 + ] + }, + { + "teal": 329, + "source": "examples/amm/amm.algo.ts:74", + "pc": [ + 354 + ] + }, + { + "teal": 330, + "source": "examples/amm/amm.algo.ts:74", + "pc": [ + 355 + ] + }, + { + "teal": 331, + "source": "examples/amm/amm.algo.ts:74", + "pc": [ + 356, + 357 + ] + }, + { + "teal": 332, + "source": "examples/amm/amm.algo.ts:74", + "pc": [ + 358, + 359 + ] + }, + { + "teal": 333, + "source": "examples/amm/amm.algo.ts:74", + "pc": [ + 360, + 361, + 362 + ] + }, + { + "teal": 334, + "source": "examples/amm/amm.algo.ts:74", + "pc": [ + 363 + ] + }, + { + "teal": 335, + "source": "examples/amm/amm.algo.ts:74", + "pc": [ + 364, + 365 + ] + }, + { + "teal": 336, + "source": "examples/amm/amm.algo.ts:74", + "pc": [ + 366, + 367 + ] + }, + { + "teal": 337, + "source": "examples/amm/amm.algo.ts:74", + "pc": [ + 368 + ] + }, + { + "teal": 338, + "source": "examples/amm/amm.algo.ts:74", + "pc": [ + 369 + ] + }, + { + "teal": 339, + "source": "examples/amm/amm.algo.ts:74", + "pc": [ + 370 + ] + }, + { + "teal": 340, + "source": "examples/amm/amm.algo.ts:74", + "pc": [ + 371 + ] + }, + { + "teal": 341, + "source": "examples/amm/amm.algo.ts:74", + "pc": [ + 372 + ] + }, + { + "teal": 342, + "source": "examples/amm/amm.algo.ts:74", + "pc": [ + 373 + ] + }, + { + "teal": 343, + "source": "examples/amm/amm.algo.ts:74", + "pc": [ + 374 + ] + }, + { + "teal": 346, + "source": "examples/amm/amm.algo.ts:74", + "errorMessage": "wideRatio failed", + "pc": [ + 375 + ] + }, + { + "teal": 349, + "source": "examples/amm/amm.algo.ts:72", + "pc": [ + 376, + 377 + ] + }, + { + "teal": 350, + "source": "examples/amm/amm.algo.ts:72", + "pc": [ + 378 + ] + }, + { + "teal": 355, + "source": "examples/amm/amm.algo.ts:77", + "pc": [ + 379, + 380, + 381 + ] + }, + { + "teal": 356, + "source": "examples/amm/amm.algo.ts:77", + "pc": [ + 382 + ] + }, + { + "teal": 357, + "source": "examples/amm/amm.algo.ts:77", + "pc": [ + 383 + ] + }, + { + "teal": 358, + "source": "examples/amm/amm.algo.ts:77", + "pc": [ + 384, + 385 + ] + }, + { + "teal": 359, + "source": "examples/amm/amm.algo.ts:77", + "pc": [ + 386 + ] + }, + { + "teal": 362, + "source": "examples/amm/amm.algo.ts:77", + "errorMessage": "argument 0 (governor) for set_governor must be a address", + "pc": [ + 387 + ] + }, + { + "teal": 365, + "source": "examples/amm/amm.algo.ts:77", + "pc": [ + 388, + 389, + 390 + ] + }, + { + "teal": 366, + "source": "examples/amm/amm.algo.ts:77", + "pc": [ + 391, + 392 + ] + }, + { + "teal": 367, + "source": "examples/amm/amm.algo.ts:77", + "pc": [ + 393 + ] + }, + { + "teal": 371, + "source": "examples/amm/amm.algo.ts:77", + "pc": [ + 394, + 395, + 396 + ] + }, + { + "teal": 376, + "source": "examples/amm/amm.algo.ts:78", + "pc": [ + 397, + 398 + ] + }, + { + "teal": 377, + "source": "examples/amm/amm.algo.ts:78", + "pc": [ + 399, + 400, + 401 + ] + }, + { + "teal": 378, + "source": "examples/amm/amm.algo.ts:78", + "pc": [ + 402 + ] + }, + { + "teal": 379, + "source": "examples/amm/amm.algo.ts:78", + "pc": [ + 403 + ] + }, + { + "teal": 382, + "source": "examples/amm/amm.algo.ts:78", + "errorMessage": "transaction verification failed: {\"txn\":\"this.txn\",\"field\":\"sender\",\"expected\":\"this.governor.value\"}", + "pc": [ + 404 + ] + }, + { + "teal": 386, + "source": "examples/amm/amm.algo.ts:79", + "pc": [ + 405, + 406, + 407 + ] + }, + { + "teal": 387, + "source": "examples/amm/amm.algo.ts:79", + "pc": [ + 408, + 409 + ] + }, + { + "teal": 388, + "source": "examples/amm/amm.algo.ts:79", + "pc": [ + 410 + ] + }, + { + "teal": 389, + "source": "examples/amm/amm.algo.ts:77", + "pc": [ + 411 + ] + }, + { + "teal": 394, + "source": "examples/amm/amm.algo.ts:82", + "pc": [ + 412, + 413, + 414, + 415, + 416, + 417 + ] + }, + { + "teal": 397, + "source": "examples/amm/amm.algo.ts:82", + "pc": [ + 418, + 419, + 420 + ] + }, + { + "teal": 398, + "source": "examples/amm/amm.algo.ts:82", + "pc": [ + 421 + ] + }, + { + "teal": 401, + "source": "examples/amm/amm.algo.ts:82", + "pc": [ + 422, + 423, + 424 + ] + }, + { + "teal": 402, + "source": "examples/amm/amm.algo.ts:82", + "pc": [ + 425 + ] + }, + { + "teal": 405, + "source": "examples/amm/amm.algo.ts:82", + "pc": [ + 426, + 427 + ] + }, + { + "teal": 406, + "source": "examples/amm/amm.algo.ts:82", + "pc": [ + 428, + 429 + ] + }, + { + "teal": 407, + "source": "examples/amm/amm.algo.ts:82", + "pc": [ + 430 + ] + }, + { + "teal": 408, + "source": "examples/amm/amm.algo.ts:82", + "pc": [ + 431 + ] + }, + { + "teal": 409, + "source": "examples/amm/amm.algo.ts:82", + "pc": [ + 432, + 433 + ] + }, + { + "teal": 410, + "source": "examples/amm/amm.algo.ts:82", + "pc": [ + 434, + 435 + ] + }, + { + "teal": 411, + "source": "examples/amm/amm.algo.ts:82", + "pc": [ + 436 + ] + }, + { + "teal": 414, + "source": "examples/amm/amm.algo.ts:82", + "errorMessage": "argument 2 (seed) for bootstrap must be a pay transaction", + "pc": [ + 437 + ] + }, + { + "teal": 417, + "source": "examples/amm/amm.algo.ts:82", + "pc": [ + 438, + 439, + 440 + ] + }, + { + "teal": 418, + "source": "examples/amm/amm.algo.ts:82", + "pc": [ + 441 + ] + }, + { + "teal": 419, + "source": "examples/amm/amm.algo.ts:82", + "pc": [ + 442 + ] + }, + { + "teal": 420, + "source": "examples/amm/amm.algo.ts:82", + "pc": [ + 443 + ] + }, + { + "teal": 421, + "source": "examples/amm/amm.algo.ts:82", + "pc": [ + 444, + 445 + ] + }, + { + "teal": 422, + "source": "examples/amm/amm.algo.ts:82", + "pc": [ + 446 + ] + }, + { + "teal": 426, + "source": "examples/amm/amm.algo.ts:82", + "pc": [ + 447, + 448, + 449 + ] + }, + { + "teal": 431, + "source": "examples/amm/amm.algo.ts:83", + "pc": [ + 450, + 451 + ] + }, + { + "teal": 432, + "source": "examples/amm/amm.algo.ts:83", + "pc": [ + 452, + 453, + 454 + ] + }, + { + "teal": 433, + "source": "examples/amm/amm.algo.ts:83", + "pc": [ + 455 + ] + }, + { + "teal": 434, + "source": "examples/amm/amm.algo.ts:83", + "pc": [ + 456 + ] + }, + { + "teal": 437, + "source": "examples/amm/amm.algo.ts:83", + "errorMessage": "transaction verification failed: {\"txn\":\"this.txn\",\"field\":\"sender\",\"expected\":\"this.governor.value\"}", + "pc": [ + 457 + ] + }, + { + "teal": 441, + "source": "examples/amm/amm.algo.ts:85", + "pc": [ + 458, + 459 + ] + }, + { + "teal": 442, + "source": "examples/amm/amm.algo.ts:85", + "pc": [ + 460, + 461 + ] + }, + { + "teal": 443, + "source": "examples/amm/amm.algo.ts:85", + "pc": [ + 462 + ] + }, + { + "teal": 444, + "source": "examples/amm/amm.algo.ts:85", + "pc": [ + 463 + ] + }, + { + "teal": 449, + "source": "examples/amm/amm.algo.ts:87", + "pc": [ + 464, + 465 + ] + }, + { + "teal": 450, + "source": "examples/amm/amm.algo.ts:87", + "pc": [ + 466, + 467 + ] + }, + { + "teal": 451, + "source": "examples/amm/amm.algo.ts:87", + "pc": [ + 468, + 469 + ] + }, + { + "teal": 452, + "source": "examples/amm/amm.algo.ts:87", + "pc": [ + 470 + ] + }, + { + "teal": 455, + "source": "examples/amm/amm.algo.ts:87", + "errorMessage": "transaction verification failed: {\"txn\":\"seed\",\"field\":\"receiver\",\"expected\":\"this.app.address\"}", + "pc": [ + 471 + ] + }, + { + "teal": 458, + "source": "examples/amm/amm.algo.ts:87", + "pc": [ + 472, + 473 + ] + }, + { + "teal": 459, + "source": "examples/amm/amm.algo.ts:87", + "pc": [ + 474, + 475 + ] + }, + { + "teal": 460, + "source": "examples/amm/amm.algo.ts:87", + "pc": [ + 476, + 477, + 478, + 479 + ] + }, + { + "teal": 461, + "source": "examples/amm/amm.algo.ts:87", + "pc": [ + 480 + ] + }, + { + "teal": 464, + "source": "examples/amm/amm.algo.ts:87", + "errorMessage": "transaction verification failed: {\"txn\":\"seed\",\"field\":\"amount\",\"condition\":\"greaterThanEqualTo\",\"expected\":\">=300_000\"}", + "pc": [ + 481 + ] + }, + { + "teal": 468, + "source": "examples/amm/amm.algo.ts:88", + "pc": [ + 482, + 483 + ] + }, + { + "teal": 469, + "source": "examples/amm/amm.algo.ts:88", + "pc": [ + 484, + 485 + ] + }, + { + "teal": 470, + "source": "examples/amm/amm.algo.ts:88", + "pc": [ + 486 + ] + }, + { + "teal": 471, + "source": "examples/amm/amm.algo.ts:88", + "pc": [ + 487 + ] + }, + { + "teal": 475, + "source": "examples/amm/amm.algo.ts:90", + "pc": [ + 488, + 489, + 490 + ] + }, + { + "teal": 476, + "source": "examples/amm/amm.algo.ts:90", + "pc": [ + 491, + 492 + ] + }, + { + "teal": 477, + "source": "examples/amm/amm.algo.ts:90", + "pc": [ + 493 + ] + }, + { + "teal": 481, + "source": "examples/amm/amm.algo.ts:91", + "pc": [ + 494, + 495, + 496 + ] + }, + { + "teal": 482, + "source": "examples/amm/amm.algo.ts:91", + "pc": [ + 497, + 498 + ] + }, + { + "teal": 483, + "source": "examples/amm/amm.algo.ts:91", + "pc": [ + 499 + ] + }, + { + "teal": 487, + "source": "examples/amm/amm.algo.ts:92", + "pc": [ + 500, + 501, + 502 + ] + }, + { + "teal": 488, + "source": "examples/amm/amm.algo.ts:92", + "pc": [ + 503, + 504 + ] + }, + { + "teal": 489, + "source": "examples/amm/amm.algo.ts:92", + "pc": [ + 505, + 506 + ] + }, + { + "teal": 490, + "source": "examples/amm/amm.algo.ts:92", + "pc": [ + 507, + 508, + 509 + ] + }, + { + "teal": 491, + "source": "examples/amm/amm.algo.ts:92", + "pc": [ + 510 + ] + }, + { + "teal": 495, + "source": "examples/amm/amm.algo.ts:94", + "pc": [ + 511, + 512 + ] + }, + { + "teal": 496, + "source": "examples/amm/amm.algo.ts:94", + "pc": [ + 513, + 514, + 515 + ] + }, + { + "teal": 500, + "source": "examples/amm/amm.algo.ts:95", + "pc": [ + 516, + 517 + ] + }, + { + "teal": 501, + "source": "examples/amm/amm.algo.ts:95", + "pc": [ + 518, + 519, + 520 + ] + }, + { + "teal": 505, + "source": "examples/amm/amm.algo.ts:97", + "pc": [ + 521, + 522, + 523 + ] + }, + { + "teal": 506, + "source": "examples/amm/amm.algo.ts:97", + "pc": [ + 524 + ] + }, + { + "teal": 507, + "source": "examples/amm/amm.algo.ts:82", + "pc": [ + 525 + ] + }, + { + "teal": 512, + "source": "examples/amm/amm.algo.ts:100", + "pc": [ + 526, + 527, + 528 + ] + }, + { + "teal": 513, + "source": "examples/amm/amm.algo.ts:100", + "pc": [ + 529 + ] + }, + { + "teal": 516, + "source": "examples/amm/amm.algo.ts:100", + "pc": [ + 530, + 531, + 532 + ] + }, + { + "teal": 517, + "source": "examples/amm/amm.algo.ts:100", + "pc": [ + 533 + ] + }, + { + "teal": 520, + "source": "examples/amm/amm.algo.ts:100", + "pc": [ + 534, + 535, + 536 + ] + }, + { + "teal": 521, + "source": "examples/amm/amm.algo.ts:100", + "pc": [ + 537 + ] + }, + { + "teal": 524, + "source": "examples/amm/amm.algo.ts:100", + "pc": [ + 538, + 539 + ] + }, + { + "teal": 525, + "source": "examples/amm/amm.algo.ts:100", + "pc": [ + 540, + 541 + ] + }, + { + "teal": 526, + "source": "examples/amm/amm.algo.ts:100", + "pc": [ + 542 + ] + }, + { + "teal": 527, + "source": "examples/amm/amm.algo.ts:100", + "pc": [ + 543 + ] + }, + { + "teal": 528, + "source": "examples/amm/amm.algo.ts:100", + "pc": [ + 544, + 545 + ] + }, + { + "teal": 529, + "source": "examples/amm/amm.algo.ts:100", + "pc": [ + 546, + 547 + ] + }, + { + "teal": 530, + "source": "examples/amm/amm.algo.ts:100", + "pc": [ + 548 + ] + }, + { + "teal": 533, + "source": "examples/amm/amm.algo.ts:100", + "errorMessage": "argument 3 (bXfer) for mint must be a axfer transaction", + "pc": [ + 549 + ] + }, + { + "teal": 536, + "source": "examples/amm/amm.algo.ts:100", + "pc": [ + 550, + 551 + ] + }, + { + "teal": 537, + "source": "examples/amm/amm.algo.ts:100", + "pc": [ + 552, + 553 + ] + }, + { + "teal": 538, + "source": "examples/amm/amm.algo.ts:100", + "pc": [ + 554 + ] + }, + { + "teal": 539, + "source": "examples/amm/amm.algo.ts:100", + "pc": [ + 555 + ] + }, + { + "teal": 540, + "source": "examples/amm/amm.algo.ts:100", + "pc": [ + 556, + 557 + ] + }, + { + "teal": 541, + "source": "examples/amm/amm.algo.ts:100", + "pc": [ + 558, + 559 + ] + }, + { + "teal": 542, + "source": "examples/amm/amm.algo.ts:100", + "pc": [ + 560 + ] + }, + { + "teal": 545, + "source": "examples/amm/amm.algo.ts:100", + "errorMessage": "argument 4 (aXfer) for mint must be a axfer transaction", + "pc": [ + 561 + ] + }, + { + "teal": 548, + "source": "examples/amm/amm.algo.ts:100", + "pc": [ + 562, + 563, + 564 + ] + }, + { + "teal": 549, + "source": "examples/amm/amm.algo.ts:100", + "pc": [ + 565, + 566 + ] + }, + { + "teal": 550, + "source": "examples/amm/amm.algo.ts:100", + "pc": [ + 567 + ] + }, + { + "teal": 554, + "source": "examples/amm/amm.algo.ts:100", + "pc": [ + 568, + 569, + 570 + ] + }, + { + "teal": 557, + "source": "examples/amm/amm.algo.ts:100", + "pc": [ + 571, + 572 + ] + }, + { + "teal": 562, + "source": "examples/amm/amm.algo.ts:102", + "pc": [ + 573, + 574 + ] + }, + { + "teal": 563, + "source": "examples/amm/amm.algo.ts:102", + "pc": [ + 575, + 576, + 577 + ] + }, + { + "teal": 564, + "source": "examples/amm/amm.algo.ts:102", + "pc": [ + 578 + ] + }, + { + "teal": 565, + "source": "examples/amm/amm.algo.ts:102", + "pc": [ + 579 + ] + }, + { + "teal": 566, + "source": "examples/amm/amm.algo.ts:102", + "pc": [ + 580 + ] + }, + { + "teal": 570, + "source": "examples/amm/amm.algo.ts:103", + "pc": [ + 581, + 582 + ] + }, + { + "teal": 571, + "source": "examples/amm/amm.algo.ts:103", + "pc": [ + 583, + 584, + 585 + ] + }, + { + "teal": 572, + "source": "examples/amm/amm.algo.ts:103", + "pc": [ + 586 + ] + }, + { + "teal": 573, + "source": "examples/amm/amm.algo.ts:103", + "pc": [ + 587 + ] + }, + { + "teal": 574, + "source": "examples/amm/amm.algo.ts:103", + "pc": [ + 588 + ] + }, + { + "teal": 578, + "source": "examples/amm/amm.algo.ts:104", + "pc": [ + 589, + 590 + ] + }, + { + "teal": 579, + "source": "examples/amm/amm.algo.ts:104", + "pc": [ + 591, + 592, + 593 + ] + }, + { + "teal": 580, + "source": "examples/amm/amm.algo.ts:104", + "pc": [ + 594 + ] + }, + { + "teal": 581, + "source": "examples/amm/amm.algo.ts:104", + "pc": [ + 595 + ] + }, + { + "teal": 582, + "source": "examples/amm/amm.algo.ts:104", + "pc": [ + 596 + ] + }, + { + "teal": 593, + "source": "examples/amm/amm.algo.ts:107", + "pc": [ + 597, + 598 + ] + }, + { + "teal": 594, + "source": "examples/amm/amm.algo.ts:108", + "pc": [ + 599, + 600 + ] + }, + { + "teal": 595, + "source": "examples/amm/amm.algo.ts:108", + "pc": [ + 601, + 602 + ] + }, + { + "teal": 596, + "source": "examples/amm/amm.algo.ts:108", + "pc": [ + 603 + ] + }, + { + "teal": 599, + "source": "examples/amm/amm.algo.ts:108", + "errorMessage": "transaction verification failed: {\"txn\":\"aXfer\",\"field\":\"sender\",\"expected\":\"this.txn.sender\"}", + "pc": [ + 604 + ] + }, + { + "teal": 602, + "source": "examples/amm/amm.algo.ts:107", + "pc": [ + 605, + 606 + ] + }, + { + "teal": 603, + "source": "examples/amm/amm.algo.ts:109", + "pc": [ + 607, + 608 + ] + }, + { + "teal": 604, + "source": "examples/amm/amm.algo.ts:109", + "pc": [ + 609, + 610 + ] + }, + { + "teal": 605, + "source": "examples/amm/amm.algo.ts:109", + "pc": [ + 611 + ] + }, + { + "teal": 608, + "source": "examples/amm/amm.algo.ts:109", + "errorMessage": "transaction verification failed: {\"txn\":\"aXfer\",\"field\":\"assetAmount\",\"condition\":\"greaterThan\",\"expected\":\">0\"}", + "pc": [ + 612 + ] + }, + { + "teal": 611, + "source": "examples/amm/amm.algo.ts:107", + "pc": [ + 613, + 614 + ] + }, + { + "teal": 612, + "source": "examples/amm/amm.algo.ts:110", + "pc": [ + 615, + 616 + ] + }, + { + "teal": 613, + "source": "examples/amm/amm.algo.ts:110", + "pc": [ + 617, + 618 + ] + }, + { + "teal": 614, + "source": "examples/amm/amm.algo.ts:110", + "pc": [ + 619 + ] + }, + { + "teal": 617, + "source": "examples/amm/amm.algo.ts:110", + "errorMessage": "transaction verification failed: {\"txn\":\"aXfer\",\"field\":\"assetReceiver\",\"expected\":\"this.app.address\"}", + "pc": [ + 620 + ] + }, + { + "teal": 620, + "source": "examples/amm/amm.algo.ts:107", + "pc": [ + 621, + 622 + ] + }, + { + "teal": 621, + "source": "examples/amm/amm.algo.ts:111", + "pc": [ + 623, + 624 + ] + }, + { + "teal": 622, + "source": "examples/amm/amm.algo.ts:111", + "pc": [ + 625, + 626 + ] + }, + { + "teal": 623, + "source": "examples/amm/amm.algo.ts:111", + "pc": [ + 627 + ] + }, + { + "teal": 626, + "source": "examples/amm/amm.algo.ts:111", + "errorMessage": "transaction verification failed: {\"txn\":\"aXfer\",\"field\":\"xferAsset\",\"expected\":\"aAsset\"}", + "pc": [ + 628 + ] + }, + { + "teal": 637, + "source": "examples/amm/amm.algo.ts:115", + "pc": [ + 629, + 630 + ] + }, + { + "teal": 638, + "source": "examples/amm/amm.algo.ts:116", + "pc": [ + 631, + 632 + ] + }, + { + "teal": 639, + "source": "examples/amm/amm.algo.ts:116", + "pc": [ + 633, + 634 + ] + }, + { + "teal": 640, + "source": "examples/amm/amm.algo.ts:116", + "pc": [ + 635 + ] + }, + { + "teal": 643, + "source": "examples/amm/amm.algo.ts:116", + "errorMessage": "transaction verification failed: {\"txn\":\"bXfer\",\"field\":\"sender\",\"expected\":\"this.txn.sender\"}", + "pc": [ + 636 + ] + }, + { + "teal": 646, + "source": "examples/amm/amm.algo.ts:115", + "pc": [ + 637, + 638 + ] + }, + { + "teal": 647, + "source": "examples/amm/amm.algo.ts:117", + "pc": [ + 639, + 640 + ] + }, + { + "teal": 648, + "source": "examples/amm/amm.algo.ts:117", + "pc": [ + 641, + 642 + ] + }, + { + "teal": 649, + "source": "examples/amm/amm.algo.ts:117", + "pc": [ + 643 + ] + }, + { + "teal": 652, + "source": "examples/amm/amm.algo.ts:117", + "errorMessage": "transaction verification failed: {\"txn\":\"bXfer\",\"field\":\"assetAmount\",\"condition\":\"greaterThan\",\"expected\":\">0\"}", + "pc": [ + 644 + ] + }, + { + "teal": 655, + "source": "examples/amm/amm.algo.ts:115", + "pc": [ + 645, + 646 + ] + }, + { + "teal": 656, + "source": "examples/amm/amm.algo.ts:118", + "pc": [ + 647, + 648 + ] + }, + { + "teal": 657, + "source": "examples/amm/amm.algo.ts:118", + "pc": [ + 649, + 650 + ] + }, + { + "teal": 658, + "source": "examples/amm/amm.algo.ts:118", + "pc": [ + 651 + ] + }, + { + "teal": 661, + "source": "examples/amm/amm.algo.ts:118", + "errorMessage": "transaction verification failed: {\"txn\":\"bXfer\",\"field\":\"assetReceiver\",\"expected\":\"this.app.address\"}", + "pc": [ + 652 + ] + }, + { + "teal": 664, + "source": "examples/amm/amm.algo.ts:115", + "pc": [ + 653, + 654 + ] + }, + { + "teal": 665, + "source": "examples/amm/amm.algo.ts:119", + "pc": [ + 655, + 656 + ] + }, + { + "teal": 666, + "source": "examples/amm/amm.algo.ts:119", + "pc": [ + 657, + 658 + ] + }, + { + "teal": 667, + "source": "examples/amm/amm.algo.ts:119", + "pc": [ + 659 + ] + }, + { + "teal": 670, + "source": "examples/amm/amm.algo.ts:119", + "errorMessage": "transaction verification failed: {\"txn\":\"bXfer\",\"field\":\"xferAsset\",\"expected\":\"bAsset\"}", + "pc": [ + 660 + ] + }, + { + "teal": 676, + "source": "examples/amm/amm.algo.ts:123", + "pc": [ + 661, + 662 + ] + }, + { + "teal": 677, + "source": "examples/amm/amm.algo.ts:123", + "pc": [ + 663, + 664 + ] + }, + { + "teal": 678, + "source": "examples/amm/amm.algo.ts:123", + "pc": [ + 665, + 666 + ] + }, + { + "teal": 679, + "source": "examples/amm/amm.algo.ts:123", + "pc": [ + 667 + ] + }, + { + "teal": 680, + "source": "examples/amm/amm.algo.ts:123", + "pc": [ + 668, + 669 + ] + }, + { + "teal": 681, + "source": "examples/amm/amm.algo.ts:123", + "pc": [ + 670, + 671 + ] + }, + { + "teal": 682, + "source": "examples/amm/amm.algo.ts:123", + "pc": [ + 672 + ] + }, + { + "teal": 683, + "source": "examples/amm/amm.algo.ts:123", + "pc": [ + 673 + ] + }, + { + "teal": 684, + "source": "examples/amm/amm.algo.ts:123", + "pc": [ + 674, + 675, + 676 + ] + }, + { + "teal": 685, + "source": "examples/amm/amm.algo.ts:124", + "pc": [ + 677, + 678 + ] + }, + { + "teal": 686, + "source": "examples/amm/amm.algo.ts:124", + "pc": [ + 679, + 680 + ] + }, + { + "teal": 687, + "source": "examples/amm/amm.algo.ts:124", + "pc": [ + 681, + 682 + ] + }, + { + "teal": 688, + "source": "examples/amm/amm.algo.ts:124", + "pc": [ + 683 + ] + }, + { + "teal": 689, + "source": "examples/amm/amm.algo.ts:124", + "pc": [ + 684, + 685 + ] + }, + { + "teal": 690, + "source": "examples/amm/amm.algo.ts:124", + "pc": [ + 686, + 687 + ] + }, + { + "teal": 691, + "source": "examples/amm/amm.algo.ts:124", + "pc": [ + 688 + ] + }, + { + "teal": 692, + "source": "examples/amm/amm.algo.ts:123", + "pc": [ + 689 + ] + }, + { + "teal": 695, + "source": "examples/amm/amm.algo.ts:122", + "pc": [ + 690, + 691, + 692 + ] + }, + { + "teal": 700, + "source": "examples/amm/amm.algo.ts:126", + "pc": [ + 693, + 694 + ] + }, + { + "teal": 701, + "source": "examples/amm/amm.algo.ts:126", + "pc": [ + 695, + 696 + ] + }, + { + "teal": 702, + "source": "examples/amm/amm.algo.ts:126", + "pc": [ + 697, + 698 + ] + }, + { + "teal": 703, + "source": "examples/amm/amm.algo.ts:126", + "pc": [ + 699, + 700 + ] + }, + { + "teal": 704, + "source": "examples/amm/amm.algo.ts:126", + "pc": [ + 701, + 702, + 703 + ] + }, + { + "teal": 705, + "source": "examples/amm/amm.algo.ts:122", + "pc": [ + 704, + 705, + 706 + ] + }, + { + "teal": 716, + "source": "examples/amm/amm.algo.ts:133", + "pc": [ + 707, + 708 + ] + }, + { + "teal": 717, + "source": "examples/amm/amm.algo.ts:133", + "pc": [ + 709, + 710 + ] + }, + { + "teal": 718, + "source": "examples/amm/amm.algo.ts:132", + "pc": [ + 711, + 712 + ] + }, + { + "teal": 719, + "source": "examples/amm/amm.algo.ts:132", + "pc": [ + 713, + 714 + ] + }, + { + "teal": 720, + "source": "examples/amm/amm.algo.ts:131", + "pc": [ + 715, + 716 + ] + }, + { + "teal": 721, + "source": "examples/amm/amm.algo.ts:131", + "pc": [ + 717, + 718 + ] + }, + { + "teal": 722, + "source": "examples/amm/amm.algo.ts:131", + "pc": [ + 719, + 720 + ] + }, + { + "teal": 723, + "source": "examples/amm/amm.algo.ts:131", + "pc": [ + 721 + ] + }, + { + "teal": 724, + "source": "examples/amm/amm.algo.ts:131", + "pc": [ + 722, + 723 + ] + }, + { + "teal": 725, + "source": "examples/amm/amm.algo.ts:131", + "pc": [ + 724, + 725 + ] + }, + { + "teal": 726, + "source": "examples/amm/amm.algo.ts:131", + "pc": [ + 726 + ] + }, + { + "teal": 727, + "source": "examples/amm/amm.algo.ts:130", + "pc": [ + 727, + 728 + ] + }, + { + "teal": 728, + "source": "examples/amm/amm.algo.ts:130", + "pc": [ + 729, + 730 + ] + }, + { + "teal": 729, + "source": "examples/amm/amm.algo.ts:130", + "pc": [ + 731, + 732 + ] + }, + { + "teal": 730, + "source": "examples/amm/amm.algo.ts:130", + "pc": [ + 733 + ] + }, + { + "teal": 731, + "source": "examples/amm/amm.algo.ts:130", + "pc": [ + 734, + 735 + ] + }, + { + "teal": 732, + "source": "examples/amm/amm.algo.ts:130", + "pc": [ + 736, + 737 + ] + }, + { + "teal": 733, + "source": "examples/amm/amm.algo.ts:130", + "pc": [ + 738 + ] + }, + { + "teal": 734, + "source": "examples/amm/amm.algo.ts:129", + "pc": [ + 739, + 740, + 741, + 742, + 743, + 744 + ] + }, + { + "teal": 735, + "source": "examples/amm/amm.algo.ts:129", + "pc": [ + 745, + 746 + ] + }, + { + "teal": 736, + "source": "examples/amm/amm.algo.ts:129", + "pc": [ + 747, + 748 + ] + }, + { + "teal": 737, + "source": "examples/amm/amm.algo.ts:129", + "pc": [ + 749, + 750 + ] + }, + { + "teal": 738, + "source": "examples/amm/amm.algo.ts:129", + "pc": [ + 751 + ] + }, + { + "teal": 739, + "source": "examples/amm/amm.algo.ts:129", + "pc": [ + 752 + ] + }, + { + "teal": 740, + "source": "examples/amm/amm.algo.ts:128", + "pc": [ + 753, + 754, + 755 + ] + }, + { + "teal": 741, + "source": "examples/amm/amm.algo.ts:128", + "pc": [ + 756, + 757 + ] + }, + { + "teal": 745, + "source": "examples/amm/amm.algo.ts:136", + "pc": [ + 758, + 759 + ] + }, + { + "teal": 746, + "source": "examples/amm/amm.algo.ts:136", + "pc": [ + 760, + 761 + ] + }, + { + "teal": 747, + "source": "examples/amm/amm.algo.ts:136", + "pc": [ + 762 + ] + }, + { + "teal": 748, + "source": "examples/amm/amm.algo.ts:136", + "pc": [ + 763 + ] + }, + { + "teal": 752, + "source": "examples/amm/amm.algo.ts:138", + "pc": [ + 764, + 765 + ] + }, + { + "teal": 753, + "source": "examples/amm/amm.algo.ts:138", + "pc": [ + 766, + 767 + ] + }, + { + "teal": 754, + "source": "examples/amm/amm.algo.ts:138", + "pc": [ + 768, + 769 + ] + }, + { + "teal": 755, + "source": "examples/amm/amm.algo.ts:138", + "pc": [ + 770, + 771, + 772 + ] + }, + { + "teal": 758, + "source": "examples/amm/amm.algo.ts:100", + "pc": [ + 773 + ] + }, + { + "teal": 763, + "source": "examples/amm/amm.algo.ts:142", + "pc": [ + 774, + 775, + 776 + ] + }, + { + "teal": 764, + "source": "examples/amm/amm.algo.ts:142", + "pc": [ + 777 + ] + }, + { + "teal": 767, + "source": "examples/amm/amm.algo.ts:142", + "pc": [ + 778, + 779, + 780 + ] + }, + { + "teal": 768, + "source": "examples/amm/amm.algo.ts:142", + "pc": [ + 781 + ] + }, + { + "teal": 771, + "source": "examples/amm/amm.algo.ts:142", + "pc": [ + 782, + 783, + 784 + ] + }, + { + "teal": 772, + "source": "examples/amm/amm.algo.ts:142", + "pc": [ + 785 + ] + }, + { + "teal": 775, + "source": "examples/amm/amm.algo.ts:142", + "pc": [ + 786, + 787 + ] + }, + { + "teal": 776, + "source": "examples/amm/amm.algo.ts:142", + "pc": [ + 788, + 789 + ] + }, + { + "teal": 777, + "source": "examples/amm/amm.algo.ts:142", + "pc": [ + 790 + ] + }, + { + "teal": 778, + "source": "examples/amm/amm.algo.ts:142", + "pc": [ + 791 + ] + }, + { + "teal": 779, + "source": "examples/amm/amm.algo.ts:142", + "pc": [ + 792, + 793 + ] + }, + { + "teal": 780, + "source": "examples/amm/amm.algo.ts:142", + "pc": [ + 794, + 795 + ] + }, + { + "teal": 781, + "source": "examples/amm/amm.algo.ts:142", + "pc": [ + 796 + ] + }, + { + "teal": 784, + "source": "examples/amm/amm.algo.ts:142", + "errorMessage": "argument 3 (poolXfer) for burn must be a axfer transaction", + "pc": [ + 797 + ] + }, + { + "teal": 787, + "source": "examples/amm/amm.algo.ts:142", + "pc": [ + 798, + 799, + 800 + ] + }, + { + "teal": 788, + "source": "examples/amm/amm.algo.ts:142", + "pc": [ + 801, + 802 + ] + }, + { + "teal": 789, + "source": "examples/amm/amm.algo.ts:142", + "pc": [ + 803 + ] + }, + { + "teal": 793, + "source": "examples/amm/amm.algo.ts:142", + "pc": [ + 804, + 805, + 806 + ] + }, + { + "teal": 796, + "source": "examples/amm/amm.algo.ts:142", + "pc": [ + 807, + 808 + ] + }, + { + "teal": 797, + "source": "examples/amm/amm.algo.ts:142", + "pc": [ + 809, + 810 + ] + }, + { + "teal": 802, + "source": "examples/amm/amm.algo.ts:144", + "pc": [ + 811, + 812 + ] + }, + { + "teal": 803, + "source": "examples/amm/amm.algo.ts:144", + "pc": [ + 813, + 814, + 815 + ] + }, + { + "teal": 804, + "source": "examples/amm/amm.algo.ts:144", + "pc": [ + 816 + ] + }, + { + "teal": 805, + "source": "examples/amm/amm.algo.ts:144", + "pc": [ + 817 + ] + }, + { + "teal": 806, + "source": "examples/amm/amm.algo.ts:144", + "pc": [ + 818 + ] + }, + { + "teal": 810, + "source": "examples/amm/amm.algo.ts:145", + "pc": [ + 819, + 820 + ] + }, + { + "teal": 811, + "source": "examples/amm/amm.algo.ts:145", + "pc": [ + 821, + 822, + 823 + ] + }, + { + "teal": 812, + "source": "examples/amm/amm.algo.ts:145", + "pc": [ + 824 + ] + }, + { + "teal": 813, + "source": "examples/amm/amm.algo.ts:145", + "pc": [ + 825 + ] + }, + { + "teal": 814, + "source": "examples/amm/amm.algo.ts:145", + "pc": [ + 826 + ] + }, + { + "teal": 818, + "source": "examples/amm/amm.algo.ts:146", + "pc": [ + 827, + 828 + ] + }, + { + "teal": 819, + "source": "examples/amm/amm.algo.ts:146", + "pc": [ + 829, + 830, + 831 + ] + }, + { + "teal": 820, + "source": "examples/amm/amm.algo.ts:146", + "pc": [ + 832 + ] + }, + { + "teal": 821, + "source": "examples/amm/amm.algo.ts:146", + "pc": [ + 833 + ] + }, + { + "teal": 822, + "source": "examples/amm/amm.algo.ts:146", + "pc": [ + 834 + ] + }, + { + "teal": 833, + "source": "examples/amm/amm.algo.ts:149", + "pc": [ + 835, + 836 + ] + }, + { + "teal": 834, + "source": "examples/amm/amm.algo.ts:150", + "pc": [ + 837, + 838 + ] + }, + { + "teal": 835, + "source": "examples/amm/amm.algo.ts:150", + "pc": [ + 839, + 840 + ] + }, + { + "teal": 836, + "source": "examples/amm/amm.algo.ts:150", + "pc": [ + 841 + ] + }, + { + "teal": 839, + "source": "examples/amm/amm.algo.ts:150", + "errorMessage": "transaction verification failed: {\"txn\":\"poolXfer\",\"field\":\"sender\",\"expected\":\"this.txn.sender\"}", + "pc": [ + 842 + ] + }, + { + "teal": 842, + "source": "examples/amm/amm.algo.ts:149", + "pc": [ + 843, + 844 + ] + }, + { + "teal": 843, + "source": "examples/amm/amm.algo.ts:151", + "pc": [ + 845, + 846 + ] + }, + { + "teal": 844, + "source": "examples/amm/amm.algo.ts:151", + "pc": [ + 847, + 848 + ] + }, + { + "teal": 845, + "source": "examples/amm/amm.algo.ts:151", + "pc": [ + 849 + ] + }, + { + "teal": 848, + "source": "examples/amm/amm.algo.ts:151", + "errorMessage": "transaction verification failed: {\"txn\":\"poolXfer\",\"field\":\"assetAmount\",\"condition\":\"greaterThan\",\"expected\":\">0\"}", + "pc": [ + 850 + ] + }, + { + "teal": 851, + "source": "examples/amm/amm.algo.ts:149", + "pc": [ + 851, + 852 + ] + }, + { + "teal": 852, + "source": "examples/amm/amm.algo.ts:152", + "pc": [ + 853, + 854 + ] + }, + { + "teal": 853, + "source": "examples/amm/amm.algo.ts:152", + "pc": [ + 855, + 856 + ] + }, + { + "teal": 854, + "source": "examples/amm/amm.algo.ts:152", + "pc": [ + 857 + ] + }, + { + "teal": 857, + "source": "examples/amm/amm.algo.ts:152", + "errorMessage": "transaction verification failed: {\"txn\":\"poolXfer\",\"field\":\"assetReceiver\",\"expected\":\"this.app.address\"}", + "pc": [ + 858 + ] + }, + { + "teal": 860, + "source": "examples/amm/amm.algo.ts:149", + "pc": [ + 859, + 860 + ] + }, + { + "teal": 861, + "source": "examples/amm/amm.algo.ts:153", + "pc": [ + 861, + 862 + ] + }, + { + "teal": 862, + "source": "examples/amm/amm.algo.ts:153", + "pc": [ + 863, + 864 + ] + }, + { + "teal": 863, + "source": "examples/amm/amm.algo.ts:153", + "pc": [ + 865 + ] + }, + { + "teal": 866, + "source": "examples/amm/amm.algo.ts:153", + "errorMessage": "transaction verification failed: {\"txn\":\"poolXfer\",\"field\":\"xferAsset\",\"expected\":\"poolAsset\"}", + "pc": [ + 866 + ] + }, + { + "teal": 870, + "source": "examples/amm/amm.algo.ts:156", + "pc": [ + 867, + 868, + 869, + 870, + 871, + 872 + ] + }, + { + "teal": 871, + "source": "examples/amm/amm.algo.ts:156", + "pc": [ + 873, + 874 + ] + }, + { + "teal": 872, + "source": "examples/amm/amm.algo.ts:156", + "pc": [ + 875, + 876 + ] + }, + { + "teal": 873, + "source": "examples/amm/amm.algo.ts:156", + "pc": [ + 877, + 878 + ] + }, + { + "teal": 874, + "source": "examples/amm/amm.algo.ts:156", + "pc": [ + 879 + ] + }, + { + "teal": 875, + "source": "examples/amm/amm.algo.ts:156", + "pc": [ + 880, + 881 + ] + }, + { + "teal": 876, + "source": "examples/amm/amm.algo.ts:156", + "pc": [ + 882, + 883 + ] + }, + { + "teal": 877, + "source": "examples/amm/amm.algo.ts:156", + "pc": [ + 884 + ] + }, + { + "teal": 878, + "source": "examples/amm/amm.algo.ts:156", + "pc": [ + 885 + ] + }, + { + "teal": 879, + "source": "examples/amm/amm.algo.ts:156", + "pc": [ + 886, + 887 + ] + }, + { + "teal": 883, + "source": "examples/amm/amm.algo.ts:158", + "pc": [ + 888, + 889 + ] + }, + { + "teal": 884, + "source": "examples/amm/amm.algo.ts:158", + "pc": [ + 890, + 891 + ] + }, + { + "teal": 885, + "source": "examples/amm/amm.algo.ts:158", + "pc": [ + 892, + 893 + ] + }, + { + "teal": 886, + "source": "examples/amm/amm.algo.ts:158", + "pc": [ + 894, + 895 + ] + }, + { + "teal": 887, + "source": "examples/amm/amm.algo.ts:158", + "pc": [ + 896, + 897 + ] + }, + { + "teal": 888, + "source": "examples/amm/amm.algo.ts:158", + "pc": [ + 898 + ] + }, + { + "teal": 889, + "source": "examples/amm/amm.algo.ts:158", + "pc": [ + 899, + 900 + ] + }, + { + "teal": 890, + "source": "examples/amm/amm.algo.ts:158", + "pc": [ + 901, + 902, + 903 + ] + }, + { + "teal": 891, + "source": "examples/amm/amm.algo.ts:158", + "pc": [ + 904, + 905 + ] + }, + { + "teal": 895, + "source": "examples/amm/amm.algo.ts:160", + "pc": [ + 906, + 907 + ] + }, + { + "teal": 896, + "source": "examples/amm/amm.algo.ts:160", + "pc": [ + 908, + 909 + ] + }, + { + "teal": 897, + "source": "examples/amm/amm.algo.ts:160", + "pc": [ + 910, + 911 + ] + }, + { + "teal": 898, + "source": "examples/amm/amm.algo.ts:160", + "pc": [ + 912, + 913 + ] + }, + { + "teal": 899, + "source": "examples/amm/amm.algo.ts:160", + "pc": [ + 914, + 915 + ] + }, + { + "teal": 900, + "source": "examples/amm/amm.algo.ts:160", + "pc": [ + 916 + ] + }, + { + "teal": 901, + "source": "examples/amm/amm.algo.ts:160", + "pc": [ + 917, + 918 + ] + }, + { + "teal": 902, + "source": "examples/amm/amm.algo.ts:160", + "pc": [ + 919, + 920, + 921 + ] + }, + { + "teal": 903, + "source": "examples/amm/amm.algo.ts:160", + "pc": [ + 922, + 923 + ] + }, + { + "teal": 907, + "source": "examples/amm/amm.algo.ts:162", + "pc": [ + 924, + 925 + ] + }, + { + "teal": 908, + "source": "examples/amm/amm.algo.ts:162", + "pc": [ + 926, + 927 + ] + }, + { + "teal": 909, + "source": "examples/amm/amm.algo.ts:162", + "pc": [ + 928, + 929 + ] + }, + { + "teal": 910, + "source": "examples/amm/amm.algo.ts:162", + "pc": [ + 930, + 931, + 932 + ] + }, + { + "teal": 914, + "source": "examples/amm/amm.algo.ts:163", + "pc": [ + 933, + 934 + ] + }, + { + "teal": 915, + "source": "examples/amm/amm.algo.ts:163", + "pc": [ + 935, + 936 + ] + }, + { + "teal": 916, + "source": "examples/amm/amm.algo.ts:163", + "pc": [ + 937, + 938 + ] }, { + "teal": 917, + "source": "examples/amm/amm.algo.ts:163", "pc": [ - 215 - ], - "errorMessage": "wideRatio failed" + 939, + 940, + 941 + ] }, { + "teal": 921, + "source": "examples/amm/amm.algo.ts:165", "pc": [ - 233 - ], - "errorMessage": "wideRatio failed" + 942, + 943, + 944 + ] }, { + "teal": 922, + "source": "examples/amm/amm.algo.ts:165", "pc": [ - 268 - ], - "errorMessage": "wideRatio failed" + 945, + 946, + 947 + ] }, { + "teal": 923, + "source": "examples/amm/amm.algo.ts:165", "pc": [ - 306 - ], - "errorMessage": "wideRatio failed" + 948 + ] }, { + "teal": 924, + "source": "examples/amm/amm.algo.ts:142", "pc": [ - 325 - ], - "errorMessage": "wideRatio failed" + 949 + ] }, { + "teal": 929, + "source": "examples/amm/amm.algo.ts:168", "pc": [ - 375 - ], - "errorMessage": "wideRatio failed" + 950, + 951, + 952 + ] }, { + "teal": 930, + "source": "examples/amm/amm.algo.ts:168", "pc": [ - 387 - ], - "errorMessage": "argument 0 (governor) for set_governor must be a address" + 953 + ] }, { + "teal": 933, + "source": "examples/amm/amm.algo.ts:168", "pc": [ - 404 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"this.txn\",\"field\":\"sender\",\"expected\":\"this.governor.value\"}" + 954, + 955, + 956 + ] }, { + "teal": 934, + "source": "examples/amm/amm.algo.ts:168", "pc": [ - 437 - ], - "errorMessage": "argument 2 (seed) for bootstrap must be a pay transaction" + 957 + ] }, { + "teal": 937, + "source": "examples/amm/amm.algo.ts:168", "pc": [ - 457 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"this.txn\",\"field\":\"sender\",\"expected\":\"this.governor.value\"}" + 958, + 959 + ] }, { + "teal": 938, + "source": "examples/amm/amm.algo.ts:168", "pc": [ - 471 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"seed\",\"field\":\"receiver\",\"expected\":\"this.app.address\"}" + 960, + 961 + ] }, { + "teal": 939, + "source": "examples/amm/amm.algo.ts:168", "pc": [ - 481 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"seed\",\"field\":\"amount\",\"condition\":\"greaterThanEqualTo\",\"expected\":\">=300_000\"}" + 962 + ] }, { + "teal": 940, + "source": "examples/amm/amm.algo.ts:168", "pc": [ - 549 - ], - "errorMessage": "argument 3 (bXfer) for mint must be a axfer transaction" + 963 + ] }, { + "teal": 941, + "source": "examples/amm/amm.algo.ts:168", "pc": [ - 561 - ], - "errorMessage": "argument 4 (aXfer) for mint must be a axfer transaction" + 964, + 965 + ] }, { + "teal": 942, + "source": "examples/amm/amm.algo.ts:168", "pc": [ - 604 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"aXfer\",\"field\":\"sender\",\"expected\":\"this.txn.sender\"}" + 966, + 967 + ] }, { + "teal": 943, + "source": "examples/amm/amm.algo.ts:168", "pc": [ - 612 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"aXfer\",\"field\":\"assetAmount\",\"condition\":\"greaterThan\",\"expected\":\">0\"}" + 968 + ] }, { + "teal": 946, + "source": "examples/amm/amm.algo.ts:168", + "errorMessage": "argument 2 (swapXfer) for swap must be a axfer transaction", "pc": [ - 620 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"aXfer\",\"field\":\"assetReceiver\",\"expected\":\"this.app.address\"}" + 969 + ] }, { + "teal": 949, + "source": "examples/amm/amm.algo.ts:168", "pc": [ - 628 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"aXfer\",\"field\":\"xferAsset\",\"expected\":\"aAsset\"}" + 970, + 971, + 972 + ] }, { + "teal": 950, + "source": "examples/amm/amm.algo.ts:168", "pc": [ - 636 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"bXfer\",\"field\":\"sender\",\"expected\":\"this.txn.sender\"}" + 973, + 974 + ] }, { + "teal": 951, + "source": "examples/amm/amm.algo.ts:168", "pc": [ - 644 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"bXfer\",\"field\":\"assetAmount\",\"condition\":\"greaterThan\",\"expected\":\">0\"}" + 975 + ] }, { + "teal": 955, + "source": "examples/amm/amm.algo.ts:168", "pc": [ - 652 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"bXfer\",\"field\":\"assetReceiver\",\"expected\":\"this.app.address\"}" + 976, + 977, + 978 + ] }, { + "teal": 958, + "source": "examples/amm/amm.algo.ts:168", "pc": [ - 660 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"bXfer\",\"field\":\"xferAsset\",\"expected\":\"bAsset\"}" + 979, + 980 + ] }, { + "teal": 959, + "source": "examples/amm/amm.algo.ts:168", "pc": [ - 797 - ], - "errorMessage": "argument 3 (poolXfer) for burn must be a axfer transaction" + 981, + 982 + ] }, { + "teal": 964, + "source": "examples/amm/amm.algo.ts:170", "pc": [ - 842 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"poolXfer\",\"field\":\"sender\",\"expected\":\"this.txn.sender\"}" + 983, + 984 + ] }, { + "teal": 965, + "source": "examples/amm/amm.algo.ts:170", "pc": [ - 850 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"poolXfer\",\"field\":\"assetAmount\",\"condition\":\"greaterThan\",\"expected\":\">0\"}" + 985, + 986, + 987 + ] }, { + "teal": 966, + "source": "examples/amm/amm.algo.ts:170", "pc": [ - 858 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"poolXfer\",\"field\":\"assetReceiver\",\"expected\":\"this.app.address\"}" + 988 + ] }, { + "teal": 967, + "source": "examples/amm/amm.algo.ts:170", "pc": [ - 866 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"poolXfer\",\"field\":\"xferAsset\",\"expected\":\"poolAsset\"}" + 989 + ] }, { + "teal": 968, + "source": "examples/amm/amm.algo.ts:170", "pc": [ - 969 - ], - "errorMessage": "argument 2 (swapXfer) for swap must be a axfer transaction" + 990 + ] + }, + { + "teal": 972, + "source": "examples/amm/amm.algo.ts:171", + "pc": [ + 991, + 992 + ] + }, + { + "teal": 973, + "source": "examples/amm/amm.algo.ts:171", + "pc": [ + 993, + 994, + 995 + ] + }, + { + "teal": 974, + "source": "examples/amm/amm.algo.ts:171", + "pc": [ + 996 + ] + }, + { + "teal": 975, + "source": "examples/amm/amm.algo.ts:171", + "pc": [ + 997 + ] + }, + { + "teal": 976, + "source": "examples/amm/amm.algo.ts:171", + "pc": [ + 998 + ] + }, + { + "teal": 986, + "source": "examples/amm/amm.algo.ts:173", + "pc": [ + 999, + 1000 + ] + }, + { + "teal": 987, + "source": "examples/amm/amm.algo.ts:174", + "pc": [ + 1001, + 1002 + ] + }, + { + "teal": 988, + "source": "examples/amm/amm.algo.ts:174", + "pc": [ + 1003, + 1004 + ] + }, + { + "teal": 989, + "source": "examples/amm/amm.algo.ts:174", + "pc": [ + 1005 + ] }, { + "teal": 992, + "source": "examples/amm/amm.algo.ts:174", + "errorMessage": "transaction verification failed: {\"txn\":\"swapXfer\",\"field\":\"assetAmount\",\"condition\":\"greaterThan\",\"expected\":\">0\"}", "pc": [ 1006 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"swapXfer\",\"field\":\"assetAmount\",\"condition\":\"greaterThan\",\"expected\":\">0\"}" + ] + }, + { + "teal": 995, + "source": "examples/amm/amm.algo.ts:173", + "pc": [ + 1007, + 1008 + ] + }, + { + "teal": 996, + "source": "examples/amm/amm.algo.ts:175", + "pc": [ + 1009, + 1010 + ] }, { + "teal": 997, + "source": "examples/amm/amm.algo.ts:175", + "pc": [ + 1011, + 1012 + ] + }, + { + "teal": 998, + "source": "examples/amm/amm.algo.ts:175", + "pc": [ + 1013 + ] + }, + { + "teal": 1001, + "source": "examples/amm/amm.algo.ts:175", + "errorMessage": "transaction verification failed: {\"txn\":\"swapXfer\",\"field\":\"assetReceiver\",\"expected\":\"this.app.address\"}", "pc": [ 1014 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"swapXfer\",\"field\":\"assetReceiver\",\"expected\":\"this.app.address\"}" + ] + }, + { + "teal": 1004, + "source": "examples/amm/amm.algo.ts:173", + "pc": [ + 1015, + 1016 + ] + }, + { + "teal": 1005, + "source": "examples/amm/amm.algo.ts:176", + "pc": [ + 1017, + 1018 + ] + }, + { + "teal": 1006, + "source": "examples/amm/amm.algo.ts:176", + "pc": [ + 1019, + 1020 + ] + }, + { + "teal": 1007, + "source": "examples/amm/amm.algo.ts:176", + "pc": [ + 1021 + ] }, { + "teal": 1010, + "source": "examples/amm/amm.algo.ts:176", + "errorMessage": "transaction verification failed: {\"txn\":\"swapXfer\",\"field\":\"sender\",\"expected\":\"this.txn.sender\"}", "pc": [ 1022 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"swapXfer\",\"field\":\"sender\",\"expected\":\"this.txn.sender\"}" + ] + }, + { + "teal": 1013, + "source": "examples/amm/amm.algo.ts:173", + "pc": [ + 1023, + 1024 + ] + }, + { + "teal": 1014, + "source": "examples/amm/amm.algo.ts:177", + "pc": [ + 1025, + 1026 + ] + }, + { + "teal": 1015, + "source": "examples/amm/amm.algo.ts:177", + "pc": [ + 1027, + 1028 + ] + }, + { + "teal": 1016, + "source": "examples/amm/amm.algo.ts:177", + "pc": [ + 1029 + ] + }, + { + "teal": 1017, + "source": "examples/amm/amm.algo.ts:173", + "pc": [ + 1030, + 1031 + ] + }, + { + "teal": 1018, + "source": "examples/amm/amm.algo.ts:177", + "pc": [ + 1032, + 1033 + ] + }, + { + "teal": 1019, + "source": "examples/amm/amm.algo.ts:177", + "pc": [ + 1034, + 1035 + ] + }, + { + "teal": 1020, + "source": "examples/amm/amm.algo.ts:177", + "pc": [ + 1036 + ] + }, + { + "teal": 1021, + "source": "examples/amm/amm.algo.ts:177", + "pc": [ + 1037 + ] }, { + "teal": 1024, + "source": "examples/amm/amm.algo.ts:177", + "errorMessage": "transaction verification failed: {\"txn\":{\"txnText\":\"swapXfer\"},\"field\":\"xferAsset\",\"condition\":\"includedIn\",\"expected\":\"[aAsset, bAsset]\"}", "pc": [ 1038 - ], - "errorMessage": "transaction verification failed: {\"txn\":{\"txnText\":\"swapXfer\"},\"field\":\"xferAsset\",\"condition\":\"includedIn\",\"expected\":\"[aAsset, bAsset]\"}" + ] + }, + { + "teal": 1028, + "source": "examples/amm/amm.algo.ts:180", + "pc": [ + 1039, + 1040 + ] + }, + { + "teal": 1029, + "source": "examples/amm/amm.algo.ts:180", + "pc": [ + 1041, + 1042 + ] + }, + { + "teal": 1030, + "source": "examples/amm/amm.algo.ts:180", + "pc": [ + 1043, + 1044 + ] + }, + { + "teal": 1031, + "source": "examples/amm/amm.algo.ts:180", + "pc": [ + 1045 + ] + }, + { + "teal": 1032, + "source": "examples/amm/amm.algo.ts:180", + "pc": [ + 1046, + 1047, + 1048 + ] + }, + { + "teal": 1033, + "source": "examples/amm/amm.algo.ts:180", + "pc": [ + 1049, + 1050 + ] + }, + { + "teal": 1034, + "source": "examples/amm/amm.algo.ts:180", + "pc": [ + 1051, + 1052, + 1053 + ] + }, + { + "teal": 1037, + "source": "examples/amm/amm.algo.ts:180", + "pc": [ + 1054, + 1055 + ] + }, + { + "teal": 1040, + "source": "examples/amm/amm.algo.ts:180", + "pc": [ + 1056, + 1057 + ] + }, + { + "teal": 1044, + "source": "examples/amm/amm.algo.ts:182", + "pc": [ + 1058, + 1059 + ] + }, + { + "teal": 1045, + "source": "examples/amm/amm.algo.ts:182", + "pc": [ + 1060, + 1061 + ] + }, + { + "teal": 1046, + "source": "examples/amm/amm.algo.ts:182", + "pc": [ + 1062, + 1063 + ] + }, + { + "teal": 1054, + "source": "examples/amm/amm.algo.ts:187", + "pc": [ + 1064, + 1065 + ] + }, + { + "teal": 1055, + "source": "examples/amm/amm.algo.ts:187", + "pc": [ + 1066, + 1067 + ] + }, + { + "teal": 1056, + "source": "examples/amm/amm.algo.ts:187", + "pc": [ + 1068, + 1069 + ] + }, + { + "teal": 1057, + "source": "examples/amm/amm.algo.ts:187", + "pc": [ + 1070 + ] + }, + { + "teal": 1058, + "source": "examples/amm/amm.algo.ts:186", + "pc": [ + 1071, + 1072 + ] + }, + { + "teal": 1059, + "source": "examples/amm/amm.algo.ts:186", + "pc": [ + 1073, + 1074 + ] + }, + { + "teal": 1060, + "source": "examples/amm/amm.algo.ts:186", + "pc": [ + 1075, + 1076 + ] + }, + { + "teal": 1061, + "source": "examples/amm/amm.algo.ts:186", + "pc": [ + 1077 + ] + }, + { + "teal": 1062, + "source": "examples/amm/amm.algo.ts:186", + "pc": [ + 1078, + 1079 + ] + }, + { + "teal": 1063, + "source": "examples/amm/amm.algo.ts:186", + "pc": [ + 1080, + 1081 + ] + }, + { + "teal": 1064, + "source": "examples/amm/amm.algo.ts:186", + "pc": [ + 1082 + ] + }, + { + "teal": 1065, + "source": "examples/amm/amm.algo.ts:185", + "pc": [ + 1083, + 1084 + ] + }, + { + "teal": 1066, + "source": "examples/amm/amm.algo.ts:185", + "pc": [ + 1085, + 1086 + ] + }, + { + "teal": 1067, + "source": "examples/amm/amm.algo.ts:184", + "pc": [ + 1087, + 1088, + 1089 + ] + }, + { + "teal": 1068, + "source": "examples/amm/amm.algo.ts:184", + "pc": [ + 1090, + 1091 + ] + }, + { + "teal": 1072, + "source": "examples/amm/amm.algo.ts:190", + "pc": [ + 1092, + 1093 + ] + }, + { + "teal": 1073, + "source": "examples/amm/amm.algo.ts:190", + "pc": [ + 1094, + 1095 + ] + }, + { + "teal": 1074, + "source": "examples/amm/amm.algo.ts:190", + "pc": [ + 1096 + ] + }, + { + "teal": 1075, + "source": "examples/amm/amm.algo.ts:190", + "pc": [ + 1097 + ] + }, + { + "teal": 1079, + "source": "examples/amm/amm.algo.ts:192", + "pc": [ + 1098, + 1099 + ] + }, + { + "teal": 1080, + "source": "examples/amm/amm.algo.ts:192", + "pc": [ + 1100, + 1101 + ] + }, + { + "teal": 1081, + "source": "examples/amm/amm.algo.ts:192", + "pc": [ + 1102, + 1103 + ] + }, + { + "teal": 1082, + "source": "examples/amm/amm.algo.ts:192", + "pc": [ + 1104, + 1105, + 1106 + ] + }, + { + "teal": 1086, + "source": "examples/amm/amm.algo.ts:194", + "pc": [ + 1107, + 1108, + 1109 + ] + }, + { + "teal": 1087, + "source": "examples/amm/amm.algo.ts:194", + "pc": [ + 1110, + 1111, + 1112 + ] + }, + { + "teal": 1088, + "source": "examples/amm/amm.algo.ts:194", + "pc": [ + 1113 + ] + }, + { + "teal": 1089, + "source": "examples/amm/amm.algo.ts:168", + "pc": [ + 1114 + ] + }, + { + "teal": 1092, + "source": "examples/amm/amm.algo.ts:8", + "pc": [ + 1115, + 1116, + 1117, + 1118, + 1119, + 1120 + ] + }, + { + "teal": 1093, + "source": "examples/amm/amm.algo.ts:8", + "pc": [ + 1121, + 1122, + 1123 + ] }, { + "teal": 1094, + "source": "examples/amm/amm.algo.ts:8", + "pc": [ + 1124, + 1125, + 1126, + 1127 + ] + }, + { + "teal": 1097, + "source": "examples/amm/amm.algo.ts:8", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 1128 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 1100, + "source": "examples/amm/amm.algo.ts:8", + "pc": [ + 1129, + 1130, + 1131, + 1132, + 1133, + 1134 + ] + }, + { + "teal": 1101, + "source": "examples/amm/amm.algo.ts:8", + "pc": [ + 1135, + 1136, + 1137, + 1138, + 1139, + 1140 + ] + }, + { + "teal": 1102, + "source": "examples/amm/amm.algo.ts:8", + "pc": [ + 1141, + 1142, + 1143, + 1144, + 1145, + 1146 + ] + }, + { + "teal": 1103, + "source": "examples/amm/amm.algo.ts:8", + "pc": [ + 1147, + 1148, + 1149, + 1150, + 1151, + 1152 + ] + }, + { + "teal": 1104, + "source": "examples/amm/amm.algo.ts:8", + "pc": [ + 1153, + 1154, + 1155, + 1156, + 1157, + 1158 + ] + }, + { + "teal": 1105, + "source": "examples/amm/amm.algo.ts:8", + "pc": [ + 1159, + 1160, + 1161 + ] + }, + { + "teal": 1106, + "source": "examples/amm/amm.algo.ts:8", + "pc": [ + 1162, + 1163, + 1164, + 1165, + 1166, + 1167, + 1168, + 1169, + 1170, + 1171, + 1172, + 1173 + ] }, { + "teal": 1109, + "source": "examples/amm/amm.algo.ts:8", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 1174 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/examples/arc58/artifacts/AbstractedAccount.arc56_draft.json b/examples/arc58/artifacts/AbstractedAccount.arc56_draft.json index 2338659f8..93557b5cd 100644 --- a/examples/arc58/artifacts/AbstractedAccount.arc56_draft.json +++ b/examples/arc58/artifacts/AbstractedAccount.arc56_draft.json @@ -386,196 +386,4919 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "examples/arc58/arc58.algo.ts:21", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "examples/arc58/arc58.algo.ts:21", + "pc": [ + 1, + 2, + 3, + 4, + 5 + ] + }, + { + "teal": 3, + "source": "examples/arc58/arc58.algo.ts:21", + "pc": [ + 6, + 7, + 8, + 9, + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32 + ] + }, + { + "teal": 15, + "source": "examples/arc58/arc58.algo.ts:21", + "pc": [ + 33, + 34 + ] + }, + { + "teal": 16, + "source": "examples/arc58/arc58.algo.ts:21", + "pc": [ + 35 + ] + }, + { + "teal": 17, + "source": "examples/arc58/arc58.algo.ts:21", + "pc": [ + 36, + 37 + ] + }, + { + "teal": 18, + "source": "examples/arc58/arc58.algo.ts:21", + "pc": [ + 38 + ] + }, + { + "teal": 19, + "source": "examples/arc58/arc58.algo.ts:21", + "pc": [ + 39, + 40 + ] + }, + { + "teal": 20, + "source": "examples/arc58/arc58.algo.ts:21", + "pc": [ + 41 + ] + }, + { + "teal": 21, + "source": "examples/arc58/arc58.algo.ts:21", + "pc": [ + 42, + 43, + 44, + 45, + 46, + 47, + 48, + 49, + 50, + 51, + 52, + 53, + 54, + 55, + 56, + 57, + 58, + 59, + 60, + 61, + 62, + 63, + 64, + 65, + 66, + 67 + ] + }, + { + "teal": 25, + "source": "examples/arc58/arc58.algo.ts:21", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 68 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 31, + "source": "examples/arc58/arc58.algo.ts:44", + "pc": [ + 69, + 70, + 71 + ] + }, + { + "teal": 34, + "source": "examples/arc58/arc58.algo.ts:44", + "pc": [ + 72, + 73 + ] + }, + { + "teal": 35, + "source": "examples/arc58/arc58.algo.ts:44", + "pc": [ + 74, + 75 + ] + }, + { + "teal": 39, + "source": "examples/arc58/arc58.algo.ts:45", + "pc": [ + 76, + 77 + ] + }, + { + "teal": 40, + "source": "examples/arc58/arc58.algo.ts:45", + "pc": [ + 78, + 79 + ] + }, + { + "teal": 44, + "source": "examples/arc58/arc58.algo.ts:47", + "pc": [ + 80, + 81 + ] + }, + { + "teal": 45, + "source": "examples/arc58/arc58.algo.ts:47", + "pc": [ + 82, + 83 + ] + }, + { + "teal": 50, + "source": "examples/arc58/arc58.algo.ts:47", + "pc": [ + 84, + 85 + ] + }, + { + "teal": 51, + "source": "examples/arc58/arc58.algo.ts:47", + "pc": [ + 86, + 87 + ] + }, + { + "teal": 52, + "source": "examples/arc58/arc58.algo.ts:47", + "pc": [ + 88 + ] + }, + { + "teal": 53, + "source": "examples/arc58/arc58.algo.ts:47", + "pc": [ + 89, + 90, + 91 + ] + }, + { + "teal": 57, + "source": "examples/arc58/arc58.algo.ts:48", + "pc": [ + 92, + 93 + ] + }, + { + "teal": 58, + "source": "examples/arc58/arc58.algo.ts:48", + "pc": [ + 94, + 95 + ] + }, + { + "teal": 63, + "source": "examples/arc58/arc58.algo.ts:51", + "pc": [ + 96, + 97 + ] + }, + { + "teal": 64, + "source": "examples/arc58/arc58.algo.ts:51", + "pc": [ + 98, + 99 + ] + }, + { + "teal": 65, + "source": "examples/arc58/arc58.algo.ts:51", + "pc": [ + 100, + 101, + 102 + ] + }, + { + "teal": 66, + "source": "examples/arc58/arc58.algo.ts:51", + "pc": [ + 103 + ] + }, + { + "teal": 67, + "source": "examples/arc58/arc58.algo.ts:51", + "pc": [ + 104 + ] + }, + { + "teal": 68, + "source": "examples/arc58/arc58.algo.ts:51", + "pc": [ + 105 + ] + }, + { + "teal": 69, + "source": "examples/arc58/arc58.algo.ts:51", + "pc": [ + 106, + 107, + 108 + ] + }, + { + "teal": 70, + "source": "examples/arc58/arc58.algo.ts:51", + "pc": [ + 109, + 110 + ] + }, + { + "teal": 71, + "source": "examples/arc58/arc58.algo.ts:51", + "pc": [ + 111, + 112 + ] + }, + { + "teal": 72, + "source": "examples/arc58/arc58.algo.ts:51", + "pc": [ + 113, + 114, + 115 + ] + }, + { + "teal": 73, + "source": "examples/arc58/arc58.algo.ts:51", + "pc": [ + 116 + ] + }, + { + "teal": 74, + "source": "examples/arc58/arc58.algo.ts:51", + "pc": [ + 117 + ] + }, + { + "teal": 75, + "source": "examples/arc58/arc58.algo.ts:51", + "pc": [ + 118 + ] + }, + { + "teal": 78, + "source": "examples/arc58/arc58.algo.ts:51", + "pc": [ + 119, + 120, + 121 + ] + }, + { + "teal": 83, + "source": "examples/arc58/arc58.algo.ts:52", + "pc": [ + 122, + 123 + ] + }, + { + "teal": 84, + "source": "examples/arc58/arc58.algo.ts:52", + "pc": [ + 124, + 125 + ] + }, + { + "teal": 85, + "source": "examples/arc58/arc58.algo.ts:53", + "pc": [ + 126, + 127, + 128 + ] + }, + { + "teal": 94, + "source": "examples/arc58/arc58.algo.ts:58", + "pc": [ + 129, + 130 + ] + }, + { + "teal": 95, + "source": "examples/arc58/arc58.algo.ts:58", + "pc": [ + 131, + 132 + ] + }, + { + "teal": 96, + "source": "examples/arc58/arc58.algo.ts:58", + "pc": [ + 133, + 134 + ] + }, + { + "teal": 97, + "source": "examples/arc58/arc58.algo.ts:58", + "pc": [ + 135 + ] + }, + { + "teal": 98, + "source": "examples/arc58/arc58.algo.ts:58", + "pc": [ + 136 + ] + }, + { + "teal": 99, + "source": "examples/arc58/arc58.algo.ts:58", + "pc": [ + 137, + 138, + 139 + ] + }, + { + "teal": 100, + "source": "examples/arc58/arc58.algo.ts:59", + "pc": [ + 140, + 141 + ] + }, + { + "teal": 101, + "source": "examples/arc58/arc58.algo.ts:59", + "pc": [ + 142, + 143 + ] + }, + { + "teal": 102, + "source": "examples/arc58/arc58.algo.ts:59", + "pc": [ + 144, + 145, + 146 + ] + }, + { + "teal": 103, + "source": "examples/arc58/arc58.algo.ts:59", + "pc": [ + 147 + ] + }, + { + "teal": 104, + "source": "examples/arc58/arc58.algo.ts:58", + "pc": [ + 148 + ] + }, + { + "teal": 107, + "source": "examples/arc58/arc58.algo.ts:59", + "pc": [ + 149 + ] + }, + { + "teal": 108, + "source": "examples/arc58/arc58.algo.ts:59", + "pc": [ + 150, + 151, + 152 + ] + }, + { + "teal": 109, + "source": "examples/arc58/arc58.algo.ts:60", + "pc": [ + 153, + 154 + ] + }, + { + "teal": 110, + "source": "examples/arc58/arc58.algo.ts:60", + "pc": [ + 155, + 156 + ] + }, + { + "teal": 111, + "source": "examples/arc58/arc58.algo.ts:60", + "pc": [ + 157, + 158 + ] + }, + { + "teal": 112, + "source": "examples/arc58/arc58.algo.ts:60", + "pc": [ + 159 + ] + }, + { + "teal": 113, + "source": "examples/arc58/arc58.algo.ts:59", + "pc": [ + 160 + ] + }, + { + "teal": 116, + "source": "examples/arc58/arc58.algo.ts:60", + "pc": [ + 161 + ] + }, + { + "teal": 117, + "source": "examples/arc58/arc58.algo.ts:60", + "pc": [ + 162, + 163, + 164 + ] + }, + { + "teal": 118, + "source": "examples/arc58/arc58.algo.ts:61", + "pc": [ + 165, + 166 + ] + }, + { + "teal": 119, + "source": "examples/arc58/arc58.algo.ts:61", + "pc": [ + 167, + 168, + 169 + ] + }, + { + "teal": 120, + "source": "examples/arc58/arc58.algo.ts:61", + "pc": [ + 170, + 171, + 172, + 173, + 174, + 175 + ] + }, + { + "teal": 121, + "source": "examples/arc58/arc58.algo.ts:61", + "pc": [ + 176 + ] + }, + { + "teal": 122, + "source": "examples/arc58/arc58.algo.ts:60", + "pc": [ + 177 + ] + }, + { + "teal": 125, + "source": "examples/arc58/arc58.algo.ts:57", + "pc": [ + 178, + 179, + 180 + ] + }, + { + "teal": 130, + "source": "examples/arc58/arc58.algo.ts:63", + "pc": [ + 181, + 182 + ] + }, + { + "teal": 131, + "source": "examples/arc58/arc58.algo.ts:63", + "pc": [ + 183, + 184 + ] + }, + { + "teal": 132, + "source": "examples/arc58/arc58.algo.ts:64", + "pc": [ + 185, + 186, + 187 + ] + }, + { + "teal": 139, + "source": "examples/arc58/arc58.algo.ts:47", + "pc": [ + 188, + 189 + ] + }, + { + "teal": 140, + "source": "examples/arc58/arc58.algo.ts:47", + "pc": [ + 190, + 191 + ] + }, + { + "teal": 141, + "source": "examples/arc58/arc58.algo.ts:47", + "pc": [ + 192 + ] + }, + { + "teal": 142, + "source": "examples/arc58/arc58.algo.ts:47", + "pc": [ + 193, + 194 + ] + }, + { + "teal": 143, + "source": "examples/arc58/arc58.algo.ts:47", + "pc": [ + 195, + 196, + 197 + ] + }, + { + "teal": 148, + "source": "examples/arc58/arc58.algo.ts:68", + "pc": [ + 198, + 199 + ] + }, + { + "teal": 149, + "source": "examples/arc58/arc58.algo.ts:68", + "pc": [ + 200 + ] + }, + { + "teal": 150, + "source": "examples/arc58/arc58.algo.ts:44", + "pc": [ + 201 + ] + }, + { + "teal": 157, + "source": "examples/arc58/arc58.algo.ts:75", + "pc": [ + 202, + 203, + 204 + ] + }, + { + "teal": 161, + "source": "examples/arc58/arc58.algo.ts:76", + "pc": [ + 205, + 206, + 207 + ] + }, + { + "teal": 162, + "source": "examples/arc58/arc58.algo.ts:76", + "pc": [ + 208 + ] + }, + { + "teal": 163, + "source": "examples/arc58/arc58.algo.ts:76", + "pc": [ + 209, + 210 + ] + }, + { + "teal": 164, + "source": "examples/arc58/arc58.algo.ts:76", + "pc": [ + 211 + ] + }, + { + "teal": 165, + "source": "examples/arc58/arc58.algo.ts:76", + "pc": [ + 212, + 213, + 214 + ] + }, + { + "teal": 166, + "source": "examples/arc58/arc58.algo.ts:76", + "pc": [ + 215, + 216 + ] + }, + { + "teal": 167, + "source": "examples/arc58/arc58.algo.ts:76", + "pc": [ + 217, + 218, + 219 + ] + }, + { + "teal": 170, + "source": "examples/arc58/arc58.algo.ts:76", + "pc": [ + 220, + 221 + ] + }, + { + "teal": 173, + "source": "examples/arc58/arc58.algo.ts:75", + "pc": [ + 222 + ] + }, + { + "teal": 178, + "source": "examples/arc58/arc58.algo.ts:86", + "pc": [ + 223, + 224, + 225 + ] + }, + { + "teal": 179, + "source": "examples/arc58/arc58.algo.ts:86", + "pc": [ + 226 + ] + }, + { + "teal": 180, + "source": "examples/arc58/arc58.algo.ts:86", + "pc": [ + 227 + ] + }, + { + "teal": 181, + "source": "examples/arc58/arc58.algo.ts:86", + "pc": [ + 228, + 229 + ] + }, + { + "teal": 182, + "source": "examples/arc58/arc58.algo.ts:86", + "pc": [ + 230 + ] + }, + { + "teal": 185, + "source": "examples/arc58/arc58.algo.ts:86", + "errorMessage": "argument 0 (admin) for createApplication must be a address", + "pc": [ + 231 + ] + }, + { + "teal": 188, + "source": "examples/arc58/arc58.algo.ts:86", + "pc": [ + 232, + 233, + 234 + ] + }, + { + "teal": 189, + "source": "examples/arc58/arc58.algo.ts:86", + "pc": [ + 235 + ] + }, + { + "teal": 190, + "source": "examples/arc58/arc58.algo.ts:86", + "pc": [ + 236 + ] + }, + { + "teal": 191, + "source": "examples/arc58/arc58.algo.ts:86", + "pc": [ + 237, + 238 + ] + }, + { + "teal": 192, + "source": "examples/arc58/arc58.algo.ts:86", + "pc": [ + 239 + ] + }, + { + "teal": 195, + "source": "examples/arc58/arc58.algo.ts:86", + "errorMessage": "argument 1 (controlledAddress) for createApplication must be a address", + "pc": [ + 240 + ] + }, + { + "teal": 198, + "source": "examples/arc58/arc58.algo.ts:86", + "pc": [ + 241, + 242, + 243 + ] + }, + { + "teal": 199, + "source": "examples/arc58/arc58.algo.ts:86", + "pc": [ + 244, + 245 + ] + }, + { + "teal": 200, + "source": "examples/arc58/arc58.algo.ts:86", + "pc": [ + 246 + ] + }, + { + "teal": 210, + "source": "examples/arc58/arc58.algo.ts:86", + "pc": [ + 247, + 248, + 249 + ] + }, + { + "teal": 217, + "source": "examples/arc58/arc58.algo.ts:88", + "pc": [ + 250, + 251 + ] + }, + { + "teal": 218, + "source": "examples/arc58/arc58.algo.ts:88", + "pc": [ + 252, + 253 + ] + }, + { + "teal": 219, + "source": "examples/arc58/arc58.algo.ts:88", + "pc": [ + 254 + ] + }, + { + "teal": 220, + "source": "examples/arc58/arc58.algo.ts:88", + "pc": [ + 255, + 256 + ] + }, + { + "teal": 221, + "source": "examples/arc58/arc58.algo.ts:88", + "pc": [ + 257, + 258 + ] + }, + { + "teal": 222, + "source": "examples/arc58/arc58.algo.ts:88", + "pc": [ + 259 + ] + }, + { + "teal": 223, + "source": "examples/arc58/arc58.algo.ts:88", + "pc": [ + 260 + ] + }, + { + "teal": 226, + "source": "examples/arc58/arc58.algo.ts:88", + "errorMessage": "transaction verification failed: {\"txn\":{\"txnText\":\"this.txn\"},\"field\":\"sender\",\"condition\":\"includedIn\",\"expected\":\"[controlledAddress, admin]\"}", + "pc": [ + 261 + ] + }, + { + "teal": 230, + "source": "examples/arc58/arc58.algo.ts:91", + "pc": [ + 262, + 263 + ] + }, + { + "teal": 231, + "source": "examples/arc58/arc58.algo.ts:91", + "pc": [ + 264, + 265 + ] + }, + { + "teal": 232, + "source": "examples/arc58/arc58.algo.ts:91", + "pc": [ + 266 + ] + }, + { + "teal": 233, + "source": "examples/arc58/arc58.algo.ts:91", + "pc": [ + 267 + ] + }, + { + "teal": 237, + "source": "examples/arc58/arc58.algo.ts:93", + "pc": [ + 268, + 269, + 270 + ] + }, + { + "teal": 238, + "source": "examples/arc58/arc58.algo.ts:93", + "pc": [ + 271, + 272 + ] + }, + { + "teal": 239, + "source": "examples/arc58/arc58.algo.ts:93", + "pc": [ + 273 + ] + }, + { + "teal": 243, + "source": "examples/arc58/arc58.algo.ts:94", + "pc": [ + 274, + 275, + 276 + ] + }, + { + "teal": 244, + "source": "examples/arc58/arc58.algo.ts:94", + "pc": [ + 277, + 278 + ] + }, + { + "teal": 245, + "source": "examples/arc58/arc58.algo.ts:94", + "pc": [ + 279, + 280 + ] + }, + { + "teal": 246, + "source": "examples/arc58/arc58.algo.ts:94", + "pc": [ + 281 + ] + }, + { + "teal": 247, + "source": "examples/arc58/arc58.algo.ts:94", + "pc": [ + 282, + 283, + 284 + ] + }, + { + "teal": 248, + "source": "examples/arc58/arc58.algo.ts:94", + "pc": [ + 285, + 286 + ] + }, + { + "teal": 249, + "source": "examples/arc58/arc58.algo.ts:94", + "pc": [ + 287, + 288, + 289 + ] + }, + { + "teal": 252, + "source": "examples/arc58/arc58.algo.ts:94", + "pc": [ + 290, + 291 + ] + }, + { + "teal": 255, + "source": "examples/arc58/arc58.algo.ts:94", + "pc": [ + 292 + ] + }, + { + "teal": 256, + "source": "examples/arc58/arc58.algo.ts:86", + "pc": [ + 293 + ] + }, + { + "teal": 261, + "source": "examples/arc58/arc58.algo.ts:102", + "pc": [ + 294, + 295, + 296 + ] + }, + { + "teal": 262, + "source": "examples/arc58/arc58.algo.ts:102", + "pc": [ + 297 + ] + }, + { + "teal": 263, + "source": "examples/arc58/arc58.algo.ts:102", + "pc": [ + 298 + ] + }, + { + "teal": 264, + "source": "examples/arc58/arc58.algo.ts:102", + "pc": [ + 299, + 300 + ] + }, + { + "teal": 265, + "source": "examples/arc58/arc58.algo.ts:102", + "pc": [ + 301 + ] + }, + { + "teal": 268, + "source": "examples/arc58/arc58.algo.ts:102", + "errorMessage": "argument 0 (newAdmin) for arc58_changeAdmin must be a address", + "pc": [ + 302 + ] + }, + { + "teal": 271, + "source": "examples/arc58/arc58.algo.ts:102", + "pc": [ + 303, + 304, + 305 + ] + }, + { + "teal": 272, + "source": "examples/arc58/arc58.algo.ts:102", + "pc": [ + 306, + 307 + ] + }, + { + "teal": 273, + "source": "examples/arc58/arc58.algo.ts:102", + "pc": [ + 308 + ] + }, + { + "teal": 281, + "source": "examples/arc58/arc58.algo.ts:102", + "pc": [ + 309, + 310, + 311 + ] + }, + { + "teal": 286, + "source": "examples/arc58/arc58.algo.ts:103", + "pc": [ + 312, + 313 + ] + }, + { + "teal": 287, + "source": "examples/arc58/arc58.algo.ts:103", + "pc": [ + 314, + 315, + 316 + ] + }, + { + "teal": 288, + "source": "examples/arc58/arc58.algo.ts:103", + "pc": [ + 317 + ] + }, + { + "teal": 289, + "source": "examples/arc58/arc58.algo.ts:103", + "pc": [ + 318 + ] + }, + { + "teal": 292, + "source": "examples/arc58/arc58.algo.ts:103", + "errorMessage": "transaction verification failed: {\"txn\":\"this.txn\",\"field\":\"sender\",\"expected\":\"this.admin.value\"}", + "pc": [ + 319 + ] + }, + { + "teal": 296, + "source": "examples/arc58/arc58.algo.ts:104", + "pc": [ + 320, + 321, + 322 + ] + }, + { + "teal": 297, + "source": "examples/arc58/arc58.algo.ts:104", + "pc": [ + 323, + 324 + ] + }, + { + "teal": 298, + "source": "examples/arc58/arc58.algo.ts:104", + "pc": [ + 325 + ] + }, + { + "teal": 299, + "source": "examples/arc58/arc58.algo.ts:102", + "pc": [ + 326 + ] + }, + { + "teal": 304, + "source": "examples/arc58/arc58.algo.ts:115", + "pc": [ + 327, + 328, + 329 + ] + }, + { + "teal": 305, + "source": "examples/arc58/arc58.algo.ts:115", + "pc": [ + 330 + ] + }, + { + "teal": 306, + "source": "examples/arc58/arc58.algo.ts:115", + "pc": [ + 331 + ] + }, + { + "teal": 307, + "source": "examples/arc58/arc58.algo.ts:115", + "pc": [ + 332, + 333 + ] + }, + { + "teal": 308, + "source": "examples/arc58/arc58.algo.ts:115", + "pc": [ + 334 + ] + }, + { + "teal": 311, + "source": "examples/arc58/arc58.algo.ts:115", + "errorMessage": "argument 0 (newAdmin) for arc58_pluginChangeAdmin must be a address", + "pc": [ + 335 + ] + }, + { + "teal": 314, + "source": "examples/arc58/arc58.algo.ts:115", + "pc": [ + 336, + 337, + 338 + ] + }, + { + "teal": 315, + "source": "examples/arc58/arc58.algo.ts:115", + "pc": [ + 339 + ] + }, + { + "teal": 316, + "source": "examples/arc58/arc58.algo.ts:115", + "pc": [ + 340 + ] + }, + { + "teal": 317, + "source": "examples/arc58/arc58.algo.ts:115", + "pc": [ + 341, + 342 + ] + }, + { + "teal": 318, + "source": "examples/arc58/arc58.algo.ts:115", + "pc": [ + 343 + ] + }, + { + "teal": 321, + "source": "examples/arc58/arc58.algo.ts:115", + "errorMessage": "argument 1 (allowedCaller) for arc58_pluginChangeAdmin must be a address", + "pc": [ + 344 + ] + }, + { + "teal": 324, + "source": "examples/arc58/arc58.algo.ts:115", + "pc": [ + 345, + 346, + 347 + ] + }, + { + "teal": 325, + "source": "examples/arc58/arc58.algo.ts:115", + "pc": [ + 348 + ] + }, + { + "teal": 328, + "source": "examples/arc58/arc58.algo.ts:115", + "pc": [ + 349, + 350, + 351 + ] + }, + { + "teal": 329, + "source": "examples/arc58/arc58.algo.ts:115", + "pc": [ + 352, + 353 + ] + }, + { + "teal": 330, + "source": "examples/arc58/arc58.algo.ts:115", + "pc": [ + 354 + ] + }, + { + "teal": 340, + "source": "examples/arc58/arc58.algo.ts:115", + "pc": [ + 355, + 356, + 357 + ] + }, + { + "teal": 343, + "source": "examples/arc58/arc58.algo.ts:115", + "pc": [ + 358, + 359 + ] + }, + { + "teal": 348, + "source": "examples/arc58/arc58.algo.ts:116", + "pc": [ + 360, + 361 + ] + }, + { + "teal": 349, + "source": "examples/arc58/arc58.algo.ts:116", + "pc": [ + 362, + 363 + ] + }, + { + "teal": 350, + "source": "examples/arc58/arc58.algo.ts:116", + "pc": [ + 364, + 365 + ] + }, + { + "teal": 351, + "source": "examples/arc58/arc58.algo.ts:116", + "pc": [ + 366 + ] + }, + { + "teal": 352, + "source": "examples/arc58/arc58.algo.ts:116", + "pc": [ + 367 + ] + }, + { + "teal": 355, + "source": "examples/arc58/arc58.algo.ts:116", + "errorMessage": "transaction verification failed: {\"txn\":\"this.txn\",\"field\":\"sender\",\"expected\":\"plugin.address\"}", + "pc": [ + 368 + ] + }, + { + "teal": 359, + "source": "examples/arc58/arc58.algo.ts:117", + "pc": [ + 369, + 370, + 371 + ] + }, + { + "teal": 360, + "source": "examples/arc58/arc58.algo.ts:117", + "pc": [ + 372 + ] + }, + { + "teal": 361, + "source": "examples/arc58/arc58.algo.ts:117", + "pc": [ + 373, + 374 + ] + }, + { + "teal": 362, + "source": "examples/arc58/arc58.algo.ts:117", + "pc": [ + 375 + ] + }, + { + "teal": 363, + "source": "examples/arc58/arc58.algo.ts:117", + "pc": [ + 376, + 377 + ] + }, + { + "teal": 364, + "source": "examples/arc58/arc58.algo.ts:117", + "pc": [ + 378, + 379 + ] + }, + { + "teal": 365, + "source": "examples/arc58/arc58.algo.ts:117", + "pc": [ + 380 + ] + }, + { + "teal": 366, + "source": "examples/arc58/arc58.algo.ts:117", + "pc": [ + 381 + ] + }, + { + "teal": 369, + "source": "examples/arc58/arc58.algo.ts:117", + "errorMessage": "This plugin is not in control of the account", + "pc": [ + 382 + ] + }, + { + "teal": 373, + "source": "examples/arc58/arc58.algo.ts:119", + "pc": [ + 383, + 384 + ] + }, + { + "teal": 374, + "source": "examples/arc58/arc58.algo.ts:119", + "pc": [ + 385 + ] + }, + { + "teal": 375, + "source": "examples/arc58/arc58.algo.ts:119", + "pc": [ + 386, + 387 + ] + }, + { + "teal": 376, + "source": "examples/arc58/arc58.algo.ts:119", + "pc": [ + 388 + ] + }, + { + "teal": 377, + "source": "examples/arc58/arc58.algo.ts:119", + "pc": [ + 389, + 390 + ] + }, + { + "teal": 384, + "source": "examples/arc58/arc58.algo.ts:121", + "pc": [ + 391, + 392, + 393 + ] + }, + { + "teal": 385, + "source": "examples/arc58/arc58.algo.ts:121", + "pc": [ + 394, + 395 + ] + }, + { + "teal": 386, + "source": "examples/arc58/arc58.algo.ts:121", + "pc": [ + 396 + ] + }, + { + "teal": 387, + "source": "examples/arc58/arc58.algo.ts:121", + "pc": [ + 397 + ] + }, + { + "teal": 388, + "source": "examples/arc58/arc58.algo.ts:121", + "pc": [ + 398 + ] + }, + { + "teal": 389, + "source": "examples/arc58/arc58.algo.ts:121", + "pc": [ + 399 + ] + }, + { + "teal": 390, + "source": "examples/arc58/arc58.algo.ts:121", + "pc": [ + 400 + ] + }, + { + "teal": 391, + "source": "examples/arc58/arc58.algo.ts:121", + "pc": [ + 401, + 402, + 403 + ] + }, + { + "teal": 392, + "source": "examples/arc58/arc58.algo.ts:121", + "pc": [ + 404, + 405, + 406 + ] + }, + { + "teal": 393, + "source": "examples/arc58/arc58.algo.ts:121", + "pc": [ + 407, + 408 + ] + }, + { + "teal": 394, + "source": "examples/arc58/arc58.algo.ts:121", + "pc": [ + 409 + ] + }, + { + "teal": 395, + "source": "examples/arc58/arc58.algo.ts:121", + "pc": [ + 410 + ] + }, + { + "teal": 398, + "source": "examples/arc58/arc58.algo.ts:121", + "errorMessage": "box value does not exist: this.plugins(key).value", + "pc": [ + 411 + ] + }, + { + "teal": 399, + "source": "examples/arc58/arc58.algo.ts:121", + "pc": [ + 412, + 413 + ] + }, + { + "teal": 400, + "source": "examples/arc58/arc58.algo.ts:121", + "pc": [ + 414, + 415 + ] + }, + { + "teal": 401, + "source": "examples/arc58/arc58.algo.ts:121", + "pc": [ + 416, + 417, + 418 + ] + }, + { + "teal": 402, + "source": "examples/arc58/arc58.algo.ts:121", + "pc": [ + 419 + ] + }, + { + "teal": 403, + "source": "examples/arc58/arc58.algo.ts:121", + "pc": [ + 420 + ] + }, + { + "teal": 407, + "source": "examples/arc58/arc58.algo.ts:120", + "errorMessage": "This plugin does not have admin privileges", + "pc": [ + 421 + ] + }, + { + "teal": 411, + "source": "examples/arc58/arc58.algo.ts:125", + "pc": [ + 422, + 423, + 424 + ] + }, + { + "teal": 412, + "source": "examples/arc58/arc58.algo.ts:125", + "pc": [ + 425, + 426 + ] + }, + { + "teal": 413, + "source": "examples/arc58/arc58.algo.ts:125", + "pc": [ + 427 + ] + }, + { + "teal": 414, + "source": "examples/arc58/arc58.algo.ts:115", + "pc": [ + 428 + ] + }, + { + "teal": 419, + "source": "examples/arc58/arc58.algo.ts:132", + "pc": [ + 429, + 430, + 431, + 432, + 433, + 434 + ] + }, + { + "teal": 422, + "source": "examples/arc58/arc58.algo.ts:132", + "pc": [ + 435, + 436, + 437 + ] + }, + { + "teal": 423, + "source": "examples/arc58/arc58.algo.ts:132", + "pc": [ + 438 + ] + }, + { + "teal": 424, + "source": "examples/arc58/arc58.algo.ts:132", + "pc": [ + 439 + ] + }, + { + "teal": 425, + "source": "examples/arc58/arc58.algo.ts:132", + "pc": [ + 440, + 441 + ] + }, + { + "teal": 426, + "source": "examples/arc58/arc58.algo.ts:132", + "pc": [ + 442 + ] + }, + { + "teal": 433, + "source": "examples/arc58/arc58.algo.ts:132", + "pc": [ + 443, + 444, + 445 + ] + }, + { + "teal": 437, + "source": "examples/arc58/arc58.algo.ts:133", + "pc": [ + 446, + 447, + 448 + ] + }, + { + "teal": 438, + "source": "examples/arc58/arc58.algo.ts:133", + "pc": [ + 449 + ] + }, + { + "teal": 439, + "source": "examples/arc58/arc58.algo.ts:132", + "pc": [ + 450 + ] + }, + { + "teal": 444, + "source": "examples/arc58/arc58.algo.ts:139", + "pc": [ + 451, + 452, + 453 + ] + }, + { + "teal": 445, + "source": "examples/arc58/arc58.algo.ts:139", + "pc": [ + 454, + 455 + ] + }, + { + "teal": 446, + "source": "examples/arc58/arc58.algo.ts:139", + "pc": [ + 456 + ] + }, + { + "teal": 452, + "source": "examples/arc58/arc58.algo.ts:139", + "pc": [ + 457, + 458, + 459 + ] + }, + { + "teal": 456, + "source": "examples/arc58/arc58.algo.ts:140", + "pc": [ + 460, + 461, + 462 + ] + }, + { + "teal": 457, + "source": "examples/arc58/arc58.algo.ts:140", + "pc": [ + 463 + ] + }, + { + "teal": 458, + "source": "examples/arc58/arc58.algo.ts:140", + "pc": [ + 464, + 465 + ] + }, + { + "teal": 459, + "source": "examples/arc58/arc58.algo.ts:140", + "pc": [ + 466 + ] + }, + { + "teal": 460, + "source": "examples/arc58/arc58.algo.ts:140", + "pc": [ + 467, + 468, + 469 + ] + }, + { + "teal": 461, + "source": "examples/arc58/arc58.algo.ts:140", + "pc": [ + 470 + ] + }, + { + "teal": 462, + "source": "examples/arc58/arc58.algo.ts:140", + "pc": [ + 471 + ] + }, + { + "teal": 463, + "source": "examples/arc58/arc58.algo.ts:139", + "pc": [ + 472 + ] + }, + { + "teal": 468, + "source": "examples/arc58/arc58.algo.ts:149", + "pc": [ + 473, + 474, + 475 + ] + }, + { + "teal": 469, + "source": "examples/arc58/arc58.algo.ts:149", + "pc": [ + 476 + ] + }, + { + "teal": 470, + "source": "examples/arc58/arc58.algo.ts:149", + "pc": [ + 477 + ] + }, + { + "teal": 471, + "source": "examples/arc58/arc58.algo.ts:149", + "pc": [ + 478, + 479 + ] + }, + { + "teal": 472, + "source": "examples/arc58/arc58.algo.ts:149", + "pc": [ + 480 + ] + }, + { + "teal": 475, + "source": "examples/arc58/arc58.algo.ts:149", + "errorMessage": "argument 0 (flash) for arc58_rekeyTo must be a bool", + "pc": [ + 481 + ] + }, + { + "teal": 476, + "source": "examples/arc58/arc58.algo.ts:149", + "pc": [ + 482, + 483 + ] + }, + { + "teal": 477, + "source": "examples/arc58/arc58.algo.ts:149", + "pc": [ + 484 + ] + }, + { + "teal": 480, + "source": "examples/arc58/arc58.algo.ts:149", + "pc": [ + 485, + 486, + 487 + ] + }, + { + "teal": 481, + "source": "examples/arc58/arc58.algo.ts:149", + "pc": [ + 488 + ] + }, + { + "teal": 482, + "source": "examples/arc58/arc58.algo.ts:149", + "pc": [ + 489 + ] + }, + { + "teal": 483, + "source": "examples/arc58/arc58.algo.ts:149", + "pc": [ + 490, + 491 + ] + }, + { + "teal": 484, + "source": "examples/arc58/arc58.algo.ts:149", + "pc": [ + 492 + ] + }, + { + "teal": 487, + "source": "examples/arc58/arc58.algo.ts:149", + "errorMessage": "argument 1 (addr) for arc58_rekeyTo must be a address", + "pc": [ + 493 + ] + }, + { + "teal": 490, + "source": "examples/arc58/arc58.algo.ts:149", + "pc": [ + 494, + 495, + 496 + ] + }, + { + "teal": 491, + "source": "examples/arc58/arc58.algo.ts:149", + "pc": [ + 497, + 498 + ] + }, + { + "teal": 492, + "source": "examples/arc58/arc58.algo.ts:149", + "pc": [ + 499 + ] + }, + { + "teal": 501, + "source": "examples/arc58/arc58.algo.ts:149", + "pc": [ + 500, + 501, + 502 + ] + }, + { + "teal": 506, + "source": "examples/arc58/arc58.algo.ts:150", + "pc": [ + 503, + 504 + ] + }, + { + "teal": 507, + "source": "examples/arc58/arc58.algo.ts:150", + "pc": [ + 505, + 506, + 507 + ] + }, + { + "teal": 508, + "source": "examples/arc58/arc58.algo.ts:150", + "pc": [ + 508 + ] + }, + { + "teal": 509, + "source": "examples/arc58/arc58.algo.ts:150", + "pc": [ + 509 + ] + }, + { + "teal": 512, + "source": "examples/arc58/arc58.algo.ts:150", + "errorMessage": "transaction verification failed: {\"txn\":\"this.txn\",\"field\":\"sender\",\"expected\":\"this.admin.value\"}", + "pc": [ + 510 + ] + }, + { + "teal": 521, + "source": "examples/arc58/arc58.algo.ts:152", + "pc": [ + 511 + ] + }, + { + "teal": 522, + "source": "examples/arc58/arc58.algo.ts:152", + "pc": [ + 512, + 513 + ] + }, + { + "teal": 523, + "source": "examples/arc58/arc58.algo.ts:152", + "pc": [ + 514, + 515 + ] + }, + { + "teal": 527, + "source": "examples/arc58/arc58.algo.ts:153", + "pc": [ + 516, + 517, + 518 + ] + }, + { + "teal": 528, + "source": "examples/arc58/arc58.algo.ts:153", + "pc": [ + 519 + ] + }, + { + "teal": 529, + "source": "examples/arc58/arc58.algo.ts:153", + "pc": [ + 520, + 521 + ] + }, + { + "teal": 533, + "source": "examples/arc58/arc58.algo.ts:154", + "pc": [ + 522, + 523 + ] + }, + { + "teal": 534, + "source": "examples/arc58/arc58.algo.ts:154", + "pc": [ + 524, + 525 + ] + }, + { + "teal": 538, + "source": "examples/arc58/arc58.algo.ts:155", + "pc": [ + 526, + 527 + ] + }, + { + "teal": 539, + "source": "examples/arc58/arc58.algo.ts:155", + "pc": [ + 528, + 529 + ] + }, + { + "teal": 543, + "source": "examples/arc58/arc58.algo.ts:156", + "pc": [ + 530, + 531, + 532, + 533, + 534, + 535, + 536, + 537, + 538, + 539, + 540, + 541, + 542, + 543, + 544, + 545, + 546, + 547, + 548, + 549, + 550, + 551, + 552, + 553, + 554, + 555, + 556, + 557, + 558 + ] + }, + { + "teal": 544, + "source": "examples/arc58/arc58.algo.ts:156", + "pc": [ + 559, + 560 + ] + }, + { + "teal": 547, + "source": "examples/arc58/arc58.algo.ts:152", + "pc": [ + 561, + 562 + ] + }, + { + "teal": 548, + "source": "examples/arc58/arc58.algo.ts:152", + "pc": [ + 563, + 564 + ] + }, + { + "teal": 551, + "source": "examples/arc58/arc58.algo.ts:152", + "pc": [ + 565 + ] + }, + { + "teal": 556, + "source": "examples/arc58/arc58.algo.ts:159", + "pc": [ + 566, + 567 + ] + }, + { + "teal": 557, + "source": "examples/arc58/arc58.algo.ts:159", + "pc": [ + 568, + 569, + 570 + ] + }, + { + "teal": 562, + "source": "examples/arc58/arc58.algo.ts:159", + "pc": [ + 571, + 572, + 573 + ] + }, + { + "teal": 565, + "source": "examples/arc58/arc58.algo.ts:149", + "pc": [ + 574 + ] + }, + { + "teal": 569, + "source": "examples/arc58/arc58.algo.ts:162", + "pc": [ + 575, + 576, + 577 + ] + }, + { + "teal": 572, + "source": "examples/arc58/arc58.algo.ts:162", + "pc": [ + 578, + 579 + ] + }, + { + "teal": 576, + "source": "examples/arc58/arc58.algo.ts:163", + "pc": [ + 580, + 581 + ] + }, + { + "teal": 577, + "source": "examples/arc58/arc58.algo.ts:163", + "pc": [ + 582 + ] + }, + { + "teal": 578, + "source": "examples/arc58/arc58.algo.ts:163", + "pc": [ + 583, + 584 + ] + }, + { + "teal": 579, + "source": "examples/arc58/arc58.algo.ts:163", + "pc": [ + 585 + ] + }, + { + "teal": 580, + "source": "examples/arc58/arc58.algo.ts:163", + "pc": [ + 586, + 587 + ] + }, + { + "teal": 588, + "source": "examples/arc58/arc58.algo.ts:166", + "pc": [ + 588, + 589, + 590 + ] + }, + { + "teal": 589, + "source": "examples/arc58/arc58.algo.ts:166", + "pc": [ + 591, + 592 + ] + }, + { + "teal": 590, + "source": "examples/arc58/arc58.algo.ts:166", + "pc": [ + 593 + ] + }, + { + "teal": 591, + "source": "examples/arc58/arc58.algo.ts:166", + "pc": [ + 594 + ] + }, + { + "teal": 592, + "source": "examples/arc58/arc58.algo.ts:166", + "pc": [ + 595 + ] + }, + { + "teal": 593, + "source": "examples/arc58/arc58.algo.ts:166", + "pc": [ + 596 + ] + }, + { + "teal": 594, + "source": "examples/arc58/arc58.algo.ts:166", + "pc": [ + 597 + ] + }, + { + "teal": 595, + "source": "examples/arc58/arc58.algo.ts:166", + "pc": [ + 598, + 599, + 600 + ] + }, + { + "teal": 596, + "source": "examples/arc58/arc58.algo.ts:167", + "pc": [ + 601, + 602, + 603 + ] + }, + { + "teal": 597, + "source": "examples/arc58/arc58.algo.ts:167", + "pc": [ + 604, + 605 + ] + }, + { + "teal": 598, + "source": "examples/arc58/arc58.algo.ts:167", + "pc": [ + 606 + ] + }, + { + "teal": 599, + "source": "examples/arc58/arc58.algo.ts:167", + "pc": [ + 607 + ] + }, + { + "teal": 602, + "source": "examples/arc58/arc58.algo.ts:167", + "errorMessage": "box value does not exist: this.plugins(key).value", + "pc": [ + 608 + ] + }, + { + "teal": 603, + "source": "examples/arc58/arc58.algo.ts:167", + "pc": [ + 609, + 610 + ] + }, + { + "teal": 604, + "source": "examples/arc58/arc58.algo.ts:167", + "pc": [ + 611, + 612 + ] + }, + { + "teal": 605, + "source": "examples/arc58/arc58.algo.ts:167", + "pc": [ + 613, + 614, + 615 + ] + }, + { + "teal": 606, + "source": "examples/arc58/arc58.algo.ts:167", + "pc": [ + 616 + ] + }, + { + "teal": 607, + "source": "examples/arc58/arc58.algo.ts:167", + "pc": [ + 617, + 618 + ] + }, + { + "teal": 608, + "source": "examples/arc58/arc58.algo.ts:167", + "pc": [ + 619 + ] + }, + { + "teal": 609, + "source": "examples/arc58/arc58.algo.ts:166", + "pc": [ + 620 + ] + }, + { + "teal": 612, + "source": "examples/arc58/arc58.algo.ts:167", + "pc": [ + 621 + ] + }, + { + "teal": 613, + "source": "examples/arc58/arc58.algo.ts:167", + "pc": [ + 622, + 623, + 624 + ] + }, + { + "teal": 614, + "source": "examples/arc58/arc58.algo.ts:168", + "pc": [ + 625, + 626 + ] + }, + { + "teal": 615, + "source": "examples/arc58/arc58.algo.ts:168", + "pc": [ + 627, + 628, + 629 + ] + }, + { + "teal": 616, + "source": "examples/arc58/arc58.algo.ts:168", + "pc": [ + 630, + 631 + ] + }, + { + "teal": 617, + "source": "examples/arc58/arc58.algo.ts:168", + "pc": [ + 632 + ] + }, + { + "teal": 618, + "source": "examples/arc58/arc58.algo.ts:168", + "pc": [ + 633 + ] + }, + { + "teal": 621, + "source": "examples/arc58/arc58.algo.ts:168", + "errorMessage": "box value does not exist: this.plugins(key).value", + "pc": [ + 634 + ] + }, + { + "teal": 622, + "source": "examples/arc58/arc58.algo.ts:168", + "pc": [ + 635, + 636 + ] + }, + { + "teal": 623, + "source": "examples/arc58/arc58.algo.ts:168", + "pc": [ + 637, + 638 + ] + }, + { + "teal": 624, + "source": "examples/arc58/arc58.algo.ts:168", + "pc": [ + 639, + 640, + 641 + ] + }, + { + "teal": 625, + "source": "examples/arc58/arc58.algo.ts:168", + "pc": [ + 642 + ] + }, + { + "teal": 626, + "source": "examples/arc58/arc58.algo.ts:168", + "pc": [ + 643 + ] + }, + { + "teal": 627, + "source": "examples/arc58/arc58.algo.ts:168", + "pc": [ + 644, + 645, + 646 + ] + }, + { + "teal": 628, + "source": "examples/arc58/arc58.algo.ts:168", + "pc": [ + 647, + 648 + ] + }, + { + "teal": 629, + "source": "examples/arc58/arc58.algo.ts:168", + "pc": [ + 649 + ] + }, + { + "teal": 630, + "source": "examples/arc58/arc58.algo.ts:168", + "pc": [ + 650 + ] + }, + { + "teal": 633, + "source": "examples/arc58/arc58.algo.ts:168", + "errorMessage": "box value does not exist: this.plugins(key).value", + "pc": [ + 651 + ] + }, + { + "teal": 634, + "source": "examples/arc58/arc58.algo.ts:168", + "pc": [ + 652, + 653 + ] + }, + { + "teal": 635, + "source": "examples/arc58/arc58.algo.ts:168", + "pc": [ + 654, + 655 + ] + }, + { + "teal": 636, + "source": "examples/arc58/arc58.algo.ts:168", + "pc": [ + 656, + 657, + 658 + ] + }, + { + "teal": 637, + "source": "examples/arc58/arc58.algo.ts:168", + "pc": [ + 659 + ] + }, + { + "teal": 638, + "source": "examples/arc58/arc58.algo.ts:168", + "pc": [ + 660 + ] + }, + { + "teal": 639, + "source": "examples/arc58/arc58.algo.ts:167", + "pc": [ + 661 + ] + }, + { + "teal": 643, + "source": "examples/arc58/arc58.algo.ts:162", + "pc": [ + 662, + 663 + ] + }, + { + "teal": 644, + "source": "examples/arc58/arc58.algo.ts:162", + "pc": [ + 664 + ] + }, + { + "teal": 649, + "source": "examples/arc58/arc58.algo.ts:177", + "pc": [ + 665, + 666, + 667 + ] + }, + { + "teal": 650, + "source": "examples/arc58/arc58.algo.ts:177", + "pc": [ + 668 + ] + }, + { + "teal": 653, + "source": "examples/arc58/arc58.algo.ts:177", + "pc": [ + 669, + 670, + 671 + ] + }, + { + "teal": 654, + "source": "examples/arc58/arc58.algo.ts:177", + "pc": [ + 672, + 673 + ] + }, + { + "teal": 655, + "source": "examples/arc58/arc58.algo.ts:177", + "pc": [ + 674 + ] + }, + { + "teal": 663, + "source": "examples/arc58/arc58.algo.ts:177", + "pc": [ + 675, + 676, + 677 + ] + }, + { + "teal": 666, + "source": "examples/arc58/arc58.algo.ts:177", + "pc": [ + 678, + 679 + ] + }, + { + "teal": 670, + "source": "examples/arc58/arc58.algo.ts:178", + "pc": [ + 680, + 681 + ] + }, + { + "teal": 671, + "source": "examples/arc58/arc58.algo.ts:178", + "pc": [ + 682, + 683 + ] + }, + { + "teal": 672, + "source": "examples/arc58/arc58.algo.ts:178", + "pc": [ + 684, + 685, + 686 + ] + }, + { + "teal": 673, + "source": "examples/arc58/arc58.algo.ts:178", + "pc": [ + 687, + 688 + ] + }, + { + "teal": 678, + "source": "examples/arc58/arc58.algo.ts:180", + "pc": [ + 689, + 690 + ] + }, + { + "teal": 679, + "source": "examples/arc58/arc58.algo.ts:180", + "pc": [ + 691 + ] + }, + { + "teal": 680, + "source": "examples/arc58/arc58.algo.ts:180", + "pc": [ + 692, + 693, + 694 + ] + }, + { + "teal": 685, + "source": "examples/arc58/arc58.algo.ts:181", + "pc": [ + 695, + 696 + ] + }, + { + "teal": 686, + "source": "examples/arc58/arc58.algo.ts:181", + "pc": [ + 697, + 698 + ] + }, + { + "teal": 687, + "source": "examples/arc58/arc58.algo.ts:181", + "pc": [ + 699, + 700, + 701 + ] + }, + { + "teal": 690, + "source": "examples/arc58/arc58.algo.ts:181", + "errorMessage": "This sender is not allowed to trigger this plugin", + "pc": [ + 702 + ] + }, + { + "teal": 700, + "source": "examples/arc58/arc58.algo.ts:183", + "pc": [ + 703 + ] + }, + { + "teal": 701, + "source": "examples/arc58/arc58.algo.ts:183", + "pc": [ + 704, + 705 + ] + }, + { + "teal": 702, + "source": "examples/arc58/arc58.algo.ts:183", + "pc": [ + 706, + 707 + ] + }, + { + "teal": 706, + "source": "examples/arc58/arc58.algo.ts:184", + "pc": [ + 708, + 709, + 710 + ] + }, + { + "teal": 707, + "source": "examples/arc58/arc58.algo.ts:184", + "pc": [ + 711 + ] + }, + { + "teal": 708, + "source": "examples/arc58/arc58.algo.ts:184", + "pc": [ + 712, + 713 + ] + }, + { + "teal": 712, + "source": "examples/arc58/arc58.algo.ts:185", + "pc": [ + 714, + 715, + 716 + ] + }, + { + "teal": 713, + "source": "examples/arc58/arc58.algo.ts:185", + "pc": [ + 717 + ] + }, + { + "teal": 714, + "source": "examples/arc58/arc58.algo.ts:185", + "pc": [ + 718, + 719 + ] + }, + { + "teal": 718, + "source": "examples/arc58/arc58.algo.ts:186", + "pc": [ + 720, + 721 + ] + }, + { + "teal": 719, + "source": "examples/arc58/arc58.algo.ts:186", + "pc": [ + 722, + 723 + ] + }, + { + "teal": 720, + "source": "examples/arc58/arc58.algo.ts:186", + "pc": [ + 724 + ] + }, + { + "teal": 721, + "source": "examples/arc58/arc58.algo.ts:186", + "pc": [ + 725, + 726 + ] + }, + { + "teal": 725, + "source": "examples/arc58/arc58.algo.ts:187", + "pc": [ + 727, + 728, + 729, + 730, + 731, + 732, + 733, + 734, + 735, + 736, + 737, + 738, + 739, + 740, + 741, + 742, + 743, + 744, + 745, + 746, + 747, + 748, + 749, + 750 + ] + }, + { + "teal": 726, + "source": "examples/arc58/arc58.algo.ts:187", + "pc": [ + 751, + 752 + ] + }, + { + "teal": 729, + "source": "examples/arc58/arc58.algo.ts:183", + "pc": [ + 753, + 754 + ] + }, + { + "teal": 730, + "source": "examples/arc58/arc58.algo.ts:183", + "pc": [ + 755, + 756 + ] + }, + { + "teal": 733, + "source": "examples/arc58/arc58.algo.ts:183", + "pc": [ + 757 + ] + }, + { + "teal": 740, + "source": "examples/arc58/arc58.algo.ts:190", + "pc": [ + 758, + 759, + 760 + ] + }, + { + "teal": 741, + "source": "examples/arc58/arc58.algo.ts:191", + "pc": [ + 761, + 762 + ] + }, + { + "teal": 742, + "source": "examples/arc58/arc58.algo.ts:191", + "pc": [ + 763 + ] + }, + { + "teal": 743, + "source": "examples/arc58/arc58.algo.ts:192", + "pc": [ + 764, + 765 + ] + }, + { + "teal": 744, + "source": "examples/arc58/arc58.algo.ts:192", + "pc": [ + 766, + 767, + 768 + ] + }, + { + "teal": 745, + "source": "examples/arc58/arc58.algo.ts:192", + "pc": [ + 769, + 770 + ] + }, + { + "teal": 746, + "source": "examples/arc58/arc58.algo.ts:192", + "pc": [ + 771, + 772, + 773 + ] + }, + { + "teal": 749, + "source": "examples/arc58/arc58.algo.ts:192", + "pc": [ + 774, + 775 + ] + }, + { + "teal": 752, + "source": "examples/arc58/arc58.algo.ts:192", + "pc": [ + 776 + ] + }, + { + "teal": 753, + "source": "examples/arc58/arc58.algo.ts:190", + "pc": [ + 777 + ] + }, + { + "teal": 754, + "source": "examples/arc58/arc58.algo.ts:190", + "pc": [ + 778 + ] + }, + { + "teal": 757, + "source": "examples/arc58/arc58.algo.ts:190", + "errorMessage": "box value does not exist: this.plugins({ application: plugin, allowedCaller: globalAllowed ? Address.zeroAddress : this.txn.sender, }).value", + "pc": [ + 779 + ] + }, + { + "teal": 758, + "source": "examples/arc58/arc58.algo.ts:190", + "pc": [ + 780, + 781 + ] + }, + { + "teal": 759, + "source": "examples/arc58/arc58.algo.ts:190", + "pc": [ + 782, + 783 + ] + }, + { + "teal": 760, + "source": "examples/arc58/arc58.algo.ts:190", + "pc": [ + 784, + 785 + ] + }, + { + "teal": 761, + "source": "examples/arc58/arc58.algo.ts:193", + "pc": [ + 786, + 787 + ] + }, + { + "teal": 762, + "source": "examples/arc58/arc58.algo.ts:193", + "pc": [ + 788 + ] + }, + { + "teal": 763, + "source": "examples/arc58/arc58.algo.ts:190", + "pc": [ + 789, + 790, + 791 + ] + }, + { + "teal": 764, + "source": "examples/arc58/arc58.algo.ts:191", + "pc": [ + 792, + 793 + ] + }, + { + "teal": 765, + "source": "examples/arc58/arc58.algo.ts:191", + "pc": [ + 794 + ] + }, + { + "teal": 766, + "source": "examples/arc58/arc58.algo.ts:192", + "pc": [ + 795, + 796 + ] + }, + { + "teal": 767, + "source": "examples/arc58/arc58.algo.ts:192", + "pc": [ + 797, + 798, + 799 + ] + }, + { + "teal": 768, + "source": "examples/arc58/arc58.algo.ts:192", + "pc": [ + 800, + 801 + ] + }, + { + "teal": 769, + "source": "examples/arc58/arc58.algo.ts:192", + "pc": [ + 802, + 803, + 804 + ] + }, + { + "teal": 772, + "source": "examples/arc58/arc58.algo.ts:192", + "pc": [ + 805, + 806 + ] + }, + { + "teal": 775, + "source": "examples/arc58/arc58.algo.ts:192", + "pc": [ + 807 + ] + }, + { + "teal": 776, + "source": "examples/arc58/arc58.algo.ts:190", + "pc": [ + 808 + ] + }, + { + "teal": 777, + "source": "examples/arc58/arc58.algo.ts:190", + "pc": [ + 809, + 810 + ] + }, + { + "teal": 778, + "source": "examples/arc58/arc58.algo.ts:190", + "pc": [ + 811 + ] + }, + { + "teal": 782, + "source": "examples/arc58/arc58.algo.ts:195", + "pc": [ + 812, + 813, + 814 + ] + }, + { + "teal": 783, + "source": "examples/arc58/arc58.algo.ts:177", + "pc": [ + 815 + ] + }, + { + "teal": 788, + "source": "examples/arc58/arc58.algo.ts:203", + "pc": [ + 816, + 817, + 818 + ] + }, + { + "teal": 789, + "source": "examples/arc58/arc58.algo.ts:203", + "pc": [ + 819, + 820, + 821 + ] + }, + { + "teal": 792, + "source": "examples/arc58/arc58.algo.ts:203", + "pc": [ + 822, + 823, + 824 + ] + }, + { + "teal": 793, + "source": "examples/arc58/arc58.algo.ts:203", + "pc": [ + 825, + 826 + ] + }, + { + "teal": 794, + "source": "examples/arc58/arc58.algo.ts:203", + "pc": [ + 827 + ] + }, + { + "teal": 802, + "source": "examples/arc58/arc58.algo.ts:203", + "pc": [ + 828, + 829, + 830 + ] + }, + { + "teal": 806, + "source": "examples/arc58/arc58.algo.ts:204", + "pc": [ + 831, + 832 + ] + }, + { + "teal": 807, + "source": "examples/arc58/arc58.algo.ts:204", + "pc": [ + 833, + 834 + ] + }, + { + "teal": 808, + "source": "examples/arc58/arc58.algo.ts:204", + "pc": [ + 835, + 836, + 837 + ] + }, + { + "teal": 809, + "source": "examples/arc58/arc58.algo.ts:204", + "pc": [ + 838, + 839 + ] + }, + { + "teal": 810, + "source": "examples/arc58/arc58.algo.ts:204", + "pc": [ + 840 + ] + }, + { + "teal": 811, + "source": "examples/arc58/arc58.algo.ts:204", + "pc": [ + 841, + 842 + ] + }, + { + "teal": 812, + "source": "examples/arc58/arc58.algo.ts:204", + "pc": [ + 843 + ] + }, + { + "teal": 813, + "source": "examples/arc58/arc58.algo.ts:204", + "pc": [ + 844 + ] + }, + { + "teal": 814, + "source": "examples/arc58/arc58.algo.ts:204", + "pc": [ + 845, + 846, + 847 + ] + }, + { + "teal": 815, + "source": "examples/arc58/arc58.algo.ts:203", + "pc": [ + 848 + ] + }, + { + "teal": 820, + "source": "examples/arc58/arc58.algo.ts:222", + "pc": [ + 849, + 850, + 851 + ] + }, + { + "teal": 821, + "source": "examples/arc58/arc58.algo.ts:222", + "pc": [ + 852 + ] + }, + { + "teal": 822, + "source": "examples/arc58/arc58.algo.ts:222", + "pc": [ + 853 + ] + }, + { + "teal": 823, + "source": "examples/arc58/arc58.algo.ts:222", + "pc": [ + 854, + 855 + ] + }, + { + "teal": 824, + "source": "examples/arc58/arc58.algo.ts:222", + "pc": [ + 856 + ] + }, + { + "teal": 827, + "source": "examples/arc58/arc58.algo.ts:222", + "errorMessage": "argument 0 (adminPrivileges) for arc58_addPlugin must be a bool", + "pc": [ + 857 + ] + }, + { + "teal": 828, + "source": "examples/arc58/arc58.algo.ts:222", + "pc": [ + 858, + 859 + ] + }, + { + "teal": 829, + "source": "examples/arc58/arc58.algo.ts:222", + "pc": [ + 860 + ] + }, + { + "teal": 832, + "source": "examples/arc58/arc58.algo.ts:221", + "pc": [ + 861, + 862, + 863 + ] + }, + { + "teal": 833, + "source": "examples/arc58/arc58.algo.ts:221", + "pc": [ + 864 + ] + }, + { + "teal": 836, + "source": "examples/arc58/arc58.algo.ts:220", + "pc": [ + 865, + 866, + 867 + ] + }, + { + "teal": 837, + "source": "examples/arc58/arc58.algo.ts:220", + "pc": [ + 868 + ] + }, + { + "teal": 840, + "source": "examples/arc58/arc58.algo.ts:219", + "pc": [ + 869, + 870, + 871 + ] + }, + { + "teal": 841, + "source": "examples/arc58/arc58.algo.ts:219", + "pc": [ + 872 + ] + }, + { + "teal": 842, + "source": "examples/arc58/arc58.algo.ts:219", + "pc": [ + 873 + ] + }, + { + "teal": 843, + "source": "examples/arc58/arc58.algo.ts:219", + "pc": [ + 874, + 875 + ] + }, + { + "teal": 844, + "source": "examples/arc58/arc58.algo.ts:219", + "pc": [ + 876 + ] + }, + { + "teal": 847, + "source": "examples/arc58/arc58.algo.ts:219", + "errorMessage": "argument 3 (allowedCaller) for arc58_addPlugin must be a address", + "pc": [ + 877 + ] + }, + { + "teal": 850, + "source": "examples/arc58/arc58.algo.ts:218", + "pc": [ + 878, + 879, + 880 + ] + }, + { + "teal": 851, + "source": "examples/arc58/arc58.algo.ts:218", + "pc": [ + 881 + ] + }, + { + "teal": 854, + "source": "examples/arc58/arc58.algo.ts:217", + "pc": [ + 882, + 883, + 884 + ] + }, + { + "teal": 855, + "source": "examples/arc58/arc58.algo.ts:217", + "pc": [ + 885, + 886 + ] + }, + { + "teal": 856, + "source": "examples/arc58/arc58.algo.ts:217", + "pc": [ + 887 + ] + }, + { + "teal": 869, + "source": "examples/arc58/arc58.algo.ts:217", + "pc": [ + 888, + 889, + 890 + ] + }, + { + "teal": 872, + "source": "examples/arc58/arc58.algo.ts:217", + "pc": [ + 891, + 892 + ] + }, + { + "teal": 877, + "source": "examples/arc58/arc58.algo.ts:224", + "pc": [ + 893, + 894 + ] + }, + { + "teal": 878, + "source": "examples/arc58/arc58.algo.ts:224", + "pc": [ + 895, + 896, + 897 + ] + }, + { + "teal": 879, + "source": "examples/arc58/arc58.algo.ts:224", + "pc": [ + 898 + ] + }, + { + "teal": 880, + "source": "examples/arc58/arc58.algo.ts:224", + "pc": [ + 899 + ] + }, + { + "teal": 883, + "source": "examples/arc58/arc58.algo.ts:224", + "errorMessage": "transaction verification failed: {\"txn\":\"this.txn\",\"field\":\"sender\",\"expected\":\"this.admin.value\"}", + "pc": [ + 900 + ] + }, + { + "teal": 887, + "source": "examples/arc58/arc58.algo.ts:225", + "pc": [ + 901, + 902 + ] + }, + { + "teal": 888, + "source": "examples/arc58/arc58.algo.ts:225", + "pc": [ + 903 + ] + }, + { + "teal": 889, + "source": "examples/arc58/arc58.algo.ts:225", + "pc": [ + 904, + 905 + ] + }, + { + "teal": 890, + "source": "examples/arc58/arc58.algo.ts:225", + "pc": [ + 906 + ] + }, + { + "teal": 891, + "source": "examples/arc58/arc58.algo.ts:225", + "pc": [ + 907, + 908 + ] + }, + { + "teal": 900, + "source": "examples/arc58/arc58.algo.ts:226", + "pc": [ + 909, + 910, + 911 + ] + }, + { + "teal": 901, + "source": "examples/arc58/arc58.algo.ts:226", + "pc": [ + 912, + 913 + ] + }, + { + "teal": 902, + "source": "examples/arc58/arc58.algo.ts:226", + "pc": [ + 914 + ] + }, + { + "teal": 903, + "source": "examples/arc58/arc58.algo.ts:227", + "pc": [ + 915, + 916 + ] + }, + { + "teal": 904, + "source": "examples/arc58/arc58.algo.ts:227", + "pc": [ + 917 + ] + }, + { + "teal": 905, + "source": "examples/arc58/arc58.algo.ts:228", + "pc": [ + 918, + 919 + ] + }, + { + "teal": 906, + "source": "examples/arc58/arc58.algo.ts:228", + "pc": [ + 920 + ] + }, + { + "teal": 907, + "source": "examples/arc58/arc58.algo.ts:228", + "pc": [ + 921 + ] + }, + { + "teal": 908, + "source": "examples/arc58/arc58.algo.ts:229", + "pc": [ + 922, + 923, + 924, + 925, + 926, + 927, + 928, + 929, + 930, + 931 + ] + }, + { + "teal": 909, + "source": "examples/arc58/arc58.algo.ts:229", + "pc": [ + 932 + ] + }, + { + "teal": 910, + "source": "examples/arc58/arc58.algo.ts:230", + "pc": [ + 933, + 934, + 935 + ] + }, + { + "teal": 911, + "source": "examples/arc58/arc58.algo.ts:230", + "pc": [ + 936, + 937 + ] + }, + { + "teal": 912, + "source": "examples/arc58/arc58.algo.ts:230", + "pc": [ + 938, + 939 + ] + }, + { + "teal": 913, + "source": "examples/arc58/arc58.algo.ts:230", + "pc": [ + 940 + ] + }, + { + "teal": 914, + "source": "examples/arc58/arc58.algo.ts:226", + "pc": [ + 941 + ] + }, + { + "teal": 915, + "source": "examples/arc58/arc58.algo.ts:226", + "pc": [ + 942 + ] + }, + { + "teal": 916, + "source": "examples/arc58/arc58.algo.ts:217", + "pc": [ + 943 + ] + }, + { + "teal": 921, + "source": "examples/arc58/arc58.algo.ts:239", + "pc": [ + 944, + 945, + 946 + ] + }, + { + "teal": 922, + "source": "examples/arc58/arc58.algo.ts:239", + "pc": [ + 947 + ] + }, + { + "teal": 923, + "source": "examples/arc58/arc58.algo.ts:239", + "pc": [ + 948 + ] + }, + { + "teal": 924, + "source": "examples/arc58/arc58.algo.ts:239", + "pc": [ + 949, + 950 + ] + }, + { + "teal": 925, + "source": "examples/arc58/arc58.algo.ts:239", + "pc": [ + 951 + ] + }, + { + "teal": 928, + "source": "examples/arc58/arc58.algo.ts:239", + "errorMessage": "argument 0 (allowedCaller) for arc58_removePlugin must be a address", + "pc": [ + 952 + ] + }, + { + "teal": 931, + "source": "examples/arc58/arc58.algo.ts:239", + "pc": [ + 953, + 954, + 955 + ] + }, + { + "teal": 932, + "source": "examples/arc58/arc58.algo.ts:239", + "pc": [ + 956 + ] + }, + { + "teal": 935, + "source": "examples/arc58/arc58.algo.ts:239", + "pc": [ + 957, + 958, + 959 + ] + }, + { + "teal": 936, + "source": "examples/arc58/arc58.algo.ts:239", + "pc": [ + 960, + 961 + ] + }, + { + "teal": 937, + "source": "examples/arc58/arc58.algo.ts:239", + "pc": [ + 962 + ] + }, + { + "teal": 945, + "source": "examples/arc58/arc58.algo.ts:239", + "pc": [ + 963, + 964, + 965 + ] + }, + { + "teal": 948, + "source": "examples/arc58/arc58.algo.ts:239", + "pc": [ + 966, + 967 + ] + }, + { + "teal": 953, + "source": "examples/arc58/arc58.algo.ts:240", + "pc": [ + 968, + 969 + ] + }, + { + "teal": 954, + "source": "examples/arc58/arc58.algo.ts:240", + "pc": [ + 970, + 971, + 972 + ] + }, + { + "teal": 955, + "source": "examples/arc58/arc58.algo.ts:240", + "pc": [ + 973 + ] + }, + { + "teal": 956, + "source": "examples/arc58/arc58.algo.ts:240", + "pc": [ + 974 + ] + }, + { + "teal": 959, + "source": "examples/arc58/arc58.algo.ts:240", + "errorMessage": "transaction verification failed: {\"txn\":\"this.txn\",\"field\":\"sender\",\"expected\":\"this.admin.value\"}", + "pc": [ + 975 + ] + }, + { + "teal": 963, + "source": "examples/arc58/arc58.algo.ts:242", + "pc": [ + 976, + 977 + ] + }, + { + "teal": 964, + "source": "examples/arc58/arc58.algo.ts:242", + "pc": [ + 978 + ] + }, + { + "teal": 965, + "source": "examples/arc58/arc58.algo.ts:242", + "pc": [ + 979, + 980 + ] + }, + { + "teal": 966, + "source": "examples/arc58/arc58.algo.ts:242", + "pc": [ + 981 + ] + }, + { + "teal": 967, + "source": "examples/arc58/arc58.algo.ts:242", + "pc": [ + 982, + 983 + ] + }, + { + "teal": 971, + "source": "examples/arc58/arc58.algo.ts:243", + "pc": [ + 984, + 985, + 986 + ] + }, + { + "teal": 972, + "source": "examples/arc58/arc58.algo.ts:243", + "pc": [ + 987, + 988 + ] + }, + { + "teal": 973, + "source": "examples/arc58/arc58.algo.ts:243", + "pc": [ + 989 + ] + }, + { + "teal": 974, + "source": "examples/arc58/arc58.algo.ts:243", + "pc": [ + 990 + ] + }, + { + "teal": 975, + "source": "examples/arc58/arc58.algo.ts:239", + "pc": [ + 991 + ] + }, + { + "teal": 980, + "source": "examples/arc58/arc58.algo.ts:263", + "pc": [ + 992, + 993, + 994 + ] + }, + { + "teal": 981, + "source": "examples/arc58/arc58.algo.ts:263", + "pc": [ + 995 + ] + }, + { + "teal": 982, + "source": "examples/arc58/arc58.algo.ts:263", + "pc": [ + 996 + ] + }, + { + "teal": 983, + "source": "examples/arc58/arc58.algo.ts:263", + "pc": [ + 997, + 998 + ] + }, + { + "teal": 984, + "source": "examples/arc58/arc58.algo.ts:263", + "pc": [ + 999 + ] }, { + "teal": 987, + "source": "examples/arc58/arc58.algo.ts:263", + "errorMessage": "argument 0 (adminPrivileges) for arc58_addNamedPlugin must be a bool", "pc": [ - 231 - ], - "errorMessage": "argument 0 (admin) for createApplication must be a address" + 1000 + ] }, { + "teal": 988, + "source": "examples/arc58/arc58.algo.ts:263", "pc": [ - 240 - ], - "errorMessage": "argument 1 (controlledAddress) for createApplication must be a address" + 1001, + 1002 + ] }, { + "teal": 989, + "source": "examples/arc58/arc58.algo.ts:263", "pc": [ - 261 - ], - "errorMessage": "transaction verification failed: {\"txn\":{\"txnText\":\"this.txn\"},\"field\":\"sender\",\"condition\":\"includedIn\",\"expected\":\"[controlledAddress, admin]\"}" + 1003 + ] }, { + "teal": 992, + "source": "examples/arc58/arc58.algo.ts:262", "pc": [ - 302 - ], - "errorMessage": "argument 0 (newAdmin) for arc58_changeAdmin must be a address" + 1004, + 1005, + 1006 + ] }, { + "teal": 993, + "source": "examples/arc58/arc58.algo.ts:262", "pc": [ - 319 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"this.txn\",\"field\":\"sender\",\"expected\":\"this.admin.value\"}" + 1007 + ] }, { + "teal": 996, + "source": "examples/arc58/arc58.algo.ts:261", "pc": [ - 335 - ], - "errorMessage": "argument 0 (newAdmin) for arc58_pluginChangeAdmin must be a address" + 1008, + 1009, + 1010 + ] }, { + "teal": 997, + "source": "examples/arc58/arc58.algo.ts:261", "pc": [ - 344 - ], - "errorMessage": "argument 1 (allowedCaller) for arc58_pluginChangeAdmin must be a address" + 1011 + ] }, { + "teal": 1000, + "source": "examples/arc58/arc58.algo.ts:260", "pc": [ - 368 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"this.txn\",\"field\":\"sender\",\"expected\":\"plugin.address\"}" + 1012, + 1013, + 1014 + ] }, { + "teal": 1001, + "source": "examples/arc58/arc58.algo.ts:260", "pc": [ - 382 - ], - "errorMessage": "This plugin is not in control of the account" + 1015 + ] }, { + "teal": 1002, + "source": "examples/arc58/arc58.algo.ts:260", "pc": [ - 411 - ], - "errorMessage": "box value does not exist: this.plugins(key).value" + 1016 + ] }, { + "teal": 1003, + "source": "examples/arc58/arc58.algo.ts:260", "pc": [ - 421 - ], - "errorMessage": "This plugin does not have admin privileges" + 1017, + 1018 + ] }, { + "teal": 1004, + "source": "examples/arc58/arc58.algo.ts:260", "pc": [ - 481 - ], - "errorMessage": "argument 0 (flash) for arc58_rekeyTo must be a bool" + 1019 + ] }, { + "teal": 1007, + "source": "examples/arc58/arc58.algo.ts:260", + "errorMessage": "argument 3 (allowedCaller) for arc58_addNamedPlugin must be a address", "pc": [ - 493 - ], - "errorMessage": "argument 1 (addr) for arc58_rekeyTo must be a address" + 1020 + ] }, { + "teal": 1010, + "source": "examples/arc58/arc58.algo.ts:259", "pc": [ - 510 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"this.txn\",\"field\":\"sender\",\"expected\":\"this.admin.value\"}" + 1021, + 1022, + 1023 + ] }, { + "teal": 1011, + "source": "examples/arc58/arc58.algo.ts:259", "pc": [ - 608 - ], - "errorMessage": "box value does not exist: this.plugins(key).value" + 1024 + ] }, { + "teal": 1014, + "source": "examples/arc58/arc58.algo.ts:258", "pc": [ - 634 - ], - "errorMessage": "box value does not exist: this.plugins(key).value" + 1025, + 1026, + 1027 + ] }, { + "teal": 1015, + "source": "examples/arc58/arc58.algo.ts:258", "pc": [ - 651 - ], - "errorMessage": "box value does not exist: this.plugins(key).value" + 1028, + 1029, + 1030 + ] }, { + "teal": 1018, + "source": "examples/arc58/arc58.algo.ts:257", "pc": [ - 702 - ], - "errorMessage": "This sender is not allowed to trigger this plugin" + 1031, + 1032, + 1033 + ] }, { + "teal": 1019, + "source": "examples/arc58/arc58.algo.ts:257", "pc": [ - 779 - ], - "errorMessage": "box value does not exist: this.plugins({ application: plugin, allowedCaller: globalAllowed ? Address.zeroAddress : this.txn.sender, }).value" + 1034, + 1035 + ] }, { + "teal": 1020, + "source": "examples/arc58/arc58.algo.ts:257", "pc": [ - 857 - ], - "errorMessage": "argument 0 (adminPrivileges) for arc58_addPlugin must be a bool" + 1036 + ] }, { + "teal": 1034, + "source": "examples/arc58/arc58.algo.ts:257", "pc": [ - 877 - ], - "errorMessage": "argument 3 (allowedCaller) for arc58_addPlugin must be a address" + 1037, + 1038, + 1039 + ] }, { + "teal": 1037, + "source": "examples/arc58/arc58.algo.ts:257", "pc": [ - 900 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"this.txn\",\"field\":\"sender\",\"expected\":\"this.admin.value\"}" + 1040, + 1041 + ] }, { + "teal": 1042, + "source": "examples/arc58/arc58.algo.ts:265", "pc": [ - 952 - ], - "errorMessage": "argument 0 (allowedCaller) for arc58_removePlugin must be a address" + 1042, + 1043 + ] }, { + "teal": 1043, + "source": "examples/arc58/arc58.algo.ts:265", "pc": [ - 975 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"this.txn\",\"field\":\"sender\",\"expected\":\"this.admin.value\"}" + 1044, + 1045, + 1046 + ] }, { + "teal": 1044, + "source": "examples/arc58/arc58.algo.ts:265", "pc": [ - 1000 - ], - "errorMessage": "argument 0 (adminPrivileges) for arc58_addNamedPlugin must be a bool" + 1047 + ] }, { + "teal": 1045, + "source": "examples/arc58/arc58.algo.ts:265", "pc": [ - 1020 - ], - "errorMessage": "argument 3 (allowedCaller) for arc58_addNamedPlugin must be a address" + 1048 + ] }, { + "teal": 1048, + "source": "examples/arc58/arc58.algo.ts:265", + "errorMessage": "transaction verification failed: {\"txn\":\"this.txn\",\"field\":\"sender\",\"expected\":\"this.admin.value\"}", "pc": [ 1049 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"this.txn\",\"field\":\"sender\",\"expected\":\"this.admin.value\"}" + ] + }, + { + "teal": 1052, + "source": "examples/arc58/arc58.algo.ts:266", + "pc": [ + 1050, + 1051, + 1052 + ] + }, + { + "teal": 1053, + "source": "examples/arc58/arc58.algo.ts:266", + "pc": [ + 1053, + 1054 + ] + }, + { + "teal": 1054, + "source": "examples/arc58/arc58.algo.ts:266", + "pc": [ + 1055 + ] + }, + { + "teal": 1055, + "source": "examples/arc58/arc58.algo.ts:266", + "pc": [ + 1056 + ] + }, + { + "teal": 1056, + "source": "examples/arc58/arc58.algo.ts:266", + "pc": [ + 1057 + ] + }, + { + "teal": 1057, + "source": "examples/arc58/arc58.algo.ts:266", + "pc": [ + 1058 + ] + }, + { + "teal": 1058, + "source": "examples/arc58/arc58.algo.ts:266", + "pc": [ + 1059 + ] + }, + { + "teal": 1059, + "source": "examples/arc58/arc58.algo.ts:266", + "pc": [ + 1060 + ] + }, + { + "teal": 1063, + "source": "examples/arc58/arc58.algo.ts:268", + "pc": [ + 1061, + 1062 + ] + }, + { + "teal": 1064, + "source": "examples/arc58/arc58.algo.ts:268", + "pc": [ + 1063 + ] + }, + { + "teal": 1065, + "source": "examples/arc58/arc58.algo.ts:268", + "pc": [ + 1064, + 1065 + ] + }, + { + "teal": 1066, + "source": "examples/arc58/arc58.algo.ts:268", + "pc": [ + 1066 + ] + }, + { + "teal": 1067, + "source": "examples/arc58/arc58.algo.ts:268", + "pc": [ + 1067, + 1068 + ] + }, + { + "teal": 1071, + "source": "examples/arc58/arc58.algo.ts:269", + "pc": [ + 1069, + 1070, + 1071 + ] + }, + { + "teal": 1072, + "source": "examples/arc58/arc58.algo.ts:269", + "pc": [ + 1072, + 1073 + ] + }, + { + "teal": 1073, + "source": "examples/arc58/arc58.algo.ts:269", + "pc": [ + 1074 + ] + }, + { + "teal": 1074, + "source": "examples/arc58/arc58.algo.ts:269", + "pc": [ + 1075, + 1076 + ] + }, + { + "teal": 1075, + "source": "examples/arc58/arc58.algo.ts:269", + "pc": [ + 1077 + ] + }, + { + "teal": 1084, + "source": "examples/arc58/arc58.algo.ts:270", + "pc": [ + 1078, + 1079, + 1080 + ] + }, + { + "teal": 1085, + "source": "examples/arc58/arc58.algo.ts:270", + "pc": [ + 1081, + 1082 + ] + }, + { + "teal": 1086, + "source": "examples/arc58/arc58.algo.ts:270", + "pc": [ + 1083 + ] + }, + { + "teal": 1087, + "source": "examples/arc58/arc58.algo.ts:271", + "pc": [ + 1084, + 1085 + ] + }, + { + "teal": 1088, + "source": "examples/arc58/arc58.algo.ts:271", + "pc": [ + 1086 + ] + }, + { + "teal": 1089, + "source": "examples/arc58/arc58.algo.ts:272", + "pc": [ + 1087, + 1088 + ] + }, + { + "teal": 1090, + "source": "examples/arc58/arc58.algo.ts:272", + "pc": [ + 1089 + ] + }, + { + "teal": 1091, + "source": "examples/arc58/arc58.algo.ts:272", + "pc": [ + 1090 + ] + }, + { + "teal": 1092, + "source": "examples/arc58/arc58.algo.ts:273", + "pc": [ + 1091, + 1092, + 1093, + 1094, + 1095, + 1096, + 1097, + 1098, + 1099, + 1100 + ] + }, + { + "teal": 1093, + "source": "examples/arc58/arc58.algo.ts:273", + "pc": [ + 1101 + ] + }, + { + "teal": 1094, + "source": "examples/arc58/arc58.algo.ts:274", + "pc": [ + 1102, + 1103, + 1104 + ] + }, + { + "teal": 1095, + "source": "examples/arc58/arc58.algo.ts:274", + "pc": [ + 1105, + 1106 + ] + }, + { + "teal": 1096, + "source": "examples/arc58/arc58.algo.ts:274", + "pc": [ + 1107, + 1108 + ] + }, + { + "teal": 1097, + "source": "examples/arc58/arc58.algo.ts:274", + "pc": [ + 1109 + ] + }, + { + "teal": 1098, + "source": "examples/arc58/arc58.algo.ts:270", + "pc": [ + 1110 + ] + }, + { + "teal": 1099, + "source": "examples/arc58/arc58.algo.ts:270", + "pc": [ + 1111 + ] + }, + { + "teal": 1100, + "source": "examples/arc58/arc58.algo.ts:257", + "pc": [ + 1112 + ] + }, + { + "teal": 1105, + "source": "examples/arc58/arc58.algo.ts:283", + "pc": [ + 1113, + 1114, + 1115 + ] + }, + { + "teal": 1106, + "source": "examples/arc58/arc58.algo.ts:283", + "pc": [ + 1116, + 1117, + 1118 + ] + }, + { + "teal": 1109, + "source": "examples/arc58/arc58.algo.ts:283", + "pc": [ + 1119, + 1120, + 1121 + ] + }, + { + "teal": 1110, + "source": "examples/arc58/arc58.algo.ts:283", + "pc": [ + 1122, + 1123 + ] + }, + { + "teal": 1111, + "source": "examples/arc58/arc58.algo.ts:283", + "pc": [ + 1124 + ] + }, + { + "teal": 1119, + "source": "examples/arc58/arc58.algo.ts:283", + "pc": [ + 1125, + 1126, + 1127 + ] + }, + { + "teal": 1122, + "source": "examples/arc58/arc58.algo.ts:283", + "pc": [ + 1128, + 1129 + ] + }, + { + "teal": 1127, + "source": "examples/arc58/arc58.algo.ts:284", + "pc": [ + 1130, + 1131 + ] + }, + { + "teal": 1128, + "source": "examples/arc58/arc58.algo.ts:284", + "pc": [ + 1132, + 1133, + 1134 + ] }, { + "teal": 1129, + "source": "examples/arc58/arc58.algo.ts:284", + "pc": [ + 1135 + ] + }, + { + "teal": 1130, + "source": "examples/arc58/arc58.algo.ts:284", + "pc": [ + 1136 + ] + }, + { + "teal": 1133, + "source": "examples/arc58/arc58.algo.ts:284", + "errorMessage": "transaction verification failed: {\"txn\":\"this.txn\",\"field\":\"sender\",\"expected\":\"this.admin.value\"}", "pc": [ 1137 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"this.txn\",\"field\":\"sender\",\"expected\":\"this.admin.value\"}" + ] + }, + { + "teal": 1137, + "source": "examples/arc58/arc58.algo.ts:286", + "pc": [ + 1138, + 1139, + 1140 + ] + }, + { + "teal": 1138, + "source": "examples/arc58/arc58.algo.ts:286", + "pc": [ + 1141, + 1142 + ] + }, + { + "teal": 1139, + "source": "examples/arc58/arc58.algo.ts:286", + "pc": [ + 1143 + ] + }, + { + "teal": 1140, + "source": "examples/arc58/arc58.algo.ts:286", + "pc": [ + 1144, + 1145 + ] + }, + { + "teal": 1144, + "source": "examples/arc58/arc58.algo.ts:287", + "pc": [ + 1146, + 1147, + 1148 + ] + }, + { + "teal": 1145, + "source": "examples/arc58/arc58.algo.ts:287", + "pc": [ + 1149, + 1150 + ] + }, + { + "teal": 1146, + "source": "examples/arc58/arc58.algo.ts:287", + "pc": [ + 1151 + ] + }, + { + "teal": 1147, + "source": "examples/arc58/arc58.algo.ts:287", + "pc": [ + 1152 + ] + }, + { + "teal": 1151, + "source": "examples/arc58/arc58.algo.ts:288", + "pc": [ + 1153, + 1154, + 1155 + ] + }, + { + "teal": 1152, + "source": "examples/arc58/arc58.algo.ts:286", + "pc": [ + 1156, + 1157 + ] }, { + "teal": 1153, + "source": "examples/arc58/arc58.algo.ts:286", + "pc": [ + 1158 + ] + }, + { + "teal": 1156, + "source": "examples/arc58/arc58.algo.ts:286", + "errorMessage": "box value does not exist: this.namedPlugins(name).value", "pc": [ 1159 - ], - "errorMessage": "box value does not exist: this.namedPlugins(name).value" + ] + }, + { + "teal": 1157, + "source": "examples/arc58/arc58.algo.ts:288", + "pc": [ + 1160 + ] + }, + { + "teal": 1158, + "source": "examples/arc58/arc58.algo.ts:288", + "pc": [ + 1161 + ] + }, + { + "teal": 1159, + "source": "examples/arc58/arc58.algo.ts:283", + "pc": [ + 1162 + ] }, { + "teal": 1162, + "source": "examples/arc58/arc58.algo.ts:21", + "pc": [ + 1163, + 1164, + 1165, + 1166, + 1167, + 1168 + ] + }, + { + "teal": 1163, + "source": "examples/arc58/arc58.algo.ts:21", + "pc": [ + 1169, + 1170, + 1171 + ] + }, + { + "teal": 1164, + "source": "examples/arc58/arc58.algo.ts:21", + "pc": [ + 1172, + 1173, + 1174, + 1175 + ] + }, + { + "teal": 1167, + "source": "examples/arc58/arc58.algo.ts:21", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 1176 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 1170, + "source": "examples/arc58/arc58.algo.ts:21", + "pc": [ + 1177, + 1178, + 1179, + 1180, + 1181, + 1182 + ] + }, + { + "teal": 1171, + "source": "examples/arc58/arc58.algo.ts:21", + "pc": [ + 1183, + 1184, + 1185, + 1186, + 1187, + 1188 + ] + }, + { + "teal": 1172, + "source": "examples/arc58/arc58.algo.ts:21", + "pc": [ + 1189, + 1190, + 1191, + 1192, + 1193, + 1194 + ] + }, + { + "teal": 1173, + "source": "examples/arc58/arc58.algo.ts:21", + "pc": [ + 1195, + 1196, + 1197, + 1198, + 1199, + 1200 + ] + }, + { + "teal": 1174, + "source": "examples/arc58/arc58.algo.ts:21", + "pc": [ + 1201, + 1202, + 1203, + 1204, + 1205, + 1206 + ] + }, + { + "teal": 1175, + "source": "examples/arc58/arc58.algo.ts:21", + "pc": [ + 1207, + 1208, + 1209, + 1210, + 1211, + 1212 + ] + }, + { + "teal": 1176, + "source": "examples/arc58/arc58.algo.ts:21", + "pc": [ + 1213, + 1214, + 1215, + 1216, + 1217, + 1218 + ] + }, + { + "teal": 1177, + "source": "examples/arc58/arc58.algo.ts:21", + "pc": [ + 1219, + 1220, + 1221, + 1222, + 1223, + 1224 + ] + }, + { + "teal": 1178, + "source": "examples/arc58/arc58.algo.ts:21", + "pc": [ + 1225, + 1226, + 1227, + 1228, + 1229, + 1230 + ] + }, + { + "teal": 1179, + "source": "examples/arc58/arc58.algo.ts:21", + "pc": [ + 1231, + 1232, + 1233, + 1234, + 1235, + 1236 + ] + }, + { + "teal": 1180, + "source": "examples/arc58/arc58.algo.ts:21", + "pc": [ + 1237, + 1238, + 1239, + 1240, + 1241, + 1242 + ] + }, + { + "teal": 1181, + "source": "examples/arc58/arc58.algo.ts:21", + "pc": [ + 1243, + 1244, + 1245 + ] + }, + { + "teal": 1182, + "source": "examples/arc58/arc58.algo.ts:21", + "pc": [ + 1246, + 1247, + 1248, + 1249, + 1250, + 1251, + 1252, + 1253, + 1254, + 1255, + 1256, + 1257, + 1258, + 1259, + 1260, + 1261, + 1262, + 1263, + 1264, + 1265, + 1266, + 1267, + 1268, + 1269 + ] }, { + "teal": 1185, + "source": "examples/arc58/arc58.algo.ts:21", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 1270 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/examples/arc72/artifacts/ARC72.arc56_draft.json b/examples/arc72/artifacts/ARC72.arc56_draft.json index 0cf68d042..0597ae530 100644 --- a/examples/arc72/artifacts/ARC72.arc56_draft.json +++ b/examples/arc72/artifacts/ARC72.arc56_draft.json @@ -265,112 +265,2761 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "examples/arc72/arc72.algo.ts:9", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "examples/arc72/arc72.algo.ts:9", + "pc": [ + 1, + 2, + 3, + 4, + 5, + 6 + ] + }, + { + "teal": 3, + "source": "examples/arc72/arc72.algo.ts:9", + "pc": [ + 7, + 8, + 9, + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38, + 39, + 40, + 41, + 42, + 43, + 44, + 45, + 46, + 47, + 48, + 49, + 50, + 51, + 52, + 53 + ] + }, + { + "teal": 15, + "source": "examples/arc72/arc72.algo.ts:9", + "pc": [ + 54, + 55 + ] + }, + { + "teal": 16, + "source": "examples/arc72/arc72.algo.ts:9", + "pc": [ + 56 + ] + }, + { + "teal": 17, + "source": "examples/arc72/arc72.algo.ts:9", + "pc": [ + 57, + 58 + ] + }, + { + "teal": 18, + "source": "examples/arc72/arc72.algo.ts:9", + "pc": [ + 59 + ] + }, + { + "teal": 19, + "source": "examples/arc72/arc72.algo.ts:9", + "pc": [ + 60, + 61 + ] + }, + { + "teal": 20, + "source": "examples/arc72/arc72.algo.ts:9", + "pc": [ + 62 + ] + }, + { + "teal": 21, + "source": "examples/arc72/arc72.algo.ts:9", + "pc": [ + 63, + 64, + 65, + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82, + 83, + 84, + 85, + 86, + 87, + 88 + ] + }, + { + "teal": 25, + "source": "examples/arc72/arc72.algo.ts:9", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 89 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 30, + "source": "examples/arc72/arc72.algo.ts:23", + "pc": [ + 90, + 91, + 92, + 93, + 94, + 95 + ] + }, + { + "teal": 33, + "source": "examples/arc72/arc72.algo.ts:24", + "pc": [ + 96, + 97, + 98 + ] + }, + { + "teal": 34, + "source": "examples/arc72/arc72.algo.ts:24", + "pc": [ + 99 + ] + }, + { + "teal": 35, + "source": "examples/arc72/arc72.algo.ts:24", + "pc": [ + 100 + ] + }, + { + "teal": 36, + "source": "examples/arc72/arc72.algo.ts:24", + "pc": [ + 101, + 102 + ] + }, + { + "teal": 37, + "source": "examples/arc72/arc72.algo.ts:24", + "pc": [ + 103 + ] }, { + "teal": 40, + "source": "examples/arc72/arc72.algo.ts:24", + "errorMessage": "argument 0 (tokenId) for arc72_ownerOf must be a uint256", "pc": [ 104 - ], - "errorMessage": "argument 0 (tokenId) for arc72_ownerOf must be a uint256" + ] + }, + { + "teal": 43, + "source": "examples/arc72/arc72.algo.ts:23", + "pc": [ + 105, + 106, + 107 + ] + }, + { + "teal": 44, + "source": "examples/arc72/arc72.algo.ts:23", + "pc": [ + 108 + ] + }, + { + "teal": 45, + "source": "examples/arc72/arc72.algo.ts:23", + "pc": [ + 109 + ] + }, + { + "teal": 46, + "source": "examples/arc72/arc72.algo.ts:23", + "pc": [ + 110, + 111 + ] + }, + { + "teal": 47, + "source": "examples/arc72/arc72.algo.ts:23", + "pc": [ + 112 + ] + }, + { + "teal": 57, + "source": "examples/arc72/arc72.algo.ts:23", + "pc": [ + 113, + 114, + 115 + ] + }, + { + "teal": 61, + "source": "examples/arc72/arc72.algo.ts:25", + "pc": [ + 116, + 117 + ] + }, + { + "teal": 62, + "source": "examples/arc72/arc72.algo.ts:25", + "pc": [ + 118, + 119 + ] + }, + { + "teal": 63, + "source": "examples/arc72/arc72.algo.ts:25", + "pc": [ + 120, + 121 + ] + }, + { + "teal": 64, + "source": "examples/arc72/arc72.algo.ts:25", + "pc": [ + 122 + ] + }, + { + "teal": 65, + "source": "examples/arc72/arc72.algo.ts:23", + "pc": [ + 123 + ] + }, + { + "teal": 70, + "source": "examples/arc72/arc72.algo.ts:35", + "pc": [ + 124, + 125, + 126, + 127, + 128, + 129 + ] + }, + { + "teal": 73, + "source": "examples/arc72/arc72.algo.ts:36", + "pc": [ + 130, + 131, + 132 + ] + }, + { + "teal": 74, + "source": "examples/arc72/arc72.algo.ts:36", + "pc": [ + 133 + ] + }, + { + "teal": 75, + "source": "examples/arc72/arc72.algo.ts:36", + "pc": [ + 134 + ] + }, + { + "teal": 76, + "source": "examples/arc72/arc72.algo.ts:36", + "pc": [ + 135, + 136 + ] }, { + "teal": 77, + "source": "examples/arc72/arc72.algo.ts:36", + "pc": [ + 137 + ] + }, + { + "teal": 80, + "source": "examples/arc72/arc72.algo.ts:36", + "errorMessage": "argument 0 (tokenId) for arc72_tokenURI must be a uint256", "pc": [ 138 - ], - "errorMessage": "argument 0 (tokenId) for arc72_tokenURI must be a uint256" + ] + }, + { + "teal": 83, + "source": "examples/arc72/arc72.algo.ts:35", + "pc": [ + 139, + 140, + 141 + ] + }, + { + "teal": 84, + "source": "examples/arc72/arc72.algo.ts:35", + "pc": [ + 142 + ] + }, + { + "teal": 85, + "source": "examples/arc72/arc72.algo.ts:35", + "pc": [ + 143 + ] + }, + { + "teal": 86, + "source": "examples/arc72/arc72.algo.ts:35", + "pc": [ + 144, + 145 + ] + }, + { + "teal": 87, + "source": "examples/arc72/arc72.algo.ts:35", + "pc": [ + 146 + ] + }, + { + "teal": 97, + "source": "examples/arc72/arc72.algo.ts:35", + "pc": [ + 147, + 148, + 149 + ] + }, + { + "teal": 101, + "source": "examples/arc72/arc72.algo.ts:37", + "pc": [ + 150, + 151 + ] + }, + { + "teal": 102, + "source": "examples/arc72/arc72.algo.ts:37", + "pc": [ + 152, + 153 + ] + }, + { + "teal": 103, + "source": "examples/arc72/arc72.algo.ts:37", + "pc": [ + 154, + 155, + 156 + ] + }, + { + "teal": 104, + "source": "examples/arc72/arc72.algo.ts:37", + "pc": [ + 157 + ] + }, + { + "teal": 105, + "source": "examples/arc72/arc72.algo.ts:35", + "pc": [ + 158 + ] + }, + { + "teal": 109, + "source": "examples/arc72/arc72.algo.ts:40", + "pc": [ + 159, + 160, + 161 + ] + }, + { + "teal": 113, + "source": "examples/arc72/arc72.algo.ts:41", + "pc": [ + 162, + 163 + ] + }, + { + "teal": 114, + "source": "examples/arc72/arc72.algo.ts:41", + "pc": [ + 164, + 165 + ] + }, + { + "teal": 115, + "source": "examples/arc72/arc72.algo.ts:41", + "pc": [ + 166, + 167 + ] + }, + { + "teal": 116, + "source": "examples/arc72/arc72.algo.ts:41", + "pc": [ + 168 + ] + }, + { + "teal": 117, + "source": "examples/arc72/arc72.algo.ts:40", + "pc": [ + 169 + ] + }, + { + "teal": 122, + "source": "examples/arc72/arc72.algo.ts:47", + "pc": [ + 170, + 171, + 172 + ] + }, + { + "teal": 123, + "source": "examples/arc72/arc72.algo.ts:47", + "pc": [ + 173 + ] + }, + { + "teal": 124, + "source": "examples/arc72/arc72.algo.ts:47", + "pc": [ + 174 + ] + }, + { + "teal": 125, + "source": "examples/arc72/arc72.algo.ts:47", + "pc": [ + 175, + 176 + ] + }, + { + "teal": 126, + "source": "examples/arc72/arc72.algo.ts:47", + "pc": [ + 177 + ] }, { + "teal": 129, + "source": "examples/arc72/arc72.algo.ts:47", + "errorMessage": "argument 0 (tokenId) for arc72_transferFrom must be a uint256", "pc": [ 178 - ], - "errorMessage": "argument 0 (tokenId) for arc72_transferFrom must be a uint256" + ] + }, + { + "teal": 132, + "source": "examples/arc72/arc72.algo.ts:47", + "pc": [ + 179, + 180, + 181 + ] + }, + { + "teal": 133, + "source": "examples/arc72/arc72.algo.ts:47", + "pc": [ + 182 + ] + }, + { + "teal": 134, + "source": "examples/arc72/arc72.algo.ts:47", + "pc": [ + 183 + ] + }, + { + "teal": 135, + "source": "examples/arc72/arc72.algo.ts:47", + "pc": [ + 184, + 185 + ] + }, + { + "teal": 136, + "source": "examples/arc72/arc72.algo.ts:47", + "pc": [ + 186 + ] }, { + "teal": 139, + "source": "examples/arc72/arc72.algo.ts:47", + "errorMessage": "argument 1 (to) for arc72_transferFrom must be a address", "pc": [ 187 - ], - "errorMessage": "argument 1 (to) for arc72_transferFrom must be a address" + ] + }, + { + "teal": 142, + "source": "examples/arc72/arc72.algo.ts:47", + "pc": [ + 188, + 189, + 190 + ] + }, + { + "teal": 143, + "source": "examples/arc72/arc72.algo.ts:47", + "pc": [ + 191 + ] + }, + { + "teal": 144, + "source": "examples/arc72/arc72.algo.ts:47", + "pc": [ + 192 + ] + }, + { + "teal": 145, + "source": "examples/arc72/arc72.algo.ts:47", + "pc": [ + 193, + 194 + ] }, { + "teal": 146, + "source": "examples/arc72/arc72.algo.ts:47", + "pc": [ + 195 + ] + }, + { + "teal": 149, + "source": "examples/arc72/arc72.algo.ts:47", + "errorMessage": "argument 2 (_from) for arc72_transferFrom must be a address", "pc": [ 196 - ], - "errorMessage": "argument 2 (_from) for arc72_transferFrom must be a address" + ] }, { + "teal": 152, + "source": "examples/arc72/arc72.algo.ts:47", "pc": [ - 264 - ], - "errorMessage": "Transfer not authorized" + 197, + 198, + 199 + ] }, { + "teal": 153, + "source": "examples/arc72/arc72.algo.ts:47", "pc": [ - 274 - ], - "errorMessage": "argument 0 (tokenId) for arc72_approve must be a uint256" + 200, + 201 + ] }, { + "teal": 154, + "source": "examples/arc72/arc72.algo.ts:47", "pc": [ - 283 - ], - "errorMessage": "argument 1 (approved) for arc72_approve must be a address" + 202 + ] }, { + "teal": 160, + "source": "examples/arc72/arc72.algo.ts:47", "pc": [ - 310 - ], - "errorMessage": "argument 0 (approved) for arc72_setApprovalForAll must be a bool" + 203, + 204, + 205 + ] }, { + "teal": 163, + "source": "examples/arc72/arc72.algo.ts:47", "pc": [ - 322 - ], - "errorMessage": "argument 1 (operator) for arc72_setApprovalForAll must be a address" + 206, + 207 + ] }, { + "teal": 164, + "source": "examples/arc72/arc72.algo.ts:47", "pc": [ - 377 - ], - "errorMessage": "argument 0 (to) for mint must be a address" + 208 + ] }, { + "teal": 168, + "source": "examples/arc72/arc72.algo.ts:48", "pc": [ - 729 - ], - "errorMessage": "index + 1 overflowed 256 bits" + 209, + 210 + ] }, { + "teal": 169, + "source": "examples/arc72/arc72.algo.ts:48", "pc": [ - 790 - ], - "errorMessage": "arc72_totalSupply return value overflowed 256 bits" + 211, + 212 + ] }, { + "teal": 173, + "source": "examples/arc72/arc72.algo.ts:50", "pc": [ - 865 - ], - "errorMessage": "argument 0 (index) for arc72_tokenByIndex must be a uint256" + 213, + 214 + ] }, { + "teal": 174, + "source": "examples/arc72/arc72.algo.ts:50", "pc": [ - 875 - ], - "errorMessage": "arc72_tokenByIndex return value overflowed 256 bits" + 215, + 216 + ] }, { + "teal": 175, + "source": "examples/arc72/arc72.algo.ts:50", "pc": [ - 946 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + 217 + ] + }, + { + "teal": 176, + "source": "examples/arc72/arc72.algo.ts:50", + "pc": [ + 218, + 219 + ] + }, + { + "teal": 181, + "source": "examples/arc72/arc72.algo.ts:52", + "pc": [ + 220, + 221 + ] + }, + { + "teal": 182, + "source": "examples/arc72/arc72.algo.ts:52", + "pc": [ + 222, + 223 + ] + }, + { + "teal": 183, + "source": "examples/arc72/arc72.algo.ts:52", + "pc": [ + 224 + ] + }, + { + "teal": 184, + "source": "examples/arc72/arc72.algo.ts:52", + "pc": [ + 225 + ] + }, + { + "teal": 185, + "source": "examples/arc72/arc72.algo.ts:52", + "pc": [ + 226, + 227, + 228 + ] + }, + { + "teal": 186, + "source": "examples/arc72/arc72.algo.ts:52", + "pc": [ + 229, + 230 + ] + }, + { + "teal": 187, + "source": "examples/arc72/arc72.algo.ts:48", + "pc": [ + 231, + 232 + ] + }, + { + "teal": 188, + "source": "examples/arc72/arc72.algo.ts:48", + "pc": [ + 233, + 234, + 235 + ] + }, + { + "teal": 189, + "source": "examples/arc72/arc72.algo.ts:48", + "pc": [ + 236, + 237 + ] + }, + { + "teal": 190, + "source": "examples/arc72/arc72.algo.ts:48", + "pc": [ + 238 + ] + }, + { + "teal": 191, + "source": "examples/arc72/arc72.algo.ts:52", + "pc": [ + 239 + ] + }, + { + "teal": 192, + "source": "examples/arc72/arc72.algo.ts:52", + "pc": [ + 240 + ] + }, + { + "teal": 195, + "source": "examples/arc72/arc72.algo.ts:52", + "pc": [ + 241 + ] + }, + { + "teal": 196, + "source": "examples/arc72/arc72.algo.ts:52", + "pc": [ + 242, + 243, + 244 + ] + }, + { + "teal": 197, + "source": "examples/arc72/arc72.algo.ts:52", + "pc": [ + 245, + 246 + ] + }, + { + "teal": 198, + "source": "examples/arc72/arc72.algo.ts:52", + "pc": [ + 247 + ] + }, + { + "teal": 199, + "source": "examples/arc72/arc72.algo.ts:52", + "pc": [ + 248 + ] + }, + { + "teal": 200, + "source": "examples/arc72/arc72.algo.ts:52", + "pc": [ + 249 + ] + }, + { + "teal": 201, + "source": "examples/arc72/arc72.algo.ts:52", + "pc": [ + 250 + ] + }, + { + "teal": 204, + "source": "examples/arc72/arc72.algo.ts:52", + "pc": [ + 251, + 252, + 253 + ] + }, + { + "teal": 209, + "source": "examples/arc72/arc72.algo.ts:53", + "pc": [ + 254, + 255 + ] + }, + { + "teal": 210, + "source": "examples/arc72/arc72.algo.ts:53", + "pc": [ + 256, + 257 + ] + }, + { + "teal": 211, + "source": "examples/arc72/arc72.algo.ts:53", + "pc": [ + 258, + 259, + 260 + ] + }, + { + "teal": 212, + "source": "examples/arc72/arc72.algo.ts:52", + "pc": [ + 261, + 262, + 263 + ] + }, + { + "teal": 216, + "source": "examples/arc72/arc72.algo.ts:54", + "errorMessage": "Transfer not authorized", + "pc": [ + 264 + ] + }, + { + "teal": 219, + "source": "examples/arc72/arc72.algo.ts:47", + "pc": [ + 265 + ] + }, + { + "teal": 224, + "source": "examples/arc72/arc72.algo.ts:64", + "pc": [ + 266, + 267, + 268 + ] + }, + { + "teal": 225, + "source": "examples/arc72/arc72.algo.ts:64", + "pc": [ + 269 + ] + }, + { + "teal": 226, + "source": "examples/arc72/arc72.algo.ts:64", + "pc": [ + 270 + ] + }, + { + "teal": 227, + "source": "examples/arc72/arc72.algo.ts:64", + "pc": [ + 271, + 272 + ] + }, + { + "teal": 228, + "source": "examples/arc72/arc72.algo.ts:64", + "pc": [ + 273 + ] + }, + { + "teal": 231, + "source": "examples/arc72/arc72.algo.ts:64", + "errorMessage": "argument 0 (tokenId) for arc72_approve must be a uint256", + "pc": [ + 274 + ] + }, + { + "teal": 234, + "source": "examples/arc72/arc72.algo.ts:64", + "pc": [ + 275, + 276, + 277 + ] + }, + { + "teal": 235, + "source": "examples/arc72/arc72.algo.ts:64", + "pc": [ + 278 + ] + }, + { + "teal": 236, + "source": "examples/arc72/arc72.algo.ts:64", + "pc": [ + 279 + ] + }, + { + "teal": 237, + "source": "examples/arc72/arc72.algo.ts:64", + "pc": [ + 280, + 281 + ] + }, + { + "teal": 238, + "source": "examples/arc72/arc72.algo.ts:64", + "pc": [ + 282 + ] + }, + { + "teal": 241, + "source": "examples/arc72/arc72.algo.ts:64", + "errorMessage": "argument 1 (approved) for arc72_approve must be a address", + "pc": [ + 283 + ] + }, + { + "teal": 244, + "source": "examples/arc72/arc72.algo.ts:64", + "pc": [ + 284, + 285, + 286 + ] + }, + { + "teal": 245, + "source": "examples/arc72/arc72.algo.ts:64", + "pc": [ + 287, + 288 + ] + }, + { + "teal": 246, + "source": "examples/arc72/arc72.algo.ts:64", + "pc": [ + 289 + ] + }, + { + "teal": 256, + "source": "examples/arc72/arc72.algo.ts:64", + "pc": [ + 290, + 291, + 292 + ] + }, + { + "teal": 260, + "source": "examples/arc72/arc72.algo.ts:65", + "pc": [ + 293, + 294 + ] + }, + { + "teal": 261, + "source": "examples/arc72/arc72.algo.ts:65", + "pc": [ + 295, + 296, + 297 + ] + }, + { + "teal": 262, + "source": "examples/arc72/arc72.algo.ts:65", + "pc": [ + 298, + 299 + ] + }, + { + "teal": 263, + "source": "examples/arc72/arc72.algo.ts:65", + "pc": [ + 300 + ] + }, + { + "teal": 264, + "source": "examples/arc72/arc72.algo.ts:64", + "pc": [ + 301 + ] + }, + { + "teal": 269, + "source": "examples/arc72/arc72.algo.ts:76", + "pc": [ + 302, + 303, + 304 + ] + }, + { + "teal": 270, + "source": "examples/arc72/arc72.algo.ts:76", + "pc": [ + 305 + ] + }, + { + "teal": 271, + "source": "examples/arc72/arc72.algo.ts:76", + "pc": [ + 306 + ] + }, + { + "teal": 272, + "source": "examples/arc72/arc72.algo.ts:76", + "pc": [ + 307, + 308 + ] + }, + { + "teal": 273, + "source": "examples/arc72/arc72.algo.ts:76", + "pc": [ + 309 + ] + }, + { + "teal": 276, + "source": "examples/arc72/arc72.algo.ts:76", + "errorMessage": "argument 0 (approved) for arc72_setApprovalForAll must be a bool", + "pc": [ + 310 + ] + }, + { + "teal": 277, + "source": "examples/arc72/arc72.algo.ts:76", + "pc": [ + 311, + 312 + ] + }, + { + "teal": 278, + "source": "examples/arc72/arc72.algo.ts:76", + "pc": [ + 313 + ] + }, + { + "teal": 281, + "source": "examples/arc72/arc72.algo.ts:76", + "pc": [ + 314, + 315, + 316 + ] + }, + { + "teal": 282, + "source": "examples/arc72/arc72.algo.ts:76", + "pc": [ + 317 + ] + }, + { + "teal": 283, + "source": "examples/arc72/arc72.algo.ts:76", + "pc": [ + 318 + ] + }, + { + "teal": 284, + "source": "examples/arc72/arc72.algo.ts:76", + "pc": [ + 319, + 320 + ] + }, + { + "teal": 285, + "source": "examples/arc72/arc72.algo.ts:76", + "pc": [ + 321 + ] + }, + { + "teal": 288, + "source": "examples/arc72/arc72.algo.ts:76", + "errorMessage": "argument 1 (operator) for arc72_setApprovalForAll must be a address", + "pc": [ + 322 + ] + }, + { + "teal": 291, + "source": "examples/arc72/arc72.algo.ts:76", + "pc": [ + 323, + 324, + 325 + ] + }, + { + "teal": 292, + "source": "examples/arc72/arc72.algo.ts:76", + "pc": [ + 326, + 327 + ] + }, + { + "teal": 293, + "source": "examples/arc72/arc72.algo.ts:76", + "pc": [ + 328 + ] + }, + { + "teal": 304, + "source": "examples/arc72/arc72.algo.ts:76", + "pc": [ + 329, + 330, + 331 + ] + }, + { + "teal": 307, + "source": "examples/arc72/arc72.algo.ts:76", + "pc": [ + 332, + 333 + ] + }, + { + "teal": 311, + "source": "examples/arc72/arc72.algo.ts:77", + "pc": [ + 334, + 335 + ] + }, + { + "teal": 312, + "source": "examples/arc72/arc72.algo.ts:77", + "pc": [ + 336, + 337 + ] + }, + { + "teal": 313, + "source": "examples/arc72/arc72.algo.ts:77", + "pc": [ + 338 + ] + }, + { + "teal": 314, + "source": "examples/arc72/arc72.algo.ts:77", + "pc": [ + 339, + 340 + ] + }, + { + "teal": 319, + "source": "examples/arc72/arc72.algo.ts:79", + "pc": [ + 341, + 342 + ] + }, + { + "teal": 320, + "source": "examples/arc72/arc72.algo.ts:79", + "pc": [ + 343, + 344, + 345 + ] + }, + { + "teal": 325, + "source": "examples/arc72/arc72.algo.ts:79", + "pc": [ + 346, + 347 + ] + }, + { + "teal": 326, + "source": "examples/arc72/arc72.algo.ts:79", + "pc": [ + 348 + ] + }, + { + "teal": 327, + "source": "examples/arc72/arc72.algo.ts:79", + "pc": [ + 349 + ] + }, + { + "teal": 328, + "source": "examples/arc72/arc72.algo.ts:79", + "pc": [ + 350 + ] + }, + { + "teal": 329, + "source": "examples/arc72/arc72.algo.ts:79", + "pc": [ + 351, + 352 + ] + }, + { + "teal": 330, + "source": "examples/arc72/arc72.algo.ts:79", + "pc": [ + 353 + ] + }, + { + "teal": 331, + "source": "examples/arc72/arc72.algo.ts:79", + "pc": [ + 354, + 355, + 356 + ] + }, + { + "teal": 336, + "source": "examples/arc72/arc72.algo.ts:80", + "pc": [ + 357, + 358 + ] + }, + { + "teal": 337, + "source": "examples/arc72/arc72.algo.ts:80", + "pc": [ + 359 + ] + }, + { + "teal": 338, + "source": "examples/arc72/arc72.algo.ts:80", + "pc": [ + 360 + ] + }, + { + "teal": 339, + "source": "examples/arc72/arc72.algo.ts:80", + "pc": [ + 361 + ] + }, + { + "teal": 340, + "source": "examples/arc72/arc72.algo.ts:80", + "pc": [ + 362, + 363, + 364 + ] + }, + { + "teal": 345, + "source": "examples/arc72/arc72.algo.ts:80", + "pc": [ + 365, + 366 + ] + }, + { + "teal": 346, + "source": "examples/arc72/arc72.algo.ts:80", + "pc": [ + 367 + ] + }, + { + "teal": 349, + "source": "examples/arc72/arc72.algo.ts:76", + "pc": [ + 368 + ] + }, + { + "teal": 354, + "source": "examples/arc72/arc72.algo.ts:83", + "pc": [ + 369, + 370, + 371 + ] + }, + { + "teal": 355, + "source": "examples/arc72/arc72.algo.ts:83", + "pc": [ + 372 + ] + }, + { + "teal": 356, + "source": "examples/arc72/arc72.algo.ts:83", + "pc": [ + 373 + ] + }, + { + "teal": 357, + "source": "examples/arc72/arc72.algo.ts:83", + "pc": [ + 374, + 375 + ] + }, + { + "teal": 358, + "source": "examples/arc72/arc72.algo.ts:83", + "pc": [ + 376 + ] + }, + { + "teal": 361, + "source": "examples/arc72/arc72.algo.ts:83", + "errorMessage": "argument 0 (to) for mint must be a address", + "pc": [ + 377 + ] + }, + { + "teal": 364, + "source": "examples/arc72/arc72.algo.ts:83", + "pc": [ + 378, + 379, + 380 + ] + }, + { + "teal": 365, + "source": "examples/arc72/arc72.algo.ts:83", + "pc": [ + 381, + 382 + ] + }, + { + "teal": 366, + "source": "examples/arc72/arc72.algo.ts:83", + "pc": [ + 383 + ] + }, + { + "teal": 370, + "source": "examples/arc72/arc72.algo.ts:83", + "pc": [ + 384, + 385, + 386 + ] + }, + { + "teal": 373, + "source": "examples/arc72/arc72.algo.ts:83", + "pc": [ + 387, + 388 + ] + }, + { + "teal": 374, + "source": "examples/arc72/arc72.algo.ts:83", + "pc": [ + 389 + ] + }, + { + "teal": 378, + "source": "examples/arc72/arc72.algo.ts:84", + "pc": [ + 390, + 391, + 392, + 393, + 394, + 395, + 396 + ] + }, + { + "teal": 379, + "source": "examples/arc72/arc72.algo.ts:84", + "pc": [ + 397 + ] + }, + { + "teal": 380, + "source": "examples/arc72/arc72.algo.ts:84", + "pc": [ + 398, + 399 + ] + }, + { + "teal": 388, + "source": "examples/arc72/arc72.algo.ts:87", + "pc": [ + 400, + 401 + ] + }, + { + "teal": 389, + "source": "examples/arc72/arc72.algo.ts:88", + "pc": [ + 402, + 403, + 404, + 405, + 406, + 407, + 408, + 409, + 410, + 411, + 412, + 413, + 414, + 415, + 416, + 417, + 418, + 419, + 420, + 421, + 422, + 423, + 424, + 425, + 426, + 427, + 428, + 429, + 430, + 431, + 432, + 433, + 434, + 435, + 436, + 437, + 438, + 439, + 440, + 441, + 442, + 443, + 444, + 445, + 446, + 447, + 448, + 449, + 450, + 451, + 452, + 453, + 454, + 455, + 456, + 457, + 458, + 459, + 460, + 461, + 462, + 463, + 464, + 465, + 466, + 467, + 468, + 469, + 470, + 471, + 472, + 473, + 474, + 475, + 476, + 477, + 478, + 479, + 480, + 481, + 482, + 483, + 484, + 485, + 486, + 487, + 488, + 489, + 490, + 491, + 492, + 493, + 494, + 495, + 496, + 497, + 498, + 499, + 500, + 501, + 502, + 503, + 504, + 505, + 506, + 507, + 508, + 509, + 510, + 511, + 512, + 513, + 514, + 515, + 516, + 517, + 518, + 519, + 520, + 521, + 522, + 523, + 524, + 525, + 526, + 527, + 528, + 529, + 530, + 531, + 532, + 533, + 534, + 535, + 536, + 537, + 538, + 539, + 540, + 541, + 542, + 543, + 544, + 545, + 546, + 547, + 548, + 549, + 550, + 551, + 552, + 553, + 554, + 555, + 556, + 557, + 558, + 559, + 560, + 561, + 562, + 563, + 564, + 565, + 566, + 567, + 568, + 569, + 570, + 571, + 572, + 573, + 574, + 575, + 576, + 577, + 578, + 579, + 580, + 581, + 582, + 583, + 584, + 585, + 586, + 587, + 588, + 589, + 590, + 591, + 592, + 593, + 594, + 595, + 596, + 597, + 598, + 599, + 600, + 601, + 602, + 603, + 604, + 605, + 606, + 607, + 608, + 609, + 610, + 611, + 612, + 613, + 614, + 615, + 616, + 617, + 618, + 619, + 620, + 621, + 622, + 623, + 624, + 625, + 626, + 627, + 628, + 629, + 630, + 631, + 632, + 633, + 634, + 635, + 636, + 637, + 638, + 639, + 640, + 641, + 642, + 643, + 644, + 645, + 646, + 647, + 648, + 649, + 650, + 651, + 652, + 653, + 654, + 655, + 656, + 657, + 658, + 659, + 660 + ] + }, + { + "teal": 390, + "source": "examples/arc72/arc72.algo.ts:88", + "pc": [ + 661 + ] + }, + { + "teal": 391, + "source": "examples/arc72/arc72.algo.ts:89", + "pc": [ + 662, + 663 + ] + }, + { + "teal": 392, + "source": "examples/arc72/arc72.algo.ts:89", + "pc": [ + 664 + ] + }, + { + "teal": 393, + "source": "examples/arc72/arc72.algo.ts:86", + "pc": [ + 665, + 666 + ] + }, + { + "teal": 397, + "source": "examples/arc72/arc72.algo.ts:92", + "pc": [ + 667, + 668 + ] + }, + { + "teal": 398, + "source": "examples/arc72/arc72.algo.ts:92", + "pc": [ + 669, + 670 + ] + }, + { + "teal": 399, + "source": "examples/arc72/arc72.algo.ts:92", + "pc": [ + 671 + ] + }, + { + "teal": 403, + "source": "examples/arc72/arc72.algo.ts:93", + "pc": [ + 672, + 673 + ] + }, + { + "teal": 404, + "source": "examples/arc72/arc72.algo.ts:93", + "pc": [ + 674, + 675 + ] + }, + { + "teal": 405, + "source": "examples/arc72/arc72.algo.ts:93", + "pc": [ + 676, + 677, + 678 + ] + }, + { + "teal": 409, + "source": "examples/arc72/arc72.algo.ts:94", + "pc": [ + 679, + 680, + 681, + 682, + 683, + 684, + 685 + ] + }, + { + "teal": 410, + "source": "examples/arc72/arc72.algo.ts:94", + "pc": [ + 686, + 687 + ] + }, + { + "teal": 411, + "source": "examples/arc72/arc72.algo.ts:94", + "pc": [ + 688, + 689, + 690, + 691, + 692, + 693, + 694, + 695, + 696, + 697, + 698, + 699, + 700, + 701, + 702, + 703, + 704, + 705, + 706, + 707, + 708, + 709, + 710, + 711, + 712, + 713, + 714, + 715, + 716, + 717, + 718, + 719, + 720, + 721 + ] + }, + { + "teal": 412, + "source": "examples/arc72/arc72.algo.ts:94", + "pc": [ + 722 + ] + }, + { + "teal": 413, + "source": "examples/arc72/arc72.algo.ts:94", + "pc": [ + 723 + ] + }, + { + "teal": 414, + "source": "examples/arc72/arc72.algo.ts:94", + "pc": [ + 724 + ] + }, + { + "teal": 415, + "source": "examples/arc72/arc72.algo.ts:94", + "pc": [ + 725, + 726, + 727 + ] + }, + { + "teal": 416, + "source": "examples/arc72/arc72.algo.ts:94", + "pc": [ + 728 + ] + }, + { + "teal": 419, + "source": "examples/arc72/arc72.algo.ts:94", + "errorMessage": "index + 1 overflowed 256 bits", + "pc": [ + 729 + ] + }, + { + "teal": 420, + "source": "examples/arc72/arc72.algo.ts:94", + "pc": [ + 730, + 731, + 732, + 733, + 734, + 735, + 736, + 737, + 738, + 739, + 740, + 741, + 742, + 743, + 744, + 745, + 746, + 747, + 748, + 749, + 750, + 751, + 752, + 753, + 754, + 755, + 756, + 757, + 758, + 759, + 760, + 761, + 762, + 763 + ] + }, + { + "teal": 421, + "source": "examples/arc72/arc72.algo.ts:94", + "pc": [ + 764 + ] + }, + { + "teal": 422, + "source": "examples/arc72/arc72.algo.ts:94", + "pc": [ + 765 + ] + }, + { + "teal": 423, + "source": "examples/arc72/arc72.algo.ts:94", + "pc": [ + 766 + ] + }, + { + "teal": 424, + "source": "examples/arc72/arc72.algo.ts:94", + "pc": [ + 767 + ] + }, + { + "teal": 425, + "source": "examples/arc72/arc72.algo.ts:94", + "pc": [ + 768, + 769 + ] + }, + { + "teal": 426, + "source": "examples/arc72/arc72.algo.ts:94", + "pc": [ + 770 + ] + }, + { + "teal": 427, + "source": "examples/arc72/arc72.algo.ts:94", + "pc": [ + 771 + ] + }, + { + "teal": 428, + "source": "examples/arc72/arc72.algo.ts:94", + "pc": [ + 772 + ] + }, + { + "teal": 429, + "source": "examples/arc72/arc72.algo.ts:94", + "pc": [ + 773 + ] + }, + { + "teal": 430, + "source": "examples/arc72/arc72.algo.ts:83", + "pc": [ + 774 + ] + }, + { + "teal": 435, + "source": "examples/arc72/arc72.algo.ts:100", + "pc": [ + 775, + 776, + 777, + 778, + 779, + 780 + ] + }, + { + "teal": 438, + "source": "examples/arc72/arc72.algo.ts:100", + "pc": [ + 781, + 782, + 783 + ] + }, + { + "teal": 439, + "source": "examples/arc72/arc72.algo.ts:100", + "pc": [ + 784 + ] + }, + { + "teal": 440, + "source": "examples/arc72/arc72.algo.ts:100", + "pc": [ + 785 + ] + }, + { + "teal": 441, + "source": "examples/arc72/arc72.algo.ts:100", + "pc": [ + 786, + 787, + 788 + ] + }, + { + "teal": 442, + "source": "examples/arc72/arc72.algo.ts:100", + "pc": [ + 789 + ] + }, + { + "teal": 445, + "source": "examples/arc72/arc72.algo.ts:100", + "errorMessage": "arc72_totalSupply return value overflowed 256 bits", + "pc": [ + 790 + ] + }, + { + "teal": 446, + "source": "examples/arc72/arc72.algo.ts:100", + "pc": [ + 791, + 792, + 793, + 794, + 795, + 796, + 797, + 798, + 799, + 800, + 801, + 802, + 803, + 804, + 805, + 806, + 807, + 808, + 809, + 810, + 811, + 812, + 813, + 814, + 815, + 816, + 817, + 818, + 819, + 820, + 821, + 822, + 823, + 824 + ] + }, + { + "teal": 447, + "source": "examples/arc72/arc72.algo.ts:100", + "pc": [ + 825 + ] + }, + { + "teal": 448, + "source": "examples/arc72/arc72.algo.ts:100", + "pc": [ + 826 + ] + }, + { + "teal": 449, + "source": "examples/arc72/arc72.algo.ts:100", + "pc": [ + 827 + ] + }, + { + "teal": 450, + "source": "examples/arc72/arc72.algo.ts:100", + "pc": [ + 828 + ] + }, + { + "teal": 451, + "source": "examples/arc72/arc72.algo.ts:100", + "pc": [ + 829, + 830 + ] + }, + { + "teal": 452, + "source": "examples/arc72/arc72.algo.ts:100", + "pc": [ + 831 + ] + }, + { + "teal": 453, + "source": "examples/arc72/arc72.algo.ts:100", + "pc": [ + 832 + ] + }, + { + "teal": 454, + "source": "examples/arc72/arc72.algo.ts:100", + "pc": [ + 833 + ] + }, + { + "teal": 455, + "source": "examples/arc72/arc72.algo.ts:100", + "pc": [ + 834 + ] + }, + { + "teal": 456, + "source": "examples/arc72/arc72.algo.ts:100", + "pc": [ + 835 + ] + }, + { + "teal": 457, + "source": "examples/arc72/arc72.algo.ts:100", + "pc": [ + 836, + 837 + ] + }, + { + "teal": 458, + "source": "examples/arc72/arc72.algo.ts:100", + "pc": [ + 838 + ] + }, + { + "teal": 464, + "source": "examples/arc72/arc72.algo.ts:100", + "pc": [ + 839, + 840, + 841 + ] + }, + { + "teal": 468, + "source": "examples/arc72/arc72.algo.ts:102", + "pc": [ + 842, + 843, + 844, + 845, + 846, + 847, + 848 + ] + }, + { + "teal": 469, + "source": "examples/arc72/arc72.algo.ts:102", + "pc": [ + 849 + ] + }, + { + "teal": 470, + "source": "examples/arc72/arc72.algo.ts:100", + "pc": [ + 850 + ] + }, + { + "teal": 475, + "source": "examples/arc72/arc72.algo.ts:108", + "pc": [ + 851, + 852, + 853, + 854, + 855, + 856 + ] + }, + { + "teal": 478, + "source": "examples/arc72/arc72.algo.ts:109", + "pc": [ + 857, + 858, + 859 + ] + }, + { + "teal": 479, + "source": "examples/arc72/arc72.algo.ts:109", + "pc": [ + 860 + ] + }, + { + "teal": 480, + "source": "examples/arc72/arc72.algo.ts:109", + "pc": [ + 861 + ] + }, + { + "teal": 481, + "source": "examples/arc72/arc72.algo.ts:109", + "pc": [ + 862, + 863 + ] + }, + { + "teal": 482, + "source": "examples/arc72/arc72.algo.ts:109", + "pc": [ + 864 + ] + }, + { + "teal": 485, + "source": "examples/arc72/arc72.algo.ts:109", + "errorMessage": "argument 0 (index) for arc72_tokenByIndex must be a uint256", + "pc": [ + 865 + ] + }, + { + "teal": 488, + "source": "examples/arc72/arc72.algo.ts:108", + "pc": [ + 866, + 867, + 868 + ] + }, + { + "teal": 489, + "source": "examples/arc72/arc72.algo.ts:108", + "pc": [ + 869 + ] + }, + { + "teal": 490, + "source": "examples/arc72/arc72.algo.ts:108", + "pc": [ + 870 + ] + }, + { + "teal": 491, + "source": "examples/arc72/arc72.algo.ts:108", + "pc": [ + 871, + 872, + 873 + ] + }, + { + "teal": 492, + "source": "examples/arc72/arc72.algo.ts:108", + "pc": [ + 874 + ] + }, + { + "teal": 495, + "source": "examples/arc72/arc72.algo.ts:108", + "errorMessage": "arc72_tokenByIndex return value overflowed 256 bits", + "pc": [ + 875 + ] + }, + { + "teal": 496, + "source": "examples/arc72/arc72.algo.ts:108", + "pc": [ + 876, + 877, + 878, + 879, + 880, + 881, + 882, + 883, + 884, + 885, + 886, + 887, + 888, + 889, + 890, + 891, + 892, + 893, + 894, + 895, + 896, + 897, + 898, + 899, + 900, + 901, + 902, + 903, + 904, + 905, + 906, + 907, + 908, + 909 + ] + }, + { + "teal": 497, + "source": "examples/arc72/arc72.algo.ts:108", + "pc": [ + 910 + ] + }, + { + "teal": 498, + "source": "examples/arc72/arc72.algo.ts:108", + "pc": [ + 911 + ] + }, + { + "teal": 499, + "source": "examples/arc72/arc72.algo.ts:108", + "pc": [ + 912 + ] + }, + { + "teal": 500, + "source": "examples/arc72/arc72.algo.ts:108", + "pc": [ + 913 + ] + }, + { + "teal": 501, + "source": "examples/arc72/arc72.algo.ts:108", + "pc": [ + 914, + 915 + ] + }, + { + "teal": 502, + "source": "examples/arc72/arc72.algo.ts:108", + "pc": [ + 916 + ] + }, + { + "teal": 503, + "source": "examples/arc72/arc72.algo.ts:108", + "pc": [ + 917 + ] + }, + { + "teal": 504, + "source": "examples/arc72/arc72.algo.ts:108", + "pc": [ + 918 + ] + }, + { + "teal": 505, + "source": "examples/arc72/arc72.algo.ts:108", + "pc": [ + 919 + ] + }, + { + "teal": 506, + "source": "examples/arc72/arc72.algo.ts:108", + "pc": [ + 920 + ] + }, + { + "teal": 507, + "source": "examples/arc72/arc72.algo.ts:108", + "pc": [ + 921, + 922 + ] + }, + { + "teal": 508, + "source": "examples/arc72/arc72.algo.ts:108", + "pc": [ + 923 + ] + }, + { + "teal": 514, + "source": "examples/arc72/arc72.algo.ts:108", + "pc": [ + 924, + 925, + 926 + ] + }, + { + "teal": 518, + "source": "examples/arc72/arc72.algo.ts:110", + "pc": [ + 927, + 928 + ] + }, + { + "teal": 519, + "source": "examples/arc72/arc72.algo.ts:108", + "pc": [ + 929 + ] + }, + { + "teal": 522, + "source": "examples/arc72/arc72.algo.ts:9", + "pc": [ + 930, + 931 + ] + }, + { + "teal": 523, + "source": "examples/arc72/arc72.algo.ts:9", + "pc": [ + 932 + ] + }, + { + "teal": 526, + "source": "examples/arc72/arc72.algo.ts:9", + "pc": [ + 933, + 934, + 935, + 936, + 937, + 938 + ] + }, + { + "teal": 527, + "source": "examples/arc72/arc72.algo.ts:9", + "pc": [ + 939, + 940, + 941 + ] + }, + { + "teal": 528, + "source": "examples/arc72/arc72.algo.ts:9", + "pc": [ + 942, + 943, + 944, + 945 + ] + }, + { + "teal": 531, + "source": "examples/arc72/arc72.algo.ts:9", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", + "pc": [ + 946 + ] + }, + { + "teal": 534, + "source": "examples/arc72/arc72.algo.ts:9", + "pc": [ + 947, + 948, + 949, + 950, + 951, + 952 + ] + }, + { + "teal": 535, + "source": "examples/arc72/arc72.algo.ts:9", + "pc": [ + 953, + 954, + 955, + 956, + 957, + 958 + ] + }, + { + "teal": 536, + "source": "examples/arc72/arc72.algo.ts:9", + "pc": [ + 959, + 960, + 961, + 962, + 963, + 964 + ] + }, + { + "teal": 537, + "source": "examples/arc72/arc72.algo.ts:9", + "pc": [ + 965, + 966, + 967, + 968, + 969, + 970 + ] + }, + { + "teal": 538, + "source": "examples/arc72/arc72.algo.ts:9", + "pc": [ + 971, + 972, + 973, + 974, + 975, + 976 + ] + }, + { + "teal": 539, + "source": "examples/arc72/arc72.algo.ts:9", + "pc": [ + 977, + 978, + 979, + 980, + 981, + 982 + ] + }, + { + "teal": 540, + "source": "examples/arc72/arc72.algo.ts:9", + "pc": [ + 983, + 984, + 985, + 986, + 987, + 988 + ] + }, + { + "teal": 541, + "source": "examples/arc72/arc72.algo.ts:9", + "pc": [ + 989, + 990, + 991, + 992, + 993, + 994 + ] + }, + { + "teal": 542, + "source": "examples/arc72/arc72.algo.ts:9", + "pc": [ + 995, + 996, + 997 + ] + }, + { + "teal": 543, + "source": "examples/arc72/arc72.algo.ts:9", + "pc": [ + 998, + 999, + 1000, + 1001, + 1002, + 1003, + 1004, + 1005, + 1006, + 1007, + 1008, + 1009, + 1010, + 1011, + 1012, + 1013, + 1014, + 1015 + ] }, { + "teal": 546, + "source": "examples/arc72/arc72.algo.ts:9", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 1016 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/examples/arc75/artifacts/ARC75.arc56_draft.json b/examples/arc75/artifacts/ARC75.arc56_draft.json index 24cb2e9b1..c0429e1b6 100644 --- a/examples/arc75/artifacts/ARC75.arc56_draft.json +++ b/examples/arc75/artifacts/ARC75.arc56_draft.json @@ -194,100 +194,3285 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "examples/arc75/arc75.algo.ts:6", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "examples/arc75/arc75.algo.ts:6", + "pc": [ + 1, + 2, + 3 + ] + }, + { + "teal": 3, + "source": "examples/arc75/arc75.algo.ts:6", + "pc": [ + 4, + 5, + 6, + 7, + 8, + 9 + ] + }, + { + "teal": 15, + "source": "examples/arc75/arc75.algo.ts:6", + "pc": [ + 10, + 11 + ] + }, + { + "teal": 16, + "source": "examples/arc75/arc75.algo.ts:6", + "pc": [ + 12 + ] + }, + { + "teal": 17, + "source": "examples/arc75/arc75.algo.ts:6", + "pc": [ + 13, + 14 + ] + }, + { + "teal": 18, + "source": "examples/arc75/arc75.algo.ts:6", + "pc": [ + 15 + ] + }, + { + "teal": 19, + "source": "examples/arc75/arc75.algo.ts:6", + "pc": [ + 16, + 17 + ] + }, + { + "teal": 20, + "source": "examples/arc75/arc75.algo.ts:6", + "pc": [ + 18 + ] + }, + { + "teal": 21, + "source": "examples/arc75/arc75.algo.ts:6", + "pc": [ + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38, + 39, + 40, + 41, + 42, + 43, + 44 + ] + }, + { + "teal": 25, + "source": "examples/arc75/arc75.algo.ts:6", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 45 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "examples/arc75/arc75.algo.ts:9", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 37, + "source": "examples/arc75/arc75.algo.ts:10", + "pc": [ + 49, + 50 + ] + }, + { + "teal": 38, + "source": "examples/arc75/arc75.algo.ts:11", + "pc": [ + 51, + 52 + ] + }, + { + "teal": 39, + "source": "examples/arc75/arc75.algo.ts:11", + "pc": [ + 53, + 54 + ] + }, + { + "teal": 40, + "source": "examples/arc75/arc75.algo.ts:11", + "pc": [ + 55 + ] }, { + "teal": 43, + "source": "examples/arc75/arc75.algo.ts:11", + "errorMessage": "transaction verification failed: {\"txn\":\"payment\",\"field\":\"receiver\",\"expected\":\"this.app.address\"}", "pc": [ 56 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"payment\",\"field\":\"receiver\",\"expected\":\"this.app.address\"}" + ] + }, + { + "teal": 46, + "source": "examples/arc75/arc75.algo.ts:10", + "pc": [ + 57, + 58 + ] + }, + { + "teal": 47, + "source": "examples/arc75/arc75.algo.ts:12", + "pc": [ + 59, + 60 + ] + }, + { + "teal": 48, + "source": "examples/arc75/arc75.algo.ts:12", + "pc": [ + 61, + 62 + ] + }, + { + "teal": 49, + "source": "examples/arc75/arc75.algo.ts:12", + "pc": [ + 63, + 64 + ] + }, + { + "teal": 50, + "source": "examples/arc75/arc75.algo.ts:12", + "pc": [ + 65 + ] + }, + { + "teal": 51, + "source": "examples/arc75/arc75.algo.ts:12", + "pc": [ + 66, + 67 + ] + }, + { + "teal": 52, + "source": "examples/arc75/arc75.algo.ts:12", + "pc": [ + 68 + ] + }, + { + "teal": 53, + "source": "examples/arc75/arc75.algo.ts:12", + "pc": [ + 69 + ] }, { + "teal": 56, + "source": "examples/arc75/arc75.algo.ts:12", + "errorMessage": "transaction verification failed: {\"txn\":\"payment\",\"field\":\"amount\",\"expected\":\"this.app.address.minBalance - preMBR\"}", "pc": [ 70 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"payment\",\"field\":\"amount\",\"expected\":\"this.app.address.minBalance - preMBR\"}" + ] + }, + { + "teal": 57, + "source": "examples/arc75/arc75.algo.ts:9", + "pc": [ + 71 + ] + }, + { + "teal": 61, + "source": "examples/arc75/arc75.algo.ts:16", + "pc": [ + 72, + 73, + 74 + ] + }, + { + "teal": 68, + "source": "examples/arc75/arc75.algo.ts:17", + "pc": [ + 75 + ] + }, + { + "teal": 69, + "source": "examples/arc75/arc75.algo.ts:17", + "pc": [ + 76, + 77 + ] + }, + { + "teal": 70, + "source": "examples/arc75/arc75.algo.ts:17", + "pc": [ + 78, + 79 + ] + }, + { + "teal": 74, + "source": "examples/arc75/arc75.algo.ts:18", + "pc": [ + 80, + 81 + ] + }, + { + "teal": 75, + "source": "examples/arc75/arc75.algo.ts:18", + "pc": [ + 82, + 83 + ] + }, + { + "teal": 79, + "source": "examples/arc75/arc75.algo.ts:19", + "pc": [ + 84, + 85 + ] + }, + { + "teal": 80, + "source": "examples/arc75/arc75.algo.ts:19", + "pc": [ + 86, + 87 + ] + }, + { + "teal": 81, + "source": "examples/arc75/arc75.algo.ts:19", + "pc": [ + 88, + 89 + ] + }, + { + "teal": 82, + "source": "examples/arc75/arc75.algo.ts:19", + "pc": [ + 90 + ] + }, + { + "teal": 83, + "source": "examples/arc75/arc75.algo.ts:19", + "pc": [ + 91 + ] + }, + { + "teal": 84, + "source": "examples/arc75/arc75.algo.ts:19", + "pc": [ + 92, + 93 + ] + }, + { + "teal": 87, + "source": "examples/arc75/arc75.algo.ts:17", + "pc": [ + 94, + 95 + ] + }, + { + "teal": 88, + "source": "examples/arc75/arc75.algo.ts:17", + "pc": [ + 96, + 97 + ] + }, + { + "teal": 91, + "source": "examples/arc75/arc75.algo.ts:17", + "pc": [ + 98 + ] + }, + { + "teal": 92, + "source": "examples/arc75/arc75.algo.ts:16", + "pc": [ + 99 + ] + }, + { + "teal": 97, + "source": "examples/arc75/arc75.algo.ts:32", + "pc": [ + 100, + 101 + ] + }, + { + "teal": 98, + "source": "examples/arc75/arc75.algo.ts:32", + "pc": [ + 102, + 103 + ] + }, + { + "teal": 99, + "source": "examples/arc75/arc75.algo.ts:32", + "pc": [ + 104 + ] + }, + { + "teal": 100, + "source": "examples/arc75/arc75.algo.ts:32", + "pc": [ + 105 + ] + }, + { + "teal": 101, + "source": "examples/arc75/arc75.algo.ts:32", + "pc": [ + 106, + 107 + ] + }, + { + "teal": 102, + "source": "examples/arc75/arc75.algo.ts:32", + "pc": [ + 108, + 109 + ] + }, + { + "teal": 103, + "source": "examples/arc75/arc75.algo.ts:32", + "pc": [ + 110 + ] }, { + "teal": 106, + "source": "examples/arc75/arc75.algo.ts:32", + "errorMessage": "argument 0 (payment) for addAppToWhiteList must be a pay transaction", "pc": [ 111 - ], - "errorMessage": "argument 0 (payment) for addAppToWhiteList must be a pay transaction" + ] + }, + { + "teal": 109, + "source": "examples/arc75/arc75.algo.ts:32", + "pc": [ + 112, + 113, + 114 + ] + }, + { + "teal": 110, + "source": "examples/arc75/arc75.algo.ts:32", + "pc": [ + 115 + ] + }, + { + "teal": 113, + "source": "examples/arc75/arc75.algo.ts:32", + "pc": [ + 116, + 117, + 118 + ] + }, + { + "teal": 114, + "source": "examples/arc75/arc75.algo.ts:32", + "pc": [ + 119 + ] + }, + { + "teal": 115, + "source": "examples/arc75/arc75.algo.ts:32", + "pc": [ + 120 + ] + }, + { + "teal": 116, + "source": "examples/arc75/arc75.algo.ts:32", + "pc": [ + 121, + 122 + ] + }, + { + "teal": 117, + "source": "examples/arc75/arc75.algo.ts:32", + "pc": [ + 123 + ] }, { + "teal": 120, + "source": "examples/arc75/arc75.algo.ts:32", + "errorMessage": "argument 2 (boxIndex) for addAppToWhiteList must be a uint16", "pc": [ 124 - ], - "errorMessage": "argument 2 (boxIndex) for addAppToWhiteList must be a uint16" + ] }, { + "teal": 121, + "source": "examples/arc75/arc75.algo.ts:32", "pc": [ - 202 - ], - "errorMessage": "box value does not exist: this.whitelist(whitelist).value" + 125 + ] }, { + "teal": 124, + "source": "examples/arc75/arc75.algo.ts:32", "pc": [ - 277 - ], - "errorMessage": "argument 1 (boxIndex) for setAppWhitelist must be a uint16" + 126, + 127, + 128 + ] }, { + "teal": 125, + "source": "examples/arc75/arc75.algo.ts:32", "pc": [ - 397 - ], - "errorMessage": "failed to cast this.txnGroup[this.txn.groupIndex - 1] to pay" + 129, + 130, + 131 + ] }, { + "teal": 128, + "source": "examples/arc75/arc75.algo.ts:32", "pc": [ - 410 - ], - "errorMessage": "argument 0 (boxIndex) for deleteWhitelist must be a uint16" + 132, + 133, + 134 + ] }, { + "teal": 129, + "source": "examples/arc75/arc75.algo.ts:32", "pc": [ - 501 - ], - "errorMessage": "argument 2 (boxIndex) for deleteAppFromWhitelist must be a uint16" + 135, + 136 + ] }, { + "teal": 130, + "source": "examples/arc75/arc75.algo.ts:32", "pc": [ - 571 - ], - "errorMessage": "box value does not exist: this.whitelist(whitelist).value" + 137 + ] }, { + "teal": 141, + "source": "examples/arc75/arc75.algo.ts:32", "pc": [ - 591 - ], - "errorMessage": "box value does not exist: this.whitelist(whitelist).value" + 138, + 139, + 140 + ] }, { + "teal": 144, + "source": "examples/arc75/arc75.algo.ts:32", "pc": [ - 603 - ], - "errorMessage": "box value does not exist: this.whitelist(whitelist).value" + 141, + 142 + ] }, { + "teal": 145, + "source": "examples/arc75/arc75.algo.ts:32", "pc": [ - 623 - ], - "errorMessage": "box value does not exist: this.whitelist(whitelist).value" + 143, + 144 + ] }, { + "teal": 149, + "source": "examples/arc75/arc75.algo.ts:33", "pc": [ - 692 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + 145, + 146 + ] }, { + "teal": 150, + "source": "examples/arc75/arc75.algo.ts:33", "pc": [ - 730 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + 147, + 148 + ] + }, + { + "teal": 151, + "source": "examples/arc75/arc75.algo.ts:33", + "pc": [ + 149 + ] + }, + { + "teal": 152, + "source": "examples/arc75/arc75.algo.ts:33", + "pc": [ + 150, + 151 + ] + }, + { + "teal": 156, + "source": "examples/arc75/arc75.algo.ts:34", + "pc": [ + 152, + 153 + ] + }, + { + "teal": 157, + "source": "examples/arc75/arc75.algo.ts:34", + "pc": [ + 154, + 155 + ] + }, + { + "teal": 158, + "source": "examples/arc75/arc75.algo.ts:34", + "pc": [ + 156, + 157, + 158, + 159 + ] + }, + { + "teal": 159, + "source": "examples/arc75/arc75.algo.ts:34", + "pc": [ + 160, + 161 + ] + }, + { + "teal": 160, + "source": "examples/arc75/arc75.algo.ts:34", + "pc": [ + 162, + 163, + 164 + ] + }, + { + "teal": 161, + "source": "examples/arc75/arc75.algo.ts:34", + "pc": [ + 165, + 166 + ] + }, + { + "teal": 162, + "source": "examples/arc75/arc75.algo.ts:34", + "pc": [ + 167 + ] + }, + { + "teal": 163, + "source": "examples/arc75/arc75.algo.ts:34", + "pc": [ + 168, + 169, + 170 + ] + }, + { + "teal": 164, + "source": "examples/arc75/arc75.algo.ts:34", + "pc": [ + 171, + 172, + 173 + ] + }, + { + "teal": 165, + "source": "examples/arc75/arc75.algo.ts:34", + "pc": [ + 174, + 175 + ] + }, + { + "teal": 166, + "source": "examples/arc75/arc75.algo.ts:34", + "pc": [ + 176 + ] + }, + { + "teal": 167, + "source": "examples/arc75/arc75.algo.ts:34", + "pc": [ + 177 + ] + }, + { + "teal": 168, + "source": "examples/arc75/arc75.algo.ts:34", + "pc": [ + 178 + ] + }, + { + "teal": 169, + "source": "examples/arc75/arc75.algo.ts:34", + "pc": [ + 179, + 180, + 181 + ] + }, + { + "teal": 170, + "source": "examples/arc75/arc75.algo.ts:34", + "pc": [ + 182 + ] + }, + { + "teal": 171, + "source": "examples/arc75/arc75.algo.ts:34", + "pc": [ + 183 + ] + }, + { + "teal": 172, + "source": "examples/arc75/arc75.algo.ts:34", + "pc": [ + 184, + 185, + 186 + ] + }, + { + "teal": 173, + "source": "examples/arc75/arc75.algo.ts:34", + "pc": [ + 187 + ] + }, + { + "teal": 174, + "source": "examples/arc75/arc75.algo.ts:34", + "pc": [ + 188 + ] + }, + { + "teal": 175, + "source": "examples/arc75/arc75.algo.ts:34", + "pc": [ + 189, + 190 + ] + }, + { + "teal": 180, + "source": "examples/arc75/arc75.algo.ts:36", + "pc": [ + 191, + 192 + ] + }, + { + "teal": 181, + "source": "examples/arc75/arc75.algo.ts:36", + "pc": [ + 193 + ] + }, + { + "teal": 182, + "source": "examples/arc75/arc75.algo.ts:36", + "pc": [ + 194 + ] + }, + { + "teal": 183, + "source": "examples/arc75/arc75.algo.ts:36", + "pc": [ + 195 + ] + }, + { + "teal": 184, + "source": "examples/arc75/arc75.algo.ts:36", + "pc": [ + 196, + 197, + 198 + ] + }, + { + "teal": 189, + "source": "examples/arc75/arc75.algo.ts:37", + "pc": [ + 199, + 200 + ] + }, + { + "teal": 190, + "source": "examples/arc75/arc75.algo.ts:37", + "pc": [ + 201 + ] + }, + { + "teal": 193, + "source": "examples/arc75/arc75.algo.ts:37", + "errorMessage": "box value does not exist: this.whitelist(whitelist).value", + "pc": [ + 202 + ] + }, + { + "teal": 194, + "source": "examples/arc75/arc75.algo.ts:37", + "pc": [ + 203, + 204, + 205 + ] + }, + { + "teal": 195, + "source": "examples/arc75/arc75.algo.ts:37", + "pc": [ + 206, + 207 + ] + }, + { + "teal": 196, + "source": "examples/arc75/arc75.algo.ts:37", + "pc": [ + 208 + ] + }, + { + "teal": 197, + "source": "examples/arc75/arc75.algo.ts:37", + "pc": [ + 209 + ] + }, + { + "teal": 198, + "source": "examples/arc75/arc75.algo.ts:37", + "pc": [ + 210, + 211 + ] + }, + { + "teal": 199, + "source": "examples/arc75/arc75.algo.ts:37", + "pc": [ + 212 + ] + }, + { + "teal": 200, + "source": "examples/arc75/arc75.algo.ts:37", + "pc": [ + 213 + ] + }, + { + "teal": 201, + "source": "examples/arc75/arc75.algo.ts:37", + "pc": [ + 214 + ] + }, + { + "teal": 202, + "source": "examples/arc75/arc75.algo.ts:37", + "pc": [ + 215 + ] + }, + { + "teal": 203, + "source": "examples/arc75/arc75.algo.ts:37", + "pc": [ + 216 + ] + }, + { + "teal": 204, + "source": "examples/arc75/arc75.algo.ts:37", + "pc": [ + 217 + ] + }, + { + "teal": 205, + "source": "examples/arc75/arc75.algo.ts:37", + "pc": [ + 218, + 219 + ] + }, + { + "teal": 206, + "source": "examples/arc75/arc75.algo.ts:37", + "pc": [ + 220 + ] + }, + { + "teal": 207, + "source": "examples/arc75/arc75.algo.ts:37", + "pc": [ + 221 + ] + }, + { + "teal": 208, + "source": "examples/arc75/arc75.algo.ts:37", + "pc": [ + 222, + 223, + 224 + ] + }, + { + "teal": 209, + "source": "examples/arc75/arc75.algo.ts:37", + "pc": [ + 225 + ] + }, + { + "teal": 210, + "source": "examples/arc75/arc75.algo.ts:37", + "pc": [ + 226 + ] + }, + { + "teal": 211, + "source": "examples/arc75/arc75.algo.ts:37", + "pc": [ + 227 + ] + }, + { + "teal": 212, + "source": "examples/arc75/arc75.algo.ts:36", + "pc": [ + 228, + 229, + 230 + ] + }, + { + "teal": 217, + "source": "examples/arc75/arc75.algo.ts:39", + "pc": [ + 231, + 232 + ] + }, + { + "teal": 218, + "source": "examples/arc75/arc75.algo.ts:39", + "pc": [ + 233 + ] + }, + { + "teal": 219, + "source": "examples/arc75/arc75.algo.ts:39", + "pc": [ + 234, + 235 + ] + }, + { + "teal": 223, + "source": "examples/arc75/arc75.algo.ts:40", + "pc": [ + 236, + 237 + ] + }, + { + "teal": 224, + "source": "examples/arc75/arc75.algo.ts:40", + "pc": [ + 238 + ] + }, + { + "teal": 225, + "source": "examples/arc75/arc75.algo.ts:40", + "pc": [ + 239 + ] + }, + { + "teal": 226, + "source": "examples/arc75/arc75.algo.ts:40", + "pc": [ + 240 + ] + }, + { + "teal": 227, + "source": "examples/arc75/arc75.algo.ts:40", + "pc": [ + 241, + 242 + ] + }, + { + "teal": 228, + "source": "examples/arc75/arc75.algo.ts:40", + "pc": [ + 243 + ] + }, + { + "teal": 229, + "source": "examples/arc75/arc75.algo.ts:40", + "pc": [ + 244 + ] + }, + { + "teal": 230, + "source": "examples/arc75/arc75.algo.ts:40", + "pc": [ + 245, + 246 + ] + }, + { + "teal": 231, + "source": "examples/arc75/arc75.algo.ts:40", + "pc": [ + 247 + ] + }, + { + "teal": 232, + "source": "examples/arc75/arc75.algo.ts:40", + "pc": [ + 248 + ] + }, + { + "teal": 233, + "source": "examples/arc75/arc75.algo.ts:40", + "pc": [ + 249, + 250, + 251 + ] + }, + { + "teal": 234, + "source": "examples/arc75/arc75.algo.ts:40", + "pc": [ + 252 + ] + }, + { + "teal": 235, + "source": "examples/arc75/arc75.algo.ts:40", + "pc": [ + 253 + ] + }, + { + "teal": 236, + "source": "examples/arc75/arc75.algo.ts:40", + "pc": [ + 254 + ] + }, + { + "teal": 241, + "source": "examples/arc75/arc75.algo.ts:43", + "pc": [ + 255, + 256 + ] + }, + { + "teal": 242, + "source": "examples/arc75/arc75.algo.ts:43", + "pc": [ + 257, + 258 + ] + }, + { + "teal": 243, + "source": "examples/arc75/arc75.algo.ts:43", + "pc": [ + 259, + 260, + 261 + ] + }, + { + "teal": 244, + "source": "examples/arc75/arc75.algo.ts:32", + "pc": [ + 262 + ] + }, + { + "teal": 249, + "source": "examples/arc75/arc75.algo.ts:54", + "pc": [ + 263, + 264, + 265 + ] + }, + { + "teal": 250, + "source": "examples/arc75/arc75.algo.ts:54", + "pc": [ + 266, + 267, + 268 + ] + }, + { + "teal": 253, + "source": "examples/arc75/arc75.algo.ts:54", + "pc": [ + 269, + 270, + 271 + ] + }, + { + "teal": 254, + "source": "examples/arc75/arc75.algo.ts:54", + "pc": [ + 272 + ] + }, + { + "teal": 255, + "source": "examples/arc75/arc75.algo.ts:54", + "pc": [ + 273 + ] + }, + { + "teal": 256, + "source": "examples/arc75/arc75.algo.ts:54", + "pc": [ + 274, + 275 + ] + }, + { + "teal": 257, + "source": "examples/arc75/arc75.algo.ts:54", + "pc": [ + 276 + ] + }, + { + "teal": 260, + "source": "examples/arc75/arc75.algo.ts:54", + "errorMessage": "argument 1 (boxIndex) for setAppWhitelist must be a uint16", + "pc": [ + 277 + ] + }, + { + "teal": 261, + "source": "examples/arc75/arc75.algo.ts:54", + "pc": [ + 278 + ] + }, + { + "teal": 264, + "source": "examples/arc75/arc75.algo.ts:54", + "pc": [ + 279, + 280, + 281 + ] + }, + { + "teal": 265, + "source": "examples/arc75/arc75.algo.ts:54", + "pc": [ + 282, + 283, + 284 + ] + }, + { + "teal": 268, + "source": "examples/arc75/arc75.algo.ts:54", + "pc": [ + 285, + 286, + 287 + ] + }, + { + "teal": 269, + "source": "examples/arc75/arc75.algo.ts:54", + "pc": [ + 288, + 289 + ] + }, + { + "teal": 270, + "source": "examples/arc75/arc75.algo.ts:54", + "pc": [ + 290 + ] + }, + { + "teal": 280, + "source": "examples/arc75/arc75.algo.ts:54", + "pc": [ + 291, + 292, + 293 + ] + }, + { + "teal": 283, + "source": "examples/arc75/arc75.algo.ts:54", + "pc": [ + 294, + 295 + ] + }, + { + "teal": 284, + "source": "examples/arc75/arc75.algo.ts:54", + "pc": [ + 296 + ] + }, + { + "teal": 288, + "source": "examples/arc75/arc75.algo.ts:55", + "pc": [ + 297, + 298 + ] + }, + { + "teal": 289, + "source": "examples/arc75/arc75.algo.ts:55", + "pc": [ + 299, + 300 + ] + }, + { + "teal": 290, + "source": "examples/arc75/arc75.algo.ts:55", + "pc": [ + 301 + ] + }, + { + "teal": 291, + "source": "examples/arc75/arc75.algo.ts:55", + "pc": [ + 302, + 303 + ] + }, + { + "teal": 295, + "source": "examples/arc75/arc75.algo.ts:56", + "pc": [ + 304, + 305 + ] + }, + { + "teal": 296, + "source": "examples/arc75/arc75.algo.ts:56", + "pc": [ + 306, + 307 + ] + }, + { + "teal": 297, + "source": "examples/arc75/arc75.algo.ts:56", + "pc": [ + 308, + 309, + 310, + 311 + ] + }, + { + "teal": 298, + "source": "examples/arc75/arc75.algo.ts:56", + "pc": [ + 312, + 313 + ] + }, + { + "teal": 299, + "source": "examples/arc75/arc75.algo.ts:56", + "pc": [ + 314, + 315, + 316 + ] + }, + { + "teal": 300, + "source": "examples/arc75/arc75.algo.ts:56", + "pc": [ + 317, + 318 + ] + }, + { + "teal": 301, + "source": "examples/arc75/arc75.algo.ts:56", + "pc": [ + 319 + ] + }, + { + "teal": 302, + "source": "examples/arc75/arc75.algo.ts:56", + "pc": [ + 320, + 321, + 322 + ] + }, + { + "teal": 303, + "source": "examples/arc75/arc75.algo.ts:56", + "pc": [ + 323, + 324, + 325 + ] + }, + { + "teal": 304, + "source": "examples/arc75/arc75.algo.ts:56", + "pc": [ + 326, + 327 + ] + }, + { + "teal": 305, + "source": "examples/arc75/arc75.algo.ts:56", + "pc": [ + 328 + ] + }, + { + "teal": 306, + "source": "examples/arc75/arc75.algo.ts:56", + "pc": [ + 329 + ] + }, + { + "teal": 307, + "source": "examples/arc75/arc75.algo.ts:56", + "pc": [ + 330 + ] + }, + { + "teal": 308, + "source": "examples/arc75/arc75.algo.ts:56", + "pc": [ + 331, + 332, + 333 + ] + }, + { + "teal": 309, + "source": "examples/arc75/arc75.algo.ts:56", + "pc": [ + 334 + ] + }, + { + "teal": 310, + "source": "examples/arc75/arc75.algo.ts:56", + "pc": [ + 335 + ] + }, + { + "teal": 311, + "source": "examples/arc75/arc75.algo.ts:56", + "pc": [ + 336, + 337, + 338 + ] + }, + { + "teal": 312, + "source": "examples/arc75/arc75.algo.ts:56", + "pc": [ + 339 + ] + }, + { + "teal": 313, + "source": "examples/arc75/arc75.algo.ts:56", + "pc": [ + 340 + ] + }, + { + "teal": 314, + "source": "examples/arc75/arc75.algo.ts:56", + "pc": [ + 341, + 342 + ] + }, + { + "teal": 318, + "source": "examples/arc75/arc75.algo.ts:58", + "pc": [ + 343, + 344 + ] + }, + { + "teal": 319, + "source": "examples/arc75/arc75.algo.ts:58", + "pc": [ + 345 + ] + }, + { + "teal": 323, + "source": "examples/arc75/arc75.algo.ts:60", + "pc": [ + 346, + 347 + ] + }, + { + "teal": 324, + "source": "examples/arc75/arc75.algo.ts:60", + "pc": [ + 348 + ] + }, + { + "teal": 325, + "source": "examples/arc75/arc75.algo.ts:60", + "pc": [ + 349 + ] + }, + { + "teal": 326, + "source": "examples/arc75/arc75.algo.ts:60", + "pc": [ + 350 + ] + }, + { + "teal": 327, + "source": "examples/arc75/arc75.algo.ts:60", + "pc": [ + 351, + 352 + ] + }, + { + "teal": 328, + "source": "examples/arc75/arc75.algo.ts:60", + "pc": [ + 353 + ] + }, + { + "teal": 329, + "source": "examples/arc75/arc75.algo.ts:60", + "pc": [ + 354 + ] + }, + { + "teal": 330, + "source": "examples/arc75/arc75.algo.ts:60", + "pc": [ + 355, + 356 + ] + }, + { + "teal": 331, + "source": "examples/arc75/arc75.algo.ts:60", + "pc": [ + 357 + ] + }, + { + "teal": 332, + "source": "examples/arc75/arc75.algo.ts:60", + "pc": [ + 358 + ] + }, + { + "teal": 333, + "source": "examples/arc75/arc75.algo.ts:60", + "pc": [ + 359, + 360, + 361 + ] + }, + { + "teal": 334, + "source": "examples/arc75/arc75.algo.ts:60", + "pc": [ + 362 + ] + }, + { + "teal": 335, + "source": "examples/arc75/arc75.algo.ts:60", + "pc": [ + 363 + ] + }, + { + "teal": 336, + "source": "examples/arc75/arc75.algo.ts:60", + "pc": [ + 364 + ] + }, + { + "teal": 341, + "source": "examples/arc75/arc75.algo.ts:62", + "pc": [ + 365, + 366 + ] + }, + { + "teal": 342, + "source": "examples/arc75/arc75.algo.ts:62", + "pc": [ + 367, + 368 + ] + }, + { + "teal": 343, + "source": "examples/arc75/arc75.algo.ts:62", + "pc": [ + 369, + 370 + ] + }, + { + "teal": 344, + "source": "examples/arc75/arc75.algo.ts:62", + "pc": [ + 371 + ] + }, + { + "teal": 345, + "source": "examples/arc75/arc75.algo.ts:62", + "pc": [ + 372 + ] + }, + { + "teal": 346, + "source": "examples/arc75/arc75.algo.ts:62", + "pc": [ + 373, + 374, + 375 + ] + }, + { + "teal": 351, + "source": "examples/arc75/arc75.algo.ts:63", + "pc": [ + 376, + 377 + ] + }, + { + "teal": 352, + "source": "examples/arc75/arc75.algo.ts:63", + "pc": [ + 378, + 379, + 380 + ] + }, + { + "teal": 353, + "source": "examples/arc75/arc75.algo.ts:62", + "pc": [ + 381, + 382, + 383 + ] + }, + { + "teal": 358, + "source": "examples/arc75/arc75.algo.ts:65", + "pc": [ + 384, + 385 + ] + }, + { + "teal": 359, + "source": "examples/arc75/arc75.algo.ts:65", + "pc": [ + 386, + 387 + ] + }, + { + "teal": 360, + "source": "examples/arc75/arc75.algo.ts:65", + "pc": [ + 388, + 389 + ] + }, + { + "teal": 361, + "source": "examples/arc75/arc75.algo.ts:65", + "pc": [ + 390 + ] + }, + { + "teal": 362, + "source": "examples/arc75/arc75.algo.ts:65", + "pc": [ + 391 + ] + }, + { + "teal": 363, + "source": "examples/arc75/arc75.algo.ts:65", + "pc": [ + 392, + 393 + ] + }, + { + "teal": 364, + "source": "examples/arc75/arc75.algo.ts:65", + "pc": [ + 394, + 395 + ] + }, + { + "teal": 365, + "source": "examples/arc75/arc75.algo.ts:65", + "pc": [ + 396 + ] + }, + { + "teal": 368, + "source": "examples/arc75/arc75.algo.ts:65", + "errorMessage": "failed to cast this.txnGroup[this.txn.groupIndex - 1] to pay", + "pc": [ + 397 + ] + }, + { + "teal": 369, + "source": "examples/arc75/arc75.algo.ts:65", + "pc": [ + 398, + 399, + 400 + ] + }, + { + "teal": 372, + "source": "examples/arc75/arc75.algo.ts:54", + "pc": [ + 401 + ] + }, + { + "teal": 377, + "source": "examples/arc75/arc75.algo.ts:76", + "pc": [ + 402, + 403, + 404 + ] + }, + { + "teal": 378, + "source": "examples/arc75/arc75.algo.ts:76", + "pc": [ + 405 + ] + }, + { + "teal": 379, + "source": "examples/arc75/arc75.algo.ts:76", + "pc": [ + 406 + ] + }, + { + "teal": 380, + "source": "examples/arc75/arc75.algo.ts:76", + "pc": [ + 407, + 408 + ] + }, + { + "teal": 381, + "source": "examples/arc75/arc75.algo.ts:76", + "pc": [ + 409 + ] + }, + { + "teal": 384, + "source": "examples/arc75/arc75.algo.ts:76", + "errorMessage": "argument 0 (boxIndex) for deleteWhitelist must be a uint16", + "pc": [ + 410 + ] + }, + { + "teal": 385, + "source": "examples/arc75/arc75.algo.ts:76", + "pc": [ + 411 + ] + }, + { + "teal": 388, + "source": "examples/arc75/arc75.algo.ts:76", + "pc": [ + 412, + 413, + 414 + ] + }, + { + "teal": 389, + "source": "examples/arc75/arc75.algo.ts:76", + "pc": [ + 415, + 416, + 417 + ] + }, + { + "teal": 392, + "source": "examples/arc75/arc75.algo.ts:76", + "pc": [ + 418, + 419, + 420 + ] + }, + { + "teal": 393, + "source": "examples/arc75/arc75.algo.ts:76", + "pc": [ + 421, + 422 + ] + }, + { + "teal": 394, + "source": "examples/arc75/arc75.algo.ts:76", + "pc": [ + 423 + ] + }, + { + "teal": 403, + "source": "examples/arc75/arc75.algo.ts:76", + "pc": [ + 424, + 425, + 426 + ] + }, + { + "teal": 406, + "source": "examples/arc75/arc75.algo.ts:76", + "pc": [ + 427, + 428 + ] + }, + { + "teal": 407, + "source": "examples/arc75/arc75.algo.ts:76", + "pc": [ + 429 + ] + }, + { + "teal": 411, + "source": "examples/arc75/arc75.algo.ts:77", + "pc": [ + 430, + 431 + ] + }, + { + "teal": 412, + "source": "examples/arc75/arc75.algo.ts:77", + "pc": [ + 432, + 433 + ] + }, + { + "teal": 413, + "source": "examples/arc75/arc75.algo.ts:77", + "pc": [ + 434 + ] + }, + { + "teal": 414, + "source": "examples/arc75/arc75.algo.ts:77", + "pc": [ + 435, + 436 + ] + }, + { + "teal": 418, + "source": "examples/arc75/arc75.algo.ts:78", + "pc": [ + 437, + 438 + ] + }, + { + "teal": 419, + "source": "examples/arc75/arc75.algo.ts:78", + "pc": [ + 439, + 440 + ] + }, + { + "teal": 420, + "source": "examples/arc75/arc75.algo.ts:78", + "pc": [ + 441, + 442, + 443, + 444 + ] + }, + { + "teal": 421, + "source": "examples/arc75/arc75.algo.ts:78", + "pc": [ + 445, + 446 + ] + }, + { + "teal": 422, + "source": "examples/arc75/arc75.algo.ts:78", + "pc": [ + 447, + 448, + 449 + ] + }, + { + "teal": 423, + "source": "examples/arc75/arc75.algo.ts:78", + "pc": [ + 450, + 451 + ] + }, + { + "teal": 424, + "source": "examples/arc75/arc75.algo.ts:78", + "pc": [ + 452 + ] + }, + { + "teal": 425, + "source": "examples/arc75/arc75.algo.ts:78", + "pc": [ + 453, + 454, + 455 + ] + }, + { + "teal": 426, + "source": "examples/arc75/arc75.algo.ts:78", + "pc": [ + 456, + 457, + 458 + ] + }, + { + "teal": 427, + "source": "examples/arc75/arc75.algo.ts:78", + "pc": [ + 459, + 460 + ] + }, + { + "teal": 428, + "source": "examples/arc75/arc75.algo.ts:78", + "pc": [ + 461 + ] + }, + { + "teal": 429, + "source": "examples/arc75/arc75.algo.ts:78", + "pc": [ + 462 + ] + }, + { + "teal": 430, + "source": "examples/arc75/arc75.algo.ts:78", + "pc": [ + 463 + ] + }, + { + "teal": 431, + "source": "examples/arc75/arc75.algo.ts:78", + "pc": [ + 464, + 465, + 466 + ] + }, + { + "teal": 432, + "source": "examples/arc75/arc75.algo.ts:78", + "pc": [ + 467 + ] + }, + { + "teal": 433, + "source": "examples/arc75/arc75.algo.ts:78", + "pc": [ + 468 + ] + }, + { + "teal": 434, + "source": "examples/arc75/arc75.algo.ts:78", + "pc": [ + 469, + 470, + 471 + ] + }, + { + "teal": 435, + "source": "examples/arc75/arc75.algo.ts:78", + "pc": [ + 472 + ] + }, + { + "teal": 436, + "source": "examples/arc75/arc75.algo.ts:78", + "pc": [ + 473 + ] + }, + { + "teal": 437, + "source": "examples/arc75/arc75.algo.ts:78", + "pc": [ + 474, + 475 + ] + }, + { + "teal": 441, + "source": "examples/arc75/arc75.algo.ts:80", + "pc": [ + 476, + 477 + ] + }, + { + "teal": 442, + "source": "examples/arc75/arc75.algo.ts:80", + "pc": [ + 478 + ] + }, + { + "teal": 446, + "source": "examples/arc75/arc75.algo.ts:82", + "pc": [ + 479, + 480 + ] + }, + { + "teal": 447, + "source": "examples/arc75/arc75.algo.ts:82", + "pc": [ + 481, + 482, + 483 + ] + }, + { + "teal": 448, + "source": "examples/arc75/arc75.algo.ts:76", + "pc": [ + 484 + ] + }, + { + "teal": 453, + "source": "examples/arc75/arc75.algo.ts:93", + "pc": [ + 485, + 486, + 487 + ] + }, + { + "teal": 454, + "source": "examples/arc75/arc75.algo.ts:93", + "pc": [ + 488 + ] + }, + { + "teal": 457, + "source": "examples/arc75/arc75.algo.ts:93", + "pc": [ + 489, + 490, + 491 + ] + }, + { + "teal": 458, + "source": "examples/arc75/arc75.algo.ts:93", + "pc": [ + 492 + ] + }, + { + "teal": 461, + "source": "examples/arc75/arc75.algo.ts:93", + "pc": [ + 493, + 494, + 495 + ] + }, + { + "teal": 462, + "source": "examples/arc75/arc75.algo.ts:93", + "pc": [ + 496 + ] + }, + { + "teal": 463, + "source": "examples/arc75/arc75.algo.ts:93", + "pc": [ + 497 + ] + }, + { + "teal": 464, + "source": "examples/arc75/arc75.algo.ts:93", + "pc": [ + 498, + 499 + ] + }, + { + "teal": 465, + "source": "examples/arc75/arc75.algo.ts:93", + "pc": [ + 500 + ] + }, + { + "teal": 468, + "source": "examples/arc75/arc75.algo.ts:93", + "errorMessage": "argument 2 (boxIndex) for deleteAppFromWhitelist must be a uint16", + "pc": [ + 501 + ] + }, + { + "teal": 469, + "source": "examples/arc75/arc75.algo.ts:93", + "pc": [ + 502 + ] + }, + { + "teal": 472, + "source": "examples/arc75/arc75.algo.ts:93", + "pc": [ + 503, + 504, + 505 + ] + }, + { + "teal": 473, + "source": "examples/arc75/arc75.algo.ts:93", + "pc": [ + 506, + 507, + 508 + ] + }, + { + "teal": 476, + "source": "examples/arc75/arc75.algo.ts:93", + "pc": [ + 509, + 510, + 511 + ] + }, + { + "teal": 477, + "source": "examples/arc75/arc75.algo.ts:93", + "pc": [ + 512, + 513 + ] + }, + { + "teal": 478, + "source": "examples/arc75/arc75.algo.ts:93", + "pc": [ + 514 + ] + }, + { + "teal": 488, + "source": "examples/arc75/arc75.algo.ts:93", + "pc": [ + 515, + 516, + 517 + ] + }, + { + "teal": 491, + "source": "examples/arc75/arc75.algo.ts:93", + "pc": [ + 518, + 519 + ] + }, + { + "teal": 492, + "source": "examples/arc75/arc75.algo.ts:93", + "pc": [ + 520, + 521 + ] + }, + { + "teal": 496, + "source": "examples/arc75/arc75.algo.ts:94", + "pc": [ + 522, + 523 + ] + }, + { + "teal": 497, + "source": "examples/arc75/arc75.algo.ts:94", + "pc": [ + 524, + 525 + ] + }, + { + "teal": 498, + "source": "examples/arc75/arc75.algo.ts:94", + "pc": [ + 526 + ] + }, + { + "teal": 499, + "source": "examples/arc75/arc75.algo.ts:94", + "pc": [ + 527, + 528 + ] + }, + { + "teal": 503, + "source": "examples/arc75/arc75.algo.ts:95", + "pc": [ + 529, + 530 + ] + }, + { + "teal": 504, + "source": "examples/arc75/arc75.algo.ts:95", + "pc": [ + 531, + 532 + ] + }, + { + "teal": 505, + "source": "examples/arc75/arc75.algo.ts:95", + "pc": [ + 533, + 534, + 535, + 536 + ] + }, + { + "teal": 506, + "source": "examples/arc75/arc75.algo.ts:95", + "pc": [ + 537, + 538 + ] + }, + { + "teal": 507, + "source": "examples/arc75/arc75.algo.ts:95", + "pc": [ + 539, + 540, + 541 + ] + }, + { + "teal": 508, + "source": "examples/arc75/arc75.algo.ts:95", + "pc": [ + 542, + 543 + ] + }, + { + "teal": 509, + "source": "examples/arc75/arc75.algo.ts:95", + "pc": [ + 544 + ] + }, + { + "teal": 510, + "source": "examples/arc75/arc75.algo.ts:95", + "pc": [ + 545, + 546, + 547 + ] + }, + { + "teal": 511, + "source": "examples/arc75/arc75.algo.ts:95", + "pc": [ + 548, + 549, + 550 + ] + }, + { + "teal": 512, + "source": "examples/arc75/arc75.algo.ts:95", + "pc": [ + 551, + 552 + ] + }, + { + "teal": 513, + "source": "examples/arc75/arc75.algo.ts:95", + "pc": [ + 553 + ] + }, + { + "teal": 514, + "source": "examples/arc75/arc75.algo.ts:95", + "pc": [ + 554 + ] + }, + { + "teal": 515, + "source": "examples/arc75/arc75.algo.ts:95", + "pc": [ + 555 + ] + }, + { + "teal": 516, + "source": "examples/arc75/arc75.algo.ts:95", + "pc": [ + 556, + 557, + 558 + ] + }, + { + "teal": 517, + "source": "examples/arc75/arc75.algo.ts:95", + "pc": [ + 559 + ] + }, + { + "teal": 518, + "source": "examples/arc75/arc75.algo.ts:95", + "pc": [ + 560 + ] + }, + { + "teal": 519, + "source": "examples/arc75/arc75.algo.ts:95", + "pc": [ + 561, + 562, + 563 + ] + }, + { + "teal": 520, + "source": "examples/arc75/arc75.algo.ts:95", + "pc": [ + 564 + ] + }, + { + "teal": 521, + "source": "examples/arc75/arc75.algo.ts:95", + "pc": [ + 565 + ] + }, + { + "teal": 522, + "source": "examples/arc75/arc75.algo.ts:95", + "pc": [ + 566, + 567 + ] + }, + { + "teal": 526, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 568, + 569 + ] + }, + { + "teal": 527, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 570 + ] + }, + { + "teal": 530, + "source": "examples/arc75/arc75.algo.ts:97", + "errorMessage": "box value does not exist: this.whitelist(whitelist).value", + "pc": [ + 571 + ] + }, + { + "teal": 531, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 572, + 573, + 574 + ] + }, + { + "teal": 532, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 575, + 576 + ] + }, + { + "teal": 533, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 577, + 578 + ] + }, + { + "teal": 534, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 579, + 580 + ] + }, + { + "teal": 535, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 581 + ] + }, + { + "teal": 536, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 582, + 583 + ] + }, + { + "teal": 537, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 584, + 585 + ] + }, + { + "teal": 538, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 586, + 587 + ] + }, + { + "teal": 539, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 588, + 589 + ] + }, + { + "teal": 540, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 590 + ] + }, + { + "teal": 543, + "source": "examples/arc75/arc75.algo.ts:97", + "errorMessage": "box value does not exist: this.whitelist(whitelist).value", + "pc": [ + 591 + ] + }, + { + "teal": 544, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 592, + 593, + 594 + ] + }, + { + "teal": 545, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 595, + 596 + ] + }, + { + "teal": 546, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 597, + 598 + ] + }, + { + "teal": 547, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 599 + ] + }, + { + "teal": 548, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 600, + 601 + ] + }, + { + "teal": 549, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 602 + ] + }, + { + "teal": 552, + "source": "examples/arc75/arc75.algo.ts:97", + "errorMessage": "box value does not exist: this.whitelist(whitelist).value", + "pc": [ + 603 + ] + }, + { + "teal": 553, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 604, + 605, + 606 + ] + }, + { + "teal": 554, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 607 + ] + }, + { + "teal": 555, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 608 + ] + }, + { + "teal": 556, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 609, + 610 + ] + }, + { + "teal": 557, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 611, + 612 + ] + }, + { + "teal": 558, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 613 + ] + }, + { + "teal": 559, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 614, + 615 + ] + }, + { + "teal": 560, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 616 + ] + }, + { + "teal": 561, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 617 + ] + }, + { + "teal": 562, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 618 + ] + }, + { + "teal": 563, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 619 + ] + }, + { + "teal": 564, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 620, + 621 + ] + }, + { + "teal": 565, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 622 + ] + }, + { + "teal": 568, + "source": "examples/arc75/arc75.algo.ts:97", + "errorMessage": "box value does not exist: this.whitelist(whitelist).value", + "pc": [ + 623 + ] + }, + { + "teal": 569, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 624, + 625, + 626 + ] + }, + { + "teal": 570, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 627, + 628 + ] + }, + { + "teal": 571, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 629, + 630 + ] + }, + { + "teal": 572, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 631, + 632 + ] + }, + { + "teal": 573, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 633 + ] + }, + { + "teal": 574, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 634 + ] + }, + { + "teal": 575, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 635 + ] + }, + { + "teal": 576, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 636, + 637 + ] + }, + { + "teal": 577, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 638 + ] + }, + { + "teal": 578, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 639 + ] + }, + { + "teal": 579, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 640 + ] + }, + { + "teal": 580, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 641 + ] + }, + { + "teal": 581, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 642 + ] + }, + { + "teal": 582, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 643 + ] + }, + { + "teal": 583, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 644, + 645 + ] + }, + { + "teal": 584, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 646 + ] + }, + { + "teal": 585, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 647 + ] + }, + { + "teal": 586, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 648, + 649, + 650 + ] + }, + { + "teal": 587, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 651 + ] + }, + { + "teal": 588, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 652 + ] + }, + { + "teal": 589, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 653 + ] + }, + { + "teal": 590, + "source": "examples/arc75/arc75.algo.ts:97", + "pc": [ + 654, + 655 + ] + }, + { + "teal": 594, + "source": "examples/arc75/arc75.algo.ts:99", + "pc": [ + 656, + 657 + ] + }, + { + "teal": 595, + "source": "examples/arc75/arc75.algo.ts:99", + "pc": [ + 658, + 659 + ] + }, + { + "teal": 596, + "source": "examples/arc75/arc75.algo.ts:99", + "pc": [ + 660, + 661 + ] + }, + { + "teal": 597, + "source": "examples/arc75/arc75.algo.ts:99", + "pc": [ + 662, + 663, + 664 + ] + }, + { + "teal": 598, + "source": "examples/arc75/arc75.algo.ts:99", + "pc": [ + 665 + ] + }, + { + "teal": 599, + "source": "examples/arc75/arc75.algo.ts:99", + "pc": [ + 666, + 667 + ] + }, + { + "teal": 600, + "source": "examples/arc75/arc75.algo.ts:99", + "pc": [ + 668 + ] + }, + { + "teal": 601, + "source": "examples/arc75/arc75.algo.ts:99", + "pc": [ + 669 + ] + }, + { + "teal": 605, + "source": "examples/arc75/arc75.algo.ts:101", + "pc": [ + 670, + 671 + ] + }, + { + "teal": 606, + "source": "examples/arc75/arc75.algo.ts:101", + "pc": [ + 672, + 673, + 674 + ] + }, + { + "teal": 607, + "source": "examples/arc75/arc75.algo.ts:93", + "pc": [ + 675 + ] + }, + { + "teal": 610, + "source": "examples/arc75/arc75.algo.ts:6", + "pc": [ + 676, + 677 + ] + }, + { + "teal": 611, + "source": "examples/arc75/arc75.algo.ts:6", + "pc": [ + 678 + ] + }, + { + "teal": 614, + "source": "examples/arc75/arc75.algo.ts:6", + "pc": [ + 679, + 680, + 681, + 682, + 683, + 684 + ] + }, + { + "teal": 615, + "source": "examples/arc75/arc75.algo.ts:6", + "pc": [ + 685, + 686, + 687 + ] + }, + { + "teal": 616, + "source": "examples/arc75/arc75.algo.ts:6", + "pc": [ + 688, + 689, + 690, + 691 + ] + }, + { + "teal": 619, + "source": "examples/arc75/arc75.algo.ts:6", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", + "pc": [ + 692 + ] + }, + { + "teal": 622, + "source": "examples/arc75/arc75.algo.ts:6", + "pc": [ + 693, + 694, + 695, + 696, + 697, + 698 + ] + }, + { + "teal": 623, + "source": "examples/arc75/arc75.algo.ts:6", + "pc": [ + 699, + 700, + 701, + 702, + 703, + 704 + ] + }, + { + "teal": 624, + "source": "examples/arc75/arc75.algo.ts:6", + "pc": [ + 705, + 706, + 707, + 708, + 709, + 710 + ] + }, + { + "teal": 625, + "source": "examples/arc75/arc75.algo.ts:6", + "pc": [ + 711, + 712, + 713, + 714, + 715, + 716 + ] + }, + { + "teal": 626, + "source": "examples/arc75/arc75.algo.ts:6", + "pc": [ + 717, + 718, + 719 + ] + }, + { + "teal": 627, + "source": "examples/arc75/arc75.algo.ts:6", + "pc": [ + 720, + 721, + 722, + 723, + 724, + 725, + 726, + 727, + 728, + 729 + ] + }, + { + "teal": 630, + "source": "examples/arc75/arc75.algo.ts:6", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", + "pc": [ + 730 + ] + }, + { + "teal": 633, + "source": "examples/arc75/arc75.algo.ts:6", + "pc": [ + 731, + 732, + 733 + ] + }, + { + "teal": 634, + "source": "examples/arc75/arc75.algo.ts:6", + "pc": [ + 734, + 735 + ] + }, + { + "teal": 635, + "source": "examples/arc75/arc75.algo.ts:6", + "pc": [ + 736, + 737 + ] + }, + { + "teal": 636, + "source": "examples/arc75/arc75.algo.ts:6", + "pc": [ + 738 + ] + }, + { + "teal": 637, + "source": "examples/arc75/arc75.algo.ts:6", + "pc": [ + 739, + 740 + ] + }, + { + "teal": 638, + "source": "examples/arc75/arc75.algo.ts:6", + "pc": [ + 741, + 742 + ] + }, + { + "teal": 639, + "source": "examples/arc75/arc75.algo.ts:6", + "pc": [ + 743 + ] + }, + { + "teal": 642, + "source": "examples/arc75/arc75.algo.ts:6", + "pc": [ + 744, + 745, + 746 + ] + }, + { + "teal": 643, + "source": "examples/arc75/arc75.algo.ts:6", + "pc": [ + 747, + 748 + ] + }, + { + "teal": 644, + "source": "examples/arc75/arc75.algo.ts:6", + "pc": [ + 749, + 750 + ] + }, + { + "teal": 645, + "source": "examples/arc75/arc75.algo.ts:6", + "pc": [ + 751 + ] + }, + { + "teal": 646, + "source": "examples/arc75/arc75.algo.ts:6", + "pc": [ + 752, + 753 + ] + }, + { + "teal": 647, + "source": "examples/arc75/arc75.algo.ts:6", + "pc": [ + 754, + 755 + ] + }, + { + "teal": 648, + "source": "examples/arc75/arc75.algo.ts:6", + "pc": [ + 756 + ] + }, + { + "teal": 649, + "source": "examples/arc75/arc75.algo.ts:6", + "pc": [ + 757 + ] + }, + { + "teal": 650, + "source": "examples/arc75/arc75.algo.ts:6", + "pc": [ + 758, + 759 + ] + }, + { + "teal": 651, + "source": "examples/arc75/arc75.algo.ts:6", + "pc": [ + 760 + ] + }, + { + "teal": 652, + "source": "examples/arc75/arc75.algo.ts:6", + "pc": [ + 761 + ] + }, + { + "teal": 653, + "source": "examples/arc75/arc75.algo.ts:6", + "pc": [ + 762 + ] + }, + { + "teal": 654, + "source": "examples/arc75/arc75.algo.ts:6", + "pc": [ + 763, + 764, + 765 + ] + }, + { + "teal": 655, + "source": "examples/arc75/arc75.algo.ts:6", + "pc": [ + 766, + 767 + ] + }, + { + "teal": 656, + "source": "examples/arc75/arc75.algo.ts:6", + "pc": [ + 768, + 769 + ] + }, + { + "teal": 657, + "source": "examples/arc75/arc75.algo.ts:6", + "pc": [ + 770 + ] + }, + { + "teal": 658, + "source": "examples/arc75/arc75.algo.ts:6", + "pc": [ + 771 + ] + }, + { + "teal": 659, + "source": "examples/arc75/arc75.algo.ts:6", + "pc": [ + 772, + 773 + ] + }, + { + "teal": 660, + "source": "examples/arc75/arc75.algo.ts:6", + "pc": [ + 774, + 775 + ] + }, + { + "teal": 661, + "source": "examples/arc75/arc75.algo.ts:6", + "pc": [ + 776, + 777 + ] + }, + { + "teal": 662, + "source": "examples/arc75/arc75.algo.ts:6", + "pc": [ + 778, + 779 + ] + }, + { + "teal": 663, + "source": "examples/arc75/arc75.algo.ts:6", + "pc": [ + 780 + ] } ], "pcOffsetMethod": "none" diff --git a/examples/auction/tealscript_artifacts/Auction.arc56_draft.json b/examples/auction/tealscript_artifacts/Auction.arc56_draft.json index 2665de0a3..2f0dd94b7 100644 --- a/examples/auction/tealscript_artifacts/Auction.arc56_draft.json +++ b/examples/auction/tealscript_artifacts/Auction.arc56_draft.json @@ -202,76 +202,2433 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "examples/auction/auction.algo.ts:4", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "examples/auction/auction.algo.ts:4", + "pc": [ + 1, + 2, + 3, + 4 + ] + }, + { + "teal": 3, + "source": "examples/auction/auction.algo.ts:4", + "pc": [ + 5, + 6, + 7, + 8, + 9, + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38, + 39, + 40, + 41, + 42, + 43, + 44, + 45, + 46, + 47, + 48, + 49, + 50, + 51, + 52, + 53, + 54, + 55, + 56, + 57, + 58, + 59, + 60, + 61, + 62, + 63, + 64, + 65, + 66, + 67, + 68, + 69, + 70, + 71, + 72 + ] + }, + { + "teal": 15, + "source": "examples/auction/auction.algo.ts:4", + "pc": [ + 73, + 74 + ] + }, + { + "teal": 16, + "source": "examples/auction/auction.algo.ts:4", + "pc": [ + 75 + ] + }, + { + "teal": 17, + "source": "examples/auction/auction.algo.ts:4", + "pc": [ + 76, + 77 + ] + }, + { + "teal": 18, + "source": "examples/auction/auction.algo.ts:4", + "pc": [ + 78 + ] + }, + { + "teal": 19, + "source": "examples/auction/auction.algo.ts:4", + "pc": [ + 79, + 80 + ] + }, + { + "teal": 20, + "source": "examples/auction/auction.algo.ts:4", + "pc": [ + 81 + ] + }, + { + "teal": 21, + "source": "examples/auction/auction.algo.ts:4", + "pc": [ + 82, + 83, + 84, + 85, + 86, + 87, + 88, + 89, + 90, + 91, + 92, + 93, + 94, + 95, + 96, + 97, + 98, + 99, + 100, + 101, + 102, + 103, + 104, + 105, + 106, + 107 + ] + }, + { + "teal": 25, + "source": "examples/auction/auction.algo.ts:4", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 108 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 30, + "source": "examples/auction/auction.algo.ts:17", + "pc": [ + 109, + 110, + 111 + ] + }, + { + "teal": 31, + "source": "examples/auction/auction.algo.ts:17", + "pc": [ + 112, + 113 + ] + }, + { + "teal": 32, + "source": "examples/auction/auction.algo.ts:17", + "pc": [ + 114 + ] + }, + { + "teal": 36, + "source": "examples/auction/auction.algo.ts:17", + "pc": [ + 115, + 116, + 117 + ] + }, + { + "teal": 40, + "source": "examples/auction/auction.algo.ts:18", + "pc": [ + 118, + 119, + 120, + 121, + 122, + 123, + 124, + 125, + 126, + 127, + 128, + 129 + ] + }, + { + "teal": 41, + "source": "examples/auction/auction.algo.ts:18", + "pc": [ + 130, + 131 + ] + }, + { + "teal": 42, + "source": "examples/auction/auction.algo.ts:18", + "pc": [ + 132 + ] + }, + { + "teal": 46, + "source": "examples/auction/auction.algo.ts:19", + "pc": [ + 133, + 134, + 135, + 136, + 137, + 138, + 139, + 140, + 141, + 142, + 143, + 144, + 145 + ] + }, + { + "teal": 47, + "source": "examples/auction/auction.algo.ts:19", + "pc": [ + 146, + 147 + ] + }, + { + "teal": 48, + "source": "examples/auction/auction.algo.ts:19", + "pc": [ + 148 + ] + }, + { + "teal": 52, + "source": "examples/auction/auction.algo.ts:20", + "pc": [ + 149, + 150, + 151, + 152, + 153, + 154, + 155, + 156 + ] + }, + { + "teal": 53, + "source": "examples/auction/auction.algo.ts:20", + "pc": [ + 157, + 158 + ] + }, + { + "teal": 54, + "source": "examples/auction/auction.algo.ts:20", + "pc": [ + 159 + ] + }, + { + "teal": 58, + "source": "examples/auction/auction.algo.ts:21", + "pc": [ + 160, + 161, + 162, + 163, + 164 + ] + }, + { + "teal": 59, + "source": "examples/auction/auction.algo.ts:21", + "pc": [ + 165, + 166 + ] + }, + { + "teal": 60, + "source": "examples/auction/auction.algo.ts:21", + "pc": [ + 167 + ] + }, + { + "teal": 64, + "source": "examples/auction/auction.algo.ts:24", + "pc": [ + 168, + 169, + 170, + 171, + 172, + 173, + 174, + 175, + 176, + 177, + 178, + 179, + 180, + 181, + 182, + 183 + ] + }, + { + "teal": 65, + "source": "examples/auction/auction.algo.ts:24", + "pc": [ + 184, + 185 + ] + }, + { + "teal": 66, + "source": "examples/auction/auction.algo.ts:24", + "pc": [ + 186 + ] + }, + { + "teal": 67, + "source": "examples/auction/auction.algo.ts:17", + "pc": [ + 187 + ] + }, + { + "teal": 72, + "source": "examples/auction/auction.algo.ts:27", + "pc": [ + 188, + 189, + 190 + ] + }, + { + "teal": 73, + "source": "examples/auction/auction.algo.ts:27", + "pc": [ + 191 + ] }, { + "teal": 76, + "source": "examples/auction/auction.algo.ts:27", + "pc": [ + 192, + 193, + 194 + ] + }, + { + "teal": 77, + "source": "examples/auction/auction.algo.ts:27", + "pc": [ + 195, + 196 + ] + }, + { + "teal": 78, + "source": "examples/auction/auction.algo.ts:27", + "pc": [ + 197 + ] + }, + { + "teal": 82, + "source": "examples/auction/auction.algo.ts:27", + "pc": [ + 198, + 199, + 200 + ] + }, + { + "teal": 88, + "source": "examples/auction/auction.algo.ts:29", + "pc": [ + 201, + 202 + ] + }, + { + "teal": 89, + "source": "examples/auction/auction.algo.ts:29", + "pc": [ + 203, + 204 + ] + }, + { + "teal": 90, + "source": "examples/auction/auction.algo.ts:29", + "pc": [ + 205 + ] + }, + { + "teal": 93, + "source": "examples/auction/auction.algo.ts:29", + "errorMessage": "transaction verification failed: {\"txn\":\"this.txn\",\"field\":\"sender\",\"expected\":\"globals.creatorAddress\"}", "pc": [ 206 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"this.txn\",\"field\":\"sender\",\"expected\":\"globals.creatorAddress\"}" + ] + }, + { + "teal": 98, + "source": "examples/auction/auction.algo.ts:32", + "pc": [ + 207, + 208, + 209, + 210, + 211 + ] + }, + { + "teal": 99, + "source": "examples/auction/auction.algo.ts:32", + "pc": [ + 212 + ] + }, + { + "teal": 100, + "source": "examples/auction/auction.algo.ts:32", + "pc": [ + 213, + 214 + ] + }, + { + "teal": 101, + "source": "examples/auction/auction.algo.ts:32", + "pc": [ + 215 + ] + }, + { + "teal": 102, + "source": "examples/auction/auction.algo.ts:32", + "pc": [ + 216 + ] + }, + { + "teal": 107, + "source": "examples/auction/auction.algo.ts:35", + "pc": [ + 217, + 218, + 219, + 220, + 221 + ] + }, + { + "teal": 108, + "source": "examples/auction/auction.algo.ts:35", + "pc": [ + 222, + 223 + ] + }, + { + "teal": 109, + "source": "examples/auction/auction.algo.ts:35", + "pc": [ + 224 + ] + }, + { + "teal": 118, + "source": "examples/auction/auction.algo.ts:38", + "pc": [ + 225 + ] + }, + { + "teal": 119, + "source": "examples/auction/auction.algo.ts:38", + "pc": [ + 226, + 227 + ] + }, + { + "teal": 120, + "source": "examples/auction/auction.algo.ts:38", + "pc": [ + 228, + 229 + ] + }, + { + "teal": 124, + "source": "examples/auction/auction.algo.ts:39", + "pc": [ + 230, + 231 + ] + }, + { + "teal": 125, + "source": "examples/auction/auction.algo.ts:39", + "pc": [ + 232, + 233 + ] + }, + { + "teal": 129, + "source": "examples/auction/auction.algo.ts:40", + "pc": [ + 234, + 235 + ] + }, + { + "teal": 130, + "source": "examples/auction/auction.algo.ts:40", + "pc": [ + 236, + 237 + ] + }, + { + "teal": 134, + "source": "examples/auction/auction.algo.ts:41", + "pc": [ + 238, + 239 + ] + }, + { + "teal": 135, + "source": "examples/auction/auction.algo.ts:41", + "pc": [ + 240, + 241 + ] + }, + { + "teal": 138, + "source": "examples/auction/auction.algo.ts:38", + "pc": [ + 242, + 243 + ] + }, + { + "teal": 139, + "source": "examples/auction/auction.algo.ts:38", + "pc": [ + 244, + 245 + ] + }, + { + "teal": 142, + "source": "examples/auction/auction.algo.ts:38", + "pc": [ + 246 + ] + }, + { + "teal": 143, + "source": "examples/auction/auction.algo.ts:27", + "pc": [ + 247 + ] + }, + { + "teal": 148, + "source": "examples/auction/auction.algo.ts:45", + "pc": [ + 248, + 249 + ] + }, + { + "teal": 149, + "source": "examples/auction/auction.algo.ts:45", + "pc": [ + 250, + 251 + ] + }, + { + "teal": 150, + "source": "examples/auction/auction.algo.ts:45", + "pc": [ + 252 + ] + }, + { + "teal": 151, + "source": "examples/auction/auction.algo.ts:45", + "pc": [ + 253 + ] }, { + "teal": 152, + "source": "examples/auction/auction.algo.ts:45", + "pc": [ + 254, + 255 + ] + }, + { + "teal": 153, + "source": "examples/auction/auction.algo.ts:45", + "pc": [ + 256, + 257 + ] + }, + { + "teal": 154, + "source": "examples/auction/auction.algo.ts:45", + "pc": [ + 258 + ] + }, + { + "teal": 157, + "source": "examples/auction/auction.algo.ts:45", + "errorMessage": "argument 0 (axfer) for startAuction must be a axfer transaction", "pc": [ 259 - ], - "errorMessage": "argument 0 (axfer) for startAuction must be a axfer transaction" + ] + }, + { + "teal": 160, + "source": "examples/auction/auction.algo.ts:45", + "pc": [ + 260, + 261, + 262 + ] + }, + { + "teal": 161, + "source": "examples/auction/auction.algo.ts:45", + "pc": [ + 263 + ] + }, + { + "teal": 164, + "source": "examples/auction/auction.algo.ts:45", + "pc": [ + 264, + 265, + 266 + ] + }, + { + "teal": 165, + "source": "examples/auction/auction.algo.ts:45", + "pc": [ + 267 + ] + }, + { + "teal": 168, + "source": "examples/auction/auction.algo.ts:45", + "pc": [ + 268, + 269, + 270 + ] + }, + { + "teal": 169, + "source": "examples/auction/auction.algo.ts:45", + "pc": [ + 271, + 272 + ] + }, + { + "teal": 170, + "source": "examples/auction/auction.algo.ts:45", + "pc": [ + 273 + ] + }, + { + "teal": 174, + "source": "examples/auction/auction.algo.ts:45", + "pc": [ + 274, + 275, + 276 + ] + }, + { + "teal": 179, + "source": "examples/auction/auction.algo.ts:46", + "pc": [ + 277, + 278 + ] + }, + { + "teal": 180, + "source": "examples/auction/auction.algo.ts:46", + "pc": [ + 279, + 280 + ] + }, + { + "teal": 181, + "source": "examples/auction/auction.algo.ts:46", + "pc": [ + 281 + ] }, { + "teal": 184, + "source": "examples/auction/auction.algo.ts:46", + "errorMessage": "transaction verification failed: {\"txn\":\"this.txn\",\"field\":\"sender\",\"expected\":\"globals.creatorAddress\"}", "pc": [ 282 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"this.txn\",\"field\":\"sender\",\"expected\":\"globals.creatorAddress\"}" + ] }, { + "teal": 189, + "source": "examples/auction/auction.algo.ts:49", "pc": [ - 307 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"axfer\",\"field\":\"assetReceiver\",\"expected\":\"this.app.address\"}" + 283, + 284, + 285, + 286, + 287, + 288, + 289, + 290, + 291, + 292, + 293, + 294 + ] }, { + "teal": 190, + "source": "examples/auction/auction.algo.ts:49", "pc": [ - 399 - ], - "errorMessage": "argument 0 (payment) for bid must be a pay transaction" + 295 + ] }, { + "teal": 191, + "source": "examples/auction/auction.algo.ts:49", "pc": [ - 433 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"payment\",\"field\":\"sender\",\"expected\":\"this.txn.sender\"}" + 296, + 297 + ] }, { + "teal": 192, + "source": "examples/auction/auction.algo.ts:49", "pc": [ - 453 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"payment\",\"field\":\"amount\",\"condition\":\"greaterThan\",\"expected\":\">this.previousBid.value\"}" + 298 + ] }, { + "teal": 193, + "source": "examples/auction/auction.algo.ts:49", "pc": [ - 770 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + 299 + ] }, { + "teal": 199, + "source": "examples/auction/auction.algo.ts:52", "pc": [ - 816 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + 300, + 301 + ] }, { + "teal": 200, + "source": "examples/auction/auction.algo.ts:52", "pc": [ - 830 - ], - "errorMessage": "this contract does not implement the given ABI method for call OptIn" + 302, + 303 + ] + }, + { + "teal": 201, + "source": "examples/auction/auction.algo.ts:52", + "pc": [ + 304, + 305 + ] + }, + { + "teal": 202, + "source": "examples/auction/auction.algo.ts:52", + "pc": [ + 306 + ] + }, + { + "teal": 205, + "source": "examples/auction/auction.algo.ts:52", + "errorMessage": "transaction verification failed: {\"txn\":\"axfer\",\"field\":\"assetReceiver\",\"expected\":\"this.app.address\"}", + "pc": [ + 307 + ] + }, + { + "teal": 210, + "source": "examples/auction/auction.algo.ts:55", + "pc": [ + 308, + 309, + 310, + 311, + 312, + 313, + 314, + 315 + ] + }, + { + "teal": 211, + "source": "examples/auction/auction.algo.ts:55", + "pc": [ + 316, + 317 + ] + }, + { + "teal": 212, + "source": "examples/auction/auction.algo.ts:55", + "pc": [ + 318, + 319 + ] + }, + { + "teal": 213, + "source": "examples/auction/auction.algo.ts:55", + "pc": [ + 320 + ] + }, + { + "teal": 217, + "source": "examples/auction/auction.algo.ts:56", + "pc": [ + 321, + 322, + 323, + 324, + 325, + 326, + 327, + 328, + 329, + 330, + 331, + 332 + ] + }, + { + "teal": 218, + "source": "examples/auction/auction.algo.ts:56", + "pc": [ + 333, + 334 + ] + }, + { + "teal": 219, + "source": "examples/auction/auction.algo.ts:56", + "pc": [ + 335, + 336 + ] + }, + { + "teal": 220, + "source": "examples/auction/auction.algo.ts:56", + "pc": [ + 337 + ] + }, + { + "teal": 221, + "source": "examples/auction/auction.algo.ts:56", + "pc": [ + 338 + ] + }, + { + "teal": 225, + "source": "examples/auction/auction.algo.ts:57", + "pc": [ + 339, + 340, + 341, + 342, + 343, + 344, + 345, + 346, + 347, + 348, + 349, + 350, + 351 + ] + }, + { + "teal": 226, + "source": "examples/auction/auction.algo.ts:57", + "pc": [ + 352, + 353 + ] + }, + { + "teal": 227, + "source": "examples/auction/auction.algo.ts:57", + "pc": [ + 354 + ] + }, + { + "teal": 228, + "source": "examples/auction/auction.algo.ts:45", + "pc": [ + 355 + ] + }, + { + "teal": 232, + "source": "examples/auction/auction.algo.ts:60", + "pc": [ + 356, + 357, + 358 + ] + }, + { + "teal": 239, + "source": "examples/auction/auction.algo.ts:61", + "pc": [ + 359 + ] + }, + { + "teal": 240, + "source": "examples/auction/auction.algo.ts:61", + "pc": [ + 360, + 361 + ] + }, + { + "teal": 241, + "source": "examples/auction/auction.algo.ts:61", + "pc": [ + 362, + 363 + ] + }, + { + "teal": 245, + "source": "examples/auction/auction.algo.ts:62", + "pc": [ + 364, + 365 + ] + }, + { + "teal": 246, + "source": "examples/auction/auction.algo.ts:62", + "pc": [ + 366, + 367 + ] + }, + { + "teal": 250, + "source": "examples/auction/auction.algo.ts:63", + "pc": [ + 368, + 369 + ] + }, + { + "teal": 251, + "source": "examples/auction/auction.algo.ts:63", + "pc": [ + 370, + 371 + ] + }, + { + "teal": 254, + "source": "examples/auction/auction.algo.ts:61", + "pc": [ + 372, + 373 + ] + }, + { + "teal": 255, + "source": "examples/auction/auction.algo.ts:61", + "pc": [ + 374, + 375 + ] + }, + { + "teal": 258, + "source": "examples/auction/auction.algo.ts:61", + "pc": [ + 376 + ] + }, + { + "teal": 259, + "source": "examples/auction/auction.algo.ts:60", + "pc": [ + 377 + ] + }, + { + "teal": 264, + "source": "examples/auction/auction.algo.ts:67", + "pc": [ + 378, + 379, + 380 + ] + }, + { + "teal": 265, + "source": "examples/auction/auction.algo.ts:67", + "pc": [ + 381, + 382 + ] + }, + { + "teal": 266, + "source": "examples/auction/auction.algo.ts:67", + "pc": [ + 383 + ] + }, + { + "teal": 270, + "source": "examples/auction/auction.algo.ts:67", + "pc": [ + 384, + 385, + 386 + ] + }, + { + "teal": 271, + "source": "examples/auction/auction.algo.ts:67", + "pc": [ + 387 + ] + }, + { + "teal": 276, + "source": "examples/auction/auction.algo.ts:70", + "pc": [ + 388, + 389 + ] + }, + { + "teal": 277, + "source": "examples/auction/auction.algo.ts:70", + "pc": [ + 390, + 391 + ] + }, + { + "teal": 278, + "source": "examples/auction/auction.algo.ts:70", + "pc": [ + 392 + ] + }, + { + "teal": 279, + "source": "examples/auction/auction.algo.ts:70", + "pc": [ + 393 + ] + }, + { + "teal": 280, + "source": "examples/auction/auction.algo.ts:70", + "pc": [ + 394, + 395 + ] + }, + { + "teal": 281, + "source": "examples/auction/auction.algo.ts:70", + "pc": [ + 396, + 397 + ] + }, + { + "teal": 282, + "source": "examples/auction/auction.algo.ts:70", + "pc": [ + 398 + ] + }, + { + "teal": 285, + "source": "examples/auction/auction.algo.ts:70", + "errorMessage": "argument 0 (payment) for bid must be a pay transaction", + "pc": [ + 399 + ] + }, + { + "teal": 288, + "source": "examples/auction/auction.algo.ts:70", + "pc": [ + 400, + 401, + 402 + ] + }, + { + "teal": 289, + "source": "examples/auction/auction.algo.ts:70", + "pc": [ + 403, + 404 + ] + }, + { + "teal": 290, + "source": "examples/auction/auction.algo.ts:70", + "pc": [ + 405 + ] + }, + { + "teal": 294, + "source": "examples/auction/auction.algo.ts:70", + "pc": [ + 406, + 407, + 408 + ] + }, + { + "teal": 299, + "source": "examples/auction/auction.algo.ts:72", + "pc": [ + 409, + 410 + ] + }, + { + "teal": 300, + "source": "examples/auction/auction.algo.ts:72", + "pc": [ + 411, + 412, + 413, + 414, + 415, + 416, + 417, + 418, + 419, + 420, + 421, + 422 + ] + }, + { + "teal": 301, + "source": "examples/auction/auction.algo.ts:72", + "pc": [ + 423 + ] + }, + { + "teal": 302, + "source": "examples/auction/auction.algo.ts:72", + "pc": [ + 424 + ] + }, + { + "teal": 303, + "source": "examples/auction/auction.algo.ts:72", + "pc": [ + 425 + ] + }, + { + "teal": 312, + "source": "examples/auction/auction.algo.ts:75", + "pc": [ + 426, + 427 + ] + }, + { + "teal": 313, + "source": "examples/auction/auction.algo.ts:76", + "pc": [ + 428, + 429 + ] + }, + { + "teal": 314, + "source": "examples/auction/auction.algo.ts:76", + "pc": [ + 430, + 431 + ] + }, + { + "teal": 315, + "source": "examples/auction/auction.algo.ts:76", + "pc": [ + 432 + ] + }, + { + "teal": 318, + "source": "examples/auction/auction.algo.ts:76", + "errorMessage": "transaction verification failed: {\"txn\":\"payment\",\"field\":\"sender\",\"expected\":\"this.txn.sender\"}", + "pc": [ + 433 + ] + }, + { + "teal": 321, + "source": "examples/auction/auction.algo.ts:75", + "pc": [ + 434, + 435 + ] + }, + { + "teal": 322, + "source": "examples/auction/auction.algo.ts:77", + "pc": [ + 436, + 437 + ] + }, + { + "teal": 323, + "source": "examples/auction/auction.algo.ts:77", + "pc": [ + 438, + 439, + 440, + 441, + 442, + 443, + 444, + 445, + 446, + 447, + 448, + 449, + 450 + ] + }, + { + "teal": 324, + "source": "examples/auction/auction.algo.ts:77", + "pc": [ + 451 + ] + }, + { + "teal": 325, + "source": "examples/auction/auction.algo.ts:77", + "pc": [ + 452 + ] + }, + { + "teal": 328, + "source": "examples/auction/auction.algo.ts:77", + "errorMessage": "transaction verification failed: {\"txn\":\"payment\",\"field\":\"amount\",\"condition\":\"greaterThan\",\"expected\":\">this.previousBid.value\"}", + "pc": [ + 453 + ] + }, + { + "teal": 333, + "source": "examples/auction/auction.algo.ts:81", + "pc": [ + 454, + 455, + 456, + 457, + 458, + 459, + 460, + 461, + 462, + 463, + 464, + 465, + 466 + ] + }, + { + "teal": 334, + "source": "examples/auction/auction.algo.ts:81", + "pc": [ + 467, + 468 + ] + }, + { + "teal": 335, + "source": "examples/auction/auction.algo.ts:81", + "pc": [ + 469, + 470 + ] + }, + { + "teal": 336, + "source": "examples/auction/auction.algo.ts:81", + "pc": [ + 471 + ] + }, + { + "teal": 340, + "source": "examples/auction/auction.algo.ts:82", + "pc": [ + 472, + 473, + 474, + 475, + 476, + 477, + 478, + 479, + 480, + 481, + 482, + 483, + 484, + 485, + 486, + 487 + ] + }, + { + "teal": 341, + "source": "examples/auction/auction.algo.ts:82", + "pc": [ + 488, + 489 + ] + }, + { + "teal": 342, + "source": "examples/auction/auction.algo.ts:82", + "pc": [ + 490, + 491 + ] + }, + { + "teal": 343, + "source": "examples/auction/auction.algo.ts:82", + "pc": [ + 492 + ] + }, + { + "teal": 348, + "source": "examples/auction/auction.algo.ts:85", + "pc": [ + 493, + 494 + ] + }, + { + "teal": 349, + "source": "examples/auction/auction.algo.ts:85", + "pc": [ + 495, + 496, + 497, + 498, + 499, + 500, + 501, + 502, + 503, + 504, + 505, + 506, + 507, + 508, + 509, + 510, + 511 + ] + }, + { + "teal": 350, + "source": "examples/auction/auction.algo.ts:85", + "pc": [ + 512, + 513 + ] + }, + { + "teal": 351, + "source": "examples/auction/auction.algo.ts:85", + "pc": [ + 514, + 515 + ] + }, + { + "teal": 352, + "source": "examples/auction/auction.algo.ts:85", + "pc": [ + 516 + ] + }, + { + "teal": 353, + "source": "examples/auction/auction.algo.ts:70", + "pc": [ + 517 + ] + }, + { + "teal": 358, + "source": "examples/auction/auction.algo.ts:88", + "pc": [ + 518, + 519, + 520 + ] + }, + { + "teal": 359, + "source": "examples/auction/auction.algo.ts:88", + "pc": [ + 521, + 522 + ] + }, + { + "teal": 360, + "source": "examples/auction/auction.algo.ts:88", + "pc": [ + 523 + ] + }, + { + "teal": 364, + "source": "examples/auction/auction.algo.ts:88", + "pc": [ + 524, + 525, + 526 + ] + }, + { + "teal": 367, + "source": "examples/auction/auction.algo.ts:88", + "pc": [ + 527, + 528 + ] + }, + { + "teal": 368, + "source": "examples/auction/auction.algo.ts:88", + "pc": [ + 529 + ] + }, + { + "teal": 372, + "source": "examples/auction/auction.algo.ts:89", + "pc": [ + 530, + 531 + ] + }, + { + "teal": 373, + "source": "examples/auction/auction.algo.ts:89", + "pc": [ + 532, + 533, + 534, + 535, + 536, + 537, + 538, + 539, + 540, + 541, + 542, + 543, + 544, + 545, + 546, + 547, + 548 + ] + }, + { + "teal": 374, + "source": "examples/auction/auction.algo.ts:89", + "pc": [ + 549 + ] + }, + { + "teal": 375, + "source": "examples/auction/auction.algo.ts:89", + "pc": [ + 550, + 551 + ] + }, + { + "teal": 379, + "source": "examples/auction/auction.algo.ts:90", + "pc": [ + 552, + 553 + ] + }, + { + "teal": 380, + "source": "examples/auction/auction.algo.ts:90", + "pc": [ + 554, + 555 + ] + }, + { + "teal": 386, + "source": "examples/auction/auction.algo.ts:93", + "pc": [ + 556, + 557 + ] + }, + { + "teal": 387, + "source": "examples/auction/auction.algo.ts:93", + "pc": [ + 558, + 559, + 560, + 561, + 562, + 563, + 564, + 565, + 566, + 567, + 568, + 569, + 570, + 571, + 572, + 573 + ] + }, + { + "teal": 388, + "source": "examples/auction/auction.algo.ts:93", + "pc": [ + 574 + ] + }, + { + "teal": 389, + "source": "examples/auction/auction.algo.ts:93", + "pc": [ + 575 + ] + }, + { + "teal": 390, + "source": "examples/auction/auction.algo.ts:93", + "pc": [ + 576, + 577, + 578 + ] + }, + { + "teal": 395, + "source": "examples/auction/auction.algo.ts:93", + "pc": [ + 579, + 580 + ] + }, + { + "teal": 396, + "source": "examples/auction/auction.algo.ts:93", + "pc": [ + 581, + 582, + 583, + 584, + 585, + 586, + 587, + 588, + 589, + 590, + 591, + 592, + 593 + ] + }, + { + "teal": 397, + "source": "examples/auction/auction.algo.ts:93", + "pc": [ + 594 + ] + }, + { + "teal": 398, + "source": "examples/auction/auction.algo.ts:93", + "pc": [ + 595 + ] + }, + { + "teal": 399, + "source": "examples/auction/auction.algo.ts:93", + "pc": [ + 596, + 597 + ] + }, + { + "teal": 404, + "source": "examples/auction/auction.algo.ts:95", + "pc": [ + 598, + 599 + ] + }, + { + "teal": 405, + "source": "examples/auction/auction.algo.ts:95", + "pc": [ + 600, + 601 + ] + }, + { + "teal": 406, + "source": "examples/auction/auction.algo.ts:95", + "pc": [ + 602, + 603, + 604 + ] + }, + { + "teal": 410, + "source": "examples/auction/auction.algo.ts:96", + "pc": [ + 605, + 606 + ] + }, + { + "teal": 411, + "source": "examples/auction/auction.algo.ts:96", + "pc": [ + 607, + 608, + 609, + 610, + 611, + 612, + 613, + 614, + 615, + 616, + 617, + 618, + 619, + 620, + 621, + 622, + 623 + ] + }, + { + "teal": 412, + "source": "examples/auction/auction.algo.ts:96", + "pc": [ + 624, + 625 + ] + }, + { + "teal": 413, + "source": "examples/auction/auction.algo.ts:96", + "pc": [ + 626, + 627 + ] + }, + { + "teal": 414, + "source": "examples/auction/auction.algo.ts:96", + "pc": [ + 628 + ] + }, + { + "teal": 415, + "source": "examples/auction/auction.algo.ts:96", + "pc": [ + 629 + ] + }, + { + "teal": 416, + "source": "examples/auction/auction.algo.ts:88", + "pc": [ + 630 + ] + }, + { + "teal": 421, + "source": "examples/auction/auction.algo.ts:99", + "pc": [ + 631, + 632, + 633 + ] + }, + { + "teal": 422, + "source": "examples/auction/auction.algo.ts:99", + "pc": [ + 634 + ] + }, + { + "teal": 425, + "source": "examples/auction/auction.algo.ts:99", + "pc": [ + 635, + 636, + 637 + ] + }, + { + "teal": 426, + "source": "examples/auction/auction.algo.ts:99", + "pc": [ + 638, + 639 + ] + }, + { + "teal": 427, + "source": "examples/auction/auction.algo.ts:99", + "pc": [ + 640 + ] + }, + { + "teal": 431, + "source": "examples/auction/auction.algo.ts:99", + "pc": [ + 641, + 642, + 643 + ] + }, + { + "teal": 435, + "source": "examples/auction/auction.algo.ts:100", + "pc": [ + 644, + 645 + ] + }, + { + "teal": 436, + "source": "examples/auction/auction.algo.ts:100", + "pc": [ + 646, + 647, + 648, + 649, + 650, + 651, + 652, + 653, + 654, + 655, + 656, + 657 + ] + }, + { + "teal": 437, + "source": "examples/auction/auction.algo.ts:100", + "pc": [ + 658 + ] + }, + { + "teal": 438, + "source": "examples/auction/auction.algo.ts:100", + "pc": [ + 659 + ] + }, + { + "teal": 439, + "source": "examples/auction/auction.algo.ts:100", + "pc": [ + 660 + ] + }, + { + "teal": 449, + "source": "examples/auction/auction.algo.ts:103", + "pc": [ + 661 + ] + }, + { + "teal": 450, + "source": "examples/auction/auction.algo.ts:103", + "pc": [ + 662, + 663 + ] + }, + { + "teal": 451, + "source": "examples/auction/auction.algo.ts:103", + "pc": [ + 664, + 665 + ] + }, + { + "teal": 455, + "source": "examples/auction/auction.algo.ts:104", + "pc": [ + 666, + 667, + 668, + 669, + 670, + 671, + 672, + 673, + 674, + 675, + 676, + 677, + 678, + 679, + 680, + 681 + ] + }, + { + "teal": 456, + "source": "examples/auction/auction.algo.ts:104", + "pc": [ + 682 + ] + }, + { + "teal": 457, + "source": "examples/auction/auction.algo.ts:104", + "pc": [ + 683, + 684 + ] + }, + { + "teal": 461, + "source": "examples/auction/auction.algo.ts:105", + "pc": [ + 685, + 686 + ] + }, + { + "teal": 462, + "source": "examples/auction/auction.algo.ts:105", + "pc": [ + 687, + 688 + ] + }, + { + "teal": 466, + "source": "examples/auction/auction.algo.ts:106", + "pc": [ + 689, + 690, + 691, + 692, + 693, + 694, + 695, + 696 + ] + }, + { + "teal": 467, + "source": "examples/auction/auction.algo.ts:106", + "pc": [ + 697 + ] + }, + { + "teal": 468, + "source": "examples/auction/auction.algo.ts:106", + "pc": [ + 698, + 699 + ] + }, + { + "teal": 472, + "source": "examples/auction/auction.algo.ts:107", + "pc": [ + 700, + 701, + 702, + 703, + 704, + 705, + 706, + 707, + 708, + 709, + 710, + 711, + 712, + 713, + 714, + 715 + ] + }, + { + "teal": 473, + "source": "examples/auction/auction.algo.ts:107", + "pc": [ + 716 + ] + }, + { + "teal": 474, + "source": "examples/auction/auction.algo.ts:107", + "pc": [ + 717, + 718 + ] + }, + { + "teal": 477, + "source": "examples/auction/auction.algo.ts:103", + "pc": [ + 719, + 720 + ] + }, + { + "teal": 478, + "source": "examples/auction/auction.algo.ts:103", + "pc": [ + 721, + 722 + ] + }, + { + "teal": 481, + "source": "examples/auction/auction.algo.ts:103", + "pc": [ + 723 + ] + }, + { + "teal": 482, + "source": "examples/auction/auction.algo.ts:99", + "pc": [ + 724 + ] + }, + { + "teal": 487, + "source": "examples/auction/auction.algo.ts:111", + "pc": [ + 725, + 726, + 727 + ] + }, + { + "teal": 488, + "source": "examples/auction/auction.algo.ts:111", + "pc": [ + 728, + 729 + ] + }, + { + "teal": 489, + "source": "examples/auction/auction.algo.ts:111", + "pc": [ + 730 + ] + }, + { + "teal": 493, + "source": "examples/auction/auction.algo.ts:111", + "pc": [ + 731, + 732, + 733 + ] + }, + { + "teal": 501, + "source": "examples/auction/auction.algo.ts:112", + "pc": [ + 734 + ] + }, + { + "teal": 502, + "source": "examples/auction/auction.algo.ts:112", + "pc": [ + 735, + 736 + ] + }, + { + "teal": 503, + "source": "examples/auction/auction.algo.ts:112", + "pc": [ + 737, + 738 + ] + }, + { + "teal": 507, + "source": "examples/auction/auction.algo.ts:113", + "pc": [ + 739, + 740 + ] + }, + { + "teal": 508, + "source": "examples/auction/auction.algo.ts:113", + "pc": [ + 741, + 742 + ] + }, + { + "teal": 512, + "source": "examples/auction/auction.algo.ts:114", + "pc": [ + 743, + 744 + ] + }, + { + "teal": 513, + "source": "examples/auction/auction.algo.ts:114", + "pc": [ + 745, + 746 + ] + }, + { + "teal": 517, + "source": "examples/auction/auction.algo.ts:115", + "pc": [ + 747, + 748 + ] + }, + { + "teal": 518, + "source": "examples/auction/auction.algo.ts:115", + "pc": [ + 749, + 750 + ] + }, + { + "teal": 521, + "source": "examples/auction/auction.algo.ts:112", + "pc": [ + 751, + 752 + ] + }, + { + "teal": 522, + "source": "examples/auction/auction.algo.ts:112", + "pc": [ + 753, + 754 + ] + }, + { + "teal": 525, + "source": "examples/auction/auction.algo.ts:112", + "pc": [ + 755 + ] + }, + { + "teal": 526, + "source": "examples/auction/auction.algo.ts:111", + "pc": [ + 756 + ] + }, + { + "teal": 529, + "source": "examples/auction/auction.algo.ts:4", + "pc": [ + 757, + 758, + 759, + 760, + 761, + 762 + ] + }, + { + "teal": 530, + "source": "examples/auction/auction.algo.ts:4", + "pc": [ + 763, + 764, + 765 + ] + }, + { + "teal": 531, + "source": "examples/auction/auction.algo.ts:4", + "pc": [ + 766, + 767, + 768, + 769 + ] + }, + { + "teal": 534, + "source": "examples/auction/auction.algo.ts:4", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", + "pc": [ + 770 + ] + }, + { + "teal": 537, + "source": "examples/auction/auction.algo.ts:4", + "pc": [ + 771, + 772, + 773, + 774, + 775, + 776 + ] + }, + { + "teal": 538, + "source": "examples/auction/auction.algo.ts:4", + "pc": [ + 777, + 778, + 779, + 780, + 781, + 782 + ] + }, + { + "teal": 539, + "source": "examples/auction/auction.algo.ts:4", + "pc": [ + 783, + 784, + 785, + 786, + 787, + 788 + ] + }, + { + "teal": 540, + "source": "examples/auction/auction.algo.ts:4", + "pc": [ + 789, + 790, + 791, + 792, + 793, + 794 + ] + }, + { + "teal": 541, + "source": "examples/auction/auction.algo.ts:4", + "pc": [ + 795, + 796, + 797, + 798, + 799, + 800 + ] + }, + { + "teal": 542, + "source": "examples/auction/auction.algo.ts:4", + "pc": [ + 801, + 802, + 803 + ] + }, + { + "teal": 543, + "source": "examples/auction/auction.algo.ts:4", + "pc": [ + 804, + 805, + 806, + 807, + 808, + 809, + 810, + 811, + 812, + 813, + 814, + 815 + ] + }, + { + "teal": 546, + "source": "examples/auction/auction.algo.ts:4", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", + "pc": [ + 816 + ] + }, + { + "teal": 549, + "source": "examples/auction/auction.algo.ts:4", + "pc": [ + 817, + 818, + 819, + 820, + 821, + 822 + ] + }, + { + "teal": 550, + "source": "examples/auction/auction.algo.ts:4", + "pc": [ + 823, + 824, + 825 + ] + }, + { + "teal": 551, + "source": "examples/auction/auction.algo.ts:4", + "pc": [ + 826, + 827, + 828, + 829 + ] + }, + { + "teal": 554, + "source": "examples/auction/auction.algo.ts:4", + "errorMessage": "this contract does not implement the given ABI method for call OptIn", + "pc": [ + 830 + ] + }, + { + "teal": 557, + "source": "examples/auction/auction.algo.ts:4", + "pc": [ + 831, + 832, + 833, + 834, + 835, + 836 + ] + }, + { + "teal": 558, + "source": "examples/auction/auction.algo.ts:4", + "pc": [ + 837, + 838, + 839 + ] + }, + { + "teal": 559, + "source": "examples/auction/auction.algo.ts:4", + "pc": [ + 840, + 841, + 842, + 843 + ] }, { + "teal": 562, + "source": "examples/auction/auction.algo.ts:4", + "errorMessage": "this contract does not implement the given ABI method for call DeleteApplication", "pc": [ 844 - ], - "errorMessage": "this contract does not implement the given ABI method for call DeleteApplication" + ] } ], "pcOffsetMethod": "none" diff --git a/examples/big_box/artifacts/BigBox.arc56_draft.json b/examples/big_box/artifacts/BigBox.arc56_draft.json index 33ff9969b..8cff8b7de 100644 --- a/examples/big_box/artifacts/BigBox.arc56_draft.json +++ b/examples/big_box/artifacts/BigBox.arc56_draft.json @@ -180,46 +180,1863 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "examples/big_box/big_box.algo.ts:20", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "examples/big_box/big_box.algo.ts:20", + "pc": [ + 1, + 2, + 3 + ] + }, + { + "teal": 3, + "source": "examples/big_box/big_box.algo.ts:20", + "pc": [ + 4, + 5, + 6, + 7, + 8, + 9, + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19 + ] + }, + { + "teal": 15, + "source": "examples/big_box/big_box.algo.ts:20", + "pc": [ + 20, + 21 + ] + }, + { + "teal": 16, + "source": "examples/big_box/big_box.algo.ts:20", + "pc": [ + 22 + ] + }, + { + "teal": 17, + "source": "examples/big_box/big_box.algo.ts:20", + "pc": [ + 23, + 24 + ] + }, + { + "teal": 18, + "source": "examples/big_box/big_box.algo.ts:20", + "pc": [ + 25 + ] + }, + { + "teal": 19, + "source": "examples/big_box/big_box.algo.ts:20", + "pc": [ + 26, + 27 + ] + }, + { + "teal": 20, + "source": "examples/big_box/big_box.algo.ts:20", + "pc": [ + 28 + ] + }, + { + "teal": 21, + "source": "examples/big_box/big_box.algo.ts:20", + "pc": [ + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38, + 39, + 40, + 41, + 42, + 43, + 44, + 45, + 46, + 47, + 48, + 49, + 50, + 51, + 52, + 53, + 54 + ] + }, + { + "teal": 25, + "source": "examples/big_box/big_box.algo.ts:20", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 55 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 30, + "source": "examples/big_box/big_box.algo.ts:40", + "pc": [ + 56, + 57 + ] + }, + { + "teal": 31, + "source": "examples/big_box/big_box.algo.ts:40", + "pc": [ + 58, + 59 + ] + }, + { + "teal": 32, + "source": "examples/big_box/big_box.algo.ts:40", + "pc": [ + 60 + ] + }, + { + "teal": 33, + "source": "examples/big_box/big_box.algo.ts:40", + "pc": [ + 61 + ] + }, + { + "teal": 34, + "source": "examples/big_box/big_box.algo.ts:40", + "pc": [ + 62, + 63 + ] + }, + { + "teal": 35, + "source": "examples/big_box/big_box.algo.ts:40", + "pc": [ + 64, + 65 + ] + }, + { + "teal": 36, + "source": "examples/big_box/big_box.algo.ts:40", + "pc": [ + 66 + ] + }, + { + "teal": 39, + "source": "examples/big_box/big_box.algo.ts:40", + "errorMessage": "argument 0 (mbrPayment) for startUpload must be a pay transaction", + "pc": [ + 67 + ] + }, + { + "teal": 42, + "source": "examples/big_box/big_box.algo.ts:40", + "pc": [ + 68, + 69, + 70 + ] + }, + { + "teal": 43, + "source": "examples/big_box/big_box.algo.ts:40", + "pc": [ + 71 + ] + }, + { + "teal": 46, + "source": "examples/big_box/big_box.algo.ts:40", + "pc": [ + 72, + 73, + 74 + ] + }, + { + "teal": 47, + "source": "examples/big_box/big_box.algo.ts:40", + "pc": [ + 75 + ] + }, + { + "teal": 50, + "source": "examples/big_box/big_box.algo.ts:40", + "pc": [ + 76, + 77, + 78 + ] + }, + { + "teal": 51, + "source": "examples/big_box/big_box.algo.ts:40", + "pc": [ + 79, + 80, + 81 + ] + }, + { + "teal": 54, + "source": "examples/big_box/big_box.algo.ts:40", + "pc": [ + 82, + 83, + 84 + ] + }, + { + "teal": 55, + "source": "examples/big_box/big_box.algo.ts:40", + "pc": [ + 85, + 86 + ] + }, + { + "teal": 56, + "source": "examples/big_box/big_box.algo.ts:40", + "pc": [ + 87 + ] + }, + { + "teal": 68, + "source": "examples/big_box/big_box.algo.ts:40", + "pc": [ + 88, + 89, + 90 + ] + }, + { + "teal": 71, + "source": "examples/big_box/big_box.algo.ts:40", + "pc": [ + 91, + 92 + ] + }, + { + "teal": 72, + "source": "examples/big_box/big_box.algo.ts:40", + "pc": [ + 93, + 94 + ] + }, + { + "teal": 76, + "source": "examples/big_box/big_box.algo.ts:41", + "pc": [ + 95, + 96, + 97, + 98, + 99, + 100, + 101, + 102, + 103, + 104, + 105, + 106, + 107, + 108 + ] + }, + { + "teal": 77, + "source": "examples/big_box/big_box.algo.ts:41", + "pc": [ + 109 + ] + }, + { + "teal": 78, + "source": "examples/big_box/big_box.algo.ts:41", + "pc": [ + 110, + 111 + ] + }, + { + "teal": 82, + "source": "examples/big_box/big_box.algo.ts:42", + "pc": [ + 112, + 113 + ] + }, + { + "teal": 83, + "source": "examples/big_box/big_box.algo.ts:42", + "pc": [ + 114, + 115 + ] + }, + { + "teal": 84, + "source": "examples/big_box/big_box.algo.ts:42", + "pc": [ + 116 + ] + }, + { + "teal": 85, + "source": "examples/big_box/big_box.algo.ts:42", + "pc": [ + 117, + 118 + ] + }, + { + "teal": 86, + "source": "examples/big_box/big_box.algo.ts:42", + "pc": [ + 119 + ] + }, + { + "teal": 87, + "source": "examples/big_box/big_box.algo.ts:42", + "pc": [ + 120, + 121 + ] + }, + { + "teal": 96, + "source": "examples/big_box/big_box.algo.ts:45", + "pc": [ + 122, + 123 + ] + }, + { + "teal": 97, + "source": "examples/big_box/big_box.algo.ts:45", + "pc": [ + 124 + ] + }, + { + "teal": 98, + "source": "examples/big_box/big_box.algo.ts:46", + "pc": [ + 125, + 126 + ] + }, + { + "teal": 99, + "source": "examples/big_box/big_box.algo.ts:46", + "pc": [ + 127 + ] + }, + { + "teal": 100, + "source": "examples/big_box/big_box.algo.ts:46", + "pc": [ + 128 + ] + }, + { + "teal": 101, + "source": "examples/big_box/big_box.algo.ts:47", + "pc": [ + 129, + 130, + 131 + ] + }, + { + "teal": 102, + "source": "examples/big_box/big_box.algo.ts:47", + "pc": [ + 132 + ] + }, + { + "teal": 103, + "source": "examples/big_box/big_box.algo.ts:48", + "pc": [ + 133, + 134 + ] + }, + { + "teal": 104, + "source": "examples/big_box/big_box.algo.ts:48", + "pc": [ + 135 + ] + }, + { + "teal": 105, + "source": "examples/big_box/big_box.algo.ts:48", + "pc": [ + 136 + ] + }, + { + "teal": 106, + "source": "examples/big_box/big_box.algo.ts:44", + "pc": [ + 137, + 138 + ] + }, + { + "teal": 110, + "source": "examples/big_box/big_box.algo.ts:51", + "pc": [ + 139, + 140 + ] + }, + { + "teal": 111, + "source": "examples/big_box/big_box.algo.ts:51", + "pc": [ + 141 + ] + }, + { + "teal": 112, + "source": "examples/big_box/big_box.algo.ts:51", + "pc": [ + 142 + ] + }, + { + "teal": 113, + "source": "examples/big_box/big_box.algo.ts:51", + "pc": [ + 143 + ] + }, + { + "teal": 114, + "source": "examples/big_box/big_box.algo.ts:51", + "pc": [ + 144 + ] + }, + { + "teal": 115, + "source": "examples/big_box/big_box.algo.ts:51", + "pc": [ + 145 + ] + }, + { + "teal": 119, + "source": "examples/big_box/big_box.algo.ts:53", + "pc": [ + 146, + 147 + ] + }, + { + "teal": 120, + "source": "examples/big_box/big_box.algo.ts:53", + "pc": [ + 148, + 149 + ] + }, + { + "teal": 121, + "source": "examples/big_box/big_box.algo.ts:53", + "pc": [ + 150 + ] + }, + { + "teal": 125, + "source": "examples/big_box/big_box.algo.ts:55", + "pc": [ + 151, + 152, + 153, + 154, + 155, + 156, + 157, + 158, + 159, + 160, + 161, + 162, + 163, + 164 + ] + }, + { + "teal": 126, + "source": "examples/big_box/big_box.algo.ts:55", + "pc": [ + 165, + 166 + ] + }, + { + "teal": 127, + "source": "examples/big_box/big_box.algo.ts:55", + "pc": [ + 167, + 168 + ] + }, + { + "teal": 128, + "source": "examples/big_box/big_box.algo.ts:55", + "pc": [ + 169 + ] + }, + { + "teal": 129, + "source": "examples/big_box/big_box.algo.ts:55", + "pc": [ + 170 + ] + }, + { + "teal": 137, + "source": "examples/big_box/big_box.algo.ts:58", + "pc": [ + 171, + 172 + ] + }, + { + "teal": 138, + "source": "examples/big_box/big_box.algo.ts:58", + "pc": [ + 173, + 174, + 175 + ] + }, + { + "teal": 139, + "source": "examples/big_box/big_box.algo.ts:58", + "pc": [ + 176 + ] + }, + { + "teal": 140, + "source": "examples/big_box/big_box.algo.ts:59", + "pc": [ + 177, + 178 + ] + }, + { + "teal": 141, + "source": "examples/big_box/big_box.algo.ts:59", + "pc": [ + 179, + 180 + ] + }, + { + "teal": 142, + "source": "examples/big_box/big_box.algo.ts:59", + "pc": [ + 181 + ] + }, + { + "teal": 143, + "source": "examples/big_box/big_box.algo.ts:59", + "pc": [ + 182, + 183, + 184, + 185 + ] + }, + { + "teal": 144, + "source": "examples/big_box/big_box.algo.ts:59", + "pc": [ + 186 + ] + }, + { + "teal": 145, + "source": "examples/big_box/big_box.algo.ts:59", + "pc": [ + 187, + 188, + 189 + ] + }, + { + "teal": 146, + "source": "examples/big_box/big_box.algo.ts:59", + "pc": [ + 190 + ] + }, + { + "teal": 147, + "source": "examples/big_box/big_box.algo.ts:58", + "pc": [ + 191 + ] + }, + { + "teal": 148, + "source": "examples/big_box/big_box.algo.ts:60", + "pc": [ + 192, + 193 + ] + }, + { + "teal": 149, + "source": "examples/big_box/big_box.algo.ts:60", + "pc": [ + 194, + 195 + ] + }, + { + "teal": 150, + "source": "examples/big_box/big_box.algo.ts:60", + "pc": [ + 196 + ] + }, + { + "teal": 151, + "source": "examples/big_box/big_box.algo.ts:60", + "pc": [ + 197, + 198, + 199 + ] + }, + { + "teal": 152, + "source": "examples/big_box/big_box.algo.ts:60", + "pc": [ + 200 + ] + }, + { + "teal": 153, + "source": "examples/big_box/big_box.algo.ts:59", + "pc": [ + 201 + ] + }, + { + "teal": 154, + "source": "examples/big_box/big_box.algo.ts:61", + "pc": [ + 202, + 203 + ] + }, + { + "teal": 155, + "source": "examples/big_box/big_box.algo.ts:61", + "pc": [ + 204, + 205, + 206 + ] + }, + { + "teal": 156, + "source": "examples/big_box/big_box.algo.ts:61", + "pc": [ + 207 + ] + }, + { + "teal": 157, + "source": "examples/big_box/big_box.algo.ts:60", + "pc": [ + 208 + ] + }, + { + "teal": 158, + "source": "examples/big_box/big_box.algo.ts:57", + "pc": [ + 209, + 210 + ] + }, + { + "teal": 163, + "source": "examples/big_box/big_box.algo.ts:63", + "pc": [ + 211, + 212 + ] + }, + { + "teal": 164, + "source": "examples/big_box/big_box.algo.ts:63", + "pc": [ + 213, + 214 + ] + }, + { + "teal": 165, + "source": "examples/big_box/big_box.algo.ts:63", + "pc": [ + 215, + 216 + ] + }, + { + "teal": 166, + "source": "examples/big_box/big_box.algo.ts:63", + "pc": [ + 217 + ] + }, + { + "teal": 169, + "source": "examples/big_box/big_box.algo.ts:63", + "errorMessage": "transaction verification failed: {\"txn\":\"mbrPayment\",\"field\":\"receiver\",\"expected\":\"this.app.address\"}", + "pc": [ + 218 + ] + }, + { + "teal": 172, + "source": "examples/big_box/big_box.algo.ts:63", + "pc": [ + 219, + 220 + ] + }, + { + "teal": 173, + "source": "examples/big_box/big_box.algo.ts:63", + "pc": [ + 221, + 222 + ] + }, + { + "teal": 174, + "source": "examples/big_box/big_box.algo.ts:63", + "pc": [ + 223, + 224 + ] + }, + { + "teal": 175, + "source": "examples/big_box/big_box.algo.ts:63", + "pc": [ + 225 + ] + }, + { + "teal": 178, + "source": "examples/big_box/big_box.algo.ts:63", + "errorMessage": "transaction verification failed: {\"txn\":\"mbrPayment\",\"field\":\"amount\",\"expected\":\"totalCost\"}", + "pc": [ + 226 + ] + }, + { + "teal": 179, + "source": "examples/big_box/big_box.algo.ts:40", + "pc": [ + 227 + ] + }, + { + "teal": 184, + "source": "examples/big_box/big_box.algo.ts:75", + "pc": [ + 228, + 229, + 230 + ] + }, + { + "teal": 185, + "source": "examples/big_box/big_box.algo.ts:75", + "pc": [ + 231, + 232, + 233 + ] + }, + { + "teal": 188, + "source": "examples/big_box/big_box.algo.ts:75", + "pc": [ + 234, + 235, + 236 + ] + }, + { + "teal": 189, + "source": "examples/big_box/big_box.algo.ts:75", + "pc": [ + 237 + ] + }, + { + "teal": 192, + "source": "examples/big_box/big_box.algo.ts:75", + "pc": [ + 238, + 239, + 240 + ] + }, + { + "teal": 193, + "source": "examples/big_box/big_box.algo.ts:75", + "pc": [ + 241 + ] + }, + { + "teal": 196, + "source": "examples/big_box/big_box.algo.ts:75", + "pc": [ + 242, + 243, + 244 + ] + }, + { + "teal": 197, + "source": "examples/big_box/big_box.algo.ts:75", + "pc": [ + 245, + 246, + 247 + ] + }, + { + "teal": 200, + "source": "examples/big_box/big_box.algo.ts:75", + "pc": [ + 248, + 249, + 250 + ] + }, + { + "teal": 201, + "source": "examples/big_box/big_box.algo.ts:75", + "pc": [ + 251, + 252 + ] + }, + { + "teal": 202, + "source": "examples/big_box/big_box.algo.ts:75", + "pc": [ + 253 + ] + }, + { + "teal": 214, + "source": "examples/big_box/big_box.algo.ts:75", + "pc": [ + 254, + 255, + 256 + ] + }, + { + "teal": 217, + "source": "examples/big_box/big_box.algo.ts:75", + "pc": [ + 257, + 258 + ] + }, + { + "teal": 221, + "source": "examples/big_box/big_box.algo.ts:76", + "pc": [ + 259, + 260 + ] + }, + { + "teal": 222, + "source": "examples/big_box/big_box.algo.ts:76", + "pc": [ + 261, + 262 + ] + }, + { + "teal": 226, + "source": "examples/big_box/big_box.algo.ts:76", + "pc": [ + 263, + 264 + ] + }, + { + "teal": 227, + "source": "examples/big_box/big_box.algo.ts:76", + "pc": [ + 265, + 266 + ] + }, + { + "teal": 228, + "source": "examples/big_box/big_box.algo.ts:76", + "pc": [ + 267, + 268 + ] + }, + { + "teal": 229, + "source": "examples/big_box/big_box.algo.ts:76", + "pc": [ + 269 + ] + }, + { + "teal": 230, + "source": "examples/big_box/big_box.algo.ts:77", + "pc": [ + 270 + ] + }, + { + "teal": 231, + "source": "examples/big_box/big_box.algo.ts:77", + "pc": [ + 271, + 272 + ] + }, + { + "teal": 232, + "source": "examples/big_box/big_box.algo.ts:77", + "pc": [ + 273 + ] + }, + { + "teal": 233, + "source": "examples/big_box/big_box.algo.ts:77", + "pc": [ + 274 + ] + }, + { + "teal": 237, + "source": "examples/big_box/big_box.algo.ts:76", + "pc": [ + 275, + 276 + ] + }, + { + "teal": 238, + "source": "examples/big_box/big_box.algo.ts:76", + "pc": [ + 277, + 278 + ] + }, + { + "teal": 239, + "source": "examples/big_box/big_box.algo.ts:76", + "pc": [ + 279, + 280 + ] + }, + { + "teal": 240, + "source": "examples/big_box/big_box.algo.ts:76", + "pc": [ + 281 + ] + }, + { + "teal": 241, + "source": "examples/big_box/big_box.algo.ts:78", + "pc": [ + 282 + ] + }, + { + "teal": 242, + "source": "examples/big_box/big_box.algo.ts:78", + "pc": [ + 283, + 284 + ] + }, + { + "teal": 243, + "source": "examples/big_box/big_box.algo.ts:78", + "pc": [ + 285 + ] + }, + { + "teal": 244, + "source": "examples/big_box/big_box.algo.ts:78", + "pc": [ + 286 + ] + }, + { + "teal": 245, + "source": "examples/big_box/big_box.algo.ts:78", + "pc": [ + 287, + 288, + 289 + ] + }, + { + "teal": 246, + "source": "examples/big_box/big_box.algo.ts:78", + "pc": [ + 290, + 291 + ] + }, + { + "teal": 247, + "source": "examples/big_box/big_box.algo.ts:76", + "pc": [ + 292, + 293 + ] + }, + { + "teal": 248, + "source": "examples/big_box/big_box.algo.ts:76", + "pc": [ + 294, + 295 + ] + }, + { + "teal": 249, + "source": "examples/big_box/big_box.algo.ts:76", + "pc": [ + 296, + 297 + ] + }, + { + "teal": 250, + "source": "examples/big_box/big_box.algo.ts:76", + "pc": [ + 298 + ] + }, + { + "teal": 251, + "source": "examples/big_box/big_box.algo.ts:78", + "pc": [ + 299 + ] + }, + { + "teal": 252, + "source": "examples/big_box/big_box.algo.ts:78", + "pc": [ + 300 + ] + }, + { + "teal": 253, + "source": "examples/big_box/big_box.algo.ts:78", + "pc": [ + 301 + ] }, { + "teal": 256, + "source": "examples/big_box/big_box.algo.ts:78", "pc": [ - 67 - ], - "errorMessage": "argument 0 (mbrPayment) for startUpload must be a pay transaction" + 302 + ] }, { + "teal": 261, + "source": "examples/big_box/big_box.algo.ts:80", "pc": [ - 218 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"mbrPayment\",\"field\":\"receiver\",\"expected\":\"this.app.address\"}" + 303, + 304 + ] }, { + "teal": 262, + "source": "examples/big_box/big_box.algo.ts:80", "pc": [ - 226 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"mbrPayment\",\"field\":\"amount\",\"expected\":\"totalCost\"}" + 305, + 306 + ] + }, + { + "teal": 263, + "source": "examples/big_box/big_box.algo.ts:80", + "pc": [ + 307 + ] + }, + { + "teal": 264, + "source": "examples/big_box/big_box.algo.ts:80", + "pc": [ + 308, + 309, + 310 + ] + }, + { + "teal": 269, + "source": "examples/big_box/big_box.algo.ts:81", + "pc": [ + 311, + 312 + ] + }, + { + "teal": 270, + "source": "examples/big_box/big_box.algo.ts:81", + "pc": [ + 313 + ] + }, + { + "teal": 271, + "source": "examples/big_box/big_box.algo.ts:81", + "pc": [ + 314, + 315 + ] + }, + { + "teal": 272, + "source": "examples/big_box/big_box.algo.ts:76", + "pc": [ + 316, + 317 + ] + }, + { + "teal": 273, + "source": "examples/big_box/big_box.algo.ts:76", + "pc": [ + 318, + 319 + ] + }, + { + "teal": 274, + "source": "examples/big_box/big_box.algo.ts:76", + "pc": [ + 320, + 321 + ] + }, + { + "teal": 275, + "source": "examples/big_box/big_box.algo.ts:76", + "pc": [ + 322 + ] + }, + { + "teal": 276, + "source": "examples/big_box/big_box.algo.ts:81", + "pc": [ + 323 + ] + }, + { + "teal": 277, + "source": "examples/big_box/big_box.algo.ts:81", + "pc": [ + 324 + ] + }, + { + "teal": 278, + "source": "examples/big_box/big_box.algo.ts:81", + "pc": [ + 325, + 326, + 327 + ] + }, + { + "teal": 279, + "source": "examples/big_box/big_box.algo.ts:76", + "pc": [ + 328, + 329 + ] + }, + { + "teal": 280, + "source": "examples/big_box/big_box.algo.ts:76", + "pc": [ + 330, + 331 + ] + }, + { + "teal": 281, + "source": "examples/big_box/big_box.algo.ts:76", + "pc": [ + 332, + 333 + ] + }, + { + "teal": 282, + "source": "examples/big_box/big_box.algo.ts:76", + "pc": [ + 334 + ] + }, + { + "teal": 283, + "source": "examples/big_box/big_box.algo.ts:81", + "pc": [ + 335 + ] + }, + { + "teal": 284, + "source": "examples/big_box/big_box.algo.ts:81", + "pc": [ + 336, + 337, + 338 + ] + }, + { + "teal": 287, + "source": "examples/big_box/big_box.algo.ts:81", + "pc": [ + 339, + 340, + 341, + 342 + ] + }, + { + "teal": 290, + "source": "examples/big_box/big_box.algo.ts:81", + "pc": [ + 343 + ] }, { + "teal": 291, + "source": "examples/big_box/big_box.algo.ts:81", + "pc": [ + 344 + ] + }, + { + "teal": 296, + "source": "examples/big_box/big_box.algo.ts:84", + "pc": [ + 345, + 346 + ] + }, + { + "teal": 297, + "source": "examples/big_box/big_box.algo.ts:84", + "pc": [ + 347 + ] + }, + { + "teal": 298, + "source": "examples/big_box/big_box.algo.ts:84", + "pc": [ + 348, + 349 + ] + }, + { + "teal": 299, + "source": "examples/big_box/big_box.algo.ts:84", + "pc": [ + 350, + 351 + ] + }, + { + "teal": 300, + "source": "examples/big_box/big_box.algo.ts:84", + "pc": [ + 352 + ] + }, + { + "teal": 301, + "source": "examples/big_box/big_box.algo.ts:75", + "pc": [ + 353 + ] + }, + { + "teal": 306, + "source": "examples/big_box/big_box.algo.ts:94", + "pc": [ + 354, + 355, + 356 + ] + }, + { + "teal": 307, + "source": "examples/big_box/big_box.algo.ts:94", + "pc": [ + 357 + ] + }, + { + "teal": 308, + "source": "examples/big_box/big_box.algo.ts:94", + "pc": [ + 358 + ] + }, + { + "teal": 309, + "source": "examples/big_box/big_box.algo.ts:94", + "pc": [ + 359, + 360 + ] + }, + { + "teal": 310, + "source": "examples/big_box/big_box.algo.ts:94", + "pc": [ + 361 + ] + }, + { + "teal": 313, + "source": "examples/big_box/big_box.algo.ts:94", + "errorMessage": "argument 0 (status) for setStatus must be a uint8", "pc": [ 362 - ], - "errorMessage": "argument 0 (status) for setStatus must be a uint8" + ] + }, + { + "teal": 314, + "source": "examples/big_box/big_box.algo.ts:94", + "pc": [ + 363 + ] + }, + { + "teal": 317, + "source": "examples/big_box/big_box.algo.ts:94", + "pc": [ + 364, + 365, + 366 + ] + }, + { + "teal": 318, + "source": "examples/big_box/big_box.algo.ts:94", + "pc": [ + 367, + 368, + 369 + ] + }, + { + "teal": 321, + "source": "examples/big_box/big_box.algo.ts:94", + "pc": [ + 370, + 371, + 372 + ] + }, + { + "teal": 322, + "source": "examples/big_box/big_box.algo.ts:94", + "pc": [ + 373, + 374 + ] + }, + { + "teal": 323, + "source": "examples/big_box/big_box.algo.ts:94", + "pc": [ + 375 + ] + }, + { + "teal": 333, + "source": "examples/big_box/big_box.algo.ts:94", + "pc": [ + 376, + 377, + 378 + ] + }, + { + "teal": 336, + "source": "examples/big_box/big_box.algo.ts:94", + "pc": [ + 379, + 380 + ] + }, + { + "teal": 340, + "source": "examples/big_box/big_box.algo.ts:95", + "pc": [ + 381, + 382 + ] + }, + { + "teal": 341, + "source": "examples/big_box/big_box.algo.ts:95", + "pc": [ + 383, + 384 + ] + }, + { + "teal": 342, + "source": "examples/big_box/big_box.algo.ts:95", + "pc": [ + 385, + 386 + ] + }, + { + "teal": 343, + "source": "examples/big_box/big_box.algo.ts:95", + "pc": [ + 387 + ] + }, + { + "teal": 344, + "source": "examples/big_box/big_box.algo.ts:95", + "pc": [ + 388 + ] + }, + { + "teal": 345, + "source": "examples/big_box/big_box.algo.ts:95", + "pc": [ + 389, + 390 + ] + }, + { + "teal": 349, + "source": "examples/big_box/big_box.algo.ts:97", + "pc": [ + 391, + 392 + ] + }, + { + "teal": 350, + "source": "examples/big_box/big_box.algo.ts:97", + "pc": [ + 393, + 394 + ] + }, + { + "teal": 351, + "source": "examples/big_box/big_box.algo.ts:97", + "pc": [ + 395 + ] + }, + { + "teal": 352, + "source": "examples/big_box/big_box.algo.ts:97", + "pc": [ + 396 + ] + }, + { + "teal": 353, + "source": "examples/big_box/big_box.algo.ts:97", + "pc": [ + 397, + 398, + 399 + ] + }, + { + "teal": 354, + "source": "examples/big_box/big_box.algo.ts:97", + "pc": [ + 400, + 401 + ] + }, + { + "teal": 355, + "source": "examples/big_box/big_box.algo.ts:97", + "pc": [ + 402, + 403 + ] + }, + { + "teal": 356, + "source": "examples/big_box/big_box.algo.ts:97", + "pc": [ + 404 + ] + }, + { + "teal": 357, + "source": "examples/big_box/big_box.algo.ts:97", + "pc": [ + 405 + ] + }, + { + "teal": 360, + "source": "examples/big_box/big_box.algo.ts:97", + "pc": [ + 406 + ] + }, + { + "teal": 361, + "source": "examples/big_box/big_box.algo.ts:97", + "pc": [ + 407, + 408, + 409 + ] + }, + { + "teal": 362, + "source": "examples/big_box/big_box.algo.ts:97", + "pc": [ + 410, + 411 + ] + }, + { + "teal": 363, + "source": "examples/big_box/big_box.algo.ts:97", + "pc": [ + 412, + 413 + ] + }, + { + "teal": 364, + "source": "examples/big_box/big_box.algo.ts:97", + "pc": [ + 414 + ] + }, + { + "teal": 365, + "source": "examples/big_box/big_box.algo.ts:97", + "pc": [ + 415 + ] + }, + { + "teal": 368, + "source": "examples/big_box/big_box.algo.ts:97", + "pc": [ + 416 + ] + }, + { + "teal": 372, + "source": "examples/big_box/big_box.algo.ts:98", + "pc": [ + 417, + 418 + ] + }, + { + "teal": 373, + "source": "examples/big_box/big_box.algo.ts:98", + "pc": [ + 419, + 420 + ] + }, + { + "teal": 374, + "source": "examples/big_box/big_box.algo.ts:98", + "pc": [ + 421 + ] + }, + { + "teal": 375, + "source": "examples/big_box/big_box.algo.ts:98", + "pc": [ + 422 + ] + }, + { + "teal": 379, + "source": "examples/big_box/big_box.algo.ts:100", + "pc": [ + 423, + 424 + ] + }, + { + "teal": 380, + "source": "examples/big_box/big_box.algo.ts:100", + "pc": [ + 425, + 426 + ] + }, + { + "teal": 381, + "source": "examples/big_box/big_box.algo.ts:100", + "pc": [ + 427 + ] + }, + { + "teal": 382, + "source": "examples/big_box/big_box.algo.ts:100", + "pc": [ + 428, + 429, + 430 + ] + }, + { + "teal": 383, + "source": "examples/big_box/big_box.algo.ts:100", + "pc": [ + 431, + 432 + ] + }, + { + "teal": 384, + "source": "examples/big_box/big_box.algo.ts:100", + "pc": [ + 433, + 434 + ] + }, + { + "teal": 385, + "source": "examples/big_box/big_box.algo.ts:100", + "pc": [ + 435 + ] + }, + { + "teal": 386, + "source": "examples/big_box/big_box.algo.ts:94", + "pc": [ + 436 + ] + }, + { + "teal": 389, + "source": "examples/big_box/big_box.algo.ts:20", + "pc": [ + 437, + 438 + ] + }, + { + "teal": 390, + "source": "examples/big_box/big_box.algo.ts:20", + "pc": [ + 439 + ] + }, + { + "teal": 393, + "source": "examples/big_box/big_box.algo.ts:20", + "pc": [ + 440, + 441, + 442, + 443, + 444, + 445 + ] + }, + { + "teal": 394, + "source": "examples/big_box/big_box.algo.ts:20", + "pc": [ + 446, + 447, + 448 + ] + }, + { + "teal": 395, + "source": "examples/big_box/big_box.algo.ts:20", + "pc": [ + 449, + 450, + 451, + 452 + ] }, { + "teal": 398, + "source": "examples/big_box/big_box.algo.ts:20", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 453 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 401, + "source": "examples/big_box/big_box.algo.ts:20", + "pc": [ + 454, + 455, + 456, + 457, + 458, + 459 + ] + }, + { + "teal": 402, + "source": "examples/big_box/big_box.algo.ts:20", + "pc": [ + 460, + 461, + 462, + 463, + 464, + 465 + ] + }, + { + "teal": 403, + "source": "examples/big_box/big_box.algo.ts:20", + "pc": [ + 466, + 467, + 468, + 469, + 470, + 471 + ] + }, + { + "teal": 404, + "source": "examples/big_box/big_box.algo.ts:20", + "pc": [ + 472, + 473, + 474 + ] + }, + { + "teal": 405, + "source": "examples/big_box/big_box.algo.ts:20", + "pc": [ + 475, + 476, + 477, + 478, + 479, + 480, + 481, + 482 + ] }, { + "teal": 408, + "source": "examples/big_box/big_box.algo.ts:20", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 483 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/examples/calculator/artifacts/Calculator.arc56_draft.json b/examples/calculator/artifacts/Calculator.arc56_draft.json index 9027396a7..3989b529a 100644 --- a/examples/calculator/artifacts/Calculator.arc56_draft.json +++ b/examples/calculator/artifacts/Calculator.arc56_draft.json @@ -82,28 +82,647 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "examples/calculator/calculator.algo.ts:4", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "examples/calculator/calculator.algo.ts:4", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "examples/calculator/calculator.algo.ts:4", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "examples/calculator/calculator.algo.ts:4", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "examples/calculator/calculator.algo.ts:4", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "examples/calculator/calculator.algo.ts:4", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "examples/calculator/calculator.algo.ts:4", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "examples/calculator/calculator.algo.ts:4", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "examples/calculator/calculator.algo.ts:4", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 33, + "source": "examples/calculator/calculator.algo.ts:12", + "pc": [ + 37, + 38, + 39 + ] + }, + { + "teal": 37, + "source": "examples/calculator/calculator.algo.ts:13", + "pc": [ + 40, + 41 + ] + }, + { + "teal": 38, + "source": "examples/calculator/calculator.algo.ts:13", + "pc": [ + 42, + 43 + ] + }, + { + "teal": 39, + "source": "examples/calculator/calculator.algo.ts:13", + "pc": [ + 44 + ] + }, + { + "teal": 40, + "source": "examples/calculator/calculator.algo.ts:12", + "pc": [ + 45 + ] + }, + { + "teal": 50, + "source": "examples/calculator/calculator.algo.ts:23", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 54, + "source": "examples/calculator/calculator.algo.ts:24", + "pc": [ + 49, + 50 + ] + }, + { + "teal": 55, + "source": "examples/calculator/calculator.algo.ts:24", + "pc": [ + 51, + 52 + ] + }, + { + "teal": 56, + "source": "examples/calculator/calculator.algo.ts:24", + "pc": [ + 53 + ] + }, + { + "teal": 57, + "source": "examples/calculator/calculator.algo.ts:24", + "pc": [ + 54, + 55, + 56 + ] + }, + { + "teal": 58, + "source": "examples/calculator/calculator.algo.ts:24", + "pc": [ + 57, + 58 + ] + }, + { + "teal": 59, + "source": "examples/calculator/calculator.algo.ts:24", + "pc": [ + 59, + 60 + ] + }, + { + "teal": 60, + "source": "examples/calculator/calculator.algo.ts:24", + "pc": [ + 61 + ] + }, + { + "teal": 61, + "source": "examples/calculator/calculator.algo.ts:24", + "pc": [ + 62, + 63, + 64 + ] + }, + { + "teal": 64, + "source": "examples/calculator/calculator.algo.ts:24", + "pc": [ + 65, + 66 + ] + }, + { + "teal": 65, + "source": "examples/calculator/calculator.algo.ts:24", + "pc": [ + 67, + 68 + ] + }, + { + "teal": 66, + "source": "examples/calculator/calculator.algo.ts:24", + "pc": [ + 69 + ] + }, + { + "teal": 69, + "source": "examples/calculator/calculator.algo.ts:23", + "pc": [ + 70 + ] + }, + { + "teal": 74, + "source": "examples/calculator/calculator.algo.ts:36", + "pc": [ + 71, + 72, + 73, + 74, + 75, + 76 + ] + }, + { + "teal": 77, + "source": "examples/calculator/calculator.algo.ts:36", + "pc": [ + 77, + 78, + 79 + ] + }, + { + "teal": 78, + "source": "examples/calculator/calculator.algo.ts:36", + "pc": [ + 80, + 81, + 82 + ] + }, + { + "teal": 81, + "source": "examples/calculator/calculator.algo.ts:36", + "pc": [ + 83, + 84, + 85 + ] + }, + { + "teal": 82, + "source": "examples/calculator/calculator.algo.ts:36", + "pc": [ + 86 + ] + }, + { + "teal": 85, + "source": "examples/calculator/calculator.algo.ts:36", + "pc": [ + 87, + 88, + 89 + ] + }, + { + "teal": 86, + "source": "examples/calculator/calculator.algo.ts:36", + "pc": [ + 90 + ] + }, + { + "teal": 89, + "source": "examples/calculator/calculator.algo.ts:36", + "pc": [ + 91, + 92, + 93 + ] + }, + { + "teal": 90, + "source": "examples/calculator/calculator.algo.ts:36", + "pc": [ + 94 + ] }, { + "teal": 91, + "source": "examples/calculator/calculator.algo.ts:36", + "pc": [ + 95 + ] + }, + { + "teal": 92, + "source": "examples/calculator/calculator.algo.ts:36", + "pc": [ + 96 + ] + }, + { + "teal": 93, + "source": "examples/calculator/calculator.algo.ts:36", + "pc": [ + 97, + 98 + ] + }, + { + "teal": 94, + "source": "examples/calculator/calculator.algo.ts:36", + "pc": [ + 99 + ] + }, + { + "teal": 106, + "source": "examples/calculator/calculator.algo.ts:36", + "pc": [ + 100, + 101, + 102 + ] + }, + { + "teal": 109, + "source": "examples/calculator/calculator.algo.ts:36", + "pc": [ + 103, + 104 + ] + }, + { + "teal": 114, + "source": "examples/calculator/calculator.algo.ts:39", + "pc": [ + 105, + 106 + ] + }, + { + "teal": 115, + "source": "examples/calculator/calculator.algo.ts:39", + "pc": [ + 107, + 108, + 109, + 110, + 111 + ] + }, + { + "teal": 116, + "source": "examples/calculator/calculator.algo.ts:39", + "pc": [ + 112 + ] + }, + { + "teal": 117, + "source": "examples/calculator/calculator.algo.ts:39", + "pc": [ + 113, + 114, + 115 + ] + }, + { + "teal": 122, + "source": "examples/calculator/calculator.algo.ts:40", + "pc": [ + 116, + 117 + ] + }, + { + "teal": 123, + "source": "examples/calculator/calculator.algo.ts:40", + "pc": [ + 118, + 119 + ] + }, + { + "teal": 124, + "source": "examples/calculator/calculator.algo.ts:40", + "pc": [ + 120, + 121, + 122 + ] + }, + { + "teal": 125, + "source": "examples/calculator/calculator.algo.ts:40", + "pc": [ + 123, + 124 + ] + }, + { + "teal": 126, + "source": "examples/calculator/calculator.algo.ts:39", + "pc": [ + 125, + 126, + 127 + ] + }, + { + "teal": 131, + "source": "examples/calculator/calculator.algo.ts:41", + "pc": [ + 128, + 129 + ] + }, + { + "teal": 132, + "source": "examples/calculator/calculator.algo.ts:41", + "pc": [ + 130, + 131, + 132, + 133, + 134, + 135, + 136, + 137, + 138, + 139, + 140, + 141 + ] + }, + { + "teal": 133, + "source": "examples/calculator/calculator.algo.ts:41", + "pc": [ + 142 + ] + }, + { + "teal": 134, + "source": "examples/calculator/calculator.algo.ts:41", + "pc": [ + 143, + 144, + 145 + ] + }, + { + "teal": 139, + "source": "examples/calculator/calculator.algo.ts:42", + "pc": [ + 146, + 147 + ] + }, + { + "teal": 140, + "source": "examples/calculator/calculator.algo.ts:42", + "pc": [ + 148, + 149 + ] + }, + { + "teal": 141, + "source": "examples/calculator/calculator.algo.ts:42", + "pc": [ + 150, + 151, + 152 + ] + }, + { + "teal": 142, + "source": "examples/calculator/calculator.algo.ts:42", + "pc": [ + 153, + 154 + ] + }, + { + "teal": 143, + "source": "examples/calculator/calculator.algo.ts:41", + "pc": [ + 155, + 156, + 157 + ] + }, + { + "teal": 147, + "source": "examples/calculator/calculator.algo.ts:43", + "errorMessage": "Invalid operation", "pc": [ 158 - ], - "errorMessage": "Invalid operation" + ] + }, + { + "teal": 152, + "source": "examples/calculator/calculator.algo.ts:45", + "pc": [ + 159, + 160 + ] + }, + { + "teal": 155, + "source": "examples/calculator/calculator.algo.ts:36", + "pc": [ + 161, + 162 + ] + }, + { + "teal": 156, + "source": "examples/calculator/calculator.algo.ts:36", + "pc": [ + 163 + ] + }, + { + "teal": 159, + "source": "examples/calculator/calculator.algo.ts:4", + "pc": [ + 164, + 165 + ] + }, + { + "teal": 160, + "source": "examples/calculator/calculator.algo.ts:4", + "pc": [ + 166 + ] + }, + { + "teal": 163, + "source": "examples/calculator/calculator.algo.ts:4", + "pc": [ + 167, + 168, + 169, + 170, + 171, + 172 + ] + }, + { + "teal": 164, + "source": "examples/calculator/calculator.algo.ts:4", + "pc": [ + 173, + 174, + 175 + ] + }, + { + "teal": 165, + "source": "examples/calculator/calculator.algo.ts:4", + "pc": [ + 176, + 177, + 178, + 179 + ] }, { + "teal": 168, + "source": "examples/calculator/calculator.algo.ts:4", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 180 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 171, + "source": "examples/calculator/calculator.algo.ts:4", + "pc": [ + 181, + 182, + 183, + 184, + 185, + 186 + ] + }, + { + "teal": 172, + "source": "examples/calculator/calculator.algo.ts:4", + "pc": [ + 187, + 188, + 189 + ] + }, + { + "teal": 173, + "source": "examples/calculator/calculator.algo.ts:4", + "pc": [ + 190, + 191, + 192, + 193 + ] }, { + "teal": 176, + "source": "examples/calculator/calculator.algo.ts:4", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 194 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/examples/itxns/artifacts/FactoryCaller.arc56_draft.json b/examples/itxns/artifacts/FactoryCaller.arc56_draft.json index 8011fec3b..1b6e7bf9b 100644 --- a/examples/itxns/artifacts/FactoryCaller.arc56_draft.json +++ b/examples/itxns/artifacts/FactoryCaller.arc56_draft.json @@ -64,22 +64,1100 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "examples/itxns/itxns.algo.ts:23", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "examples/itxns/itxns.algo.ts:23", + "pc": [ + 1, + 2, + 3, + 4, + 5, + 6, + 7, + 8 + ] + }, + { + "teal": 14, + "source": "examples/itxns/itxns.algo.ts:23", + "pc": [ + 9, + 10 + ] + }, + { + "teal": 15, + "source": "examples/itxns/itxns.algo.ts:23", + "pc": [ + 11 + ] + }, + { + "teal": 16, + "source": "examples/itxns/itxns.algo.ts:23", + "pc": [ + 12, + 13 + ] + }, + { + "teal": 17, + "source": "examples/itxns/itxns.algo.ts:23", + "pc": [ + 14 + ] + }, + { + "teal": 18, + "source": "examples/itxns/itxns.algo.ts:23", + "pc": [ + 15, + 16 + ] + }, + { + "teal": 19, + "source": "examples/itxns/itxns.algo.ts:23", + "pc": [ + 17 + ] + }, + { + "teal": 20, + "source": "examples/itxns/itxns.algo.ts:23", + "pc": [ + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38, + 39, + 40, + 41, + 42, + 43 + ] + }, + { + "teal": 24, + "source": "examples/itxns/itxns.algo.ts:23", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 44 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "examples/itxns/itxns.algo.ts:24", + "pc": [ + 45, + 46, + 47, + 48, + 49, + 50 + ] + }, + { + "teal": 32, + "source": "examples/itxns/itxns.algo.ts:24", + "pc": [ + 51, + 52, + 53 + ] + }, + { + "teal": 33, + "source": "examples/itxns/itxns.algo.ts:24", + "pc": [ + 54 + ] + }, + { + "teal": 34, + "source": "examples/itxns/itxns.algo.ts:24", + "pc": [ + 55 + ] + }, + { + "teal": 35, + "source": "examples/itxns/itxns.algo.ts:24", + "pc": [ + 56 + ] + }, + { + "teal": 36, + "source": "examples/itxns/itxns.algo.ts:24", + "pc": [ + 57, + 58 + ] + }, + { + "teal": 37, + "source": "examples/itxns/itxns.algo.ts:24", + "pc": [ + 59 + ] + }, + { + "teal": 41, + "source": "examples/itxns/itxns.algo.ts:24", + "pc": [ + 60, + 61, + 62 + ] + }, + { + "teal": 44, + "source": "examples/itxns/itxns.algo.ts:24", + "pc": [ + 63, + 64 + ] + }, + { + "teal": 45, + "source": "examples/itxns/itxns.algo.ts:24", + "pc": [ + 65 + ] + }, + { + "teal": 52, + "source": "examples/itxns/itxns.algo.ts:25", + "pc": [ + 66 + ] + }, + { + "teal": 53, + "source": "examples/itxns/itxns.algo.ts:25", + "pc": [ + 67, + 68 + ] + }, + { + "teal": 54, + "source": "examples/itxns/itxns.algo.ts:25", + "pc": [ + 69, + 70 + ] + }, + { + "teal": 55, + "source": "examples/itxns/itxns.algo.ts:25", + "pc": [ + 71, + 72, + 73, + 74, + 75, + 76 + ] + }, + { + "teal": 56, + "source": "examples/itxns/itxns.algo.ts:25", + "pc": [ + 77, + 78 + ] + }, + { + "teal": 60, + "source": "examples/itxns/itxns.algo.ts:26", + "pc": [ + 79, + 80, + 81 + ] + }, + { + "teal": 61, + "source": "examples/itxns/itxns.algo.ts:26", + "pc": [ + 82, + 83 + ] + }, + { + "teal": 65, + "source": "examples/itxns/itxns.algo.ts:27", + "pc": [ + 84, + 85, + 86, + 87, + 88, + 89, + 90, + 91, + 92, + 93, + 94, + 95, + 96, + 97, + 98, + 99, + 100, + 101, + 102, + 103, + 104, + 105, + 106, + 107, + 108, + 109, + 110, + 111, + 112, + 113, + 114, + 115, + 116, + 117, + 118, + 119, + 120, + 121, + 122, + 123, + 124, + 125, + 126, + 127, + 128, + 129, + 130, + 131, + 132, + 133, + 134, + 135, + 136, + 137, + 138, + 139, + 140, + 141, + 142, + 143, + 144, + 145, + 146, + 147, + 148, + 149, + 150, + 151, + 152, + 153, + 154, + 155, + 156, + 157, + 158, + 159, + 160, + 161, + 162, + 163, + 164, + 165, + 166, + 167, + 168, + 169, + 170, + 171, + 172, + 173, + 174, + 175, + 176, + 177, + 178, + 179, + 180, + 181, + 182, + 183, + 184, + 185, + 186, + 187, + 188, + 189, + 190, + 191, + 192, + 193, + 194, + 195, + 196, + 197, + 198, + 199, + 200, + 201, + 202, + 203, + 204, + 205, + 206, + 207, + 208, + 209, + 210, + 211, + 212, + 213, + 214, + 215, + 216, + 217, + 218, + 219, + 220, + 221, + 222, + 223, + 224, + 225, + 226, + 227, + 228, + 229, + 230, + 231, + 232, + 233, + 234, + 235, + 236, + 237, + 238, + 239, + 240, + 241, + 242, + 243, + 244, + 245, + 246, + 247, + 248, + 249, + 250, + 251, + 252, + 253, + 254, + 255, + 256, + 257, + 258, + 259, + 260, + 261, + 262 + ] + }, + { + "teal": 66, + "source": "examples/itxns/itxns.algo.ts:27", + "pc": [ + 263, + 264 + ] + }, + { + "teal": 69, + "source": "examples/itxns/itxns.algo.ts:25", + "pc": [ + 265, + 266 + ] + }, + { + "teal": 70, + "source": "examples/itxns/itxns.algo.ts:25", + "pc": [ + 267, + 268 + ] + }, + { + "teal": 73, + "source": "examples/itxns/itxns.algo.ts:25", + "pc": [ + 269 + ] + }, + { + "teal": 77, + "source": "examples/itxns/itxns.algo.ts:30", + "pc": [ + 270, + 271 + ] + }, + { + "teal": 78, + "source": "examples/itxns/itxns.algo.ts:30", + "pc": [ + 272, + 273 + ] }, { + "teal": 85, + "source": "examples/itxns/itxns.algo.ts:32", + "pc": [ + 274 + ] + }, + { + "teal": 86, + "source": "examples/itxns/itxns.algo.ts:32", + "pc": [ + 275, + 276 + ] + }, + { + "teal": 87, + "source": "examples/itxns/itxns.algo.ts:32", + "pc": [ + 277, + 278 + ] + }, + { + "teal": 91, + "source": "examples/itxns/itxns.algo.ts:33", + "pc": [ + 279, + 280, + 281, + 282 + ] + }, + { + "teal": 92, + "source": "examples/itxns/itxns.algo.ts:33", + "pc": [ + 283, + 284 + ] + }, + { + "teal": 96, + "source": "examples/itxns/itxns.algo.ts:34", + "pc": [ + 285, + 286 + ] + }, + { + "teal": 97, + "source": "examples/itxns/itxns.algo.ts:34", + "pc": [ + 287, + 288 + ] + }, + { + "teal": 98, + "source": "examples/itxns/itxns.algo.ts:34", + "pc": [ + 289 + ] + }, + { + "teal": 99, + "source": "examples/itxns/itxns.algo.ts:34", + "pc": [ + 290, + 291 + ] + }, + { + "teal": 102, + "source": "examples/itxns/itxns.algo.ts:32", + "pc": [ + 292, + 293 + ] + }, + { + "teal": 103, + "source": "examples/itxns/itxns.algo.ts:32", + "pc": [ + 294, + 295 + ] + }, + { + "teal": 106, + "source": "examples/itxns/itxns.algo.ts:32", + "pc": [ + 296 + ] + }, + { + "teal": 113, + "source": "examples/itxns/itxns.algo.ts:37", + "pc": [ + 297 + ] + }, + { + "teal": 114, + "source": "examples/itxns/itxns.algo.ts:37", + "pc": [ + 298, + 299 + ] + }, + { + "teal": 115, + "source": "examples/itxns/itxns.algo.ts:37", + "pc": [ + 300, + 301 + ] + }, + { + "teal": 116, + "source": "examples/itxns/itxns.algo.ts:37", + "pc": [ + 302, + 303, + 304, + 305, + 306, + 307 + ] + }, + { + "teal": 117, + "source": "examples/itxns/itxns.algo.ts:37", + "pc": [ + 308, + 309 + ] + }, + { + "teal": 121, + "source": "examples/itxns/itxns.algo.ts:38", + "pc": [ + 310, + 311 + ] + }, + { + "teal": 122, + "source": "examples/itxns/itxns.algo.ts:38", + "pc": [ + 312, + 313 + ] + }, + { + "teal": 126, + "source": "examples/itxns/itxns.algo.ts:39", + "pc": [ + 314, + 315, + 316, + 317, + 318, + 319, + 320, + 321, + 322, + 323 + ] + }, + { + "teal": 127, + "source": "examples/itxns/itxns.algo.ts:39", + "pc": [ + 324, + 325 + ] + }, + { + "teal": 128, + "source": "examples/itxns/itxns.algo.ts:39", + "pc": [ + 326, + 327, + 328, + 329, + 330, + 331, + 332, + 333 + ] + }, + { + "teal": 129, + "source": "examples/itxns/itxns.algo.ts:39", + "pc": [ + 334, + 335 + ] + }, + { + "teal": 132, + "source": "examples/itxns/itxns.algo.ts:37", + "pc": [ + 336, + 337 + ] + }, + { + "teal": 133, + "source": "examples/itxns/itxns.algo.ts:37", + "pc": [ + 338, + 339 + ] + }, + { + "teal": 136, + "source": "examples/itxns/itxns.algo.ts:37", + "pc": [ + 340 + ] + }, + { + "teal": 137, + "source": "examples/itxns/itxns.algo.ts:37", + "pc": [ + 341, + 342 + ] + }, + { + "teal": 138, + "source": "examples/itxns/itxns.algo.ts:37", + "pc": [ + 343, + 344 + ] + }, + { + "teal": 139, + "source": "examples/itxns/itxns.algo.ts:37", + "pc": [ + 345 + ] + }, + { + "teal": 140, + "source": "examples/itxns/itxns.algo.ts:37", + "pc": [ + 346, + 347 + ] + }, + { + "teal": 141, + "source": "examples/itxns/itxns.algo.ts:37", + "pc": [ + 348, + 349, + 350 + ] + }, + { + "teal": 142, + "source": "examples/itxns/itxns.algo.ts:37", + "pc": [ + 351 + ] + }, + { + "teal": 143, + "source": "examples/itxns/itxns.algo.ts:37", + "pc": [ + 352, + 353 + ] + }, + { + "teal": 151, + "source": "examples/itxns/itxns.algo.ts:42", + "pc": [ + 354 + ] + }, + { + "teal": 152, + "source": "examples/itxns/itxns.algo.ts:42", + "pc": [ + 355, + 356 + ] + }, + { + "teal": 153, + "source": "examples/itxns/itxns.algo.ts:42", + "pc": [ + 357, + 358 + ] + }, + { + "teal": 157, + "source": "examples/itxns/itxns.algo.ts:43", + "pc": [ + 359, + 360 + ] + }, + { + "teal": 158, + "source": "examples/itxns/itxns.algo.ts:43", + "pc": [ + 361, + 362 + ] + }, + { + "teal": 162, + "source": "examples/itxns/itxns.algo.ts:44", + "pc": [ + 363, + 364 + ] + }, + { + "teal": 163, + "source": "examples/itxns/itxns.algo.ts:44", + "pc": [ + 365, + 366 + ] + }, + { + "teal": 167, + "source": "examples/itxns/itxns.algo.ts:45", + "pc": [ + 367, + 368 + ] + }, + { + "teal": 168, + "source": "examples/itxns/itxns.algo.ts:45", + "pc": [ + 369, + 370 + ] + }, + { + "teal": 171, + "source": "examples/itxns/itxns.algo.ts:42", + "pc": [ + 371, + 372 + ] + }, + { + "teal": 172, + "source": "examples/itxns/itxns.algo.ts:42", + "pc": [ + 373, + 374 + ] + }, + { + "teal": 175, + "source": "examples/itxns/itxns.algo.ts:42", + "pc": [ + 375 + ] + }, + { + "teal": 182, + "source": "examples/itxns/itxns.algo.ts:48", + "pc": [ + 376 + ] + }, + { + "teal": 183, + "source": "examples/itxns/itxns.algo.ts:48", + "pc": [ + 377, + 378 + ] + }, + { + "teal": 184, + "source": "examples/itxns/itxns.algo.ts:48", + "pc": [ + 379, + 380 + ] + }, + { + "teal": 185, + "source": "examples/itxns/itxns.algo.ts:48", + "pc": [ + 381, + 382, + 383, + 384, + 385, + 386 + ] + }, + { + "teal": 186, + "source": "examples/itxns/itxns.algo.ts:48", + "pc": [ + 387, + 388 + ] + }, + { + "teal": 190, + "source": "examples/itxns/itxns.algo.ts:49", + "pc": [ + 389, + 390 + ] + }, + { + "teal": 191, + "source": "examples/itxns/itxns.algo.ts:49", + "pc": [ + 391, + 392 + ] + }, + { + "teal": 195, + "source": "examples/itxns/itxns.algo.ts:50", + "pc": [ + 393, + 394 + ] + }, + { + "teal": 196, + "source": "examples/itxns/itxns.algo.ts:50", + "pc": [ + 395 + ] + }, + { + "teal": 197, + "source": "examples/itxns/itxns.algo.ts:50", + "pc": [ + 396, + 397 + ] + }, + { + "teal": 198, + "source": "examples/itxns/itxns.algo.ts:50", + "pc": [ + 398, + 399 + ] + }, + { + "teal": 199, + "source": "examples/itxns/itxns.algo.ts:50", + "pc": [ + 400, + 401 + ] + }, + { + "teal": 202, + "source": "examples/itxns/itxns.algo.ts:48", + "pc": [ + 402, + 403 + ] + }, + { + "teal": 203, + "source": "examples/itxns/itxns.algo.ts:48", + "pc": [ + 404, + 405 + ] + }, + { + "teal": 206, + "source": "examples/itxns/itxns.algo.ts:48", + "pc": [ + 406 + ] + }, + { + "teal": 210, + "source": "examples/itxns/itxns.algo.ts:53", + "pc": [ + 407, + 408 + ] + }, + { + "teal": 213, + "source": "examples/itxns/itxns.algo.ts:24", + "pc": [ + 409, + 410 + ] + }, + { + "teal": 216, + "source": "examples/itxns/itxns.algo.ts:24", + "pc": [ + 411, + 412 + ] + }, + { + "teal": 217, + "source": "examples/itxns/itxns.algo.ts:24", + "pc": [ + 413 + ] + }, + { + "teal": 220, + "source": "examples/itxns/itxns.algo.ts:23", + "pc": [ + 414, + 415 + ] + }, + { + "teal": 221, + "source": "examples/itxns/itxns.algo.ts:23", + "pc": [ + 416 + ] + }, + { + "teal": 224, + "source": "examples/itxns/itxns.algo.ts:23", + "pc": [ + 417, + 418, + 419, + 420, + 421, + 422 + ] + }, + { + "teal": 225, + "source": "examples/itxns/itxns.algo.ts:23", + "pc": [ + 423, + 424, + 425 + ] + }, + { + "teal": 226, + "source": "examples/itxns/itxns.algo.ts:23", + "pc": [ + 426, + 427, + 428, + 429 + ] + }, + { + "teal": 229, + "source": "examples/itxns/itxns.algo.ts:23", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 430 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 232, + "source": "examples/itxns/itxns.algo.ts:23", + "pc": [ + 431, + 432, + 433, + 434, + 435, + 436 + ] + }, + { + "teal": 233, + "source": "examples/itxns/itxns.algo.ts:23", + "pc": [ + 437, + 438, + 439 + ] + }, + { + "teal": 234, + "source": "examples/itxns/itxns.algo.ts:23", + "pc": [ + 440, + 441, + 442, + 443 + ] }, { + "teal": 237, + "source": "examples/itxns/itxns.algo.ts:23", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 444 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/examples/itxns/artifacts/NFTFactory.arc56_draft.json b/examples/itxns/artifacts/NFTFactory.arc56_draft.json index 62cab4e16..134e9ae2c 100644 --- a/examples/itxns/artifacts/NFTFactory.arc56_draft.json +++ b/examples/itxns/artifacts/NFTFactory.arc56_draft.json @@ -95,28 +95,610 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "examples/itxns/itxns.algo.ts:4", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "examples/itxns/itxns.algo.ts:4", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "examples/itxns/itxns.algo.ts:4", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "examples/itxns/itxns.algo.ts:4", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "examples/itxns/itxns.algo.ts:4", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "examples/itxns/itxns.algo.ts:4", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "examples/itxns/itxns.algo.ts:4", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "examples/itxns/itxns.algo.ts:4", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "examples/itxns/itxns.algo.ts:4", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "examples/itxns/itxns.algo.ts:5", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "examples/itxns/itxns.algo.ts:5", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "examples/itxns/itxns.algo.ts:5", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 35, + "source": "examples/itxns/itxns.algo.ts:5", + "pc": [ + 49, + 50, + 51 + ] + }, + { + "teal": 36, + "source": "examples/itxns/itxns.algo.ts:5", + "pc": [ + 52, + 53, + 54 + ] + }, + { + "teal": 39, + "source": "examples/itxns/itxns.algo.ts:5", + "pc": [ + 55, + 56, + 57 + ] + }, + { + "teal": 40, + "source": "examples/itxns/itxns.algo.ts:5", + "pc": [ + 58 + ] + }, + { + "teal": 41, + "source": "examples/itxns/itxns.algo.ts:5", + "pc": [ + 59 + ] + }, + { + "teal": 42, + "source": "examples/itxns/itxns.algo.ts:5", + "pc": [ + 60 + ] }, { + "teal": 43, + "source": "examples/itxns/itxns.algo.ts:5", + "pc": [ + 61, + 62 + ] + }, + { + "teal": 44, + "source": "examples/itxns/itxns.algo.ts:5", + "pc": [ + 63 + ] + }, + { + "teal": 48, + "source": "examples/itxns/itxns.algo.ts:5", + "pc": [ + 64, + 65, + 66 + ] + }, + { + "teal": 56, + "source": "examples/itxns/itxns.algo.ts:6", + "pc": [ + 67 + ] + }, + { + "teal": 57, + "source": "examples/itxns/itxns.algo.ts:6", + "pc": [ + 68, + 69 + ] + }, + { + "teal": 58, + "source": "examples/itxns/itxns.algo.ts:6", + "pc": [ + 70, + 71 + ] + }, + { + "teal": 62, + "source": "examples/itxns/itxns.algo.ts:7", + "pc": [ + 72, + 73 + ] + }, + { + "teal": 63, + "source": "examples/itxns/itxns.algo.ts:7", + "pc": [ + 74, + 75 + ] + }, + { + "teal": 67, + "source": "examples/itxns/itxns.algo.ts:8", + "pc": [ + 76, + 77 + ] + }, + { + "teal": 68, + "source": "examples/itxns/itxns.algo.ts:8", + "pc": [ + 78, + 79 + ] + }, + { + "teal": 72, + "source": "examples/itxns/itxns.algo.ts:9", + "pc": [ + 80, + 81 + ] + }, + { + "teal": 73, + "source": "examples/itxns/itxns.algo.ts:9", + "pc": [ + 82, + 83 + ] + }, + { + "teal": 76, + "source": "examples/itxns/itxns.algo.ts:6", + "pc": [ + 84, + 85 + ] + }, + { + "teal": 77, + "source": "examples/itxns/itxns.algo.ts:6", + "pc": [ + 86, + 87 + ] + }, + { + "teal": 80, + "source": "examples/itxns/itxns.algo.ts:6", + "pc": [ + 88 + ] + }, + { + "teal": 81, + "source": "examples/itxns/itxns.algo.ts:6", + "pc": [ + 89, + 90 + ] + }, + { + "teal": 82, + "source": "examples/itxns/itxns.algo.ts:5", + "pc": [ + 91 + ] + }, + { + "teal": 87, + "source": "examples/itxns/itxns.algo.ts:13", + "pc": [ + 92, + 93, + 94 + ] + }, + { + "teal": 88, + "source": "examples/itxns/itxns.algo.ts:13", + "pc": [ + 95 + ] + }, + { + "teal": 89, + "source": "examples/itxns/itxns.algo.ts:13", + "pc": [ + 96 + ] + }, + { + "teal": 90, + "source": "examples/itxns/itxns.algo.ts:13", + "pc": [ + 97, + 98 + ] + }, + { + "teal": 91, + "source": "examples/itxns/itxns.algo.ts:13", + "pc": [ + 99 + ] + }, + { + "teal": 94, + "source": "examples/itxns/itxns.algo.ts:13", + "errorMessage": "argument 0 (receiver) for transferNFT must be a address", "pc": [ 100 - ], - "errorMessage": "argument 0 (receiver) for transferNFT must be a address" + ] + }, + { + "teal": 97, + "source": "examples/itxns/itxns.algo.ts:13", + "pc": [ + 101, + 102, + 103 + ] + }, + { + "teal": 98, + "source": "examples/itxns/itxns.algo.ts:13", + "pc": [ + 104 + ] + }, + { + "teal": 101, + "source": "examples/itxns/itxns.algo.ts:13", + "pc": [ + 105, + 106, + 107 + ] + }, + { + "teal": 102, + "source": "examples/itxns/itxns.algo.ts:13", + "pc": [ + 108, + 109 + ] + }, + { + "teal": 103, + "source": "examples/itxns/itxns.algo.ts:13", + "pc": [ + 110 + ] + }, + { + "teal": 107, + "source": "examples/itxns/itxns.algo.ts:13", + "pc": [ + 111, + 112, + 113 + ] + }, + { + "teal": 115, + "source": "examples/itxns/itxns.algo.ts:14", + "pc": [ + 114 + ] + }, + { + "teal": 116, + "source": "examples/itxns/itxns.algo.ts:14", + "pc": [ + 115, + 116 + ] + }, + { + "teal": 117, + "source": "examples/itxns/itxns.algo.ts:14", + "pc": [ + 117, + 118 + ] + }, + { + "teal": 121, + "source": "examples/itxns/itxns.algo.ts:15", + "pc": [ + 119, + 120 + ] + }, + { + "teal": 122, + "source": "examples/itxns/itxns.algo.ts:15", + "pc": [ + 121, + 122 + ] + }, + { + "teal": 126, + "source": "examples/itxns/itxns.algo.ts:16", + "pc": [ + 123, + 124 + ] + }, + { + "teal": 127, + "source": "examples/itxns/itxns.algo.ts:16", + "pc": [ + 125, + 126 + ] + }, + { + "teal": 131, + "source": "examples/itxns/itxns.algo.ts:17", + "pc": [ + 127, + 128 + ] + }, + { + "teal": 132, + "source": "examples/itxns/itxns.algo.ts:17", + "pc": [ + 129, + 130 + ] + }, + { + "teal": 135, + "source": "examples/itxns/itxns.algo.ts:14", + "pc": [ + 131, + 132 + ] + }, + { + "teal": 136, + "source": "examples/itxns/itxns.algo.ts:14", + "pc": [ + 133, + 134 + ] + }, + { + "teal": 139, + "source": "examples/itxns/itxns.algo.ts:14", + "pc": [ + 135 + ] + }, + { + "teal": 140, + "source": "examples/itxns/itxns.algo.ts:13", + "pc": [ + 136 + ] + }, + { + "teal": 143, + "source": "examples/itxns/itxns.algo.ts:4", + "pc": [ + 137, + 138 + ] + }, + { + "teal": 144, + "source": "examples/itxns/itxns.algo.ts:4", + "pc": [ + 139 + ] + }, + { + "teal": 147, + "source": "examples/itxns/itxns.algo.ts:4", + "pc": [ + 140, + 141, + 142, + 143, + 144, + 145 + ] + }, + { + "teal": 148, + "source": "examples/itxns/itxns.algo.ts:4", + "pc": [ + 146, + 147, + 148 + ] + }, + { + "teal": 149, + "source": "examples/itxns/itxns.algo.ts:4", + "pc": [ + 149, + 150, + 151, + 152 + ] }, { + "teal": 152, + "source": "examples/itxns/itxns.algo.ts:4", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 153 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 155, + "source": "examples/itxns/itxns.algo.ts:4", + "pc": [ + 154, + 155, + 156, + 157, + 158, + 159 + ] + }, + { + "teal": 156, + "source": "examples/itxns/itxns.algo.ts:4", + "pc": [ + 160, + 161, + 162, + 163, + 164, + 165 + ] + }, + { + "teal": 157, + "source": "examples/itxns/itxns.algo.ts:4", + "pc": [ + 166, + 167, + 168 + ] + }, + { + "teal": 158, + "source": "examples/itxns/itxns.algo.ts:4", + "pc": [ + 169, + 170, + 171, + 172, + 173, + 174 + ] }, { + "teal": 161, + "source": "examples/itxns/itxns.algo.ts:4", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 175 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/examples/lsig_with_app/artifacts/CreatorVerifier.arc56_draft.json b/examples/lsig_with_app/artifacts/CreatorVerifier.arc56_draft.json index cc8961892..eb4c3f00f 100644 --- a/examples/lsig_with_app/artifacts/CreatorVerifier.arc56_draft.json +++ b/examples/lsig_with_app/artifacts/CreatorVerifier.arc56_draft.json @@ -112,46 +112,731 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:35", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:35", + "pc": [ + 1, + 2, + 3, + 4 + ] + }, + { + "teal": 14, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:35", + "pc": [ + 5, + 6 + ] + }, + { + "teal": 15, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:35", + "pc": [ + 7 + ] + }, + { + "teal": 16, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:35", + "pc": [ + 8, + 9 + ] + }, + { + "teal": 17, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:35", + "pc": [ + 10 + ] + }, + { + "teal": 18, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:35", + "pc": [ + 11, + 12 + ] + }, + { + "teal": 19, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:35", + "pc": [ + 13 + ] + }, + { + "teal": 20, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:35", + "pc": [ + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38, + 39 + ] + }, + { + "teal": 24, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:35", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 40 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:40", + "pc": [ + 41, + 42, + 43 + ] }, { + "teal": 30, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:40", + "pc": [ + 44 + ] + }, + { + "teal": 31, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:40", + "pc": [ + 45 + ] + }, + { + "teal": 32, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:40", + "pc": [ + 46, + 47 + ] + }, + { + "teal": 33, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:40", + "pc": [ + 48 + ] + }, + { + "teal": 36, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:40", + "errorMessage": "argument 0 (creator) for allowOptInsFrom must be a address", "pc": [ 49 - ], - "errorMessage": "argument 0 (creator) for allowOptInsFrom must be a address" + ] + }, + { + "teal": 39, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:40", + "pc": [ + 50, + 51, + 52 + ] + }, + { + "teal": 40, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:40", + "pc": [ + 53, + 54 + ] + }, + { + "teal": 41, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:40", + "pc": [ + 55 + ] + }, + { + "teal": 47, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:40", + "pc": [ + 56, + 57, + 58 + ] + }, + { + "teal": 51, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:41", + "pc": [ + 59, + 60 + ] + }, + { + "teal": 52, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:41", + "pc": [ + 61, + 62 + ] }, { + "teal": 53, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:41", + "pc": [ + 63 + ] + }, + { + "teal": 54, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:41", + "pc": [ + 64, + 65 + ] + }, + { + "teal": 55, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:41", + "pc": [ + 66, + 67, + 68 + ] + }, + { + "teal": 56, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:41", + "pc": [ + 69, + 70 + ] + }, + { + "teal": 57, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:41", + "pc": [ + 71, + 72 + ] + }, + { + "teal": 58, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:41", + "pc": [ + 73 + ] + }, + { + "teal": 59, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:41", + "pc": [ + 74 + ] + }, + { + "teal": 60, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:40", + "pc": [ + 75 + ] + }, + { + "teal": 65, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:45", + "pc": [ + 76, + 77, + 78 + ] + }, + { + "teal": 66, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:45", + "pc": [ + 79 + ] + }, + { + "teal": 67, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:45", + "pc": [ + 80 + ] + }, + { + "teal": 68, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:45", + "pc": [ + 81, + 82 + ] + }, + { + "teal": 69, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:45", + "pc": [ + 83 + ] + }, + { + "teal": 72, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:45", + "errorMessage": "argument 0 (creator) for disableOptInsFrom must be a address", "pc": [ 84 - ], - "errorMessage": "argument 0 (creator) for disableOptInsFrom must be a address" + ] + }, + { + "teal": 75, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:45", + "pc": [ + 85, + 86, + 87 + ] + }, + { + "teal": 76, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:45", + "pc": [ + 88, + 89 + ] + }, + { + "teal": 77, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:45", + "pc": [ + 90 + ] + }, + { + "teal": 83, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:45", + "pc": [ + 91, + 92, + 93 + ] + }, + { + "teal": 87, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:46", + "pc": [ + 94, + 95 + ] + }, + { + "teal": 88, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:46", + "pc": [ + 96, + 97 + ] + }, + { + "teal": 89, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:46", + "pc": [ + 98 + ] }, { + "teal": 90, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:46", + "pc": [ + 99, + 100 + ] + }, + { + "teal": 91, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:46", + "pc": [ + 101, + 102, + 103 + ] + }, + { + "teal": 92, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:46", + "pc": [ + 104, + 105 + ] + }, + { + "teal": 93, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:46", + "pc": [ + 106, + 107 + ] + }, + { + "teal": 94, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:46", + "pc": [ + 108 + ] + }, + { + "teal": 95, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:46", + "pc": [ + 109 + ] + }, + { + "teal": 96, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:45", + "pc": [ + 110 + ] + }, + { + "teal": 101, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:50", + "pc": [ + 111, + 112 + ] + }, + { + "teal": 102, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:50", + "pc": [ + 113, + 114 + ] + }, + { + "teal": 103, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:50", + "pc": [ + 115 + ] + }, + { + "teal": 104, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:50", + "pc": [ + 116 + ] + }, + { + "teal": 105, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:50", + "pc": [ + 117, + 118 + ] + }, + { + "teal": 106, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:50", + "pc": [ + 119, + 120 + ] + }, + { + "teal": 107, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:50", + "pc": [ + 121 + ] + }, + { + "teal": 110, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:50", + "errorMessage": "argument 0 (optIn) for verifyCreator must be a axfer transaction", "pc": [ 122 - ], - "errorMessage": "argument 0 (optIn) for verifyCreator must be a axfer transaction" + ] + }, + { + "teal": 113, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:50", + "pc": [ + 123, + 124, + 125 + ] + }, + { + "teal": 114, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:50", + "pc": [ + 126, + 127 + ] + }, + { + "teal": 115, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:50", + "pc": [ + 128 + ] + }, + { + "teal": 119, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:50", + "pc": [ + 129, + 130, + 131 + ] + }, + { + "teal": 123, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:52", + "pc": [ + 132, + 133 + ] + }, + { + "teal": 124, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:52", + "pc": [ + 134, + 135 + ] }, { + "teal": 125, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:52", + "pc": [ + 136, + 137 + ] + }, + { + "teal": 126, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:52", + "pc": [ + 138, + 139 + ] + }, + { + "teal": 127, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:52", + "pc": [ + 140, + 141 + ] + }, + { + "teal": 128, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:52", + "pc": [ + 142 + ] + }, + { + "teal": 129, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:52", + "pc": [ + 143 + ] + }, + { + "teal": 130, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:52", + "pc": [ + 144 + ] + }, + { + "teal": 133, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:52", + "errorMessage": "box value does not exist: this.allowedCreators([optIn.sender, optIn.xferAsset.creator]).value", "pc": [ 145 - ], - "errorMessage": "box value does not exist: this.allowedCreators([optIn.sender, optIn.xferAsset.creator]).value" + ] + }, + { + "teal": 134, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:52", + "pc": [ + 146, + 147 + ] + }, + { + "teal": 135, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:52", + "pc": [ + 148 + ] + }, + { + "teal": 136, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:52", + "pc": [ + 149 + ] + }, + { + "teal": 137, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:50", + "pc": [ + 150 + ] }, { + "teal": 140, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:35", + "pc": [ + 151, + 152 + ] + }, + { + "teal": 141, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:35", + "pc": [ + 153 + ] + }, + { + "teal": 144, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:35", + "pc": [ + 154, + 155, + 156, + 157, + 158, + 159 + ] + }, + { + "teal": 145, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:35", + "pc": [ + 160, + 161, + 162 + ] + }, + { + "teal": 146, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:35", + "pc": [ + 163, + 164, + 165, + 166 + ] + }, + { + "teal": 149, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:35", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 167 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 152, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:35", + "pc": [ + 168, + 169, + 170, + 171, + 172, + 173 + ] + }, + { + "teal": 153, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:35", + "pc": [ + 174, + 175, + 176, + 177, + 178, + 179 + ] + }, + { + "teal": 154, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:35", + "pc": [ + 180, + 181, + 182, + 183, + 184, + 185 + ] + }, + { + "teal": 155, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:35", + "pc": [ + 186, + 187, + 188 + ] + }, + { + "teal": 156, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:35", + "pc": [ + 189, + 190, + 191, + 192, + 193, + 194, + 195, + 196 + ] }, { + "teal": 159, + "source": "examples/lsig_with_app/lsig_with_app.algo.ts:35", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 197 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/examples/merkle/artifacts/MerkleTree.arc56_draft.json b/examples/merkle/artifacts/MerkleTree.arc56_draft.json index 4df5daf9a..952eec777 100644 --- a/examples/merkle/artifacts/MerkleTree.arc56_draft.json +++ b/examples/merkle/artifacts/MerkleTree.arc56_draft.json @@ -145,52 +145,2332 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "examples/merkle/merkle.algo.ts:11", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "examples/merkle/merkle.algo.ts:11", + "pc": [ + 1, + 2, + 3 + ] + }, + { + "teal": 3, + "source": "examples/merkle/merkle.algo.ts:11", + "pc": [ + 4, + 5, + 6, + 7, + 8, + 9, + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38, + 39, + 40, + 41, + 42, + 43, + 44, + 45, + 46, + 47, + 48, + 49, + 50, + 51, + 52, + 53, + 54, + 55, + 56, + 57, + 58, + 59, + 60, + 61, + 62, + 63, + 64, + 65, + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82, + 83, + 84, + 85, + 86, + 87, + 88, + 89, + 90, + 91, + 92, + 93, + 94, + 95, + 96, + 97, + 98, + 99, + 100, + 101, + 102, + 103, + 104, + 105, + 106, + 107, + 108, + 109, + 110, + 111, + 112, + 113, + 114 + ] + }, + { + "teal": 15, + "source": "examples/merkle/merkle.algo.ts:11", + "pc": [ + 115, + 116 + ] + }, + { + "teal": 16, + "source": "examples/merkle/merkle.algo.ts:11", + "pc": [ + 117 + ] + }, + { + "teal": 17, + "source": "examples/merkle/merkle.algo.ts:11", + "pc": [ + 118, + 119 + ] + }, + { + "teal": 18, + "source": "examples/merkle/merkle.algo.ts:11", + "pc": [ + 120 + ] + }, + { + "teal": 19, + "source": "examples/merkle/merkle.algo.ts:11", + "pc": [ + 121, + 122 + ] + }, + { + "teal": 20, + "source": "examples/merkle/merkle.algo.ts:11", + "pc": [ + 123 + ] + }, + { + "teal": 21, + "source": "examples/merkle/merkle.algo.ts:11", + "pc": [ + 124, + 125, + 126, + 127, + 128, + 129, + 130, + 131, + 132, + 133, + 134, + 135, + 136, + 137, + 138, + 139, + 140, + 141, + 142, + 143, + 144, + 145, + 146, + 147, + 148, + 149 + ] + }, + { + "teal": 25, + "source": "examples/merkle/merkle.algo.ts:11", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 150 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "examples/merkle/merkle.algo.ts:16", + "pc": [ + 151, + 152, + 153 + ] + }, + { + "teal": 32, + "source": "examples/merkle/merkle.algo.ts:16", + "pc": [ + 154, + 155 + ] + }, + { + "teal": 33, + "source": "examples/merkle/merkle.algo.ts:16", + "pc": [ + 156 + ] + }, + { + "teal": 37, + "source": "examples/merkle/merkle.algo.ts:17", + "pc": [ + 157, + 158, + 159, + 160, + 161, + 162, + 163, + 164, + 165, + 166, + 167, + 168, + 169, + 170, + 171, + 172, + 173, + 174, + 175, + 176, + 177, + 178, + 179, + 180, + 181, + 182, + 183, + 184, + 185, + 186, + 187, + 188, + 189, + 190, + 191, + 192, + 193, + 194, + 195, + 196, + 197, + 198, + 199, + 200, + 201, + 202, + 203, + 204, + 205, + 206, + 207, + 208, + 209, + 210, + 211, + 212, + 213, + 214, + 215, + 216, + 217, + 218, + 219, + 220, + 221, + 222 + ] + }, + { + "teal": 38, + "source": "examples/merkle/merkle.algo.ts:17", + "pc": [ + 223, + 224 + ] + }, + { + "teal": 39, + "source": "examples/merkle/merkle.algo.ts:17", + "pc": [ + 225 + ] + }, + { + "teal": 40, + "source": "examples/merkle/merkle.algo.ts:17", + "pc": [ + 226 + ] + }, + { + "teal": 41, + "source": "examples/merkle/merkle.algo.ts:17", + "pc": [ + 227 + ] + }, + { + "teal": 42, + "source": "examples/merkle/merkle.algo.ts:17", + "pc": [ + 228, + 229, + 230 + ] + }, + { + "teal": 43, + "source": "examples/merkle/merkle.algo.ts:17", + "pc": [ + 231, + 232 + ] + }, + { + "teal": 47, + "source": "examples/merkle/merkle.algo.ts:19", + "pc": [ + 233, + 234 + ] + }, + { + "teal": 48, + "source": "examples/merkle/merkle.algo.ts:19", + "pc": [ + 235, + 236 + ] + }, + { + "teal": 53, + "source": "examples/merkle/merkle.algo.ts:19", + "pc": [ + 237, + 238 + ] + }, + { + "teal": 54, + "source": "examples/merkle/merkle.algo.ts:19", + "pc": [ + 239, + 240 + ] + }, + { + "teal": 55, + "source": "examples/merkle/merkle.algo.ts:19", + "pc": [ + 241 + ] + }, + { + "teal": 56, + "source": "examples/merkle/merkle.algo.ts:19", + "pc": [ + 242, + 243, + 244 + ] + }, + { + "teal": 60, + "source": "examples/merkle/merkle.algo.ts:20", + "pc": [ + 245, + 246 + ] + }, + { + "teal": 61, + "source": "examples/merkle/merkle.algo.ts:20", + "pc": [ + 247, + 248 + ] + }, + { + "teal": 62, + "source": "examples/merkle/merkle.algo.ts:20", + "pc": [ + 249 + ] + }, + { + "teal": 63, + "source": "examples/merkle/merkle.algo.ts:20", + "pc": [ + 250 + ] + }, + { + "teal": 64, + "source": "examples/merkle/merkle.algo.ts:20", + "pc": [ + 251, + 252 + ] + }, + { + "teal": 69, + "source": "examples/merkle/merkle.algo.ts:19", + "pc": [ + 253, + 254 + ] + }, + { + "teal": 70, + "source": "examples/merkle/merkle.algo.ts:19", + "pc": [ + 255, + 256 + ] + }, + { + "teal": 71, + "source": "examples/merkle/merkle.algo.ts:19", + "pc": [ + 257 + ] + }, + { + "teal": 72, + "source": "examples/merkle/merkle.algo.ts:19", + "pc": [ + 258, + 259 + ] + }, + { + "teal": 73, + "source": "examples/merkle/merkle.algo.ts:19", + "pc": [ + 260, + 261, + 262 + ] + }, + { + "teal": 78, + "source": "examples/merkle/merkle.algo.ts:23", + "pc": [ + 263, + 264 + ] + }, + { + "teal": 81, + "source": "examples/merkle/merkle.algo.ts:16", + "pc": [ + 265, + 266 + ] + }, + { + "teal": 84, + "source": "examples/merkle/merkle.algo.ts:16", + "pc": [ + 267, + 268 + ] + }, + { + "teal": 85, + "source": "examples/merkle/merkle.algo.ts:16", + "pc": [ + 269 + ] + }, + { + "teal": 89, + "source": "examples/merkle/merkle.algo.ts:26", + "pc": [ + 270, + 271, + 272 + ] + }, + { + "teal": 93, + "source": "examples/merkle/merkle.algo.ts:27", + "pc": [ + 273, + 274 + ] + }, + { + "teal": 94, + "source": "examples/merkle/merkle.algo.ts:27", + "pc": [ + 275, + 276 + ] + }, + { + "teal": 95, + "source": "examples/merkle/merkle.algo.ts:27", + "pc": [ + 277 + ] + }, + { + "teal": 96, + "source": "examples/merkle/merkle.algo.ts:27", + "pc": [ + 278 + ] + }, + { + "teal": 97, + "source": "examples/merkle/merkle.algo.ts:26", + "pc": [ + 279 + ] + }, + { + "teal": 101, + "source": "examples/merkle/merkle.algo.ts:30", + "pc": [ + 280, + 281, + 282 + ] + }, + { + "teal": 105, + "source": "examples/merkle/merkle.algo.ts:31", + "pc": [ + 283, + 284 + ] + }, + { + "teal": 106, + "source": "examples/merkle/merkle.algo.ts:31", + "pc": [ + 285, + 286 + ] + }, + { + "teal": 107, + "source": "examples/merkle/merkle.algo.ts:31", + "pc": [ + 287 + ] + }, + { + "teal": 108, + "source": "examples/merkle/merkle.algo.ts:31", + "pc": [ + 288, + 289, + 290 + ] + }, + { + "teal": 109, + "source": "examples/merkle/merkle.algo.ts:31", + "pc": [ + 291 + ] + }, + { + "teal": 110, + "source": "examples/merkle/merkle.algo.ts:30", + "pc": [ + 292 + ] + }, + { + "teal": 114, + "source": "examples/merkle/merkle.algo.ts:34", + "pc": [ + 293, + 294, + 295 + ] + }, + { + "teal": 117, + "source": "examples/merkle/merkle.algo.ts:34", + "pc": [ + 296, + 297 + ] + }, + { + "teal": 118, + "source": "examples/merkle/merkle.algo.ts:34", + "pc": [ + 298 + ] + }, + { + "teal": 122, + "source": "examples/merkle/merkle.algo.ts:37", + "pc": [ + 299, + 300 + ] + }, + { + "teal": 123, + "source": "examples/merkle/merkle.algo.ts:37", + "pc": [ + 301, + 302 + ] + }, + { + "teal": 128, + "source": "examples/merkle/merkle.algo.ts:37", + "pc": [ + 303, + 304 + ] + }, + { + "teal": 129, + "source": "examples/merkle/merkle.algo.ts:37", + "pc": [ + 305, + 306 + ] + }, + { + "teal": 130, + "source": "examples/merkle/merkle.algo.ts:37", + "pc": [ + 307 + ] + }, + { + "teal": 131, + "source": "examples/merkle/merkle.algo.ts:37", + "pc": [ + 308, + 309, + 310 + ] + }, + { + "teal": 132, + "source": "examples/merkle/merkle.algo.ts:38", + "pc": [ + 311, + 312 + ] + }, + { + "teal": 133, + "source": "examples/merkle/merkle.algo.ts:38", + "pc": [ + 313, + 314 + ] + }, + { + "teal": 138, + "source": "examples/merkle/merkle.algo.ts:40", + "pc": [ + 315, + 316 + ] + }, + { + "teal": 139, + "source": "examples/merkle/merkle.algo.ts:40", + "pc": [ + 317, + 318 + ] + }, + { + "teal": 140, + "source": "examples/merkle/merkle.algo.ts:40", + "pc": [ + 319, + 320 + ] + }, + { + "teal": 141, + "source": "examples/merkle/merkle.algo.ts:40", + "pc": [ + 321 + ] + }, + { + "teal": 142, + "source": "examples/merkle/merkle.algo.ts:40", + "pc": [ + 322, + 323 + ] + }, + { + "teal": 143, + "source": "examples/merkle/merkle.algo.ts:40", + "pc": [ + 324 + ] + }, + { + "teal": 144, + "source": "examples/merkle/merkle.algo.ts:40", + "pc": [ + 325, + 326, + 327 + ] + }, + { + "teal": 145, + "source": "examples/merkle/merkle.algo.ts:40", + "pc": [ + 328, + 329, + 330 + ] + }, + { + "teal": 150, + "source": "examples/merkle/merkle.algo.ts:41", + "pc": [ + 331, + 332 + ] + }, + { + "teal": 151, + "source": "examples/merkle/merkle.algo.ts:41", + "pc": [ + 333, + 334 + ] + }, + { + "teal": 152, + "source": "examples/merkle/merkle.algo.ts:41", + "pc": [ + 335, + 336 + ] + }, + { + "teal": 153, + "source": "examples/merkle/merkle.algo.ts:41", + "pc": [ + 337 + ] + }, + { + "teal": 154, + "source": "examples/merkle/merkle.algo.ts:41", + "pc": [ + 338, + 339 + ] + }, + { + "teal": 155, + "source": "examples/merkle/merkle.algo.ts:41", + "pc": [ + 340 + ] + }, + { + "teal": 156, + "source": "examples/merkle/merkle.algo.ts:41", + "pc": [ + 341, + 342, + 343 + ] + }, + { + "teal": 157, + "source": "examples/merkle/merkle.algo.ts:41", + "pc": [ + 344, + 345, + 346, + 347, + 348, + 349, + 350, + 351, + 352, + 353, + 354, + 355, + 356, + 357, + 358, + 359, + 360, + 361, + 362, + 363, + 364, + 365, + 366, + 367, + 368, + 369, + 370, + 371, + 372, + 373, + 374, + 375, + 376, + 377 + ] + }, + { + "teal": 158, + "source": "examples/merkle/merkle.algo.ts:41", + "pc": [ + 378 + ] + }, + { + "teal": 159, + "source": "examples/merkle/merkle.algo.ts:41", + "pc": [ + 379 + ] + }, + { + "teal": 160, + "source": "examples/merkle/merkle.algo.ts:41", + "pc": [ + 380, + 381, + 382 + ] + }, + { + "teal": 161, + "source": "examples/merkle/merkle.algo.ts:41", + "pc": [ + 383, + 384 + ] + }, + { + "teal": 162, + "source": "examples/merkle/merkle.algo.ts:41", + "pc": [ + 385 + ] + }, + { + "teal": 163, + "source": "examples/merkle/merkle.algo.ts:41", + "pc": [ + 386 + ] + }, + { + "teal": 164, + "source": "examples/merkle/merkle.algo.ts:41", + "pc": [ + 387, + 388, + 389 + ] + }, + { + "teal": 165, + "source": "examples/merkle/merkle.algo.ts:41", + "pc": [ + 390, + 391 + ] + }, + { + "teal": 166, + "source": "examples/merkle/merkle.algo.ts:41", + "pc": [ + 392, + 393, + 394 + ] + }, + { + "teal": 167, + "source": "examples/merkle/merkle.algo.ts:41", + "pc": [ + 395, + 396 + ] + }, + { + "teal": 168, + "source": "examples/merkle/merkle.algo.ts:40", + "pc": [ + 397, + 398, + 399 + ] + }, + { + "teal": 173, + "source": "examples/merkle/merkle.algo.ts:43", + "pc": [ + 400, + 401 + ] + }, + { + "teal": 174, + "source": "examples/merkle/merkle.algo.ts:43", + "pc": [ + 402, + 403 + ] + }, + { + "teal": 175, + "source": "examples/merkle/merkle.algo.ts:43", + "pc": [ + 404, + 405 + ] + }, + { + "teal": 176, + "source": "examples/merkle/merkle.algo.ts:43", + "pc": [ + 406, + 407 + ] + }, + { + "teal": 177, + "source": "examples/merkle/merkle.algo.ts:43", + "pc": [ + 408 + ] + }, + { + "teal": 178, + "source": "examples/merkle/merkle.algo.ts:43", + "pc": [ + 409, + 410 + ] + }, + { + "teal": 179, + "source": "examples/merkle/merkle.algo.ts:43", + "pc": [ + 411 + ] + }, + { + "teal": 180, + "source": "examples/merkle/merkle.algo.ts:43", + "pc": [ + 412, + 413, + 414 + ] + }, + { + "teal": 181, + "source": "examples/merkle/merkle.algo.ts:43", + "pc": [ + 415, + 416, + 417, + 418, + 419, + 420, + 421, + 422, + 423, + 424, + 425, + 426, + 427, + 428, + 429, + 430, + 431, + 432, + 433, + 434, + 435, + 436, + 437, + 438, + 439, + 440, + 441, + 442, + 443, + 444, + 445, + 446, + 447, + 448 + ] + }, + { + "teal": 182, + "source": "examples/merkle/merkle.algo.ts:43", + "pc": [ + 449 + ] + }, + { + "teal": 183, + "source": "examples/merkle/merkle.algo.ts:43", + "pc": [ + 450 + ] + }, + { + "teal": 184, + "source": "examples/merkle/merkle.algo.ts:43", + "pc": [ + 451, + 452, + 453 + ] + }, + { + "teal": 185, + "source": "examples/merkle/merkle.algo.ts:43", + "pc": [ + 454, + 455 + ] + }, + { + "teal": 186, + "source": "examples/merkle/merkle.algo.ts:43", + "pc": [ + 456 + ] + }, + { + "teal": 187, + "source": "examples/merkle/merkle.algo.ts:43", + "pc": [ + 457 + ] + }, + { + "teal": 188, + "source": "examples/merkle/merkle.algo.ts:43", + "pc": [ + 458, + 459, + 460 + ] + }, + { + "teal": 189, + "source": "examples/merkle/merkle.algo.ts:43", + "pc": [ + 461, + 462, + 463 + ] + }, + { + "teal": 190, + "source": "examples/merkle/merkle.algo.ts:43", + "pc": [ + 464, + 465 + ] + }, + { + "teal": 197, + "source": "examples/merkle/merkle.algo.ts:37", + "pc": [ + 466, + 467 + ] + }, + { + "teal": 198, + "source": "examples/merkle/merkle.algo.ts:37", + "pc": [ + 468, + 469 + ] + }, + { + "teal": 199, + "source": "examples/merkle/merkle.algo.ts:37", + "pc": [ + 470 + ] + }, + { + "teal": 200, + "source": "examples/merkle/merkle.algo.ts:37", + "pc": [ + 471, + 472 + ] + }, + { + "teal": 201, + "source": "examples/merkle/merkle.algo.ts:37", + "pc": [ + 473, + 474, + 475 + ] + }, + { + "teal": 206, + "source": "examples/merkle/merkle.algo.ts:47", + "pc": [ + 476, + 477 + ] + }, + { + "teal": 209, + "source": "examples/merkle/merkle.algo.ts:34", + "pc": [ + 478, + 479 + ] + }, + { + "teal": 212, + "source": "examples/merkle/merkle.algo.ts:34", + "pc": [ + 480, + 481 + ] + }, + { + "teal": 213, + "source": "examples/merkle/merkle.algo.ts:34", + "pc": [ + 482 + ] + }, + { + "teal": 218, + "source": "examples/merkle/merkle.algo.ts:50", + "pc": [ + 483, + 484, + 485 + ] + }, + { + "teal": 219, + "source": "examples/merkle/merkle.algo.ts:50", + "pc": [ + 486, + 487 + ] + }, + { + "teal": 220, + "source": "examples/merkle/merkle.algo.ts:50", + "pc": [ + 488 + ] + }, + { + "teal": 224, + "source": "examples/merkle/merkle.algo.ts:50", + "pc": [ + 489, + 490, + 491 + ] + }, + { + "teal": 229, + "source": "examples/merkle/merkle.algo.ts:51", + "pc": [ + 492, + 493 + ] + }, + { + "teal": 230, + "source": "examples/merkle/merkle.algo.ts:51", + "pc": [ + 494, + 495, + 496 + ] + }, + { + "teal": 231, + "source": "examples/merkle/merkle.algo.ts:51", + "pc": [ + 497, + 498 + ] + }, + { + "teal": 232, + "source": "examples/merkle/merkle.algo.ts:51", + "pc": [ + 499 + ] + }, + { + "teal": 233, + "source": "examples/merkle/merkle.algo.ts:51", + "pc": [ + 500 + ] + }, + { + "teal": 236, + "source": "examples/merkle/merkle.algo.ts:51", + "errorMessage": "transaction verification failed: {\"txn\":\"this.txn\",\"field\":\"sender\",\"expected\":\"this.app.creator\"}", + "pc": [ + 501 + ] + }, + { + "teal": 237, + "source": "examples/merkle/merkle.algo.ts:50", + "pc": [ + 502 + ] + }, + { + "teal": 242, + "source": "examples/merkle/merkle.algo.ts:54", + "pc": [ + 503, + 504, + 505 + ] + }, + { + "teal": 243, + "source": "examples/merkle/merkle.algo.ts:54", + "pc": [ + 506, + 507 + ] + }, + { + "teal": 244, + "source": "examples/merkle/merkle.algo.ts:54", + "pc": [ + 508 + ] + }, + { + "teal": 248, + "source": "examples/merkle/merkle.algo.ts:54", + "pc": [ + 509, + 510, + 511 + ] + }, + { + "teal": 252, + "source": "examples/merkle/merkle.algo.ts:55", + "pc": [ + 512, + 513, + 514, + 515, + 516, + 517 + ] + }, + { + "teal": 253, + "source": "examples/merkle/merkle.algo.ts:55", + "pc": [ + 518, + 519, + 520 + ] + }, + { + "teal": 254, + "source": "examples/merkle/merkle.algo.ts:55", + "pc": [ + 521 + ] + }, + { + "teal": 255, + "source": "examples/merkle/merkle.algo.ts:54", + "pc": [ + 522 + ] + }, + { + "teal": 260, + "source": "examples/merkle/merkle.algo.ts:58", + "pc": [ + 523, + 524, + 525 + ] + }, + { + "teal": 261, + "source": "examples/merkle/merkle.algo.ts:58", + "pc": [ + 526 + ] + }, + { + "teal": 262, + "source": "examples/merkle/merkle.algo.ts:58", + "pc": [ + 527 + ] + }, + { + "teal": 263, + "source": "examples/merkle/merkle.algo.ts:58", + "pc": [ + 528, + 529 + ] + }, + { + "teal": 264, + "source": "examples/merkle/merkle.algo.ts:58", + "pc": [ + 530 + ] + }, + { + "teal": 267, + "source": "examples/merkle/merkle.algo.ts:58", + "errorMessage": "argument 0 (path) for verify must be a byte[33][3]", + "pc": [ + 531 + ] + }, + { + "teal": 270, + "source": "examples/merkle/merkle.algo.ts:58", + "pc": [ + 532, + 533, + 534 + ] + }, + { + "teal": 271, + "source": "examples/merkle/merkle.algo.ts:58", + "pc": [ + 535, + 536, + 537 + ] + }, + { + "teal": 274, + "source": "examples/merkle/merkle.algo.ts:58", + "pc": [ + 538, + 539, + 540 + ] + }, + { + "teal": 275, + "source": "examples/merkle/merkle.algo.ts:58", + "pc": [ + 541, + 542 + ] + }, + { + "teal": 276, + "source": "examples/merkle/merkle.algo.ts:58", + "pc": [ + 543 + ] + }, + { + "teal": 280, + "source": "examples/merkle/merkle.algo.ts:58", + "pc": [ + 544, + 545, + 546 + ] + }, + { + "teal": 284, + "source": "examples/merkle/merkle.algo.ts:59", + "pc": [ + 547, + 548, + 549, + 550, + 551, + 552 + ] + }, + { + "teal": 285, + "source": "examples/merkle/merkle.algo.ts:59", + "pc": [ + 553 + ] + }, + { + "teal": 286, + "source": "examples/merkle/merkle.algo.ts:59", + "pc": [ + 554, + 555 + ] + }, + { + "teal": 287, + "source": "examples/merkle/merkle.algo.ts:59", + "pc": [ + 556, + 557 + ] + }, + { + "teal": 288, + "source": "examples/merkle/merkle.algo.ts:59", + "pc": [ + 558 + ] + }, + { + "teal": 289, + "source": "examples/merkle/merkle.algo.ts:59", + "pc": [ + 559, + 560, + 561 + ] }, { + "teal": 290, + "source": "examples/merkle/merkle.algo.ts:59", "pc": [ - 501 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"this.txn\",\"field\":\"sender\",\"expected\":\"this.app.creator\"}" + 562 + ] }, { + "teal": 291, + "source": "examples/merkle/merkle.algo.ts:59", "pc": [ - 531 - ], - "errorMessage": "argument 0 (path) for verify must be a byte[33][3]" + 563 + ] + }, + { + "teal": 292, + "source": "examples/merkle/merkle.algo.ts:58", + "pc": [ + 564 + ] + }, + { + "teal": 297, + "source": "examples/merkle/merkle.algo.ts:62", + "pc": [ + 565, + 566, + 567 + ] + }, + { + "teal": 298, + "source": "examples/merkle/merkle.algo.ts:62", + "pc": [ + 568 + ] + }, + { + "teal": 299, + "source": "examples/merkle/merkle.algo.ts:62", + "pc": [ + 569 + ] }, { + "teal": 300, + "source": "examples/merkle/merkle.algo.ts:62", + "pc": [ + 570, + 571 + ] + }, + { + "teal": 301, + "source": "examples/merkle/merkle.algo.ts:62", + "pc": [ + 572 + ] + }, + { + "teal": 304, + "source": "examples/merkle/merkle.algo.ts:62", + "errorMessage": "argument 0 (path) for appendLeaf must be a byte[33][3]", "pc": [ 573 - ], - "errorMessage": "argument 0 (path) for appendLeaf must be a byte[33][3]" + ] + }, + { + "teal": 307, + "source": "examples/merkle/merkle.algo.ts:62", + "pc": [ + 574, + 575, + 576 + ] + }, + { + "teal": 308, + "source": "examples/merkle/merkle.algo.ts:62", + "pc": [ + 577, + 578, + 579 + ] + }, + { + "teal": 311, + "source": "examples/merkle/merkle.algo.ts:62", + "pc": [ + 580, + 581, + 582 + ] + }, + { + "teal": 312, + "source": "examples/merkle/merkle.algo.ts:62", + "pc": [ + 583, + 584 + ] + }, + { + "teal": 313, + "source": "examples/merkle/merkle.algo.ts:62", + "pc": [ + 585 + ] + }, + { + "teal": 317, + "source": "examples/merkle/merkle.algo.ts:62", + "pc": [ + 586, + 587, + 588 + ] + }, + { + "teal": 321, + "source": "examples/merkle/merkle.algo.ts:63", + "pc": [ + 589, + 590 + ] + }, + { + "teal": 322, + "source": "examples/merkle/merkle.algo.ts:63", + "pc": [ + 591, + 592 + ] + }, + { + "teal": 323, + "source": "examples/merkle/merkle.algo.ts:63", + "pc": [ + 593 + ] + }, + { + "teal": 324, + "source": "examples/merkle/merkle.algo.ts:63", + "pc": [ + 594 + ] + }, + { + "teal": 328, + "source": "examples/merkle/merkle.algo.ts:64", + "pc": [ + 595, + 596, + 597, + 598, + 599, + 600 + ] + }, + { + "teal": 329, + "source": "examples/merkle/merkle.algo.ts:64", + "pc": [ + 601 + ] + }, + { + "teal": 330, + "source": "examples/merkle/merkle.algo.ts:64", + "pc": [ + 602, + 603 + ] + }, + { + "teal": 331, + "source": "examples/merkle/merkle.algo.ts:64", + "pc": [ + 604, + 605, + 606, + 607, + 608, + 609, + 610, + 611, + 612, + 613, + 614, + 615, + 616, + 617, + 618, + 619, + 620, + 621, + 622, + 623, + 624, + 625, + 626, + 627, + 628, + 629, + 630, + 631, + 632, + 633, + 634, + 635, + 636, + 637, + 638, + 639, + 640, + 641, + 642, + 643, + 644, + 645, + 646, + 647, + 648, + 649, + 650, + 651, + 652, + 653, + 654, + 655, + 656, + 657, + 658, + 659, + 660, + 661, + 662, + 663, + 664, + 665, + 666, + 667, + 668, + 669 + ] + }, + { + "teal": 332, + "source": "examples/merkle/merkle.algo.ts:64", + "pc": [ + 670, + 671 + ] + }, + { + "teal": 333, + "source": "examples/merkle/merkle.algo.ts:64", + "pc": [ + 672 + ] + }, + { + "teal": 334, + "source": "examples/merkle/merkle.algo.ts:64", + "pc": [ + 673 + ] + }, + { + "teal": 335, + "source": "examples/merkle/merkle.algo.ts:64", + "pc": [ + 674 + ] + }, + { + "teal": 336, + "source": "examples/merkle/merkle.algo.ts:64", + "pc": [ + 675, + 676, + 677 + ] + }, + { + "teal": 337, + "source": "examples/merkle/merkle.algo.ts:64", + "pc": [ + 678, + 679, + 680 + ] + }, + { + "teal": 338, + "source": "examples/merkle/merkle.algo.ts:64", + "pc": [ + 681 + ] + }, + { + "teal": 339, + "source": "examples/merkle/merkle.algo.ts:64", + "pc": [ + 682 + ] + }, + { + "teal": 343, + "source": "examples/merkle/merkle.algo.ts:66", + "pc": [ + 683, + 684, + 685, + 686, + 687, + 688 + ] + }, + { + "teal": 344, + "source": "examples/merkle/merkle.algo.ts:66", + "pc": [ + 689, + 690 + ] + }, + { + "teal": 345, + "source": "examples/merkle/merkle.algo.ts:66", + "pc": [ + 691, + 692 + ] + }, + { + "teal": 346, + "source": "examples/merkle/merkle.algo.ts:66", + "pc": [ + 693 + ] + }, + { + "teal": 347, + "source": "examples/merkle/merkle.algo.ts:66", + "pc": [ + 694, + 695, + 696 + ] + }, + { + "teal": 348, + "source": "examples/merkle/merkle.algo.ts:66", + "pc": [ + 697 + ] + }, + { + "teal": 352, + "source": "examples/merkle/merkle.algo.ts:68", + "pc": [ + 698, + 699, + 700, + 701, + 702, + 703 + ] + }, + { + "teal": 353, + "source": "examples/merkle/merkle.algo.ts:68", + "pc": [ + 704 + ] + }, + { + "teal": 354, + "source": "examples/merkle/merkle.algo.ts:68", + "pc": [ + 705 + ] + }, + { + "teal": 355, + "source": "examples/merkle/merkle.algo.ts:68", + "pc": [ + 706, + 707 + ] + }, + { + "teal": 356, + "source": "examples/merkle/merkle.algo.ts:68", + "pc": [ + 708 + ] + }, + { + "teal": 357, + "source": "examples/merkle/merkle.algo.ts:68", + "pc": [ + 709 + ] + }, + { + "teal": 358, + "source": "examples/merkle/merkle.algo.ts:62", + "pc": [ + 710 + ] + }, + { + "teal": 363, + "source": "examples/merkle/merkle.algo.ts:71", + "pc": [ + 711, + 712, + 713 + ] + }, + { + "teal": 364, + "source": "examples/merkle/merkle.algo.ts:71", + "pc": [ + 714 + ] + }, + { + "teal": 365, + "source": "examples/merkle/merkle.algo.ts:71", + "pc": [ + 715 + ] }, { + "teal": 366, + "source": "examples/merkle/merkle.algo.ts:71", + "pc": [ + 716, + 717 + ] + }, + { + "teal": 367, + "source": "examples/merkle/merkle.algo.ts:71", + "pc": [ + 718 + ] + }, + { + "teal": 370, + "source": "examples/merkle/merkle.algo.ts:71", + "errorMessage": "argument 0 (path) for updateLeaf must be a byte[33][3]", "pc": [ 719 - ], - "errorMessage": "argument 0 (path) for updateLeaf must be a byte[33][3]" + ] + }, + { + "teal": 373, + "source": "examples/merkle/merkle.algo.ts:71", + "pc": [ + 720, + 721, + 722 + ] + }, + { + "teal": 374, + "source": "examples/merkle/merkle.algo.ts:71", + "pc": [ + 723, + 724, + 725 + ] + }, + { + "teal": 377, + "source": "examples/merkle/merkle.algo.ts:71", + "pc": [ + 726, + 727, + 728 + ] + }, + { + "teal": 378, + "source": "examples/merkle/merkle.algo.ts:71", + "pc": [ + 729, + 730, + 731 + ] + }, + { + "teal": 381, + "source": "examples/merkle/merkle.algo.ts:71", + "pc": [ + 732, + 733, + 734 + ] + }, + { + "teal": 382, + "source": "examples/merkle/merkle.algo.ts:71", + "pc": [ + 735, + 736 + ] + }, + { + "teal": 383, + "source": "examples/merkle/merkle.algo.ts:71", + "pc": [ + 737 + ] + }, + { + "teal": 387, + "source": "examples/merkle/merkle.algo.ts:71", + "pc": [ + 738, + 739, + 740 + ] + }, + { + "teal": 391, + "source": "examples/merkle/merkle.algo.ts:72", + "pc": [ + 741, + 742 + ] + }, + { + "teal": 392, + "source": "examples/merkle/merkle.algo.ts:72", + "pc": [ + 743, + 744 + ] + }, + { + "teal": 393, + "source": "examples/merkle/merkle.algo.ts:72", + "pc": [ + 745 + ] + }, + { + "teal": 394, + "source": "examples/merkle/merkle.algo.ts:72", + "pc": [ + 746 + ] + }, + { + "teal": 398, + "source": "examples/merkle/merkle.algo.ts:73", + "pc": [ + 747, + 748, + 749, + 750, + 751, + 752 + ] + }, + { + "teal": 399, + "source": "examples/merkle/merkle.algo.ts:73", + "pc": [ + 753 + ] + }, + { + "teal": 400, + "source": "examples/merkle/merkle.algo.ts:73", + "pc": [ + 754, + 755 + ] + }, + { + "teal": 401, + "source": "examples/merkle/merkle.algo.ts:73", + "pc": [ + 756, + 757 + ] + }, + { + "teal": 402, + "source": "examples/merkle/merkle.algo.ts:73", + "pc": [ + 758 + ] + }, + { + "teal": 403, + "source": "examples/merkle/merkle.algo.ts:73", + "pc": [ + 759, + 760, + 761 + ] + }, + { + "teal": 404, + "source": "examples/merkle/merkle.algo.ts:73", + "pc": [ + 762 + ] + }, + { + "teal": 405, + "source": "examples/merkle/merkle.algo.ts:73", + "pc": [ + 763 + ] + }, + { + "teal": 409, + "source": "examples/merkle/merkle.algo.ts:75", + "pc": [ + 764, + 765, + 766, + 767, + 768, + 769 + ] + }, + { + "teal": 410, + "source": "examples/merkle/merkle.algo.ts:75", + "pc": [ + 770, + 771 + ] + }, + { + "teal": 411, + "source": "examples/merkle/merkle.algo.ts:75", + "pc": [ + 772, + 773 + ] + }, + { + "teal": 412, + "source": "examples/merkle/merkle.algo.ts:75", + "pc": [ + 774 + ] + }, + { + "teal": 413, + "source": "examples/merkle/merkle.algo.ts:75", + "pc": [ + 775, + 776, + 777 + ] + }, + { + "teal": 414, + "source": "examples/merkle/merkle.algo.ts:75", + "pc": [ + 778 + ] + }, + { + "teal": 415, + "source": "examples/merkle/merkle.algo.ts:71", + "pc": [ + 779 + ] + }, + { + "teal": 418, + "source": "examples/merkle/merkle.algo.ts:11", + "pc": [ + 780, + 781, + 782, + 783, + 784, + 785 + ] + }, + { + "teal": 419, + "source": "examples/merkle/merkle.algo.ts:11", + "pc": [ + 786, + 787, + 788 + ] + }, + { + "teal": 420, + "source": "examples/merkle/merkle.algo.ts:11", + "pc": [ + 789, + 790, + 791, + 792 + ] }, { + "teal": 423, + "source": "examples/merkle/merkle.algo.ts:11", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 793 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 426, + "source": "examples/merkle/merkle.algo.ts:11", + "pc": [ + 794, + 795, + 796, + 797, + 798, + 799 + ] + }, + { + "teal": 427, + "source": "examples/merkle/merkle.algo.ts:11", + "pc": [ + 800, + 801, + 802, + 803, + 804, + 805 + ] + }, + { + "teal": 428, + "source": "examples/merkle/merkle.algo.ts:11", + "pc": [ + 806, + 807, + 808, + 809, + 810, + 811 + ] + }, + { + "teal": 429, + "source": "examples/merkle/merkle.algo.ts:11", + "pc": [ + 812, + 813, + 814 + ] }, { + "teal": 430, + "source": "examples/merkle/merkle.algo.ts:11", + "pc": [ + 815, + 816, + 817, + 818, + 819, + 820, + 821, + 822 + ] + }, + { + "teal": 433, + "source": "examples/merkle/merkle.algo.ts:11", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 823 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] + }, + { + "teal": 436, + "source": "examples/merkle/merkle.algo.ts:11", + "pc": [ + 824, + 825, + 826, + 827, + 828, + 829 + ] + }, + { + "teal": 437, + "source": "examples/merkle/merkle.algo.ts:11", + "pc": [ + 830, + 831, + 832 + ] + }, + { + "teal": 438, + "source": "examples/merkle/merkle.algo.ts:11", + "pc": [ + 833, + 834, + 835, + 836 + ] }, { + "teal": 441, + "source": "examples/merkle/merkle.algo.ts:11", + "errorMessage": "this contract does not implement the given ABI method for call DeleteApplication", "pc": [ 837 - ], - "errorMessage": "this contract does not implement the given ABI method for call DeleteApplication" + ] } ], "pcOffsetMethod": "none" diff --git a/examples/non_abi/artifacts/NonABIExample.arc56_draft.json b/examples/non_abi/artifacts/NonABIExample.arc56_draft.json index f931a6cca..c07c208a9 100644 --- a/examples/non_abi/artifacts/NonABIExample.arc56_draft.json +++ b/examples/non_abi/artifacts/NonABIExample.arc56_draft.json @@ -73,16 +73,564 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "examples/non_abi/non_abi.algo.ts:4", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "examples/non_abi/non_abi.algo.ts:4", + "pc": [ + 1, + 2, + 3 + ] + }, + { + "teal": 14, + "source": "examples/non_abi/non_abi.algo.ts:4", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 15, + "source": "examples/non_abi/non_abi.algo.ts:4", + "pc": [ + 6 + ] + }, + { + "teal": 16, + "source": "examples/non_abi/non_abi.algo.ts:4", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 17, + "source": "examples/non_abi/non_abi.algo.ts:4", + "pc": [ + 9 + ] + }, + { + "teal": 18, + "source": "examples/non_abi/non_abi.algo.ts:4", + "pc": [ + 10, + 11 + ] + }, + { + "teal": 19, + "source": "examples/non_abi/non_abi.algo.ts:4", + "pc": [ + 12 + ] + }, + { + "teal": 20, + "source": "examples/non_abi/non_abi.algo.ts:4", + "pc": [ + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38 + ] + }, + { + "teal": 24, + "source": "examples/non_abi/non_abi.algo.ts:4", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 39 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "examples/non_abi/non_abi.algo.ts:5", + "pc": [ + 40, + 41, + 42 + ] + }, + { + "teal": 32, + "source": "examples/non_abi/non_abi.algo.ts:6", + "pc": [ + 43, + 44 + ] + }, + { + "teal": 33, + "source": "examples/non_abi/non_abi.algo.ts:6", + "pc": [ + 45, + 46 + ] + }, + { + "teal": 34, + "source": "examples/non_abi/non_abi.algo.ts:6", + "pc": [ + 47 + ] + }, + { + "teal": 35, + "source": "examples/non_abi/non_abi.algo.ts:5", + "pc": [ + 48 + ] + }, + { + "teal": 40, + "source": "examples/non_abi/non_abi.algo.ts:9", + "pc": [ + 49, + 50, + 51, + 52, + 53, + 54 + ] + }, + { + "teal": 43, + "source": "examples/non_abi/non_abi.algo.ts:9", + "pc": [ + 55, + 56, + 57 + ] }, { + "teal": 44, + "source": "examples/non_abi/non_abi.algo.ts:9", + "pc": [ + 58 + ] + }, + { + "teal": 47, + "source": "examples/non_abi/non_abi.algo.ts:9", + "pc": [ + 59, + 60, + 61 + ] + }, + { + "teal": 48, + "source": "examples/non_abi/non_abi.algo.ts:9", + "pc": [ + 62 + ] + }, + { + "teal": 51, + "source": "examples/non_abi/non_abi.algo.ts:9", + "pc": [ + 63, + 64, + 65 + ] + }, + { + "teal": 52, + "source": "examples/non_abi/non_abi.algo.ts:9", + "pc": [ + 66 + ] + }, + { + "teal": 53, + "source": "examples/non_abi/non_abi.algo.ts:9", + "pc": [ + 67 + ] + }, + { + "teal": 54, + "source": "examples/non_abi/non_abi.algo.ts:9", + "pc": [ + 68 + ] + }, + { + "teal": 55, + "source": "examples/non_abi/non_abi.algo.ts:9", + "pc": [ + 69, + 70 + ] + }, + { + "teal": 56, + "source": "examples/non_abi/non_abi.algo.ts:9", + "pc": [ + 71 + ] + }, + { + "teal": 60, + "source": "examples/non_abi/non_abi.algo.ts:9", + "pc": [ + 72, + 73, + 74 + ] + }, + { + "teal": 64, + "source": "examples/non_abi/non_abi.algo.ts:10", + "pc": [ + 75, + 76 + ] + }, + { + "teal": 65, + "source": "examples/non_abi/non_abi.algo.ts:10", + "pc": [ + 77, + 78 + ] + }, + { + "teal": 66, + "source": "examples/non_abi/non_abi.algo.ts:10", + "pc": [ + 79, + 80, + 81 + ] + }, + { + "teal": 67, + "source": "examples/non_abi/non_abi.algo.ts:9", + "pc": [ + 82 + ] + }, + { + "teal": 71, + "source": "examples/non_abi/non_abi.algo.ts:13", + "pc": [ + 83, + 84, + 85 + ] + }, + { + "teal": 74, + "source": "examples/non_abi/non_abi.algo.ts:13", + "pc": [ + 86, + 87 + ] + }, + { + "teal": 75, + "source": "examples/non_abi/non_abi.algo.ts:13", + "pc": [ + 88 + ] + }, + { + "teal": 79, + "source": "examples/non_abi/non_abi.algo.ts:15", + "pc": [ + 89, + 90, + 91 + ] + }, + { + "teal": 80, + "source": "examples/non_abi/non_abi.algo.ts:15", + "pc": [ + 92 + ] + }, + { + "teal": 81, + "source": "examples/non_abi/non_abi.algo.ts:15", + "pc": [ + 93, + 94 + ] + }, + { + "teal": 85, + "source": "examples/non_abi/non_abi.algo.ts:16", + "pc": [ + 95, + 96, + 97 + ] + }, + { + "teal": 86, + "source": "examples/non_abi/non_abi.algo.ts:16", + "pc": [ + 98 + ] + }, + { + "teal": 87, + "source": "examples/non_abi/non_abi.algo.ts:16", + "pc": [ + 99, + 100 + ] + }, + { + "teal": 91, + "source": "examples/non_abi/non_abi.algo.ts:17", + "pc": [ + 101, + 102 + ] + }, + { + "teal": 92, + "source": "examples/non_abi/non_abi.algo.ts:17", + "pc": [ + 103, + 104 + ] + }, + { + "teal": 93, + "source": "examples/non_abi/non_abi.algo.ts:17", + "pc": [ + 105, + 106, + 107 + ] + }, + { + "teal": 94, + "source": "examples/non_abi/non_abi.algo.ts:17", + "pc": [ + 108 + ] + }, + { + "teal": 95, + "source": "examples/non_abi/non_abi.algo.ts:17", + "pc": [ + 109 + ] + }, + { + "teal": 96, + "source": "examples/non_abi/non_abi.algo.ts:13", + "pc": [ + 110 + ] + }, + { + "teal": 100, + "source": "examples/non_abi/non_abi.algo.ts:20", + "pc": [ + 111, + 112, + 113 + ] + }, + { + "teal": 104, + "source": "examples/non_abi/non_abi.algo.ts:22", + "pc": [ + 114, + 115, + 116, + 117, + 118, + 119, + 120, + 121, + 122, + 123 + ] + }, + { + "teal": 105, + "source": "examples/non_abi/non_abi.algo.ts:22", + "pc": [ + 124 + ] + }, + { + "teal": 106, + "source": "examples/non_abi/non_abi.algo.ts:20", + "pc": [ + 125 + ] + }, + { + "teal": 109, + "source": "examples/non_abi/non_abi.algo.ts:4", + "pc": [ + 126, + 127 + ] + }, + { + "teal": 110, + "source": "examples/non_abi/non_abi.algo.ts:4", + "pc": [ + 128 + ] + }, + { + "teal": 113, + "source": "examples/non_abi/non_abi.algo.ts:4", + "pc": [ + 129, + 130, + 131, + 132, + 133, + 134 + ] + }, + { + "teal": 114, + "source": "examples/non_abi/non_abi.algo.ts:4", + "pc": [ + 135, + 136, + 137 + ] + }, + { + "teal": 115, + "source": "examples/non_abi/non_abi.algo.ts:4", + "pc": [ + 138, + 139, + 140, + 141 + ] + }, + { + "teal": 118, + "source": "examples/non_abi/non_abi.algo.ts:4", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 142 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 121, + "source": "examples/non_abi/non_abi.algo.ts:4", + "pc": [ + 143, + 144, + 145, + 146, + 147, + 148 + ] + }, + { + "teal": 122, + "source": "examples/non_abi/non_abi.algo.ts:4", + "pc": [ + 149, + 150, + 151 + ] + }, + { + "teal": 123, + "source": "examples/non_abi/non_abi.algo.ts:4", + "pc": [ + 152, + 153, + 154, + 155 + ] + }, + { + "teal": 126, + "source": "examples/non_abi/non_abi.algo.ts:4", + "pc": [ + 156, + 157, + 158 + ] + }, + { + "teal": 127, + "source": "examples/non_abi/non_abi.algo.ts:4", + "pc": [ + 159, + 160 + ] + }, + { + "teal": 128, + "source": "examples/non_abi/non_abi.algo.ts:4", + "pc": [ + 161 + ] + }, + { + "teal": 132, + "source": "examples/non_abi/non_abi.algo.ts:4", + "pc": [ + 162, + 163, + 164 + ] + }, + { + "teal": 133, + "source": "examples/non_abi/non_abi.algo.ts:4", + "pc": [ + 165, + 166 + ] + }, + { + "teal": 134, + "source": "examples/non_abi/non_abi.algo.ts:4", + "pc": [ + 167 + ] } ], "pcOffsetMethod": "none" diff --git a/examples/reti/artifacts/StakingPool.arc56_draft.json b/examples/reti/artifacts/StakingPool.arc56_draft.json index 0984b735d..6f4ee23b1 100644 --- a/examples/reti/artifacts/StakingPool.arc56_draft.json +++ b/examples/reti/artifacts/StakingPool.arc56_draft.json @@ -503,370 +503,20411 @@ "approval": { "sourceInfo": [ { + "teal": 11, + "source": "examples/reti/stakingPool.algo.ts:38", + "pc": [ + 1 + ] + }, + { + "teal": 12, + "source": "examples/reti/stakingPool.algo.ts:38", + "pc": [ + 2 + ] + }, + { + "teal": 19, + "source": "examples/reti/stakingPool.algo.ts:38", + "pc": [ + 3, + 4 + ] + }, + { + "teal": 20, + "source": "examples/reti/stakingPool.algo.ts:38", + "pc": [ + 5 + ] + }, + { + "teal": 21, + "source": "examples/reti/stakingPool.algo.ts:38", + "pc": [ + 6, + 7 + ] + }, + { + "teal": 22, + "source": "examples/reti/stakingPool.algo.ts:38", + "pc": [ + 8 + ] + }, + { + "teal": 23, + "source": "examples/reti/stakingPool.algo.ts:38", + "pc": [ + 9, + 10 + ] + }, + { + "teal": 24, + "source": "examples/reti/stakingPool.algo.ts:38", + "pc": [ + 11 + ] + }, + { + "teal": 25, + "source": "examples/reti/stakingPool.algo.ts:38", + "pc": [ + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37 + ] + }, + { + "teal": 29, + "source": "examples/reti/stakingPool.algo.ts:38", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 38 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 34, + "source": "examples/reti/stakingPool.algo.ts:93", + "pc": [ + 39, + 40, + 41 + ] + }, + { + "teal": 35, + "source": "examples/reti/stakingPool.algo.ts:93", + "pc": [ + 42, + 43 + ] + }, + { + "teal": 36, + "source": "examples/reti/stakingPool.algo.ts:93", + "pc": [ + 44 + ] + }, + { + "teal": 40, + "source": "examples/reti/stakingPool.algo.ts:93", + "pc": [ + 45, + 46, + 47 + ] + }, + { + "teal": 47, + "source": "examples/reti/stakingPool.algo.ts:95", + "pc": [ + 48, + 49 + ] + }, + { + "teal": 48, + "source": "examples/reti/stakingPool.algo.ts:95", + "pc": [ + 50, + 51, + 52, + 53, + 54, + 55, + 56, + 57, + 58, + 59, + 60, + 61, + 62, + 63, + 64, + 65, + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82, + 83 + ] + }, + { + "teal": 49, + "source": "examples/reti/stakingPool.algo.ts:95", + "pc": [ + 84 + ] + }, + { + "teal": 52, + "source": "examples/reti/stakingPool.algo.ts:94", + "errorMessage": "Temporary: contract is upgradeable but only during testing and only from a development account", + "pc": [ + 85 + ] + }, + { + "teal": 53, + "source": "examples/reti/stakingPool.algo.ts:93", + "pc": [ + 86 + ] + }, + { + "teal": 58, + "source": "examples/reti/stakingPool.algo.ts:107", + "pc": [ + 87, + 88, + 89 + ] + }, + { + "teal": 59, + "source": "examples/reti/stakingPool.algo.ts:107", + "pc": [ + 90 + ] + }, + { + "teal": 62, + "source": "examples/reti/stakingPool.algo.ts:107", + "pc": [ + 91, + 92, + 93 + ] + }, + { + "teal": 63, + "source": "examples/reti/stakingPool.algo.ts:107", + "pc": [ + 94 + ] + }, + { + "teal": 66, + "source": "examples/reti/stakingPool.algo.ts:107", + "pc": [ + 95, + 96, + 97 + ] + }, + { + "teal": 67, + "source": "examples/reti/stakingPool.algo.ts:107", + "pc": [ + 98 + ] + }, + { + "teal": 70, + "source": "examples/reti/stakingPool.algo.ts:107", + "pc": [ + 99, + 100, + 101 + ] + }, + { + "teal": 71, + "source": "examples/reti/stakingPool.algo.ts:107", + "pc": [ + 102 + ] + }, + { + "teal": 74, + "source": "examples/reti/stakingPool.algo.ts:107", + "pc": [ + 103, + 104, + 105 + ] + }, + { + "teal": 75, + "source": "examples/reti/stakingPool.algo.ts:107", + "pc": [ + 106, + 107 + ] + }, + { + "teal": 76, + "source": "examples/reti/stakingPool.algo.ts:107", + "pc": [ + 108 + ] + }, + { + "teal": 86, + "source": "examples/reti/stakingPool.algo.ts:107", + "pc": [ + 109, + 110, + 111 + ] + }, + { + "teal": 91, + "source": "examples/reti/stakingPool.algo.ts:108", + "pc": [ + 112, + 113 + ] + }, + { + "teal": 92, + "source": "examples/reti/stakingPool.algo.ts:108", + "pc": [ + 114, + 115 + ] + }, + { + "teal": 93, + "source": "examples/reti/stakingPool.algo.ts:108", + "pc": [ + 116 + ] + }, + { + "teal": 94, + "source": "examples/reti/stakingPool.algo.ts:108", + "pc": [ + 117, + 118, + 119 + ] + }, + { + "teal": 99, + "source": "examples/reti/stakingPool.algo.ts:110", + "pc": [ + 120, + 121 + ] + }, + { + "teal": 100, + "source": "examples/reti/stakingPool.algo.ts:110", + "pc": [ + 122, + 123 + ] + }, + { + "teal": 101, + "source": "examples/reti/stakingPool.algo.ts:110", + "pc": [ + 124 + ] + }, + { + "teal": 102, + "source": "examples/reti/stakingPool.algo.ts:110", + "pc": [ + 125 + ] + }, + { + "teal": 106, + "source": "examples/reti/stakingPool.algo.ts:111", + "pc": [ + 126, + 127 + ] + }, + { + "teal": 107, + "source": "examples/reti/stakingPool.algo.ts:111", + "pc": [ + 128, + 129 + ] + }, + { + "teal": 108, + "source": "examples/reti/stakingPool.algo.ts:111", + "pc": [ + 130 + ] + }, + { + "teal": 109, + "source": "examples/reti/stakingPool.algo.ts:111", + "pc": [ + 131 + ] + }, + { + "teal": 110, + "source": "examples/reti/stakingPool.algo.ts:108", + "pc": [ + 132, + 133, + 134 + ] + }, + { + "teal": 115, + "source": "examples/reti/stakingPool.algo.ts:113", + "pc": [ + 135, + 136 + ] + }, + { + "teal": 116, + "source": "examples/reti/stakingPool.algo.ts:113", + "pc": [ + 137, + 138 + ] + }, + { + "teal": 117, + "source": "examples/reti/stakingPool.algo.ts:113", + "pc": [ + 139 + ] + }, + { + "teal": 118, + "source": "examples/reti/stakingPool.algo.ts:113", + "pc": [ + 140 + ] + }, + { + "teal": 122, + "source": "examples/reti/stakingPool.algo.ts:114", + "pc": [ + 141, + 142 + ] + }, + { + "teal": 123, + "source": "examples/reti/stakingPool.algo.ts:114", + "pc": [ + 143, + 144 + ] + }, + { + "teal": 124, + "source": "examples/reti/stakingPool.algo.ts:114", + "pc": [ + 145 + ] + }, + { + "teal": 125, + "source": "examples/reti/stakingPool.algo.ts:114", + "pc": [ + 146 + ] + }, + { + "teal": 130, + "source": "examples/reti/stakingPool.algo.ts:116", + "pc": [ + 147, + 148 + ] + }, + { + "teal": 131, + "source": "examples/reti/stakingPool.algo.ts:116", + "pc": [ + 149, + 150, + 151, + 152 + ] + }, + { + "teal": 132, + "source": "examples/reti/stakingPool.algo.ts:116", + "pc": [ + 153 + ] + }, + { + "teal": 135, + "source": "examples/reti/stakingPool.algo.ts:116", + "errorMessage": "staking pool must have minimum entry of 1 algo", + "pc": [ + 154 + ] + }, + { + "teal": 139, + "source": "examples/reti/stakingPool.algo.ts:117", + "pc": [ + 155, + 156, + 157, + 158, + 159, + 160, + 161, + 162, + 163, + 164, + 165, + 166 + ] + }, + { + "teal": 140, + "source": "examples/reti/stakingPool.algo.ts:117", + "pc": [ + 167, + 168 + ] + }, + { + "teal": 141, + "source": "examples/reti/stakingPool.algo.ts:117", + "pc": [ + 169 + ] + }, + { + "teal": 145, + "source": "examples/reti/stakingPool.algo.ts:118", + "pc": [ + 170, + 171, + 172, + 173, + 174, + 175, + 176, + 177, + 178, + 179, + 180, + 181, + 182 + ] + }, + { + "teal": 146, + "source": "examples/reti/stakingPool.algo.ts:118", + "pc": [ + 183, + 184 + ] + }, + { + "teal": 147, + "source": "examples/reti/stakingPool.algo.ts:118", + "pc": [ + 185 + ] + }, + { + "teal": 151, + "source": "examples/reti/stakingPool.algo.ts:119", + "pc": [ + 186, + 187, + 188, + 189, + 190, + 191, + 192, + 193 + ] + }, + { + "teal": 152, + "source": "examples/reti/stakingPool.algo.ts:119", + "pc": [ + 194, + 195 + ] + }, + { + "teal": 153, + "source": "examples/reti/stakingPool.algo.ts:119", + "pc": [ + 196 + ] + }, + { + "teal": 157, + "source": "examples/reti/stakingPool.algo.ts:120", + "pc": [ + 197, + 198, + 199, + 200, + 201, + 202, + 203, + 204, + 205, + 206, + 207, + 208 + ] + }, + { + "teal": 158, + "source": "examples/reti/stakingPool.algo.ts:120", + "pc": [ + 209, + 210 + ] + }, + { + "teal": 159, + "source": "examples/reti/stakingPool.algo.ts:120", + "pc": [ + 211 + ] + }, + { + "teal": 163, + "source": "examples/reti/stakingPool.algo.ts:121", + "pc": [ + 212, + 213, + 214, + 215, + 216, + 217, + 218, + 219 + ] + }, + { + "teal": 164, + "source": "examples/reti/stakingPool.algo.ts:121", + "pc": [ + 220, + 221 + ] + }, + { + "teal": 165, + "source": "examples/reti/stakingPool.algo.ts:121", + "pc": [ + 222 + ] + }, + { + "teal": 169, + "source": "examples/reti/stakingPool.algo.ts:122", + "pc": [ + 223, + 224, + 225, + 226, + 227, + 228, + 229, + 230, + 231, + 232, + 233, + 234, + 235, + 236, + 237 + ] + }, + { + "teal": 170, + "source": "examples/reti/stakingPool.algo.ts:122", + "pc": [ + 238, + 239 + ] + }, + { + "teal": 171, + "source": "examples/reti/stakingPool.algo.ts:122", + "pc": [ + 240 + ] + }, + { + "teal": 175, + "source": "examples/reti/stakingPool.algo.ts:123", + "pc": [ + 241, + 242, + 243, + 244, + 245, + 246, + 247, + 248, + 249, + 250, + 251, + 252 + ] + }, + { + "teal": 176, + "source": "examples/reti/stakingPool.algo.ts:123", + "pc": [ + 253, + 254 + ] + }, + { + "teal": 177, + "source": "examples/reti/stakingPool.algo.ts:123", + "pc": [ + 255 + ] + }, + { + "teal": 181, + "source": "examples/reti/stakingPool.algo.ts:124", + "pc": [ + 256, + 257, + 258, + 259, + 260, + 261, + 262, + 263, + 264, + 265, + 266, + 267, + 268 + ] + }, + { + "teal": 182, + "source": "examples/reti/stakingPool.algo.ts:124", + "pc": [ + 269, + 270 + ] + }, + { + "teal": 183, + "source": "examples/reti/stakingPool.algo.ts:124", + "pc": [ + 271 + ] + }, + { + "teal": 187, + "source": "examples/reti/stakingPool.algo.ts:126", + "pc": [ + 272, + 273, + 274 + ] + }, + { + "teal": 191, + "source": "examples/reti/stakingPool.algo.ts:127", + "pc": [ + 275, + 276, + 277, + 278, + 279, + 280, + 281, + 282, + 283, + 284, + 285, + 286, + 287, + 288, + 289 + ] + }, + { + "teal": 192, + "source": "examples/reti/stakingPool.algo.ts:127", + "pc": [ + 290, + 291 + ] + }, + { + "teal": 193, + "source": "examples/reti/stakingPool.algo.ts:127", + "pc": [ + 292, + 293 + ] + }, + { + "teal": 194, + "source": "examples/reti/stakingPool.algo.ts:127", + "pc": [ + 294, + 295, + 296, + 297, + 298, + 299, + 300, + 301, + 302, + 303, + 304, + 305, + 306, + 307 + ] + }, + { + "teal": 195, + "source": "examples/reti/stakingPool.algo.ts:127", + "pc": [ + 308 + ] + }, + { + "teal": 196, + "source": "examples/reti/stakingPool.algo.ts:127", + "pc": [ + 309 + ] + }, + { + "teal": 197, + "source": "examples/reti/stakingPool.algo.ts:127", + "pc": [ + 310 + ] + }, + { + "teal": 198, + "source": "examples/reti/stakingPool.algo.ts:127", + "pc": [ + 311 + ] + }, + { + "teal": 202, + "source": "examples/reti/stakingPool.algo.ts:128", + "pc": [ + 312, + 313, + 314, + 315, + 316, + 317, + 318, + 319, + 320, + 321, + 322, + 323, + 324, + 325, + 326, + 327, + 328, + 329 + ] + }, + { + "teal": 203, + "source": "examples/reti/stakingPool.algo.ts:128", + "pc": [ + 330, + 331, + 332, + 333, + 334, + 335, + 336, + 337, + 338, + 339, + 340, + 341, + 342, + 343, + 344, + 345, + 346, + 347 + ] + }, + { + "teal": 204, + "source": "examples/reti/stakingPool.algo.ts:128", + "pc": [ + 348 + ] + }, + { + "teal": 208, + "source": "examples/reti/stakingPool.algo.ts:129", + "pc": [ + 349, + 350, + 351, + 352, + 353, + 354, + 355, + 356, + 357, + 358, + 359, + 360, + 361, + 362, + 363, + 364, + 365, + 366, + 367 + ] + }, + { + "teal": 209, + "source": "examples/reti/stakingPool.algo.ts:129", + "pc": [ + 368, + 369 + ] + }, + { + "teal": 210, + "source": "examples/reti/stakingPool.algo.ts:129", + "pc": [ + 370 + ] + }, + { + "teal": 214, + "source": "examples/reti/stakingPool.algo.ts:130", + "pc": [ + 371, + 372, + 373, + 374, + 375, + 376 + ] + }, + { + "teal": 215, + "source": "examples/reti/stakingPool.algo.ts:130", + "pc": [ + 377, + 378, + 379, + 380, + 381, + 382, + 383, + 384, + 385, + 386, + 387, + 388, + 389, + 390, + 391, + 392, + 393, + 394 + ] + }, + { + "teal": 216, + "source": "examples/reti/stakingPool.algo.ts:130", + "pc": [ + 395 + ] + }, + { + "teal": 217, + "source": "examples/reti/stakingPool.algo.ts:107", + "pc": [ + 396 + ] + }, + { + "teal": 222, + "source": "examples/reti/stakingPool.algo.ts:136", + "pc": [ + 397, + 398, + 399 + ] + }, + { + "teal": 223, + "source": "examples/reti/stakingPool.algo.ts:136", + "pc": [ + 400, + 401 + ] + }, + { + "teal": 224, + "source": "examples/reti/stakingPool.algo.ts:136", + "pc": [ + 402 + ] + }, + { + "teal": 230, + "source": "examples/reti/stakingPool.algo.ts:136", + "pc": [ + 403, + 404, + 405 + ] + }, + { + "teal": 231, + "source": "examples/reti/stakingPool.algo.ts:136", + "pc": [ + 406 + ] + }, + { + "teal": 235, + "source": "examples/reti/stakingPool.algo.ts:138", + "pc": [ + 407, + 408, + 409 + ] + }, + { + "teal": 239, + "source": "examples/reti/stakingPool.algo.ts:142", + "pc": [ + 410, + 411, + 412 + ] + }, + { + "teal": 240, + "source": "examples/reti/stakingPool.algo.ts:142", + "pc": [ + 413, + 414 + ] + }, + { + "teal": 241, + "source": "examples/reti/stakingPool.algo.ts:142", + "pc": [ + 415, + 416, + 417 + ] + }, + { + "teal": 242, + "source": "examples/reti/stakingPool.algo.ts:142", + "pc": [ + 418 + ] + }, + { + "teal": 243, + "source": "examples/reti/stakingPool.algo.ts:142", + "pc": [ + 419 + ] + }, + { + "teal": 244, + "source": "examples/reti/stakingPool.algo.ts:138", + "pc": [ + 420 + ] + }, + { + "teal": 249, + "source": "examples/reti/stakingPool.algo.ts:152", + "pc": [ + 421, + 422 + ] + }, + { + "teal": 250, + "source": "examples/reti/stakingPool.algo.ts:152", + "pc": [ + 423, + 424 + ] + }, + { + "teal": 251, + "source": "examples/reti/stakingPool.algo.ts:152", + "pc": [ + 425 + ] + }, + { + "teal": 252, + "source": "examples/reti/stakingPool.algo.ts:152", + "pc": [ + 426 + ] + }, + { + "teal": 253, + "source": "examples/reti/stakingPool.algo.ts:152", + "pc": [ + 427, + 428 + ] + }, + { + "teal": 254, + "source": "examples/reti/stakingPool.algo.ts:152", + "pc": [ + 429, + 430 + ] + }, + { + "teal": 255, + "source": "examples/reti/stakingPool.algo.ts:152", + "pc": [ + 431 + ] + }, + { + "teal": 258, + "source": "examples/reti/stakingPool.algo.ts:152", + "errorMessage": "argument 0 (mbrPayment) for initStorage must be a pay transaction", + "pc": [ + 432 + ] + }, + { + "teal": 261, + "source": "examples/reti/stakingPool.algo.ts:152", + "pc": [ + 433, + 434, + 435 + ] + }, + { + "teal": 262, + "source": "examples/reti/stakingPool.algo.ts:152", + "pc": [ + 436, + 437 + ] + }, + { + "teal": 263, + "source": "examples/reti/stakingPool.algo.ts:152", + "pc": [ + 438 + ] + }, + { + "teal": 273, + "source": "examples/reti/stakingPool.algo.ts:152", + "pc": [ + 439, + 440, + 441 + ] + }, + { + "teal": 276, + "source": "examples/reti/stakingPool.algo.ts:152", + "pc": [ + 442, + 443 + ] + }, + { + "teal": 277, + "source": "examples/reti/stakingPool.algo.ts:152", + "pc": [ + 444, + 445 + ] + }, + { + "teal": 281, + "source": "examples/reti/stakingPool.algo.ts:153", + "pc": [ + 446, + 447, + 448, + 449, + 450, + 451, + 452, + 453, + 454 + ] + }, + { + "teal": 282, + "source": "examples/reti/stakingPool.algo.ts:153", + "pc": [ + 455 + ] + }, + { + "teal": 283, + "source": "examples/reti/stakingPool.algo.ts:153", + "pc": [ + 456 + ] + }, + { + "teal": 284, + "source": "examples/reti/stakingPool.algo.ts:153", + "pc": [ + 457 + ] + }, + { + "teal": 285, + "source": "examples/reti/stakingPool.algo.ts:153", + "pc": [ + 458 + ] + }, + { + "teal": 288, + "source": "examples/reti/stakingPool.algo.ts:153", + "errorMessage": "staking pool already initialized", + "pc": [ + 459 + ] + }, + { + "teal": 295, + "source": "examples/reti/stakingPool.algo.ts:156", + "pc": [ + 460 + ] + }, + { + "teal": 296, + "source": "examples/reti/stakingPool.algo.ts:156", + "pc": [ + 461, + 462 + ] + }, + { + "teal": 297, + "source": "examples/reti/stakingPool.algo.ts:156", + "pc": [ + 463, + 464 + ] + }, + { + "teal": 298, + "source": "examples/reti/stakingPool.algo.ts:156", + "pc": [ + 465, + 466, + 467, + 468, + 469, + 470 + ] + }, + { + "teal": 299, + "source": "examples/reti/stakingPool.algo.ts:156", + "pc": [ + 471, + 472 + ] + }, + { + "teal": 303, + "source": "examples/reti/stakingPool.algo.ts:157", + "pc": [ + 473, + 474, + 475, + 476, + 477, + 478, + 479, + 480, + 481, + 482, + 483, + 484 + ] + }, + { + "teal": 304, + "source": "examples/reti/stakingPool.algo.ts:157", + "pc": [ + 485 + ] + }, + { + "teal": 305, + "source": "examples/reti/stakingPool.algo.ts:157", + "pc": [ + 486, + 487 + ] + }, + { + "teal": 309, + "source": "examples/reti/stakingPool.algo.ts:158", + "pc": [ + 488, + 489, + 490, + 491, + 492, + 493, + 494, + 495, + 496, + 497, + 498, + 499, + 500 + ] + }, + { + "teal": 310, + "source": "examples/reti/stakingPool.algo.ts:158", + "pc": [ + 501 + ] + }, + { + "teal": 311, + "source": "examples/reti/stakingPool.algo.ts:158", + "pc": [ + 502 + ] + }, + { + "teal": 312, + "source": "examples/reti/stakingPool.algo.ts:158", + "pc": [ + 503, + 504 + ] + }, + { + "teal": 315, + "source": "examples/reti/stakingPool.algo.ts:156", + "pc": [ + 505, + 506 + ] + }, + { + "teal": 316, + "source": "examples/reti/stakingPool.algo.ts:156", + "pc": [ + 507, + 508 + ] + }, + { + "teal": 319, + "source": "examples/reti/stakingPool.algo.ts:156", + "pc": [ + 509 + ] + }, + { + "teal": 320, + "source": "examples/reti/stakingPool.algo.ts:156", + "pc": [ + 510, + 511 + ] + }, + { + "teal": 321, + "source": "examples/reti/stakingPool.algo.ts:156", + "pc": [ + 512, + 513 + ] + }, + { + "teal": 322, + "source": "examples/reti/stakingPool.algo.ts:156", + "pc": [ + 514 + ] + }, + { + "teal": 323, + "source": "examples/reti/stakingPool.algo.ts:156", + "pc": [ + 515, + 516 + ] + }, + { + "teal": 324, + "source": "examples/reti/stakingPool.algo.ts:156", + "pc": [ + 517, + 518, + 519 + ] + }, + { + "teal": 325, + "source": "examples/reti/stakingPool.algo.ts:156", + "pc": [ + 520, + 521 + ] + }, + { + "teal": 329, + "source": "examples/reti/stakingPool.algo.ts:160", + "pc": [ + 522, + 523 + ] + }, + { + "teal": 330, + "source": "examples/reti/stakingPool.algo.ts:160", + "pc": [ + 524, + 525, + 526 + ] + }, + { + "teal": 331, + "source": "examples/reti/stakingPool.algo.ts:160", + "pc": [ + 527 + ] + }, + { + "teal": 332, + "source": "examples/reti/stakingPool.algo.ts:160", + "pc": [ + 528, + 529 + ] + }, + { + "teal": 333, + "source": "examples/reti/stakingPool.algo.ts:160", + "pc": [ + 530 + ] + }, + { + "teal": 334, + "source": "examples/reti/stakingPool.algo.ts:160", + "pc": [ + 531, + 532 + ] + }, + { + "teal": 338, + "source": "examples/reti/stakingPool.algo.ts:161", + "pc": [ + 533, + 534 + ] + }, + { + "teal": 339, + "source": "examples/reti/stakingPool.algo.ts:161", + "pc": [ + 535 + ] + }, + { + "teal": 340, + "source": "examples/reti/stakingPool.algo.ts:161", + "pc": [ + 536, + 537, + 538 + ] + }, + { + "teal": 341, + "source": "examples/reti/stakingPool.algo.ts:161", + "pc": [ + 539, + 540, + 541, + 542, + 543, + 544, + 545, + 546 + ] + }, + { + "teal": 342, + "source": "examples/reti/stakingPool.algo.ts:161", + "pc": [ + 547 + ] + }, + { + "teal": 343, + "source": "examples/reti/stakingPool.algo.ts:161", + "pc": [ + 548, + 549 + ] + }, + { + "teal": 344, + "source": "examples/reti/stakingPool.algo.ts:161", + "pc": [ + 550 + ] + }, + { + "teal": 345, + "source": "examples/reti/stakingPool.algo.ts:161", + "pc": [ + 551 + ] + }, + { + "teal": 348, + "source": "examples/reti/stakingPool.algo.ts:161", + "pc": [ + 552, + 553, + 554 + ] + }, + { + "teal": 349, + "source": "examples/reti/stakingPool.algo.ts:161", + "pc": [ + 555, + 556, + 557, + 558 + ] + }, + { + "teal": 350, + "source": "examples/reti/stakingPool.algo.ts:161", + "pc": [ + 559, + 560, + 561 + ] + }, + { + "teal": 353, + "source": "examples/reti/stakingPool.algo.ts:161", + "pc": [ + 562, + 563 + ] + }, + { + "teal": 356, + "source": "examples/reti/stakingPool.algo.ts:161", + "pc": [ + 564, + 565 + ] + }, + { + "teal": 363, + "source": "examples/reti/stakingPool.algo.ts:163", + "pc": [ + 566, + 567, + 568, + 569 + ] + }, + { + "teal": 364, + "source": "examples/reti/stakingPool.algo.ts:164", + "pc": [ + 570, + 571 + ] + }, + { + "teal": 365, + "source": "examples/reti/stakingPool.algo.ts:163", + "pc": [ + 572 + ] + }, + { + "teal": 366, + "source": "examples/reti/stakingPool.algo.ts:165", + "pc": [ + 573, + 574, + 575 + ] + }, + { + "teal": 367, + "source": "examples/reti/stakingPool.algo.ts:165", + "pc": [ + 576, + 577, + 578 + ] + }, + { + "teal": 368, + "source": "examples/reti/stakingPool.algo.ts:164", + "pc": [ + 579 + ] + }, + { + "teal": 369, + "source": "examples/reti/stakingPool.algo.ts:162", + "pc": [ + 580, + 581 + ] + }, + { + "teal": 374, + "source": "examples/reti/stakingPool.algo.ts:168", + "pc": [ + 582, + 583 + ] + }, + { + "teal": 375, + "source": "examples/reti/stakingPool.algo.ts:168", + "pc": [ + 584, + 585 + ] + }, + { + "teal": 376, + "source": "examples/reti/stakingPool.algo.ts:168", + "pc": [ + 586, + 587 + ] + }, + { + "teal": 377, + "source": "examples/reti/stakingPool.algo.ts:168", + "pc": [ + 588 + ] + }, + { + "teal": 380, + "source": "examples/reti/stakingPool.algo.ts:168", + "errorMessage": "transaction verification failed: {\"txn\":\"mbrPayment\",\"field\":\"receiver\",\"expected\":\"this.app.address\"}", + "pc": [ + 589 + ] + }, + { + "teal": 383, + "source": "examples/reti/stakingPool.algo.ts:168", + "pc": [ + 590, + 591 + ] + }, + { + "teal": 384, + "source": "examples/reti/stakingPool.algo.ts:168", + "pc": [ + 592, + 593 + ] + }, + { + "teal": 385, + "source": "examples/reti/stakingPool.algo.ts:168", + "pc": [ + 594, + 595 + ] + }, + { + "teal": 386, + "source": "examples/reti/stakingPool.algo.ts:168", + "pc": [ + 596 + ] + }, + { + "teal": 389, + "source": "examples/reti/stakingPool.algo.ts:168", + "errorMessage": "transaction verification failed: {\"txn\":\"mbrPayment\",\"field\":\"amount\",\"expected\":\"PoolInitMbr\"}", + "pc": [ + 597 + ] + }, + { + "teal": 393, + "source": "examples/reti/stakingPool.algo.ts:169", + "pc": [ + 598, + 599, + 600, + 601, + 602, + 603, + 604, + 605, + 606 + ] + }, + { + "teal": 394, + "source": "examples/reti/stakingPool.algo.ts:169", + "pc": [ + 607, + 608, + 609 + ] + }, + { + "teal": 395, + "source": "examples/reti/stakingPool.algo.ts:169", + "pc": [ + 610 + ] + }, + { + "teal": 396, + "source": "examples/reti/stakingPool.algo.ts:169", + "pc": [ + 611 + ] + }, + { + "teal": 401, + "source": "examples/reti/stakingPool.algo.ts:171", + "pc": [ + 612, + 613 + ] + }, + { + "teal": 402, + "source": "examples/reti/stakingPool.algo.ts:171", + "pc": [ + 614 + ] + }, + { + "teal": 403, + "source": "examples/reti/stakingPool.algo.ts:171", + "pc": [ + 615, + 616, + 617 + ] + }, + { + "teal": 404, + "source": "examples/reti/stakingPool.algo.ts:171", + "pc": [ + 618, + 619, + 620, + 621, + 622, + 623, + 624, + 625 + ] + }, + { + "teal": 405, + "source": "examples/reti/stakingPool.algo.ts:171", + "pc": [ + 626 + ] + }, + { + "teal": 406, + "source": "examples/reti/stakingPool.algo.ts:171", + "pc": [ + 627, + 628 + ] + }, + { + "teal": 407, + "source": "examples/reti/stakingPool.algo.ts:171", + "pc": [ + 629 + ] + }, + { + "teal": 408, + "source": "examples/reti/stakingPool.algo.ts:171", + "pc": [ + 630 + ] + }, + { + "teal": 411, + "source": "examples/reti/stakingPool.algo.ts:171", + "pc": [ + 631, + 632, + 633 + ] + }, + { + "teal": 420, + "source": "examples/reti/stakingPool.algo.ts:173", + "pc": [ + 634 + ] + }, + { + "teal": 421, + "source": "examples/reti/stakingPool.algo.ts:173", + "pc": [ + 635, + 636 + ] + }, + { + "teal": 422, + "source": "examples/reti/stakingPool.algo.ts:173", + "pc": [ + 637, + 638 + ] + }, + { + "teal": 426, + "source": "examples/reti/stakingPool.algo.ts:174", + "pc": [ + 639, + 640 + ] + }, + { + "teal": 427, + "source": "examples/reti/stakingPool.algo.ts:174", + "pc": [ + 641, + 642, + 643 + ] + }, + { + "teal": 428, + "source": "examples/reti/stakingPool.algo.ts:174", + "pc": [ + 644 + ] + }, + { + "teal": 429, + "source": "examples/reti/stakingPool.algo.ts:174", + "pc": [ + 645, + 646 + ] + }, + { + "teal": 433, + "source": "examples/reti/stakingPool.algo.ts:175", + "pc": [ + 647, + 648 + ] + }, + { + "teal": 434, + "source": "examples/reti/stakingPool.algo.ts:175", + "pc": [ + 649, + 650 + ] + }, + { + "teal": 438, + "source": "examples/reti/stakingPool.algo.ts:176", + "pc": [ + 651, + 652 + ] + }, + { + "teal": 439, + "source": "examples/reti/stakingPool.algo.ts:176", + "pc": [ + 653, + 654 + ] + }, + { + "teal": 442, + "source": "examples/reti/stakingPool.algo.ts:173", + "pc": [ + 655, + 656 + ] + }, + { + "teal": 443, + "source": "examples/reti/stakingPool.algo.ts:173", + "pc": [ + 657, + 658 + ] + }, + { + "teal": 446, + "source": "examples/reti/stakingPool.algo.ts:173", + "pc": [ + 659 + ] + }, + { + "teal": 449, + "source": "examples/reti/stakingPool.algo.ts:152", + "pc": [ + 660 + ] + }, + { + "teal": 454, + "source": "examples/reti/stakingPool.algo.ts:191", + "pc": [ + 661, + 662, + 663, + 664, + 665, + 666 + ] + }, + { + "teal": 457, + "source": "examples/reti/stakingPool.algo.ts:191", + "pc": [ + 667, + 668, + 669 + ] + }, + { + "teal": 458, + "source": "examples/reti/stakingPool.algo.ts:191", + "pc": [ + 670 + ] + }, + { + "teal": 459, + "source": "examples/reti/stakingPool.algo.ts:191", + "pc": [ + 671 + ] + }, + { + "teal": 460, + "source": "examples/reti/stakingPool.algo.ts:191", + "pc": [ + 672, + 673 + ] + }, + { + "teal": 461, + "source": "examples/reti/stakingPool.algo.ts:191", + "pc": [ + 674 + ] + }, + { + "teal": 464, + "source": "examples/reti/stakingPool.algo.ts:191", + "errorMessage": "argument 0 (staker) for addStake must be a address", + "pc": [ + 675 + ] + }, + { + "teal": 467, + "source": "examples/reti/stakingPool.algo.ts:191", + "pc": [ + 676, + 677 + ] + }, + { + "teal": 468, + "source": "examples/reti/stakingPool.algo.ts:191", + "pc": [ + 678, + 679 + ] + }, + { + "teal": 469, + "source": "examples/reti/stakingPool.algo.ts:191", + "pc": [ + 680 + ] + }, + { + "teal": 470, + "source": "examples/reti/stakingPool.algo.ts:191", + "pc": [ + 681 + ] + }, + { + "teal": 471, + "source": "examples/reti/stakingPool.algo.ts:191", + "pc": [ + 682, + 683 + ] + }, + { + "teal": 472, + "source": "examples/reti/stakingPool.algo.ts:191", + "pc": [ + 684, + 685 + ] + }, + { + "teal": 473, + "source": "examples/reti/stakingPool.algo.ts:191", + "pc": [ + 686 + ] + }, + { + "teal": 476, + "source": "examples/reti/stakingPool.algo.ts:191", + "errorMessage": "argument 1 (stakedAmountPayment) for addStake must be a pay transaction", + "pc": [ + 687 + ] + }, + { + "teal": 479, + "source": "examples/reti/stakingPool.algo.ts:191", + "pc": [ + 688, + 689, + 690 + ] + }, + { + "teal": 480, + "source": "examples/reti/stakingPool.algo.ts:191", + "pc": [ + 691 + ] + }, + { + "teal": 481, + "source": "examples/reti/stakingPool.algo.ts:191", + "pc": [ + 692 + ] + }, + { + "teal": 482, + "source": "examples/reti/stakingPool.algo.ts:191", + "pc": [ + 693 + ] + }, + { + "teal": 483, + "source": "examples/reti/stakingPool.algo.ts:191", + "pc": [ + 694, + 695 + ] + }, + { + "teal": 484, + "source": "examples/reti/stakingPool.algo.ts:191", + "pc": [ + 696 + ] + }, + { + "teal": 497, + "source": "examples/reti/stakingPool.algo.ts:191", + "pc": [ + 697, + 698, + 699 + ] + }, + { + "teal": 500, + "source": "examples/reti/stakingPool.algo.ts:191", + "pc": [ + 700, + 701 + ] + }, + { + "teal": 501, + "source": "examples/reti/stakingPool.algo.ts:191", + "pc": [ + 702, + 703 + ] + }, + { + "teal": 505, + "source": "examples/reti/stakingPool.algo.ts:192", + "pc": [ + 704, + 705, + 706, + 707, + 708, + 709, + 710, + 711, + 712 + ] + }, + { + "teal": 506, + "source": "examples/reti/stakingPool.algo.ts:192", + "pc": [ + 713 + ] + }, + { + "teal": 507, + "source": "examples/reti/stakingPool.algo.ts:192", + "pc": [ + 714 + ] + }, + { + "teal": 508, + "source": "examples/reti/stakingPool.algo.ts:192", + "pc": [ + 715 + ] + }, + { + "teal": 511, + "source": "examples/reti/stakingPool.algo.ts:192", + "errorMessage": "staking pool must be initialized first", + "pc": [ + 716 + ] + }, + { + "teal": 518, + "source": "examples/reti/stakingPool.algo.ts:196", + "pc": [ + 717, + 718 + ] + }, + { + "teal": 519, + "source": "examples/reti/stakingPool.algo.ts:196", + "pc": [ + 719, + 720, + 721, + 722, + 723, + 724, + 725, + 726, + 727, + 728, + 729, + 730 + ] + }, + { + "teal": 520, + "source": "examples/reti/stakingPool.algo.ts:196", + "pc": [ + 731 + ] + }, + { + "teal": 521, + "source": "examples/reti/stakingPool.algo.ts:196", + "pc": [ + 732, + 733 + ] + }, + { + "teal": 522, + "source": "examples/reti/stakingPool.algo.ts:196", + "pc": [ + 734 + ] + }, + { + "teal": 523, + "source": "examples/reti/stakingPool.algo.ts:196", + "pc": [ + 735 + ] + }, + { + "teal": 526, + "source": "examples/reti/stakingPool.algo.ts:195", + "errorMessage": "stake can only be added via the validator contract", + "pc": [ + 736 + ] + }, + { + "teal": 530, + "source": "examples/reti/stakingPool.algo.ts:199", + "pc": [ + 737, + 738 + ] + }, + { + "teal": 531, + "source": "examples/reti/stakingPool.algo.ts:199", + "pc": [ + 739, + 740 + ] + }, + { + "teal": 532, + "source": "examples/reti/stakingPool.algo.ts:199", + "pc": [ + 741 + ] + }, + { + "teal": 533, + "source": "examples/reti/stakingPool.algo.ts:199", + "pc": [ + 742 + ] + }, + { + "teal": 537, + "source": "examples/reti/stakingPool.algo.ts:202", + "pc": [ + 743, + 744, + 745 + ] + }, + { + "teal": 546, + "source": "examples/reti/stakingPool.algo.ts:206", + "pc": [ + 746, + 747 + ] + }, + { + "teal": 547, + "source": "examples/reti/stakingPool.algo.ts:207", + "pc": [ + 748, + 749 + ] + }, + { + "teal": 548, + "source": "examples/reti/stakingPool.algo.ts:207", + "pc": [ + 750, + 751, + 752, + 753, + 754, + 755, + 756, + 757, + 758, + 759, + 760, + 761 + ] + }, + { + "teal": 549, + "source": "examples/reti/stakingPool.algo.ts:207", + "pc": [ + 762 + ] + }, + { + "teal": 550, + "source": "examples/reti/stakingPool.algo.ts:207", + "pc": [ + 763, + 764 + ] + }, + { + "teal": 551, + "source": "examples/reti/stakingPool.algo.ts:207", + "pc": [ + 765 + ] + }, + { + "teal": 552, + "source": "examples/reti/stakingPool.algo.ts:207", + "pc": [ + 766 + ] + }, + { + "teal": 555, + "source": "examples/reti/stakingPool.algo.ts:207", + "errorMessage": "transaction verification failed: {\"txn\":\"stakedAmountPayment\",\"field\":\"sender\",\"expected\":\"AppID.fromUint64(this.creatingValidatorContractAppId.value).address\"}", + "pc": [ + 767 + ] + }, + { + "teal": 558, + "source": "examples/reti/stakingPool.algo.ts:206", + "pc": [ + 768, + 769 + ] + }, + { + "teal": 559, + "source": "examples/reti/stakingPool.algo.ts:208", + "pc": [ + 770, + 771 + ] + }, + { + "teal": 560, + "source": "examples/reti/stakingPool.algo.ts:208", + "pc": [ + 772, + 773 + ] + }, + { + "teal": 561, + "source": "examples/reti/stakingPool.algo.ts:208", + "pc": [ + 774 + ] + }, + { + "teal": 564, + "source": "examples/reti/stakingPool.algo.ts:208", + "errorMessage": "transaction verification failed: {\"txn\":\"stakedAmountPayment\",\"field\":\"receiver\",\"expected\":\"this.app.address\"}", + "pc": [ + 775 + ] + }, + { + "teal": 567, + "source": "examples/reti/stakingPool.algo.ts:206", + "pc": [ + 776, + 777 + ] + }, + { + "teal": 568, + "source": "examples/reti/stakingPool.algo.ts:209", + "pc": [ + 778, + 779 + ] + }, + { + "teal": 569, + "source": "examples/reti/stakingPool.algo.ts:209", + "pc": [ + 780, + 781 + ] + }, + { + "teal": 570, + "source": "examples/reti/stakingPool.algo.ts:209", + "pc": [ + 782, + 783 + ] + }, + { + "teal": 571, + "source": "examples/reti/stakingPool.algo.ts:209", + "pc": [ + 784 + ] + }, + { + "teal": 574, + "source": "examples/reti/stakingPool.algo.ts:209", + "errorMessage": "transaction verification failed: {\"txn\":\"stakedAmountPayment\",\"field\":\"amount\",\"expected\":\"stakedAmountPayment.amount\"}", + "pc": [ + 785 + ] + }, + { + "teal": 578, + "source": "examples/reti/stakingPool.algo.ts:215", + "pc": [ + 786, + 787 + ] + }, + { + "teal": 579, + "source": "examples/reti/stakingPool.algo.ts:215", + "pc": [ + 788, + 789, + 790 + ] + }, + { + "teal": 580, + "source": "examples/reti/stakingPool.algo.ts:215", + "pc": [ + 791 + ] + }, + { + "teal": 581, + "source": "examples/reti/stakingPool.algo.ts:215", + "pc": [ + 792, + 793 + ] + }, + { + "teal": 585, + "source": "examples/reti/stakingPool.algo.ts:216", + "pc": [ + 794, + 795 + ] + }, + { + "teal": 586, + "source": "examples/reti/stakingPool.algo.ts:216", + "pc": [ + 796, + 797 + ] + }, + { + "teal": 590, + "source": "examples/reti/stakingPool.algo.ts:218", + "pc": [ + 798, + 799, + 800, + 801, + 802, + 803, + 804, + 805 + ] + }, + { + "teal": 591, + "source": "examples/reti/stakingPool.algo.ts:218", + "pc": [ + 806 + ] + }, + { + "teal": 592, + "source": "examples/reti/stakingPool.algo.ts:218", + "pc": [ + 807, + 808 + ] + }, + { + "teal": 593, + "source": "examples/reti/stakingPool.algo.ts:218", + "pc": [ + 809, + 810 + ] + }, + { + "teal": 594, + "source": "examples/reti/stakingPool.algo.ts:218", + "pc": [ + 811 + ] + }, + { + "teal": 595, + "source": "examples/reti/stakingPool.algo.ts:218", + "pc": [ + 812, + 813, + 814, + 815, + 816, + 817, + 818, + 819 + ] + }, + { + "teal": 596, + "source": "examples/reti/stakingPool.algo.ts:218", + "pc": [ + 820 + ] + }, + { + "teal": 597, + "source": "examples/reti/stakingPool.algo.ts:218", + "pc": [ + 821 + ] + }, + { + "teal": 601, + "source": "examples/reti/stakingPool.algo.ts:220", + "pc": [ + 822, + 823, + 824, + 825, + 826, + 827, + 828, + 829, + 830, + 831, + 832, + 833, + 834, + 835, + 836 + ] + }, + { + "teal": 602, + "source": "examples/reti/stakingPool.algo.ts:220", + "pc": [ + 837 + ] + }, + { + "teal": 603, + "source": "examples/reti/stakingPool.algo.ts:220", + "pc": [ + 838, + 839, + 840, + 841, + 842, + 843, + 844, + 845, + 846, + 847, + 848, + 849, + 850, + 851 + ] + }, + { + "teal": 604, + "source": "examples/reti/stakingPool.algo.ts:220", + "pc": [ + 852 + ] + }, + { + "teal": 605, + "source": "examples/reti/stakingPool.algo.ts:220", + "pc": [ + 853 + ] + }, + { + "teal": 606, + "source": "examples/reti/stakingPool.algo.ts:220", + "pc": [ + 854, + 855 + ] + }, + { + "teal": 607, + "source": "examples/reti/stakingPool.algo.ts:220", + "pc": [ + 856 + ] + }, + { + "teal": 608, + "source": "examples/reti/stakingPool.algo.ts:220", + "pc": [ + 857, + 858 + ] + }, + { + "teal": 613, + "source": "examples/reti/stakingPool.algo.ts:221", + "pc": [ + 859, + 860, + 861, + 862, + 863, + 864, + 865, + 866, + 867, + 868, + 869, + 870, + 871, + 872, + 873, + 874, + 875, + 876 + ] + }, + { + "teal": 614, + "source": "examples/reti/stakingPool.algo.ts:221", + "pc": [ + 877 + ] + }, + { + "teal": 615, + "source": "examples/reti/stakingPool.algo.ts:222", + "pc": [ + 878 + ] + }, + { + "teal": 616, + "source": "examples/reti/stakingPool.algo.ts:222", + "pc": [ + 879, + 880 + ] + }, + { + "teal": 617, + "source": "examples/reti/stakingPool.algo.ts:222", + "pc": [ + 881, + 882 + ] + }, + { + "teal": 618, + "source": "examples/reti/stakingPool.algo.ts:222", + "pc": [ + 883 + ] + }, + { + "teal": 619, + "source": "examples/reti/stakingPool.algo.ts:222", + "pc": [ + 884, + 885 + ] + }, + { + "teal": 620, + "source": "examples/reti/stakingPool.algo.ts:222", + "pc": [ + 886 + ] + }, + { + "teal": 621, + "source": "examples/reti/stakingPool.algo.ts:222", + "pc": [ + 887 + ] + }, + { + "teal": 622, + "source": "examples/reti/stakingPool.algo.ts:222", + "pc": [ + 888 + ] + }, + { + "teal": 623, + "source": "examples/reti/stakingPool.algo.ts:222", + "pc": [ + 889 + ] + }, + { + "teal": 624, + "source": "examples/reti/stakingPool.algo.ts:222", + "pc": [ + 890 + ] + }, + { + "teal": 625, + "source": "examples/reti/stakingPool.algo.ts:222", + "pc": [ + 891, + 892, + 893 + ] + }, + { + "teal": 626, + "source": "examples/reti/stakingPool.algo.ts:222", + "pc": [ + 894 + ] + }, + { + "teal": 629, + "source": "examples/reti/stakingPool.algo.ts:222", + "errorMessage": "this.stakeAccumulator.value + (stakedAmountPayment.amount as uint128) * (roundsLeftInBin as uint128) overflowed 128 bits", + "pc": [ + 895 + ] + }, + { + "teal": 630, + "source": "examples/reti/stakingPool.algo.ts:222", + "pc": [ + 896, + 897, + 898, + 899, + 900, + 901, + 902, + 903, + 904, + 905, + 906, + 907, + 908, + 909, + 910, + 911, + 912, + 913 + ] + }, + { + "teal": 631, + "source": "examples/reti/stakingPool.algo.ts:222", + "pc": [ + 914 + ] + }, + { + "teal": 632, + "source": "examples/reti/stakingPool.algo.ts:222", + "pc": [ + 915 + ] + }, + { + "teal": 633, + "source": "examples/reti/stakingPool.algo.ts:222", + "pc": [ + 916 + ] + }, + { + "teal": 634, + "source": "examples/reti/stakingPool.algo.ts:222", + "pc": [ + 917 + ] + }, + { + "teal": 635, + "source": "examples/reti/stakingPool.algo.ts:222", + "pc": [ + 918, + 919 + ] + }, + { + "teal": 636, + "source": "examples/reti/stakingPool.algo.ts:222", + "pc": [ + 920 + ] + }, + { + "teal": 637, + "source": "examples/reti/stakingPool.algo.ts:222", + "pc": [ + 921 + ] + }, + { + "teal": 638, + "source": "examples/reti/stakingPool.algo.ts:222", + "pc": [ + 922 + ] + }, + { + "teal": 639, + "source": "examples/reti/stakingPool.algo.ts:221", + "pc": [ + 923 + ] + }, + { + "teal": 643, + "source": "examples/reti/stakingPool.algo.ts:225", + "pc": [ + 924, + 925 + ] + }, + { + "teal": 644, + "source": "examples/reti/stakingPool.algo.ts:225", + "pc": [ + 926, + 927 + ] + }, + { + "teal": 649, + "source": "examples/reti/stakingPool.algo.ts:225", + "pc": [ + 928, + 929 + ] + }, + { + "teal": 650, + "source": "examples/reti/stakingPool.algo.ts:225", + "pc": [ + 930, + 931, + 932 + ] + }, + { + "teal": 651, + "source": "examples/reti/stakingPool.algo.ts:225", + "pc": [ + 933 + ] + }, + { + "teal": 652, + "source": "examples/reti/stakingPool.algo.ts:225", + "pc": [ + 934, + 935, + 936 + ] + }, + { + "teal": 657, + "source": "examples/reti/stakingPool.algo.ts:226", + "pc": [ + 937, + 938 + ] + }, + { + "teal": 658, + "source": "examples/reti/stakingPool.algo.ts:226", + "pc": [ + 939, + 940, + 941 + ] + }, + { + "teal": 659, + "source": "examples/reti/stakingPool.algo.ts:226", + "pc": [ + 942 + ] + }, + { + "teal": 660, + "source": "examples/reti/stakingPool.algo.ts:226", + "pc": [ + 943, + 944, + 945 + ] + }, + { + "teal": 665, + "source": "examples/reti/stakingPool.algo.ts:227", + "pc": [ + 946 + ] + }, + { + "teal": 666, + "source": "examples/reti/stakingPool.algo.ts:227", + "pc": [ + 947, + 948 + ] + }, + { + "teal": 667, + "source": "examples/reti/stakingPool.algo.ts:227", + "pc": [ + 949, + 950 + ] + }, + { + "teal": 668, + "source": "examples/reti/stakingPool.algo.ts:227", + "pc": [ + 951, + 952 + ] + }, + { + "teal": 669, + "source": "examples/reti/stakingPool.algo.ts:227", + "pc": [ + 953, + 954 + ] + }, + { + "teal": 670, + "source": "examples/reti/stakingPool.algo.ts:227", + "pc": [ + 955, + 956, + 957, + 958, + 959 + ] + }, + { + "teal": 671, + "source": "examples/reti/stakingPool.algo.ts:227", + "pc": [ + 960 + ] + }, + { + "teal": 672, + "source": "examples/reti/stakingPool.algo.ts:227", + "pc": [ + 961, + 962 + ] + }, + { + "teal": 673, + "source": "examples/reti/stakingPool.algo.ts:227", + "pc": [ + 963, + 964 + ] + }, + { + "teal": 674, + "source": "examples/reti/stakingPool.algo.ts:227", + "pc": [ + 965, + 966 + ] + }, + { + "teal": 675, + "source": "examples/reti/stakingPool.algo.ts:227", + "pc": [ + 967, + 968 + ] + }, + { + "teal": 676, + "source": "examples/reti/stakingPool.algo.ts:227", + "pc": [ + 969 + ] + }, + { + "teal": 681, + "source": "examples/reti/stakingPool.algo.ts:229", + "pc": [ + 970, + 971 + ] + }, + { + "teal": 682, + "source": "examples/reti/stakingPool.algo.ts:229", + "pc": [ + 972, + 973 + ] + }, + { + "teal": 683, + "source": "examples/reti/stakingPool.algo.ts:229", + "pc": [ + 974 + ] + }, + { + "teal": 684, + "source": "examples/reti/stakingPool.algo.ts:229", + "pc": [ + 975, + 976 + ] + }, + { + "teal": 685, + "source": "examples/reti/stakingPool.algo.ts:229", + "pc": [ + 977, + 978, + 979, + 980, + 981, + 982, + 983, + 984, + 985 + ] + }, + { + "teal": 686, + "source": "examples/reti/stakingPool.algo.ts:229", + "pc": [ + 986, + 987 + ] + }, + { + "teal": 687, + "source": "examples/reti/stakingPool.algo.ts:229", + "pc": [ + 988 + ] + }, + { + "teal": 688, + "source": "examples/reti/stakingPool.algo.ts:229", + "pc": [ + 989, + 990 + ] + }, + { + "teal": 693, + "source": "examples/reti/stakingPool.algo.ts:230", + "pc": [ + 991, + 992 + ] + }, + { + "teal": 694, + "source": "examples/reti/stakingPool.algo.ts:230", + "pc": [ + 993, + 994, + 995 + ] + }, + { + "teal": 695, + "source": "examples/reti/stakingPool.algo.ts:230", + "pc": [ + 996, + 997 + ] + }, + { + "teal": 696, + "source": "examples/reti/stakingPool.algo.ts:230", + "pc": [ + 998 + ] + }, + { + "teal": 697, + "source": "examples/reti/stakingPool.algo.ts:230", + "pc": [ + 999, + 1000, + 1001 + ] + }, + { + "teal": 702, + "source": "examples/reti/stakingPool.algo.ts:232", + "pc": [ + 1002, + 1003 + ] + }, + { + "teal": 703, + "source": "examples/reti/stakingPool.algo.ts:232", + "pc": [ + 1004, + 1005 + ] + }, + { + "teal": 704, + "source": "examples/reti/stakingPool.algo.ts:232", + "pc": [ + 1006, + 1007 + ] + }, + { + "teal": 705, + "source": "examples/reti/stakingPool.algo.ts:232", + "pc": [ + 1008, + 1009, + 1010 + ] + }, + { + "teal": 706, + "source": "examples/reti/stakingPool.algo.ts:232", + "pc": [ + 1011 + ] + }, + { + "teal": 707, + "source": "examples/reti/stakingPool.algo.ts:232", + "pc": [ + 1012, + 1013 + ] + }, + { + "teal": 708, + "source": "examples/reti/stakingPool.algo.ts:232", + "pc": [ + 1014, + 1015 + ] + }, + { + "teal": 709, + "source": "examples/reti/stakingPool.algo.ts:232", + "pc": [ + 1016 + ] + }, + { + "teal": 710, + "source": "examples/reti/stakingPool.algo.ts:232", + "pc": [ + 1017 + ] + }, + { + "teal": 711, + "source": "examples/reti/stakingPool.algo.ts:232", + "pc": [ + 1018 + ] + }, + { + "teal": 712, + "source": "examples/reti/stakingPool.algo.ts:232", + "pc": [ + 1019, + 1020 + ] + }, + { + "teal": 716, + "source": "examples/reti/stakingPool.algo.ts:233", + "pc": [ + 1021, + 1022 + ] + }, + { + "teal": 717, + "source": "examples/reti/stakingPool.algo.ts:233", + "pc": [ + 1023, + 1024 + ] + }, + { + "teal": 718, + "source": "examples/reti/stakingPool.algo.ts:233", + "pc": [ + 1025, + 1026 + ] + }, + { + "teal": 719, + "source": "examples/reti/stakingPool.algo.ts:233", + "pc": [ + 1027 + ] + }, + { + "teal": 720, + "source": "examples/reti/stakingPool.algo.ts:233", + "pc": [ + 1028 + ] + }, + { + "teal": 721, + "source": "examples/reti/stakingPool.algo.ts:233", + "pc": [ + 1029, + 1030 + ] + }, + { + "teal": 725, + "source": "examples/reti/stakingPool.algo.ts:236", + "pc": [ + 1031, + 1032 + ] + }, + { + "teal": 726, + "source": "examples/reti/stakingPool.algo.ts:236", + "pc": [ + 1033, + 1034 + ] + }, + { + "teal": 727, + "source": "examples/reti/stakingPool.algo.ts:236", + "pc": [ + 1035 + ] + }, + { + "teal": 728, + "source": "examples/reti/stakingPool.algo.ts:236", + "pc": [ + 1036, + 1037 + ] + }, + { + "teal": 729, + "source": "examples/reti/stakingPool.algo.ts:236", + "pc": [ + 1038, + 1039, + 1040, + 1041, + 1042, + 1043, + 1044, + 1045, + 1046 + ] + }, + { + "teal": 730, + "source": "examples/reti/stakingPool.algo.ts:236", + "pc": [ + 1047, + 1048 + ] + }, + { + "teal": 731, + "source": "examples/reti/stakingPool.algo.ts:236", + "pc": [ + 1049 + ] + }, + { + "teal": 735, + "source": "examples/reti/stakingPool.algo.ts:238", + "pc": [ + 1050, + 1051 + ] + }, + { + "teal": 736, + "source": "examples/reti/stakingPool.algo.ts:238", + "pc": [ + 1052, + 1053, + 1054 + ] + }, + { + "teal": 742, + "source": "examples/reti/stakingPool.algo.ts:240", + "pc": [ + 1055, + 1056 + ] + }, + { + "teal": 743, + "source": "examples/reti/stakingPool.algo.ts:240", + "pc": [ + 1057, + 1058 + ] + }, + { + "teal": 744, + "source": "examples/reti/stakingPool.algo.ts:240", + "pc": [ + 1059 + ] + }, + { + "teal": 745, + "source": "examples/reti/stakingPool.algo.ts:240", + "pc": [ + 1060 + ] + }, + { + "teal": 746, + "source": "examples/reti/stakingPool.algo.ts:240", + "pc": [ + 1061, + 1062, + 1063 + ] + }, + { + "teal": 747, + "source": "examples/reti/stakingPool.algo.ts:240", + "pc": [ + 1064, + 1065 + ] + }, + { + "teal": 748, + "source": "examples/reti/stakingPool.algo.ts:240", + "pc": [ + 1066, + 1067, + 1068 + ] + }, + { + "teal": 749, + "source": "examples/reti/stakingPool.algo.ts:240", + "pc": [ + 1069, + 1070 + ] + }, + { + "teal": 750, + "source": "examples/reti/stakingPool.algo.ts:240", + "pc": [ + 1071 + ] + }, + { + "teal": 751, + "source": "examples/reti/stakingPool.algo.ts:240", + "pc": [ + 1072 + ] + }, + { + "teal": 754, + "source": "examples/reti/stakingPool.algo.ts:240", + "pc": [ + 1073, + 1074, + 1075 + ] + }, + { + "teal": 759, + "source": "examples/reti/stakingPool.algo.ts:241", + "pc": [ + 1076, + 1077 + ] + }, + { + "teal": 760, + "source": "examples/reti/stakingPool.algo.ts:241", + "pc": [ + 1078, + 1079 + ] + }, + { + "teal": 761, + "source": "examples/reti/stakingPool.algo.ts:241", + "pc": [ + 1080 + ] + }, + { + "teal": 762, + "source": "examples/reti/stakingPool.algo.ts:241", + "pc": [ + 1081, + 1082 + ] + }, + { + "teal": 769, + "source": "examples/reti/stakingPool.algo.ts:225", + "pc": [ + 1083, + 1084 + ] + }, + { + "teal": 770, + "source": "examples/reti/stakingPool.algo.ts:225", + "pc": [ + 1085, + 1086 + ] + }, + { + "teal": 771, + "source": "examples/reti/stakingPool.algo.ts:225", + "pc": [ + 1087 + ] + }, + { + "teal": 772, + "source": "examples/reti/stakingPool.algo.ts:225", + "pc": [ + 1088, + 1089 + ] + }, + { + "teal": 773, + "source": "examples/reti/stakingPool.algo.ts:225", + "pc": [ + 1090, + 1091, + 1092 + ] + }, + { + "teal": 779, + "source": "examples/reti/stakingPool.algo.ts:245", + "pc": [ + 1093, + 1094 + ] + }, + { + "teal": 780, + "source": "examples/reti/stakingPool.algo.ts:245", + "pc": [ + 1095, + 1096 + ] + }, + { + "teal": 781, + "source": "examples/reti/stakingPool.algo.ts:245", + "pc": [ + 1097 + ] + }, + { + "teal": 782, + "source": "examples/reti/stakingPool.algo.ts:245", + "pc": [ + 1098, + 1099, + 1100 + ] + }, + { + "teal": 786, + "source": "examples/reti/stakingPool.algo.ts:247", + "errorMessage": "Staking pool full", + "pc": [ + 1101 + ] + }, + { + "teal": 791, + "source": "examples/reti/stakingPool.algo.ts:252", + "pc": [ + 1102, + 1103 + ] + }, + { + "teal": 792, + "source": "examples/reti/stakingPool.algo.ts:252", + "pc": [ + 1104, + 1105 + ] + }, + { + "teal": 793, + "source": "examples/reti/stakingPool.algo.ts:252", + "pc": [ + 1106, + 1107, + 1108, + 1109, + 1110, + 1111, + 1112, + 1113, + 1114, + 1115, + 1116, + 1117, + 1118, + 1119, + 1120 + ] + }, + { + "teal": 794, + "source": "examples/reti/stakingPool.algo.ts:252", + "pc": [ + 1121 + ] + }, + { + "teal": 795, + "source": "examples/reti/stakingPool.algo.ts:252", + "pc": [ + 1122 + ] + }, + { + "teal": 798, + "source": "examples/reti/stakingPool.algo.ts:252", + "errorMessage": "must stake at least the minimum for this pool", + "pc": [ + 1123 + ] + }, + { + "teal": 802, + "source": "examples/reti/stakingPool.algo.ts:254", + "pc": [ + 1124, + 1125 + ] + }, + { + "teal": 803, + "source": "examples/reti/stakingPool.algo.ts:254", + "pc": [ + 1126, + 1127 + ] + }, + { + "teal": 804, + "source": "examples/reti/stakingPool.algo.ts:254", + "pc": [ + 1128 + ] + }, + { + "teal": 805, + "source": "examples/reti/stakingPool.algo.ts:254", + "pc": [ + 1129, + 1130 + ] + }, + { + "teal": 806, + "source": "examples/reti/stakingPool.algo.ts:254", + "pc": [ + 1131 + ] + }, + { + "teal": 807, + "source": "examples/reti/stakingPool.algo.ts:254", + "pc": [ + 1132, + 1133 + ] + }, + { + "teal": 808, + "source": "examples/reti/stakingPool.algo.ts:254", + "pc": [ + 1134 + ] + }, + { + "teal": 809, + "source": "examples/reti/stakingPool.algo.ts:254", + "pc": [ + 1135, + 1136 + ] + }, + { + "teal": 810, + "source": "examples/reti/stakingPool.algo.ts:254", + "pc": [ + 1137, + 1138, + 1139, + 1140, + 1141, + 1142, + 1143, + 1144, + 1145 + ] + }, + { + "teal": 811, + "source": "examples/reti/stakingPool.algo.ts:254", + "pc": [ + 1146, + 1147 + ] + }, + { + "teal": 812, + "source": "examples/reti/stakingPool.algo.ts:254", + "pc": [ + 1148 + ] + }, + { + "teal": 813, + "source": "examples/reti/stakingPool.algo.ts:254", + "pc": [ + 1149, + 1150 + ] + }, + { + "teal": 814, + "source": "examples/reti/stakingPool.algo.ts:254", + "pc": [ + 1151 + ] + }, + { + "teal": 815, + "source": "examples/reti/stakingPool.algo.ts:254", + "pc": [ + 1152 + ] + }, + { + "teal": 825, + "source": "examples/reti/stakingPool.algo.ts:255", + "pc": [ + 1153, + 1154 + ] + }, + { + "teal": 826, + "source": "examples/reti/stakingPool.algo.ts:255", + "pc": [ + 1155, + 1156 + ] + }, + { + "teal": 827, + "source": "examples/reti/stakingPool.algo.ts:255", + "pc": [ + 1157 + ] + }, + { + "teal": 828, + "source": "examples/reti/stakingPool.algo.ts:255", + "pc": [ + 1158, + 1159 + ] + }, + { + "teal": 829, + "source": "examples/reti/stakingPool.algo.ts:255", + "pc": [ + 1160 + ] + }, + { + "teal": 830, + "source": "examples/reti/stakingPool.algo.ts:256", + "pc": [ + 1161, + 1162 + ] + }, + { + "teal": 831, + "source": "examples/reti/stakingPool.algo.ts:257", + "pc": [ + 1163, + 1164 + ] + }, + { + "teal": 832, + "source": "examples/reti/stakingPool.algo.ts:257", + "pc": [ + 1165, + 1166 + ] + }, + { + "teal": 833, + "source": "examples/reti/stakingPool.algo.ts:257", + "pc": [ + 1167 + ] + }, + { + "teal": 834, + "source": "examples/reti/stakingPool.algo.ts:257", + "pc": [ + 1168 + ] + }, + { + "teal": 835, + "source": "examples/reti/stakingPool.algo.ts:258", + "pc": [ + 1169, + 1170, + 1171, + 1172, + 1173, + 1174, + 1175, + 1176, + 1177, + 1178 + ] + }, + { + "teal": 836, + "source": "examples/reti/stakingPool.algo.ts:258", + "pc": [ + 1179 + ] + }, + { + "teal": 837, + "source": "examples/reti/stakingPool.algo.ts:259", + "pc": [ + 1180, + 1181, + 1182, + 1183, + 1184, + 1185, + 1186, + 1187, + 1188, + 1189 + ] + }, + { + "teal": 838, + "source": "examples/reti/stakingPool.algo.ts:259", + "pc": [ + 1190 + ] + }, + { + "teal": 839, + "source": "examples/reti/stakingPool.algo.ts:260", + "pc": [ + 1191, + 1192 + ] + }, + { + "teal": 840, + "source": "examples/reti/stakingPool.algo.ts:260", + "pc": [ + 1193 + ] + }, + { + "teal": 841, + "source": "examples/reti/stakingPool.algo.ts:260", + "pc": [ + 1194 + ] + }, + { + "teal": 842, + "source": "examples/reti/stakingPool.algo.ts:255", + "pc": [ + 1195, + 1196, + 1197, + 1198, + 1199, + 1200, + 1201, + 1202, + 1203 + ] + }, + { + "teal": 843, + "source": "examples/reti/stakingPool.algo.ts:255", + "pc": [ + 1204, + 1205 + ] + }, + { + "teal": 844, + "source": "examples/reti/stakingPool.algo.ts:255", + "pc": [ + 1206 + ] + }, + { + "teal": 848, + "source": "examples/reti/stakingPool.algo.ts:262", + "pc": [ + 1207, + 1208, + 1209, + 1210, + 1211, + 1212, + 1213, + 1214, + 1215, + 1216, + 1217, + 1218 + ] + }, + { + "teal": 849, + "source": "examples/reti/stakingPool.algo.ts:262", + "pc": [ + 1219 + ] + }, + { + "teal": 850, + "source": "examples/reti/stakingPool.algo.ts:262", + "pc": [ + 1220, + 1221 + ] + }, + { + "teal": 851, + "source": "examples/reti/stakingPool.algo.ts:262", + "pc": [ + 1222 + ] + }, + { + "teal": 852, + "source": "examples/reti/stakingPool.algo.ts:262", + "pc": [ + 1223, + 1224, + 1225, + 1226, + 1227, + 1228, + 1229, + 1230, + 1231, + 1232, + 1233, + 1234 + ] + }, + { + "teal": 853, + "source": "examples/reti/stakingPool.algo.ts:262", + "pc": [ + 1235 + ] + }, + { + "teal": 854, + "source": "examples/reti/stakingPool.algo.ts:262", + "pc": [ + 1236 + ] + }, + { + "teal": 858, + "source": "examples/reti/stakingPool.algo.ts:263", + "pc": [ + 1237, + 1238 + ] + }, + { + "teal": 862, + "source": "examples/reti/stakingPool.algo.ts:191", + "pc": [ + 1239, + 1240 + ] + }, + { + "teal": 865, + "source": "examples/reti/stakingPool.algo.ts:191", + "pc": [ + 1241, + 1242 + ] + }, + { + "teal": 866, + "source": "examples/reti/stakingPool.algo.ts:191", + "pc": [ + 1243 + ] + }, + { + "teal": 871, + "source": "examples/reti/stakingPool.algo.ts:277", + "pc": [ + 1244, + 1245, + 1246 + ] + }, + { + "teal": 872, + "source": "examples/reti/stakingPool.algo.ts:277", + "pc": [ + 1247 + ] + }, + { + "teal": 875, + "source": "examples/reti/stakingPool.algo.ts:277", + "pc": [ + 1248, + 1249, + 1250 + ] + }, + { + "teal": 876, + "source": "examples/reti/stakingPool.algo.ts:277", + "pc": [ + 1251 + ] + }, + { + "teal": 877, + "source": "examples/reti/stakingPool.algo.ts:277", + "pc": [ + 1252 + ] + }, + { + "teal": 878, + "source": "examples/reti/stakingPool.algo.ts:277", + "pc": [ + 1253, + 1254 + ] + }, + { + "teal": 879, + "source": "examples/reti/stakingPool.algo.ts:277", + "pc": [ + 1255 + ] + }, + { + "teal": 882, + "source": "examples/reti/stakingPool.algo.ts:277", + "errorMessage": "argument 1 (staker) for removeStake must be a address", + "pc": [ + 1256 + ] + }, + { + "teal": 885, + "source": "examples/reti/stakingPool.algo.ts:277", + "pc": [ + 1257, + 1258, + 1259 + ] + }, + { + "teal": 886, + "source": "examples/reti/stakingPool.algo.ts:277", + "pc": [ + 1260, + 1261 + ] + }, + { + "teal": 887, + "source": "examples/reti/stakingPool.algo.ts:277", + "pc": [ + 1262 + ] + }, + { + "teal": 901, + "source": "examples/reti/stakingPool.algo.ts:277", + "pc": [ + 1263, + 1264, + 1265 + ] + }, + { + "teal": 904, + "source": "examples/reti/stakingPool.algo.ts:277", + "pc": [ + 1266, + 1267 + ] + }, + { + "teal": 905, + "source": "examples/reti/stakingPool.algo.ts:277", + "pc": [ + 1268, + 1269 + ] + }, + { + "teal": 910, + "source": "examples/reti/stakingPool.algo.ts:280", + "pc": [ + 1270, + 1271 + ] + }, + { + "teal": 911, + "source": "examples/reti/stakingPool.algo.ts:280", + "pc": [ + 1272, + 1273 + ] + }, + { + "teal": 912, + "source": "examples/reti/stakingPool.algo.ts:280", + "pc": [ + 1274 + ] + }, + { + "teal": 913, + "source": "examples/reti/stakingPool.algo.ts:280", + "pc": [ + 1275, + 1276, + 1277 + ] + }, + { + "teal": 921, + "source": "examples/reti/stakingPool.algo.ts:282", + "pc": [ + 1278, + 1279, + 1280 + ] + }, + { + "teal": 924, + "source": "examples/reti/stakingPool.algo.ts:281", + "errorMessage": "If staker is not sender in removeStake call, then sender MUST be owner or manager of validator", + "pc": [ + 1281 + ] + }, + { + "teal": 929, + "source": "examples/reti/stakingPool.algo.ts:287", + "pc": [ + 1282, + 1283, + 1284 + ] + }, + { + "teal": 933, + "source": "examples/reti/stakingPool.algo.ts:289", + "pc": [ + 1285, + 1286 + ] + }, + { + "teal": 934, + "source": "examples/reti/stakingPool.algo.ts:289", + "pc": [ + 1287, + 1288 + ] + }, + { + "teal": 939, + "source": "examples/reti/stakingPool.algo.ts:289", + "pc": [ + 1289, + 1290 + ] + }, + { + "teal": 940, + "source": "examples/reti/stakingPool.algo.ts:289", + "pc": [ + 1291, + 1292, + 1293 + ] + }, + { + "teal": 941, + "source": "examples/reti/stakingPool.algo.ts:289", + "pc": [ + 1294 + ] + }, + { + "teal": 942, + "source": "examples/reti/stakingPool.algo.ts:289", + "pc": [ + 1295, + 1296, + 1297 + ] + }, + { + "teal": 947, + "source": "examples/reti/stakingPool.algo.ts:290", + "pc": [ + 1298, + 1299 + ] + }, + { + "teal": 948, + "source": "examples/reti/stakingPool.algo.ts:290", + "pc": [ + 1300, + 1301, + 1302 + ] + }, + { + "teal": 949, + "source": "examples/reti/stakingPool.algo.ts:290", + "pc": [ + 1303 + ] + }, + { + "teal": 950, + "source": "examples/reti/stakingPool.algo.ts:290", + "pc": [ + 1304, + 1305, + 1306 + ] + }, + { + "teal": 955, + "source": "examples/reti/stakingPool.algo.ts:291", + "pc": [ + 1307 + ] + }, + { + "teal": 956, + "source": "examples/reti/stakingPool.algo.ts:291", + "pc": [ + 1308, + 1309 + ] + }, + { + "teal": 957, + "source": "examples/reti/stakingPool.algo.ts:291", + "pc": [ + 1310, + 1311 + ] + }, + { + "teal": 958, + "source": "examples/reti/stakingPool.algo.ts:291", + "pc": [ + 1312, + 1313 + ] + }, + { + "teal": 959, + "source": "examples/reti/stakingPool.algo.ts:291", + "pc": [ + 1314, + 1315 + ] + }, + { + "teal": 960, + "source": "examples/reti/stakingPool.algo.ts:291", + "pc": [ + 1316, + 1317, + 1318, + 1319, + 1320 + ] + }, + { + "teal": 961, + "source": "examples/reti/stakingPool.algo.ts:291", + "pc": [ + 1321 + ] + }, + { + "teal": 962, + "source": "examples/reti/stakingPool.algo.ts:291", + "pc": [ + 1322, + 1323 + ] + }, + { + "teal": 963, + "source": "examples/reti/stakingPool.algo.ts:291", + "pc": [ + 1324, + 1325 + ] + }, + { + "teal": 964, + "source": "examples/reti/stakingPool.algo.ts:291", + "pc": [ + 1326, + 1327 + ] + }, + { + "teal": 965, + "source": "examples/reti/stakingPool.algo.ts:291", + "pc": [ + 1328, + 1329 + ] + }, + { + "teal": 966, + "source": "examples/reti/stakingPool.algo.ts:291", + "pc": [ + 1330 + ] + }, + { + "teal": 971, + "source": "examples/reti/stakingPool.algo.ts:293", + "pc": [ + 1331, + 1332 + ] + }, + { + "teal": 972, + "source": "examples/reti/stakingPool.algo.ts:293", + "pc": [ + 1333, + 1334 + ] + }, + { + "teal": 973, + "source": "examples/reti/stakingPool.algo.ts:293", + "pc": [ + 1335 + ] + }, + { + "teal": 974, + "source": "examples/reti/stakingPool.algo.ts:293", + "pc": [ + 1336, + 1337 + ] + }, + { + "teal": 975, + "source": "examples/reti/stakingPool.algo.ts:293", + "pc": [ + 1338, + 1339, + 1340, + 1341, + 1342, + 1343, + 1344, + 1345, + 1346 + ] + }, + { + "teal": 976, + "source": "examples/reti/stakingPool.algo.ts:293", + "pc": [ + 1347, + 1348 + ] + }, + { + "teal": 977, + "source": "examples/reti/stakingPool.algo.ts:293", + "pc": [ + 1349 + ] + }, + { + "teal": 978, + "source": "examples/reti/stakingPool.algo.ts:293", + "pc": [ + 1350, + 1351 + ] + }, + { + "teal": 983, + "source": "examples/reti/stakingPool.algo.ts:294", + "pc": [ + 1352, + 1353 + ] + }, + { + "teal": 984, + "source": "examples/reti/stakingPool.algo.ts:294", + "pc": [ + 1354, + 1355, + 1356 + ] + }, + { + "teal": 985, + "source": "examples/reti/stakingPool.algo.ts:294", + "pc": [ + 1357, + 1358 + ] + }, + { + "teal": 986, + "source": "examples/reti/stakingPool.algo.ts:294", + "pc": [ + 1359 + ] + }, + { + "teal": 987, + "source": "examples/reti/stakingPool.algo.ts:294", + "pc": [ + 1360, + 1361, + 1362 + ] + }, + { + "teal": 993, + "source": "examples/reti/stakingPool.algo.ts:295", + "pc": [ + 1363, + 1364 + ] + }, + { + "teal": 994, + "source": "examples/reti/stakingPool.algo.ts:295", + "pc": [ + 1365, + 1366 + ] + }, + { + "teal": 995, + "source": "examples/reti/stakingPool.algo.ts:295", + "pc": [ + 1367 + ] + }, + { + "teal": 996, + "source": "examples/reti/stakingPool.algo.ts:295", + "pc": [ + 1368, + 1369, + 1370 + ] + }, + { + "teal": 1001, + "source": "examples/reti/stakingPool.algo.ts:297", + "pc": [ + 1371, + 1372 + ] + }, + { + "teal": 1002, + "source": "examples/reti/stakingPool.algo.ts:297", + "pc": [ + 1373, + 1374, + 1375 + ] + }, + { + "teal": 1003, + "source": "examples/reti/stakingPool.algo.ts:297", + "pc": [ + 1376 + ] + }, + { + "teal": 1004, + "source": "examples/reti/stakingPool.algo.ts:297", + "pc": [ + 1377, + 1378 + ] + }, + { + "teal": 1010, + "source": "examples/reti/stakingPool.algo.ts:299", + "pc": [ + 1379, + 1380 + ] + }, + { + "teal": 1011, + "source": "examples/reti/stakingPool.algo.ts:299", + "pc": [ + 1381, + 1382, + 1383 + ] + }, + { + "teal": 1012, + "source": "examples/reti/stakingPool.algo.ts:299", + "pc": [ + 1384 + ] + }, + { + "teal": 1013, + "source": "examples/reti/stakingPool.algo.ts:299", + "pc": [ + 1385, + 1386 + ] + }, + { + "teal": 1014, + "source": "examples/reti/stakingPool.algo.ts:299", + "pc": [ + 1387 + ] + }, + { + "teal": 1015, + "source": "examples/reti/stakingPool.algo.ts:299", + "pc": [ + 1388, + 1389, + 1390 + ] + }, + { + "teal": 1019, + "source": "examples/reti/stakingPool.algo.ts:300", + "errorMessage": "Insufficient balance", + "pc": [ + 1391 + ] + }, + { + "teal": 1024, + "source": "examples/reti/stakingPool.algo.ts:302", + "pc": [ + 1392, + 1393 + ] + }, + { + "teal": 1025, + "source": "examples/reti/stakingPool.algo.ts:302", + "pc": [ + 1394, + 1395 + ] + }, + { + "teal": 1026, + "source": "examples/reti/stakingPool.algo.ts:302", + "pc": [ + 1396, + 1397 + ] + }, + { + "teal": 1027, + "source": "examples/reti/stakingPool.algo.ts:302", + "pc": [ + 1398, + 1399, + 1400 + ] + }, + { + "teal": 1028, + "source": "examples/reti/stakingPool.algo.ts:302", + "pc": [ + 1401 + ] + }, + { + "teal": 1029, + "source": "examples/reti/stakingPool.algo.ts:302", + "pc": [ + 1402, + 1403 + ] + }, + { + "teal": 1030, + "source": "examples/reti/stakingPool.algo.ts:302", + "pc": [ + 1404 + ] + }, + { + "teal": 1031, + "source": "examples/reti/stakingPool.algo.ts:302", + "pc": [ + 1405 + ] + }, + { + "teal": 1032, + "source": "examples/reti/stakingPool.algo.ts:302", + "pc": [ + 1406 + ] + }, + { + "teal": 1033, + "source": "examples/reti/stakingPool.algo.ts:302", + "pc": [ + 1407, + 1408 + ] + }, + { + "teal": 1037, + "source": "examples/reti/stakingPool.algo.ts:303", + "pc": [ + 1409, + 1410, + 1411, + 1412, + 1413, + 1414, + 1415, + 1416 + ] + }, + { + "teal": 1038, + "source": "examples/reti/stakingPool.algo.ts:303", + "pc": [ + 1417 + ] + }, + { + "teal": 1039, + "source": "examples/reti/stakingPool.algo.ts:303", + "pc": [ + 1418, + 1419 + ] + }, + { + "teal": 1040, + "source": "examples/reti/stakingPool.algo.ts:303", + "pc": [ + 1420 + ] + }, + { + "teal": 1041, + "source": "examples/reti/stakingPool.algo.ts:303", + "pc": [ + 1421, + 1422, + 1423, + 1424, + 1425, + 1426, + 1427, + 1428 + ] + }, + { + "teal": 1042, + "source": "examples/reti/stakingPool.algo.ts:303", + "pc": [ + 1429 + ] + }, + { + "teal": 1043, + "source": "examples/reti/stakingPool.algo.ts:303", + "pc": [ + 1430 + ] + }, + { + "teal": 1047, + "source": "examples/reti/stakingPool.algo.ts:305", + "pc": [ + 1431, + 1432 + ] + }, + { + "teal": 1048, + "source": "examples/reti/stakingPool.algo.ts:305", + "pc": [ + 1433, + 1434 + ] + }, + { + "teal": 1053, + "source": "examples/reti/stakingPool.algo.ts:306", + "pc": [ + 1435, + 1436 + ] + }, + { + "teal": 1054, + "source": "examples/reti/stakingPool.algo.ts:306", + "pc": [ + 1437, + 1438, + 1439 + ] + }, + { + "teal": 1055, + "source": "examples/reti/stakingPool.algo.ts:306", + "pc": [ + 1440 + ] + }, + { + "teal": 1056, + "source": "examples/reti/stakingPool.algo.ts:306", + "pc": [ + 1441, + 1442 + ] + }, + { + "teal": 1057, + "source": "examples/reti/stakingPool.algo.ts:306", + "pc": [ + 1443 + ] + }, + { + "teal": 1058, + "source": "examples/reti/stakingPool.algo.ts:306", + "pc": [ + 1444, + 1445, + 1446 + ] + }, + { + "teal": 1064, + "source": "examples/reti/stakingPool.algo.ts:308", + "pc": [ + 1447, + 1448, + 1449, + 1450, + 1451, + 1452, + 1453, + 1454 + ] + }, + { + "teal": 1065, + "source": "examples/reti/stakingPool.algo.ts:308", + "pc": [ + 1455 + ] + }, + { + "teal": 1066, + "source": "examples/reti/stakingPool.algo.ts:308", + "pc": [ + 1456, + 1457 + ] + }, + { + "teal": 1067, + "source": "examples/reti/stakingPool.algo.ts:308", + "pc": [ + 1458 + ] + }, + { + "teal": 1068, + "source": "examples/reti/stakingPool.algo.ts:308", + "pc": [ + 1459, + 1460, + 1461 + ] + }, + { + "teal": 1076, + "source": "examples/reti/stakingPool.algo.ts:309", + "pc": [ + 1462 + ] + }, + { + "teal": 1077, + "source": "examples/reti/stakingPool.algo.ts:309", + "pc": [ + 1463, + 1464 + ] + }, + { + "teal": 1078, + "source": "examples/reti/stakingPool.algo.ts:309", + "pc": [ + 1465, + 1466 + ] + }, + { + "teal": 1079, + "source": "examples/reti/stakingPool.algo.ts:309", + "pc": [ + 1467, + 1468, + 1469, + 1470, + 1471, + 1472 + ] + }, + { + "teal": 1080, + "source": "examples/reti/stakingPool.algo.ts:309", + "pc": [ + 1473, + 1474 + ] + }, + { + "teal": 1084, + "source": "examples/reti/stakingPool.algo.ts:310", + "pc": [ + 1475, + 1476, + 1477, + 1478, + 1479, + 1480, + 1481, + 1482, + 1483, + 1484, + 1485, + 1486 + ] + }, + { + "teal": 1085, + "source": "examples/reti/stakingPool.algo.ts:310", + "pc": [ + 1487 + ] + }, + { + "teal": 1086, + "source": "examples/reti/stakingPool.algo.ts:310", + "pc": [ + 1488, + 1489 + ] + }, + { + "teal": 1090, + "source": "examples/reti/stakingPool.algo.ts:311", + "pc": [ + 1490, + 1491, + 1492, + 1493, + 1494, + 1495, + 1496, + 1497, + 1498, + 1499, + 1500, + 1501, + 1502 + ] + }, + { + "teal": 1091, + "source": "examples/reti/stakingPool.algo.ts:311", + "pc": [ + 1503 + ] + }, + { + "teal": 1092, + "source": "examples/reti/stakingPool.algo.ts:311", + "pc": [ + 1504 + ] + }, + { + "teal": 1093, + "source": "examples/reti/stakingPool.algo.ts:311", + "pc": [ + 1505, + 1506 + ] + }, + { + "teal": 1096, + "source": "examples/reti/stakingPool.algo.ts:309", + "pc": [ + 1507, + 1508 + ] + }, + { + "teal": 1097, + "source": "examples/reti/stakingPool.algo.ts:309", + "pc": [ + 1509, + 1510 + ] + }, + { + "teal": 1100, + "source": "examples/reti/stakingPool.algo.ts:309", + "pc": [ + 1511 + ] + }, + { + "teal": 1101, + "source": "examples/reti/stakingPool.algo.ts:309", + "pc": [ + 1512, + 1513 + ] + }, + { + "teal": 1102, + "source": "examples/reti/stakingPool.algo.ts:309", + "pc": [ + 1514, + 1515 + ] + }, + { + "teal": 1103, + "source": "examples/reti/stakingPool.algo.ts:309", + "pc": [ + 1516 + ] + }, + { + "teal": 1104, + "source": "examples/reti/stakingPool.algo.ts:309", + "pc": [ + 1517, + 1518 + ] + }, + { + "teal": 1105, + "source": "examples/reti/stakingPool.algo.ts:309", + "pc": [ + 1519, + 1520, + 1521 + ] + }, + { + "teal": 1106, + "source": "examples/reti/stakingPool.algo.ts:309", + "pc": [ + 1522, + 1523 + ] + }, + { + "teal": 1114, + "source": "examples/reti/stakingPool.algo.ts:317", + "pc": [ + 1524 + ] + }, + { + "teal": 1115, + "source": "examples/reti/stakingPool.algo.ts:317", + "pc": [ + 1525, + 1526 + ] + }, + { + "teal": 1116, + "source": "examples/reti/stakingPool.algo.ts:317", + "pc": [ + 1527, + 1528 + ] + }, + { + "teal": 1120, + "source": "examples/reti/stakingPool.algo.ts:318", + "pc": [ + 1529, + 1530 + ] + }, + { + "teal": 1121, + "source": "examples/reti/stakingPool.algo.ts:318", + "pc": [ + 1531, + 1532, + 1533 + ] + }, + { + "teal": 1122, + "source": "examples/reti/stakingPool.algo.ts:318", + "pc": [ + 1534 + ] + }, + { + "teal": 1123, + "source": "examples/reti/stakingPool.algo.ts:318", + "pc": [ + 1535, + 1536 + ] + }, + { + "teal": 1127, + "source": "examples/reti/stakingPool.algo.ts:319", + "pc": [ + 1537, + 1538 + ] + }, + { + "teal": 1128, + "source": "examples/reti/stakingPool.algo.ts:319", + "pc": [ + 1539, + 1540 + ] + }, + { + "teal": 1132, + "source": "examples/reti/stakingPool.algo.ts:320", + "pc": [ + 1541, + 1542 + ] + }, + { + "teal": 1133, + "source": "examples/reti/stakingPool.algo.ts:320", + "pc": [ + 1543, + 1544, + 1545 + ] + }, + { + "teal": 1134, + "source": "examples/reti/stakingPool.algo.ts:320", + "pc": [ + 1546 + ] + }, + { + "teal": 1135, + "source": "examples/reti/stakingPool.algo.ts:320", + "pc": [ + 1547, + 1548 + ] + }, + { + "teal": 1138, + "source": "examples/reti/stakingPool.algo.ts:317", + "pc": [ + 1549, + 1550 + ] + }, + { + "teal": 1139, + "source": "examples/reti/stakingPool.algo.ts:317", + "pc": [ + 1551, + 1552 + ] + }, + { + "teal": 1142, + "source": "examples/reti/stakingPool.algo.ts:317", + "pc": [ + 1553 + ] + }, + { + "teal": 1146, + "source": "examples/reti/stakingPool.algo.ts:322", + "pc": [ + 1554, + 1555 + ] + }, + { + "teal": 1147, + "source": "examples/reti/stakingPool.algo.ts:322", + "pc": [ + 1556, + 1557, + 1558 + ] + }, + { + "teal": 1148, + "source": "examples/reti/stakingPool.algo.ts:322", + "pc": [ + 1559 + ] + }, + { + "teal": 1149, + "source": "examples/reti/stakingPool.algo.ts:322", + "pc": [ + 1560, + 1561 + ] + }, + { + "teal": 1153, + "source": "examples/reti/stakingPool.algo.ts:323", + "pc": [ + 1562, + 1563 + ] + }, + { + "teal": 1154, + "source": "examples/reti/stakingPool.algo.ts:323", + "pc": [ + 1564, + 1565, + 1566, + 1567, + 1568, + 1569, + 1570, + 1571, + 1572, + 1573 + ] + }, + { + "teal": 1155, + "source": "examples/reti/stakingPool.algo.ts:323", + "pc": [ + 1574, + 1575 + ] + }, + { + "teal": 1156, + "source": "examples/reti/stakingPool.algo.ts:323", + "pc": [ + 1576, + 1577 + ] + }, + { + "teal": 1157, + "source": "examples/reti/stakingPool.algo.ts:308", + "pc": [ + 1578, + 1579, + 1580 + ] + }, + { + "teal": 1162, + "source": "examples/reti/stakingPool.algo.ts:328", + "pc": [ + 1581, + 1582 + ] + }, + { + "teal": 1163, + "source": "examples/reti/stakingPool.algo.ts:328", + "pc": [ + 1583, + 1584, + 1585 + ] + }, + { + "teal": 1164, + "source": "examples/reti/stakingPool.algo.ts:328", + "pc": [ + 1586 + ] + }, + { + "teal": 1165, + "source": "examples/reti/stakingPool.algo.ts:328", + "pc": [ + 1587, + 1588 + ] + }, + { + "teal": 1169, + "source": "examples/reti/stakingPool.algo.ts:329", + "pc": [ + 1589, + 1590 + ] + }, + { + "teal": 1170, + "source": "examples/reti/stakingPool.algo.ts:329", + "pc": [ + 1591, + 1592, + 1593, + 1594, + 1595, + 1596, + 1597, + 1598, + 1599, + 1600 + ] + }, + { + "teal": 1171, + "source": "examples/reti/stakingPool.algo.ts:329", + "pc": [ + 1601, + 1602 + ] + }, + { + "teal": 1172, + "source": "examples/reti/stakingPool.algo.ts:329", + "pc": [ + 1603, + 1604 + ] + }, + { + "teal": 1182, + "source": "examples/reti/stakingPool.algo.ts:335", + "pc": [ + 1605, + 1606 + ] + }, + { + "teal": 1183, + "source": "examples/reti/stakingPool.algo.ts:335", + "pc": [ + 1607, + 1608, + 1609 + ] + }, + { + "teal": 1184, + "source": "examples/reti/stakingPool.algo.ts:335", + "pc": [ + 1610 + ] + }, + { + "teal": 1185, + "source": "examples/reti/stakingPool.algo.ts:335", + "pc": [ + 1611, + 1612 + ] + }, + { + "teal": 1186, + "source": "examples/reti/stakingPool.algo.ts:335", + "pc": [ + 1613 + ] + }, + { + "teal": 1187, + "source": "examples/reti/stakingPool.algo.ts:335", + "pc": [ + 1614 + ] + }, + { + "teal": 1188, + "source": "examples/reti/stakingPool.algo.ts:335", + "pc": [ + 1615, + 1616, + 1617 + ] + }, + { + "teal": 1189, + "source": "examples/reti/stakingPool.algo.ts:335", + "pc": [ + 1618, + 1619 + ] + }, + { + "teal": 1190, + "source": "examples/reti/stakingPool.algo.ts:335", + "pc": [ + 1620, + 1621, + 1622 + ] + }, + { + "teal": 1191, + "source": "examples/reti/stakingPool.algo.ts:335", + "pc": [ + 1623 + ] + }, + { + "teal": 1192, + "source": "examples/reti/stakingPool.algo.ts:335", + "pc": [ + 1624, + 1625, + 1626, + 1627, + 1628, + 1629, + 1630, + 1631, + 1632, + 1633, + 1634, + 1635, + 1636, + 1637, + 1638 + ] + }, + { + "teal": 1193, + "source": "examples/reti/stakingPool.algo.ts:335", + "pc": [ + 1639 + ] + }, + { + "teal": 1194, + "source": "examples/reti/stakingPool.algo.ts:335", + "pc": [ + 1640 + ] + }, + { + "teal": 1195, + "source": "examples/reti/stakingPool.algo.ts:335", + "pc": [ + 1641 + ] + }, + { + "teal": 1199, + "source": "examples/reti/stakingPool.algo.ts:334", + "errorMessage": "cannot reduce balance below minimum allowed stake unless all is removed", + "pc": [ + 1642 + ] + }, + { + "teal": 1207, + "source": "examples/reti/stakingPool.algo.ts:342", + "pc": [ + 1643 + ] + }, + { + "teal": 1208, + "source": "examples/reti/stakingPool.algo.ts:342", + "pc": [ + 1644, + 1645 + ] + }, + { + "teal": 1209, + "source": "examples/reti/stakingPool.algo.ts:342", + "pc": [ + 1646, + 1647 + ] + }, + { + "teal": 1213, + "source": "examples/reti/stakingPool.algo.ts:343", + "pc": [ + 1648, + 1649 + ] + }, + { + "teal": 1214, + "source": "examples/reti/stakingPool.algo.ts:343", + "pc": [ + 1650, + 1651 + ] + }, + { + "teal": 1218, + "source": "examples/reti/stakingPool.algo.ts:344", + "pc": [ + 1652, + 1653 + ] + }, + { + "teal": 1219, + "source": "examples/reti/stakingPool.algo.ts:344", + "pc": [ + 1654, + 1655 + ] + }, + { + "teal": 1223, + "source": "examples/reti/stakingPool.algo.ts:345", + "pc": [ + 1656, + 1657, + 1658, + 1659, + 1660, + 1661, + 1662, + 1663, + 1664, + 1665 + ] + }, + { + "teal": 1224, + "source": "examples/reti/stakingPool.algo.ts:345", + "pc": [ + 1666, + 1667 + ] + }, + { + "teal": 1227, + "source": "examples/reti/stakingPool.algo.ts:342", + "pc": [ + 1668, + 1669 + ] + }, + { + "teal": 1228, + "source": "examples/reti/stakingPool.algo.ts:342", + "pc": [ + 1670, + 1671 + ] + }, + { + "teal": 1231, + "source": "examples/reti/stakingPool.algo.ts:342", + "pc": [ + 1672 + ] + }, + { + "teal": 1235, + "source": "examples/reti/stakingPool.algo.ts:347", + "pc": [ + 1673, + 1674 + ] + }, + { + "teal": 1236, + "source": "examples/reti/stakingPool.algo.ts:347", + "pc": [ + 1675, + 1676 + ] + }, + { + "teal": 1241, + "source": "examples/reti/stakingPool.algo.ts:348", + "pc": [ + 1677, + 1678 + ] + }, + { + "teal": 1242, + "source": "examples/reti/stakingPool.algo.ts:348", + "pc": [ + 1679, + 1680, + 1681 + ] + }, + { + "teal": 1243, + "source": "examples/reti/stakingPool.algo.ts:348", + "pc": [ + 1682 + ] + }, + { + "teal": 1244, + "source": "examples/reti/stakingPool.algo.ts:348", + "pc": [ + 1683, + 1684 + ] + }, + { + "teal": 1245, + "source": "examples/reti/stakingPool.algo.ts:348", + "pc": [ + 1685 + ] + }, + { + "teal": 1246, + "source": "examples/reti/stakingPool.algo.ts:348", + "pc": [ + 1686, + 1687, + 1688 + ] + }, + { + "teal": 1251, + "source": "examples/reti/stakingPool.algo.ts:350", + "pc": [ + 1689, + 1690, + 1691, + 1692, + 1693, + 1694, + 1695, + 1696, + 1697, + 1698, + 1699, + 1700 + ] + }, + { + "teal": 1252, + "source": "examples/reti/stakingPool.algo.ts:350", + "pc": [ + 1701 + ] + }, + { + "teal": 1253, + "source": "examples/reti/stakingPool.algo.ts:350", + "pc": [ + 1702, + 1703 + ] + }, + { + "teal": 1254, + "source": "examples/reti/stakingPool.algo.ts:350", + "pc": [ + 1704 + ] + }, + { + "teal": 1255, + "source": "examples/reti/stakingPool.algo.ts:350", + "pc": [ + 1705, + 1706, + 1707, + 1708, + 1709, + 1710, + 1711, + 1712, + 1713, + 1714, + 1715, + 1716 + ] + }, + { + "teal": 1256, + "source": "examples/reti/stakingPool.algo.ts:350", + "pc": [ + 1717 + ] + }, + { + "teal": 1257, + "source": "examples/reti/stakingPool.algo.ts:350", + "pc": [ + 1718 + ] + }, + { + "teal": 1261, + "source": "examples/reti/stakingPool.algo.ts:351", + "pc": [ + 1719, + 1720 + ] + }, + { + "teal": 1262, + "source": "examples/reti/stakingPool.algo.ts:351", + "pc": [ + 1721, + 1722 + ] + }, + { + "teal": 1263, + "source": "examples/reti/stakingPool.algo.ts:351", + "pc": [ + 1723, + 1724 + ] + }, + { + "teal": 1264, + "source": "examples/reti/stakingPool.algo.ts:351", + "pc": [ + 1725 + ] + }, + { + "teal": 1265, + "source": "examples/reti/stakingPool.algo.ts:351", + "pc": [ + 1726, + 1727 + ] + }, + { + "teal": 1269, + "source": "examples/reti/stakingPool.algo.ts:352", + "pc": [ + 1728, + 1729 + ] + }, + { + "teal": 1270, + "source": "examples/reti/stakingPool.algo.ts:352", + "pc": [ + 1730, + 1731, + 1732, + 1733, + 1734, + 1735, + 1736, + 1737, + 1738, + 1739 + ] + }, + { + "teal": 1271, + "source": "examples/reti/stakingPool.algo.ts:352", + "pc": [ + 1740, + 1741 + ] + }, + { + "teal": 1272, + "source": "examples/reti/stakingPool.algo.ts:352", + "pc": [ + 1742, + 1743 + ] + }, + { + "teal": 1276, + "source": "examples/reti/stakingPool.algo.ts:353", + "pc": [ + 1744, + 1745 + ] + }, + { + "teal": 1277, + "source": "examples/reti/stakingPool.algo.ts:353", + "pc": [ + 1746, + 1747, + 1748, + 1749, + 1750, + 1751, + 1752, + 1753, + 1754, + 1755 + ] + }, + { + "teal": 1278, + "source": "examples/reti/stakingPool.algo.ts:353", + "pc": [ + 1756, + 1757 + ] + }, + { + "teal": 1279, + "source": "examples/reti/stakingPool.algo.ts:353", + "pc": [ + 1758, + 1759 + ] + }, + { + "teal": 1283, + "source": "examples/reti/stakingPool.algo.ts:354", + "pc": [ + 1760, + 1761 + ] + }, + { + "teal": 1284, + "source": "examples/reti/stakingPool.algo.ts:354", + "pc": [ + 1762, + 1763 + ] + }, + { + "teal": 1289, + "source": "examples/reti/stakingPool.algo.ts:357", + "pc": [ + 1764, + 1765 + ] + }, + { + "teal": 1290, + "source": "examples/reti/stakingPool.algo.ts:357", + "pc": [ + 1766, + 1767 + ] + }, + { + "teal": 1291, + "source": "examples/reti/stakingPool.algo.ts:357", + "pc": [ + 1768 + ] + }, + { + "teal": 1292, + "source": "examples/reti/stakingPool.algo.ts:357", + "pc": [ + 1769, + 1770 + ] + }, + { + "teal": 1293, + "source": "examples/reti/stakingPool.algo.ts:357", + "pc": [ + 1771, + 1772, + 1773, + 1774, + 1775, + 1776, + 1777, + 1778, + 1779 + ] + }, + { + "teal": 1294, + "source": "examples/reti/stakingPool.algo.ts:357", + "pc": [ + 1780, + 1781 + ] + }, + { + "teal": 1295, + "source": "examples/reti/stakingPool.algo.ts:357", + "pc": [ + 1782 + ] + }, + { + "teal": 1299, + "source": "examples/reti/stakingPool.algo.ts:359", + "pc": [ + 1783, + 1784, + 1785, + 1786, + 1787, + 1788, + 1789, + 1790, + 1791, + 1792, + 1793, + 1794, + 1795, + 1796, + 1797 + ] + }, + { + "teal": 1300, + "source": "examples/reti/stakingPool.algo.ts:359", + "pc": [ + 1798 + ] + }, + { + "teal": 1301, + "source": "examples/reti/stakingPool.algo.ts:359", + "pc": [ + 1799, + 1800, + 1801, + 1802, + 1803, + 1804, + 1805, + 1806, + 1807, + 1808, + 1809, + 1810, + 1811, + 1812 + ] + }, + { + "teal": 1302, + "source": "examples/reti/stakingPool.algo.ts:359", + "pc": [ + 1813 + ] + }, + { + "teal": 1303, + "source": "examples/reti/stakingPool.algo.ts:359", + "pc": [ + 1814 + ] + }, + { + "teal": 1304, + "source": "examples/reti/stakingPool.algo.ts:359", + "pc": [ + 1815, + 1816 + ] + }, + { + "teal": 1305, + "source": "examples/reti/stakingPool.algo.ts:359", + "pc": [ + 1817 + ] + }, + { + "teal": 1306, + "source": "examples/reti/stakingPool.algo.ts:359", + "pc": [ + 1818, + 1819 + ] + }, + { + "teal": 1310, + "source": "examples/reti/stakingPool.algo.ts:360", + "pc": [ + 1820, + 1821 + ] + }, + { + "teal": 1311, + "source": "examples/reti/stakingPool.algo.ts:360", + "pc": [ + 1822 + ] + }, + { + "teal": 1312, + "source": "examples/reti/stakingPool.algo.ts:360", + "pc": [ + 1823, + 1824 + ] + }, + { + "teal": 1313, + "source": "examples/reti/stakingPool.algo.ts:360", + "pc": [ + 1825 + ] + }, + { + "teal": 1314, + "source": "examples/reti/stakingPool.algo.ts:360", + "pc": [ + 1826 + ] + }, + { + "teal": 1315, + "source": "examples/reti/stakingPool.algo.ts:360", + "pc": [ + 1827 + ] + }, + { + "teal": 1316, + "source": "examples/reti/stakingPool.algo.ts:360", + "pc": [ + 1828 + ] + }, + { + "teal": 1317, + "source": "examples/reti/stakingPool.algo.ts:360", + "pc": [ + 1829, + 1830, + 1831 + ] + }, + { + "teal": 1318, + "source": "examples/reti/stakingPool.algo.ts:360", + "pc": [ + 1832 + ] + }, + { + "teal": 1321, + "source": "examples/reti/stakingPool.algo.ts:360", + "errorMessage": "(amountToUnstake as uint128) * (roundsLeftInBin as uint128) overflowed 128 bits", + "pc": [ + 1833 + ] + }, + { + "teal": 1322, + "source": "examples/reti/stakingPool.algo.ts:360", + "pc": [ + 1834, + 1835, + 1836, + 1837, + 1838, + 1839, + 1840, + 1841, + 1842, + 1843, + 1844, + 1845, + 1846, + 1847, + 1848, + 1849, + 1850, + 1851 + ] + }, + { + "teal": 1323, + "source": "examples/reti/stakingPool.algo.ts:360", + "pc": [ + 1852 + ] + }, + { + "teal": 1324, + "source": "examples/reti/stakingPool.algo.ts:360", + "pc": [ + 1853 + ] + }, + { + "teal": 1325, + "source": "examples/reti/stakingPool.algo.ts:360", + "pc": [ + 1854 + ] + }, + { + "teal": 1326, + "source": "examples/reti/stakingPool.algo.ts:360", + "pc": [ + 1855 + ] + }, + { + "teal": 1327, + "source": "examples/reti/stakingPool.algo.ts:360", + "pc": [ + 1856, + 1857 + ] + }, + { + "teal": 1328, + "source": "examples/reti/stakingPool.algo.ts:360", + "pc": [ + 1858 + ] + }, + { + "teal": 1329, + "source": "examples/reti/stakingPool.algo.ts:360", + "pc": [ + 1859 + ] + }, + { + "teal": 1330, + "source": "examples/reti/stakingPool.algo.ts:360", + "pc": [ + 1860 + ] + }, + { + "teal": 1331, + "source": "examples/reti/stakingPool.algo.ts:360", + "pc": [ + 1861, + 1862 + ] + }, + { + "teal": 1335, + "source": "examples/reti/stakingPool.algo.ts:361", + "pc": [ + 1863, + 1864, + 1865, + 1866, + 1867, + 1868, + 1869, + 1870, + 1871, + 1872, + 1873, + 1874, + 1875, + 1876, + 1877, + 1878, + 1879, + 1880 + ] + }, + { + "teal": 1336, + "source": "examples/reti/stakingPool.algo.ts:361", + "pc": [ + 1881 + ] + }, + { + "teal": 1337, + "source": "examples/reti/stakingPool.algo.ts:361", + "pc": [ + 1882 + ] + }, + { + "teal": 1338, + "source": "examples/reti/stakingPool.algo.ts:361", + "pc": [ + 1883, + 1884 + ] + }, + { + "teal": 1339, + "source": "examples/reti/stakingPool.algo.ts:361", + "pc": [ + 1885 + ] + }, + { + "teal": 1340, + "source": "examples/reti/stakingPool.algo.ts:361", + "pc": [ + 1886 + ] + }, + { + "teal": 1341, + "source": "examples/reti/stakingPool.algo.ts:361", + "pc": [ + 1887 + ] + }, + { + "teal": 1342, + "source": "examples/reti/stakingPool.algo.ts:361", + "pc": [ + 1888, + 1889, + 1890 + ] + }, + { + "teal": 1343, + "source": "examples/reti/stakingPool.algo.ts:361", + "pc": [ + 1891 + ] + }, + { + "teal": 1346, + "source": "examples/reti/stakingPool.algo.ts:361", + "errorMessage": "this.stakeAccumulator.value - subtractAmount overflowed 128 bits", + "pc": [ + 1892 + ] + }, + { + "teal": 1347, + "source": "examples/reti/stakingPool.algo.ts:361", + "pc": [ + 1893, + 1894, + 1895, + 1896, + 1897, + 1898, + 1899, + 1900, + 1901, + 1902, + 1903, + 1904, + 1905, + 1906, + 1907, + 1908, + 1909, + 1910 + ] + }, + { + "teal": 1348, + "source": "examples/reti/stakingPool.algo.ts:361", + "pc": [ + 1911 + ] + }, + { + "teal": 1349, + "source": "examples/reti/stakingPool.algo.ts:361", + "pc": [ + 1912 + ] + }, + { + "teal": 1350, + "source": "examples/reti/stakingPool.algo.ts:361", + "pc": [ + 1913 + ] + }, + { + "teal": 1351, + "source": "examples/reti/stakingPool.algo.ts:361", + "pc": [ + 1914 + ] + }, + { + "teal": 1352, + "source": "examples/reti/stakingPool.algo.ts:361", + "pc": [ + 1915, + 1916 + ] + }, + { + "teal": 1353, + "source": "examples/reti/stakingPool.algo.ts:361", + "pc": [ + 1917 + ] + }, + { + "teal": 1354, + "source": "examples/reti/stakingPool.algo.ts:361", + "pc": [ + 1918 + ] + }, + { + "teal": 1355, + "source": "examples/reti/stakingPool.algo.ts:361", + "pc": [ + 1919 + ] + }, + { + "teal": 1356, + "source": "examples/reti/stakingPool.algo.ts:361", + "pc": [ + 1920 + ] + }, + { + "teal": 1369, + "source": "examples/reti/stakingPool.algo.ts:366", + "pc": [ + 1921 + ] + }, + { + "teal": 1370, + "source": "examples/reti/stakingPool.algo.ts:366", + "pc": [ + 1922, + 1923 + ] + }, + { + "teal": 1371, + "source": "examples/reti/stakingPool.algo.ts:366", + "pc": [ + 1924, + 1925 + ] + }, + { + "teal": 1372, + "source": "examples/reti/stakingPool.algo.ts:366", + "pc": [ + 1926, + 1927, + 1928, + 1929, + 1930, + 1931 + ] + }, + { + "teal": 1373, + "source": "examples/reti/stakingPool.algo.ts:366", + "pc": [ + 1932, + 1933 + ] + }, + { + "teal": 1377, + "source": "examples/reti/stakingPool.algo.ts:367", + "pc": [ + 1934, + 1935, + 1936, + 1937, + 1938, + 1939, + 1940, + 1941, + 1942, + 1943, + 1944, + 1945 + ] + }, + { + "teal": 1378, + "source": "examples/reti/stakingPool.algo.ts:367", + "pc": [ + 1946 + ] + }, + { + "teal": 1379, + "source": "examples/reti/stakingPool.algo.ts:367", + "pc": [ + 1947, + 1948 + ] + }, + { + "teal": 1389, + "source": "examples/reti/stakingPool.algo.ts:369", + "pc": [ + 1949, + 1950, + 1951, + 1952, + 1953, + 1954, + 1955, + 1956, + 1957, + 1958, + 1959, + 1960, + 1961 + ] + }, + { + "teal": 1390, + "source": "examples/reti/stakingPool.algo.ts:369", + "pc": [ + 1962 + ] + }, + { + "teal": 1391, + "source": "examples/reti/stakingPool.algo.ts:369", + "pc": [ + 1963 + ] + }, + { + "teal": 1392, + "source": "examples/reti/stakingPool.algo.ts:369", + "pc": [ + 1964, + 1965, + 1966, + 1967, + 1968, + 1969, + 1970, + 1971 + ] + }, + { + "teal": 1393, + "source": "examples/reti/stakingPool.algo.ts:369", + "pc": [ + 1972 + ] + }, + { + "teal": 1394, + "source": "examples/reti/stakingPool.algo.ts:369", + "pc": [ + 1973 + ] + }, + { + "teal": 1395, + "source": "examples/reti/stakingPool.algo.ts:369", + "pc": [ + 1974 + ] + }, + { + "teal": 1396, + "source": "examples/reti/stakingPool.algo.ts:369", + "pc": [ + 1975, + 1976, + 1977 + ] + }, + { + "teal": 1397, + "source": "examples/reti/stakingPool.algo.ts:369", + "pc": [ + 1978 + ] + }, + { + "teal": 1398, + "source": "examples/reti/stakingPool.algo.ts:369", + "pc": [ + 1979 + ] + }, + { + "teal": 1399, + "source": "examples/reti/stakingPool.algo.ts:369", + "pc": [ + 1980, + 1981 + ] + }, + { + "teal": 1400, + "source": "examples/reti/stakingPool.algo.ts:370", + "pc": [ + 1982, + 1983 + ] + }, + { + "teal": 1401, + "source": "examples/reti/stakingPool.algo.ts:370", + "pc": [ + 1984, + 1985 + ] + }, + { + "teal": 1402, + "source": "examples/reti/stakingPool.algo.ts:371", + "pc": [ + 1986, + 1987 + ] + }, + { + "teal": 1403, + "source": "examples/reti/stakingPool.algo.ts:371", + "pc": [ + 1988 + ] + }, + { + "teal": 1404, + "source": "examples/reti/stakingPool.algo.ts:371", + "pc": [ + 1989, + 1990 + ] + }, + { + "teal": 1405, + "source": "examples/reti/stakingPool.algo.ts:372", + "pc": [ + 1991, + 1992 + ] + }, + { + "teal": 1406, + "source": "examples/reti/stakingPool.algo.ts:372", + "pc": [ + 1993 + ] + }, + { + "teal": 1407, + "source": "examples/reti/stakingPool.algo.ts:372", + "pc": [ + 1994, + 1995 + ] + }, + { + "teal": 1408, + "source": "examples/reti/stakingPool.algo.ts:373", + "pc": [ + 1996, + 1997 + ] + }, + { + "teal": 1409, + "source": "examples/reti/stakingPool.algo.ts:373", + "pc": [ + 1998, + 1999, + 2000 + ] + }, + { + "teal": 1410, + "source": "examples/reti/stakingPool.algo.ts:373", + "pc": [ + 2001, + 2002 + ] + }, + { + "teal": 1411, + "source": "examples/reti/stakingPool.algo.ts:373", + "pc": [ + 2003, + 2004 + ] + }, + { + "teal": 1412, + "source": "examples/reti/stakingPool.algo.ts:373", + "pc": [ + 2005 + ] + }, + { + "teal": 1413, + "source": "examples/reti/stakingPool.algo.ts:373", + "pc": [ + 2006, + 2007 + ] + }, + { + "teal": 1416, + "source": "examples/reti/stakingPool.algo.ts:366", + "pc": [ + 2008, + 2009 + ] + }, + { + "teal": 1417, + "source": "examples/reti/stakingPool.algo.ts:366", + "pc": [ + 2010, + 2011 + ] + }, + { + "teal": 1420, + "source": "examples/reti/stakingPool.algo.ts:366", + "pc": [ + 2012 + ] + }, + { + "teal": 1424, + "source": "examples/reti/stakingPool.algo.ts:376", + "pc": [ + 2013 + ] + }, + { + "teal": 1431, + "source": "examples/reti/stakingPool.algo.ts:289", + "pc": [ + 2014, + 2015 + ] + }, + { + "teal": 1432, + "source": "examples/reti/stakingPool.algo.ts:289", + "pc": [ + 2016, + 2017 + ] + }, + { + "teal": 1433, + "source": "examples/reti/stakingPool.algo.ts:289", + "pc": [ + 2018 + ] + }, + { + "teal": 1434, + "source": "examples/reti/stakingPool.algo.ts:289", + "pc": [ + 2019, + 2020 + ] + }, + { + "teal": 1435, + "source": "examples/reti/stakingPool.algo.ts:289", + "pc": [ + 2021, + 2022, + 2023 + ] + }, + { + "teal": 1439, + "source": "examples/reti/stakingPool.algo.ts:379", + "errorMessage": "account not found", + "pc": [ + 2024 + ] + }, + { + "teal": 1440, + "source": "examples/reti/stakingPool.algo.ts:277", + "pc": [ + 2025 + ] + }, + { + "teal": 1445, + "source": "examples/reti/stakingPool.algo.ts:387", + "pc": [ + 2026, + 2027, + 2028 + ] + }, + { + "teal": 1446, + "source": "examples/reti/stakingPool.algo.ts:387", + "pc": [ + 2029, + 2030 + ] + }, + { + "teal": 1447, + "source": "examples/reti/stakingPool.algo.ts:387", + "pc": [ + 2031 + ] + }, + { + "teal": 1455, + "source": "examples/reti/stakingPool.algo.ts:387", + "pc": [ + 2032, + 2033, + 2034 + ] + }, + { + "teal": 1458, + "source": "examples/reti/stakingPool.algo.ts:387", + "pc": [ + 2035, + 2036 + ] + }, + { + "teal": 1459, + "source": "examples/reti/stakingPool.algo.ts:387", + "pc": [ + 2037, + 2038 + ] + }, + { + "teal": 1463, + "source": "examples/reti/stakingPool.algo.ts:391", + "pc": [ + 2039, + 2040 + ] + }, + { + "teal": 1464, + "source": "examples/reti/stakingPool.algo.ts:391", + "pc": [ + 2041, + 2042 + ] + }, + { + "teal": 1468, + "source": "examples/reti/stakingPool.algo.ts:393", + "pc": [ + 2043, + 2044 + ] + }, + { + "teal": 1469, + "source": "examples/reti/stakingPool.algo.ts:393", + "pc": [ + 2045, + 2046 + ] + }, + { + "teal": 1474, + "source": "examples/reti/stakingPool.algo.ts:393", + "pc": [ + 2047, + 2048 + ] + }, + { + "teal": 1475, + "source": "examples/reti/stakingPool.algo.ts:393", + "pc": [ + 2049, + 2050, + 2051 + ] + }, + { + "teal": 1476, + "source": "examples/reti/stakingPool.algo.ts:393", + "pc": [ + 2052 + ] + }, + { + "teal": 1477, + "source": "examples/reti/stakingPool.algo.ts:393", + "pc": [ + 2053, + 2054, + 2055 + ] + }, + { + "teal": 1482, + "source": "examples/reti/stakingPool.algo.ts:394", + "pc": [ + 2056, + 2057 + ] + }, + { + "teal": 1483, + "source": "examples/reti/stakingPool.algo.ts:394", + "pc": [ + 2058, + 2059, + 2060 + ] + }, + { + "teal": 1484, + "source": "examples/reti/stakingPool.algo.ts:394", + "pc": [ + 2061 + ] + }, + { + "teal": 1485, + "source": "examples/reti/stakingPool.algo.ts:394", + "pc": [ + 2062, + 2063, + 2064 + ] + }, + { + "teal": 1490, + "source": "examples/reti/stakingPool.algo.ts:395", + "pc": [ + 2065 + ] + }, + { + "teal": 1491, + "source": "examples/reti/stakingPool.algo.ts:395", + "pc": [ + 2066, + 2067 + ] + }, + { + "teal": 1492, + "source": "examples/reti/stakingPool.algo.ts:395", + "pc": [ + 2068, + 2069 + ] + }, + { + "teal": 1493, + "source": "examples/reti/stakingPool.algo.ts:395", + "pc": [ + 2070, + 2071 + ] + }, + { + "teal": 1494, + "source": "examples/reti/stakingPool.algo.ts:395", + "pc": [ + 2072, + 2073 + ] + }, + { + "teal": 1495, + "source": "examples/reti/stakingPool.algo.ts:395", + "pc": [ + 2074, + 2075, + 2076, + 2077, + 2078 + ] + }, + { + "teal": 1496, + "source": "examples/reti/stakingPool.algo.ts:395", + "pc": [ + 2079 + ] + }, + { + "teal": 1497, + "source": "examples/reti/stakingPool.algo.ts:395", + "pc": [ + 2080, + 2081 + ] + }, + { + "teal": 1498, + "source": "examples/reti/stakingPool.algo.ts:395", + "pc": [ + 2082, + 2083 + ] + }, + { + "teal": 1499, + "source": "examples/reti/stakingPool.algo.ts:395", + "pc": [ + 2084, + 2085 + ] + }, + { + "teal": 1500, + "source": "examples/reti/stakingPool.algo.ts:395", + "pc": [ + 2086, + 2087 + ] + }, + { + "teal": 1501, + "source": "examples/reti/stakingPool.algo.ts:395", + "pc": [ + 2088 + ] + }, + { + "teal": 1506, + "source": "examples/reti/stakingPool.algo.ts:397", + "pc": [ + 2089, + 2090 + ] + }, + { + "teal": 1507, + "source": "examples/reti/stakingPool.algo.ts:397", + "pc": [ + 2091, + 2092 + ] + }, + { + "teal": 1508, + "source": "examples/reti/stakingPool.algo.ts:397", + "pc": [ + 2093 + ] + }, + { + "teal": 1509, + "source": "examples/reti/stakingPool.algo.ts:397", + "pc": [ + 2094, + 2095 + ] + }, + { + "teal": 1510, + "source": "examples/reti/stakingPool.algo.ts:397", + "pc": [ + 2096, + 2097, + 2098, + 2099, + 2100, + 2101, + 2102, + 2103, + 2104 + ] + }, + { + "teal": 1511, + "source": "examples/reti/stakingPool.algo.ts:397", + "pc": [ + 2105, + 2106 + ] + }, + { + "teal": 1512, + "source": "examples/reti/stakingPool.algo.ts:397", + "pc": [ + 2107 + ] + }, + { + "teal": 1513, + "source": "examples/reti/stakingPool.algo.ts:397", + "pc": [ + 2108, + 2109 + ] + }, + { + "teal": 1518, + "source": "examples/reti/stakingPool.algo.ts:398", + "pc": [ + 2110, + 2111 + ] + }, + { + "teal": 1519, + "source": "examples/reti/stakingPool.algo.ts:398", + "pc": [ + 2112, + 2113, + 2114 + ] + }, + { + "teal": 1520, + "source": "examples/reti/stakingPool.algo.ts:398", + "pc": [ + 2115, + 2116 + ] + }, + { + "teal": 1521, + "source": "examples/reti/stakingPool.algo.ts:398", + "pc": [ + 2117 + ] + }, + { + "teal": 1522, + "source": "examples/reti/stakingPool.algo.ts:398", + "pc": [ + 2118, + 2119, + 2120 + ] + }, + { + "teal": 1528, + "source": "examples/reti/stakingPool.algo.ts:399", + "pc": [ + 2121, + 2122 + ] + }, + { + "teal": 1529, + "source": "examples/reti/stakingPool.algo.ts:399", + "pc": [ + 2123, + 2124, + 2125 + ] + }, + { + "teal": 1530, + "source": "examples/reti/stakingPool.algo.ts:399", + "pc": [ + 2126 + ] + }, + { + "teal": 1531, + "source": "examples/reti/stakingPool.algo.ts:399", + "pc": [ + 2127, + 2128 + ] + }, + { + "teal": 1532, + "source": "examples/reti/stakingPool.algo.ts:399", + "pc": [ + 2129 + ] + }, + { + "teal": 1533, + "source": "examples/reti/stakingPool.algo.ts:399", + "pc": [ + 2130, + 2131, + 2132 + ] + }, + { + "teal": 1538, + "source": "examples/reti/stakingPool.algo.ts:400", + "pc": [ + 2133 + ] + }, + { + "teal": 1543, + "source": "examples/reti/stakingPool.algo.ts:402", + "pc": [ + 2134, + 2135 + ] + }, + { + "teal": 1544, + "source": "examples/reti/stakingPool.algo.ts:402", + "pc": [ + 2136, + 2137 + ] + }, + { + "teal": 1549, + "source": "examples/reti/stakingPool.algo.ts:404", + "pc": [ + 2138, + 2139, + 2140, + 2141, + 2142, + 2143, + 2144, + 2145 + ] + }, + { + "teal": 1550, + "source": "examples/reti/stakingPool.algo.ts:404", + "pc": [ + 2146 + ] + }, + { + "teal": 1551, + "source": "examples/reti/stakingPool.algo.ts:404", + "pc": [ + 2147, + 2148 + ] + }, + { + "teal": 1552, + "source": "examples/reti/stakingPool.algo.ts:404", + "pc": [ + 2149 + ] + }, + { + "teal": 1553, + "source": "examples/reti/stakingPool.algo.ts:404", + "pc": [ + 2150, + 2151, + 2152 + ] + }, + { + "teal": 1561, + "source": "examples/reti/stakingPool.algo.ts:405", + "pc": [ + 2153 + ] + }, + { + "teal": 1562, + "source": "examples/reti/stakingPool.algo.ts:405", + "pc": [ + 2154, + 2155 + ] + }, + { + "teal": 1563, + "source": "examples/reti/stakingPool.algo.ts:405", + "pc": [ + 2156, + 2157 + ] + }, + { + "teal": 1564, + "source": "examples/reti/stakingPool.algo.ts:405", + "pc": [ + 2158, + 2159, + 2160, + 2161, + 2162, + 2163 + ] + }, + { + "teal": 1565, + "source": "examples/reti/stakingPool.algo.ts:405", + "pc": [ + 2164, + 2165 + ] + }, + { + "teal": 1569, + "source": "examples/reti/stakingPool.algo.ts:406", + "pc": [ + 2166, + 2167, + 2168, + 2169, + 2170, + 2171, + 2172, + 2173, + 2174, + 2175, + 2176, + 2177 + ] + }, + { + "teal": 1570, + "source": "examples/reti/stakingPool.algo.ts:406", + "pc": [ + 2178 + ] + }, + { + "teal": 1571, + "source": "examples/reti/stakingPool.algo.ts:406", + "pc": [ + 2179, + 2180 + ] + }, + { + "teal": 1575, + "source": "examples/reti/stakingPool.algo.ts:407", + "pc": [ + 2181, + 2182, + 2183, + 2184, + 2185, + 2186, + 2187, + 2188, + 2189, + 2190, + 2191, + 2192, + 2193 + ] + }, + { + "teal": 1576, + "source": "examples/reti/stakingPool.algo.ts:407", + "pc": [ + 2194 + ] + }, + { + "teal": 1577, + "source": "examples/reti/stakingPool.algo.ts:407", + "pc": [ + 2195 + ] + }, + { + "teal": 1578, + "source": "examples/reti/stakingPool.algo.ts:407", + "pc": [ + 2196, + 2197 + ] + }, + { + "teal": 1581, + "source": "examples/reti/stakingPool.algo.ts:405", + "pc": [ + 2198, + 2199 + ] + }, + { + "teal": 1582, + "source": "examples/reti/stakingPool.algo.ts:405", + "pc": [ + 2200, + 2201 + ] + }, + { + "teal": 1585, + "source": "examples/reti/stakingPool.algo.ts:405", + "pc": [ + 2202 + ] + }, + { + "teal": 1586, + "source": "examples/reti/stakingPool.algo.ts:405", + "pc": [ + 2203, + 2204 + ] + }, + { + "teal": 1587, + "source": "examples/reti/stakingPool.algo.ts:405", + "pc": [ + 2205, + 2206 + ] + }, + { + "teal": 1588, + "source": "examples/reti/stakingPool.algo.ts:405", + "pc": [ + 2207 + ] + }, + { + "teal": 1589, + "source": "examples/reti/stakingPool.algo.ts:405", + "pc": [ + 2208, + 2209 + ] + }, + { + "teal": 1590, + "source": "examples/reti/stakingPool.algo.ts:405", + "pc": [ + 2210, + 2211, + 2212 + ] + }, + { + "teal": 1591, + "source": "examples/reti/stakingPool.algo.ts:405", + "pc": [ + 2213, + 2214 + ] + }, + { + "teal": 1599, + "source": "examples/reti/stakingPool.algo.ts:412", + "pc": [ + 2215 + ] + }, + { + "teal": 1600, + "source": "examples/reti/stakingPool.algo.ts:412", + "pc": [ + 2216, + 2217 + ] + }, + { + "teal": 1601, + "source": "examples/reti/stakingPool.algo.ts:412", + "pc": [ + 2218, + 2219 + ] + }, + { + "teal": 1605, + "source": "examples/reti/stakingPool.algo.ts:413", + "pc": [ + 2220, + 2221 + ] + }, + { + "teal": 1606, + "source": "examples/reti/stakingPool.algo.ts:413", + "pc": [ + 2222, + 2223, + 2224 + ] + }, + { + "teal": 1607, + "source": "examples/reti/stakingPool.algo.ts:413", + "pc": [ + 2225 + ] + }, + { + "teal": 1608, + "source": "examples/reti/stakingPool.algo.ts:413", + "pc": [ + 2226, + 2227 + ] + }, + { + "teal": 1612, + "source": "examples/reti/stakingPool.algo.ts:414", + "pc": [ + 2228, + 2229 + ] + }, + { + "teal": 1613, + "source": "examples/reti/stakingPool.algo.ts:414", + "pc": [ + 2230, + 2231 + ] + }, + { + "teal": 1617, + "source": "examples/reti/stakingPool.algo.ts:415", + "pc": [ + 2232, + 2233 + ] + }, + { + "teal": 1618, + "source": "examples/reti/stakingPool.algo.ts:415", + "pc": [ + 2234, + 2235, + 2236 + ] + }, + { + "teal": 1619, + "source": "examples/reti/stakingPool.algo.ts:415", + "pc": [ + 2237 + ] + }, + { + "teal": 1620, + "source": "examples/reti/stakingPool.algo.ts:415", + "pc": [ + 2238, + 2239 + ] + }, + { + "teal": 1623, + "source": "examples/reti/stakingPool.algo.ts:412", + "pc": [ + 2240, + 2241 + ] + }, + { + "teal": 1624, + "source": "examples/reti/stakingPool.algo.ts:412", + "pc": [ + 2242, + 2243 + ] + }, + { + "teal": 1627, + "source": "examples/reti/stakingPool.algo.ts:412", + "pc": [ + 2244 + ] + }, + { + "teal": 1631, + "source": "examples/reti/stakingPool.algo.ts:417", + "pc": [ + 2245, + 2246 + ] + }, + { + "teal": 1632, + "source": "examples/reti/stakingPool.algo.ts:417", + "pc": [ + 2247, + 2248, + 2249 + ] + }, + { + "teal": 1633, + "source": "examples/reti/stakingPool.algo.ts:417", + "pc": [ + 2250 + ] + }, + { + "teal": 1634, + "source": "examples/reti/stakingPool.algo.ts:417", + "pc": [ + 2251, + 2252 + ] + }, + { + "teal": 1638, + "source": "examples/reti/stakingPool.algo.ts:418", + "pc": [ + 2253, + 2254 + ] + }, + { + "teal": 1639, + "source": "examples/reti/stakingPool.algo.ts:418", + "pc": [ + 2255, + 2256, + 2257, + 2258, + 2259, + 2260, + 2261, + 2262, + 2263, + 2264 + ] + }, + { + "teal": 1640, + "source": "examples/reti/stakingPool.algo.ts:418", + "pc": [ + 2265, + 2266 + ] + }, + { + "teal": 1641, + "source": "examples/reti/stakingPool.algo.ts:418", + "pc": [ + 2267, + 2268 + ] + }, + { + "teal": 1642, + "source": "examples/reti/stakingPool.algo.ts:404", + "pc": [ + 2269, + 2270, + 2271 + ] + }, + { + "teal": 1647, + "source": "examples/reti/stakingPool.algo.ts:423", + "pc": [ + 2272, + 2273 + ] + }, + { + "teal": 1648, + "source": "examples/reti/stakingPool.algo.ts:423", + "pc": [ + 2274, + 2275, + 2276 + ] + }, + { + "teal": 1649, + "source": "examples/reti/stakingPool.algo.ts:423", + "pc": [ + 2277 + ] + }, + { + "teal": 1650, + "source": "examples/reti/stakingPool.algo.ts:423", + "pc": [ + 2278, + 2279 + ] + }, + { + "teal": 1654, + "source": "examples/reti/stakingPool.algo.ts:424", + "pc": [ + 2280, + 2281 + ] + }, + { + "teal": 1655, + "source": "examples/reti/stakingPool.algo.ts:424", + "pc": [ + 2282, + 2283, + 2284, + 2285, + 2286, + 2287, + 2288, + 2289, + 2290, + 2291 + ] + }, + { + "teal": 1656, + "source": "examples/reti/stakingPool.algo.ts:424", + "pc": [ + 2292, + 2293 + ] + }, + { + "teal": 1657, + "source": "examples/reti/stakingPool.algo.ts:424", + "pc": [ + 2294, + 2295 + ] + }, + { + "teal": 1662, + "source": "examples/reti/stakingPool.algo.ts:428", + "pc": [ + 2296, + 2297 + ] + }, + { + "teal": 1663, + "source": "examples/reti/stakingPool.algo.ts:428", + "pc": [ + 2298, + 2299 + ] + }, + { + "teal": 1664, + "source": "examples/reti/stakingPool.algo.ts:428", + "pc": [ + 2300 + ] + }, + { + "teal": 1665, + "source": "examples/reti/stakingPool.algo.ts:428", + "pc": [ + 2301, + 2302 + ] + }, + { + "teal": 1666, + "source": "examples/reti/stakingPool.algo.ts:428", + "pc": [ + 2303, + 2304, + 2305, + 2306, + 2307, + 2308, + 2309, + 2310, + 2311 + ] + }, + { + "teal": 1667, + "source": "examples/reti/stakingPool.algo.ts:428", + "pc": [ + 2312, + 2313 + ] + }, + { + "teal": 1668, + "source": "examples/reti/stakingPool.algo.ts:428", + "pc": [ + 2314 + ] + }, + { + "teal": 1681, + "source": "examples/reti/stakingPool.algo.ts:433", + "pc": [ + 2315 + ] + }, + { + "teal": 1682, + "source": "examples/reti/stakingPool.algo.ts:433", + "pc": [ + 2316, + 2317 + ] + }, + { + "teal": 1683, + "source": "examples/reti/stakingPool.algo.ts:433", + "pc": [ + 2318, + 2319 + ] + }, + { + "teal": 1684, + "source": "examples/reti/stakingPool.algo.ts:433", + "pc": [ + 2320, + 2321, + 2322, + 2323, + 2324, + 2325 + ] + }, + { + "teal": 1685, + "source": "examples/reti/stakingPool.algo.ts:433", + "pc": [ + 2326, + 2327 + ] + }, + { + "teal": 1689, + "source": "examples/reti/stakingPool.algo.ts:434", + "pc": [ + 2328, + 2329, + 2330, + 2331, + 2332, + 2333, + 2334, + 2335, + 2336, + 2337, + 2338, + 2339 + ] + }, + { + "teal": 1690, + "source": "examples/reti/stakingPool.algo.ts:434", + "pc": [ + 2340 + ] + }, + { + "teal": 1691, + "source": "examples/reti/stakingPool.algo.ts:434", + "pc": [ + 2341, + 2342 + ] + }, + { + "teal": 1701, + "source": "examples/reti/stakingPool.algo.ts:436", + "pc": [ + 2343, + 2344, + 2345, + 2346, + 2347, + 2348, + 2349, + 2350, + 2351, + 2352, + 2353, + 2354, + 2355 + ] + }, + { + "teal": 1702, + "source": "examples/reti/stakingPool.algo.ts:436", + "pc": [ + 2356 + ] + }, + { + "teal": 1703, + "source": "examples/reti/stakingPool.algo.ts:436", + "pc": [ + 2357 + ] + }, + { + "teal": 1704, + "source": "examples/reti/stakingPool.algo.ts:436", + "pc": [ + 2358, + 2359, + 2360, + 2361, + 2362, + 2363, + 2364, + 2365 + ] + }, + { + "teal": 1705, + "source": "examples/reti/stakingPool.algo.ts:436", + "pc": [ + 2366 + ] + }, + { + "teal": 1706, + "source": "examples/reti/stakingPool.algo.ts:436", + "pc": [ + 2367 + ] + }, + { + "teal": 1707, + "source": "examples/reti/stakingPool.algo.ts:436", + "pc": [ + 2368 + ] + }, + { + "teal": 1708, + "source": "examples/reti/stakingPool.algo.ts:436", + "pc": [ + 2369, + 2370, + 2371 + ] + }, + { + "teal": 1709, + "source": "examples/reti/stakingPool.algo.ts:436", + "pc": [ + 2372 + ] + }, + { + "teal": 1710, + "source": "examples/reti/stakingPool.algo.ts:436", + "pc": [ + 2373 + ] + }, + { + "teal": 1711, + "source": "examples/reti/stakingPool.algo.ts:436", + "pc": [ + 2374, + 2375 + ] + }, + { + "teal": 1712, + "source": "examples/reti/stakingPool.algo.ts:437", + "pc": [ + 2376, + 2377 + ] + }, + { + "teal": 1713, + "source": "examples/reti/stakingPool.algo.ts:437", + "pc": [ + 2378, + 2379 + ] + }, + { + "teal": 1714, + "source": "examples/reti/stakingPool.algo.ts:438", + "pc": [ + 2380, + 2381, + 2382, + 2383, + 2384, + 2385, + 2386, + 2387, + 2388, + 2389 + ] + }, + { + "teal": 1715, + "source": "examples/reti/stakingPool.algo.ts:438", + "pc": [ + 2390, + 2391 + ] + }, + { + "teal": 1716, + "source": "examples/reti/stakingPool.algo.ts:439", + "pc": [ + 2392, + 2393 + ] + }, + { + "teal": 1717, + "source": "examples/reti/stakingPool.algo.ts:439", + "pc": [ + 2394 + ] + }, + { + "teal": 1718, + "source": "examples/reti/stakingPool.algo.ts:439", + "pc": [ + 2395, + 2396 + ] + }, + { + "teal": 1719, + "source": "examples/reti/stakingPool.algo.ts:440", + "pc": [ + 2397, + 2398 + ] + }, + { + "teal": 1720, + "source": "examples/reti/stakingPool.algo.ts:440", + "pc": [ + 2399, + 2400, + 2401 + ] + }, + { + "teal": 1721, + "source": "examples/reti/stakingPool.algo.ts:440", + "pc": [ + 2402, + 2403 + ] + }, + { + "teal": 1722, + "source": "examples/reti/stakingPool.algo.ts:440", + "pc": [ + 2404, + 2405 + ] + }, + { + "teal": 1723, + "source": "examples/reti/stakingPool.algo.ts:440", + "pc": [ + 2406 + ] + }, + { + "teal": 1724, + "source": "examples/reti/stakingPool.algo.ts:440", + "pc": [ + 2407, + 2408 + ] + }, + { + "teal": 1727, + "source": "examples/reti/stakingPool.algo.ts:433", + "pc": [ + 2409, + 2410 + ] + }, + { + "teal": 1728, + "source": "examples/reti/stakingPool.algo.ts:433", + "pc": [ + 2411, + 2412 + ] + }, + { + "teal": 1731, + "source": "examples/reti/stakingPool.algo.ts:433", + "pc": [ + 2413 + ] + }, + { + "teal": 1735, + "source": "examples/reti/stakingPool.algo.ts:443", + "pc": [ + 2414 + ] + }, + { + "teal": 1742, + "source": "examples/reti/stakingPool.algo.ts:393", + "pc": [ + 2415, + 2416 + ] + }, + { + "teal": 1743, + "source": "examples/reti/stakingPool.algo.ts:393", + "pc": [ + 2417, + 2418 + ] + }, + { + "teal": 1744, + "source": "examples/reti/stakingPool.algo.ts:393", + "pc": [ + 2419 + ] + }, + { + "teal": 1745, + "source": "examples/reti/stakingPool.algo.ts:393", + "pc": [ + 2420, + 2421 + ] + }, + { + "teal": 1746, + "source": "examples/reti/stakingPool.algo.ts:393", + "pc": [ + 2422, + 2423, + 2424 + ] + }, + { + "teal": 1750, + "source": "examples/reti/stakingPool.algo.ts:446", + "errorMessage": "account not found", + "pc": [ + 2425 + ] + }, + { + "teal": 1751, + "source": "examples/reti/stakingPool.algo.ts:387", + "pc": [ + 2426 + ] + }, + { + "teal": 1756, + "source": "examples/reti/stakingPool.algo.ts:457", + "pc": [ + 2427, + 2428, + 2429, + 2430, + 2431, + 2432 + ] + }, + { + "teal": 1759, + "source": "examples/reti/stakingPool.algo.ts:457", + "pc": [ + 2433, + 2434, + 2435 + ] + }, + { + "teal": 1760, + "source": "examples/reti/stakingPool.algo.ts:457", + "pc": [ + 2436 + ] + }, + { + "teal": 1761, + "source": "examples/reti/stakingPool.algo.ts:457", + "pc": [ + 2437 + ] + }, + { + "teal": 1762, + "source": "examples/reti/stakingPool.algo.ts:457", + "pc": [ + 2438, + 2439 + ] + }, + { + "teal": 1763, + "source": "examples/reti/stakingPool.algo.ts:457", + "pc": [ + 2440 + ] + }, + { + "teal": 1766, + "source": "examples/reti/stakingPool.algo.ts:457", + "errorMessage": "argument 0 (staker) for getStakerInfo must be a address", + "pc": [ + 2441 + ] + }, + { + "teal": 1769, + "source": "examples/reti/stakingPool.algo.ts:457", + "pc": [ + 2442, + 2443, + 2444 + ] + }, + { + "teal": 1770, + "source": "examples/reti/stakingPool.algo.ts:457", + "pc": [ + 2445 + ] + }, + { + "teal": 1771, + "source": "examples/reti/stakingPool.algo.ts:457", + "pc": [ + 2446 + ] + }, + { + "teal": 1772, + "source": "examples/reti/stakingPool.algo.ts:457", + "pc": [ + 2447, + 2448 + ] + }, + { + "teal": 1773, + "source": "examples/reti/stakingPool.algo.ts:457", + "pc": [ + 2449 + ] + }, + { + "teal": 1783, + "source": "examples/reti/stakingPool.algo.ts:457", + "pc": [ + 2450, + 2451, + 2452 + ] + }, + { + "teal": 1786, + "source": "examples/reti/stakingPool.algo.ts:457", + "pc": [ + 2453, + 2454 + ] + }, + { + "teal": 1790, + "source": "examples/reti/stakingPool.algo.ts:458", + "pc": [ + 2455, + 2456 + ] + }, + { + "teal": 1791, + "source": "examples/reti/stakingPool.algo.ts:458", + "pc": [ + 2457, + 2458 + ] + }, + { + "teal": 1796, + "source": "examples/reti/stakingPool.algo.ts:458", + "pc": [ + 2459, + 2460 + ] + }, + { + "teal": 1797, + "source": "examples/reti/stakingPool.algo.ts:458", + "pc": [ + 2461, + 2462, + 2463 + ] + }, + { + "teal": 1798, + "source": "examples/reti/stakingPool.algo.ts:458", + "pc": [ + 2464 + ] + }, + { + "teal": 1799, + "source": "examples/reti/stakingPool.algo.ts:458", + "pc": [ + 2465, + 2466, + 2467 + ] + }, + { + "teal": 1804, + "source": "examples/reti/stakingPool.algo.ts:459", + "pc": [ + 2468, + 2469 + ] + }, + { + "teal": 1805, + "source": "examples/reti/stakingPool.algo.ts:459", + "pc": [ + 2470, + 2471, + 2472 + ] + }, + { + "teal": 1806, + "source": "examples/reti/stakingPool.algo.ts:459", + "pc": [ + 2473 + ] + }, + { + "teal": 1807, + "source": "examples/reti/stakingPool.algo.ts:459", + "pc": [ + 2474, + 2475, + 2476 + ] + }, + { + "teal": 1812, + "source": "examples/reti/stakingPool.algo.ts:460", + "pc": [ + 2477 + ] + }, + { + "teal": 1813, + "source": "examples/reti/stakingPool.algo.ts:460", + "pc": [ + 2478, + 2479 + ] + }, + { + "teal": 1814, + "source": "examples/reti/stakingPool.algo.ts:460", + "pc": [ + 2480, + 2481 + ] + }, + { + "teal": 1815, + "source": "examples/reti/stakingPool.algo.ts:460", + "pc": [ + 2482, + 2483 + ] + }, + { + "teal": 1816, + "source": "examples/reti/stakingPool.algo.ts:460", + "pc": [ + 2484, + 2485 + ] + }, + { + "teal": 1817, + "source": "examples/reti/stakingPool.algo.ts:460", + "pc": [ + 2486, + 2487, + 2488, + 2489, + 2490 + ] + }, + { + "teal": 1818, + "source": "examples/reti/stakingPool.algo.ts:460", + "pc": [ + 2491 + ] + }, + { + "teal": 1819, + "source": "examples/reti/stakingPool.algo.ts:460", + "pc": [ + 2492, + 2493 + ] + }, + { + "teal": 1820, + "source": "examples/reti/stakingPool.algo.ts:460", + "pc": [ + 2494, + 2495 + ] + }, + { + "teal": 1821, + "source": "examples/reti/stakingPool.algo.ts:460", + "pc": [ + 2496, + 2497 + ] + }, + { + "teal": 1822, + "source": "examples/reti/stakingPool.algo.ts:460", + "pc": [ + 2498, + 2499 + ] + }, + { + "teal": 1823, + "source": "examples/reti/stakingPool.algo.ts:460", + "pc": [ + 2500 + ] + }, + { + "teal": 1829, + "source": "examples/reti/stakingPool.algo.ts:462", + "pc": [ + 2501, + 2502 + ] + }, + { + "teal": 1830, + "source": "examples/reti/stakingPool.algo.ts:462", + "pc": [ + 2503, + 2504 + ] + }, + { + "teal": 1831, + "source": "examples/reti/stakingPool.algo.ts:462", + "pc": [ + 2505 + ] + }, + { + "teal": 1832, + "source": "examples/reti/stakingPool.algo.ts:462", + "pc": [ + 2506, + 2507 + ] + }, + { + "teal": 1833, + "source": "examples/reti/stakingPool.algo.ts:462", + "pc": [ + 2508 + ] + }, + { + "teal": 1834, + "source": "examples/reti/stakingPool.algo.ts:462", + "pc": [ + 2509, + 2510 + ] + }, + { + "teal": 1835, + "source": "examples/reti/stakingPool.algo.ts:462", + "pc": [ + 2511, + 2512, + 2513, + 2514, + 2515, + 2516, + 2517, + 2518, + 2519 + ] + }, + { + "teal": 1836, + "source": "examples/reti/stakingPool.algo.ts:462", + "pc": [ + 2520, + 2521 + ] + }, + { + "teal": 1837, + "source": "examples/reti/stakingPool.algo.ts:462", + "pc": [ + 2522 + ] + }, + { + "teal": 1838, + "source": "examples/reti/stakingPool.algo.ts:462", + "pc": [ + 2523, + 2524 + ] + }, + { + "teal": 1839, + "source": "examples/reti/stakingPool.algo.ts:462", + "pc": [ + 2525 + ] + }, + { + "teal": 1840, + "source": "examples/reti/stakingPool.algo.ts:462", + "pc": [ + 2526, + 2527, + 2528 + ] + }, + { + "teal": 1845, + "source": "examples/reti/stakingPool.algo.ts:463", + "pc": [ + 2529, + 2530 + ] + }, + { + "teal": 1846, + "source": "examples/reti/stakingPool.algo.ts:463", + "pc": [ + 2531, + 2532 + ] + }, + { + "teal": 1847, + "source": "examples/reti/stakingPool.algo.ts:463", + "pc": [ + 2533 + ] + }, + { + "teal": 1848, + "source": "examples/reti/stakingPool.algo.ts:463", + "pc": [ + 2534, + 2535 + ] + }, + { + "teal": 1849, + "source": "examples/reti/stakingPool.algo.ts:463", + "pc": [ + 2536, + 2537, + 2538, + 2539, + 2540, + 2541, + 2542, + 2543, + 2544 + ] + }, + { + "teal": 1850, + "source": "examples/reti/stakingPool.algo.ts:463", + "pc": [ + 2545, + 2546 + ] + }, + { + "teal": 1851, + "source": "examples/reti/stakingPool.algo.ts:463", + "pc": [ + 2547 + ] + }, + { + "teal": 1852, + "source": "examples/reti/stakingPool.algo.ts:463", + "pc": [ + 2548, + 2549, + 2550 + ] + }, + { + "teal": 1859, + "source": "examples/reti/stakingPool.algo.ts:458", + "pc": [ + 2551, + 2552 + ] + }, + { + "teal": 1860, + "source": "examples/reti/stakingPool.algo.ts:458", + "pc": [ + 2553, + 2554 + ] + }, + { + "teal": 1861, + "source": "examples/reti/stakingPool.algo.ts:458", + "pc": [ + 2555 + ] + }, + { + "teal": 1862, + "source": "examples/reti/stakingPool.algo.ts:458", + "pc": [ + 2556, + 2557 + ] + }, + { + "teal": 1863, + "source": "examples/reti/stakingPool.algo.ts:458", + "pc": [ + 2558, + 2559, + 2560 + ] + }, + { + "teal": 1867, + "source": "examples/reti/stakingPool.algo.ts:466", + "errorMessage": "account not found", + "pc": [ + 2561 + ] + }, + { + "teal": 1871, + "source": "examples/reti/stakingPool.algo.ts:457", + "pc": [ + 2562, + 2563 + ] + }, + { + "teal": 1872, + "source": "examples/reti/stakingPool.algo.ts:457", + "pc": [ + 2564 + ] + }, + { + "teal": 1877, + "source": "examples/reti/stakingPool.algo.ts:479", + "pc": [ + 2565, + 2566, + 2567 + ] + }, + { + "teal": 1878, + "source": "examples/reti/stakingPool.algo.ts:479", + "pc": [ + 2568 + ] + }, + { + "teal": 1881, + "source": "examples/reti/stakingPool.algo.ts:479", + "pc": [ + 2569, + 2570, + 2571 + ] + }, + { + "teal": 1882, + "source": "examples/reti/stakingPool.algo.ts:479", + "pc": [ + 2572 + ] + }, + { + "teal": 1885, + "source": "examples/reti/stakingPool.algo.ts:479", + "pc": [ + 2573, + 2574, + 2575 + ] + }, + { + "teal": 1886, + "source": "examples/reti/stakingPool.algo.ts:479", + "pc": [ + 2576 + ] + }, + { + "teal": 1887, + "source": "examples/reti/stakingPool.algo.ts:479", + "pc": [ + 2577 + ] + }, + { + "teal": 1888, + "source": "examples/reti/stakingPool.algo.ts:479", + "pc": [ + 2578, + 2579 + ] + }, + { + "teal": 1889, + "source": "examples/reti/stakingPool.algo.ts:479", + "pc": [ + 2580 + ] + }, + { + "teal": 1892, + "source": "examples/reti/stakingPool.algo.ts:479", + "errorMessage": "argument 2 (staker) for payTokenReward must be a address", + "pc": [ + 2581 + ] + }, + { + "teal": 1895, + "source": "examples/reti/stakingPool.algo.ts:479", + "pc": [ + 2582, + 2583, + 2584 + ] + }, + { + "teal": 1896, + "source": "examples/reti/stakingPool.algo.ts:479", + "pc": [ + 2585, + 2586 + ] + }, + { + "teal": 1897, + "source": "examples/reti/stakingPool.algo.ts:479", + "pc": [ + 2587 + ] + }, + { + "teal": 1910, + "source": "examples/reti/stakingPool.algo.ts:479", + "pc": [ + 2588, + 2589, + 2590 + ] + }, + { + "teal": 1917, + "source": "examples/reti/stakingPool.algo.ts:482", + "pc": [ + 2591, + 2592 + ] + }, + { + "teal": 1918, + "source": "examples/reti/stakingPool.algo.ts:482", + "pc": [ + 2593, + 2594, + 2595, + 2596, + 2597, + 2598, + 2599, + 2600, + 2601, + 2602, + 2603, + 2604 + ] + }, + { + "teal": 1919, + "source": "examples/reti/stakingPool.algo.ts:482", + "pc": [ + 2605 + ] + }, + { + "teal": 1920, + "source": "examples/reti/stakingPool.algo.ts:482", + "pc": [ + 2606, + 2607 + ] + }, + { + "teal": 1921, + "source": "examples/reti/stakingPool.algo.ts:482", + "pc": [ + 2608 + ] + }, + { + "teal": 1922, + "source": "examples/reti/stakingPool.algo.ts:482", + "pc": [ + 2609 + ] + }, + { + "teal": 1925, + "source": "examples/reti/stakingPool.algo.ts:481", + "errorMessage": "this can only be called via the validator contract", + "pc": [ + 2610 + ] + }, + { + "teal": 1929, + "source": "examples/reti/stakingPool.algo.ts:485", + "pc": [ + 2611, + 2612, + 2613, + 2614, + 2615, + 2616, + 2617, + 2618 + ] + }, + { + "teal": 1930, + "source": "examples/reti/stakingPool.algo.ts:485", + "pc": [ + 2619 + ] + }, + { + "teal": 1931, + "source": "examples/reti/stakingPool.algo.ts:485", + "pc": [ + 2620, + 2621 + ] + }, + { + "teal": 1932, + "source": "examples/reti/stakingPool.algo.ts:485", + "pc": [ + 2622 + ] + }, + { + "teal": 1935, + "source": "examples/reti/stakingPool.algo.ts:485", + "errorMessage": "must be pool 1 in order to be called to pay out token rewards", + "pc": [ + 2623 + ] + }, + { + "teal": 1939, + "source": "examples/reti/stakingPool.algo.ts:486", + "pc": [ + 2624, + 2625 + ] + }, + { + "teal": 1940, + "source": "examples/reti/stakingPool.algo.ts:486", + "pc": [ + 2626, + 2627 + ] + }, + { + "teal": 1941, + "source": "examples/reti/stakingPool.algo.ts:486", + "pc": [ + 2628 + ] + }, + { + "teal": 1944, + "source": "examples/reti/stakingPool.algo.ts:486", + "errorMessage": "can only claim token rewards from validator that has them", + "pc": [ + 2629 + ] + }, + { + "teal": 1952, + "source": "examples/reti/stakingPool.algo.ts:489", + "pc": [ + 2630 + ] + }, + { + "teal": 1953, + "source": "examples/reti/stakingPool.algo.ts:489", + "pc": [ + 2631, + 2632 + ] + }, + { + "teal": 1954, + "source": "examples/reti/stakingPool.algo.ts:489", + "pc": [ + 2633, + 2634 + ] + }, + { + "teal": 1958, + "source": "examples/reti/stakingPool.algo.ts:490", + "pc": [ + 2635, + 2636 + ] + }, + { + "teal": 1959, + "source": "examples/reti/stakingPool.algo.ts:490", + "pc": [ + 2637, + 2638 + ] + }, + { + "teal": 1963, + "source": "examples/reti/stakingPool.algo.ts:491", + "pc": [ + 2639, + 2640 + ] + }, + { + "teal": 1964, + "source": "examples/reti/stakingPool.algo.ts:491", + "pc": [ + 2641, + 2642 + ] + }, + { + "teal": 1968, + "source": "examples/reti/stakingPool.algo.ts:492", + "pc": [ + 2643, + 2644 + ] + }, + { + "teal": 1969, + "source": "examples/reti/stakingPool.algo.ts:492", + "pc": [ + 2645, + 2646 + ] + }, + { + "teal": 1972, + "source": "examples/reti/stakingPool.algo.ts:489", + "pc": [ + 2647, + 2648 + ] + }, + { + "teal": 1973, + "source": "examples/reti/stakingPool.algo.ts:489", + "pc": [ + 2649, + 2650 + ] + }, + { + "teal": 1976, + "source": "examples/reti/stakingPool.algo.ts:489", + "pc": [ + 2651 + ] + }, + { + "teal": 1977, + "source": "examples/reti/stakingPool.algo.ts:479", + "pc": [ + 2652 + ] + }, + { + "teal": 1982, + "source": "examples/reti/stakingPool.algo.ts:505", + "pc": [ + 2653, + 2654, + 2655 + ] + }, + { + "teal": 1983, + "source": "examples/reti/stakingPool.algo.ts:505", + "pc": [ + 2656, + 2657, + 2658 + ] + }, + { + "teal": 1986, + "source": "examples/reti/stakingPool.algo.ts:505", + "pc": [ + 2659, + 2660, + 2661 + ] + }, + { + "teal": 1987, + "source": "examples/reti/stakingPool.algo.ts:505", + "pc": [ + 2662, + 2663 + ] + }, + { + "teal": 1988, + "source": "examples/reti/stakingPool.algo.ts:505", + "pc": [ + 2664 + ] + }, + { + "teal": 2000, + "source": "examples/reti/stakingPool.algo.ts:505", + "pc": [ + 2665, + 2666, + 2667 + ] + }, + { + "teal": 2004, + "source": "examples/reti/stakingPool.algo.ts:506", + "pc": [ + 2668, + 2669, + 2670 + ] + }, + { + "teal": 2007, + "source": "examples/reti/stakingPool.algo.ts:506", + "errorMessage": "can only be called by owner or manager of validator", + "pc": [ + 2671 + ] + }, + { + "teal": 2011, + "source": "examples/reti/stakingPool.algo.ts:507", + "pc": [ + 2672, + 2673, + 2674, + 2675, + 2676, + 2677, + 2678, + 2679, + 2680, + 2681 + ] + }, + { + "teal": 2012, + "source": "examples/reti/stakingPool.algo.ts:507", + "pc": [ + 2682, + 2683 + ] + }, + { + "teal": 2013, + "source": "examples/reti/stakingPool.algo.ts:507", + "pc": [ + 2684 + ] + }, + { + "teal": 2014, + "source": "examples/reti/stakingPool.algo.ts:505", + "pc": [ + 2685 + ] + }, + { + "teal": 2019, + "source": "examples/reti/stakingPool.algo.ts:518", + "pc": [ + 2686, + 2687, + 2688 + ] + }, + { + "teal": 2020, + "source": "examples/reti/stakingPool.algo.ts:518", + "pc": [ + 2689, + 2690 + ] + }, + { + "teal": 2021, + "source": "examples/reti/stakingPool.algo.ts:518", + "pc": [ + 2691 + ] + }, + { + "teal": 2032, + "source": "examples/reti/stakingPool.algo.ts:518", + "pc": [ + 2692, + 2693, + 2694 + ] + }, + { + "teal": 2035, + "source": "examples/reti/stakingPool.algo.ts:518", + "pc": [ + 2695, + 2696 + ] + }, + { + "teal": 2036, + "source": "examples/reti/stakingPool.algo.ts:518", + "pc": [ + 2697, + 2698 + ] + }, + { + "teal": 2043, + "source": "examples/reti/stakingPool.algo.ts:520", + "pc": [ + 2699 + ] + }, + { + "teal": 2044, + "source": "examples/reti/stakingPool.algo.ts:520", + "pc": [ + 2700, + 2701 + ] + }, + { + "teal": 2045, + "source": "examples/reti/stakingPool.algo.ts:520", + "pc": [ + 2702, + 2703 + ] + }, + { + "teal": 2046, + "source": "examples/reti/stakingPool.algo.ts:520", + "pc": [ + 2704, + 2705, + 2706, + 2707, + 2708, + 2709 + ] + }, + { + "teal": 2047, + "source": "examples/reti/stakingPool.algo.ts:520", + "pc": [ + 2710, + 2711 + ] + }, + { + "teal": 2051, + "source": "examples/reti/stakingPool.algo.ts:521", + "pc": [ + 2712, + 2713, + 2714, + 2715, + 2716, + 2717, + 2718, + 2719, + 2720, + 2721, + 2722, + 2723 + ] + }, + { + "teal": 2052, + "source": "examples/reti/stakingPool.algo.ts:521", + "pc": [ + 2724 + ] + }, + { + "teal": 2053, + "source": "examples/reti/stakingPool.algo.ts:521", + "pc": [ + 2725, + 2726 + ] + }, + { + "teal": 2057, + "source": "examples/reti/stakingPool.algo.ts:522", + "pc": [ + 2727, + 2728, + 2729, + 2730, + 2731, + 2732, + 2733, + 2734, + 2735, + 2736, + 2737, + 2738, + 2739 + ] + }, + { + "teal": 2058, + "source": "examples/reti/stakingPool.algo.ts:522", + "pc": [ + 2740 + ] + }, + { + "teal": 2059, + "source": "examples/reti/stakingPool.algo.ts:522", + "pc": [ + 2741 + ] + }, + { + "teal": 2060, + "source": "examples/reti/stakingPool.algo.ts:522", + "pc": [ + 2742, + 2743 + ] + }, + { + "teal": 2063, + "source": "examples/reti/stakingPool.algo.ts:520", + "pc": [ + 2744, + 2745 + ] + }, + { + "teal": 2064, + "source": "examples/reti/stakingPool.algo.ts:520", + "pc": [ + 2746, + 2747 + ] + }, + { + "teal": 2067, + "source": "examples/reti/stakingPool.algo.ts:520", + "pc": [ + 2748 + ] + }, + { + "teal": 2068, + "source": "examples/reti/stakingPool.algo.ts:520", + "pc": [ + 2749, + 2750 + ] + }, + { + "teal": 2069, + "source": "examples/reti/stakingPool.algo.ts:520", + "pc": [ + 2751, + 2752 + ] + }, + { + "teal": 2070, + "source": "examples/reti/stakingPool.algo.ts:520", + "pc": [ + 2753 + ] + }, + { + "teal": 2071, + "source": "examples/reti/stakingPool.algo.ts:520", + "pc": [ + 2754, + 2755 + ] + }, + { + "teal": 2072, + "source": "examples/reti/stakingPool.algo.ts:520", + "pc": [ + 2756, + 2757, + 2758 + ] + }, + { + "teal": 2073, + "source": "examples/reti/stakingPool.algo.ts:520", + "pc": [ + 2759, + 2760 + ] + }, + { + "teal": 2077, + "source": "examples/reti/stakingPool.algo.ts:529", + "pc": [ + 2761, + 2762 + ] + }, + { + "teal": 2078, + "source": "examples/reti/stakingPool.algo.ts:529", + "pc": [ + 2763, + 2764, + 2765 + ] + }, + { + "teal": 2079, + "source": "examples/reti/stakingPool.algo.ts:529", + "pc": [ + 2766 + ] + }, + { + "teal": 2080, + "source": "examples/reti/stakingPool.algo.ts:529", + "pc": [ + 2767, + 2768 + ] + }, + { + "teal": 2084, + "source": "examples/reti/stakingPool.algo.ts:530", + "pc": [ + 2769, + 2770 + ] + }, + { + "teal": 2085, + "source": "examples/reti/stakingPool.algo.ts:530", + "pc": [ + 2771, + 2772 + ] + }, + { + "teal": 2089, + "source": "examples/reti/stakingPool.algo.ts:531", + "pc": [ + 2773, + 2774 + ] + }, + { + "teal": 2090, + "source": "examples/reti/stakingPool.algo.ts:531", + "pc": [ + 2775, + 2776 + ] + }, + { + "teal": 2091, + "source": "examples/reti/stakingPool.algo.ts:531", + "pc": [ + 2777, + 2778 + ] + }, + { + "teal": 2092, + "source": "examples/reti/stakingPool.algo.ts:531", + "pc": [ + 2779 + ] + }, + { + "teal": 2093, + "source": "examples/reti/stakingPool.algo.ts:531", + "pc": [ + 2780 + ] + }, + { + "teal": 2094, + "source": "examples/reti/stakingPool.algo.ts:531", + "pc": [ + 2781, + 2782 + ] + }, + { + "teal": 2099, + "source": "examples/reti/stakingPool.algo.ts:534", + "pc": [ + 2783, + 2784, + 2785 + ] + }, + { + "teal": 2100, + "source": "examples/reti/stakingPool.algo.ts:534", + "pc": [ + 2786, + 2787, + 2788, + 2789, + 2790, + 2791, + 2792, + 2793, + 2794, + 2795, + 2796, + 2797 + ] + }, + { + "teal": 2101, + "source": "examples/reti/stakingPool.algo.ts:534", + "pc": [ + 2798 + ] + }, + { + "teal": 2102, + "source": "examples/reti/stakingPool.algo.ts:534", + "pc": [ + 2799 + ] + }, + { + "teal": 2103, + "source": "examples/reti/stakingPool.algo.ts:534", + "pc": [ + 2800 + ] + }, + { + "teal": 2104, + "source": "examples/reti/stakingPool.algo.ts:534", + "pc": [ + 2801, + 2802, + 2803 + ] + }, + { + "teal": 2109, + "source": "examples/reti/stakingPool.algo.ts:535", + "pc": [ + 2804, + 2805, + 2806, + 2807, + 2808, + 2809, + 2810, + 2811, + 2812, + 2813, + 2814, + 2815 + ] + }, + { + "teal": 2110, + "source": "examples/reti/stakingPool.algo.ts:535", + "pc": [ + 2816 + ] + }, + { + "teal": 2111, + "source": "examples/reti/stakingPool.algo.ts:535", + "pc": [ + 2817, + 2818, + 2819, + 2820, + 2821, + 2822, + 2823, + 2824, + 2825, + 2826, + 2827, + 2828 + ] + }, + { + "teal": 2112, + "source": "examples/reti/stakingPool.algo.ts:535", + "pc": [ + 2829 + ] + }, + { + "teal": 2113, + "source": "examples/reti/stakingPool.algo.ts:535", + "pc": [ + 2830, + 2831 + ] + }, + { + "teal": 2114, + "source": "examples/reti/stakingPool.algo.ts:535", + "pc": [ + 2832 + ] + }, + { + "teal": 2115, + "source": "examples/reti/stakingPool.algo.ts:535", + "pc": [ + 2833 + ] + }, + { + "teal": 2116, + "source": "examples/reti/stakingPool.algo.ts:535", + "pc": [ + 2834, + 2835 + ] + }, + { + "teal": 2120, + "source": "examples/reti/stakingPool.algo.ts:539", + "pc": [ + 2836, + 2837 + ] + }, + { + "teal": 2121, + "source": "examples/reti/stakingPool.algo.ts:539", + "pc": [ + 2838, + 2839 + ] + }, + { + "teal": 2122, + "source": "examples/reti/stakingPool.algo.ts:539", + "pc": [ + 2840 + ] + }, + { + "teal": 2125, + "source": "examples/reti/stakingPool.algo.ts:539", + "errorMessage": "can't call epochBalanceUpdate in same epoch as prior call", + "pc": [ + 2841 + ] + }, + { + "teal": 2130, + "source": "examples/reti/stakingPool.algo.ts:542", + "pc": [ + 2842, + 2843, + 2844 + ] + }, + { + "teal": 2134, + "source": "examples/reti/stakingPool.algo.ts:545", + "pc": [ + 2845, + 2846, + 2847, + 2848, + 2849, + 2850, + 2851, + 2852, + 2853, + 2854, + 2855, + 2856 + ] + }, + { + "teal": 2135, + "source": "examples/reti/stakingPool.algo.ts:545", + "pc": [ + 2857, + 2858 + ] + }, + { + "teal": 2136, + "source": "examples/reti/stakingPool.algo.ts:545", + "pc": [ + 2859 + ] + }, + { + "teal": 2140, + "source": "examples/reti/stakingPool.algo.ts:546", + "pc": [ + 2860, + 2861, + 2862, + 2863, + 2864, + 2865, + 2866, + 2867, + 2868, + 2869, + 2870, + 2871, + 2872 + ] + }, + { + "teal": 2141, + "source": "examples/reti/stakingPool.algo.ts:546", + "pc": [ + 2873 + ] + }, + { + "teal": 2142, + "source": "examples/reti/stakingPool.algo.ts:546", + "pc": [ + 2874, + 2875 + ] + }, + { + "teal": 2143, + "source": "examples/reti/stakingPool.algo.ts:546", + "pc": [ + 2876 + ] + }, + { + "teal": 2144, + "source": "examples/reti/stakingPool.algo.ts:546", + "pc": [ + 2877, + 2878, + 2879, + 2880, + 2881, + 2882, + 2883, + 2884, + 2885, + 2886, + 2887, + 2888, + 2889 + ] + }, + { + "teal": 2145, + "source": "examples/reti/stakingPool.algo.ts:546", + "pc": [ + 2890 + ] + }, + { + "teal": 2146, + "source": "examples/reti/stakingPool.algo.ts:546", + "pc": [ + 2891 + ] + }, + { + "teal": 2150, + "source": "examples/reti/stakingPool.algo.ts:551", + "pc": [ + 2892, + 2893 + ] + }, + { + "teal": 2151, + "source": "examples/reti/stakingPool.algo.ts:551", + "pc": [ + 2894, + 2895, + 2896 + ] + }, + { + "teal": 2152, + "source": "examples/reti/stakingPool.algo.ts:551", + "pc": [ + 2897 + ] + }, + { + "teal": 2153, + "source": "examples/reti/stakingPool.algo.ts:551", + "pc": [ + 2898, + 2899 + ] + }, + { + "teal": 2154, + "source": "examples/reti/stakingPool.algo.ts:551", + "pc": [ + 2900 + ] + }, + { + "teal": 2155, + "source": "examples/reti/stakingPool.algo.ts:551", + "pc": [ + 2901, + 2902 + ] + }, + { + "teal": 2159, + "source": "examples/reti/stakingPool.algo.ts:552", + "pc": [ + 2903, + 2904, + 2905 + ] + }, + { + "teal": 2160, + "source": "examples/reti/stakingPool.algo.ts:552", + "pc": [ + 2906, + 2907 + ] + }, + { + "teal": 2164, + "source": "examples/reti/stakingPool.algo.ts:553", + "pc": [ + 2908, + 2909 + ] + }, + { + "teal": 2165, + "source": "examples/reti/stakingPool.algo.ts:553", + "pc": [ + 2910, + 2911 + ] + }, + { + "teal": 2170, + "source": "examples/reti/stakingPool.algo.ts:558", + "pc": [ + 2912, + 2913 + ] + }, + { + "teal": 2171, + "source": "examples/reti/stakingPool.algo.ts:558", + "pc": [ + 2914, + 2915, + 2916 + ] + }, + { + "teal": 2177, + "source": "examples/reti/stakingPool.algo.ts:559", + "pc": [ + 2917, + 2918, + 2919, + 2920, + 2921, + 2922, + 2923, + 2924 + ] + }, + { + "teal": 2178, + "source": "examples/reti/stakingPool.algo.ts:559", + "pc": [ + 2925 + ] + }, + { + "teal": 2179, + "source": "examples/reti/stakingPool.algo.ts:559", + "pc": [ + 2926, + 2927 + ] + }, + { + "teal": 2180, + "source": "examples/reti/stakingPool.algo.ts:559", + "pc": [ + 2928 + ] + }, + { + "teal": 2181, + "source": "examples/reti/stakingPool.algo.ts:559", + "pc": [ + 2929, + 2930, + 2931 + ] + }, + { + "teal": 2189, + "source": "examples/reti/stakingPool.algo.ts:561", + "pc": [ + 2932 + ] + }, + { + "teal": 2190, + "source": "examples/reti/stakingPool.algo.ts:561", + "pc": [ + 2933, + 2934 + ] + }, + { + "teal": 2191, + "source": "examples/reti/stakingPool.algo.ts:561", + "pc": [ + 2935, + 2936 + ] + }, + { + "teal": 2192, + "source": "examples/reti/stakingPool.algo.ts:561", + "pc": [ + 2937, + 2938, + 2939, + 2940, + 2941, + 2942 + ] + }, + { + "teal": 2193, + "source": "examples/reti/stakingPool.algo.ts:561", + "pc": [ + 2943, + 2944 + ] + }, + { + "teal": 2197, + "source": "examples/reti/stakingPool.algo.ts:562", + "pc": [ + 2945, + 2946, + 2947, + 2948, + 2949, + 2950, + 2951, + 2952, + 2953, + 2954, + 2955, + 2956 + ] + }, + { + "teal": 2198, + "source": "examples/reti/stakingPool.algo.ts:562", + "pc": [ + 2957 + ] + }, + { + "teal": 2199, + "source": "examples/reti/stakingPool.algo.ts:562", + "pc": [ + 2958, + 2959 + ] + }, + { + "teal": 2203, + "source": "examples/reti/stakingPool.algo.ts:563", + "pc": [ + 2960, + 2961, + 2962, + 2963, + 2964, + 2965, + 2966, + 2967, + 2968, + 2969, + 2970, + 2971, + 2972 + ] + }, + { + "teal": 2204, + "source": "examples/reti/stakingPool.algo.ts:563", + "pc": [ + 2973 + ] + }, + { + "teal": 2205, + "source": "examples/reti/stakingPool.algo.ts:563", + "pc": [ + 2974 + ] + }, + { + "teal": 2206, + "source": "examples/reti/stakingPool.algo.ts:563", + "pc": [ + 2975, + 2976 + ] + }, + { + "teal": 2207, + "source": "examples/reti/stakingPool.algo.ts:563", + "pc": [ + 2977, + 2978, + 2979, + 2980, + 2981, + 2982, + 2983, + 2984, + 2985, + 2986 + ] + }, + { + "teal": 2208, + "source": "examples/reti/stakingPool.algo.ts:563", + "pc": [ + 2987, + 2988 + ] + }, + { + "teal": 2211, + "source": "examples/reti/stakingPool.algo.ts:561", + "pc": [ + 2989, + 2990 + ] + }, + { + "teal": 2212, + "source": "examples/reti/stakingPool.algo.ts:561", + "pc": [ + 2991, + 2992 + ] + }, + { + "teal": 2215, + "source": "examples/reti/stakingPool.algo.ts:561", + "pc": [ + 2993 + ] + }, + { + "teal": 2216, + "source": "examples/reti/stakingPool.algo.ts:561", + "pc": [ + 2994, + 2995 + ] + }, + { + "teal": 2217, + "source": "examples/reti/stakingPool.algo.ts:561", + "pc": [ + 2996, + 2997 + ] + }, + { + "teal": 2218, + "source": "examples/reti/stakingPool.algo.ts:561", + "pc": [ + 2998 + ] + }, + { + "teal": 2219, + "source": "examples/reti/stakingPool.algo.ts:561", + "pc": [ + 2999, + 3000 + ] + }, + { + "teal": 2220, + "source": "examples/reti/stakingPool.algo.ts:561", + "pc": [ + 3001, + 3002, + 3003 + ] + }, + { + "teal": 2221, + "source": "examples/reti/stakingPool.algo.ts:561", + "pc": [ + 3004 + ] + }, + { + "teal": 2222, + "source": "examples/reti/stakingPool.algo.ts:561", + "pc": [ + 3005, + 3006 + ] + }, + { + "teal": 2226, + "source": "examples/reti/stakingPool.algo.ts:565", + "pc": [ + 3007, + 3008 + ] + }, + { + "teal": 2227, + "source": "examples/reti/stakingPool.algo.ts:565", + "pc": [ + 3009, + 3010 + ] + }, + { + "teal": 2228, + "source": "examples/reti/stakingPool.algo.ts:565", + "pc": [ + 3011 + ] + }, + { + "teal": 2229, + "source": "examples/reti/stakingPool.algo.ts:565", + "pc": [ + 3012, + 3013 + ] + }, + { + "teal": 2235, + "source": "examples/reti/stakingPool.algo.ts:570", + "pc": [ + 3014, + 3015, + 3016, + 3017, + 3018, + 3019, + 3020, + 3021 + ] + }, + { + "teal": 2236, + "source": "examples/reti/stakingPool.algo.ts:570", + "pc": [ + 3022 + ] + }, + { + "teal": 2237, + "source": "examples/reti/stakingPool.algo.ts:570", + "pc": [ + 3023, + 3024 + ] + }, + { + "teal": 2238, + "source": "examples/reti/stakingPool.algo.ts:570", + "pc": [ + 3025 + ] + }, + { + "teal": 2239, + "source": "examples/reti/stakingPool.algo.ts:570", + "pc": [ + 3026, + 3027, + 3028 + ] + }, + { + "teal": 2247, + "source": "examples/reti/stakingPool.algo.ts:571", + "pc": [ + 3029 + ] + }, + { + "teal": 2248, + "source": "examples/reti/stakingPool.algo.ts:571", + "pc": [ + 3030, + 3031 + ] + }, + { + "teal": 2249, + "source": "examples/reti/stakingPool.algo.ts:571", + "pc": [ + 3032, + 3033 + ] + }, + { + "teal": 2250, + "source": "examples/reti/stakingPool.algo.ts:571", + "pc": [ + 3034, + 3035, + 3036, + 3037, + 3038, + 3039 + ] + }, + { + "teal": 2251, + "source": "examples/reti/stakingPool.algo.ts:571", + "pc": [ + 3040, + 3041 + ] + }, + { + "teal": 2255, + "source": "examples/reti/stakingPool.algo.ts:572", + "pc": [ + 3042, + 3043, + 3044, + 3045, + 3046, + 3047, + 3048, + 3049, + 3050, + 3051, + 3052, + 3053 + ] + }, + { + "teal": 2256, + "source": "examples/reti/stakingPool.algo.ts:572", + "pc": [ + 3054 + ] + }, + { + "teal": 2257, + "source": "examples/reti/stakingPool.algo.ts:572", + "pc": [ + 3055, + 3056 + ] + }, + { + "teal": 2261, + "source": "examples/reti/stakingPool.algo.ts:573", + "pc": [ + 3057, + 3058, + 3059, + 3060, + 3061, + 3062, + 3063, + 3064, + 3065, + 3066, + 3067, + 3068, + 3069 + ] + }, + { + "teal": 2262, + "source": "examples/reti/stakingPool.algo.ts:573", + "pc": [ + 3070 + ] + }, + { + "teal": 2263, + "source": "examples/reti/stakingPool.algo.ts:573", + "pc": [ + 3071 + ] + }, + { + "teal": 2264, + "source": "examples/reti/stakingPool.algo.ts:573", + "pc": [ + 3072, + 3073 + ] + }, + { + "teal": 2267, + "source": "examples/reti/stakingPool.algo.ts:571", + "pc": [ + 3074, + 3075 + ] + }, + { + "teal": 2268, + "source": "examples/reti/stakingPool.algo.ts:571", + "pc": [ + 3076, + 3077 + ] + }, + { + "teal": 2271, + "source": "examples/reti/stakingPool.algo.ts:571", + "pc": [ + 3078 + ] + }, + { + "teal": 2272, + "source": "examples/reti/stakingPool.algo.ts:571", + "pc": [ + 3079, + 3080 + ] + }, + { + "teal": 2273, + "source": "examples/reti/stakingPool.algo.ts:571", + "pc": [ + 3081, + 3082 + ] + }, + { + "teal": 2274, + "source": "examples/reti/stakingPool.algo.ts:571", + "pc": [ + 3083 + ] + }, + { + "teal": 2275, + "source": "examples/reti/stakingPool.algo.ts:571", + "pc": [ + 3084, + 3085 + ] + }, + { + "teal": 2276, + "source": "examples/reti/stakingPool.algo.ts:571", + "pc": [ + 3086, + 3087, + 3088 + ] + }, + { + "teal": 2277, + "source": "examples/reti/stakingPool.algo.ts:571", + "pc": [ + 3089, + 3090 + ] + }, + { + "teal": 2278, + "source": "examples/reti/stakingPool.algo.ts:570", + "pc": [ + 3091, + 3092, + 3093 + ] + }, + { + "teal": 2286, + "source": "examples/reti/stakingPool.algo.ts:577", + "pc": [ + 3094 + ] + }, + { + "teal": 2287, + "source": "examples/reti/stakingPool.algo.ts:577", + "pc": [ + 3095, + 3096 + ] + }, + { + "teal": 2288, + "source": "examples/reti/stakingPool.algo.ts:577", + "pc": [ + 3097, + 3098 + ] + }, + { + "teal": 2289, + "source": "examples/reti/stakingPool.algo.ts:577", + "pc": [ + 3099, + 3100, + 3101, + 3102, + 3103, + 3104 + ] + }, + { + "teal": 2290, + "source": "examples/reti/stakingPool.algo.ts:577", + "pc": [ + 3105, + 3106 + ] + }, + { + "teal": 2294, + "source": "examples/reti/stakingPool.algo.ts:578", + "pc": [ + 3107, + 3108 + ] + }, + { + "teal": 2295, + "source": "examples/reti/stakingPool.algo.ts:578", + "pc": [ + 3109, + 3110 + ] + }, + { + "teal": 2299, + "source": "examples/reti/stakingPool.algo.ts:579", + "pc": [ + 3111, + 3112, + 3113, + 3114, + 3115, + 3116, + 3117, + 3118, + 3119, + 3120, + 3121, + 3122, + 3123 + ] + }, + { + "teal": 2300, + "source": "examples/reti/stakingPool.algo.ts:579", + "pc": [ + 3124 + ] + }, + { + "teal": 2301, + "source": "examples/reti/stakingPool.algo.ts:579", + "pc": [ + 3125 + ] + }, + { + "teal": 2302, + "source": "examples/reti/stakingPool.algo.ts:579", + "pc": [ + 3126, + 3127, + 3128, + 3129, + 3130, + 3131, + 3132, + 3133 + ] + }, + { + "teal": 2303, + "source": "examples/reti/stakingPool.algo.ts:579", + "pc": [ + 3134 + ] + }, + { + "teal": 2304, + "source": "examples/reti/stakingPool.algo.ts:579", + "pc": [ + 3135 + ] + }, + { + "teal": 2305, + "source": "examples/reti/stakingPool.algo.ts:579", + "pc": [ + 3136 + ] + }, + { + "teal": 2306, + "source": "examples/reti/stakingPool.algo.ts:579", + "pc": [ + 3137, + 3138, + 3139 + ] + }, + { + "teal": 2307, + "source": "examples/reti/stakingPool.algo.ts:579", + "pc": [ + 3140 + ] + }, + { + "teal": 2308, + "source": "examples/reti/stakingPool.algo.ts:579", + "pc": [ + 3141 + ] + }, + { + "teal": 2309, + "source": "examples/reti/stakingPool.algo.ts:579", + "pc": [ + 3142, + 3143 + ] + }, + { + "teal": 2312, + "source": "examples/reti/stakingPool.algo.ts:577", + "pc": [ + 3144, + 3145 + ] + }, + { + "teal": 2313, + "source": "examples/reti/stakingPool.algo.ts:577", + "pc": [ + 3146, + 3147 + ] + }, + { + "teal": 2316, + "source": "examples/reti/stakingPool.algo.ts:577", + "pc": [ + 3148 + ] + }, + { + "teal": 2317, + "source": "examples/reti/stakingPool.algo.ts:577", + "pc": [ + 3149, + 3150 + ] + }, + { + "teal": 2318, + "source": "examples/reti/stakingPool.algo.ts:577", + "pc": [ + 3151, + 3152 + ] + }, + { + "teal": 2319, + "source": "examples/reti/stakingPool.algo.ts:577", + "pc": [ + 3153 + ] + }, + { + "teal": 2320, + "source": "examples/reti/stakingPool.algo.ts:577", + "pc": [ + 3154, + 3155 + ] + }, + { + "teal": 2321, + "source": "examples/reti/stakingPool.algo.ts:577", + "pc": [ + 3156, + 3157, + 3158 + ] + }, + { + "teal": 2322, + "source": "examples/reti/stakingPool.algo.ts:577", + "pc": [ + 3159, + 3160 + ] + }, + { + "teal": 2332, + "source": "examples/reti/stakingPool.algo.ts:586", + "pc": [ + 3161 + ] + }, + { + "teal": 2333, + "source": "examples/reti/stakingPool.algo.ts:586", + "pc": [ + 3162, + 3163 + ] + }, + { + "teal": 2334, + "source": "examples/reti/stakingPool.algo.ts:586", + "pc": [ + 3164, + 3165 + ] + }, + { + "teal": 2335, + "source": "examples/reti/stakingPool.algo.ts:586", + "pc": [ + 3166, + 3167, + 3168, + 3169, + 3170, + 3171 + ] + }, + { + "teal": 2336, + "source": "examples/reti/stakingPool.algo.ts:586", + "pc": [ + 3172, + 3173 + ] + }, + { + "teal": 2340, + "source": "examples/reti/stakingPool.algo.ts:587", + "pc": [ + 3174, + 3175, + 3176, + 3177, + 3178, + 3179, + 3180, + 3181, + 3182, + 3183, + 3184, + 3185 + ] + }, + { + "teal": 2341, + "source": "examples/reti/stakingPool.algo.ts:587", + "pc": [ + 3186 + ] + }, + { + "teal": 2342, + "source": "examples/reti/stakingPool.algo.ts:587", + "pc": [ + 3187, + 3188 + ] + }, + { + "teal": 2346, + "source": "examples/reti/stakingPool.algo.ts:588", + "pc": [ + 3189, + 3190, + 3191, + 3192, + 3193, + 3194, + 3195, + 3196, + 3197, + 3198, + 3199, + 3200, + 3201 + ] + }, + { + "teal": 2347, + "source": "examples/reti/stakingPool.algo.ts:588", + "pc": [ + 3202 + ] + }, + { + "teal": 2348, + "source": "examples/reti/stakingPool.algo.ts:588", + "pc": [ + 3203 + ] + }, + { + "teal": 2349, + "source": "examples/reti/stakingPool.algo.ts:588", + "pc": [ + 3204, + 3205 + ] + }, + { + "teal": 2352, + "source": "examples/reti/stakingPool.algo.ts:586", + "pc": [ + 3206, + 3207 + ] + }, + { + "teal": 2353, + "source": "examples/reti/stakingPool.algo.ts:586", + "pc": [ + 3208, + 3209 + ] + }, + { + "teal": 2356, + "source": "examples/reti/stakingPool.algo.ts:586", + "pc": [ + 3210 + ] + }, + { + "teal": 2357, + "source": "examples/reti/stakingPool.algo.ts:586", + "pc": [ + 3211, + 3212 + ] + }, + { + "teal": 2358, + "source": "examples/reti/stakingPool.algo.ts:586", + "pc": [ + 3213, + 3214 + ] + }, + { + "teal": 2359, + "source": "examples/reti/stakingPool.algo.ts:586", + "pc": [ + 3215 + ] + }, + { + "teal": 2360, + "source": "examples/reti/stakingPool.algo.ts:586", + "pc": [ + 3216, + 3217 + ] + }, + { + "teal": 2361, + "source": "examples/reti/stakingPool.algo.ts:586", + "pc": [ + 3218, + 3219, + 3220 + ] + }, + { + "teal": 2362, + "source": "examples/reti/stakingPool.algo.ts:586", + "pc": [ + 3221, + 3222 + ] + }, + { + "teal": 2366, + "source": "examples/reti/stakingPool.algo.ts:590", + "pc": [ + 3223, + 3224 + ] + }, + { + "teal": 2367, + "source": "examples/reti/stakingPool.algo.ts:590", + "pc": [ + 3225, + 3226, + 3227 + ] + }, + { + "teal": 2368, + "source": "examples/reti/stakingPool.algo.ts:590", + "pc": [ + 3228 + ] + }, + { + "teal": 2369, + "source": "examples/reti/stakingPool.algo.ts:590", + "pc": [ + 3229, + 3230 + ] + }, + { + "teal": 2373, + "source": "examples/reti/stakingPool.algo.ts:596", + "pc": [ + 3231, + 3232 + ] + }, + { + "teal": 2374, + "source": "examples/reti/stakingPool.algo.ts:596", + "pc": [ + 3233, + 3234 + ] + }, + { + "teal": 2375, + "source": "examples/reti/stakingPool.algo.ts:596", + "pc": [ + 3235 + ] + }, + { + "teal": 2376, + "source": "examples/reti/stakingPool.algo.ts:596", + "pc": [ + 3236, + 3237, + 3238, + 3239, + 3240, + 3241, + 3242, + 3243 + ] + }, + { + "teal": 2377, + "source": "examples/reti/stakingPool.algo.ts:596", + "pc": [ + 3244 + ] + }, + { + "teal": 2378, + "source": "examples/reti/stakingPool.algo.ts:596", + "pc": [ + 3245 + ] + }, + { + "teal": 2379, + "source": "examples/reti/stakingPool.algo.ts:596", + "pc": [ + 3246, + 3247 + ] + }, + { + "teal": 2380, + "source": "examples/reti/stakingPool.algo.ts:596", + "pc": [ + 3248, + 3249 + ] + }, + { + "teal": 2381, + "source": "examples/reti/stakingPool.algo.ts:596", + "pc": [ + 3250 + ] + }, + { + "teal": 2382, + "source": "examples/reti/stakingPool.algo.ts:596", + "pc": [ + 3251 + ] + }, + { + "teal": 2383, + "source": "examples/reti/stakingPool.algo.ts:596", + "pc": [ + 3252, + 3253 + ] + }, + { + "teal": 2387, + "source": "examples/reti/stakingPool.algo.ts:597", + "pc": [ + 3254, + 3255 + ] + }, + { + "teal": 2388, + "source": "examples/reti/stakingPool.algo.ts:597", + "pc": [ + 3256, + 3257 + ] + }, + { + "teal": 2392, + "source": "examples/reti/stakingPool.algo.ts:598", + "pc": [ + 3258, + 3259, + 3260 + ] + }, + { + "teal": 2393, + "source": "examples/reti/stakingPool.algo.ts:598", + "pc": [ + 3261, + 3262 + ] + }, + { + "teal": 2398, + "source": "examples/reti/stakingPool.algo.ts:606", + "pc": [ + 3263, + 3264 + ] + }, + { + "teal": 2399, + "source": "examples/reti/stakingPool.algo.ts:606", + "pc": [ + 3265, + 3266, + 3267 + ] + }, + { + "teal": 2400, + "source": "examples/reti/stakingPool.algo.ts:606", + "pc": [ + 3268 + ] + }, + { + "teal": 2401, + "source": "examples/reti/stakingPool.algo.ts:606", + "pc": [ + 3269, + 3270 + ] + }, + { + "teal": 2402, + "source": "examples/reti/stakingPool.algo.ts:606", + "pc": [ + 3271 + ] + }, + { + "teal": 2403, + "source": "examples/reti/stakingPool.algo.ts:606", + "pc": [ + 3272, + 3273, + 3274 + ] + }, + { + "teal": 2408, + "source": "examples/reti/stakingPool.algo.ts:607", + "pc": [ + 3275, + 3276 + ] + }, + { + "teal": 2409, + "source": "examples/reti/stakingPool.algo.ts:607", + "pc": [ + 3277, + 3278 + ] + }, + { + "teal": 2414, + "source": "examples/reti/stakingPool.algo.ts:613", + "pc": [ + 3279, + 3280 + ] + }, + { + "teal": 2415, + "source": "examples/reti/stakingPool.algo.ts:613", + "pc": [ + 3281, + 3282 + ] + }, + { + "teal": 2419, + "source": "examples/reti/stakingPool.algo.ts:614", + "pc": [ + 3283, + 3284 + ] + }, + { + "teal": 2420, + "source": "examples/reti/stakingPool.algo.ts:614", + "pc": [ + 3285, + 3286 + ] + }, + { + "teal": 2424, + "source": "examples/reti/stakingPool.algo.ts:615", + "pc": [ + 3287, + 3288 + ] + }, + { + "teal": 2425, + "source": "examples/reti/stakingPool.algo.ts:615", + "pc": [ + 3289, + 3290 + ] + }, + { + "teal": 2429, + "source": "examples/reti/stakingPool.algo.ts:616", + "pc": [ + 3291, + 3292 + ] + }, + { + "teal": 2430, + "source": "examples/reti/stakingPool.algo.ts:616", + "pc": [ + 3293, + 3294 + ] + }, + { + "teal": 2435, + "source": "examples/reti/stakingPool.algo.ts:617", + "pc": [ + 3295, + 3296 + ] + }, + { + "teal": 2436, + "source": "examples/reti/stakingPool.algo.ts:617", + "pc": [ + 3297, + 3298, + 3299 + ] + }, + { + "teal": 2442, + "source": "examples/reti/stakingPool.algo.ts:619", + "pc": [ + 3300, + 3301 + ] + }, + { + "teal": 2443, + "source": "examples/reti/stakingPool.algo.ts:619", + "pc": [ + 3302, + 3303 + ] + }, + { + "teal": 2444, + "source": "examples/reti/stakingPool.algo.ts:619", + "pc": [ + 3304, + 3305, + 3306 + ] + }, + { + "teal": 2445, + "source": "examples/reti/stakingPool.algo.ts:619", + "pc": [ + 3307 + ] + }, + { + "teal": 2446, + "source": "examples/reti/stakingPool.algo.ts:619", + "pc": [ + 3308, + 3309 + ] + }, + { + "teal": 2447, + "source": "examples/reti/stakingPool.algo.ts:619", + "pc": [ + 3310 + ] + }, + { + "teal": 2448, + "source": "examples/reti/stakingPool.algo.ts:619", + "pc": [ + 3311, + 3312 + ] + }, + { + "teal": 2449, + "source": "examples/reti/stakingPool.algo.ts:619", + "pc": [ + 3313 + ] + }, + { + "teal": 2450, + "source": "examples/reti/stakingPool.algo.ts:618", + "pc": [ + 3314, + 3315 + ] + }, + { + "teal": 2455, + "source": "examples/reti/stakingPool.algo.ts:623", + "pc": [ + 3316, + 3317 + ] + }, + { + "teal": 2456, + "source": "examples/reti/stakingPool.algo.ts:623", + "pc": [ + 3318, + 3319 + ] + }, + { + "teal": 2457, + "source": "examples/reti/stakingPool.algo.ts:623", + "pc": [ + 3320, + 3321, + 3322 + ] + }, + { + "teal": 2458, + "source": "examples/reti/stakingPool.algo.ts:623", + "pc": [ + 3323 + ] + }, + { + "teal": 2459, + "source": "examples/reti/stakingPool.algo.ts:623", + "pc": [ + 3324 + ] + }, + { + "teal": 2460, + "source": "examples/reti/stakingPool.algo.ts:623", + "pc": [ + 3325, + 3326, + 3327 + ] + }, + { + "teal": 2465, + "source": "examples/reti/stakingPool.algo.ts:629", + "pc": [ + 3328, + 3329 + ] + }, + { + "teal": 2466, + "source": "examples/reti/stakingPool.algo.ts:629", + "pc": [ + 3330, + 3331 + ] + }, + { + "teal": 2467, + "source": "examples/reti/stakingPool.algo.ts:629", + "pc": [ + 3332, + 3333, + 3334, + 3335, + 3336, + 3337, + 3338, + 3339 + ] + }, + { + "teal": 2468, + "source": "examples/reti/stakingPool.algo.ts:629", + "pc": [ + 3340 + ] + }, + { + "teal": 2469, + "source": "examples/reti/stakingPool.algo.ts:629", + "pc": [ + 3341, + 3342 + ] + }, + { + "teal": 2470, + "source": "examples/reti/stakingPool.algo.ts:629", + "pc": [ + 3343 + ] + }, + { + "teal": 2471, + "source": "examples/reti/stakingPool.algo.ts:629", + "pc": [ + 3344, + 3345 + ] + }, + { + "teal": 2472, + "source": "examples/reti/stakingPool.algo.ts:629", + "pc": [ + 3346 + ] + }, + { + "teal": 2473, + "source": "examples/reti/stakingPool.algo.ts:629", + "pc": [ + 3347 + ] + }, + { + "teal": 2474, + "source": "examples/reti/stakingPool.algo.ts:629", + "pc": [ + 3348, + 3349 + ] + }, + { + "teal": 2475, + "source": "examples/reti/stakingPool.algo.ts:629", + "pc": [ + 3350 + ] + }, + { + "teal": 2476, + "source": "examples/reti/stakingPool.algo.ts:629", + "pc": [ + 3351 + ] + }, + { + "teal": 2477, + "source": "examples/reti/stakingPool.algo.ts:629", + "pc": [ + 3352, + 3353 + ] + }, + { + "teal": 2481, + "source": "examples/reti/stakingPool.algo.ts:632", + "pc": [ + 3354, + 3355 + ] + }, + { + "teal": 2482, + "source": "examples/reti/stakingPool.algo.ts:632", + "pc": [ + 3356, + 3357, + 3358 + ] + }, + { + "teal": 2483, + "source": "examples/reti/stakingPool.algo.ts:632", + "pc": [ + 3359 + ] + }, + { + "teal": 2484, + "source": "examples/reti/stakingPool.algo.ts:632", + "pc": [ + 3360, + 3361 + ] + }, + { + "teal": 2485, + "source": "examples/reti/stakingPool.algo.ts:632", + "pc": [ + 3362 + ] + }, + { + "teal": 2486, + "source": "examples/reti/stakingPool.algo.ts:632", + "pc": [ + 3363, + 3364 + ] + }, + { + "teal": 2487, + "source": "examples/reti/stakingPool.algo.ts:632", + "pc": [ + 3365, + 3366, + 3367, + 3368 + ] + }, + { + "teal": 2488, + "source": "examples/reti/stakingPool.algo.ts:632", + "pc": [ + 3369 + ] + }, + { + "teal": 2489, + "source": "examples/reti/stakingPool.algo.ts:632", + "pc": [ + 3370 + ] + }, + { + "teal": 2490, + "source": "examples/reti/stakingPool.algo.ts:632", + "pc": [ + 3371 + ] + }, + { + "teal": 2491, + "source": "examples/reti/stakingPool.algo.ts:632", + "pc": [ + 3372 + ] + }, + { + "teal": 2492, + "source": "examples/reti/stakingPool.algo.ts:632", + "pc": [ + 3373 + ] + }, + { + "teal": 2495, + "source": "examples/reti/stakingPool.algo.ts:632", + "errorMessage": "wideRatio failed", + "pc": [ + 3374 + ] + }, + { + "teal": 2496, + "source": "examples/reti/stakingPool.algo.ts:632", + "pc": [ + 3375, + 3376 + ] + }, + { + "teal": 2504, + "source": "examples/reti/stakingPool.algo.ts:635", + "pc": [ + 3377, + 3378 + ] + }, + { + "teal": 2505, + "source": "examples/reti/stakingPool.algo.ts:635", + "pc": [ + 3379, + 3380 + ] + }, + { + "teal": 2506, + "source": "examples/reti/stakingPool.algo.ts:635", + "pc": [ + 3381 + ] + }, + { + "teal": 2507, + "source": "examples/reti/stakingPool.algo.ts:635", + "pc": [ + 3382, + 3383, + 3384 + ] + }, + { + "teal": 2513, + "source": "examples/reti/stakingPool.algo.ts:640", + "pc": [ + 3385, + 3386 + ] + }, + { + "teal": 2514, + "source": "examples/reti/stakingPool.algo.ts:640", + "pc": [ + 3387, + 3388, + 3389, + 3390 + ] + }, + { + "teal": 2515, + "source": "examples/reti/stakingPool.algo.ts:640", + "pc": [ + 3391 + ] + }, + { + "teal": 2516, + "source": "examples/reti/stakingPool.algo.ts:640", + "pc": [ + 3392, + 3393, + 3394 + ] + }, + { + "teal": 2521, + "source": "examples/reti/stakingPool.algo.ts:641", + "pc": [ + 3395, + 3396, + 3397, + 3398, + 3399, + 3400, + 3401, + 3402, + 3403, + 3404, + 3405, + 3406, + 3407, + 3408, + 3409, + 3410, + 3411, + 3412, + 3413, + 3414, + 3415, + 3416, + 3417, + 3418 + ] + }, + { + "teal": 2522, + "source": "examples/reti/stakingPool.algo.ts:641", + "pc": [ + 3419 + ] + }, + { + "teal": 2526, + "source": "examples/reti/stakingPool.algo.ts:642", + "pc": [ + 3420 + ] + }, + { + "teal": 2534, + "source": "examples/reti/stakingPool.algo.ts:646", + "pc": [ + 3421, + 3422 + ] + }, + { + "teal": 2535, + "source": "examples/reti/stakingPool.algo.ts:646", + "pc": [ + 3423, + 3424, + 3425 + ] + }, + { + "teal": 2540, + "source": "examples/reti/stakingPool.algo.ts:649", + "pc": [ + 3426, + 3427 + ] + }, + { + "teal": 2541, + "source": "examples/reti/stakingPool.algo.ts:649", + "pc": [ + 3428, + 3429 + ] + }, + { + "teal": 2542, + "source": "examples/reti/stakingPool.algo.ts:649", + "pc": [ + 3430 + ] + }, + { + "teal": 2543, + "source": "examples/reti/stakingPool.algo.ts:649", + "pc": [ + 3431, + 3432 + ] + }, + { + "teal": 2544, + "source": "examples/reti/stakingPool.algo.ts:649", + "pc": [ + 3433, + 3434 + ] + }, + { + "teal": 2545, + "source": "examples/reti/stakingPool.algo.ts:649", + "pc": [ + 3435, + 3436, + 3437 + ] + }, + { + "teal": 2546, + "source": "examples/reti/stakingPool.algo.ts:649", + "pc": [ + 3438 + ] + }, + { + "teal": 2547, + "source": "examples/reti/stakingPool.algo.ts:649", + "pc": [ + 3439 + ] + }, + { + "teal": 2548, + "source": "examples/reti/stakingPool.algo.ts:649", + "pc": [ + 3440 + ] + }, + { + "teal": 2549, + "source": "examples/reti/stakingPool.algo.ts:649", + "pc": [ + 3441 + ] + }, + { + "teal": 2550, + "source": "examples/reti/stakingPool.algo.ts:649", + "pc": [ + 3442 + ] + }, + { + "teal": 2551, + "source": "examples/reti/stakingPool.algo.ts:649", + "pc": [ + 3443 + ] + }, + { + "teal": 2554, + "source": "examples/reti/stakingPool.algo.ts:649", + "errorMessage": "wideRatio failed", + "pc": [ + 3444 + ] + }, + { + "teal": 2555, + "source": "examples/reti/stakingPool.algo.ts:649", + "pc": [ + 3445, + 3446 + ] + }, + { + "teal": 2559, + "source": "examples/reti/stakingPool.algo.ts:651", + "pc": [ + 3447, + 3448 + ] + }, + { + "teal": 2560, + "source": "examples/reti/stakingPool.algo.ts:651", + "pc": [ + 3449, + 3450 + ] + }, + { + "teal": 2561, + "source": "examples/reti/stakingPool.algo.ts:651", + "pc": [ + 3451 + ] + }, + { + "teal": 2562, + "source": "examples/reti/stakingPool.algo.ts:651", + "pc": [ + 3452, + 3453 + ] + }, + { + "teal": 2570, + "source": "examples/reti/stakingPool.algo.ts:652", + "pc": [ + 3454 + ] + }, + { + "teal": 2571, + "source": "examples/reti/stakingPool.algo.ts:652", + "pc": [ + 3455, + 3456 + ] + }, + { + "teal": 2572, + "source": "examples/reti/stakingPool.algo.ts:652", + "pc": [ + 3457, + 3458 + ] + }, + { + "teal": 2576, + "source": "examples/reti/stakingPool.algo.ts:653", + "pc": [ + 3459, + 3460 + ] + }, + { + "teal": 2577, + "source": "examples/reti/stakingPool.algo.ts:653", + "pc": [ + 3461, + 3462 + ] + }, + { + "teal": 2581, + "source": "examples/reti/stakingPool.algo.ts:654", + "pc": [ + 3463, + 3464, + 3465 + ] + }, + { + "teal": 2582, + "source": "examples/reti/stakingPool.algo.ts:654", + "pc": [ + 3466, + 3467 + ] + }, + { + "teal": 2586, + "source": "examples/reti/stakingPool.algo.ts:655", + "pc": [ + 3468, + 3469, + 3470, + 3471, + 3472, + 3473, + 3474, + 3475, + 3476, + 3477, + 3478, + 3479, + 3480, + 3481, + 3482, + 3483, + 3484, + 3485, + 3486, + 3487, + 3488, + 3489, + 3490, + 3491, + 3492, + 3493, + 3494, + 3495, + 3496, + 3497, + 3498, + 3499, + 3500, + 3501, + 3502, + 3503 + ] + }, + { + "teal": 2587, + "source": "examples/reti/stakingPool.algo.ts:655", + "pc": [ + 3504, + 3505 + ] + }, + { + "teal": 2590, + "source": "examples/reti/stakingPool.algo.ts:652", + "pc": [ + 3506, + 3507 + ] + }, + { + "teal": 2591, + "source": "examples/reti/stakingPool.algo.ts:652", + "pc": [ + 3508, + 3509 + ] + }, + { + "teal": 2594, + "source": "examples/reti/stakingPool.algo.ts:652", + "pc": [ + 3510 + ] + }, + { + "teal": 2598, + "source": "examples/reti/stakingPool.algo.ts:658", + "pc": [ + 3511, + 3512 + ] + }, + { + "teal": 2599, + "source": "examples/reti/stakingPool.algo.ts:658", + "pc": [ + 3513, + 3514 + ] + }, + { + "teal": 2600, + "source": "examples/reti/stakingPool.algo.ts:646", + "pc": [ + 3515, + 3516, + 3517 + ] + }, + { + "teal": 2605, + "source": "examples/reti/stakingPool.algo.ts:659", + "pc": [ + 3518, + 3519 + ] + }, + { + "teal": 2606, + "source": "examples/reti/stakingPool.algo.ts:659", + "pc": [ + 3520, + 3521, + 3522 + ] + }, + { + "teal": 2607, + "source": "examples/reti/stakingPool.algo.ts:659", + "pc": [ + 3523 + ] + }, + { + "teal": 2608, + "source": "examples/reti/stakingPool.algo.ts:659", + "pc": [ + 3524, + 3525 + ] + }, + { + "teal": 2609, + "source": "examples/reti/stakingPool.algo.ts:659", + "pc": [ + 3526 + ] + }, + { + "teal": 2610, + "source": "examples/reti/stakingPool.algo.ts:659", + "pc": [ + 3527, + 3528, + 3529 + ] + }, + { + "teal": 2618, + "source": "examples/reti/stakingPool.algo.ts:663", + "pc": [ + 3530, + 3531 + ] + }, + { + "teal": 2619, + "source": "examples/reti/stakingPool.algo.ts:663", + "pc": [ + 3532, + 3533 + ] + }, + { + "teal": 2620, + "source": "examples/reti/stakingPool.algo.ts:663", + "pc": [ + 3534, + 3535, + 3536 + ] + }, + { + "teal": 2621, + "source": "examples/reti/stakingPool.algo.ts:663", + "pc": [ + 3537 + ] + }, + { + "teal": 2622, + "source": "examples/reti/stakingPool.algo.ts:662", + "pc": [ + 3538 + ] + }, + { + "teal": 2623, + "source": "examples/reti/stakingPool.algo.ts:662", + "pc": [ + 3539, + 3540 + ] + }, + { + "teal": 2624, + "source": "examples/reti/stakingPool.algo.ts:664", + "pc": [ + 3541, + 3542, + 3543, + 3544 + ] + }, + { + "teal": 2625, + "source": "examples/reti/stakingPool.algo.ts:662", + "pc": [ + 3545 + ] + }, + { + "teal": 2626, + "source": "examples/reti/stakingPool.algo.ts:662", + "pc": [ + 3546 + ] + }, + { + "teal": 2627, + "source": "examples/reti/stakingPool.algo.ts:662", + "pc": [ + 3547 + ] + }, + { + "teal": 2628, + "source": "examples/reti/stakingPool.algo.ts:662", + "pc": [ + 3548 + ] + }, + { + "teal": 2629, + "source": "examples/reti/stakingPool.algo.ts:662", + "pc": [ + 3549 + ] + }, + { + "teal": 2632, + "source": "examples/reti/stakingPool.algo.ts:662", + "errorMessage": "wideRatio failed", + "pc": [ + 3550 + ] + }, + { + "teal": 2633, + "source": "examples/reti/stakingPool.algo.ts:662", + "pc": [ + 3551, + 3552 + ] + }, + { + "teal": 2637, + "source": "examples/reti/stakingPool.algo.ts:668", + "pc": [ + 3553, + 3554 + ] + }, + { + "teal": 2638, + "source": "examples/reti/stakingPool.algo.ts:668", + "pc": [ + 3555, + 3556 + ] + }, + { + "teal": 2639, + "source": "examples/reti/stakingPool.algo.ts:668", + "pc": [ + 3557 + ] + }, + { + "teal": 2640, + "source": "examples/reti/stakingPool.algo.ts:668", + "pc": [ + 3558, + 3559 + ] + }, + { + "teal": 2645, + "source": "examples/reti/stakingPool.algo.ts:675", + "pc": [ + 3560, + 3561 + ] + }, + { + "teal": 2646, + "source": "examples/reti/stakingPool.algo.ts:675", + "pc": [ + 3562, + 3563 + ] + }, + { + "teal": 2647, + "source": "examples/reti/stakingPool.algo.ts:675", + "pc": [ + 3564 + ] + }, + { + "teal": 2648, + "source": "examples/reti/stakingPool.algo.ts:675", + "pc": [ + 3565, + 3566, + 3567 + ] + }, + { + "teal": 2653, + "source": "examples/reti/stakingPool.algo.ts:678", + "pc": [ + 3568, + 3569 + ] + }, + { + "teal": 2654, + "source": "examples/reti/stakingPool.algo.ts:678", + "pc": [ + 3570, + 3571 + ] + }, + { + "teal": 2660, + "source": "examples/reti/stakingPool.algo.ts:680", + "pc": [ + 3572, + 3573 + ] + }, + { + "teal": 2661, + "source": "examples/reti/stakingPool.algo.ts:680", + "pc": [ + 3574, + 3575, + 3576 + ] + }, + { + "teal": 2662, + "source": "examples/reti/stakingPool.algo.ts:680", + "pc": [ + 3577, + 3578 + ] + }, + { + "teal": 2663, + "source": "examples/reti/stakingPool.algo.ts:680", + "pc": [ + 3579, + 3580, + 3581 + ] + }, + { + "teal": 2664, + "source": "examples/reti/stakingPool.algo.ts:680", + "pc": [ + 3582 + ] + }, + { + "teal": 2665, + "source": "examples/reti/stakingPool.algo.ts:680", + "pc": [ + 3583 + ] + }, + { + "teal": 2666, + "source": "examples/reti/stakingPool.algo.ts:680", + "pc": [ + 3584, + 3585, + 3586 + ] + }, + { + "teal": 2667, + "source": "examples/reti/stakingPool.algo.ts:681", + "pc": [ + 3587, + 3588 + ] + }, + { + "teal": 2668, + "source": "examples/reti/stakingPool.algo.ts:681", + "pc": [ + 3589, + 3590, + 3591 + ] + }, + { + "teal": 2669, + "source": "examples/reti/stakingPool.algo.ts:681", + "pc": [ + 3592, + 3593 + ] + }, + { + "teal": 2670, + "source": "examples/reti/stakingPool.algo.ts:681", + "pc": [ + 3594 + ] + }, + { + "teal": 2671, + "source": "examples/reti/stakingPool.algo.ts:681", + "pc": [ + 3595, + 3596 + ] + }, + { + "teal": 2672, + "source": "examples/reti/stakingPool.algo.ts:681", + "pc": [ + 3597, + 3598, + 3599 + ] + }, + { + "teal": 2673, + "source": "examples/reti/stakingPool.algo.ts:681", + "pc": [ + 3600, + 3601 + ] + }, + { + "teal": 2674, + "source": "examples/reti/stakingPool.algo.ts:681", + "pc": [ + 3602 + ] + }, + { + "teal": 2675, + "source": "examples/reti/stakingPool.algo.ts:681", + "pc": [ + 3603 + ] + }, + { + "teal": 2676, + "source": "examples/reti/stakingPool.algo.ts:681", + "pc": [ + 3604, + 3605, + 3606, + 3607, + 3608 + ] + }, + { + "teal": 2677, + "source": "examples/reti/stakingPool.algo.ts:681", + "pc": [ + 3609 + ] + }, + { + "teal": 2678, + "source": "examples/reti/stakingPool.algo.ts:680", + "pc": [ + 3610 + ] + }, + { + "teal": 2681, + "source": "examples/reti/stakingPool.algo.ts:679", + "pc": [ + 3611, + 3612, + 3613 + ] + }, + { + "teal": 2686, + "source": "examples/reti/stakingPool.algo.ts:683", + "pc": [ + 3614, + 3615 + ] + }, + { + "teal": 2687, + "source": "examples/reti/stakingPool.algo.ts:683", + "pc": [ + 3616, + 3617, + 3618, + 3619, + 3620 + ] + }, + { + "teal": 2688, + "source": "examples/reti/stakingPool.algo.ts:683", + "pc": [ + 3621 + ] + }, + { + "teal": 2689, + "source": "examples/reti/stakingPool.algo.ts:683", + "pc": [ + 3622, + 3623, + 3624 + ] + }, + { + "teal": 2690, + "source": "examples/reti/stakingPool.algo.ts:683", + "pc": [ + 3625, + 3626 + ] + }, + { + "teal": 2691, + "source": "examples/reti/stakingPool.algo.ts:683", + "pc": [ + 3627, + 3628, + 3629 + ] + }, + { + "teal": 2694, + "source": "examples/reti/stakingPool.algo.ts:683", + "pc": [ + 3630, + 3631, + 3632, + 3633, + 3634 + ] + }, + { + "teal": 2697, + "source": "examples/reti/stakingPool.algo.ts:683", + "pc": [ + 3635, + 3636 + ] + }, + { + "teal": 2705, + "source": "examples/reti/stakingPool.algo.ts:684", + "pc": [ + 3637 + ] + }, + { + "teal": 2706, + "source": "examples/reti/stakingPool.algo.ts:684", + "pc": [ + 3638, + 3639 + ] + }, + { + "teal": 2707, + "source": "examples/reti/stakingPool.algo.ts:684", + "pc": [ + 3640, + 3641 + ] + }, + { + "teal": 2711, + "source": "examples/reti/stakingPool.algo.ts:685", + "pc": [ + 3642, + 3643 + ] + }, + { + "teal": 2712, + "source": "examples/reti/stakingPool.algo.ts:685", + "pc": [ + 3644, + 3645 + ] + }, + { + "teal": 2716, + "source": "examples/reti/stakingPool.algo.ts:686", + "pc": [ + 3646, + 3647 + ] + }, + { + "teal": 2717, + "source": "examples/reti/stakingPool.algo.ts:686", + "pc": [ + 3648, + 3649, + 3650 + ] + }, + { + "teal": 2718, + "source": "examples/reti/stakingPool.algo.ts:686", + "pc": [ + 3651, + 3652 + ] + }, + { + "teal": 2722, + "source": "examples/reti/stakingPool.algo.ts:687", + "pc": [ + 3653, + 3654, + 3655, + 3656, + 3657, + 3658, + 3659, + 3660, + 3661, + 3662, + 3663, + 3664, + 3665, + 3666, + 3667, + 3668, + 3669, + 3670, + 3671, + 3672, + 3673, + 3674, + 3675, + 3676, + 3677, + 3678, + 3679, + 3680, + 3681, + 3682, + 3683, + 3684, + 3685, + 3686, + 3687, + 3688, + 3689, + 3690, + 3691, + 3692, + 3693, + 3694, + 3695, + 3696, + 3697, + 3698, + 3699, + 3700, + 3701, + 3702, + 3703, + 3704, + 3705, + 3706, + 3707 + ] + }, + { + "teal": 2723, + "source": "examples/reti/stakingPool.algo.ts:687", + "pc": [ + 3708, + 3709 + ] + }, + { + "teal": 2726, + "source": "examples/reti/stakingPool.algo.ts:684", + "pc": [ + 3710, + 3711 + ] + }, + { + "teal": 2727, + "source": "examples/reti/stakingPool.algo.ts:684", + "pc": [ + 3712, + 3713 + ] + }, + { + "teal": 2730, + "source": "examples/reti/stakingPool.algo.ts:684", + "pc": [ + 3714 + ] + }, + { + "teal": 2736, + "source": "examples/reti/stakingPool.algo.ts:690", + "pc": [ + 3715, + 3716 + ] + }, + { + "teal": 2737, + "source": "examples/reti/stakingPool.algo.ts:690", + "pc": [ + 3717, + 3718 + ] + }, + { + "teal": 2738, + "source": "examples/reti/stakingPool.algo.ts:690", + "pc": [ + 3719 + ] + }, + { + "teal": 2739, + "source": "examples/reti/stakingPool.algo.ts:690", + "pc": [ + 3720, + 3721 + ] + }, + { + "teal": 2740, + "source": "examples/reti/stakingPool.algo.ts:690", + "pc": [ + 3722 + ] + }, + { + "teal": 2741, + "source": "examples/reti/stakingPool.algo.ts:690", + "pc": [ + 3723, + 3724, + 3725 + ] + }, + { + "teal": 2750, + "source": "examples/reti/stakingPool.algo.ts:691", + "pc": [ + 3726 + ] + }, + { + "teal": 2751, + "source": "examples/reti/stakingPool.algo.ts:691", + "pc": [ + 3727, + 3728 + ] + }, + { + "teal": 2752, + "source": "examples/reti/stakingPool.algo.ts:691", + "pc": [ + 3729, + 3730 + ] + }, + { + "teal": 2756, + "source": "examples/reti/stakingPool.algo.ts:692", + "pc": [ + 3731, + 3732 + ] + }, + { + "teal": 2757, + "source": "examples/reti/stakingPool.algo.ts:692", + "pc": [ + 3733, + 3734 + ] + }, + { + "teal": 2758, + "source": "examples/reti/stakingPool.algo.ts:692", + "pc": [ + 3735 + ] + }, + { + "teal": 2759, + "source": "examples/reti/stakingPool.algo.ts:692", + "pc": [ + 3736, + 3737 + ] + }, + { + "teal": 2763, + "source": "examples/reti/stakingPool.algo.ts:693", + "pc": [ + 3738, + 3739 + ] + }, + { + "teal": 2764, + "source": "examples/reti/stakingPool.algo.ts:693", + "pc": [ + 3740, + 3741, + 3742 + ] + }, + { + "teal": 2765, + "source": "examples/reti/stakingPool.algo.ts:693", + "pc": [ + 3743, + 3744 + ] + }, + { + "teal": 2769, + "source": "examples/reti/stakingPool.algo.ts:694", + "pc": [ + 3745, + 3746, + 3747, + 3748, + 3749, + 3750, + 3751, + 3752, + 3753, + 3754, + 3755, + 3756, + 3757, + 3758, + 3759, + 3760, + 3761, + 3762 + ] + }, + { + "teal": 2770, + "source": "examples/reti/stakingPool.algo.ts:694", + "pc": [ + 3763, + 3764 + ] + }, + { + "teal": 2773, + "source": "examples/reti/stakingPool.algo.ts:691", + "pc": [ + 3765, + 3766 + ] + }, + { + "teal": 2774, + "source": "examples/reti/stakingPool.algo.ts:691", + "pc": [ + 3767, + 3768 + ] + }, + { + "teal": 2777, + "source": "examples/reti/stakingPool.algo.ts:691", + "pc": [ + 3769 + ] + }, + { + "teal": 2786, + "source": "examples/reti/stakingPool.algo.ts:706", + "pc": [ + 3770, + 3771 + ] + }, + { + "teal": 2787, + "source": "examples/reti/stakingPool.algo.ts:706", + "pc": [ + 3772, + 3773 + ] + }, + { + "teal": 2792, + "source": "examples/reti/stakingPool.algo.ts:730", + "pc": [ + 3774, + 3775 + ] + }, + { + "teal": 2793, + "source": "examples/reti/stakingPool.algo.ts:730", + "pc": [ + 3776, + 3777 + ] + }, + { + "teal": 2794, + "source": "examples/reti/stakingPool.algo.ts:730", + "pc": [ + 3778 + ] + }, + { + "teal": 2795, + "source": "examples/reti/stakingPool.algo.ts:730", + "pc": [ + 3779 + ] + }, + { + "teal": 2796, + "source": "examples/reti/stakingPool.algo.ts:730", + "pc": [ + 3780, + 3781, + 3782 + ] + }, + { + "teal": 2797, + "source": "examples/reti/stakingPool.algo.ts:730", + "pc": [ + 3783, + 3784 + ] + }, + { + "teal": 2798, + "source": "examples/reti/stakingPool.algo.ts:730", + "pc": [ + 3785, + 3786 + ] + }, + { + "teal": 2799, + "source": "examples/reti/stakingPool.algo.ts:730", + "pc": [ + 3787 + ] + }, + { + "teal": 2800, + "source": "examples/reti/stakingPool.algo.ts:730", + "pc": [ + 3788 + ] + }, + { + "teal": 2803, + "source": "examples/reti/stakingPool.algo.ts:730", + "pc": [ + 3789, + 3790, + 3791 + ] + }, + { + "teal": 2808, + "source": "examples/reti/stakingPool.algo.ts:731", + "pc": [ + 3792, + 3793 + ] + }, + { + "teal": 2809, + "source": "examples/reti/stakingPool.algo.ts:731", + "pc": [ + 3794, + 3795 + ] + }, + { + "teal": 2813, + "source": "examples/reti/stakingPool.algo.ts:732", + "pc": [ + 3796, + 3797 + ] + }, + { + "teal": 2814, + "source": "examples/reti/stakingPool.algo.ts:732", + "pc": [ + 3798, + 3799 + ] + }, + { + "teal": 2819, + "source": "examples/reti/stakingPool.algo.ts:732", + "pc": [ + 3800, + 3801 + ] + }, + { + "teal": 2820, + "source": "examples/reti/stakingPool.algo.ts:732", + "pc": [ + 3802, + 3803, + 3804 + ] + }, + { + "teal": 2821, + "source": "examples/reti/stakingPool.algo.ts:732", + "pc": [ + 3805 + ] + }, + { + "teal": 2822, + "source": "examples/reti/stakingPool.algo.ts:732", + "pc": [ + 3806, + 3807, + 3808 + ] + }, + { + "teal": 2827, + "source": "examples/reti/stakingPool.algo.ts:733", + "pc": [ + 3809, + 3810 + ] + }, + { + "teal": 2828, + "source": "examples/reti/stakingPool.algo.ts:733", + "pc": [ + 3811, + 3812, + 3813 + ] + }, + { + "teal": 2829, + "source": "examples/reti/stakingPool.algo.ts:733", + "pc": [ + 3814 + ] + }, + { + "teal": 2830, + "source": "examples/reti/stakingPool.algo.ts:733", + "pc": [ + 3815, + 3816, + 3817 + ] + }, + { + "teal": 2835, + "source": "examples/reti/stakingPool.algo.ts:734", + "pc": [ + 3818 + ] + }, + { + "teal": 2836, + "source": "examples/reti/stakingPool.algo.ts:734", + "pc": [ + 3819, + 3820 + ] + }, + { + "teal": 2837, + "source": "examples/reti/stakingPool.algo.ts:734", + "pc": [ + 3821, + 3822 + ] + }, + { + "teal": 2838, + "source": "examples/reti/stakingPool.algo.ts:734", + "pc": [ + 3823, + 3824 + ] + }, + { + "teal": 2839, + "source": "examples/reti/stakingPool.algo.ts:734", + "pc": [ + 3825, + 3826 + ] + }, + { + "teal": 2840, + "source": "examples/reti/stakingPool.algo.ts:734", + "pc": [ + 3827, + 3828, + 3829, + 3830, + 3831 + ] + }, + { + "teal": 2841, + "source": "examples/reti/stakingPool.algo.ts:734", + "pc": [ + 3832 + ] + }, + { + "teal": 2842, + "source": "examples/reti/stakingPool.algo.ts:734", + "pc": [ + 3833, + 3834 + ] + }, + { + "teal": 2843, + "source": "examples/reti/stakingPool.algo.ts:734", + "pc": [ + 3835, + 3836 + ] + }, + { + "teal": 2844, + "source": "examples/reti/stakingPool.algo.ts:734", + "pc": [ + 3837, + 3838 + ] + }, + { + "teal": 2845, + "source": "examples/reti/stakingPool.algo.ts:734", + "pc": [ + 3839, + 3840 + ] + }, + { + "teal": 2846, + "source": "examples/reti/stakingPool.algo.ts:734", + "pc": [ + 3841 + ] + }, + { + "teal": 2851, + "source": "examples/reti/stakingPool.algo.ts:736", + "pc": [ + 3842, + 3843 + ] + }, + { + "teal": 2852, + "source": "examples/reti/stakingPool.algo.ts:736", + "pc": [ + 3844, + 3845 + ] + }, + { + "teal": 2853, + "source": "examples/reti/stakingPool.algo.ts:736", + "pc": [ + 3846 + ] + }, + { + "teal": 2854, + "source": "examples/reti/stakingPool.algo.ts:736", + "pc": [ + 3847, + 3848 + ] + }, + { + "teal": 2855, + "source": "examples/reti/stakingPool.algo.ts:736", + "pc": [ + 3849, + 3850, + 3851, + 3852, + 3853, + 3854, + 3855, + 3856, + 3857 + ] + }, + { + "teal": 2856, + "source": "examples/reti/stakingPool.algo.ts:736", + "pc": [ + 3858, + 3859 + ] + }, + { + "teal": 2857, + "source": "examples/reti/stakingPool.algo.ts:736", + "pc": [ + 3860 + ] + }, + { + "teal": 2858, + "source": "examples/reti/stakingPool.algo.ts:736", + "pc": [ + 3861, + 3862 + ] + }, + { + "teal": 2863, + "source": "examples/reti/stakingPool.algo.ts:737", + "pc": [ + 3863, + 3864 + ] + }, + { + "teal": 2864, + "source": "examples/reti/stakingPool.algo.ts:737", + "pc": [ + 3865, + 3866, + 3867 + ] + }, + { + "teal": 2865, + "source": "examples/reti/stakingPool.algo.ts:737", + "pc": [ + 3868, + 3869 + ] + }, + { + "teal": 2866, + "source": "examples/reti/stakingPool.algo.ts:737", + "pc": [ + 3870 + ] + }, + { + "teal": 2867, + "source": "examples/reti/stakingPool.algo.ts:737", + "pc": [ + 3871, + 3872, + 3873 + ] + }, + { + "teal": 2873, + "source": "examples/reti/stakingPool.algo.ts:738", + "pc": [ + 3874, + 3875 + ] + }, + { + "teal": 2874, + "source": "examples/reti/stakingPool.algo.ts:738", + "pc": [ + 3876, + 3877, + 3878 + ] + }, + { + "teal": 2875, + "source": "examples/reti/stakingPool.algo.ts:738", + "pc": [ + 3879 + ] + }, + { + "teal": 2876, + "source": "examples/reti/stakingPool.algo.ts:738", + "pc": [ + 3880, + 3881 + ] + }, + { + "teal": 2877, + "source": "examples/reti/stakingPool.algo.ts:738", + "pc": [ + 3882 + ] + }, + { + "teal": 2878, + "source": "examples/reti/stakingPool.algo.ts:738", + "pc": [ + 3883, + 3884, + 3885 + ] + }, + { + "teal": 2883, + "source": "examples/reti/stakingPool.algo.ts:741", + "pc": [ + 3886, + 3887 + ] + }, + { + "teal": 2884, + "source": "examples/reti/stakingPool.algo.ts:741", + "pc": [ + 3888, + 3889 + ] + }, + { + "teal": 2885, + "source": "examples/reti/stakingPool.algo.ts:741", + "pc": [ + 3890, + 3891, + 3892 + ] + }, + { + "teal": 2886, + "source": "examples/reti/stakingPool.algo.ts:741", + "pc": [ + 3893 + ] + }, + { + "teal": 2887, + "source": "examples/reti/stakingPool.algo.ts:741", + "pc": [ + 3894 + ] + }, + { + "teal": 2888, + "source": "examples/reti/stakingPool.algo.ts:741", + "pc": [ + 3895, + 3896 + ] + }, + { + "teal": 2889, + "source": "examples/reti/stakingPool.algo.ts:738", + "pc": [ + 3897, + 3898, + 3899 + ] + }, + { + "teal": 2894, + "source": "examples/reti/stakingPool.algo.ts:745", + "pc": [ + 3900, + 3901 + ] + }, + { + "teal": 2895, + "source": "examples/reti/stakingPool.algo.ts:745", + "pc": [ + 3902, + 3903 + ] + }, + { + "teal": 2896, + "source": "examples/reti/stakingPool.algo.ts:745", + "pc": [ + 3904, + 3905, + 3906 + ] + }, + { + "teal": 2897, + "source": "examples/reti/stakingPool.algo.ts:745", + "pc": [ + 3907 + ] + }, + { + "teal": 2898, + "source": "examples/reti/stakingPool.algo.ts:745", + "pc": [ + 3908 + ] + }, + { + "teal": 2899, + "source": "examples/reti/stakingPool.algo.ts:745", + "pc": [ + 3909, + 3910 + ] + }, + { + "teal": 2904, + "source": "examples/reti/stakingPool.algo.ts:749", + "pc": [ + 3911, + 3912 + ] + }, + { + "teal": 2905, + "source": "examples/reti/stakingPool.algo.ts:749", + "pc": [ + 3913, + 3914 + ] + }, + { + "teal": 2906, + "source": "examples/reti/stakingPool.algo.ts:749", + "pc": [ + 3915 + ] + }, + { + "teal": 2907, + "source": "examples/reti/stakingPool.algo.ts:749", + "pc": [ + 3916, + 3917, + 3918 + ] + }, + { + "teal": 2912, + "source": "examples/reti/stakingPool.algo.ts:750", + "pc": [ + 3919, + 3920 + ] + }, + { + "teal": 2913, + "source": "examples/reti/stakingPool.algo.ts:750", + "pc": [ + 3921, + 3922 + ] + }, + { + "teal": 2914, + "source": "examples/reti/stakingPool.algo.ts:750", + "pc": [ + 3923, + 3924, + 3925 + ] + }, + { + "teal": 2915, + "source": "examples/reti/stakingPool.algo.ts:750", + "pc": [ + 3926 + ] + }, + { + "teal": 2916, + "source": "examples/reti/stakingPool.algo.ts:750", + "pc": [ + 3927 + ] + }, + { + "teal": 2917, + "source": "examples/reti/stakingPool.algo.ts:750", + "pc": [ + 3928, + 3929 + ] + }, + { + "teal": 2921, + "source": "examples/reti/stakingPool.algo.ts:751", + "pc": [ + 3930, + 3931 + ] + }, + { + "teal": 2922, + "source": "examples/reti/stakingPool.algo.ts:751", + "pc": [ + 3932, + 3933, + 3934 + ] + }, + { + "teal": 2923, + "source": "examples/reti/stakingPool.algo.ts:751", + "pc": [ + 3935 + ] + }, + { + "teal": 2924, + "source": "examples/reti/stakingPool.algo.ts:751", + "pc": [ + 3936, + 3937 + ] + }, + { + "teal": 2925, + "source": "examples/reti/stakingPool.algo.ts:751", + "pc": [ + 3938 + ] + }, + { + "teal": 2926, + "source": "examples/reti/stakingPool.algo.ts:751", + "pc": [ + 3939, + 3940 + ] + }, + { + "teal": 2931, + "source": "examples/reti/stakingPool.algo.ts:753", + "pc": [ + 3941, + 3942 + ] + }, + { + "teal": 2932, + "source": "examples/reti/stakingPool.algo.ts:753", + "pc": [ + 3943, + 3944 + ] + }, + { + "teal": 2933, + "source": "examples/reti/stakingPool.algo.ts:753", + "pc": [ + 3945 + ] + }, + { + "teal": 2934, + "source": "examples/reti/stakingPool.algo.ts:753", + "pc": [ + 3946, + 3947, + 3948 + ] + }, + { + "teal": 2942, + "source": "examples/reti/stakingPool.algo.ts:756", + "pc": [ + 3949, + 3950 + ] + }, + { + "teal": 2943, + "source": "examples/reti/stakingPool.algo.ts:756", + "pc": [ + 3951, + 3952, + 3953 + ] + }, + { + "teal": 2944, + "source": "examples/reti/stakingPool.algo.ts:756", + "pc": [ + 3954 + ] + }, + { + "teal": 2945, + "source": "examples/reti/stakingPool.algo.ts:756", + "pc": [ + 3955, + 3956 + ] + }, + { + "teal": 2946, + "source": "examples/reti/stakingPool.algo.ts:755", + "pc": [ + 3957 + ] + }, + { + "teal": 2947, + "source": "examples/reti/stakingPool.algo.ts:756", + "pc": [ + 3958, + 3959 + ] + }, + { + "teal": 2948, + "source": "examples/reti/stakingPool.algo.ts:755", + "pc": [ + 3960, + 3961 + ] + }, + { + "teal": 2949, + "source": "examples/reti/stakingPool.algo.ts:755", + "pc": [ + 3962, + 3963 + ] + }, + { + "teal": 2950, + "source": "examples/reti/stakingPool.algo.ts:755", + "pc": [ + 3964 + ] + }, + { + "teal": 2951, + "source": "examples/reti/stakingPool.algo.ts:755", + "pc": [ + 3965, + 3966 + ] + }, + { + "teal": 2952, + "source": "examples/reti/stakingPool.algo.ts:755", + "pc": [ + 3967 + ] + }, + { + "teal": 2953, + "source": "examples/reti/stakingPool.algo.ts:755", + "pc": [ + 3968, + 3969 + ] + }, + { + "teal": 2954, + "source": "examples/reti/stakingPool.algo.ts:755", + "pc": [ + 3970 + ] + }, + { + "teal": 2955, + "source": "examples/reti/stakingPool.algo.ts:755", + "pc": [ + 3971 + ] + }, + { + "teal": 2956, + "source": "examples/reti/stakingPool.algo.ts:757", + "pc": [ + 3972, + 3973, + 3974, + 3975, + 3976, + 3977, + 3978, + 3979 + ] + }, + { + "teal": 2957, + "source": "examples/reti/stakingPool.algo.ts:757", + "pc": [ + 3980 + ] + }, + { + "teal": 2958, + "source": "examples/reti/stakingPool.algo.ts:757", + "pc": [ + 3981, + 3982, + 3983 + ] + }, + { + "teal": 2959, + "source": "examples/reti/stakingPool.algo.ts:755", + "pc": [ + 3984 + ] + }, + { + "teal": 2960, + "source": "examples/reti/stakingPool.algo.ts:755", + "pc": [ + 3985 + ] + }, + { + "teal": 2961, + "source": "examples/reti/stakingPool.algo.ts:755", + "pc": [ + 3986 + ] + }, + { + "teal": 2962, + "source": "examples/reti/stakingPool.algo.ts:755", + "pc": [ + 3987 + ] + }, + { + "teal": 2963, + "source": "examples/reti/stakingPool.algo.ts:755", + "pc": [ + 3988 + ] + }, + { + "teal": 2964, + "source": "examples/reti/stakingPool.algo.ts:755", + "pc": [ + 3989 + ] + }, + { + "teal": 2967, + "source": "examples/reti/stakingPool.algo.ts:755", + "errorMessage": "wideRatio failed", + "pc": [ + 3990 + ] + }, + { + "teal": 2968, + "source": "examples/reti/stakingPool.algo.ts:755", + "pc": [ + 3991, + 3992 + ] + }, + { + "teal": 2972, + "source": "examples/reti/stakingPool.algo.ts:762", + "pc": [ + 3993, + 3994 + ] + }, + { + "teal": 2973, + "source": "examples/reti/stakingPool.algo.ts:762", + "pc": [ + 3995, + 3996 + ] + }, + { + "teal": 2974, + "source": "examples/reti/stakingPool.algo.ts:762", + "pc": [ + 3997 + ] + }, + { + "teal": 2975, + "source": "examples/reti/stakingPool.algo.ts:762", + "pc": [ + 3998, + 3999 + ] + }, + { + "teal": 2979, + "source": "examples/reti/stakingPool.algo.ts:763", + "pc": [ + 4000, + 4001 + ] + }, + { + "teal": 2980, + "source": "examples/reti/stakingPool.algo.ts:763", + "pc": [ + 4002, + 4003 + ] + }, + { + "teal": 2981, + "source": "examples/reti/stakingPool.algo.ts:763", + "pc": [ + 4004, + 4005 + ] + }, + { + "teal": 2982, + "source": "examples/reti/stakingPool.algo.ts:763", + "pc": [ + 4006, + 4007, + 4008 + ] + }, + { + "teal": 2983, + "source": "examples/reti/stakingPool.algo.ts:763", + "pc": [ + 4009 + ] + }, + { + "teal": 2984, + "source": "examples/reti/stakingPool.algo.ts:763", + "pc": [ + 4010, + 4011 + ] + }, + { + "teal": 2985, + "source": "examples/reti/stakingPool.algo.ts:763", + "pc": [ + 4012 + ] + }, + { + "teal": 2986, + "source": "examples/reti/stakingPool.algo.ts:763", + "pc": [ + 4013 + ] + }, + { + "teal": 2987, + "source": "examples/reti/stakingPool.algo.ts:763", + "pc": [ + 4014 + ] + }, + { + "teal": 2988, + "source": "examples/reti/stakingPool.algo.ts:763", + "pc": [ + 4015, + 4016 + ] + }, + { + "teal": 2992, + "source": "examples/reti/stakingPool.algo.ts:764", + "pc": [ + 4017, + 4018 + ] + }, + { + "teal": 2993, + "source": "examples/reti/stakingPool.algo.ts:764", + "pc": [ + 4019, + 4020 + ] + }, + { + "teal": 2994, + "source": "examples/reti/stakingPool.algo.ts:764", + "pc": [ + 4021 + ] + }, + { + "teal": 2995, + "source": "examples/reti/stakingPool.algo.ts:764", + "pc": [ + 4022, + 4023 + ] + }, + { + "teal": 3001, + "source": "examples/reti/stakingPool.algo.ts:766", + "pc": [ + 4024, + 4025 + ] + }, + { + "teal": 3002, + "source": "examples/reti/stakingPool.algo.ts:766", + "pc": [ + 4026, + 4027 + ] + }, + { + "teal": 3003, + "source": "examples/reti/stakingPool.algo.ts:766", + "pc": [ + 4028 + ] + }, + { + "teal": 3004, + "source": "examples/reti/stakingPool.algo.ts:766", + "pc": [ + 4029, + 4030, + 4031 + ] + }, + { + "teal": 3012, + "source": "examples/reti/stakingPool.algo.ts:769", + "pc": [ + 4032, + 4033 + ] + }, + { + "teal": 3013, + "source": "examples/reti/stakingPool.algo.ts:769", + "pc": [ + 4034, + 4035, + 4036 + ] + }, + { + "teal": 3014, + "source": "examples/reti/stakingPool.algo.ts:769", + "pc": [ + 4037 + ] + }, + { + "teal": 3015, + "source": "examples/reti/stakingPool.algo.ts:769", + "pc": [ + 4038, + 4039 + ] + }, + { + "teal": 3016, + "source": "examples/reti/stakingPool.algo.ts:768", + "pc": [ + 4040 + ] + }, + { + "teal": 3017, + "source": "examples/reti/stakingPool.algo.ts:769", + "pc": [ + 4041, + 4042 + ] + }, + { + "teal": 3018, + "source": "examples/reti/stakingPool.algo.ts:768", + "pc": [ + 4043, + 4044 + ] + }, + { + "teal": 3019, + "source": "examples/reti/stakingPool.algo.ts:768", + "pc": [ + 4045, + 4046 + ] + }, + { + "teal": 3020, + "source": "examples/reti/stakingPool.algo.ts:768", + "pc": [ + 4047 + ] + }, + { + "teal": 3021, + "source": "examples/reti/stakingPool.algo.ts:768", + "pc": [ + 4048, + 4049 + ] + }, + { + "teal": 3022, + "source": "examples/reti/stakingPool.algo.ts:768", + "pc": [ + 4050 + ] + }, + { + "teal": 3023, + "source": "examples/reti/stakingPool.algo.ts:768", + "pc": [ + 4051, + 4052 + ] + }, + { + "teal": 3024, + "source": "examples/reti/stakingPool.algo.ts:768", + "pc": [ + 4053 + ] + }, + { + "teal": 3025, + "source": "examples/reti/stakingPool.algo.ts:768", + "pc": [ + 4054 + ] + }, + { + "teal": 3026, + "source": "examples/reti/stakingPool.algo.ts:770", + "pc": [ + 4055, + 4056, + 4057, + 4058, + 4059, + 4060, + 4061, + 4062 + ] + }, + { + "teal": 3027, + "source": "examples/reti/stakingPool.algo.ts:770", + "pc": [ + 4063 + ] + }, + { + "teal": 3028, + "source": "examples/reti/stakingPool.algo.ts:770", + "pc": [ + 4064, + 4065, + 4066 + ] + }, + { + "teal": 3029, + "source": "examples/reti/stakingPool.algo.ts:768", + "pc": [ + 4067 + ] + }, + { + "teal": 3030, + "source": "examples/reti/stakingPool.algo.ts:768", + "pc": [ + 4068 + ] + }, + { + "teal": 3031, + "source": "examples/reti/stakingPool.algo.ts:768", + "pc": [ + 4069 + ] + }, + { + "teal": 3032, + "source": "examples/reti/stakingPool.algo.ts:768", + "pc": [ + 4070 + ] + }, + { + "teal": 3033, + "source": "examples/reti/stakingPool.algo.ts:768", + "pc": [ + 4071 + ] + }, + { + "teal": 3034, + "source": "examples/reti/stakingPool.algo.ts:768", + "pc": [ + 4072 + ] + }, + { + "teal": 3037, + "source": "examples/reti/stakingPool.algo.ts:768", + "errorMessage": "wideRatio failed", + "pc": [ + 4073 + ] + }, + { + "teal": 3038, + "source": "examples/reti/stakingPool.algo.ts:768", + "pc": [ + 4074, + 4075 + ] + }, + { + "teal": 3042, + "source": "examples/reti/stakingPool.algo.ts:775", + "pc": [ + 4076, + 4077 + ] + }, + { + "teal": 3043, + "source": "examples/reti/stakingPool.algo.ts:775", + "pc": [ + 4078, + 4079 + ] + }, + { + "teal": 3044, + "source": "examples/reti/stakingPool.algo.ts:775", + "pc": [ + 4080 + ] + }, + { + "teal": 3045, + "source": "examples/reti/stakingPool.algo.ts:775", + "pc": [ + 4081, + 4082 + ] + }, + { + "teal": 3049, + "source": "examples/reti/stakingPool.algo.ts:778", + "pc": [ + 4083, + 4084 + ] + }, + { + "teal": 3050, + "source": "examples/reti/stakingPool.algo.ts:778", + "pc": [ + 4085, + 4086 + ] + }, + { + "teal": 3051, + "source": "examples/reti/stakingPool.algo.ts:778", + "pc": [ + 4087, + 4088 + ] + }, + { + "teal": 3052, + "source": "examples/reti/stakingPool.algo.ts:778", + "pc": [ + 4089, + 4090, + 4091 + ] + }, + { + "teal": 3053, + "source": "examples/reti/stakingPool.algo.ts:778", + "pc": [ + 4092 + ] + }, + { + "teal": 3054, + "source": "examples/reti/stakingPool.algo.ts:778", + "pc": [ + 4093, + 4094 + ] + }, + { + "teal": 3055, + "source": "examples/reti/stakingPool.algo.ts:778", + "pc": [ + 4095 + ] + }, + { + "teal": 3056, + "source": "examples/reti/stakingPool.algo.ts:778", + "pc": [ + 4096 + ] + }, + { + "teal": 3057, + "source": "examples/reti/stakingPool.algo.ts:778", + "pc": [ + 4097 + ] + }, + { + "teal": 3058, + "source": "examples/reti/stakingPool.algo.ts:778", + "pc": [ + 4098, + 4099 + ] + }, + { + "teal": 3062, + "source": "examples/reti/stakingPool.algo.ts:779", + "pc": [ + 4100, + 4101 + ] + }, + { + "teal": 3063, + "source": "examples/reti/stakingPool.algo.ts:779", + "pc": [ + 4102, + 4103 + ] + }, + { + "teal": 3064, + "source": "examples/reti/stakingPool.algo.ts:779", + "pc": [ + 4104, + 4105 + ] + }, + { + "teal": 3065, + "source": "examples/reti/stakingPool.algo.ts:779", + "pc": [ + 4106, + 4107, + 4108 + ] + }, + { + "teal": 3066, + "source": "examples/reti/stakingPool.algo.ts:779", + "pc": [ + 4109 + ] + }, + { + "teal": 3067, + "source": "examples/reti/stakingPool.algo.ts:779", + "pc": [ + 4110, + 4111 + ] + }, + { + "teal": 3068, + "source": "examples/reti/stakingPool.algo.ts:779", + "pc": [ + 4112 + ] + }, + { + "teal": 3069, + "source": "examples/reti/stakingPool.algo.ts:779", + "pc": [ + 4113 + ] + }, + { + "teal": 3070, + "source": "examples/reti/stakingPool.algo.ts:779", + "pc": [ + 4114 + ] + }, + { + "teal": 3071, + "source": "examples/reti/stakingPool.algo.ts:779", + "pc": [ + 4115, + 4116 + ] + }, + { + "teal": 3075, + "source": "examples/reti/stakingPool.algo.ts:780", + "pc": [ + 4117, + 4118 + ] + }, + { + "teal": 3076, + "source": "examples/reti/stakingPool.algo.ts:780", + "pc": [ + 4119, + 4120 + ] + }, + { + "teal": 3077, + "source": "examples/reti/stakingPool.algo.ts:780", + "pc": [ + 4121 + ] + }, + { + "teal": 3078, + "source": "examples/reti/stakingPool.algo.ts:780", + "pc": [ + 4122, + 4123 + ] + }, + { + "teal": 3083, + "source": "examples/reti/stakingPool.algo.ts:783", + "pc": [ + 4124, + 4125 + ] + }, + { + "teal": 3084, + "source": "examples/reti/stakingPool.algo.ts:783", + "pc": [ + 4126, + 4127 + ] + }, + { + "teal": 3085, + "source": "examples/reti/stakingPool.algo.ts:783", + "pc": [ + 4128 + ] + }, + { + "teal": 3086, + "source": "examples/reti/stakingPool.algo.ts:783", + "pc": [ + 4129, + 4130 + ] + }, + { + "teal": 3087, + "source": "examples/reti/stakingPool.algo.ts:783", + "pc": [ + 4131, + 4132, + 4133, + 4134, + 4135, + 4136, + 4137, + 4138, + 4139 + ] + }, + { + "teal": 3088, + "source": "examples/reti/stakingPool.algo.ts:783", + "pc": [ + 4140, + 4141 + ] + }, + { + "teal": 3089, + "source": "examples/reti/stakingPool.algo.ts:783", + "pc": [ + 4142 + ] + }, + { + "teal": 3100, + "source": "examples/reti/stakingPool.algo.ts:732", + "pc": [ + 4143, + 4144 + ] + }, + { + "teal": 3101, + "source": "examples/reti/stakingPool.algo.ts:732", + "pc": [ + 4145, + 4146 + ] + }, + { + "teal": 3102, + "source": "examples/reti/stakingPool.algo.ts:732", + "pc": [ + 4147 + ] + }, + { + "teal": 3103, + "source": "examples/reti/stakingPool.algo.ts:732", + "pc": [ + 4148, + 4149 + ] + }, + { + "teal": 3104, + "source": "examples/reti/stakingPool.algo.ts:732", + "pc": [ + 4150, + 4151, + 4152 + ] + }, + { + "teal": 3109, + "source": "examples/reti/stakingPool.algo.ts:791", + "pc": [ + 4153, + 4154, + 4155, + 4156, + 4157, + 4158, + 4159, + 4160 + ] + }, + { + "teal": 3110, + "source": "examples/reti/stakingPool.algo.ts:791", + "pc": [ + 4161 + ] + }, + { + "teal": 3111, + "source": "examples/reti/stakingPool.algo.ts:791", + "pc": [ + 4162, + 4163 + ] + }, + { + "teal": 3112, + "source": "examples/reti/stakingPool.algo.ts:791", + "pc": [ + 4164 + ] + }, + { + "teal": 3113, + "source": "examples/reti/stakingPool.algo.ts:791", + "pc": [ + 4165, + 4166 + ] + }, + { + "teal": 3118, + "source": "examples/reti/stakingPool.algo.ts:795", + "pc": [ + 4167, + 4168 + ] + }, + { + "teal": 3119, + "source": "examples/reti/stakingPool.algo.ts:795", + "pc": [ + 4169, + 4170 + ] + }, + { + "teal": 3120, + "source": "examples/reti/stakingPool.algo.ts:795", + "pc": [ + 4171 + ] + }, + { + "teal": 3121, + "source": "examples/reti/stakingPool.algo.ts:795", + "pc": [ + 4172, + 4173, + 4174 + ] + }, + { + "teal": 3126, + "source": "examples/reti/stakingPool.algo.ts:797", + "pc": [ + 4175, + 4176 + ] + }, + { + "teal": 3127, + "source": "examples/reti/stakingPool.algo.ts:797", + "pc": [ + 4177, + 4178 + ] + }, + { + "teal": 3132, + "source": "examples/reti/stakingPool.algo.ts:797", + "pc": [ + 4179, + 4180 + ] + }, + { + "teal": 3133, + "source": "examples/reti/stakingPool.algo.ts:797", + "pc": [ + 4181, + 4182, + 4183 + ] + }, + { + "teal": 3134, + "source": "examples/reti/stakingPool.algo.ts:797", + "pc": [ + 4184 + ] + }, + { + "teal": 3135, + "source": "examples/reti/stakingPool.algo.ts:797", + "pc": [ + 4185, + 4186, + 4187 + ] + }, + { + "teal": 3140, + "source": "examples/reti/stakingPool.algo.ts:798", + "pc": [ + 4188, + 4189 + ] + }, + { + "teal": 3141, + "source": "examples/reti/stakingPool.algo.ts:798", + "pc": [ + 4190, + 4191, + 4192 + ] + }, + { + "teal": 3142, + "source": "examples/reti/stakingPool.algo.ts:798", + "pc": [ + 4193 + ] + }, + { + "teal": 3143, + "source": "examples/reti/stakingPool.algo.ts:798", + "pc": [ + 4194, + 4195, + 4196 + ] + }, + { + "teal": 3148, + "source": "examples/reti/stakingPool.algo.ts:799", + "pc": [ + 4197 + ] + }, + { + "teal": 3149, + "source": "examples/reti/stakingPool.algo.ts:799", + "pc": [ + 4198, + 4199 + ] + }, + { + "teal": 3150, + "source": "examples/reti/stakingPool.algo.ts:799", + "pc": [ + 4200, + 4201 + ] + }, + { + "teal": 3151, + "source": "examples/reti/stakingPool.algo.ts:799", + "pc": [ + 4202, + 4203 + ] + }, + { + "teal": 3152, + "source": "examples/reti/stakingPool.algo.ts:799", + "pc": [ + 4204, + 4205 + ] + }, + { + "teal": 3153, + "source": "examples/reti/stakingPool.algo.ts:799", + "pc": [ + 4206, + 4207, + 4208, + 4209, + 4210 + ] + }, + { + "teal": 3154, + "source": "examples/reti/stakingPool.algo.ts:799", + "pc": [ + 4211 + ] + }, + { + "teal": 3155, + "source": "examples/reti/stakingPool.algo.ts:799", + "pc": [ + 4212, + 4213 + ] + }, + { + "teal": 3156, + "source": "examples/reti/stakingPool.algo.ts:799", + "pc": [ + 4214, + 4215 + ] + }, + { + "teal": 3157, + "source": "examples/reti/stakingPool.algo.ts:799", + "pc": [ + 4216, + 4217 + ] + }, + { + "teal": 3158, + "source": "examples/reti/stakingPool.algo.ts:799", + "pc": [ + 4218, + 4219 + ] + }, + { + "teal": 3159, + "source": "examples/reti/stakingPool.algo.ts:799", + "pc": [ + 4220 + ] + }, + { + "teal": 3164, + "source": "examples/reti/stakingPool.algo.ts:801", + "pc": [ + 4221, + 4222 + ] + }, + { + "teal": 3165, + "source": "examples/reti/stakingPool.algo.ts:801", + "pc": [ + 4223, + 4224 + ] + }, + { + "teal": 3166, + "source": "examples/reti/stakingPool.algo.ts:801", + "pc": [ + 4225 + ] + }, + { + "teal": 3167, + "source": "examples/reti/stakingPool.algo.ts:801", + "pc": [ + 4226, + 4227 + ] + }, + { + "teal": 3168, + "source": "examples/reti/stakingPool.algo.ts:801", + "pc": [ + 4228, + 4229, + 4230, + 4231, + 4232, + 4233, + 4234, + 4235, + 4236 + ] + }, + { + "teal": 3169, + "source": "examples/reti/stakingPool.algo.ts:801", + "pc": [ + 4237, + 4238 + ] + }, + { + "teal": 3170, + "source": "examples/reti/stakingPool.algo.ts:801", + "pc": [ + 4239 + ] + }, + { + "teal": 3171, + "source": "examples/reti/stakingPool.algo.ts:801", + "pc": [ + 4240, + 4241 + ] + }, + { + "teal": 3176, + "source": "examples/reti/stakingPool.algo.ts:802", + "pc": [ + 4242, + 4243 + ] + }, + { + "teal": 3177, + "source": "examples/reti/stakingPool.algo.ts:802", + "pc": [ + 4244, + 4245, + 4246 + ] + }, + { + "teal": 3178, + "source": "examples/reti/stakingPool.algo.ts:802", + "pc": [ + 4247, + 4248 + ] + }, + { + "teal": 3179, + "source": "examples/reti/stakingPool.algo.ts:802", + "pc": [ + 4249 + ] + }, + { + "teal": 3180, + "source": "examples/reti/stakingPool.algo.ts:802", + "pc": [ + 4250 + ] + }, + { + "teal": 3181, + "source": "examples/reti/stakingPool.algo.ts:802", + "pc": [ + 4251, + 4252, + 4253 + ] + }, + { + "teal": 3182, + "source": "examples/reti/stakingPool.algo.ts:802", + "pc": [ + 4254, + 4255 + ] + }, + { + "teal": 3183, + "source": "examples/reti/stakingPool.algo.ts:802", + "pc": [ + 4256, + 4257, + 4258 + ] + }, + { + "teal": 3184, + "source": "examples/reti/stakingPool.algo.ts:802", + "pc": [ + 4259 + ] + }, + { + "teal": 3185, + "source": "examples/reti/stakingPool.algo.ts:802", + "pc": [ + 4260, + 4261 + ] + }, + { + "teal": 3186, + "source": "examples/reti/stakingPool.algo.ts:802", + "pc": [ + 4262 + ] + }, + { + "teal": 3187, + "source": "examples/reti/stakingPool.algo.ts:802", + "pc": [ + 4263 + ] + }, + { + "teal": 3190, + "source": "examples/reti/stakingPool.algo.ts:802", + "pc": [ + 4264, + 4265, + 4266 + ] + }, + { + "teal": 3195, + "source": "examples/reti/stakingPool.algo.ts:803", + "pc": [ + 4267, + 4268 + ] + }, + { + "teal": 3196, + "source": "examples/reti/stakingPool.algo.ts:803", + "pc": [ + 4269, + 4270 + ] + }, + { + "teal": 3197, + "source": "examples/reti/stakingPool.algo.ts:803", + "pc": [ + 4271, + 4272, + 4273 + ] + }, + { + "teal": 3198, + "source": "examples/reti/stakingPool.algo.ts:803", + "pc": [ + 4274 + ] + }, + { + "teal": 3199, + "source": "examples/reti/stakingPool.algo.ts:803", + "pc": [ + 4275 + ] + }, + { + "teal": 3200, + "source": "examples/reti/stakingPool.algo.ts:803", + "pc": [ + 4276, + 4277 + ] + }, + { + "teal": 3205, + "source": "examples/reti/stakingPool.algo.ts:805", + "pc": [ + 4278, + 4279 + ] + }, + { + "teal": 3206, + "source": "examples/reti/stakingPool.algo.ts:805", + "pc": [ + 4280, + 4281 + ] + }, + { + "teal": 3207, + "source": "examples/reti/stakingPool.algo.ts:805", + "pc": [ + 4282 + ] + }, + { + "teal": 3208, + "source": "examples/reti/stakingPool.algo.ts:805", + "pc": [ + 4283, + 4284, + 4285 + ] + }, + { + "teal": 3214, + "source": "examples/reti/stakingPool.algo.ts:810", + "pc": [ + 4286, + 4287 + ] + }, + { + "teal": 3215, + "source": "examples/reti/stakingPool.algo.ts:810", + "pc": [ + 4288, + 4289 + ] + }, + { + "teal": 3216, + "source": "examples/reti/stakingPool.algo.ts:810", + "pc": [ + 4290 + ] + }, + { + "teal": 3217, + "source": "examples/reti/stakingPool.algo.ts:810", + "pc": [ + 4291, + 4292, + 4293 + ] + }, + { + "teal": 3222, + "source": "examples/reti/stakingPool.algo.ts:811", + "pc": [ + 4294, + 4295 + ] + }, + { + "teal": 3223, + "source": "examples/reti/stakingPool.algo.ts:811", + "pc": [ + 4296, + 4297, + 4298 + ] + }, + { + "teal": 3224, + "source": "examples/reti/stakingPool.algo.ts:811", + "pc": [ + 4299 + ] + }, + { + "teal": 3225, + "source": "examples/reti/stakingPool.algo.ts:811", + "pc": [ + 4300, + 4301 + ] + }, + { + "teal": 3226, + "source": "examples/reti/stakingPool.algo.ts:811", + "pc": [ + 4302 + ] + }, + { + "teal": 3227, + "source": "examples/reti/stakingPool.algo.ts:811", + "pc": [ + 4303, + 4304 + ] + }, + { + "teal": 3228, + "source": "examples/reti/stakingPool.algo.ts:811", + "pc": [ + 4305, + 4306 + ] + }, + { + "teal": 3229, + "source": "examples/reti/stakingPool.algo.ts:811", + "pc": [ + 4307 + ] + }, + { + "teal": 3230, + "source": "examples/reti/stakingPool.algo.ts:811", + "pc": [ + 4308 + ] + }, + { + "teal": 3231, + "source": "examples/reti/stakingPool.algo.ts:811", + "pc": [ + 4309 + ] + }, + { + "teal": 3232, + "source": "examples/reti/stakingPool.algo.ts:811", + "pc": [ + 4310 + ] + }, + { + "teal": 3233, + "source": "examples/reti/stakingPool.algo.ts:811", + "pc": [ + 4311 + ] + }, + { + "teal": 3236, + "source": "examples/reti/stakingPool.algo.ts:811", + "errorMessage": "wideRatio failed", + "pc": [ + 4312 + ] + }, + { + "teal": 3237, + "source": "examples/reti/stakingPool.algo.ts:811", + "pc": [ + 4313, + 4314 + ] + }, + { + "teal": 3241, + "source": "examples/reti/stakingPool.algo.ts:814", + "pc": [ + 4315, + 4316 + ] + }, + { + "teal": 3242, + "source": "examples/reti/stakingPool.algo.ts:814", + "pc": [ + 4317, + 4318 + ] + }, + { + "teal": 3243, + "source": "examples/reti/stakingPool.algo.ts:814", + "pc": [ + 4319, + 4320 + ] + }, + { + "teal": 3244, + "source": "examples/reti/stakingPool.algo.ts:814", + "pc": [ + 4321, + 4322, + 4323 + ] + }, + { + "teal": 3245, + "source": "examples/reti/stakingPool.algo.ts:814", + "pc": [ + 4324 + ] + }, + { + "teal": 3246, + "source": "examples/reti/stakingPool.algo.ts:814", + "pc": [ + 4325, + 4326 + ] + }, + { + "teal": 3247, + "source": "examples/reti/stakingPool.algo.ts:814", + "pc": [ + 4327 + ] + }, + { + "teal": 3248, + "source": "examples/reti/stakingPool.algo.ts:814", + "pc": [ + 4328 + ] + }, + { + "teal": 3249, + "source": "examples/reti/stakingPool.algo.ts:814", + "pc": [ + 4329 + ] + }, + { + "teal": 3250, + "source": "examples/reti/stakingPool.algo.ts:814", + "pc": [ + 4330, + 4331 + ] + }, + { + "teal": 3254, + "source": "examples/reti/stakingPool.algo.ts:815", + "pc": [ + 4332, + 4333 + ] + }, + { + "teal": 3255, + "source": "examples/reti/stakingPool.algo.ts:815", + "pc": [ + 4334, + 4335 + ] + }, + { + "teal": 3256, + "source": "examples/reti/stakingPool.algo.ts:815", + "pc": [ + 4336 + ] + }, + { + "teal": 3257, + "source": "examples/reti/stakingPool.algo.ts:815", + "pc": [ + 4337, + 4338 + ] + }, + { + "teal": 3263, + "source": "examples/reti/stakingPool.algo.ts:817", + "pc": [ + 4339, + 4340 + ] + }, + { + "teal": 3264, + "source": "examples/reti/stakingPool.algo.ts:817", + "pc": [ + 4341, + 4342 + ] + }, + { + "teal": 3265, + "source": "examples/reti/stakingPool.algo.ts:817", + "pc": [ + 4343 + ] + }, + { + "teal": 3266, + "source": "examples/reti/stakingPool.algo.ts:817", + "pc": [ + 4344, + 4345, + 4346 + ] + }, + { + "teal": 3271, + "source": "examples/reti/stakingPool.algo.ts:818", + "pc": [ + 4347, + 4348 + ] + }, + { + "teal": 3272, + "source": "examples/reti/stakingPool.algo.ts:818", + "pc": [ + 4349, + 4350, + 4351 + ] + }, + { + "teal": 3273, + "source": "examples/reti/stakingPool.algo.ts:818", + "pc": [ + 4352 + ] + }, + { + "teal": 3274, + "source": "examples/reti/stakingPool.algo.ts:818", + "pc": [ + 4353, + 4354 + ] + }, + { + "teal": 3275, + "source": "examples/reti/stakingPool.algo.ts:818", + "pc": [ + 4355 + ] + }, + { + "teal": 3276, + "source": "examples/reti/stakingPool.algo.ts:818", + "pc": [ + 4356, + 4357 + ] + }, + { + "teal": 3277, + "source": "examples/reti/stakingPool.algo.ts:818", + "pc": [ + 4358, + 4359 + ] + }, + { + "teal": 3278, + "source": "examples/reti/stakingPool.algo.ts:818", + "pc": [ + 4360 + ] + }, + { + "teal": 3279, + "source": "examples/reti/stakingPool.algo.ts:818", + "pc": [ + 4361 + ] + }, + { + "teal": 3280, + "source": "examples/reti/stakingPool.algo.ts:818", + "pc": [ + 4362 + ] + }, + { + "teal": 3281, + "source": "examples/reti/stakingPool.algo.ts:818", + "pc": [ + 4363 + ] + }, + { + "teal": 3282, + "source": "examples/reti/stakingPool.algo.ts:818", + "pc": [ + 4364 + ] + }, + { + "teal": 3285, + "source": "examples/reti/stakingPool.algo.ts:818", + "errorMessage": "wideRatio failed", + "pc": [ + 4365 + ] + }, + { + "teal": 3286, + "source": "examples/reti/stakingPool.algo.ts:818", + "pc": [ + 4366, + 4367 + ] + }, + { + "teal": 3290, + "source": "examples/reti/stakingPool.algo.ts:821", + "pc": [ + 4368, + 4369 + ] + }, + { + "teal": 3291, + "source": "examples/reti/stakingPool.algo.ts:821", + "pc": [ + 4370, + 4371 + ] + }, + { + "teal": 3292, + "source": "examples/reti/stakingPool.algo.ts:821", + "pc": [ + 4372, + 4373 + ] + }, + { + "teal": 3293, + "source": "examples/reti/stakingPool.algo.ts:821", + "pc": [ + 4374, + 4375, + 4376 + ] + }, + { + "teal": 3294, + "source": "examples/reti/stakingPool.algo.ts:821", + "pc": [ + 4377 + ] + }, + { + "teal": 3295, + "source": "examples/reti/stakingPool.algo.ts:821", + "pc": [ + 4378, + 4379 + ] + }, + { + "teal": 3296, + "source": "examples/reti/stakingPool.algo.ts:821", + "pc": [ + 4380 + ] + }, + { + "teal": 3297, + "source": "examples/reti/stakingPool.algo.ts:821", + "pc": [ + 4381 + ] + }, + { + "teal": 3298, + "source": "examples/reti/stakingPool.algo.ts:821", + "pc": [ + 4382 + ] + }, + { + "teal": 3299, + "source": "examples/reti/stakingPool.algo.ts:821", + "pc": [ + 4383, + 4384 + ] + }, + { + "teal": 3303, + "source": "examples/reti/stakingPool.algo.ts:822", + "pc": [ + 4385, + 4386 + ] + }, + { + "teal": 3304, + "source": "examples/reti/stakingPool.algo.ts:822", + "pc": [ + 4387, + 4388 + ] + }, + { + "teal": 3305, + "source": "examples/reti/stakingPool.algo.ts:822", + "pc": [ + 4389, + 4390 + ] + }, + { + "teal": 3306, + "source": "examples/reti/stakingPool.algo.ts:822", + "pc": [ + 4391, + 4392, + 4393 + ] + }, + { + "teal": 3307, + "source": "examples/reti/stakingPool.algo.ts:822", + "pc": [ + 4394 + ] + }, + { + "teal": 3308, + "source": "examples/reti/stakingPool.algo.ts:822", + "pc": [ + 4395, + 4396 + ] + }, + { + "teal": 3309, + "source": "examples/reti/stakingPool.algo.ts:822", + "pc": [ + 4397 + ] + }, + { + "teal": 3310, + "source": "examples/reti/stakingPool.algo.ts:822", + "pc": [ + 4398 + ] + }, + { + "teal": 3311, + "source": "examples/reti/stakingPool.algo.ts:822", + "pc": [ + 4399 + ] + }, + { + "teal": 3312, + "source": "examples/reti/stakingPool.algo.ts:822", + "pc": [ + 4400, + 4401 + ] + }, + { + "teal": 3316, + "source": "examples/reti/stakingPool.algo.ts:823", + "pc": [ + 4402, + 4403 + ] + }, + { + "teal": 3317, + "source": "examples/reti/stakingPool.algo.ts:823", + "pc": [ + 4404, + 4405 + ] + }, + { + "teal": 3318, + "source": "examples/reti/stakingPool.algo.ts:823", + "pc": [ + 4406 + ] + }, + { + "teal": 3319, + "source": "examples/reti/stakingPool.algo.ts:823", + "pc": [ + 4407, + 4408 + ] + }, + { + "teal": 3324, + "source": "examples/reti/stakingPool.algo.ts:827", + "pc": [ + 4409, + 4410 + ] + }, + { + "teal": 3325, + "source": "examples/reti/stakingPool.algo.ts:827", + "pc": [ + 4411, + 4412 + ] + }, + { + "teal": 3326, + "source": "examples/reti/stakingPool.algo.ts:827", + "pc": [ + 4413 + ] + }, + { + "teal": 3327, + "source": "examples/reti/stakingPool.algo.ts:827", + "pc": [ + 4414, + 4415 + ] + }, + { + "teal": 3328, + "source": "examples/reti/stakingPool.algo.ts:827", + "pc": [ + 4416, + 4417, + 4418, + 4419, + 4420, + 4421, + 4422, + 4423, + 4424 + ] + }, + { + "teal": 3329, + "source": "examples/reti/stakingPool.algo.ts:827", + "pc": [ + 4425, + 4426 + ] + }, + { + "teal": 3330, + "source": "examples/reti/stakingPool.algo.ts:827", + "pc": [ + 4427 + ] + }, + { + "teal": 3339, + "source": "examples/reti/stakingPool.algo.ts:797", + "pc": [ + 4428, + 4429 + ] + }, + { + "teal": 3340, + "source": "examples/reti/stakingPool.algo.ts:797", + "pc": [ + 4430, + 4431 + ] + }, + { + "teal": 3341, + "source": "examples/reti/stakingPool.algo.ts:797", + "pc": [ + 4432 + ] + }, + { + "teal": 3342, + "source": "examples/reti/stakingPool.algo.ts:797", + "pc": [ + 4433, + 4434 + ] + }, + { + "teal": 3343, + "source": "examples/reti/stakingPool.algo.ts:797", + "pc": [ + 4435, + 4436, + 4437 + ] + }, + { + "teal": 3352, + "source": "examples/reti/stakingPool.algo.ts:837", + "pc": [ + 4438, + 4439, + 4440, + 4441, + 4442, + 4443, + 4444, + 4445, + 4446, + 4447, + 4448, + 4449, + 4450, + 4451, + 4452 + ] + }, + { + "teal": 3353, + "source": "examples/reti/stakingPool.algo.ts:837", + "pc": [ + 4453 + ] + }, + { + "teal": 3354, + "source": "examples/reti/stakingPool.algo.ts:837", + "pc": [ + 4454, + 4455, + 4456, + 4457, + 4458, + 4459, + 4460, + 4461, + 4462, + 4463, + 4464, + 4465, + 4466, + 4467 + ] + }, + { + "teal": 3355, + "source": "examples/reti/stakingPool.algo.ts:837", + "pc": [ + 4468 + ] + }, + { + "teal": 3356, + "source": "examples/reti/stakingPool.algo.ts:837", + "pc": [ + 4469 + ] + }, + { + "teal": 3357, + "source": "examples/reti/stakingPool.algo.ts:837", + "pc": [ + 4470, + 4471 + ] + }, + { + "teal": 3358, + "source": "examples/reti/stakingPool.algo.ts:837", + "pc": [ + 4472 + ] + }, + { + "teal": 3359, + "source": "examples/reti/stakingPool.algo.ts:837", + "pc": [ + 4473, + 4474 + ] + }, + { + "teal": 3363, + "source": "examples/reti/stakingPool.algo.ts:838", + "pc": [ + 4475, + 4476, + 4477, + 4478, + 4479, + 4480, + 4481, + 4482 + ] + }, + { + "teal": 3364, + "source": "examples/reti/stakingPool.algo.ts:838", + "pc": [ + 4483 + ] + }, + { + "teal": 3365, + "source": "examples/reti/stakingPool.algo.ts:838", + "pc": [ + 4484, + 4485 + ] + }, + { + "teal": 3366, + "source": "examples/reti/stakingPool.algo.ts:838", + "pc": [ + 4486 + ] + }, + { + "teal": 3367, + "source": "examples/reti/stakingPool.algo.ts:838", + "pc": [ + 4487, + 4488, + 4489, + 4490, + 4491, + 4492, + 4493, + 4494 + ] + }, + { + "teal": 3368, + "source": "examples/reti/stakingPool.algo.ts:838", + "pc": [ + 4495 + ] + }, + { + "teal": 3369, + "source": "examples/reti/stakingPool.algo.ts:838", + "pc": [ + 4496 + ] + }, + { + "teal": 3374, + "source": "examples/reti/stakingPool.algo.ts:839", + "pc": [ + 4497, + 4498, + 4499, + 4500, + 4501, + 4502, + 4503, + 4504, + 4505, + 4506, + 4507, + 4508, + 4509, + 4510, + 4511, + 4512, + 4513, + 4514 + ] + }, + { + "teal": 3375, + "source": "examples/reti/stakingPool.algo.ts:839", + "pc": [ + 4515 + ] + }, + { + "teal": 3376, + "source": "examples/reti/stakingPool.algo.ts:840", + "pc": [ + 4516 + ] + }, + { + "teal": 3377, + "source": "examples/reti/stakingPool.algo.ts:840", + "pc": [ + 4517, + 4518 + ] + }, + { + "teal": 3378, + "source": "examples/reti/stakingPool.algo.ts:840", + "pc": [ + 4519 + ] + }, + { + "teal": 3379, + "source": "examples/reti/stakingPool.algo.ts:840", + "pc": [ + 4520, + 4521 + ] + }, + { + "teal": 3380, + "source": "examples/reti/stakingPool.algo.ts:840", + "pc": [ + 4522 + ] + }, + { + "teal": 3381, + "source": "examples/reti/stakingPool.algo.ts:840", + "pc": [ + 4523 + ] + }, + { + "teal": 3382, + "source": "examples/reti/stakingPool.algo.ts:840", + "pc": [ + 4524 + ] + }, + { + "teal": 3383, + "source": "examples/reti/stakingPool.algo.ts:840", + "pc": [ + 4525 + ] + }, + { + "teal": 3384, + "source": "examples/reti/stakingPool.algo.ts:840", + "pc": [ + 4526 + ] + }, + { + "teal": 3385, + "source": "examples/reti/stakingPool.algo.ts:840", + "pc": [ + 4527, + 4528, + 4529 + ] + }, + { + "teal": 3386, + "source": "examples/reti/stakingPool.algo.ts:840", + "pc": [ + 4530 + ] + }, + { + "teal": 3389, + "source": "examples/reti/stakingPool.algo.ts:840", + "errorMessage": "this.stakeAccumulator.value + (increasedStake as uint128) * (roundsLeftInBin as uint128) overflowed 128 bits", + "pc": [ + 4531 + ] + }, + { + "teal": 3390, + "source": "examples/reti/stakingPool.algo.ts:840", + "pc": [ + 4532, + 4533, + 4534, + 4535, + 4536, + 4537, + 4538, + 4539, + 4540, + 4541, + 4542, + 4543, + 4544, + 4545, + 4546, + 4547, + 4548, + 4549 + ] + }, + { + "teal": 3391, + "source": "examples/reti/stakingPool.algo.ts:840", + "pc": [ + 4550 + ] + }, + { + "teal": 3392, + "source": "examples/reti/stakingPool.algo.ts:840", + "pc": [ + 4551 + ] + }, + { + "teal": 3393, + "source": "examples/reti/stakingPool.algo.ts:840", + "pc": [ + 4552 + ] + }, + { + "teal": 3394, + "source": "examples/reti/stakingPool.algo.ts:840", + "pc": [ + 4553 + ] + }, + { + "teal": 3395, + "source": "examples/reti/stakingPool.algo.ts:840", + "pc": [ + 4554, + 4555 + ] + }, + { + "teal": 3396, + "source": "examples/reti/stakingPool.algo.ts:840", + "pc": [ + 4556 + ] + }, + { + "teal": 3397, + "source": "examples/reti/stakingPool.algo.ts:840", + "pc": [ + 4557 + ] + }, + { + "teal": 3398, + "source": "examples/reti/stakingPool.algo.ts:840", + "pc": [ + 4558 + ] + }, + { + "teal": 3399, + "source": "examples/reti/stakingPool.algo.ts:839", + "pc": [ + 4559 + ] + }, + { + "teal": 3403, + "source": "examples/reti/stakingPool.algo.ts:841", + "pc": [ + 4560, + 4561, + 4562, + 4563, + 4564, + 4565, + 4566, + 4567, + 4568, + 4569, + 4570, + 4571, + 4572, + 4573, + 4574, + 4575, + 4576, + 4577, + 4578 + ] + }, + { + "teal": 3404, + "source": "examples/reti/stakingPool.algo.ts:841", + "pc": [ + 4579 + ] + }, + { + "teal": 3405, + "source": "examples/reti/stakingPool.algo.ts:841", + "pc": [ + 4580 + ] + }, + { + "teal": 3406, + "source": "examples/reti/stakingPool.algo.ts:841", + "pc": [ + 4581, + 4582 + ] + }, + { + "teal": 3407, + "source": "examples/reti/stakingPool.algo.ts:841", + "pc": [ + 4583 + ] + }, + { + "teal": 3408, + "source": "examples/reti/stakingPool.algo.ts:841", + "pc": [ + 4584 + ] + }, + { + "teal": 3421, + "source": "examples/reti/stakingPool.algo.ts:847", + "pc": [ + 4585 + ] + }, + { + "teal": 3422, + "source": "examples/reti/stakingPool.algo.ts:847", + "pc": [ + 4586, + 4587 + ] + }, + { + "teal": 3423, + "source": "examples/reti/stakingPool.algo.ts:847", + "pc": [ + 4588, + 4589 + ] + }, + { + "teal": 3424, + "source": "examples/reti/stakingPool.algo.ts:847", + "pc": [ + 4590, + 4591, + 4592, + 4593, + 4594, + 4595 + ] + }, + { + "teal": 3425, + "source": "examples/reti/stakingPool.algo.ts:847", + "pc": [ + 4596, + 4597 + ] + }, + { + "teal": 3429, + "source": "examples/reti/stakingPool.algo.ts:848", + "pc": [ + 4598, + 4599, + 4600, + 4601, + 4602, + 4603, + 4604, + 4605, + 4606, + 4607, + 4608, + 4609 + ] + }, + { + "teal": 3430, + "source": "examples/reti/stakingPool.algo.ts:848", + "pc": [ + 4610 + ] + }, + { + "teal": 3431, + "source": "examples/reti/stakingPool.algo.ts:848", + "pc": [ + 4611, + 4612 + ] + }, + { + "teal": 3441, + "source": "examples/reti/stakingPool.algo.ts:850", + "pc": [ + 4613, + 4614, + 4615, + 4616, + 4617, + 4618, + 4619, + 4620, + 4621, + 4622, + 4623, + 4624, + 4625 + ] + }, + { + "teal": 3442, + "source": "examples/reti/stakingPool.algo.ts:850", + "pc": [ + 4626 + ] + }, + { + "teal": 3443, + "source": "examples/reti/stakingPool.algo.ts:850", + "pc": [ + 4627 + ] + }, + { + "teal": 3444, + "source": "examples/reti/stakingPool.algo.ts:850", + "pc": [ + 4628, + 4629, + 4630, + 4631, + 4632, + 4633, + 4634, + 4635 + ] + }, + { + "teal": 3445, + "source": "examples/reti/stakingPool.algo.ts:850", + "pc": [ + 4636 + ] + }, + { + "teal": 3446, + "source": "examples/reti/stakingPool.algo.ts:850", + "pc": [ + 4637 + ] + }, + { + "teal": 3447, + "source": "examples/reti/stakingPool.algo.ts:850", + "pc": [ + 4638 + ] + }, + { + "teal": 3448, + "source": "examples/reti/stakingPool.algo.ts:850", + "pc": [ + 4639, + 4640, + 4641 + ] + }, + { + "teal": 3449, + "source": "examples/reti/stakingPool.algo.ts:850", + "pc": [ + 4642 + ] + }, + { + "teal": 3450, + "source": "examples/reti/stakingPool.algo.ts:850", + "pc": [ + 4643 + ] + }, + { + "teal": 3451, + "source": "examples/reti/stakingPool.algo.ts:850", + "pc": [ + 4644, + 4645 + ] + }, + { + "teal": 3452, + "source": "examples/reti/stakingPool.algo.ts:851", + "pc": [ + 4646, + 4647 + ] + }, + { + "teal": 3453, + "source": "examples/reti/stakingPool.algo.ts:851", + "pc": [ + 4648 + ] + }, + { + "teal": 3454, + "source": "examples/reti/stakingPool.algo.ts:851", + "pc": [ + 4649, + 4650 + ] + }, + { + "teal": 3455, + "source": "examples/reti/stakingPool.algo.ts:852", + "pc": [ + 4651, + 4652 + ] + }, + { + "teal": 3456, + "source": "examples/reti/stakingPool.algo.ts:852", + "pc": [ + 4653 + ] + }, + { + "teal": 3457, + "source": "examples/reti/stakingPool.algo.ts:852", + "pc": [ + 4654, + 4655 + ] + }, + { + "teal": 3458, + "source": "examples/reti/stakingPool.algo.ts:853", + "pc": [ + 4656, + 4657 + ] + }, + { + "teal": 3459, + "source": "examples/reti/stakingPool.algo.ts:853", + "pc": [ + 4658 + ] + }, + { + "teal": 3460, + "source": "examples/reti/stakingPool.algo.ts:853", + "pc": [ + 4659, + 4660 + ] + }, + { + "teal": 3461, + "source": "examples/reti/stakingPool.algo.ts:854", + "pc": [ + 4661, + 4662 + ] + }, + { + "teal": 3462, + "source": "examples/reti/stakingPool.algo.ts:854", + "pc": [ + 4663 + ] + }, + { + "teal": 3463, + "source": "examples/reti/stakingPool.algo.ts:854", + "pc": [ + 4664, + 4665 + ] + }, + { + "teal": 3466, + "source": "examples/reti/stakingPool.algo.ts:847", + "pc": [ + 4666, + 4667 + ] + }, + { + "teal": 3467, + "source": "examples/reti/stakingPool.algo.ts:847", + "pc": [ + 4668, + 4669 + ] + }, + { + "teal": 3470, + "source": "examples/reti/stakingPool.algo.ts:847", + "pc": [ + 4670 + ] + }, + { + "teal": 3471, + "source": "examples/reti/stakingPool.algo.ts:518", + "pc": [ + 4671 + ] + }, + { + "teal": 3476, + "source": "examples/reti/stakingPool.algo.ts:879", + "pc": [ + 4672, + 4673, + 4674 + ] + }, + { + "teal": 3477, + "source": "examples/reti/stakingPool.algo.ts:879", + "pc": [ + 4675 + ] + }, + { + "teal": 3480, + "source": "examples/reti/stakingPool.algo.ts:878", + "pc": [ + 4676, + 4677, + 4678 + ] + }, + { + "teal": 3481, + "source": "examples/reti/stakingPool.algo.ts:878", + "pc": [ + 4679 + ] + }, + { + "teal": 3484, + "source": "examples/reti/stakingPool.algo.ts:877", + "pc": [ + 4680, + 4681, + 4682 + ] + }, + { + "teal": 3485, + "source": "examples/reti/stakingPool.algo.ts:877", + "pc": [ + 4683 + ] + }, + { + "teal": 3488, + "source": "examples/reti/stakingPool.algo.ts:876", + "pc": [ + 4684, + 4685, + 4686 + ] + }, + { + "teal": 3489, + "source": "examples/reti/stakingPool.algo.ts:876", + "pc": [ + 4687, + 4688, + 4689 + ] + }, + { + "teal": 3492, + "source": "examples/reti/stakingPool.algo.ts:875", + "pc": [ + 4690, + 4691, + 4692 + ] + }, + { + "teal": 3493, + "source": "examples/reti/stakingPool.algo.ts:875", + "pc": [ + 4693, + 4694, + 4695 + ] + }, + { + "teal": 3496, + "source": "examples/reti/stakingPool.algo.ts:874", + "pc": [ + 4696, + 4697, + 4698 + ] + }, + { + "teal": 3497, + "source": "examples/reti/stakingPool.algo.ts:874", + "pc": [ + 4699, + 4700, + 4701 + ] + }, + { + "teal": 3500, + "source": "examples/reti/stakingPool.algo.ts:873", + "pc": [ + 4702, + 4703 + ] + }, + { + "teal": 3501, + "source": "examples/reti/stakingPool.algo.ts:873", + "pc": [ + 4704, + 4705 + ] + }, + { + "teal": 3502, + "source": "examples/reti/stakingPool.algo.ts:873", + "pc": [ + 4706 + ] + }, + { + "teal": 3503, + "source": "examples/reti/stakingPool.algo.ts:873", + "pc": [ + 4707 + ] + }, + { + "teal": 3504, + "source": "examples/reti/stakingPool.algo.ts:873", + "pc": [ + 4708, + 4709 + ] + }, + { + "teal": 3505, + "source": "examples/reti/stakingPool.algo.ts:873", + "pc": [ + 4710, + 4711 + ] + }, + { + "teal": 3506, + "source": "examples/reti/stakingPool.algo.ts:873", + "pc": [ + 4712 + ] + }, + { + "teal": 3509, + "source": "examples/reti/stakingPool.algo.ts:873", + "errorMessage": "argument 6 (feePayment) for goOnline must be a pay transaction", + "pc": [ + 4713 + ] + }, + { + "teal": 3512, + "source": "examples/reti/stakingPool.algo.ts:872", + "pc": [ + 4714, + 4715, + 4716 + ] + }, + { + "teal": 3513, + "source": "examples/reti/stakingPool.algo.ts:872", + "pc": [ + 4717, + 4718 + ] + }, + { + "teal": 3514, + "source": "examples/reti/stakingPool.algo.ts:872", + "pc": [ + 4719 + ] + }, + { + "teal": 3530, + "source": "examples/reti/stakingPool.algo.ts:872", + "pc": [ + 4720, + 4721, + 4722 + ] + }, + { + "teal": 3533, + "source": "examples/reti/stakingPool.algo.ts:872", + "pc": [ + 4723, + 4724 + ] + }, + { + "teal": 3537, + "source": "examples/reti/stakingPool.algo.ts:881", + "pc": [ + 4725, + 4726, + 4727 + ] + }, + { + "teal": 3540, + "source": "examples/reti/stakingPool.algo.ts:881", + "errorMessage": "can only be called by owner or manager of validator", + "pc": [ + 4728 + ] + }, + { + "teal": 3544, + "source": "examples/reti/stakingPool.algo.ts:882", + "pc": [ + 4729, + 4730, + 4731 + ] + }, + { + "teal": 3545, + "source": "examples/reti/stakingPool.algo.ts:882", + "pc": [ + 4732, + 4733 + ] + }, + { + "teal": 3550, + "source": "examples/reti/stakingPool.algo.ts:883", + "pc": [ + 4734, + 4735 + ] + }, + { + "teal": 3551, + "source": "examples/reti/stakingPool.algo.ts:883", + "pc": [ + 4736, + 4737 + ] + }, + { + "teal": 3552, + "source": "examples/reti/stakingPool.algo.ts:883", + "pc": [ + 4738, + 4739 + ] + }, + { + "teal": 3553, + "source": "examples/reti/stakingPool.algo.ts:883", + "pc": [ + 4740 + ] + }, + { + "teal": 3556, + "source": "examples/reti/stakingPool.algo.ts:883", + "errorMessage": "transaction verification failed: {\"txn\":\"feePayment\",\"field\":\"receiver\",\"expected\":\"this.app.address\"}", + "pc": [ + 4741 + ] + }, + { + "teal": 3559, + "source": "examples/reti/stakingPool.algo.ts:883", + "pc": [ + 4742, + 4743 + ] + }, + { + "teal": 3560, + "source": "examples/reti/stakingPool.algo.ts:883", + "pc": [ + 4744, + 4745 + ] + }, + { + "teal": 3561, + "source": "examples/reti/stakingPool.algo.ts:883", + "pc": [ + 4746, + 4747 + ] + }, + { + "teal": 3562, + "source": "examples/reti/stakingPool.algo.ts:883", + "pc": [ + 4748 + ] + }, + { + "teal": 3565, + "source": "examples/reti/stakingPool.algo.ts:883", + "errorMessage": "transaction verification failed: {\"txn\":\"feePayment\",\"field\":\"amount\",\"expected\":\"extraFee\"}", + "pc": [ + 4749 + ] + }, + { + "teal": 3577, + "source": "examples/reti/stakingPool.algo.ts:884", + "pc": [ + 4750 + ] + }, + { + "teal": 3578, + "source": "examples/reti/stakingPool.algo.ts:884", + "pc": [ + 4751, + 4752 + ] + }, + { + "teal": 3579, + "source": "examples/reti/stakingPool.algo.ts:884", + "pc": [ + 4753, + 4754 + ] + }, + { + "teal": 3583, + "source": "examples/reti/stakingPool.algo.ts:885", + "pc": [ + 4755, + 4756 + ] + }, + { + "teal": 3584, + "source": "examples/reti/stakingPool.algo.ts:885", + "pc": [ + 4757, + 4758 + ] + }, + { + "teal": 3588, + "source": "examples/reti/stakingPool.algo.ts:886", + "pc": [ + 4759, + 4760 + ] + }, + { + "teal": 3589, + "source": "examples/reti/stakingPool.algo.ts:886", + "pc": [ + 4761, + 4762 + ] + }, + { + "teal": 3593, + "source": "examples/reti/stakingPool.algo.ts:887", + "pc": [ + 4763, + 4764 + ] + }, + { + "teal": 3594, + "source": "examples/reti/stakingPool.algo.ts:887", + "pc": [ + 4765, + 4766 + ] + }, + { + "teal": 3598, + "source": "examples/reti/stakingPool.algo.ts:888", + "pc": [ + 4767, + 4768 + ] + }, + { + "teal": 3599, + "source": "examples/reti/stakingPool.algo.ts:888", + "pc": [ + 4769, + 4770 + ] + }, + { + "teal": 3603, + "source": "examples/reti/stakingPool.algo.ts:889", + "pc": [ + 4771, + 4772 + ] + }, + { + "teal": 3604, + "source": "examples/reti/stakingPool.algo.ts:889", + "pc": [ + 4773, + 4774 + ] + }, + { + "teal": 3608, + "source": "examples/reti/stakingPool.algo.ts:890", + "pc": [ + 4775, + 4776 + ] + }, + { + "teal": 3609, + "source": "examples/reti/stakingPool.algo.ts:890", + "pc": [ + 4777, + 4778 + ] + }, + { + "teal": 3613, + "source": "examples/reti/stakingPool.algo.ts:891", + "pc": [ + 4779, + 4780, + 4781 + ] + }, + { + "teal": 3614, + "source": "examples/reti/stakingPool.algo.ts:891", + "pc": [ + 4782, + 4783 + ] + }, + { + "teal": 3617, + "source": "examples/reti/stakingPool.algo.ts:884", + "pc": [ + 4784 + ] + }, + { + "teal": 3618, + "source": "examples/reti/stakingPool.algo.ts:872", + "pc": [ + 4785 + ] + }, + { + "teal": 3623, + "source": "examples/reti/stakingPool.algo.ts:900", + "pc": [ + 4786, + 4787, + 4788 + ] + }, + { + "teal": 3624, + "source": "examples/reti/stakingPool.algo.ts:900", + "pc": [ + 4789, + 4790 + ] + }, + { + "teal": 3625, + "source": "examples/reti/stakingPool.algo.ts:900", + "pc": [ + 4791 + ] + }, + { + "teal": 3632, + "source": "examples/reti/stakingPool.algo.ts:900", + "pc": [ + 4792, + 4793, + 4794 + ] + }, + { + "teal": 3637, + "source": "examples/reti/stakingPool.algo.ts:903", + "pc": [ + 4795, + 4796 + ] + }, + { + "teal": 3638, + "source": "examples/reti/stakingPool.algo.ts:903", + "pc": [ + 4797, + 4798, + 4799, + 4800, + 4801, + 4802, + 4803, + 4804, + 4805, + 4806, + 4807, + 4808 + ] + }, + { + "teal": 3639, + "source": "examples/reti/stakingPool.algo.ts:903", + "pc": [ + 4809 + ] + }, + { + "teal": 3640, + "source": "examples/reti/stakingPool.algo.ts:903", + "pc": [ + 4810, + 4811 + ] + }, + { + "teal": 3641, + "source": "examples/reti/stakingPool.algo.ts:903", + "pc": [ + 4812 + ] + }, + { + "teal": 3642, + "source": "examples/reti/stakingPool.algo.ts:903", + "pc": [ + 4813 + ] + }, + { + "teal": 3643, + "source": "examples/reti/stakingPool.algo.ts:903", + "pc": [ + 4814, + 4815, + 4816 + ] + }, + { + "teal": 3648, + "source": "examples/reti/stakingPool.algo.ts:904", + "pc": [ + 4817, + 4818, + 4819 + ] + }, + { + "teal": 3651, + "source": "examples/reti/stakingPool.algo.ts:904", + "errorMessage": "can only be called by owner or manager of validator", + "pc": [ + 4820 + ] + }, + { + "teal": 3656, + "source": "examples/reti/stakingPool.algo.ts:907", + "pc": [ + 4821 + ] + }, + { + "teal": 3657, + "source": "examples/reti/stakingPool.algo.ts:907", + "pc": [ + 4822, + 4823 + ] + }, + { + "teal": 3658, + "source": "examples/reti/stakingPool.algo.ts:907", + "pc": [ + 4824, + 4825 + ] + }, + { + "teal": 3661, + "source": "examples/reti/stakingPool.algo.ts:907", + "pc": [ + 4826, + 4827 + ] + }, + { + "teal": 3662, + "source": "examples/reti/stakingPool.algo.ts:907", + "pc": [ + 4828, + 4829 + ] + }, + { + "teal": 3665, + "source": "examples/reti/stakingPool.algo.ts:907", + "pc": [ + 4830 + ] + }, + { + "teal": 3666, + "source": "examples/reti/stakingPool.algo.ts:900", + "pc": [ + 4831 + ] + }, + { + "teal": 3671, + "source": "examples/reti/stakingPool.algo.ts:913", + "pc": [ + 4832, + 4833, + 4834 + ] + }, + { + "teal": 3672, + "source": "examples/reti/stakingPool.algo.ts:913", + "pc": [ + 4835, + 4836, + 4837 + ] + }, + { + "teal": 3675, + "source": "examples/reti/stakingPool.algo.ts:913", + "pc": [ + 4838, + 4839, + 4840 + ] + }, + { + "teal": 3676, + "source": "examples/reti/stakingPool.algo.ts:913", + "pc": [ + 4841 + ] + }, + { + "teal": 3679, + "source": "examples/reti/stakingPool.algo.ts:913", + "pc": [ + 4842, + 4843, + 4844 + ] + }, + { + "teal": 3680, + "source": "examples/reti/stakingPool.algo.ts:913", + "pc": [ + 4845, + 4846 + ] + }, + { + "teal": 3681, + "source": "examples/reti/stakingPool.algo.ts:913", + "pc": [ + 4847 + ] + }, + { + "teal": 3685, + "source": "examples/reti/stakingPool.algo.ts:913", + "pc": [ + 4848, + 4849, + 4850 + ] + }, + { + "teal": 3689, + "source": "examples/reti/stakingPool.algo.ts:914", + "pc": [ + 4851, + 4852, + 4853 + ] + }, + { + "teal": 3692, + "source": "examples/reti/stakingPool.algo.ts:914", + "errorMessage": "can only be called by owner or manager of validator", + "pc": [ + 4854 + ] + }, + { + "teal": 3700, + "source": "examples/reti/stakingPool.algo.ts:916", + "pc": [ + 4855 + ] + }, + { + "teal": 3701, + "source": "examples/reti/stakingPool.algo.ts:916", + "pc": [ + 4856, + 4857 + ] + }, + { + "teal": 3702, + "source": "examples/reti/stakingPool.algo.ts:916", + "pc": [ + 4858, + 4859 + ] + }, + { + "teal": 3706, + "source": "examples/reti/stakingPool.algo.ts:917", + "pc": [ + 4860 + ] + }, + { + "teal": 3707, + "source": "examples/reti/stakingPool.algo.ts:917", + "pc": [ + 4861, + 4862 + ] + }, + { + "teal": 3711, + "source": "examples/reti/stakingPool.algo.ts:918", + "pc": [ + 4863, + 4864, + 4865, + 4866, + 4867, + 4868, + 4869, + 4870, + 4871, + 4872, + 4873, + 4874, + 4875, + 4876, + 4877, + 4878, + 4879 + ] + }, + { + "teal": 3712, + "source": "examples/reti/stakingPool.algo.ts:918", + "pc": [ + 4880, + 4881 + ] + }, + { + "teal": 3713, + "source": "examples/reti/stakingPool.algo.ts:918", + "pc": [ + 4882, + 4883 + ] + }, + { + "teal": 3714, + "source": "examples/reti/stakingPool.algo.ts:918", + "pc": [ + 4884, + 4885 + ] + }, + { + "teal": 3715, + "source": "examples/reti/stakingPool.algo.ts:918", + "pc": [ + 4886, + 4887 + ] + }, + { + "teal": 3716, + "source": "examples/reti/stakingPool.algo.ts:918", + "pc": [ + 4888 + ] + }, + { + "teal": 3717, + "source": "examples/reti/stakingPool.algo.ts:918", + "pc": [ + 4889, + 4890 + ] + }, + { + "teal": 3718, + "source": "examples/reti/stakingPool.algo.ts:918", + "pc": [ + 4891, + 4892 + ] + }, + { + "teal": 3719, + "source": "examples/reti/stakingPool.algo.ts:918", + "pc": [ + 4893, + 4894 + ] + }, + { + "teal": 3723, + "source": "examples/reti/stakingPool.algo.ts:919", + "pc": [ + 4895, + 4896 + ] + }, + { + "teal": 3724, + "source": "examples/reti/stakingPool.algo.ts:919", + "pc": [ + 4897, + 4898 + ] + }, + { + "teal": 3727, + "source": "examples/reti/stakingPool.algo.ts:916", + "pc": [ + 4899, + 4900 + ] + }, + { + "teal": 3728, + "source": "examples/reti/stakingPool.algo.ts:916", + "pc": [ + 4901, + 4902 + ] + }, + { + "teal": 3731, + "source": "examples/reti/stakingPool.algo.ts:916", + "pc": [ + 4903 + ] + }, + { + "teal": 3732, + "source": "examples/reti/stakingPool.algo.ts:913", + "pc": [ + 4904 + ] + }, + { + "teal": 3737, + "source": "examples/reti/stakingPool.algo.ts:929", + "pc": [ + 4905, + 4906, + 4907, + 4908, + 4909, + 4910 + ] + }, + { + "teal": 3740, + "source": "examples/reti/stakingPool.algo.ts:929", + "pc": [ + 4911, + 4912, + 4913 + ] + }, + { + "teal": 3741, + "source": "examples/reti/stakingPool.algo.ts:929", + "pc": [ + 4914 + ] + }, + { + "teal": 3742, + "source": "examples/reti/stakingPool.algo.ts:929", + "pc": [ + 4915 + ] + }, + { + "teal": 3743, + "source": "examples/reti/stakingPool.algo.ts:929", + "pc": [ + 4916, + 4917 + ] + }, + { + "teal": 3744, + "source": "examples/reti/stakingPool.algo.ts:929", + "pc": [ + 4918 + ] + }, + { + "teal": 3747, + "source": "examples/reti/stakingPool.algo.ts:929", + "errorMessage": "argument 0 (poolKey) for proxiedSetTokenPayoutRatio must be a (uint64,uint64,uint64)", + "pc": [ + 4919 + ] + }, + { + "teal": 3750, + "source": "examples/reti/stakingPool.algo.ts:929", + "pc": [ + 4920, + 4921, + 4922 + ] + }, + { + "teal": 3751, + "source": "examples/reti/stakingPool.algo.ts:929", + "pc": [ + 4923 + ] + }, + { + "teal": 3752, + "source": "examples/reti/stakingPool.algo.ts:929", + "pc": [ + 4924 + ] + }, + { + "teal": 3753, + "source": "examples/reti/stakingPool.algo.ts:929", + "pc": [ + 4925, + 4926 + ] + }, + { + "teal": 3754, + "source": "examples/reti/stakingPool.algo.ts:929", + "pc": [ + 4927 + ] + }, + { + "teal": 3763, + "source": "examples/reti/stakingPool.algo.ts:929", + "pc": [ + 4928, + 4929, + 4930 + ] + }, + { + "teal": 3766, + "source": "examples/reti/stakingPool.algo.ts:929", + "pc": [ + 4931, + 4932 + ] + }, + { + "teal": 3770, + "source": "examples/reti/stakingPool.algo.ts:930", + "pc": [ + 4933, + 4934, + 4935, + 4936, + 4937, + 4938, + 4939, + 4940, + 4941, + 4942, + 4943, + 4944, + 4945 + ] + }, + { + "teal": 3771, + "source": "examples/reti/stakingPool.algo.ts:930", + "pc": [ + 4946 + ] + }, + { + "teal": 3772, + "source": "examples/reti/stakingPool.algo.ts:930", + "pc": [ + 4947, + 4948 + ] + }, + { + "teal": 3773, + "source": "examples/reti/stakingPool.algo.ts:930", + "pc": [ + 4949, + 4950, + 4951 + ] + }, + { + "teal": 3774, + "source": "examples/reti/stakingPool.algo.ts:930", + "pc": [ + 4952 + ] + }, + { + "teal": 3775, + "source": "examples/reti/stakingPool.algo.ts:930", + "pc": [ + 4953 + ] + }, + { + "teal": 3778, + "source": "examples/reti/stakingPool.algo.ts:930", + "errorMessage": "caller must be part of same validator set!", + "pc": [ + 4954 + ] + }, + { + "teal": 3782, + "source": "examples/reti/stakingPool.algo.ts:931", + "pc": [ + 4955, + 4956, + 4957, + 4958, + 4959, + 4960, + 4961, + 4962 + ] + }, + { + "teal": 3783, + "source": "examples/reti/stakingPool.algo.ts:931", + "pc": [ + 4963 + ] + }, + { + "teal": 3784, + "source": "examples/reti/stakingPool.algo.ts:931", + "pc": [ + 4964, + 4965 + ] + }, + { + "teal": 3785, + "source": "examples/reti/stakingPool.algo.ts:931", + "pc": [ + 4966 + ] + }, + { + "teal": 3788, + "source": "examples/reti/stakingPool.algo.ts:931", + "errorMessage": "callee must be pool 1", + "pc": [ + 4967 + ] + }, + { + "teal": 3792, + "source": "examples/reti/stakingPool.algo.ts:932", + "pc": [ + 4968, + 4969 + ] + }, + { + "teal": 3793, + "source": "examples/reti/stakingPool.algo.ts:932", + "pc": [ + 4970, + 4971, + 4972 + ] + }, + { + "teal": 3794, + "source": "examples/reti/stakingPool.algo.ts:932", + "pc": [ + 4973 + ] + }, + { + "teal": 3795, + "source": "examples/reti/stakingPool.algo.ts:932", + "pc": [ + 4974, + 4975 + ] + }, + { + "teal": 3796, + "source": "examples/reti/stakingPool.algo.ts:932", + "pc": [ + 4976 + ] + }, + { + "teal": 3799, + "source": "examples/reti/stakingPool.algo.ts:932", + "errorMessage": "caller must NOT be pool 1", + "pc": [ + 4977 + ] + }, + { + "teal": 3806, + "source": "examples/reti/stakingPool.algo.ts:934", + "pc": [ + 4978 + ] + }, + { + "teal": 3807, + "source": "examples/reti/stakingPool.algo.ts:934", + "pc": [ + 4979, + 4980 + ] + }, + { + "teal": 3808, + "source": "examples/reti/stakingPool.algo.ts:934", + "pc": [ + 4981, + 4982 + ] + }, + { + "teal": 3809, + "source": "examples/reti/stakingPool.algo.ts:934", + "pc": [ + 4983, + 4984, + 4985, + 4986, + 4987, + 4988 + ] + }, + { + "teal": 3810, + "source": "examples/reti/stakingPool.algo.ts:934", + "pc": [ + 4989, + 4990 + ] + }, + { + "teal": 3814, + "source": "examples/reti/stakingPool.algo.ts:935", + "pc": [ + 4991, + 4992, + 4993, + 4994, + 4995, + 4996, + 4997, + 4998, + 4999, + 5000, + 5001, + 5002 + ] + }, + { + "teal": 3815, + "source": "examples/reti/stakingPool.algo.ts:935", + "pc": [ + 5003 + ] + }, + { + "teal": 3816, + "source": "examples/reti/stakingPool.algo.ts:935", + "pc": [ + 5004, + 5005 + ] + }, + { + "teal": 3820, + "source": "examples/reti/stakingPool.algo.ts:936", + "pc": [ + 5006, + 5007 + ] + }, + { + "teal": 3821, + "source": "examples/reti/stakingPool.algo.ts:936", + "pc": [ + 5008, + 5009, + 5010 + ] + }, + { + "teal": 3822, + "source": "examples/reti/stakingPool.algo.ts:936", + "pc": [ + 5011 + ] + }, + { + "teal": 3823, + "source": "examples/reti/stakingPool.algo.ts:936", + "pc": [ + 5012 + ] + }, + { + "teal": 3824, + "source": "examples/reti/stakingPool.algo.ts:936", + "pc": [ + 5013, + 5014 + ] + }, + { + "teal": 3825, + "source": "examples/reti/stakingPool.algo.ts:936", + "pc": [ + 5015, + 5016 + ] + }, + { + "teal": 3826, + "source": "examples/reti/stakingPool.algo.ts:936", + "pc": [ + 5017, + 5018, + 5019 + ] + }, + { + "teal": 3827, + "source": "examples/reti/stakingPool.algo.ts:936", + "pc": [ + 5020 + ] + }, + { + "teal": 3828, + "source": "examples/reti/stakingPool.algo.ts:936", + "pc": [ + 5021 + ] + }, + { + "teal": 3829, + "source": "examples/reti/stakingPool.algo.ts:936", + "pc": [ + 5022, + 5023 + ] + }, + { + "teal": 3832, + "source": "examples/reti/stakingPool.algo.ts:934", + "pc": [ + 5024, + 5025 + ] + }, + { + "teal": 3833, + "source": "examples/reti/stakingPool.algo.ts:934", + "pc": [ + 5026, + 5027 + ] + }, + { + "teal": 3836, + "source": "examples/reti/stakingPool.algo.ts:934", + "pc": [ + 5028 + ] + }, + { + "teal": 3837, + "source": "examples/reti/stakingPool.algo.ts:934", + "pc": [ + 5029, + 5030 + ] + }, + { + "teal": 3838, + "source": "examples/reti/stakingPool.algo.ts:934", + "pc": [ + 5031, + 5032 + ] + }, + { + "teal": 3839, + "source": "examples/reti/stakingPool.algo.ts:934", + "pc": [ + 5033 + ] + }, + { + "teal": 3840, + "source": "examples/reti/stakingPool.algo.ts:934", + "pc": [ + 5034, + 5035 + ] + }, + { + "teal": 3841, + "source": "examples/reti/stakingPool.algo.ts:934", + "pc": [ + 5036, + 5037, + 5038 + ] + }, + { + "teal": 3842, + "source": "examples/reti/stakingPool.algo.ts:934", + "pc": [ + 5039 + ] + }, + { + "teal": 3843, + "source": "examples/reti/stakingPool.algo.ts:934", + "pc": [ + 5040, + 5041 + ] + }, + { + "teal": 3847, + "source": "examples/reti/stakingPool.algo.ts:938", + "pc": [ + 5042, + 5043 + ] + }, + { + "teal": 3848, + "source": "examples/reti/stakingPool.algo.ts:938", + "pc": [ + 5044, + 5045 + ] + }, + { + "teal": 3849, + "source": "examples/reti/stakingPool.algo.ts:938", + "pc": [ + 5046, + 5047, + 5048 + ] + }, + { + "teal": 3850, + "source": "examples/reti/stakingPool.algo.ts:938", + "pc": [ + 5049 + ] + }, + { + "teal": 3851, + "source": "examples/reti/stakingPool.algo.ts:938", + "pc": [ + 5050 + ] + }, + { + "teal": 3852, + "source": "examples/reti/stakingPool.algo.ts:938", + "pc": [ + 5051 + ] + }, + { + "teal": 3856, + "source": "examples/reti/stakingPool.algo.ts:939", + "pc": [ + 5052, + 5053 + ] + }, + { + "teal": 3857, + "source": "examples/reti/stakingPool.algo.ts:939", + "pc": [ + 5054, + 5055 + ] + }, + { + "teal": 3858, + "source": "examples/reti/stakingPool.algo.ts:939", + "pc": [ + 5056, + 5057, + 5058 + ] + }, + { + "teal": 3859, + "source": "examples/reti/stakingPool.algo.ts:939", + "pc": [ + 5059 + ] + }, + { + "teal": 3860, + "source": "examples/reti/stakingPool.algo.ts:939", + "pc": [ + 5060, + 5061 + ] + }, + { + "teal": 3861, + "source": "examples/reti/stakingPool.algo.ts:939", + "pc": [ + 5062 + ] + }, + { + "teal": 3862, + "source": "examples/reti/stakingPool.algo.ts:939", + "pc": [ + 5063 + ] + }, + { + "teal": 3863, + "source": "examples/reti/stakingPool.algo.ts:939", + "pc": [ + 5064 + ] + }, + { + "teal": 3870, + "source": "examples/reti/stakingPool.algo.ts:941", + "pc": [ + 5065 + ] + }, + { + "teal": 3871, + "source": "examples/reti/stakingPool.algo.ts:941", + "pc": [ + 5066, + 5067 + ] + }, + { + "teal": 3872, + "source": "examples/reti/stakingPool.algo.ts:941", + "pc": [ + 5068, + 5069 + ] + }, + { + "teal": 3873, + "source": "examples/reti/stakingPool.algo.ts:941", + "pc": [ + 5070, + 5071, + 5072, + 5073, + 5074, + 5075 + ] + }, + { + "teal": 3874, + "source": "examples/reti/stakingPool.algo.ts:941", + "pc": [ + 5076, + 5077 + ] + }, + { + "teal": 3878, + "source": "examples/reti/stakingPool.algo.ts:942", + "pc": [ + 5078, + 5079, + 5080, + 5081, + 5082, + 5083, + 5084, + 5085, + 5086, + 5087, + 5088, + 5089 + ] + }, + { + "teal": 3879, + "source": "examples/reti/stakingPool.algo.ts:942", + "pc": [ + 5090 + ] + }, + { + "teal": 3880, + "source": "examples/reti/stakingPool.algo.ts:942", + "pc": [ + 5091, + 5092 + ] + }, + { + "teal": 3884, + "source": "examples/reti/stakingPool.algo.ts:943", + "pc": [ + 5093, + 5094, + 5095, + 5096, + 5097, + 5098, + 5099, + 5100, + 5101, + 5102, + 5103, + 5104, + 5105 + ] + }, + { + "teal": 3885, + "source": "examples/reti/stakingPool.algo.ts:943", + "pc": [ + 5106 + ] + }, + { + "teal": 3886, + "source": "examples/reti/stakingPool.algo.ts:943", + "pc": [ + 5107 + ] + }, + { + "teal": 3887, + "source": "examples/reti/stakingPool.algo.ts:943", + "pc": [ + 5108, + 5109 + ] + }, + { + "teal": 3890, + "source": "examples/reti/stakingPool.algo.ts:941", + "pc": [ + 5110, + 5111 + ] + }, + { + "teal": 3891, + "source": "examples/reti/stakingPool.algo.ts:941", + "pc": [ + 5112, + 5113 + ] + }, + { + "teal": 3894, + "source": "examples/reti/stakingPool.algo.ts:941", + "pc": [ + 5114 + ] + }, + { + "teal": 3895, + "source": "examples/reti/stakingPool.algo.ts:941", + "pc": [ + 5115, + 5116 + ] + }, + { + "teal": 3896, + "source": "examples/reti/stakingPool.algo.ts:941", + "pc": [ + 5117, + 5118 + ] + }, + { + "teal": 3897, + "source": "examples/reti/stakingPool.algo.ts:941", + "pc": [ + 5119 + ] + }, + { + "teal": 3898, + "source": "examples/reti/stakingPool.algo.ts:941", + "pc": [ + 5120, + 5121 + ] + }, + { + "teal": 3899, + "source": "examples/reti/stakingPool.algo.ts:941", + "pc": [ + 5122, + 5123, + 5124 + ] + }, + { + "teal": 3902, + "source": "examples/reti/stakingPool.algo.ts:929", + "pc": [ + 5125, + 5126 + ] + }, + { + "teal": 3903, + "source": "examples/reti/stakingPool.algo.ts:929", + "pc": [ + 5127 + ] + }, + { + "teal": 3907, + "source": "examples/reti/stakingPool.algo.ts:947", + "pc": [ + 5128, + 5129, + 5130 + ] + }, + { + "teal": 3910, + "source": "examples/reti/stakingPool.algo.ts:947", + "pc": [ + 5131, + 5132 + ] + }, + { + "teal": 3917, + "source": "examples/reti/stakingPool.algo.ts:948", + "pc": [ + 5133 + ] + }, + { + "teal": 3918, + "source": "examples/reti/stakingPool.algo.ts:948", + "pc": [ + 5134, + 5135 + ] + }, + { + "teal": 3919, + "source": "examples/reti/stakingPool.algo.ts:948", + "pc": [ + 5136, + 5137 + ] + }, + { + "teal": 3920, + "source": "examples/reti/stakingPool.algo.ts:948", + "pc": [ + 5138, + 5139, + 5140, + 5141, + 5142, + 5143 + ] + }, + { + "teal": 3921, + "source": "examples/reti/stakingPool.algo.ts:948", + "pc": [ + 5144, + 5145 + ] + }, + { + "teal": 3925, + "source": "examples/reti/stakingPool.algo.ts:949", + "pc": [ + 5146, + 5147, + 5148, + 5149, + 5150, + 5151, + 5152, + 5153, + 5154, + 5155, + 5156, + 5157 + ] + }, + { + "teal": 3926, + "source": "examples/reti/stakingPool.algo.ts:949", + "pc": [ + 5158 + ] + }, + { + "teal": 3927, + "source": "examples/reti/stakingPool.algo.ts:949", + "pc": [ + 5159, + 5160 + ] + }, + { + "teal": 3931, + "source": "examples/reti/stakingPool.algo.ts:950", + "pc": [ + 5161, + 5162, + 5163, + 5164, + 5165, + 5166, + 5167, + 5168, + 5169, + 5170, + 5171, + 5172, + 5173 + ] + }, + { + "teal": 3932, + "source": "examples/reti/stakingPool.algo.ts:950", + "pc": [ + 5174 + ] + }, + { + "teal": 3933, + "source": "examples/reti/stakingPool.algo.ts:950", + "pc": [ + 5175 + ] + }, + { + "teal": 3934, + "source": "examples/reti/stakingPool.algo.ts:950", + "pc": [ + 5176, + 5177 + ] + }, + { + "teal": 3937, + "source": "examples/reti/stakingPool.algo.ts:948", + "pc": [ + 5178, + 5179 + ] + }, + { + "teal": 3938, + "source": "examples/reti/stakingPool.algo.ts:948", + "pc": [ + 5180, + 5181 + ] + }, + { + "teal": 3941, + "source": "examples/reti/stakingPool.algo.ts:948", + "pc": [ + 5182 + ] + }, + { + "teal": 3942, + "source": "examples/reti/stakingPool.algo.ts:948", + "pc": [ + 5183, + 5184 + ] + }, + { + "teal": 3943, + "source": "examples/reti/stakingPool.algo.ts:948", + "pc": [ + 5185, + 5186 + ] + }, + { + "teal": 3944, + "source": "examples/reti/stakingPool.algo.ts:948", + "pc": [ + 5187 + ] + }, + { + "teal": 3945, + "source": "examples/reti/stakingPool.algo.ts:948", + "pc": [ + 5188, + 5189 + ] + }, + { + "teal": 3946, + "source": "examples/reti/stakingPool.algo.ts:948", + "pc": [ + 5190, + 5191, + 5192 + ] + }, + { + "teal": 3947, + "source": "examples/reti/stakingPool.algo.ts:948", + "pc": [ + 5193, + 5194 + ] + }, + { + "teal": 3951, + "source": "examples/reti/stakingPool.algo.ts:952", + "pc": [ + 5195, + 5196 + ] + }, + { + "teal": 3952, + "source": "examples/reti/stakingPool.algo.ts:952", + "pc": [ + 5197, + 5198 + ] + }, + { + "teal": 3953, + "source": "examples/reti/stakingPool.algo.ts:952", + "pc": [ + 5199, + 5200, + 5201 + ] + }, + { + "teal": 3954, + "source": "examples/reti/stakingPool.algo.ts:952", + "pc": [ + 5202 + ] + }, + { + "teal": 3955, + "source": "examples/reti/stakingPool.algo.ts:952", + "pc": [ + 5203 + ] + }, + { + "teal": 3956, + "source": "examples/reti/stakingPool.algo.ts:952", + "pc": [ + 5204, + 5205, + 5206 + ] + }, + { + "teal": 3957, + "source": "examples/reti/stakingPool.algo.ts:952", + "pc": [ + 5207, + 5208 + ] + }, + { + "teal": 3958, + "source": "examples/reti/stakingPool.algo.ts:952", + "pc": [ + 5209, + 5210 + ] + }, + { + "teal": 3959, + "source": "examples/reti/stakingPool.algo.ts:952", + "pc": [ + 5211, + 5212, + 5213 + ] + }, + { + "teal": 3960, + "source": "examples/reti/stakingPool.algo.ts:952", + "pc": [ + 5214 + ] + }, + { + "teal": 3961, + "source": "examples/reti/stakingPool.algo.ts:952", + "pc": [ + 5215 + ] + }, + { + "teal": 3965, + "source": "examples/reti/stakingPool.algo.ts:947", + "pc": [ + 5216, + 5217 + ] + }, + { + "teal": 3966, + "source": "examples/reti/stakingPool.algo.ts:947", + "pc": [ + 5218 + ] + }, + { + "teal": 3970, + "source": "examples/reti/stakingPool.algo.ts:955", + "pc": [ + 5219, + 5220, + 5221 + ] + }, + { + "teal": 3974, + "source": "examples/reti/stakingPool.algo.ts:956", + "pc": [ + 5222 + ] + }, + { + "teal": 3975, + "source": "examples/reti/stakingPool.algo.ts:955", + "pc": [ + 5223 + ] + }, + { + "teal": 3982, + "source": "examples/reti/stakingPool.algo.ts:965", + "pc": [ + 5224, + 5225, + 5226 + ] + }, + { + "teal": 3985, + "source": "examples/reti/stakingPool.algo.ts:965", + "pc": [ + 5227, + 5228 + ] + }, + { + "teal": 3989, + "source": "examples/reti/stakingPool.algo.ts:966", + "pc": [ + 5229, + 5230, + 5231 + ] + }, + { + "teal": 3990, + "source": "examples/reti/stakingPool.algo.ts:966", + "pc": [ + 5232, + 5233 + ] + }, + { + "teal": 3994, + "source": "examples/reti/stakingPool.algo.ts:968", + "pc": [ + 5234, + 5235 + ] + }, + { + "teal": 3995, + "source": "examples/reti/stakingPool.algo.ts:968", + "pc": [ + 5236, + 5237 + ] + }, + { + "teal": 3996, + "source": "examples/reti/stakingPool.algo.ts:968", + "pc": [ + 5238 + ] + }, + { + "teal": 3997, + "source": "examples/reti/stakingPool.algo.ts:968", + "pc": [ + 5239, + 5240 + ] + }, + { + "teal": 3998, + "source": "examples/reti/stakingPool.algo.ts:968", + "pc": [ + 5241, + 5242, + 5243 + ] + }, + { + "teal": 3999, + "source": "examples/reti/stakingPool.algo.ts:968", + "pc": [ + 5244 + ] + }, + { + "teal": 4000, + "source": "examples/reti/stakingPool.algo.ts:968", + "pc": [ + 5245 + ] + }, + { + "teal": 4001, + "source": "examples/reti/stakingPool.algo.ts:968", + "pc": [ + 5246 + ] + }, + { + "teal": 4002, + "source": "examples/reti/stakingPool.algo.ts:968", + "pc": [ + 5247 + ] + }, + { + "teal": 4003, + "source": "examples/reti/stakingPool.algo.ts:968", + "pc": [ + 5248 + ] + }, + { + "teal": 4006, + "source": "examples/reti/stakingPool.algo.ts:968", + "errorMessage": "wideRatio failed", + "pc": [ + 5249 + ] + }, + { + "teal": 4009, + "source": "examples/reti/stakingPool.algo.ts:965", + "pc": [ + 5250, + 5251 + ] + }, + { + "teal": 4010, + "source": "examples/reti/stakingPool.algo.ts:965", + "pc": [ + 5252 + ] + }, + { + "teal": 4014, + "source": "examples/reti/stakingPool.algo.ts:971", + "pc": [ + 5253, + 5254, + 5255 + ] + }, + { + "teal": 4017, + "source": "examples/reti/stakingPool.algo.ts:971", + "pc": [ + 5256, + 5257 + ] + }, + { + "teal": 4021, + "source": "examples/reti/stakingPool.algo.ts:975", + "pc": [ + 5258, + 5259 + ] + }, + { + "teal": 4022, + "source": "examples/reti/stakingPool.algo.ts:975", + "pc": [ + 5260, + 5261 + ] + }, + { + "teal": 4027, + "source": "examples/reti/stakingPool.algo.ts:976", + "pc": [ + 5262, + 5263 + ] + }, + { + "teal": 4028, + "source": "examples/reti/stakingPool.algo.ts:976", + "pc": [ + 5264 + ] + }, + { + "teal": 4029, + "source": "examples/reti/stakingPool.algo.ts:976", + "pc": [ + 5265, + 5266, + 5267 + ] + }, + { + "teal": 4034, + "source": "examples/reti/stakingPool.algo.ts:978", + "pc": [ + 5268, + 5269, + 5270, + 5271 + ] + }, + { + "teal": 4035, + "source": "examples/reti/stakingPool.algo.ts:978", + "pc": [ + 5272, + 5273, + 5274 + ] + }, + { + "teal": 4040, + "source": "examples/reti/stakingPool.algo.ts:980", + "pc": [ + 5275, + 5276 + ] + }, + { + "teal": 4044, + "source": "examples/reti/stakingPool.algo.ts:971", + "pc": [ + 5277, + 5278 + ] + }, + { + "teal": 4045, + "source": "examples/reti/stakingPool.algo.ts:971", + "pc": [ + 5279 + ] + }, + { + "teal": 4049, + "source": "examples/reti/stakingPool.algo.ts:983", + "pc": [ + 5280, + 5281, + 5282 + ] + }, + { + "teal": 4053, + "source": "examples/reti/stakingPool.algo.ts:985", + "pc": [ + 5283, + 5284, + 5285, + 5286, + 5287, + 5288, + 5289, + 5290, + 5291 + ] + }, + { + "teal": 4054, + "source": "examples/reti/stakingPool.algo.ts:983", + "pc": [ + 5292 + ] + }, + { + "teal": 4060, + "source": "examples/reti/stakingPool.algo.ts:991", + "pc": [ + 5293, + 5294, + 5295 + ] + }, + { + "teal": 4063, + "source": "examples/reti/stakingPool.algo.ts:991", + "pc": [ + 5296, + 5297 + ] + }, + { + "teal": 4064, + "source": "examples/reti/stakingPool.algo.ts:991", + "pc": [ + 5298, + 5299 + ] + }, + { + "teal": 4068, + "source": "examples/reti/stakingPool.algo.ts:992", + "pc": [ + 5300, + 5301, + 5302, + 5303, + 5304, + 5305, + 5306, + 5307, + 5308, + 5309, + 5310, + 5311, + 5312, + 5313 + ] + }, + { + "teal": 4069, + "source": "examples/reti/stakingPool.algo.ts:992", + "pc": [ + 5314 + ] + }, + { + "teal": 4070, + "source": "examples/reti/stakingPool.algo.ts:992", + "pc": [ + 5315 + ] + }, + { + "teal": 4071, + "source": "examples/reti/stakingPool.algo.ts:992", + "pc": [ + 5316, + 5317 + ] + }, + { + "teal": 4076, + "source": "examples/reti/stakingPool.algo.ts:993", + "pc": [ + 5318, + 5319 + ] + }, + { + "teal": 4077, + "source": "examples/reti/stakingPool.algo.ts:993", + "pc": [ + 5320, + 5321, + 5322, + 5323, + 5324, + 5325, + 5326, + 5327, + 5328, + 5329, + 5330, + 5331, + 5332, + 5333, + 5334 + ] + }, + { + "teal": 4078, + "source": "examples/reti/stakingPool.algo.ts:993", + "pc": [ + 5335 + ] + }, + { + "teal": 4079, + "source": "examples/reti/stakingPool.algo.ts:993", + "pc": [ + 5336, + 5337 + ] + }, + { + "teal": 4080, + "source": "examples/reti/stakingPool.algo.ts:993", + "pc": [ + 5338 + ] + }, + { + "teal": 4081, + "source": "examples/reti/stakingPool.algo.ts:993", + "pc": [ + 5339 + ] + }, + { + "teal": 4082, + "source": "examples/reti/stakingPool.algo.ts:993", + "pc": [ + 5340, + 5341 + ] + }, + { + "teal": 4083, + "source": "examples/reti/stakingPool.algo.ts:993", + "pc": [ + 5342 + ] + }, + { + "teal": 4086, + "source": "examples/reti/stakingPool.algo.ts:993", + "errorMessage": "currentBinSize as uint64 overflowed 64 bits", + "pc": [ + 5343 + ] + }, + { + "teal": 4087, + "source": "examples/reti/stakingPool.algo.ts:993", + "pc": [ + 5344, + 5345, + 5346, + 5347, + 5348, + 5349, + 5350, + 5351, + 5352, + 5353 + ] + }, + { + "teal": 4088, + "source": "examples/reti/stakingPool.algo.ts:993", + "pc": [ + 5354 + ] + }, + { + "teal": 4089, + "source": "examples/reti/stakingPool.algo.ts:993", + "pc": [ + 5355 + ] + }, + { + "teal": 4090, + "source": "examples/reti/stakingPool.algo.ts:993", + "pc": [ + 5356 + ] + }, + { + "teal": 4091, + "source": "examples/reti/stakingPool.algo.ts:993", + "pc": [ + 5357 + ] + }, + { + "teal": 4092, + "source": "examples/reti/stakingPool.algo.ts:993", + "pc": [ + 5358, + 5359 + ] + }, + { + "teal": 4093, + "source": "examples/reti/stakingPool.algo.ts:993", + "pc": [ + 5360 + ] + }, + { + "teal": 4094, + "source": "examples/reti/stakingPool.algo.ts:993", + "pc": [ + 5361 + ] + }, + { + "teal": 4095, + "source": "examples/reti/stakingPool.algo.ts:993", + "pc": [ + 5362 + ] + }, + { + "teal": 4096, + "source": "examples/reti/stakingPool.algo.ts:993", + "pc": [ + 5363 + ] + }, + { + "teal": 4097, + "source": "examples/reti/stakingPool.algo.ts:993", + "pc": [ + 5364 + ] + }, + { + "teal": 4098, + "source": "examples/reti/stakingPool.algo.ts:993", + "pc": [ + 5365 + ] + }, + { + "teal": 4099, + "source": "examples/reti/stakingPool.algo.ts:993", + "pc": [ + 5366, + 5367, + 5368 + ] + }, + { + "teal": 4105, + "source": "examples/reti/stakingPool.algo.ts:994", + "pc": [ + 5369, + 5370 + ] + }, + { + "teal": 4106, + "source": "examples/reti/stakingPool.algo.ts:994", + "pc": [ + 5371, + 5372, + 5373 + ] + }, + { + "teal": 4107, + "source": "examples/reti/stakingPool.algo.ts:994", + "pc": [ + 5374 + ] + }, + { + "teal": 4108, + "source": "examples/reti/stakingPool.algo.ts:994", + "pc": [ + 5375, + 5376, + 5377 + ] + }, + { + "teal": 4113, + "source": "examples/reti/stakingPool.algo.ts:995", + "pc": [ + 5378 + ] + }, + { + "teal": 4114, + "source": "examples/reti/stakingPool.algo.ts:995", + "pc": [ + 5379, + 5380 + ] + }, + { + "teal": 4115, + "source": "examples/reti/stakingPool.algo.ts:995", + "pc": [ + 5381, + 5382 + ] + }, + { + "teal": 4116, + "source": "examples/reti/stakingPool.algo.ts:995", + "pc": [ + 5383, + 5384 + ] + }, + { + "teal": 4117, + "source": "examples/reti/stakingPool.algo.ts:995", + "pc": [ + 5385, + 5386 + ] + }, + { + "teal": 4118, + "source": "examples/reti/stakingPool.algo.ts:995", + "pc": [ + 5387, + 5388, + 5389, + 5390, + 5391 + ] + }, + { + "teal": 4119, + "source": "examples/reti/stakingPool.algo.ts:995", + "pc": [ + 5392 + ] + }, + { + "teal": 4120, + "source": "examples/reti/stakingPool.algo.ts:995", + "pc": [ + 5393, + 5394 + ] + }, + { + "teal": 4121, + "source": "examples/reti/stakingPool.algo.ts:995", + "pc": [ + 5395, + 5396 + ] + }, + { + "teal": 4122, + "source": "examples/reti/stakingPool.algo.ts:995", + "pc": [ + 5397, + 5398 + ] + }, + { + "teal": 4123, + "source": "examples/reti/stakingPool.algo.ts:995", + "pc": [ + 5399, + 5400 + ] + }, + { + "teal": 4124, + "source": "examples/reti/stakingPool.algo.ts:995", + "pc": [ + 5401 + ] + }, + { + "teal": 4129, + "source": "examples/reti/stakingPool.algo.ts:997", + "pc": [ + 5402, + 5403 + ] + }, + { + "teal": 4130, + "source": "examples/reti/stakingPool.algo.ts:997", + "pc": [ + 5404, + 5405, + 5406, + 5407, + 5408, + 5409, + 5410, + 5411, + 5412, + 5413, + 5414, + 5415, + 5416, + 5417, + 5418, + 5419, + 5420, + 5421 + ] + }, + { + "teal": 4131, + "source": "examples/reti/stakingPool.algo.ts:997", + "pc": [ + 5422 + ] + }, + { + "teal": 4132, + "source": "examples/reti/stakingPool.algo.ts:997", + "pc": [ + 5423 + ] + }, + { + "teal": 4133, + "source": "examples/reti/stakingPool.algo.ts:997", + "pc": [ + 5424 + ] + }, + { + "teal": 4134, + "source": "examples/reti/stakingPool.algo.ts:997", + "pc": [ + 5425, + 5426, + 5427 + ] + }, + { + "teal": 4135, + "source": "examples/reti/stakingPool.algo.ts:997", + "pc": [ + 5428 + ] + }, + { + "teal": 4138, + "source": "examples/reti/stakingPool.algo.ts:997", + "errorMessage": "currentBinSize * (365 as uint128) overflowed 128 bits", + "pc": [ + 5429 + ] + }, + { + "teal": 4139, + "source": "examples/reti/stakingPool.algo.ts:997", + "pc": [ + 5430, + 5431, + 5432, + 5433, + 5434, + 5435, + 5436, + 5437, + 5438, + 5439, + 5440, + 5441, + 5442, + 5443, + 5444, + 5445, + 5446, + 5447 + ] + }, + { + "teal": 4140, + "source": "examples/reti/stakingPool.algo.ts:997", + "pc": [ + 5448 + ] + }, + { + "teal": 4141, + "source": "examples/reti/stakingPool.algo.ts:997", + "pc": [ + 5449 + ] + }, + { + "teal": 4142, + "source": "examples/reti/stakingPool.algo.ts:997", + "pc": [ + 5450 + ] + }, + { + "teal": 4143, + "source": "examples/reti/stakingPool.algo.ts:997", + "pc": [ + 5451 + ] + }, + { + "teal": 4144, + "source": "examples/reti/stakingPool.algo.ts:997", + "pc": [ + 5452, + 5453 + ] + }, + { + "teal": 4145, + "source": "examples/reti/stakingPool.algo.ts:997", + "pc": [ + 5454 + ] + }, + { + "teal": 4146, + "source": "examples/reti/stakingPool.algo.ts:997", + "pc": [ + 5455 + ] + }, + { + "teal": 4147, + "source": "examples/reti/stakingPool.algo.ts:997", + "pc": [ + 5456 + ] + }, + { + "teal": 4148, + "source": "examples/reti/stakingPool.algo.ts:997", + "pc": [ + 5457, + 5458 + ] + }, + { + "teal": 4152, + "source": "examples/reti/stakingPool.algo.ts:998", + "pc": [ + 5459, + 5460, + 5461, + 5462, + 5463, + 5464, + 5465, + 5466, + 5467, + 5468, + 5469, + 5470, + 5471, + 5472, + 5473, + 5474, + 5475, + 5476 + ] + }, + { + "teal": 4153, + "source": "examples/reti/stakingPool.algo.ts:998", + "pc": [ + 5477 + ] + }, + { + "teal": 4154, + "source": "examples/reti/stakingPool.algo.ts:998", + "pc": [ + 5478, + 5479 + ] + }, + { + "teal": 4155, + "source": "examples/reti/stakingPool.algo.ts:998", + "pc": [ + 5480 + ] + }, + { + "teal": 4156, + "source": "examples/reti/stakingPool.algo.ts:998", + "pc": [ + 5481 + ] + }, + { + "teal": 4157, + "source": "examples/reti/stakingPool.algo.ts:998", + "pc": [ + 5482 + ] + }, + { + "teal": 4158, + "source": "examples/reti/stakingPool.algo.ts:998", + "pc": [ + 5483, + 5484, + 5485 + ] + }, + { + "teal": 4159, + "source": "examples/reti/stakingPool.algo.ts:998", + "pc": [ + 5486 + ] + }, + { + "teal": 4162, + "source": "examples/reti/stakingPool.algo.ts:998", + "errorMessage": "this.stakeAccumulator.value / currentBinSize overflowed 128 bits", + "pc": [ + 5487 + ] + }, + { + "teal": 4163, + "source": "examples/reti/stakingPool.algo.ts:998", + "pc": [ + 5488, + 5489, + 5490, + 5491, + 5492, + 5493, + 5494, + 5495, + 5496, + 5497, + 5498, + 5499, + 5500, + 5501, + 5502, + 5503, + 5504, + 5505 + ] + }, + { + "teal": 4164, + "source": "examples/reti/stakingPool.algo.ts:998", + "pc": [ + 5506 + ] + }, + { + "teal": 4165, + "source": "examples/reti/stakingPool.algo.ts:998", + "pc": [ + 5507 + ] + }, + { + "teal": 4166, + "source": "examples/reti/stakingPool.algo.ts:998", + "pc": [ + 5508 + ] + }, + { + "teal": 4167, + "source": "examples/reti/stakingPool.algo.ts:998", + "pc": [ + 5509 + ] + }, + { + "teal": 4168, + "source": "examples/reti/stakingPool.algo.ts:998", + "pc": [ + 5510, + 5511 + ] + }, + { + "teal": 4169, + "source": "examples/reti/stakingPool.algo.ts:998", + "pc": [ + 5512 + ] + }, + { + "teal": 4170, + "source": "examples/reti/stakingPool.algo.ts:998", + "pc": [ + 5513 + ] + }, + { + "teal": 4171, + "source": "examples/reti/stakingPool.algo.ts:998", + "pc": [ + 5514 + ] + }, + { + "teal": 4172, + "source": "examples/reti/stakingPool.algo.ts:998", + "pc": [ + 5515, + 5516 + ] + }, + { + "teal": 4177, + "source": "examples/reti/stakingPool.algo.ts:999", + "pc": [ + 5517, + 5518 + ] + }, + { + "teal": 4178, + "source": "examples/reti/stakingPool.algo.ts:999", + "pc": [ + 5519, + 5520, + 5521, + 5522, + 5523, + 5524, + 5525, + 5526, + 5527, + 5528, + 5529, + 5530, + 5531, + 5532, + 5533, + 5534, + 5535, + 5536 + ] + }, + { + "teal": 4179, + "source": "examples/reti/stakingPool.algo.ts:999", + "pc": [ + 5537 + ] + }, + { + "teal": 4180, + "source": "examples/reti/stakingPool.algo.ts:999", + "pc": [ + 5538, + 5539, + 5540 + ] + }, + { + "teal": 4187, + "source": "examples/reti/stakingPool.algo.ts:1004", + "pc": [ + 5541, + 5542, + 5543, + 5544, + 5545, + 5546, + 5547, + 5548, + 5549, + 5550, + 5551, + 5552, + 5553, + 5554, + 5555, + 5556, + 5557, + 5558, + 5559 + ] + }, + { + "teal": 4188, + "source": "examples/reti/stakingPool.algo.ts:1004", + "pc": [ + 5560 + ] + }, + { + "teal": 4189, + "source": "examples/reti/stakingPool.algo.ts:1004", + "pc": [ + 5561 + ] }, { + "teal": 4190, + "source": "examples/reti/stakingPool.algo.ts:1004", "pc": [ - 85 - ], - "errorMessage": "Temporary: contract is upgradeable but only during testing and only from a development account" + 5562, + 5563, + 5564, + 5565, + 5566, + 5567, + 5568, + 5569, + 5570, + 5571, + 5572, + 5573, + 5574, + 5575, + 5576, + 5577, + 5578, + 5579 + ] }, { + "teal": 4191, + "source": "examples/reti/stakingPool.algo.ts:1004", "pc": [ - 154 - ], - "errorMessage": "staking pool must have minimum entry of 1 algo" + 5580 + ] }, { + "teal": 4192, + "source": "examples/reti/stakingPool.algo.ts:1004", "pc": [ - 432 - ], - "errorMessage": "argument 0 (mbrPayment) for initStorage must be a pay transaction" + 5581, + 5582 + ] }, { + "teal": 4193, + "source": "examples/reti/stakingPool.algo.ts:1004", "pc": [ - 459 - ], - "errorMessage": "staking pool already initialized" + 5583 + ] }, { + "teal": 4194, + "source": "examples/reti/stakingPool.algo.ts:1005", "pc": [ - 589 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"mbrPayment\",\"field\":\"receiver\",\"expected\":\"this.app.address\"}" + 5584, + 5585 + ] }, { + "teal": 4195, + "source": "examples/reti/stakingPool.algo.ts:1005", "pc": [ - 597 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"mbrPayment\",\"field\":\"amount\",\"expected\":\"PoolInitMbr\"}" + 5586, + 5587 + ] }, { + "teal": 4196, + "source": "examples/reti/stakingPool.algo.ts:1005", "pc": [ - 675 - ], - "errorMessage": "argument 0 (staker) for addStake must be a address" + 5588 + ] }, { + "teal": 4197, + "source": "examples/reti/stakingPool.algo.ts:1004", "pc": [ - 687 - ], - "errorMessage": "argument 1 (stakedAmountPayment) for addStake must be a pay transaction" + 5589 + ] }, { + "teal": 4198, + "source": "examples/reti/stakingPool.algo.ts:1004", "pc": [ - 716 - ], - "errorMessage": "staking pool must be initialized first" + 5590 + ] }, { + "teal": 4199, + "source": "examples/reti/stakingPool.algo.ts:1004", "pc": [ - 736 - ], - "errorMessage": "stake can only be added via the validator contract" + 5591 + ] }, { + "teal": 4200, + "source": "examples/reti/stakingPool.algo.ts:1004", "pc": [ - 767 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"stakedAmountPayment\",\"field\":\"sender\",\"expected\":\"AppID.fromUint64(this.creatingValidatorContractAppId.value).address\"}" + 5592, + 5593, + 5594 + ] }, { + "teal": 4201, + "source": "examples/reti/stakingPool.algo.ts:1004", "pc": [ - 775 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"stakedAmountPayment\",\"field\":\"receiver\",\"expected\":\"this.app.address\"}" + 5595 + ] }, { + "teal": 4204, + "source": "examples/reti/stakingPool.algo.ts:1004", + "errorMessage": "(((this.rewardAccumulator.value as uint128) * (10000 as uint128)) / avgStake) *\\n (approxRoundsPerYear / currentBinSize) overflowed 128 bits", "pc": [ - 785 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"stakedAmountPayment\",\"field\":\"amount\",\"expected\":\"stakedAmountPayment.amount\"}" + 5596 + ] }, { + "teal": 4205, + "source": "examples/reti/stakingPool.algo.ts:1004", "pc": [ - 895 - ], - "errorMessage": "this.stakeAccumulator.value + (stakedAmountPayment.amount as uint128) * (roundsLeftInBin as uint128) overflowed 128 bits" + 5597, + 5598, + 5599, + 5600, + 5601, + 5602, + 5603, + 5604, + 5605, + 5606, + 5607, + 5608, + 5609, + 5610, + 5611, + 5612, + 5613, + 5614 + ] }, { + "teal": 4206, + "source": "examples/reti/stakingPool.algo.ts:1004", "pc": [ - 1101 - ], - "errorMessage": "Staking pool full" + 5615 + ] }, { + "teal": 4207, + "source": "examples/reti/stakingPool.algo.ts:1004", "pc": [ - 1123 - ], - "errorMessage": "must stake at least the minimum for this pool" + 5616 + ] }, { + "teal": 4208, + "source": "examples/reti/stakingPool.algo.ts:1004", "pc": [ - 1256 - ], - "errorMessage": "argument 1 (staker) for removeStake must be a address" + 5617 + ] }, { + "teal": 4209, + "source": "examples/reti/stakingPool.algo.ts:1004", "pc": [ - 1281 - ], - "errorMessage": "If staker is not sender in removeStake call, then sender MUST be owner or manager of validator" + 5618 + ] }, { + "teal": 4210, + "source": "examples/reti/stakingPool.algo.ts:1004", "pc": [ - 1391 - ], - "errorMessage": "Insufficient balance" + 5619, + 5620 + ] }, { + "teal": 4211, + "source": "examples/reti/stakingPool.algo.ts:1004", "pc": [ - 1642 - ], - "errorMessage": "cannot reduce balance below minimum allowed stake unless all is removed" + 5621 + ] }, { + "teal": 4212, + "source": "examples/reti/stakingPool.algo.ts:1004", "pc": [ - 1833 - ], - "errorMessage": "(amountToUnstake as uint128) * (roundsLeftInBin as uint128) overflowed 128 bits" + 5622 + ] }, { + "teal": 4213, + "source": "examples/reti/stakingPool.algo.ts:1004", "pc": [ - 1892 - ], - "errorMessage": "this.stakeAccumulator.value - subtractAmount overflowed 128 bits" + 5623 + ] }, { + "teal": 4214, + "source": "examples/reti/stakingPool.algo.ts:1003", "pc": [ - 2024 - ], - "errorMessage": "account not found" + 5624, + 5625 + ] }, { + "teal": 4218, + "source": "examples/reti/stakingPool.algo.ts:1007", "pc": [ - 2425 - ], - "errorMessage": "account not found" + 5626, + 5627, + 5628, + 5629, + 5630, + 5631, + 5632, + 5633, + 5634, + 5635, + 5636, + 5637, + 5638, + 5639, + 5640, + 5641, + 5642, + 5643 + ] }, { + "teal": 4219, + "source": "examples/reti/stakingPool.algo.ts:1007", "pc": [ - 2441 - ], - "errorMessage": "argument 0 (staker) for getStakerInfo must be a address" + 5644, + 5645 + ] }, { + "teal": 4224, + "source": "examples/reti/stakingPool.algo.ts:1009", "pc": [ - 2561 - ], - "errorMessage": "account not found" + 5646, + 5647 + ] }, { + "teal": 4225, + "source": "examples/reti/stakingPool.algo.ts:1009", "pc": [ - 2581 - ], - "errorMessage": "argument 2 (staker) for payTokenReward must be a address" + 5648, + 5649, + 5650, + 5651, + 5652, + 5653, + 5654, + 5655, + 5656, + 5657, + 5658, + 5659, + 5660, + 5661, + 5662, + 5663, + 5664, + 5665 + ] }, { + "teal": 4226, + "source": "examples/reti/stakingPool.algo.ts:1009", "pc": [ - 2610 - ], - "errorMessage": "this can only be called via the validator contract" + 5666 + ] }, { + "teal": 4227, + "source": "examples/reti/stakingPool.algo.ts:1009", "pc": [ - 2623 - ], - "errorMessage": "must be pool 1 in order to be called to pay out token rewards" + 5667, + 5668, + 5669 + ] }, { + "teal": 4232, + "source": "examples/reti/stakingPool.algo.ts:1010", "pc": [ - 2629 - ], - "errorMessage": "can only claim token rewards from validator that has them" + 5670, + 5671, + 5672, + 5673, + 5674, + 5675, + 5676, + 5677, + 5678, + 5679, + 5680, + 5681, + 5682, + 5683, + 5684, + 5685, + 5686, + 5687 + ] }, { + "teal": 4233, + "source": "examples/reti/stakingPool.algo.ts:1010", "pc": [ - 2671 - ], - "errorMessage": "can only be called by owner or manager of validator" + 5688, + 5689 + ] }, { + "teal": 4240, + "source": "examples/reti/stakingPool.algo.ts:1012", "pc": [ - 2841 - ], - "errorMessage": "can't call epochBalanceUpdate in same epoch as prior call" + 5690, + 5691, + 5692, + 5693, + 5694, + 5695 + ] }, { + "teal": 4241, + "source": "examples/reti/stakingPool.algo.ts:1012", "pc": [ - 3374 - ], - "errorMessage": "wideRatio failed" + 5696 + ] }, { + "teal": 4242, + "source": "examples/reti/stakingPool.algo.ts:1013", "pc": [ - 3444 - ], - "errorMessage": "wideRatio failed" + 5697 + ] }, { + "teal": 4243, + "source": "examples/reti/stakingPool.algo.ts:1013", "pc": [ - 3550 - ], - "errorMessage": "wideRatio failed" + 5698, + 5699, + 5700, + 5701, + 5702, + 5703, + 5704, + 5705, + 5706, + 5707, + 5708, + 5709, + 5710, + 5711, + 5712, + 5713, + 5714, + 5715 + ] }, { + "teal": 4244, + "source": "examples/reti/stakingPool.algo.ts:1013", "pc": [ - 3990 - ], - "errorMessage": "wideRatio failed" + 5716, + 5717 + ] }, { + "teal": 4245, + "source": "examples/reti/stakingPool.algo.ts:1013", "pc": [ - 4073 - ], - "errorMessage": "wideRatio failed" + 5718 + ] }, { + "teal": 4246, + "source": "examples/reti/stakingPool.algo.ts:1013", "pc": [ - 4312 - ], - "errorMessage": "wideRatio failed" + 5719 + ] }, { + "teal": 4247, + "source": "examples/reti/stakingPool.algo.ts:1013", "pc": [ - 4365 - ], - "errorMessage": "wideRatio failed" + 5720, + 5721, + 5722, + 5723, + 5724, + 5725, + 5726, + 5727, + 5728, + 5729, + 5730, + 5731, + 5732, + 5733, + 5734, + 5735, + 5736, + 5737 + ] }, { + "teal": 4248, + "source": "examples/reti/stakingPool.algo.ts:1013", "pc": [ - 4531 - ], - "errorMessage": "this.stakeAccumulator.value + (increasedStake as uint128) * (roundsLeftInBin as uint128) overflowed 128 bits" + 5738 + ] }, { + "teal": 4249, + "source": "examples/reti/stakingPool.algo.ts:1014", "pc": [ - 4713 - ], - "errorMessage": "argument 6 (feePayment) for goOnline must be a pay transaction" + 5739, + 5740 + ] }, { + "teal": 4250, + "source": "examples/reti/stakingPool.algo.ts:1014", "pc": [ - 4728 - ], - "errorMessage": "can only be called by owner or manager of validator" + 5741, + 5742 + ] }, { + "teal": 4251, + "source": "examples/reti/stakingPool.algo.ts:1014", "pc": [ - 4741 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"feePayment\",\"field\":\"receiver\",\"expected\":\"this.app.address\"}" + 5743 + ] }, { + "teal": 4252, + "source": "examples/reti/stakingPool.algo.ts:1014", "pc": [ - 4749 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"feePayment\",\"field\":\"amount\",\"expected\":\"extraFee\"}" + 5744, + 5745, + 5746, + 5747, + 5748, + 5749, + 5750, + 5751, + 5752, + 5753, + 5754, + 5755, + 5756, + 5757, + 5758, + 5759, + 5760, + 5761 + ] }, { + "teal": 4253, + "source": "examples/reti/stakingPool.algo.ts:1014", "pc": [ - 4820 - ], - "errorMessage": "can only be called by owner or manager of validator" + 5762 + ] }, { + "teal": 4254, + "source": "examples/reti/stakingPool.algo.ts:1013", "pc": [ - 4854 - ], - "errorMessage": "can only be called by owner or manager of validator" + 5763 + ] }, { + "teal": 4255, + "source": "examples/reti/stakingPool.algo.ts:1013", "pc": [ - 4919 - ], - "errorMessage": "argument 0 (poolKey) for proxiedSetTokenPayoutRatio must be a (uint64,uint64,uint64)" + 5764 + ] }, { + "teal": 4256, + "source": "examples/reti/stakingPool.algo.ts:1013", "pc": [ - 4954 - ], - "errorMessage": "caller must be part of same validator set!" + 5765 + ] }, { + "teal": 4257, + "source": "examples/reti/stakingPool.algo.ts:1013", "pc": [ - 4967 - ], - "errorMessage": "callee must be pool 1" + 5766, + 5767, + 5768 + ] }, { + "teal": 4258, + "source": "examples/reti/stakingPool.algo.ts:1013", "pc": [ - 4977 - ], - "errorMessage": "caller must NOT be pool 1" + 5769 + ] }, { + "teal": 4261, + "source": "examples/reti/stakingPool.algo.ts:1013", + "errorMessage": "(this.weightedMovingAverage.value * ((100 as uint128) - alpha)) / (100 as uint128) +\\n (apr * alpha) / (100 as uint128) overflowed 128 bits", "pc": [ - 5249 - ], - "errorMessage": "wideRatio failed" + 5770 + ] }, { + "teal": 4262, + "source": "examples/reti/stakingPool.algo.ts:1013", "pc": [ - 5343 - ], - "errorMessage": "currentBinSize as uint64 overflowed 64 bits" + 5771, + 5772, + 5773, + 5774, + 5775, + 5776, + 5777, + 5778, + 5779, + 5780, + 5781, + 5782, + 5783, + 5784, + 5785, + 5786, + 5787, + 5788 + ] }, { + "teal": 4263, + "source": "examples/reti/stakingPool.algo.ts:1013", "pc": [ - 5429 - ], - "errorMessage": "currentBinSize * (365 as uint128) overflowed 128 bits" + 5789 + ] }, { + "teal": 4264, + "source": "examples/reti/stakingPool.algo.ts:1013", "pc": [ - 5487 - ], - "errorMessage": "this.stakeAccumulator.value / currentBinSize overflowed 128 bits" + 5790 + ] }, { + "teal": 4265, + "source": "examples/reti/stakingPool.algo.ts:1013", "pc": [ - 5596 - ], - "errorMessage": "(((this.rewardAccumulator.value as uint128) * (10000 as uint128)) / avgStake) *\\n (approxRoundsPerYear / currentBinSize) overflowed 128 bits" + 5791 + ] }, { + "teal": 4266, + "source": "examples/reti/stakingPool.algo.ts:1013", "pc": [ - 5770 - ], - "errorMessage": "(this.weightedMovingAverage.value * ((100 as uint128) - alpha)) / (100 as uint128) +\\n (apr * alpha) / (100 as uint128) overflowed 128 bits" + 5792 + ] + }, + { + "teal": 4267, + "source": "examples/reti/stakingPool.algo.ts:1013", + "pc": [ + 5793, + 5794 + ] + }, + { + "teal": 4268, + "source": "examples/reti/stakingPool.algo.ts:1013", + "pc": [ + 5795 + ] }, { + "teal": 4269, + "source": "examples/reti/stakingPool.algo.ts:1013", + "pc": [ + 5796 + ] + }, + { + "teal": 4270, + "source": "examples/reti/stakingPool.algo.ts:1013", + "pc": [ + 5797 + ] + }, + { + "teal": 4271, + "source": "examples/reti/stakingPool.algo.ts:1012", + "pc": [ + 5798 + ] + }, + { + "teal": 4276, + "source": "examples/reti/stakingPool.algo.ts:1018", + "pc": [ + 5799, + 5800, + 5801 + ] + }, + { + "teal": 4280, + "source": "examples/reti/stakingPool.algo.ts:1019", + "pc": [ + 5802, + 5803, + 5804, + 5805, + 5806, + 5807, + 5808, + 5809, + 5810, + 5811, + 5812, + 5813, + 5814, + 5815, + 5816, + 5817, + 5818, + 5819 + ] + }, + { + "teal": 4281, + "source": "examples/reti/stakingPool.algo.ts:1019", + "pc": [ + 5820, + 5821, + 5822, + 5823, + 5824, + 5825, + 5826, + 5827 + ] + }, + { + "teal": 4282, + "source": "examples/reti/stakingPool.algo.ts:1019", + "pc": [ + 5828 + ] + }, + { + "teal": 4283, + "source": "examples/reti/stakingPool.algo.ts:1019", + "pc": [ + 5829 + ] + }, + { + "teal": 4284, + "source": "examples/reti/stakingPool.algo.ts:1019", + "pc": [ + 5830, + 5831, + 5832, + 5833, + 5834, + 5835, + 5836, + 5837, + 5838, + 5839, + 5840, + 5841, + 5842, + 5843 + ] + }, + { + "teal": 4285, + "source": "examples/reti/stakingPool.algo.ts:1019", + "pc": [ + 5844 + ] + }, + { + "teal": 4286, + "source": "examples/reti/stakingPool.algo.ts:1019", + "pc": [ + 5845 + ] + }, + { + "teal": 4287, + "source": "examples/reti/stakingPool.algo.ts:1019", + "pc": [ + 5846 + ] + }, + { + "teal": 4288, + "source": "examples/reti/stakingPool.algo.ts:1019", + "pc": [ + 5847 + ] + }, + { + "teal": 4289, + "source": "examples/reti/stakingPool.algo.ts:1019", + "pc": [ + 5848 + ] + }, + { + "teal": 4290, + "source": "examples/reti/stakingPool.algo.ts:1019", + "pc": [ + 5849, + 5850, + 5851 + ] + }, + { + "teal": 4291, + "source": "examples/reti/stakingPool.algo.ts:1019", + "pc": [ + 5852 + ] + }, + { + "teal": 4294, + "source": "examples/reti/stakingPool.algo.ts:1019", + "errorMessage": "(this.totalAlgoStaked.value as uint128) * (this.roundsPerDay.value as uint128) overflowed 128 bits", "pc": [ 5853 - ], - "errorMessage": "(this.totalAlgoStaked.value as uint128) * (this.roundsPerDay.value as uint128) overflowed 128 bits" + ] + }, + { + "teal": 4295, + "source": "examples/reti/stakingPool.algo.ts:1019", + "pc": [ + 5854, + 5855, + 5856, + 5857, + 5858, + 5859, + 5860, + 5861, + 5862, + 5863, + 5864, + 5865, + 5866, + 5867, + 5868, + 5869, + 5870, + 5871 + ] + }, + { + "teal": 4296, + "source": "examples/reti/stakingPool.algo.ts:1019", + "pc": [ + 5872 + ] + }, + { + "teal": 4297, + "source": "examples/reti/stakingPool.algo.ts:1019", + "pc": [ + 5873 + ] + }, + { + "teal": 4298, + "source": "examples/reti/stakingPool.algo.ts:1019", + "pc": [ + 5874 + ] + }, + { + "teal": 4299, + "source": "examples/reti/stakingPool.algo.ts:1019", + "pc": [ + 5875 + ] + }, + { + "teal": 4300, + "source": "examples/reti/stakingPool.algo.ts:1019", + "pc": [ + 5876, + 5877 + ] + }, + { + "teal": 4301, + "source": "examples/reti/stakingPool.algo.ts:1019", + "pc": [ + 5878 + ] + }, + { + "teal": 4302, + "source": "examples/reti/stakingPool.algo.ts:1019", + "pc": [ + 5879 + ] + }, + { + "teal": 4303, + "source": "examples/reti/stakingPool.algo.ts:1019", + "pc": [ + 5880 + ] + }, + { + "teal": 4304, + "source": "examples/reti/stakingPool.algo.ts:1019", + "pc": [ + 5881 + ] + }, + { + "teal": 4308, + "source": "examples/reti/stakingPool.algo.ts:1020", + "pc": [ + 5882, + 5883, + 5884, + 5885, + 5886, + 5887, + 5888, + 5889, + 5890, + 5891, + 5892, + 5893, + 5894, + 5895, + 5896, + 5897, + 5898, + 5899, + 5900 + ] + }, + { + "teal": 4309, + "source": "examples/reti/stakingPool.algo.ts:1020", + "pc": [ + 5901, + 5902 + ] + }, + { + "teal": 4310, + "source": "examples/reti/stakingPool.algo.ts:1020", + "pc": [ + 5903 + ] + }, + { + "teal": 4314, + "source": "examples/reti/stakingPool.algo.ts:1021", + "pc": [ + 5904, + 5905, + 5906, + 5907, + 5908, + 5909, + 5910, + 5911, + 5912, + 5913, + 5914, + 5915, + 5916, + 5917, + 5918 + ] + }, + { + "teal": 4315, + "source": "examples/reti/stakingPool.algo.ts:1021", + "pc": [ + 5919, + 5920 + ] + }, + { + "teal": 4316, + "source": "examples/reti/stakingPool.algo.ts:1021", + "pc": [ + 5921, + 5922 + ] + }, + { + "teal": 4317, + "source": "examples/reti/stakingPool.algo.ts:1021", + "pc": [ + 5923, + 5924, + 5925, + 5926, + 5927, + 5928, + 5929, + 5930, + 5931, + 5932, + 5933, + 5934, + 5935, + 5936 + ] + }, + { + "teal": 4318, + "source": "examples/reti/stakingPool.algo.ts:1021", + "pc": [ + 5937 + ] + }, + { + "teal": 4319, + "source": "examples/reti/stakingPool.algo.ts:1021", + "pc": [ + 5938 + ] + }, + { + "teal": 4320, + "source": "examples/reti/stakingPool.algo.ts:1021", + "pc": [ + 5939 + ] + }, + { + "teal": 4321, + "source": "examples/reti/stakingPool.algo.ts:1021", + "pc": [ + 5940 + ] + }, + { + "teal": 4324, + "source": "examples/reti/stakingPool.algo.ts:991", + "pc": [ + 5941 + ] + }, + { + "teal": 4328, + "source": "examples/reti/stakingPool.algo.ts:1025", + "pc": [ + 5942, + 5943, + 5944 + ] + }, + { + "teal": 4332, + "source": "examples/reti/stakingPool.algo.ts:1026", + "pc": [ + 5945, + 5946, + 5947, + 5948, + 5949, + 5950, + 5951, + 5952, + 5953, + 5954, + 5955, + 5956, + 5957, + 5958 + ] + }, + { + "teal": 4333, + "source": "examples/reti/stakingPool.algo.ts:1026", + "pc": [ + 5959, + 5960, + 5961, + 5962 + ] + }, + { + "teal": 4334, + "source": "examples/reti/stakingPool.algo.ts:1026", + "pc": [ + 5963 + ] + }, + { + "teal": 4335, + "source": "examples/reti/stakingPool.algo.ts:1025", + "pc": [ + 5964 + ] + }, + { + "teal": 4338, + "source": "examples/reti/stakingPool.algo.ts:38", + "pc": [ + 5965, + 5966, + 5967, + 5968, + 5969, + 5970 + ] + }, + { + "teal": 4339, + "source": "examples/reti/stakingPool.algo.ts:38", + "pc": [ + 5971, + 5972, + 5973 + ] + }, + { + "teal": 4340, + "source": "examples/reti/stakingPool.algo.ts:38", + "pc": [ + 5974, + 5975, + 5976, + 5977 + ] }, { + "teal": 4343, + "source": "examples/reti/stakingPool.algo.ts:38", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 5978 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 4346, + "source": "examples/reti/stakingPool.algo.ts:38", + "pc": [ + 5979, + 5980, + 5981, + 5982, + 5983, + 5984 + ] + }, + { + "teal": 4347, + "source": "examples/reti/stakingPool.algo.ts:38", + "pc": [ + 5985, + 5986, + 5987, + 5988, + 5989, + 5990 + ] + }, + { + "teal": 4348, + "source": "examples/reti/stakingPool.algo.ts:38", + "pc": [ + 5991, + 5992, + 5993, + 5994, + 5995, + 5996 + ] + }, + { + "teal": 4349, + "source": "examples/reti/stakingPool.algo.ts:38", + "pc": [ + 5997, + 5998, + 5999, + 6000, + 6001, + 6002 + ] + }, + { + "teal": 4350, + "source": "examples/reti/stakingPool.algo.ts:38", + "pc": [ + 6003, + 6004, + 6005, + 6006, + 6007, + 6008 + ] + }, + { + "teal": 4351, + "source": "examples/reti/stakingPool.algo.ts:38", + "pc": [ + 6009, + 6010, + 6011, + 6012, + 6013, + 6014 + ] + }, + { + "teal": 4352, + "source": "examples/reti/stakingPool.algo.ts:38", + "pc": [ + 6015, + 6016, + 6017, + 6018, + 6019, + 6020 + ] + }, + { + "teal": 4353, + "source": "examples/reti/stakingPool.algo.ts:38", + "pc": [ + 6021, + 6022, + 6023, + 6024, + 6025, + 6026 + ] + }, + { + "teal": 4354, + "source": "examples/reti/stakingPool.algo.ts:38", + "pc": [ + 6027, + 6028, + 6029, + 6030, + 6031, + 6032 + ] + }, + { + "teal": 4355, + "source": "examples/reti/stakingPool.algo.ts:38", + "pc": [ + 6033, + 6034, + 6035, + 6036, + 6037, + 6038 + ] + }, + { + "teal": 4356, + "source": "examples/reti/stakingPool.algo.ts:38", + "pc": [ + 6039, + 6040, + 6041, + 6042, + 6043, + 6044 + ] + }, + { + "teal": 4357, + "source": "examples/reti/stakingPool.algo.ts:38", + "pc": [ + 6045, + 6046, + 6047, + 6048, + 6049, + 6050 + ] + }, + { + "teal": 4358, + "source": "examples/reti/stakingPool.algo.ts:38", + "pc": [ + 6051, + 6052, + 6053, + 6054, + 6055, + 6056 + ] + }, + { + "teal": 4359, + "source": "examples/reti/stakingPool.algo.ts:38", + "pc": [ + 6057, + 6058, + 6059 + ] }, { + "teal": 4360, + "source": "examples/reti/stakingPool.algo.ts:38", + "pc": [ + 6060, + 6061, + 6062, + 6063, + 6064, + 6065, + 6066, + 6067, + 6068, + 6069, + 6070, + 6071, + 6072, + 6073, + 6074, + 6075, + 6076, + 6077, + 6078, + 6079, + 6080, + 6081, + 6082, + 6083, + 6084, + 6085, + 6086, + 6087 + ] + }, + { + "teal": 4363, + "source": "examples/reti/stakingPool.algo.ts:38", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 6088 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] + }, + { + "teal": 4366, + "source": "examples/reti/stakingPool.algo.ts:38", + "pc": [ + 6089, + 6090, + 6091, + 6092, + 6093, + 6094 + ] + }, + { + "teal": 4367, + "source": "examples/reti/stakingPool.algo.ts:38", + "pc": [ + 6095, + 6096, + 6097 + ] + }, + { + "teal": 4368, + "source": "examples/reti/stakingPool.algo.ts:38", + "pc": [ + 6098, + 6099, + 6100, + 6101 + ] }, { + "teal": 4371, + "source": "examples/reti/stakingPool.algo.ts:38", + "errorMessage": "this contract does not implement the given ABI method for call UpdateApplication", "pc": [ 6102 - ], - "errorMessage": "this contract does not implement the given ABI method for call UpdateApplication" + ] } ], "pcOffsetMethod": "cblocks" diff --git a/examples/reti/artifacts/ValidatorRegistry.arc56_draft.json b/examples/reti/artifacts/ValidatorRegistry.arc56_draft.json index bc42a9e98..b79dce7a8 100644 --- a/examples/reti/artifacts/ValidatorRegistry.arc56_draft.json +++ b/examples/reti/artifacts/ValidatorRegistry.arc56_draft.json @@ -1200,598 +1200,28612 @@ "approval": { "sourceInfo": [ { + "teal": 11, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "pc": [ + 1 + ] + }, + { + "teal": 18, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "pc": [ + 2, + 3 + ] + }, + { + "teal": 19, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "pc": [ + 4 + ] + }, + { + "teal": 20, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "pc": [ + 5, + 6 + ] + }, + { + "teal": 21, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "pc": [ + 7 + ] + }, + { + "teal": 22, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "pc": [ + 8, + 9 + ] + }, + { + "teal": 23, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "pc": [ + 10 + ] + }, + { + "teal": 24, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "pc": [ + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36 + ] + }, + { + "teal": 28, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 37 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 33, + "source": "examples/reti/validatorRegistry.algo.ts:201", + "pc": [ + 38, + 39, + 40 + ] + }, + { + "teal": 34, + "source": "examples/reti/validatorRegistry.algo.ts:201", + "pc": [ + 41, + 42 + ] + }, + { + "teal": 35, + "source": "examples/reti/validatorRegistry.algo.ts:201", + "pc": [ + 43 + ] + }, + { + "teal": 39, + "source": "examples/reti/validatorRegistry.algo.ts:201", + "pc": [ + 44, + 45, + 46 + ] + }, + { + "teal": 43, + "source": "examples/reti/validatorRegistry.algo.ts:202", + "pc": [ + 47, + 48 + ] + }, + { + "teal": 44, + "source": "examples/reti/validatorRegistry.algo.ts:202", + "pc": [ + 49, + 50, + 51, + 52, + 53, + 54, + 55, + 56, + 57, + 58, + 59, + 60, + 61, + 62, + 63, + 64, + 65, + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82 + ] + }, + { + "teal": 45, + "source": "examples/reti/validatorRegistry.algo.ts:202", + "pc": [ + 83 + ] + }, + { + "teal": 46, + "source": "examples/reti/validatorRegistry.algo.ts:202", + "pc": [ + 84 + ] + }, + { + "teal": 50, + "source": "examples/reti/validatorRegistry.algo.ts:204", + "pc": [ + 85, + 86, + 87, + 88, + 89, + 90, + 91, + 92, + 93, + 94, + 95, + 96, + 97, + 98, + 99, + 100, + 101, + 102, + 103, + 104, + 105, + 106, + 107, + 108, + 109, + 110, + 111 + ] + }, + { + "teal": 51, + "source": "examples/reti/validatorRegistry.algo.ts:204", + "pc": [ + 112 + ] + }, + { + "teal": 55, + "source": "examples/reti/validatorRegistry.algo.ts:205", + "pc": [ + 113, + 114, + 115, + 116, + 117, + 118 + ] + }, + { + "teal": 56, + "source": "examples/reti/validatorRegistry.algo.ts:205", + "pc": [ + 119, + 120 + ] + }, + { + "teal": 57, + "source": "examples/reti/validatorRegistry.algo.ts:205", + "pc": [ + 121, + 122, + 123 + ] + }, + { + "teal": 58, + "source": "examples/reti/validatorRegistry.algo.ts:205", + "pc": [ + 124, + 125 + ] + }, + { + "teal": 59, + "source": "examples/reti/validatorRegistry.algo.ts:205", + "pc": [ + 126, + 127 + ] + }, + { + "teal": 60, + "source": "examples/reti/validatorRegistry.algo.ts:205", + "pc": [ + 128 + ] + }, + { + "teal": 61, + "source": "examples/reti/validatorRegistry.algo.ts:205", + "pc": [ + 129 + ] + }, + { + "teal": 62, + "source": "examples/reti/validatorRegistry.algo.ts:201", + "pc": [ + 130 + ] + }, + { + "teal": 67, + "source": "examples/reti/validatorRegistry.algo.ts:208", + "pc": [ + 131, + 132, + 133 + ] + }, + { + "teal": 68, + "source": "examples/reti/validatorRegistry.algo.ts:208", + "pc": [ + 134, + 135 + ] + }, + { + "teal": 69, + "source": "examples/reti/validatorRegistry.algo.ts:208", + "pc": [ + 136 + ] + }, + { + "teal": 73, + "source": "examples/reti/validatorRegistry.algo.ts:208", + "pc": [ + 137, + 138, + 139 + ] + }, + { + "teal": 77, + "source": "examples/reti/validatorRegistry.algo.ts:209", + "pc": [ + 140, + 141, + 142, + 143, + 144, + 145 + ] + }, + { + "teal": 78, + "source": "examples/reti/validatorRegistry.algo.ts:209", + "pc": [ + 146, + 147 + ] + }, + { + "teal": 79, + "source": "examples/reti/validatorRegistry.algo.ts:209", + "pc": [ + 148, + 149, + 150 + ] + }, + { + "teal": 80, + "source": "examples/reti/validatorRegistry.algo.ts:209", + "pc": [ + 151, + 152 + ] + }, + { + "teal": 81, + "source": "examples/reti/validatorRegistry.algo.ts:209", + "pc": [ + 153, + 154 + ] + }, + { + "teal": 82, + "source": "examples/reti/validatorRegistry.algo.ts:209", + "pc": [ + 155 + ] + }, + { + "teal": 83, + "source": "examples/reti/validatorRegistry.algo.ts:209", + "pc": [ + 156 + ] + }, + { + "teal": 87, + "source": "examples/reti/validatorRegistry.algo.ts:210", + "pc": [ + 157, + 158, + 159, + 160, + 161, + 162 + ] + }, + { + "teal": 88, + "source": "examples/reti/validatorRegistry.algo.ts:210", + "pc": [ + 163, + 164 + ] + }, + { + "teal": 89, + "source": "examples/reti/validatorRegistry.algo.ts:210", + "pc": [ + 165 + ] + }, + { + "teal": 93, + "source": "examples/reti/validatorRegistry.algo.ts:211", + "pc": [ + 166, + 167, + 168, + 169, + 170, + 171, + 172, + 173, + 174, + 175, + 176, + 177 + ] + }, + { + "teal": 94, + "source": "examples/reti/validatorRegistry.algo.ts:211", + "pc": [ + 178, + 179 + ] + }, + { + "teal": 95, + "source": "examples/reti/validatorRegistry.algo.ts:211", + "pc": [ + 180 + ] + }, + { + "teal": 99, + "source": "examples/reti/validatorRegistry.algo.ts:212", + "pc": [ + 181, + 182, + 183, + 184, + 185, + 186, + 187, + 188 + ] + }, + { + "teal": 100, + "source": "examples/reti/validatorRegistry.algo.ts:212", + "pc": [ + 189, + 190 + ] + }, + { + "teal": 101, + "source": "examples/reti/validatorRegistry.algo.ts:212", + "pc": [ + 191 + ] + }, + { + "teal": 102, + "source": "examples/reti/validatorRegistry.algo.ts:208", + "pc": [ + 192 + ] + }, + { + "teal": 107, + "source": "examples/reti/validatorRegistry.algo.ts:215", + "pc": [ + 193, + 194, + 195 + ] + }, + { + "teal": 108, + "source": "examples/reti/validatorRegistry.algo.ts:215", + "pc": [ + 196 + ] + }, + { + "teal": 111, + "source": "examples/reti/validatorRegistry.algo.ts:215", + "pc": [ + 197, + 198, + 199 + ] + }, + { + "teal": 112, + "source": "examples/reti/validatorRegistry.algo.ts:215", + "pc": [ + 200, + 201 + ] + }, + { + "teal": 113, + "source": "examples/reti/validatorRegistry.algo.ts:215", + "pc": [ + 202 + ] + }, + { + "teal": 117, + "source": "examples/reti/validatorRegistry.algo.ts:215", + "pc": [ + 203, + 204, + 205 + ] + }, + { + "teal": 121, + "source": "examples/reti/validatorRegistry.algo.ts:217", + "pc": [ + 206, + 207, + 208, + 209, + 210, + 211, + 212, + 213, + 214, + 215, + 216, + 217, + 218, + 219, + 220, + 221, + 222, + 223, + 224, + 225, + 226, + 227, + 228, + 229, + 230, + 231, + 232 + ] + }, + { + "teal": 122, + "source": "examples/reti/validatorRegistry.algo.ts:217", + "pc": [ + 233, + 234 + ] + }, + { + "teal": 123, + "source": "examples/reti/validatorRegistry.algo.ts:217", + "pc": [ + 235 + ] + }, + { + "teal": 124, + "source": "examples/reti/validatorRegistry.algo.ts:217", + "pc": [ + 236 + ] + }, + { + "teal": 125, + "source": "examples/reti/validatorRegistry.algo.ts:215", + "pc": [ + 237 + ] + }, + { + "teal": 130, + "source": "examples/reti/validatorRegistry.algo.ts:220", + "pc": [ + 238, + 239, + 240 + ] + }, + { + "teal": 131, + "source": "examples/reti/validatorRegistry.algo.ts:220", + "pc": [ + 241, + 242, + 243 + ] + }, + { + "teal": 134, + "source": "examples/reti/validatorRegistry.algo.ts:220", + "pc": [ + 244, + 245, + 246 + ] + }, + { + "teal": 135, + "source": "examples/reti/validatorRegistry.algo.ts:220", + "pc": [ + 247 + ] + }, + { + "teal": 138, + "source": "examples/reti/validatorRegistry.algo.ts:220", + "pc": [ + 248, + 249, + 250 + ] + }, + { + "teal": 139, + "source": "examples/reti/validatorRegistry.algo.ts:220", + "pc": [ + 251, + 252 + ] + }, + { + "teal": 140, + "source": "examples/reti/validatorRegistry.algo.ts:220", + "pc": [ + 253 + ] + }, + { + "teal": 144, + "source": "examples/reti/validatorRegistry.algo.ts:220", + "pc": [ + 254, + 255, + 256 + ] + }, + { + "teal": 148, + "source": "examples/reti/validatorRegistry.algo.ts:221", + "pc": [ + 257, + 258, + 259, + 260, + 261, + 262 + ] + }, + { + "teal": 149, + "source": "examples/reti/validatorRegistry.algo.ts:221", + "pc": [ + 263 + ] + }, + { + "teal": 150, + "source": "examples/reti/validatorRegistry.algo.ts:221", + "pc": [ + 264, + 265 + ] + }, + { + "teal": 151, + "source": "examples/reti/validatorRegistry.algo.ts:221", + "pc": [ + 266 + ] + }, + { + "teal": 152, + "source": "examples/reti/validatorRegistry.algo.ts:221", + "pc": [ + 267 + ] + }, + { + "teal": 153, + "source": "examples/reti/validatorRegistry.algo.ts:221", + "pc": [ + 268 + ] + }, + { + "teal": 157, + "source": "examples/reti/validatorRegistry.algo.ts:222", + "pc": [ + 269, + 270, + 271, + 272, + 273, + 274, + 275, + 276, + 277, + 278, + 279, + 280, + 281, + 282, + 283, + 284, + 285, + 286, + 287, + 288, + 289, + 290, + 291, + 292, + 293, + 294, + 295 + ] + }, + { + "teal": 158, + "source": "examples/reti/validatorRegistry.algo.ts:222", + "pc": [ + 296, + 297 + ] + }, + { + "teal": 159, + "source": "examples/reti/validatorRegistry.algo.ts:222", + "pc": [ + 298, + 299 + ] + }, + { + "teal": 160, + "source": "examples/reti/validatorRegistry.algo.ts:222", + "pc": [ + 300 + ] + }, + { + "teal": 161, + "source": "examples/reti/validatorRegistry.algo.ts:220", + "pc": [ + 301 + ] + }, + { + "teal": 166, + "source": "examples/reti/validatorRegistry.algo.ts:225", + "pc": [ + 302, + 303, + 304 + ] + }, + { + "teal": 167, + "source": "examples/reti/validatorRegistry.algo.ts:225", + "pc": [ + 305, + 306 + ] + }, + { + "teal": 168, + "source": "examples/reti/validatorRegistry.algo.ts:225", + "pc": [ + 307 + ] + }, + { + "teal": 172, + "source": "examples/reti/validatorRegistry.algo.ts:225", + "pc": [ + 308, + 309, + 310 + ] + }, + { + "teal": 176, + "source": "examples/reti/validatorRegistry.algo.ts:226", + "pc": [ + 311, + 312, + 313, + 314, + 315, + 316 + ] + }, + { + "teal": 177, + "source": "examples/reti/validatorRegistry.algo.ts:226", + "pc": [ + 317, + 318 + ] + }, + { + "teal": 178, + "source": "examples/reti/validatorRegistry.algo.ts:226", + "pc": [ + 319, + 320, + 321 + ] + }, + { + "teal": 179, + "source": "examples/reti/validatorRegistry.algo.ts:226", + "pc": [ + 322, + 323 + ] + }, + { + "teal": 180, + "source": "examples/reti/validatorRegistry.algo.ts:226", + "pc": [ + 324, + 325 + ] + }, + { + "teal": 181, + "source": "examples/reti/validatorRegistry.algo.ts:226", + "pc": [ + 326 + ] + }, + { + "teal": 182, + "source": "examples/reti/validatorRegistry.algo.ts:226", + "pc": [ + 327 + ] + }, + { + "teal": 183, + "source": "examples/reti/validatorRegistry.algo.ts:225", + "pc": [ + 328 + ] + }, + { + "teal": 188, + "source": "examples/reti/validatorRegistry.algo.ts:232", + "pc": [ + 329, + 330, + 331 + ] + }, + { + "teal": 189, + "source": "examples/reti/validatorRegistry.algo.ts:232", + "pc": [ + 332, + 333 + ] + }, + { + "teal": 190, + "source": "examples/reti/validatorRegistry.algo.ts:232", + "pc": [ + 334 + ] + }, + { + "teal": 196, + "source": "examples/reti/validatorRegistry.algo.ts:232", + "pc": [ + 335, + 336, + 337 + ] + }, + { + "teal": 197, + "source": "examples/reti/validatorRegistry.algo.ts:232", + "pc": [ + 338 + ] + }, + { + "teal": 202, + "source": "examples/reti/validatorRegistry.algo.ts:243", + "pc": [ + 339, + 340, + 341, + 342, + 343, + 344 + ] + }, + { + "teal": 205, + "source": "examples/reti/validatorRegistry.algo.ts:243", + "pc": [ + 345, + 346, + 347 + ] + }, + { + "teal": 206, + "source": "examples/reti/validatorRegistry.algo.ts:243", + "pc": [ + 348 + ] + }, + { + "teal": 207, + "source": "examples/reti/validatorRegistry.algo.ts:243", + "pc": [ + 349 + ] + }, + { + "teal": 208, + "source": "examples/reti/validatorRegistry.algo.ts:243", + "pc": [ + 350, + 351 + ] + }, + { + "teal": 209, + "source": "examples/reti/validatorRegistry.algo.ts:243", + "pc": [ + 352 + ] + }, + { + "teal": 221, + "source": "examples/reti/validatorRegistry.algo.ts:243", + "pc": [ + 353, + 354, + 355 + ] + }, + { + "teal": 244, + "source": "examples/reti/validatorRegistry.algo.ts:247", + "pc": [ + 356, + 357, + 358 + ] + }, + { + "teal": 245, + "source": "examples/reti/validatorRegistry.algo.ts:247", + "pc": [ + 359, + 360, + 361 + ] + }, + { + "teal": 246, + "source": "examples/reti/validatorRegistry.algo.ts:247", + "pc": [ + 362 + ] + }, + { + "teal": 247, + "source": "examples/reti/validatorRegistry.algo.ts:257", + "pc": [ + 363, + 364 + ] + }, + { + "teal": 248, + "source": "examples/reti/validatorRegistry.algo.ts:256", + "pc": [ + 365, + 366 + ] + }, + { + "teal": 249, + "source": "examples/reti/validatorRegistry.algo.ts:255", + "pc": [ + 367, + 368 + ] + }, + { + "teal": 250, + "source": "examples/reti/validatorRegistry.algo.ts:255", + "pc": [ + 369, + 370 + ] + }, + { + "teal": 251, + "source": "examples/reti/validatorRegistry.algo.ts:252", + "pc": [ + 371, + 372 + ] + }, + { + "teal": 252, + "source": "examples/reti/validatorRegistry.algo.ts:249", + "pc": [ + 373, + 374 + ] + }, + { + "teal": 253, + "source": "examples/reti/validatorRegistry.algo.ts:248", + "pc": [ + 375, + 376, + 377 + ] + }, + { + "teal": 254, + "source": "examples/reti/validatorRegistry.algo.ts:248", + "pc": [ + 378 + ] + }, + { + "teal": 255, + "source": "examples/reti/validatorRegistry.algo.ts:248", + "pc": [ + 379 + ] + }, + { + "teal": 256, + "source": "examples/reti/validatorRegistry.algo.ts:260", + "pc": [ + 380, + 381, + 382, + 383 + ] + }, + { + "teal": 257, + "source": "examples/reti/validatorRegistry.algo.ts:261", + "pc": [ + 384, + 385, + 386 + ] + }, + { + "teal": 258, + "source": "examples/reti/validatorRegistry.algo.ts:261", + "pc": [ + 387, + 388, + 389 + ] + }, + { + "teal": 259, + "source": "examples/reti/validatorRegistry.algo.ts:260", + "pc": [ + 390 + ] + }, + { + "teal": 260, + "source": "examples/reti/validatorRegistry.algo.ts:260", + "pc": [ + 391 + ] + }, + { + "teal": 261, + "source": "examples/reti/validatorRegistry.algo.ts:260", + "pc": [ + 392 + ] + }, + { + "teal": 262, + "source": "examples/reti/validatorRegistry.algo.ts:264", + "pc": [ + 393, + 394, + 395 + ] + }, + { + "teal": 263, + "source": "examples/reti/validatorRegistry.algo.ts:264", + "pc": [ + 396, + 397, + 398 + ] + }, + { + "teal": 264, + "source": "examples/reti/validatorRegistry.algo.ts:264", + "pc": [ + 399 + ] + }, + { + "teal": 265, + "source": "examples/reti/validatorRegistry.algo.ts:264", + "pc": [ + 400 + ] + }, + { + "teal": 266, + "source": "examples/reti/validatorRegistry.algo.ts:243", + "pc": [ + 401 + ] + }, + { + "teal": 271, + "source": "examples/reti/validatorRegistry.algo.ts:271", + "pc": [ + 402, + 403, + 404, + 405, + 406, + 407 + ] + }, + { + "teal": 274, + "source": "examples/reti/validatorRegistry.algo.ts:271", + "pc": [ + 408, + 409, + 410 + ] + }, + { + "teal": 275, + "source": "examples/reti/validatorRegistry.algo.ts:271", + "pc": [ + 411 + ] + }, + { + "teal": 276, + "source": "examples/reti/validatorRegistry.algo.ts:271", + "pc": [ + 412 + ] + }, + { + "teal": 277, + "source": "examples/reti/validatorRegistry.algo.ts:271", + "pc": [ + 413, + 414 + ] + }, + { + "teal": 278, + "source": "examples/reti/validatorRegistry.algo.ts:271", + "pc": [ + 415 + ] + }, + { + "teal": 284, + "source": "examples/reti/validatorRegistry.algo.ts:271", + "pc": [ + 416, + 417, + 418 + ] + }, + { + "teal": 300, + "source": "examples/reti/validatorRegistry.algo.ts:277", + "pc": [ + 419, + 420, + 421, + 422, + 423, + 424, + 425, + 426, + 427, + 428, + 429, + 430, + 431, + 432, + 433, + 434, + 435, + 436, + 437, + 438, + 439, + 440, + 441, + 442, + 443, + 444, + 445, + 446, + 447, + 448, + 449, + 450, + 451, + 452, + 453, + 454, + 455, + 456, + 457, + 458, + 459, + 460 + ] + }, + { + "teal": 301, + "source": "examples/reti/validatorRegistry.algo.ts:278", + "pc": [ + 461, + 462, + 463 + ] + }, + { + "teal": 302, + "source": "examples/reti/validatorRegistry.algo.ts:278", + "pc": [ + 464 + ] + }, + { + "teal": 303, + "source": "examples/reti/validatorRegistry.algo.ts:278", + "pc": [ + 465 + ] + }, + { + "teal": 304, + "source": "examples/reti/validatorRegistry.algo.ts:279", + "pc": [ + 466, + 467, + 468 + ] + }, + { + "teal": 305, + "source": "examples/reti/validatorRegistry.algo.ts:279", + "pc": [ + 469 + ] + }, + { + "teal": 306, + "source": "examples/reti/validatorRegistry.algo.ts:279", + "pc": [ + 470 + ] + }, + { + "teal": 307, + "source": "examples/reti/validatorRegistry.algo.ts:280", + "pc": [ + 471, + 472, + 473 + ] + }, + { + "teal": 308, + "source": "examples/reti/validatorRegistry.algo.ts:280", + "pc": [ + 474 + ] + }, + { + "teal": 309, + "source": "examples/reti/validatorRegistry.algo.ts:280", + "pc": [ + 475 + ] + }, + { + "teal": 310, + "source": "examples/reti/validatorRegistry.algo.ts:281", + "pc": [ + 476, + 477, + 478, + 479, + 480, + 481, + 482, + 483, + 484, + 485 + ] + }, + { + "teal": 311, + "source": "examples/reti/validatorRegistry.algo.ts:281", + "pc": [ + 486 + ] + }, + { + "teal": 312, + "source": "examples/reti/validatorRegistry.algo.ts:282", + "pc": [ + 487, + 488, + 489, + 490, + 491, + 492, + 493, + 494, + 495, + 496 + ] + }, + { + "teal": 313, + "source": "examples/reti/validatorRegistry.algo.ts:282", + "pc": [ + 497 + ] + }, + { + "teal": 314, + "source": "examples/reti/validatorRegistry.algo.ts:283", + "pc": [ + 498, + 499, + 500, + 501, + 502, + 503, + 504, + 505, + 506, + 507 + ] + }, + { + "teal": 315, + "source": "examples/reti/validatorRegistry.algo.ts:283", + "pc": [ + 508 + ] + }, + { + "teal": 316, + "source": "examples/reti/validatorRegistry.algo.ts:271", + "pc": [ + 509 + ] + }, + { + "teal": 321, + "source": "examples/reti/validatorRegistry.algo.ts:291", + "pc": [ + 510, + 511, + 512, + 513, + 514, + 515 + ] + }, + { + "teal": 324, + "source": "examples/reti/validatorRegistry.algo.ts:291", + "pc": [ + 516, + 517, + 518 + ] + }, + { + "teal": 325, + "source": "examples/reti/validatorRegistry.algo.ts:291", + "pc": [ + 519 + ] + }, + { + "teal": 326, + "source": "examples/reti/validatorRegistry.algo.ts:291", + "pc": [ + 520 + ] + }, + { + "teal": 327, + "source": "examples/reti/validatorRegistry.algo.ts:291", + "pc": [ + 521 + ] + }, + { + "teal": 328, + "source": "examples/reti/validatorRegistry.algo.ts:291", + "pc": [ + 522, + 523 + ] + }, + { + "teal": 329, + "source": "examples/reti/validatorRegistry.algo.ts:291", + "pc": [ + 524 + ] + }, + { + "teal": 335, + "source": "examples/reti/validatorRegistry.algo.ts:291", + "pc": [ + 525, + 526, + 527 + ] + }, + { + "teal": 339, + "source": "examples/reti/validatorRegistry.algo.ts:292", + "pc": [ + 528, + 529, + 530, + 531, + 532, + 533 + ] + }, + { + "teal": 340, + "source": "examples/reti/validatorRegistry.algo.ts:292", + "pc": [ + 534 + ] + }, + { + "teal": 341, + "source": "examples/reti/validatorRegistry.algo.ts:291", + "pc": [ + 535 + ] + }, + { + "teal": 346, + "source": "examples/reti/validatorRegistry.algo.ts:296", + "pc": [ + 536, + 537, + 538, + 539, + 540, + 541 + ] + }, + { + "teal": 349, + "source": "examples/reti/validatorRegistry.algo.ts:296", + "pc": [ + 542, + 543, + 544 + ] + }, + { + "teal": 350, + "source": "examples/reti/validatorRegistry.algo.ts:296", + "pc": [ + 545 + ] + }, + { + "teal": 353, + "source": "examples/reti/validatorRegistry.algo.ts:296", + "pc": [ + 546, + 547, + 548 + ] + }, + { + "teal": 354, + "source": "examples/reti/validatorRegistry.algo.ts:296", + "pc": [ + 549 + ] + }, + { + "teal": 355, + "source": "examples/reti/validatorRegistry.algo.ts:296", + "pc": [ + 550 + ] + }, + { + "teal": 356, + "source": "examples/reti/validatorRegistry.algo.ts:296", + "pc": [ + 551, + 552 + ] + }, + { + "teal": 357, + "source": "examples/reti/validatorRegistry.algo.ts:296", + "pc": [ + 553 + ] + }, + { + "teal": 361, + "source": "examples/reti/validatorRegistry.algo.ts:296", + "pc": [ + 554, + 555, + 556 + ] + }, + { + "teal": 365, + "source": "examples/reti/validatorRegistry.algo.ts:297", + "pc": [ + 557, + 558 + ] + }, + { + "teal": 366, + "source": "examples/reti/validatorRegistry.algo.ts:297", + "pc": [ + 559, + 560, + 561 + ] + }, + { + "teal": 367, + "source": "examples/reti/validatorRegistry.algo.ts:297", + "pc": [ + 562, + 563, + 564 + ] + }, + { + "teal": 368, + "source": "examples/reti/validatorRegistry.algo.ts:297", + "pc": [ + 565, + 566 + ] + }, + { + "teal": 369, + "source": "examples/reti/validatorRegistry.algo.ts:297", + "pc": [ + 567 + ] + }, + { + "teal": 370, + "source": "examples/reti/validatorRegistry.algo.ts:297", + "pc": [ + 568 + ] + }, + { + "teal": 371, + "source": "examples/reti/validatorRegistry.algo.ts:297", + "pc": [ + 569, + 570 + ] + }, + { + "teal": 372, + "source": "examples/reti/validatorRegistry.algo.ts:297", + "pc": [ + 571 + ] + }, + { + "teal": 373, + "source": "examples/reti/validatorRegistry.algo.ts:296", + "pc": [ + 572 + ] + }, + { + "teal": 378, + "source": "examples/reti/validatorRegistry.algo.ts:301", + "pc": [ + 573, + 574, + 575, + 576, + 577, + 578 + ] + }, + { + "teal": 381, + "source": "examples/reti/validatorRegistry.algo.ts:301", + "pc": [ + 579, + 580, + 581 + ] + }, + { + "teal": 382, + "source": "examples/reti/validatorRegistry.algo.ts:301", + "pc": [ + 582 + ] + }, + { + "teal": 385, + "source": "examples/reti/validatorRegistry.algo.ts:301", + "pc": [ + 583, + 584, + 585 + ] + }, + { + "teal": 386, + "source": "examples/reti/validatorRegistry.algo.ts:301", + "pc": [ + 586 + ] + }, + { + "teal": 387, + "source": "examples/reti/validatorRegistry.algo.ts:301", + "pc": [ + 587 + ] + }, + { + "teal": 388, + "source": "examples/reti/validatorRegistry.algo.ts:301", + "pc": [ + 588, + 589 + ] + }, + { + "teal": 389, + "source": "examples/reti/validatorRegistry.algo.ts:301", + "pc": [ + 590 + ] + }, + { + "teal": 393, + "source": "examples/reti/validatorRegistry.algo.ts:301", + "pc": [ + 591, + 592, + 593 + ] + }, + { + "teal": 397, + "source": "examples/reti/validatorRegistry.algo.ts:302", + "pc": [ + 594, + 595, + 596 + ] + }, + { + "teal": 398, + "source": "examples/reti/validatorRegistry.algo.ts:302", + "pc": [ + 597, + 598 + ] + }, + { + "teal": 399, + "source": "examples/reti/validatorRegistry.algo.ts:302", + "pc": [ + 599, + 600, + 601 + ] + }, + { + "teal": 400, + "source": "examples/reti/validatorRegistry.algo.ts:302", + "pc": [ + 602, + 603 + ] + }, + { + "teal": 401, + "source": "examples/reti/validatorRegistry.algo.ts:302", + "pc": [ + 604 + ] + }, + { + "teal": 402, + "source": "examples/reti/validatorRegistry.algo.ts:302", + "pc": [ + 605 + ] + }, + { + "teal": 403, + "source": "examples/reti/validatorRegistry.algo.ts:302", + "pc": [ + 606, + 607 + ] + }, + { + "teal": 404, + "source": "examples/reti/validatorRegistry.algo.ts:302", + "pc": [ + 608 + ] + }, + { + "teal": 405, + "source": "examples/reti/validatorRegistry.algo.ts:301", + "pc": [ + 609 + ] + }, + { + "teal": 410, + "source": "examples/reti/validatorRegistry.algo.ts:306", + "pc": [ + 610, + 611, + 612, + 613, + 614, + 615 + ] + }, + { + "teal": 413, + "source": "examples/reti/validatorRegistry.algo.ts:306", + "pc": [ + 616, + 617, + 618 + ] + }, + { + "teal": 414, + "source": "examples/reti/validatorRegistry.algo.ts:306", + "pc": [ + 619 + ] + }, + { + "teal": 417, + "source": "examples/reti/validatorRegistry.algo.ts:306", + "pc": [ + 620, + 621, + 622 + ] + }, + { + "teal": 418, + "source": "examples/reti/validatorRegistry.algo.ts:306", + "pc": [ + 623 + ] + }, + { + "teal": 419, + "source": "examples/reti/validatorRegistry.algo.ts:306", + "pc": [ + 624 + ] + }, + { + "teal": 420, + "source": "examples/reti/validatorRegistry.algo.ts:306", + "pc": [ + 625, + 626 + ] + }, + { + "teal": 421, + "source": "examples/reti/validatorRegistry.algo.ts:306", + "pc": [ + 627 + ] + }, + { + "teal": 425, + "source": "examples/reti/validatorRegistry.algo.ts:306", + "pc": [ + 628, + 629, + 630 + ] + }, + { + "teal": 429, + "source": "examples/reti/validatorRegistry.algo.ts:307", + "pc": [ + 631, + 632 + ] + }, + { + "teal": 430, + "source": "examples/reti/validatorRegistry.algo.ts:307", + "pc": [ + 633, + 634 + ] + }, + { + "teal": 431, + "source": "examples/reti/validatorRegistry.algo.ts:307", + "pc": [ + 635, + 636, + 637 + ] + }, + { + "teal": 432, + "source": "examples/reti/validatorRegistry.algo.ts:307", + "pc": [ + 638, + 639 + ] + }, + { + "teal": 433, + "source": "examples/reti/validatorRegistry.algo.ts:307", + "pc": [ + 640 + ] + }, + { + "teal": 434, + "source": "examples/reti/validatorRegistry.algo.ts:307", + "pc": [ + 641 + ] + }, + { + "teal": 435, + "source": "examples/reti/validatorRegistry.algo.ts:307", + "pc": [ + 642, + 643 + ] + }, + { + "teal": 436, + "source": "examples/reti/validatorRegistry.algo.ts:307", + "pc": [ + 644 + ] + }, + { + "teal": 437, + "source": "examples/reti/validatorRegistry.algo.ts:307", + "pc": [ + 645, + 646 + ] + }, + { + "teal": 438, + "source": "examples/reti/validatorRegistry.algo.ts:307", + "pc": [ + 647, + 648 + ] + }, + { + "teal": 439, + "source": "examples/reti/validatorRegistry.algo.ts:307", + "pc": [ + 649, + 650, + 651 + ] + }, + { + "teal": 440, + "source": "examples/reti/validatorRegistry.algo.ts:307", + "pc": [ + 652, + 653 + ] + }, + { + "teal": 441, + "source": "examples/reti/validatorRegistry.algo.ts:307", + "pc": [ + 654 + ] + }, + { + "teal": 442, + "source": "examples/reti/validatorRegistry.algo.ts:307", + "pc": [ + 655 + ] + }, + { + "teal": 443, + "source": "examples/reti/validatorRegistry.algo.ts:307", + "pc": [ + 656, + 657 + ] + }, + { + "teal": 444, + "source": "examples/reti/validatorRegistry.algo.ts:307", + "pc": [ + 658 + ] + }, + { + "teal": 445, + "source": "examples/reti/validatorRegistry.algo.ts:307", + "pc": [ + 659 + ] + }, + { + "teal": 446, + "source": "examples/reti/validatorRegistry.algo.ts:306", + "pc": [ + 660 + ] + }, + { + "teal": 451, + "source": "examples/reti/validatorRegistry.algo.ts:317", + "pc": [ + 661, + 662, + 663, + 664, + 665, + 666 + ] + }, + { + "teal": 454, + "source": "examples/reti/validatorRegistry.algo.ts:317", + "pc": [ + 667, + 668, + 669 + ] + }, + { + "teal": 455, + "source": "examples/reti/validatorRegistry.algo.ts:317", + "pc": [ + 670 + ] + }, + { + "teal": 458, + "source": "examples/reti/validatorRegistry.algo.ts:317", + "pc": [ + 671, + 672, + 673 + ] + }, + { + "teal": 459, + "source": "examples/reti/validatorRegistry.algo.ts:317", + "pc": [ + 674 + ] + }, + { + "teal": 460, + "source": "examples/reti/validatorRegistry.algo.ts:317", + "pc": [ + 675 + ] + }, + { + "teal": 461, + "source": "examples/reti/validatorRegistry.algo.ts:317", + "pc": [ + 676, + 677 + ] + }, + { + "teal": 462, + "source": "examples/reti/validatorRegistry.algo.ts:317", + "pc": [ + 678 + ] + }, + { + "teal": 463, + "source": "examples/reti/validatorRegistry.algo.ts:317", + "pc": [ + 679 + ] + }, + { + "teal": 464, + "source": "examples/reti/validatorRegistry.algo.ts:317", + "pc": [ + 680, + 681, + 682 + ] + }, + { + "teal": 465, + "source": "examples/reti/validatorRegistry.algo.ts:317", + "pc": [ + 683 + ] + }, + { + "teal": 466, + "source": "examples/reti/validatorRegistry.algo.ts:317", + "pc": [ + 684 + ] + }, + { + "teal": 467, + "source": "examples/reti/validatorRegistry.algo.ts:317", + "pc": [ + 685 + ] + }, + { + "teal": 468, + "source": "examples/reti/validatorRegistry.algo.ts:317", + "pc": [ + 686 + ] + }, + { + "teal": 469, + "source": "examples/reti/validatorRegistry.algo.ts:317", + "pc": [ + 687, + 688 + ] + }, + { + "teal": 470, + "source": "examples/reti/validatorRegistry.algo.ts:317", + "pc": [ + 689 + ] + }, + { + "teal": 479, + "source": "examples/reti/validatorRegistry.algo.ts:317", + "pc": [ + 690, + 691, + 692 + ] + }, + { + "teal": 482, + "source": "examples/reti/validatorRegistry.algo.ts:317", + "pc": [ + 693, + 694 + ] + }, + { + "teal": 483, + "source": "examples/reti/validatorRegistry.algo.ts:317", + "pc": [ + 695, + 696 + ] + }, + { + "teal": 487, + "source": "examples/reti/validatorRegistry.algo.ts:318", + "pc": [ + 697, + 698 + ] + }, + { + "teal": 488, + "source": "examples/reti/validatorRegistry.algo.ts:318", + "pc": [ + 699, + 700 + ] + }, + { + "teal": 492, + "source": "examples/reti/validatorRegistry.algo.ts:319", + "pc": [ + 701, + 702, + 703 + ] + }, + { + "teal": 493, + "source": "examples/reti/validatorRegistry.algo.ts:319", + "pc": [ + 704, + 705, + 706 + ] + }, + { + "teal": 494, + "source": "examples/reti/validatorRegistry.algo.ts:319", + "pc": [ + 707, + 708, + 709 + ] + }, + { + "teal": 495, + "source": "examples/reti/validatorRegistry.algo.ts:319", + "pc": [ + 710, + 711 + ] + }, + { + "teal": 496, + "source": "examples/reti/validatorRegistry.algo.ts:319", + "pc": [ + 712 + ] + }, + { + "teal": 497, + "source": "examples/reti/validatorRegistry.algo.ts:319", + "pc": [ + 713 + ] + }, + { + "teal": 498, + "source": "examples/reti/validatorRegistry.algo.ts:319", + "pc": [ + 714, + 715 + ] + }, + { + "teal": 499, + "source": "examples/reti/validatorRegistry.algo.ts:319", + "pc": [ + 716 + ] + }, + { + "teal": 500, + "source": "examples/reti/validatorRegistry.algo.ts:319", + "pc": [ + 717, + 718 + ] + }, + { + "teal": 504, + "source": "examples/reti/validatorRegistry.algo.ts:320", + "pc": [ + 719, + 720 + ] + }, + { + "teal": 505, + "source": "examples/reti/validatorRegistry.algo.ts:320", + "pc": [ + 721, + 722 + ] + }, + { + "teal": 510, + "source": "examples/reti/validatorRegistry.algo.ts:320", + "pc": [ + 723, + 724 + ] + }, + { + "teal": 511, + "source": "examples/reti/validatorRegistry.algo.ts:320", + "pc": [ + 725, + 726 + ] + }, + { + "teal": 512, + "source": "examples/reti/validatorRegistry.algo.ts:320", + "pc": [ + 727 + ] + }, + { + "teal": 513, + "source": "examples/reti/validatorRegistry.algo.ts:320", + "pc": [ + 728, + 729, + 730 + ] + }, + { + "teal": 518, + "source": "examples/reti/validatorRegistry.algo.ts:321", + "pc": [ + 731, + 732 + ] + }, + { + "teal": 519, + "source": "examples/reti/validatorRegistry.algo.ts:321", + "pc": [ + 733, + 734 + ] + }, + { + "teal": 520, + "source": "examples/reti/validatorRegistry.algo.ts:321", + "pc": [ + 735, + 736 + ] + }, + { + "teal": 521, + "source": "examples/reti/validatorRegistry.algo.ts:321", + "pc": [ + 737 + ] + }, + { + "teal": 522, + "source": "examples/reti/validatorRegistry.algo.ts:321", + "pc": [ + 738, + 739 + ] + }, + { + "teal": 523, + "source": "examples/reti/validatorRegistry.algo.ts:321", + "pc": [ + 740 + ] + }, + { + "teal": 524, + "source": "examples/reti/validatorRegistry.algo.ts:321", + "pc": [ + 741, + 742 + ] + }, + { + "teal": 525, + "source": "examples/reti/validatorRegistry.algo.ts:321", + "pc": [ + 743 + ] + }, + { + "teal": 526, + "source": "examples/reti/validatorRegistry.algo.ts:321", + "pc": [ + 744 + ] + }, + { + "teal": 527, + "source": "examples/reti/validatorRegistry.algo.ts:321", + "pc": [ + 745, + 746 + ] + }, + { + "teal": 528, + "source": "examples/reti/validatorRegistry.algo.ts:321", + "pc": [ + 747 + ] + }, + { + "teal": 529, + "source": "examples/reti/validatorRegistry.algo.ts:321", + "pc": [ + 748, + 749, + 750 + ] + }, + { + "teal": 532, + "source": "examples/reti/validatorRegistry.algo.ts:323", + "pc": [ + 751, + 752, + 753 + ] + }, + { + "teal": 537, + "source": "examples/reti/validatorRegistry.algo.ts:325", + "pc": [ + 754, + 755 + ] + }, + { + "teal": 538, + "source": "examples/reti/validatorRegistry.algo.ts:325", + "pc": [ + 756, + 757 + ] + }, + { + "teal": 539, + "source": "examples/reti/validatorRegistry.algo.ts:325", + "pc": [ + 758, + 759 + ] + }, + { + "teal": 540, + "source": "examples/reti/validatorRegistry.algo.ts:325", + "pc": [ + 760, + 761 + ] + }, + { + "teal": 541, + "source": "examples/reti/validatorRegistry.algo.ts:325", + "pc": [ + 762 + ] + }, + { + "teal": 542, + "source": "examples/reti/validatorRegistry.algo.ts:325", + "pc": [ + 763, + 764 + ] + }, + { + "teal": 543, + "source": "examples/reti/validatorRegistry.algo.ts:325", + "pc": [ + 765 + ] + }, + { + "teal": 544, + "source": "examples/reti/validatorRegistry.algo.ts:325", + "pc": [ + 766 + ] + }, + { + "teal": 545, + "source": "examples/reti/validatorRegistry.algo.ts:325", + "pc": [ + 767, + 768 + ] + }, + { + "teal": 550, + "source": "examples/reti/validatorRegistry.algo.ts:320", + "pc": [ + 769, + 770 + ] + }, + { + "teal": 551, + "source": "examples/reti/validatorRegistry.algo.ts:320", + "pc": [ + 771, + 772 + ] + }, + { + "teal": 552, + "source": "examples/reti/validatorRegistry.algo.ts:320", + "pc": [ + 773 + ] + }, + { + "teal": 553, + "source": "examples/reti/validatorRegistry.algo.ts:320", + "pc": [ + 774, + 775 + ] + }, + { + "teal": 554, + "source": "examples/reti/validatorRegistry.algo.ts:320", + "pc": [ + 776, + 777, + 778 + ] + }, + { + "teal": 559, + "source": "examples/reti/validatorRegistry.algo.ts:327", + "pc": [ + 779, + 780 + ] + }, + { + "teal": 562, + "source": "examples/reti/validatorRegistry.algo.ts:317", + "pc": [ + 781, + 782 + ] + }, + { + "teal": 565, + "source": "examples/reti/validatorRegistry.algo.ts:317", + "pc": [ + 783, + 784 + ] + }, + { + "teal": 566, + "source": "examples/reti/validatorRegistry.algo.ts:317", + "pc": [ + 785 + ] + }, + { + "teal": 571, + "source": "examples/reti/validatorRegistry.algo.ts:334", + "pc": [ + 786, + 787, + 788, + 789, + 790, + 791 + ] + }, + { + "teal": 574, + "source": "examples/reti/validatorRegistry.algo.ts:334", + "pc": [ + 792, + 793, + 794 + ] + }, + { + "teal": 575, + "source": "examples/reti/validatorRegistry.algo.ts:334", + "pc": [ + 795 + ] + }, + { + "teal": 578, + "source": "examples/reti/validatorRegistry.algo.ts:334", + "pc": [ + 796, + 797, + 798 + ] + }, + { + "teal": 579, + "source": "examples/reti/validatorRegistry.algo.ts:334", + "pc": [ + 799 + ] + }, + { + "teal": 582, + "source": "examples/reti/validatorRegistry.algo.ts:334", + "pc": [ + 800, + 801, + 802 + ] + }, + { + "teal": 583, + "source": "examples/reti/validatorRegistry.algo.ts:334", + "pc": [ + 803 + ] + }, + { + "teal": 584, + "source": "examples/reti/validatorRegistry.algo.ts:334", + "pc": [ + 804 + ] + }, + { + "teal": 585, + "source": "examples/reti/validatorRegistry.algo.ts:334", + "pc": [ + 805 + ] + }, + { + "teal": 586, + "source": "examples/reti/validatorRegistry.algo.ts:334", + "pc": [ + 806, + 807 + ] + }, + { + "teal": 587, + "source": "examples/reti/validatorRegistry.algo.ts:334", + "pc": [ + 808 + ] + }, + { + "teal": 591, + "source": "examples/reti/validatorRegistry.algo.ts:334", + "pc": [ + 809, + 810, + 811 + ] + }, + { + "teal": 598, + "source": "examples/reti/validatorRegistry.algo.ts:336", + "pc": [ + 812, + 813 + ] + }, + { + "teal": 599, + "source": "examples/reti/validatorRegistry.algo.ts:336", + "pc": [ + 814, + 815 + ] + }, + { + "teal": 600, + "source": "examples/reti/validatorRegistry.algo.ts:336", + "pc": [ + 816 + ] + }, + { + "teal": 601, + "source": "examples/reti/validatorRegistry.algo.ts:336", + "pc": [ + 817 + ] + }, + { + "teal": 602, + "source": "examples/reti/validatorRegistry.algo.ts:336", + "pc": [ + 818, + 819, + 820 + ] + }, + { + "teal": 603, + "source": "examples/reti/validatorRegistry.algo.ts:336", + "pc": [ + 821, + 822 + ] + }, + { + "teal": 604, + "source": "examples/reti/validatorRegistry.algo.ts:336", + "pc": [ + 823, + 824 + ] + }, + { + "teal": 605, + "source": "examples/reti/validatorRegistry.algo.ts:336", + "pc": [ + 825 + ] + }, + { + "teal": 606, + "source": "examples/reti/validatorRegistry.algo.ts:336", + "pc": [ + 826 + ] + }, + { + "teal": 610, + "source": "examples/reti/validatorRegistry.algo.ts:335", + "errorMessage": "pool id must be between 1 and number of pools for this validator", + "pc": [ + 827 + ] + }, + { + "teal": 614, + "source": "examples/reti/validatorRegistry.algo.ts:339", + "pc": [ + 828, + 829, + 830 + ] + }, + { + "teal": 615, + "source": "examples/reti/validatorRegistry.algo.ts:339", + "pc": [ + 831, + 832 + ] + }, + { + "teal": 616, + "source": "examples/reti/validatorRegistry.algo.ts:339", + "pc": [ + 833, + 834 + ] + }, + { + "teal": 617, + "source": "examples/reti/validatorRegistry.algo.ts:339", + "pc": [ + 835 + ] + }, + { + "teal": 618, + "source": "examples/reti/validatorRegistry.algo.ts:339", + "pc": [ + 836, + 837 + ] + }, + { + "teal": 619, + "source": "examples/reti/validatorRegistry.algo.ts:339", + "pc": [ + 838 + ] + }, + { + "teal": 620, + "source": "examples/reti/validatorRegistry.algo.ts:339", + "pc": [ + 839 + ] + }, + { + "teal": 621, + "source": "examples/reti/validatorRegistry.algo.ts:339", + "pc": [ + 840, + 841 + ] + }, + { + "teal": 622, + "source": "examples/reti/validatorRegistry.algo.ts:339", + "pc": [ + 842 + ] + }, + { + "teal": 623, + "source": "examples/reti/validatorRegistry.algo.ts:339", + "pc": [ + 843, + 844 + ] + }, + { + "teal": 624, + "source": "examples/reti/validatorRegistry.algo.ts:339", + "pc": [ + 845, + 846, + 847 + ] + }, + { + "teal": 625, + "source": "examples/reti/validatorRegistry.algo.ts:339", + "pc": [ + 848, + 849 + ] + }, + { + "teal": 626, + "source": "examples/reti/validatorRegistry.algo.ts:339", + "pc": [ + 850 + ] + }, + { + "teal": 627, + "source": "examples/reti/validatorRegistry.algo.ts:339", + "pc": [ + 851 + ] + }, + { + "teal": 628, + "source": "examples/reti/validatorRegistry.algo.ts:339", + "pc": [ + 852, + 853 + ] + }, + { + "teal": 629, + "source": "examples/reti/validatorRegistry.algo.ts:339", + "pc": [ + 854 + ] + }, + { + "teal": 630, + "source": "examples/reti/validatorRegistry.algo.ts:339", + "pc": [ + 855 + ] + }, + { + "teal": 631, + "source": "examples/reti/validatorRegistry.algo.ts:334", + "pc": [ + 856 + ] + }, + { + "teal": 636, + "source": "examples/reti/validatorRegistry.algo.ts:343", + "pc": [ + 857, + 858, + 859, + 860, + 861, + 862 + ] + }, + { + "teal": 639, + "source": "examples/reti/validatorRegistry.algo.ts:343", + "pc": [ + 863, + 864, + 865 + ] + }, + { + "teal": 640, + "source": "examples/reti/validatorRegistry.algo.ts:343", + "pc": [ + 866 + ] + }, + { + "teal": 641, + "source": "examples/reti/validatorRegistry.algo.ts:343", + "pc": [ + 867 + ] + }, + { + "teal": 642, + "source": "examples/reti/validatorRegistry.algo.ts:343", + "pc": [ + 868, + 869 + ] + }, + { + "teal": 643, + "source": "examples/reti/validatorRegistry.algo.ts:343", + "pc": [ + 870 + ] + }, + { + "teal": 646, + "source": "examples/reti/validatorRegistry.algo.ts:343", + "errorMessage": "argument 0 (poolKey) for getPoolInfo must be a (uint64,uint64,uint64)", + "pc": [ + 871 + ] + }, + { + "teal": 649, + "source": "examples/reti/validatorRegistry.algo.ts:343", + "pc": [ + 872, + 873, + 874 + ] + }, + { + "teal": 650, + "source": "examples/reti/validatorRegistry.algo.ts:343", + "pc": [ + 875 + ] + }, + { + "teal": 651, + "source": "examples/reti/validatorRegistry.algo.ts:343", + "pc": [ + 876 + ] + }, + { + "teal": 652, + "source": "examples/reti/validatorRegistry.algo.ts:343", + "pc": [ + 877, + 878 + ] + }, + { + "teal": 653, + "source": "examples/reti/validatorRegistry.algo.ts:343", + "pc": [ + 879 + ] + }, + { + "teal": 657, + "source": "examples/reti/validatorRegistry.algo.ts:343", + "pc": [ + 880, + 881, + 882 + ] + }, + { + "teal": 661, + "source": "examples/reti/validatorRegistry.algo.ts:344", + "pc": [ + 883, + 884, + 885 + ] + }, + { + "teal": 662, + "source": "examples/reti/validatorRegistry.algo.ts:344", + "pc": [ + 886, + 887 + ] + }, + { + "teal": 663, + "source": "examples/reti/validatorRegistry.algo.ts:344", + "pc": [ + 888, + 889, + 890 + ] + }, + { + "teal": 664, + "source": "examples/reti/validatorRegistry.algo.ts:344", + "pc": [ + 891 + ] + }, + { + "teal": 665, + "source": "examples/reti/validatorRegistry.algo.ts:344", + "pc": [ + 892, + 893 + ] + }, + { + "teal": 666, + "source": "examples/reti/validatorRegistry.algo.ts:344", + "pc": [ + 894 + ] + }, + { + "teal": 667, + "source": "examples/reti/validatorRegistry.algo.ts:344", + "pc": [ + 895, + 896 + ] + }, + { + "teal": 668, + "source": "examples/reti/validatorRegistry.algo.ts:344", + "pc": [ + 897 + ] + }, + { + "teal": 669, + "source": "examples/reti/validatorRegistry.algo.ts:344", + "pc": [ + 898 + ] + }, + { + "teal": 670, + "source": "examples/reti/validatorRegistry.algo.ts:344", + "pc": [ + 899, + 900 + ] + }, + { + "teal": 671, + "source": "examples/reti/validatorRegistry.algo.ts:344", + "pc": [ + 901, + 902, + 903 + ] + }, + { + "teal": 672, + "source": "examples/reti/validatorRegistry.algo.ts:344", + "pc": [ + 904, + 905 + ] + }, + { + "teal": 673, + "source": "examples/reti/validatorRegistry.algo.ts:344", + "pc": [ + 906, + 907, + 908 + ] + }, + { + "teal": 674, + "source": "examples/reti/validatorRegistry.algo.ts:344", + "pc": [ + 909 + ] + }, + { + "teal": 675, + "source": "examples/reti/validatorRegistry.algo.ts:344", + "pc": [ + 910 + ] + }, + { + "teal": 676, + "source": "examples/reti/validatorRegistry.algo.ts:344", + "pc": [ + 911 + ] + }, + { + "teal": 677, + "source": "examples/reti/validatorRegistry.algo.ts:344", + "pc": [ + 912, + 913 + ] + }, + { + "teal": 678, + "source": "examples/reti/validatorRegistry.algo.ts:344", + "pc": [ + 914 + ] + }, + { + "teal": 679, + "source": "examples/reti/validatorRegistry.algo.ts:343", + "pc": [ + 915 + ] + }, + { + "teal": 684, + "source": "examples/reti/validatorRegistry.algo.ts:354", + "pc": [ + 916, + 917, + 918, + 919, + 920, + 921 + ] + }, + { + "teal": 687, + "source": "examples/reti/validatorRegistry.algo.ts:354", + "pc": [ + 922, + 923, + 924 + ] + }, + { + "teal": 688, + "source": "examples/reti/validatorRegistry.algo.ts:354", + "pc": [ + 925 + ] + }, + { + "teal": 691, + "source": "examples/reti/validatorRegistry.algo.ts:354", + "pc": [ + 926, + 927, + 928 + ] + }, + { + "teal": 692, + "source": "examples/reti/validatorRegistry.algo.ts:354", + "pc": [ + 929 + ] + }, + { + "teal": 693, + "source": "examples/reti/validatorRegistry.algo.ts:354", + "pc": [ + 930 + ] + }, + { + "teal": 694, + "source": "examples/reti/validatorRegistry.algo.ts:354", + "pc": [ + 931 + ] + }, + { + "teal": 695, + "source": "examples/reti/validatorRegistry.algo.ts:354", + "pc": [ + 932, + 933 + ] + }, + { + "teal": 696, + "source": "examples/reti/validatorRegistry.algo.ts:354", + "pc": [ + 934 + ] + }, + { + "teal": 706, + "source": "examples/reti/validatorRegistry.algo.ts:354", + "pc": [ + 935, + 936, + 937 + ] + }, + { + "teal": 709, + "source": "examples/reti/validatorRegistry.algo.ts:354", + "pc": [ + 938, + 939 + ] + }, + { + "teal": 710, + "source": "examples/reti/validatorRegistry.algo.ts:354", + "pc": [ + 940, + 941 + ] + }, + { + "teal": 714, + "source": "examples/reti/validatorRegistry.algo.ts:355", + "pc": [ + 942, + 943, + 944 + ] + }, + { + "teal": 715, + "source": "examples/reti/validatorRegistry.algo.ts:355", + "pc": [ + 945, + 946 + ] + }, + { + "teal": 716, + "source": "examples/reti/validatorRegistry.algo.ts:355", + "pc": [ + 947, + 948, + 949 + ] + }, + { + "teal": 717, + "source": "examples/reti/validatorRegistry.algo.ts:355", + "pc": [ + 950, + 951 + ] + }, + { + "teal": 718, + "source": "examples/reti/validatorRegistry.algo.ts:355", + "pc": [ + 952 + ] + }, + { + "teal": 719, + "source": "examples/reti/validatorRegistry.algo.ts:355", + "pc": [ + 953 + ] + }, + { + "teal": 720, + "source": "examples/reti/validatorRegistry.algo.ts:355", + "pc": [ + 954, + 955 + ] + }, + { + "teal": 721, + "source": "examples/reti/validatorRegistry.algo.ts:355", + "pc": [ + 956 + ] + }, + { + "teal": 722, + "source": "examples/reti/validatorRegistry.algo.ts:355", + "pc": [ + 957 + ] + }, + { + "teal": 723, + "source": "examples/reti/validatorRegistry.algo.ts:355", + "pc": [ + 958, + 959 + ] + }, + { + "teal": 727, + "source": "examples/reti/validatorRegistry.algo.ts:356", + "pc": [ + 960, + 961, + 962 + ] + }, + { + "teal": 728, + "source": "examples/reti/validatorRegistry.algo.ts:356", + "pc": [ + 963, + 964 + ] + }, + { + "teal": 729, + "source": "examples/reti/validatorRegistry.algo.ts:356", + "pc": [ + 965 + ] + }, + { + "teal": 730, + "source": "examples/reti/validatorRegistry.algo.ts:356", + "pc": [ + 966, + 967 + ] + }, + { + "teal": 734, + "source": "examples/reti/validatorRegistry.algo.ts:357", + "pc": [ + 968, + 969, + 970 + ] + }, + { + "teal": 735, + "source": "examples/reti/validatorRegistry.algo.ts:357", + "pc": [ + 971, + 972 + ] + }, + { + "teal": 736, + "source": "examples/reti/validatorRegistry.algo.ts:357", + "pc": [ + 973, + 974, + 975 + ] + }, + { + "teal": 737, + "source": "examples/reti/validatorRegistry.algo.ts:357", + "pc": [ + 976, + 977 + ] + }, + { + "teal": 738, + "source": "examples/reti/validatorRegistry.algo.ts:357", + "pc": [ + 978 + ] + }, + { + "teal": 739, + "source": "examples/reti/validatorRegistry.algo.ts:357", + "pc": [ + 979 + ] + }, + { + "teal": 740, + "source": "examples/reti/validatorRegistry.algo.ts:357", + "pc": [ + 980, + 981 + ] + }, + { + "teal": 741, + "source": "examples/reti/validatorRegistry.algo.ts:357", + "pc": [ + 982 + ] + }, + { + "teal": 742, + "source": "examples/reti/validatorRegistry.algo.ts:357", + "pc": [ + 983 + ] + }, + { + "teal": 743, + "source": "examples/reti/validatorRegistry.algo.ts:357", + "pc": [ + 984, + 985 + ] + }, + { + "teal": 748, + "source": "examples/reti/validatorRegistry.algo.ts:358", + "pc": [ + 986, + 987 + ] + }, + { + "teal": 749, + "source": "examples/reti/validatorRegistry.algo.ts:358", + "pc": [ + 988, + 989 + ] + }, + { + "teal": 750, + "source": "examples/reti/validatorRegistry.algo.ts:358", + "pc": [ + 990 + ] + }, + { + "teal": 751, + "source": "examples/reti/validatorRegistry.algo.ts:358", + "pc": [ + 991, + 992, + 993 + ] + }, + { + "teal": 756, + "source": "examples/reti/validatorRegistry.algo.ts:359", + "pc": [ + 994, + 995, + 996 + ] + }, + { + "teal": 757, + "source": "examples/reti/validatorRegistry.algo.ts:359", + "pc": [ + 997, + 998 + ] + }, + { + "teal": 763, + "source": "examples/reti/validatorRegistry.algo.ts:361", + "pc": [ + 999, + 1000 + ] + }, + { + "teal": 764, + "source": "examples/reti/validatorRegistry.algo.ts:361", + "pc": [ + 1001, + 1002 + ] + }, + { + "teal": 765, + "source": "examples/reti/validatorRegistry.algo.ts:361", + "pc": [ + 1003 + ] + }, + { + "teal": 766, + "source": "examples/reti/validatorRegistry.algo.ts:361", + "pc": [ + 1004, + 1005, + 1006 + ] + }, + { + "teal": 771, + "source": "examples/reti/validatorRegistry.algo.ts:362", + "pc": [ + 1007, + 1008 + ] + }, + { + "teal": 772, + "source": "examples/reti/validatorRegistry.algo.ts:362", + "pc": [ + 1009, + 1010 + ] + }, + { + "teal": 777, + "source": "examples/reti/validatorRegistry.algo.ts:364", + "pc": [ + 1011, + 1012 + ] + }, + { + "teal": 780, + "source": "examples/reti/validatorRegistry.algo.ts:354", + "pc": [ + 1013, + 1014 + ] + }, + { + "teal": 783, + "source": "examples/reti/validatorRegistry.algo.ts:354", + "pc": [ + 1015, + 1016 + ] + }, + { + "teal": 784, + "source": "examples/reti/validatorRegistry.algo.ts:354", + "pc": [ + 1017 + ] + }, + { + "teal": 789, + "source": "examples/reti/validatorRegistry.algo.ts:372", + "pc": [ + 1018, + 1019, + 1020, + 1021, + 1022, + 1023 + ] + }, + { + "teal": 792, + "source": "examples/reti/validatorRegistry.algo.ts:372", + "pc": [ + 1024, + 1025, + 1026 + ] + }, + { + "teal": 793, + "source": "examples/reti/validatorRegistry.algo.ts:372", + "pc": [ + 1027 + ] + }, + { + "teal": 794, + "source": "examples/reti/validatorRegistry.algo.ts:372", + "pc": [ + 1028 + ] + }, + { + "teal": 795, + "source": "examples/reti/validatorRegistry.algo.ts:372", + "pc": [ + 1029, + 1030 + ] + }, + { + "teal": 796, + "source": "examples/reti/validatorRegistry.algo.ts:372", + "pc": [ + 1031 + ] + }, + { + "teal": 799, + "source": "examples/reti/validatorRegistry.algo.ts:372", + "errorMessage": "argument 0 (staker) for doesStakerNeedToPayMBR must be a address", + "pc": [ + 1032 + ] + }, + { + "teal": 802, + "source": "examples/reti/validatorRegistry.algo.ts:372", + "pc": [ + 1033, + 1034, + 1035 + ] + }, + { + "teal": 803, + "source": "examples/reti/validatorRegistry.algo.ts:372", + "pc": [ + 1036, + 1037, + 1038 + ] + }, + { + "teal": 804, + "source": "examples/reti/validatorRegistry.algo.ts:372", + "pc": [ + 1039, + 1040 + ] + }, + { + "teal": 805, + "source": "examples/reti/validatorRegistry.algo.ts:372", + "pc": [ + 1041, + 1042 + ] + }, + { + "teal": 806, + "source": "examples/reti/validatorRegistry.algo.ts:372", + "pc": [ + 1043 + ] + }, + { + "teal": 807, + "source": "examples/reti/validatorRegistry.algo.ts:372", + "pc": [ + 1044 + ] + }, + { + "teal": 808, + "source": "examples/reti/validatorRegistry.algo.ts:372", + "pc": [ + 1045 + ] + }, + { + "teal": 809, + "source": "examples/reti/validatorRegistry.algo.ts:372", + "pc": [ + 1046, + 1047 + ] + }, + { + "teal": 810, + "source": "examples/reti/validatorRegistry.algo.ts:372", + "pc": [ + 1048 + ] + }, + { + "teal": 817, + "source": "examples/reti/validatorRegistry.algo.ts:372", + "pc": [ + 1049, + 1050, + 1051 + ] + }, + { + "teal": 821, + "source": "examples/reti/validatorRegistry.algo.ts:373", + "pc": [ + 1052, + 1053, + 1054, + 1055, + 1056 + ] + }, + { + "teal": 822, + "source": "examples/reti/validatorRegistry.algo.ts:373", + "pc": [ + 1057, + 1058 + ] + }, + { + "teal": 823, + "source": "examples/reti/validatorRegistry.algo.ts:373", + "pc": [ + 1059 + ] + }, + { + "teal": 824, + "source": "examples/reti/validatorRegistry.algo.ts:373", + "pc": [ + 1060 + ] + }, + { + "teal": 825, + "source": "examples/reti/validatorRegistry.algo.ts:373", + "pc": [ + 1061 + ] + }, + { + "teal": 826, + "source": "examples/reti/validatorRegistry.algo.ts:373", + "pc": [ + 1062 + ] + }, + { + "teal": 827, + "source": "examples/reti/validatorRegistry.algo.ts:373", + "pc": [ + 1063 + ] + }, + { + "teal": 828, + "source": "examples/reti/validatorRegistry.algo.ts:372", + "pc": [ + 1064 + ] + }, + { + "teal": 833, + "source": "examples/reti/validatorRegistry.algo.ts:382", + "pc": [ + 1065, + 1066, + 1067, + 1068, + 1069, + 1070 + ] + }, + { + "teal": 836, + "source": "examples/reti/validatorRegistry.algo.ts:382", + "pc": [ + 1071, + 1072, + 1073 + ] + }, + { + "teal": 837, + "source": "examples/reti/validatorRegistry.algo.ts:382", + "pc": [ + 1074 + ] + }, + { + "teal": 838, + "source": "examples/reti/validatorRegistry.algo.ts:382", + "pc": [ + 1075 + ] + }, + { + "teal": 839, + "source": "examples/reti/validatorRegistry.algo.ts:382", + "pc": [ + 1076, + 1077 + ] + }, + { + "teal": 840, + "source": "examples/reti/validatorRegistry.algo.ts:382", + "pc": [ + 1078 + ] + }, + { + "teal": 843, + "source": "examples/reti/validatorRegistry.algo.ts:382", + "errorMessage": "argument 0 (staker) for getStakedPoolsForAccount must be a address", + "pc": [ + 1079 + ] + }, + { + "teal": 846, + "source": "examples/reti/validatorRegistry.algo.ts:382", + "pc": [ + 1080, + 1081, + 1082 + ] + }, + { + "teal": 847, + "source": "examples/reti/validatorRegistry.algo.ts:382", + "pc": [ + 1083 + ] + }, + { + "teal": 848, + "source": "examples/reti/validatorRegistry.algo.ts:382", + "pc": [ + 1084 + ] + }, + { + "teal": 849, + "source": "examples/reti/validatorRegistry.algo.ts:382", + "pc": [ + 1085, + 1086 + ] + }, + { + "teal": 850, + "source": "examples/reti/validatorRegistry.algo.ts:382", + "pc": [ + 1087 + ] + }, + { + "teal": 851, + "source": "examples/reti/validatorRegistry.algo.ts:382", + "pc": [ + 1088 + ] + }, + { + "teal": 852, + "source": "examples/reti/validatorRegistry.algo.ts:382", + "pc": [ + 1089, + 1090, + 1091 + ] + }, + { + "teal": 853, + "source": "examples/reti/validatorRegistry.algo.ts:382", + "pc": [ + 1092 + ] + }, + { + "teal": 854, + "source": "examples/reti/validatorRegistry.algo.ts:382", + "pc": [ + 1093 + ] + }, + { + "teal": 855, + "source": "examples/reti/validatorRegistry.algo.ts:382", + "pc": [ + 1094 + ] + }, + { + "teal": 856, + "source": "examples/reti/validatorRegistry.algo.ts:382", + "pc": [ + 1095 + ] + }, + { + "teal": 857, + "source": "examples/reti/validatorRegistry.algo.ts:382", + "pc": [ + 1096, + 1097 + ] + }, + { + "teal": 858, + "source": "examples/reti/validatorRegistry.algo.ts:382", + "pc": [ + 1098 + ] + }, + { + "teal": 867, + "source": "examples/reti/validatorRegistry.algo.ts:382", + "pc": [ + 1099, + 1100, + 1101 + ] + }, + { + "teal": 870, + "source": "examples/reti/validatorRegistry.algo.ts:382", + "pc": [ + 1102, + 1103 + ] + }, + { + "teal": 871, + "source": "examples/reti/validatorRegistry.algo.ts:382", + "pc": [ + 1104, + 1105 + ] + }, + { + "teal": 876, + "source": "examples/reti/validatorRegistry.algo.ts:383", + "pc": [ + 1106, + 1107, + 1108, + 1109, + 1110 + ] + }, + { + "teal": 877, + "source": "examples/reti/validatorRegistry.algo.ts:383", + "pc": [ + 1111, + 1112 + ] + }, + { + "teal": 878, + "source": "examples/reti/validatorRegistry.algo.ts:383", + "pc": [ + 1113 + ] + }, + { + "teal": 879, + "source": "examples/reti/validatorRegistry.algo.ts:383", + "pc": [ + 1114 + ] + }, + { + "teal": 880, + "source": "examples/reti/validatorRegistry.algo.ts:383", + "pc": [ + 1115 + ] + }, + { + "teal": 881, + "source": "examples/reti/validatorRegistry.algo.ts:383", + "pc": [ + 1116 + ] + }, + { + "teal": 882, + "source": "examples/reti/validatorRegistry.algo.ts:383", + "pc": [ + 1117 + ] + }, + { + "teal": 883, + "source": "examples/reti/validatorRegistry.algo.ts:383", + "pc": [ + 1118, + 1119, + 1120 + ] + }, + { + "teal": 888, + "source": "examples/reti/validatorRegistry.algo.ts:384", + "pc": [ + 1121, + 1122 + ] + }, + { + "teal": 889, + "source": "examples/reti/validatorRegistry.algo.ts:384", + "pc": [ + 1123, + 1124, + 1125 + ] + }, + { + "teal": 894, + "source": "examples/reti/validatorRegistry.algo.ts:386", + "pc": [ + 1126, + 1127 + ] + }, + { + "teal": 895, + "source": "examples/reti/validatorRegistry.algo.ts:386", + "pc": [ + 1128, + 1129 + ] + }, + { + "teal": 899, + "source": "examples/reti/validatorRegistry.algo.ts:387", + "pc": [ + 1130, + 1131, + 1132, + 1133, + 1134 + ] + }, + { + "teal": 900, + "source": "examples/reti/validatorRegistry.algo.ts:387", + "pc": [ + 1135, + 1136 + ] + }, + { + "teal": 901, + "source": "examples/reti/validatorRegistry.algo.ts:387", + "pc": [ + 1137 + ] + }, + { + "teal": 902, + "source": "examples/reti/validatorRegistry.algo.ts:387", + "pc": [ + 1138 + ] + }, + { + "teal": 905, + "source": "examples/reti/validatorRegistry.algo.ts:387", + "errorMessage": "box value does not exist: this.stakerPoolSet(staker).value", + "pc": [ + 1139 + ] + }, + { + "teal": 906, + "source": "examples/reti/validatorRegistry.algo.ts:387", + "pc": [ + 1140, + 1141 + ] + }, + { + "teal": 910, + "source": "examples/reti/validatorRegistry.algo.ts:388", + "pc": [ + 1142, + 1143 + ] + }, + { + "teal": 911, + "source": "examples/reti/validatorRegistry.algo.ts:388", + "pc": [ + 1144, + 1145 + ] + }, + { + "teal": 916, + "source": "examples/reti/validatorRegistry.algo.ts:388", + "pc": [ + 1146, + 1147 + ] + }, + { + "teal": 917, + "source": "examples/reti/validatorRegistry.algo.ts:388", + "pc": [ + 1148, + 1149 + ] + }, + { + "teal": 918, + "source": "examples/reti/validatorRegistry.algo.ts:388", + "pc": [ + 1150 + ] + }, + { + "teal": 919, + "source": "examples/reti/validatorRegistry.algo.ts:388", + "pc": [ + 1151, + 1152, + 1153 + ] + }, + { + "teal": 924, + "source": "examples/reti/validatorRegistry.algo.ts:389", + "pc": [ + 1154, + 1155 + ] + }, + { + "teal": 925, + "source": "examples/reti/validatorRegistry.algo.ts:389", + "pc": [ + 1156, + 1157 + ] + }, + { + "teal": 926, + "source": "examples/reti/validatorRegistry.algo.ts:389", + "pc": [ + 1158, + 1159 + ] + }, + { + "teal": 927, + "source": "examples/reti/validatorRegistry.algo.ts:389", + "pc": [ + 1160 + ] + }, + { + "teal": 928, + "source": "examples/reti/validatorRegistry.algo.ts:389", + "pc": [ + 1161, + 1162 + ] + }, + { + "teal": 929, + "source": "examples/reti/validatorRegistry.algo.ts:389", + "pc": [ + 1163 + ] + }, + { + "teal": 930, + "source": "examples/reti/validatorRegistry.algo.ts:389", + "pc": [ + 1164, + 1165 + ] + }, + { + "teal": 931, + "source": "examples/reti/validatorRegistry.algo.ts:389", + "pc": [ + 1166 + ] + }, + { + "teal": 932, + "source": "examples/reti/validatorRegistry.algo.ts:389", + "pc": [ + 1167 + ] + }, + { + "teal": 933, + "source": "examples/reti/validatorRegistry.algo.ts:389", + "pc": [ + 1168, + 1169 + ] + }, + { + "teal": 934, + "source": "examples/reti/validatorRegistry.algo.ts:389", + "pc": [ + 1170 + ] + }, + { + "teal": 935, + "source": "examples/reti/validatorRegistry.algo.ts:389", + "pc": [ + 1171, + 1172, + 1173 + ] + }, + { + "teal": 940, + "source": "examples/reti/validatorRegistry.algo.ts:390", + "pc": [ + 1174, + 1175 + ] + }, + { + "teal": 941, + "source": "examples/reti/validatorRegistry.algo.ts:390", + "pc": [ + 1176, + 1177 + ] + }, + { + "teal": 942, + "source": "examples/reti/validatorRegistry.algo.ts:390", + "pc": [ + 1178, + 1179 + ] + }, + { + "teal": 943, + "source": "examples/reti/validatorRegistry.algo.ts:390", + "pc": [ + 1180, + 1181 + ] + }, + { + "teal": 944, + "source": "examples/reti/validatorRegistry.algo.ts:390", + "pc": [ + 1182 + ] + }, + { + "teal": 945, + "source": "examples/reti/validatorRegistry.algo.ts:390", + "pc": [ + 1183, + 1184 + ] + }, + { + "teal": 946, + "source": "examples/reti/validatorRegistry.algo.ts:390", + "pc": [ + 1185 + ] + }, + { + "teal": 947, + "source": "examples/reti/validatorRegistry.algo.ts:390", + "pc": [ + 1186 + ] + }, + { + "teal": 948, + "source": "examples/reti/validatorRegistry.algo.ts:390", + "pc": [ + 1187, + 1188 + ] + }, + { + "teal": 955, + "source": "examples/reti/validatorRegistry.algo.ts:388", + "pc": [ + 1189, + 1190 + ] + }, + { + "teal": 956, + "source": "examples/reti/validatorRegistry.algo.ts:388", + "pc": [ + 1191, + 1192 + ] + }, + { + "teal": 957, + "source": "examples/reti/validatorRegistry.algo.ts:388", + "pc": [ + 1193 + ] + }, + { + "teal": 958, + "source": "examples/reti/validatorRegistry.algo.ts:388", + "pc": [ + 1194, + 1195 + ] + }, + { + "teal": 959, + "source": "examples/reti/validatorRegistry.algo.ts:388", + "pc": [ + 1196, + 1197, + 1198 + ] + }, + { + "teal": 964, + "source": "examples/reti/validatorRegistry.algo.ts:393", + "pc": [ + 1199, + 1200 + ] + }, + { + "teal": 968, + "source": "examples/reti/validatorRegistry.algo.ts:382", + "pc": [ + 1201, + 1202 + ] + }, + { + "teal": 971, + "source": "examples/reti/validatorRegistry.algo.ts:382", + "pc": [ + 1203, + 1204 + ] + }, + { + "teal": 972, + "source": "examples/reti/validatorRegistry.algo.ts:382", + "pc": [ + 1205 + ] + }, + { + "teal": 977, + "source": "examples/reti/validatorRegistry.algo.ts:404", + "pc": [ + 1206, + 1207, + 1208, + 1209, + 1210, + 1211 + ] + }, + { + "teal": 980, + "source": "examples/reti/validatorRegistry.algo.ts:404", + "pc": [ + 1212, + 1213, + 1214 + ] + }, + { + "teal": 981, + "source": "examples/reti/validatorRegistry.algo.ts:404", + "pc": [ + 1215 + ] + }, + { + "teal": 984, + "source": "examples/reti/validatorRegistry.algo.ts:404", + "pc": [ + 1216, + 1217, + 1218 + ] + }, + { + "teal": 985, + "source": "examples/reti/validatorRegistry.algo.ts:404", + "pc": [ + 1219 + ] + }, + { + "teal": 986, + "source": "examples/reti/validatorRegistry.algo.ts:404", + "pc": [ + 1220 + ] + }, + { + "teal": 987, + "source": "examples/reti/validatorRegistry.algo.ts:404", + "pc": [ + 1221, + 1222 + ] + }, + { + "teal": 988, + "source": "examples/reti/validatorRegistry.algo.ts:404", + "pc": [ + 1223 + ] + }, + { + "teal": 998, + "source": "examples/reti/validatorRegistry.algo.ts:404", + "pc": [ + 1224, + 1225, + 1226 + ] + }, + { + "teal": 1002, + "source": "examples/reti/validatorRegistry.algo.ts:405", + "pc": [ + 1227, + 1228, + 1229 + ] + }, + { + "teal": 1003, + "source": "examples/reti/validatorRegistry.algo.ts:405", + "pc": [ + 1230, + 1231, + 1232 + ] + }, + { + "teal": 1004, + "source": "examples/reti/validatorRegistry.algo.ts:405", + "pc": [ + 1233, + 1234, + 1235 + ] + }, + { + "teal": 1005, + "source": "examples/reti/validatorRegistry.algo.ts:405", + "pc": [ + 1236, + 1237 + ] + }, + { + "teal": 1006, + "source": "examples/reti/validatorRegistry.algo.ts:405", + "pc": [ + 1238 + ] + }, + { + "teal": 1007, + "source": "examples/reti/validatorRegistry.algo.ts:405", + "pc": [ + 1239 + ] + }, + { + "teal": 1008, + "source": "examples/reti/validatorRegistry.algo.ts:405", + "pc": [ + 1240, + 1241 + ] + }, + { + "teal": 1009, + "source": "examples/reti/validatorRegistry.algo.ts:405", + "pc": [ + 1242 + ] + }, + { + "teal": 1010, + "source": "examples/reti/validatorRegistry.algo.ts:404", + "pc": [ + 1243 + ] + }, + { + "teal": 1015, + "source": "examples/reti/validatorRegistry.algo.ts:409", + "pc": [ + 1244, + 1245, + 1246, + 1247, + 1248, + 1249 + ] + }, + { + "teal": 1018, + "source": "examples/reti/validatorRegistry.algo.ts:409", + "pc": [ + 1250, + 1251, + 1252 + ] + }, + { + "teal": 1019, + "source": "examples/reti/validatorRegistry.algo.ts:409", + "pc": [ + 1253 + ] + }, + { + "teal": 1022, + "source": "examples/reti/validatorRegistry.algo.ts:409", + "pc": [ + 1254, + 1255, + 1256 + ] + }, + { + "teal": 1023, + "source": "examples/reti/validatorRegistry.algo.ts:409", + "pc": [ + 1257 + ] + }, + { + "teal": 1024, + "source": "examples/reti/validatorRegistry.algo.ts:409", + "pc": [ + 1258 + ] + }, + { + "teal": 1025, + "source": "examples/reti/validatorRegistry.algo.ts:409", + "pc": [ + 1259, + 1260 + ] + }, + { + "teal": 1026, + "source": "examples/reti/validatorRegistry.algo.ts:409", + "pc": [ + 1261 + ] + }, + { + "teal": 1030, + "source": "examples/reti/validatorRegistry.algo.ts:409", + "pc": [ + 1262, + 1263, + 1264 + ] + }, + { + "teal": 1034, + "source": "examples/reti/validatorRegistry.algo.ts:410", + "pc": [ + 1265, + 1266, + 1267 + ] + }, + { + "teal": 1035, + "source": "examples/reti/validatorRegistry.algo.ts:410", + "pc": [ + 1268, + 1269 + ] + }, + { + "teal": 1036, + "source": "examples/reti/validatorRegistry.algo.ts:410", + "pc": [ + 1270 + ] + }, + { + "teal": 1037, + "source": "examples/reti/validatorRegistry.algo.ts:410", + "pc": [ + 1271 + ] + }, + { + "teal": 1038, + "source": "examples/reti/validatorRegistry.algo.ts:410", + "pc": [ + 1272 + ] + }, + { + "teal": 1039, + "source": "examples/reti/validatorRegistry.algo.ts:410", + "pc": [ + 1273 + ] + }, + { + "teal": 1040, + "source": "examples/reti/validatorRegistry.algo.ts:410", + "pc": [ + 1274 + ] + }, + { + "teal": 1043, + "source": "examples/reti/validatorRegistry.algo.ts:410", + "errorMessage": "the specified validator id doesn't exist", + "pc": [ + 1275 + ] + }, + { + "teal": 1047, + "source": "examples/reti/validatorRegistry.algo.ts:412", + "pc": [ + 1276, + 1277, + 1278 + ] + }, + { + "teal": 1048, + "source": "examples/reti/validatorRegistry.algo.ts:412", + "pc": [ + 1279, + 1280, + 1281 + ] + }, + { + "teal": 1049, + "source": "examples/reti/validatorRegistry.algo.ts:412", + "pc": [ + 1282, + 1283, + 1284 + ] + }, + { + "teal": 1050, + "source": "examples/reti/validatorRegistry.algo.ts:412", + "pc": [ + 1285, + 1286 + ] + }, + { + "teal": 1051, + "source": "examples/reti/validatorRegistry.algo.ts:412", + "pc": [ + 1287 + ] + }, + { + "teal": 1052, + "source": "examples/reti/validatorRegistry.algo.ts:412", + "pc": [ + 1288 + ] + }, + { + "teal": 1053, + "source": "examples/reti/validatorRegistry.algo.ts:412", + "pc": [ + 1289, + 1290 + ] + }, + { + "teal": 1054, + "source": "examples/reti/validatorRegistry.algo.ts:412", + "pc": [ + 1291 + ] + }, + { + "teal": 1055, + "source": "examples/reti/validatorRegistry.algo.ts:409", + "pc": [ + 1292 + ] + }, + { + "teal": 1060, + "source": "examples/reti/validatorRegistry.algo.ts:415", + "pc": [ + 1293, + 1294, + 1295, + 1296, + 1297, + 1298 + ] + }, + { + "teal": 1063, + "source": "examples/reti/validatorRegistry.algo.ts:415", + "pc": [ + 1299, + 1300, + 1301 + ] + }, + { + "teal": 1064, + "source": "examples/reti/validatorRegistry.algo.ts:415", + "pc": [ + 1302 + ] + }, + { + "teal": 1065, + "source": "examples/reti/validatorRegistry.algo.ts:415", + "pc": [ + 1303 + ] + }, + { + "teal": 1066, + "source": "examples/reti/validatorRegistry.algo.ts:415", + "pc": [ + 1304 + ] + }, + { + "teal": 1067, + "source": "examples/reti/validatorRegistry.algo.ts:415", + "pc": [ + 1305, + 1306 + ] + }, + { + "teal": 1068, + "source": "examples/reti/validatorRegistry.algo.ts:415", + "pc": [ + 1307 + ] + }, + { + "teal": 1072, + "source": "examples/reti/validatorRegistry.algo.ts:415", + "pc": [ + 1308, + 1309, + 1310 + ] + }, + { + "teal": 1076, + "source": "examples/reti/validatorRegistry.algo.ts:416", + "pc": [ + 1311 + ] + }, + { + "teal": 1077, + "source": "examples/reti/validatorRegistry.algo.ts:415", + "pc": [ + 1312 + ] + }, + { + "teal": 1082, + "source": "examples/reti/validatorRegistry.algo.ts:427", + "pc": [ + 1313, + 1314, + 1315, + 1316, + 1317, + 1318 + ] + }, + { + "teal": 1085, + "source": "examples/reti/validatorRegistry.algo.ts:427", + "pc": [ + 1319, + 1320, + 1321 + ] + }, + { + "teal": 1086, + "source": "examples/reti/validatorRegistry.algo.ts:427", + "pc": [ + 1322 + ] + }, + { + "teal": 1087, + "source": "examples/reti/validatorRegistry.algo.ts:427", + "pc": [ + 1323 + ] + }, + { + "teal": 1088, + "source": "examples/reti/validatorRegistry.algo.ts:427", + "pc": [ + 1324, + 1325, + 1326 + ] + }, + { + "teal": 1089, + "source": "examples/reti/validatorRegistry.algo.ts:427", + "pc": [ + 1327 + ] + }, + { + "teal": 1092, + "source": "examples/reti/validatorRegistry.algo.ts:427", + "errorMessage": "argument 0 (config) for addValidator must be a (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)", + "pc": [ + 1328 + ] + }, + { + "teal": 1095, + "source": "examples/reti/validatorRegistry.algo.ts:427", + "pc": [ + 1329, + 1330, + 1331 + ] + }, + { + "teal": 1096, + "source": "examples/reti/validatorRegistry.algo.ts:427", + "pc": [ + 1332, + 1333, + 1334 + ] + }, + { + "teal": 1099, + "source": "examples/reti/validatorRegistry.algo.ts:427", + "pc": [ + 1335, + 1336 + ] + }, + { + "teal": 1100, + "source": "examples/reti/validatorRegistry.algo.ts:427", + "pc": [ + 1337, + 1338 + ] + }, + { + "teal": 1101, + "source": "examples/reti/validatorRegistry.algo.ts:427", + "pc": [ + 1339 + ] + }, + { + "teal": 1102, + "source": "examples/reti/validatorRegistry.algo.ts:427", + "pc": [ + 1340 + ] + }, + { + "teal": 1103, + "source": "examples/reti/validatorRegistry.algo.ts:427", + "pc": [ + 1341, + 1342 + ] + }, + { + "teal": 1104, + "source": "examples/reti/validatorRegistry.algo.ts:427", + "pc": [ + 1343, + 1344 + ] + }, + { + "teal": 1105, + "source": "examples/reti/validatorRegistry.algo.ts:427", + "pc": [ + 1345 + ] + }, + { + "teal": 1108, + "source": "examples/reti/validatorRegistry.algo.ts:427", + "errorMessage": "argument 2 (mbrPayment) for addValidator must be a pay transaction", + "pc": [ + 1346 + ] + }, + { + "teal": 1111, + "source": "examples/reti/validatorRegistry.algo.ts:427", + "pc": [ + 1347, + 1348, + 1349 + ] + }, + { + "teal": 1112, + "source": "examples/reti/validatorRegistry.algo.ts:427", + "pc": [ + 1350 + ] + }, + { + "teal": 1113, + "source": "examples/reti/validatorRegistry.algo.ts:427", + "pc": [ + 1351 + ] + }, + { + "teal": 1114, + "source": "examples/reti/validatorRegistry.algo.ts:427", + "pc": [ + 1352 + ] + }, + { + "teal": 1115, + "source": "examples/reti/validatorRegistry.algo.ts:427", + "pc": [ + 1353, + 1354 + ] + }, + { + "teal": 1116, + "source": "examples/reti/validatorRegistry.algo.ts:427", + "pc": [ + 1355 + ] + }, + { + "teal": 1128, + "source": "examples/reti/validatorRegistry.algo.ts:427", + "pc": [ + 1356, + 1357, + 1358 + ] + }, + { + "teal": 1131, + "source": "examples/reti/validatorRegistry.algo.ts:427", + "pc": [ + 1359, + 1360 + ] + }, + { + "teal": 1135, + "source": "examples/reti/validatorRegistry.algo.ts:428", + "pc": [ + 1361, + 1362 + ] + }, + { + "teal": 1136, + "source": "examples/reti/validatorRegistry.algo.ts:428", + "pc": [ + 1363, + 1364, + 1365 + ] + }, + { + "teal": 1140, + "source": "examples/reti/validatorRegistry.algo.ts:429", + "pc": [ + 1366, + 1367 + ] + }, + { + "teal": 1141, + "source": "examples/reti/validatorRegistry.algo.ts:429", + "pc": [ + 1368, + 1369, + 1370 + ] + }, + { + "teal": 1142, + "source": "examples/reti/validatorRegistry.algo.ts:429", + "pc": [ + 1371, + 1372 + ] + }, + { + "teal": 1143, + "source": "examples/reti/validatorRegistry.algo.ts:429", + "pc": [ + 1373 + ] + }, + { + "teal": 1144, + "source": "examples/reti/validatorRegistry.algo.ts:429", + "pc": [ + 1374 + ] + }, + { + "teal": 1148, + "source": "examples/reti/validatorRegistry.algo.ts:430", + "pc": [ + 1375, + 1376 + ] + }, + { + "teal": 1149, + "source": "examples/reti/validatorRegistry.algo.ts:430", + "pc": [ + 1377, + 1378, + 1379 + ] + }, + { + "teal": 1150, + "source": "examples/reti/validatorRegistry.algo.ts:430", + "pc": [ + 1380, + 1381 + ] + }, + { + "teal": 1151, + "source": "examples/reti/validatorRegistry.algo.ts:430", + "pc": [ + 1382 + ] + }, + { + "teal": 1152, + "source": "examples/reti/validatorRegistry.algo.ts:430", + "pc": [ + 1383 + ] + }, + { + "teal": 1156, + "source": "examples/reti/validatorRegistry.algo.ts:431", + "pc": [ + 1384, + 1385 + ] + }, + { + "teal": 1157, + "source": "examples/reti/validatorRegistry.algo.ts:431", + "pc": [ + 1386, + 1387 + ] + }, + { + "teal": 1158, + "source": "examples/reti/validatorRegistry.algo.ts:431", + "pc": [ + 1388, + 1389, + 1390 + ] + }, + { + "teal": 1159, + "source": "examples/reti/validatorRegistry.algo.ts:431", + "pc": [ + 1391 + ] + }, + { + "teal": 1162, + "source": "examples/reti/validatorRegistry.algo.ts:431", + "errorMessage": "sender must be owner to add new validator", + "pc": [ + 1392 + ] + }, + { + "teal": 1167, + "source": "examples/reti/validatorRegistry.algo.ts:433", + "pc": [ + 1393, + 1394 + ] + }, + { + "teal": 1168, + "source": "examples/reti/validatorRegistry.algo.ts:433", + "pc": [ + 1395, + 1396 + ] + }, + { + "teal": 1169, + "source": "examples/reti/validatorRegistry.algo.ts:433", + "pc": [ + 1397, + 1398, + 1399 + ] + }, + { + "teal": 1170, + "source": "examples/reti/validatorRegistry.algo.ts:433", + "pc": [ + 1400, + 1401, + 1402 + ] + }, + { + "teal": 1171, + "source": "examples/reti/validatorRegistry.algo.ts:433", + "pc": [ + 1403 + ] + }, + { + "teal": 1172, + "source": "examples/reti/validatorRegistry.algo.ts:433", + "pc": [ + 1404 + ] + }, + { + "teal": 1175, + "source": "examples/reti/validatorRegistry.algo.ts:433", + "errorMessage": "transaction verification failed: {\"txn\":\"mbrPayment\",\"field\":\"amount\",\"expected\":\"this.getMbrAmounts().addValidatorMbr\"}", + "pc": [ + 1405 + ] + }, + { + "teal": 1179, + "source": "examples/reti/validatorRegistry.algo.ts:435", + "pc": [ + 1406, + 1407 + ] + }, + { + "teal": 1180, + "source": "examples/reti/validatorRegistry.algo.ts:435", + "pc": [ + 1408, + 1409 + ] + }, + { + "teal": 1181, + "source": "examples/reti/validatorRegistry.algo.ts:435", + "pc": [ + 1410, + 1411, + 1412, + 1413, + 1414 + ] + }, + { + "teal": 1182, + "source": "examples/reti/validatorRegistry.algo.ts:435", + "pc": [ + 1415 + ] + }, + { + "teal": 1185, + "source": "examples/reti/validatorRegistry.algo.ts:435", + "errorMessage": "fee must be 10 ALGO or more to prevent spamming of validators", + "pc": [ + 1416 + ] + }, + { + "teal": 1189, + "source": "examples/reti/validatorRegistry.algo.ts:438", + "pc": [ + 1417, + 1418, + 1419, + 1420, + 1421, + 1422 + ] + }, + { + "teal": 1190, + "source": "examples/reti/validatorRegistry.algo.ts:438", + "pc": [ + 1423 + ] + }, + { + "teal": 1191, + "source": "examples/reti/validatorRegistry.algo.ts:438", + "pc": [ + 1424, + 1425 + ] + }, + { + "teal": 1192, + "source": "examples/reti/validatorRegistry.algo.ts:438", + "pc": [ + 1426 + ] + }, + { + "teal": 1193, + "source": "examples/reti/validatorRegistry.algo.ts:438", + "pc": [ + 1427, + 1428 + ] + }, + { + "teal": 1197, + "source": "examples/reti/validatorRegistry.algo.ts:439", + "pc": [ + 1429, + 1430, + 1431, + 1432, + 1433, + 1434 + ] + }, + { + "teal": 1198, + "source": "examples/reti/validatorRegistry.algo.ts:439", + "pc": [ + 1435, + 1436 + ] + }, + { + "teal": 1199, + "source": "examples/reti/validatorRegistry.algo.ts:439", + "pc": [ + 1437 + ] + }, + { + "teal": 1203, + "source": "examples/reti/validatorRegistry.algo.ts:441", + "pc": [ + 1438, + 1439, + 1440 + ] + }, + { + "teal": 1204, + "source": "examples/reti/validatorRegistry.algo.ts:441", + "pc": [ + 1441, + 1442 + ] + }, + { + "teal": 1205, + "source": "examples/reti/validatorRegistry.algo.ts:441", + "pc": [ + 1443 + ] + }, + { + "teal": 1206, + "source": "examples/reti/validatorRegistry.algo.ts:441", + "pc": [ + 1444 + ] + }, + { + "teal": 1207, + "source": "examples/reti/validatorRegistry.algo.ts:441", + "pc": [ + 1445, + 1446, + 1447 + ] + }, + { + "teal": 1208, + "source": "examples/reti/validatorRegistry.algo.ts:441", + "pc": [ + 1448 + ] + }, + { + "teal": 1209, + "source": "examples/reti/validatorRegistry.algo.ts:441", + "pc": [ + 1449 + ] + }, + { + "teal": 1213, + "source": "examples/reti/validatorRegistry.algo.ts:442", + "pc": [ + 1450, + 1451 + ] + }, + { + "teal": 1214, + "source": "examples/reti/validatorRegistry.algo.ts:442", + "pc": [ + 1452, + 1453 + ] + }, + { + "teal": 1215, + "source": "examples/reti/validatorRegistry.algo.ts:442", + "pc": [ + 1454, + 1455, + 1456 + ] + }, + { + "teal": 1216, + "source": "examples/reti/validatorRegistry.algo.ts:442", + "pc": [ + 1457, + 1458 + ] + }, + { + "teal": 1217, + "source": "examples/reti/validatorRegistry.algo.ts:442", + "pc": [ + 1459 + ] + }, + { + "teal": 1218, + "source": "examples/reti/validatorRegistry.algo.ts:442", + "pc": [ + 1460 + ] + }, + { + "teal": 1219, + "source": "examples/reti/validatorRegistry.algo.ts:442", + "pc": [ + 1461, + 1462 + ] + }, + { + "teal": 1220, + "source": "examples/reti/validatorRegistry.algo.ts:442", + "pc": [ + 1463 + ] + }, + { + "teal": 1224, + "source": "examples/reti/validatorRegistry.algo.ts:443", + "pc": [ + 1464, + 1465 + ] + }, + { + "teal": 1225, + "source": "examples/reti/validatorRegistry.algo.ts:443", + "pc": [ + 1466, + 1467 + ] + }, + { + "teal": 1226, + "source": "examples/reti/validatorRegistry.algo.ts:443", + "pc": [ + 1468 + ] + }, + { + "teal": 1227, + "source": "examples/reti/validatorRegistry.algo.ts:443", + "pc": [ + 1469, + 1470, + 1471 + ] + }, + { + "teal": 1228, + "source": "examples/reti/validatorRegistry.algo.ts:443", + "pc": [ + 1472, + 1473 + ] + }, + { + "teal": 1229, + "source": "examples/reti/validatorRegistry.algo.ts:443", + "pc": [ + 1474 + ] + }, + { + "teal": 1230, + "source": "examples/reti/validatorRegistry.algo.ts:443", + "pc": [ + 1475 + ] + }, + { + "teal": 1231, + "source": "examples/reti/validatorRegistry.algo.ts:443", + "pc": [ + 1476, + 1477 + ] + }, + { + "teal": 1232, + "source": "examples/reti/validatorRegistry.algo.ts:443", + "pc": [ + 1478 + ] + }, + { + "teal": 1237, + "source": "examples/reti/validatorRegistry.algo.ts:446", + "pc": [ + 1479, + 1480 + ] + }, + { + "teal": 1238, + "source": "examples/reti/validatorRegistry.algo.ts:446", + "pc": [ + 1481, + 1482, + 1483 + ] + }, + { + "teal": 1239, + "source": "examples/reti/validatorRegistry.algo.ts:446", + "pc": [ + 1484 + ] + }, + { + "teal": 1240, + "source": "examples/reti/validatorRegistry.algo.ts:446", + "pc": [ + 1485, + 1486 + ] + }, + { + "teal": 1241, + "source": "examples/reti/validatorRegistry.algo.ts:446", + "pc": [ + 1487 + ] + }, + { + "teal": 1242, + "source": "examples/reti/validatorRegistry.algo.ts:446", + "pc": [ + 1488, + 1489, + 1490 + ] + }, + { + "teal": 1251, + "source": "examples/reti/validatorRegistry.algo.ts:448", + "pc": [ + 1491 + ] + }, + { + "teal": 1252, + "source": "examples/reti/validatorRegistry.algo.ts:448", + "pc": [ + 1492, + 1493 + ] + }, + { + "teal": 1253, + "source": "examples/reti/validatorRegistry.algo.ts:448", + "pc": [ + 1494, + 1495 + ] + }, + { + "teal": 1257, + "source": "examples/reti/validatorRegistry.algo.ts:449", + "pc": [ + 1496 + ] + }, + { + "teal": 1258, + "source": "examples/reti/validatorRegistry.algo.ts:449", + "pc": [ + 1497, + 1498 + ] + }, + { + "teal": 1262, + "source": "examples/reti/validatorRegistry.algo.ts:450", + "pc": [ + 1499, + 1500, + 1501, + 1502, + 1503, + 1504, + 1505, + 1506, + 1507, + 1508, + 1509, + 1510, + 1511, + 1512, + 1513, + 1514, + 1515, + 1516, + 1517, + 1518 + ] + }, + { + "teal": 1263, + "source": "examples/reti/validatorRegistry.algo.ts:450", + "pc": [ + 1519, + 1520 + ] + }, + { + "teal": 1264, + "source": "examples/reti/validatorRegistry.algo.ts:450", + "pc": [ + 1521, + 1522 + ] + }, + { + "teal": 1265, + "source": "examples/reti/validatorRegistry.algo.ts:450", + "pc": [ + 1523, + 1524 + ] + }, + { + "teal": 1266, + "source": "examples/reti/validatorRegistry.algo.ts:450", + "pc": [ + 1525, + 1526 + ] + }, + { + "teal": 1267, + "source": "examples/reti/validatorRegistry.algo.ts:450", + "pc": [ + 1527, + 1528, + 1529 + ] + }, + { + "teal": 1268, + "source": "examples/reti/validatorRegistry.algo.ts:450", + "pc": [ + 1530 + ] + }, + { + "teal": 1269, + "source": "examples/reti/validatorRegistry.algo.ts:450", + "pc": [ + 1531 + ] + }, + { + "teal": 1270, + "source": "examples/reti/validatorRegistry.algo.ts:450", + "pc": [ + 1532, + 1533 + ] + }, + { + "teal": 1274, + "source": "examples/reti/validatorRegistry.algo.ts:451", + "pc": [ + 1534, + 1535 + ] + }, + { + "teal": 1275, + "source": "examples/reti/validatorRegistry.algo.ts:451", + "pc": [ + 1536, + 1537, + 1538 + ] + }, + { + "teal": 1276, + "source": "examples/reti/validatorRegistry.algo.ts:451", + "pc": [ + 1539 + ] + }, + { + "teal": 1277, + "source": "examples/reti/validatorRegistry.algo.ts:451", + "pc": [ + 1540, + 1541 + ] + }, + { + "teal": 1280, + "source": "examples/reti/validatorRegistry.algo.ts:448", + "pc": [ + 1542, + 1543 + ] + }, + { + "teal": 1281, + "source": "examples/reti/validatorRegistry.algo.ts:448", + "pc": [ + 1544, + 1545 + ] + }, + { + "teal": 1284, + "source": "examples/reti/validatorRegistry.algo.ts:448", + "pc": [ + 1546 + ] + }, + { + "teal": 1288, + "source": "examples/reti/validatorRegistry.algo.ts:453", + "pc": [ + 1547, + 1548 + ] + }, + { + "teal": 1289, + "source": "examples/reti/validatorRegistry.algo.ts:453", + "pc": [ + 1549 + ] + }, + { + "teal": 1290, + "source": "examples/reti/validatorRegistry.algo.ts:453", + "pc": [ + 1550, + 1551 + ] + }, + { + "teal": 1291, + "source": "examples/reti/validatorRegistry.algo.ts:453", + "pc": [ + 1552 + ] + }, + { + "teal": 1294, + "source": "examples/reti/validatorRegistry.algo.ts:453", + "errorMessage": "provided NFD isn't valid", + "pc": [ + 1553 + ] + }, + { + "teal": 1301, + "source": "examples/reti/validatorRegistry.algo.ts:456", + "pc": [ + 1554, + 1555 + ] + }, + { + "teal": 1302, + "source": "examples/reti/validatorRegistry.algo.ts:456", + "pc": [ + 1556, + 1557 + ] + }, + { + "teal": 1303, + "source": "examples/reti/validatorRegistry.algo.ts:456", + "pc": [ + 1558, + 1559, + 1560 + ] + }, + { + "teal": 1304, + "source": "examples/reti/validatorRegistry.algo.ts:456", + "pc": [ + 1561 + ] + }, + { + "teal": 1305, + "source": "examples/reti/validatorRegistry.algo.ts:456", + "pc": [ + 1562, + 1563, + 1564, + 1565, + 1566, + 1567, + 1568, + 1569, + 1570, + 1571, + 1572 + ] + }, + { + "teal": 1306, + "source": "examples/reti/validatorRegistry.algo.ts:456", + "pc": [ + 1573 + ] + }, + { + "teal": 1309, + "source": "examples/reti/validatorRegistry.algo.ts:456", + "errorMessage": "global state value does not exist: AppID.fromUint64(config.nfdForInfo).globalState('i.owner.a')", + "pc": [ + 1574 + ] + }, + { + "teal": 1310, + "source": "examples/reti/validatorRegistry.algo.ts:456", + "pc": [ + 1575 + ] + }, + { + "teal": 1313, + "source": "examples/reti/validatorRegistry.algo.ts:455", + "errorMessage": "If specifying NFD, account adding validator must be owner", + "pc": [ + 1576 + ] + }, + { + "teal": 1320, + "source": "examples/reti/validatorRegistry.algo.ts:461", + "pc": [ + 1577, + 1578 + ] + }, + { + "teal": 1321, + "source": "examples/reti/validatorRegistry.algo.ts:461", + "pc": [ + 1579, + 1580, + 1581 + ] + }, + { + "teal": 1322, + "source": "examples/reti/validatorRegistry.algo.ts:461", + "pc": [ + 1582 + ] + }, + { + "teal": 1323, + "source": "examples/reti/validatorRegistry.algo.ts:461", + "pc": [ + 1583, + 1584 + ] + }, + { + "teal": 1324, + "source": "examples/reti/validatorRegistry.algo.ts:461", + "pc": [ + 1585 + ] + }, + { + "teal": 1325, + "source": "examples/reti/validatorRegistry.algo.ts:461", + "pc": [ + 1586 + ] + }, + { + "teal": 1326, + "source": "examples/reti/validatorRegistry.algo.ts:461", + "pc": [ + 1587, + 1588, + 1589 + ] + }, + { + "teal": 1327, + "source": "examples/reti/validatorRegistry.algo.ts:462", + "pc": [ + 1590, + 1591 + ] + }, + { + "teal": 1328, + "source": "examples/reti/validatorRegistry.algo.ts:462", + "pc": [ + 1592, + 1593, + 1594 + ] + }, + { + "teal": 1329, + "source": "examples/reti/validatorRegistry.algo.ts:462", + "pc": [ + 1595 + ] + }, + { + "teal": 1330, + "source": "examples/reti/validatorRegistry.algo.ts:462", + "pc": [ + 1596, + 1597 + ] + }, + { + "teal": 1331, + "source": "examples/reti/validatorRegistry.algo.ts:462", + "pc": [ + 1598 + ] + }, + { + "teal": 1332, + "source": "examples/reti/validatorRegistry.algo.ts:461", + "pc": [ + 1599 + ] + }, + { + "teal": 1335, + "source": "examples/reti/validatorRegistry.algo.ts:460", + "pc": [ + 1600, + 1601, + 1602 + ] + }, + { + "teal": 1340, + "source": "examples/reti/validatorRegistry.algo.ts:465", + "pc": [ + 1603, + 1604 + ] + }, + { + "teal": 1341, + "source": "examples/reti/validatorRegistry.algo.ts:465", + "pc": [ + 1605, + 1606, + 1607 + ] + }, + { + "teal": 1342, + "source": "examples/reti/validatorRegistry.algo.ts:465", + "pc": [ + 1608 + ] + }, + { + "teal": 1343, + "source": "examples/reti/validatorRegistry.algo.ts:465", + "pc": [ + 1609, + 1610, + 1611 + ] + }, + { + "teal": 1346, + "source": "examples/reti/validatorRegistry.algo.ts:465", + "errorMessage": "provided NFD App id for gating must be valid NFD", + "pc": [ + 1612 + ] + }, + { + "teal": 1351, + "source": "examples/reti/validatorRegistry.algo.ts:468", + "pc": [ + 1613, + 1614 + ] + }, + { + "teal": 1354, + "source": "examples/reti/validatorRegistry.algo.ts:427", + "pc": [ + 1615, + 1616 + ] + }, + { + "teal": 1355, + "source": "examples/reti/validatorRegistry.algo.ts:427", + "pc": [ + 1617 + ] + }, + { + "teal": 1360, + "source": "examples/reti/validatorRegistry.algo.ts:478", + "pc": [ + 1618, + 1619, + 1620 + ] + }, + { + "teal": 1361, + "source": "examples/reti/validatorRegistry.algo.ts:478", + "pc": [ + 1621 + ] + }, + { + "teal": 1362, + "source": "examples/reti/validatorRegistry.algo.ts:478", + "pc": [ + 1622 + ] + }, + { + "teal": 1363, + "source": "examples/reti/validatorRegistry.algo.ts:478", + "pc": [ + 1623, + 1624 + ] + }, + { + "teal": 1364, + "source": "examples/reti/validatorRegistry.algo.ts:478", + "pc": [ + 1625 + ] + }, + { + "teal": 1367, + "source": "examples/reti/validatorRegistry.algo.ts:478", + "errorMessage": "argument 0 (manager) for changeValidatorManager must be a address", + "pc": [ + 1626 + ] + }, + { + "teal": 1370, + "source": "examples/reti/validatorRegistry.algo.ts:478", + "pc": [ + 1627, + 1628, + 1629 + ] + }, + { + "teal": 1371, + "source": "examples/reti/validatorRegistry.algo.ts:478", + "pc": [ + 1630 + ] + }, + { + "teal": 1374, + "source": "examples/reti/validatorRegistry.algo.ts:478", + "pc": [ + 1631, + 1632, + 1633 + ] + }, + { + "teal": 1375, + "source": "examples/reti/validatorRegistry.algo.ts:478", + "pc": [ + 1634, + 1635 + ] + }, + { + "teal": 1376, + "source": "examples/reti/validatorRegistry.algo.ts:478", + "pc": [ + 1636 + ] + }, + { + "teal": 1386, + "source": "examples/reti/validatorRegistry.algo.ts:478", + "pc": [ + 1637, + 1638, + 1639 + ] + }, + { + "teal": 1393, + "source": "examples/reti/validatorRegistry.algo.ts:480", + "pc": [ + 1640, + 1641 + ] + }, + { + "teal": 1394, + "source": "examples/reti/validatorRegistry.algo.ts:480", + "pc": [ + 1642, + 1643 + ] + }, + { + "teal": 1395, + "source": "examples/reti/validatorRegistry.algo.ts:480", + "pc": [ + 1644, + 1645 + ] + }, + { + "teal": 1396, + "source": "examples/reti/validatorRegistry.algo.ts:480", + "pc": [ + 1646, + 1647, + 1648 + ] + }, + { + "teal": 1397, + "source": "examples/reti/validatorRegistry.algo.ts:480", + "pc": [ + 1649, + 1650 + ] + }, + { + "teal": 1398, + "source": "examples/reti/validatorRegistry.algo.ts:480", + "pc": [ + 1651 + ] + }, + { + "teal": 1399, + "source": "examples/reti/validatorRegistry.algo.ts:480", + "pc": [ + 1652 + ] + }, + { + "teal": 1400, + "source": "examples/reti/validatorRegistry.algo.ts:480", + "pc": [ + 1653, + 1654 + ] + }, + { + "teal": 1401, + "source": "examples/reti/validatorRegistry.algo.ts:480", + "pc": [ + 1655 + ] + }, + { + "teal": 1402, + "source": "examples/reti/validatorRegistry.algo.ts:480", + "pc": [ + 1656 + ] + }, + { + "teal": 1405, + "source": "examples/reti/validatorRegistry.algo.ts:479", + "errorMessage": "can only be called by validator owner", + "pc": [ + 1657 + ] + }, + { + "teal": 1409, + "source": "examples/reti/validatorRegistry.algo.ts:483", + "pc": [ + 1658, + 1659 + ] + }, + { + "teal": 1410, + "source": "examples/reti/validatorRegistry.algo.ts:483", + "pc": [ + 1660, + 1661 + ] + }, + { + "teal": 1411, + "source": "examples/reti/validatorRegistry.algo.ts:483", + "pc": [ + 1662, + 1663, + 1664 + ] + }, + { + "teal": 1412, + "source": "examples/reti/validatorRegistry.algo.ts:483", + "pc": [ + 1665, + 1666 + ] + }, + { + "teal": 1413, + "source": "examples/reti/validatorRegistry.algo.ts:483", + "pc": [ + 1667 + ] + }, + { + "teal": 1414, + "source": "examples/reti/validatorRegistry.algo.ts:483", + "pc": [ + 1668 + ] + }, + { + "teal": 1415, + "source": "examples/reti/validatorRegistry.algo.ts:483", + "pc": [ + 1669, + 1670 + ] + }, + { + "teal": 1416, + "source": "examples/reti/validatorRegistry.algo.ts:483", + "pc": [ + 1671 + ] + }, + { + "teal": 1417, + "source": "examples/reti/validatorRegistry.algo.ts:478", + "pc": [ + 1672 + ] + }, + { + "teal": 1422, + "source": "examples/reti/validatorRegistry.algo.ts:494", + "pc": [ + 1673, + 1674, + 1675 + ] + }, + { + "teal": 1423, + "source": "examples/reti/validatorRegistry.algo.ts:494", + "pc": [ + 1676 + ] + }, + { + "teal": 1426, + "source": "examples/reti/validatorRegistry.algo.ts:494", + "pc": [ + 1677, + 1678, + 1679 + ] + }, + { + "teal": 1427, + "source": "examples/reti/validatorRegistry.algo.ts:494", + "pc": [ + 1680 + ] + }, + { + "teal": 1430, + "source": "examples/reti/validatorRegistry.algo.ts:494", + "pc": [ + 1681, + 1682, + 1683 + ] + }, + { + "teal": 1431, + "source": "examples/reti/validatorRegistry.algo.ts:494", + "pc": [ + 1684 + ] + }, + { + "teal": 1434, + "source": "examples/reti/validatorRegistry.algo.ts:494", + "pc": [ + 1685, + 1686, + 1687 + ] + }, + { + "teal": 1435, + "source": "examples/reti/validatorRegistry.algo.ts:494", + "pc": [ + 1688, + 1689 + ] + }, + { + "teal": 1436, + "source": "examples/reti/validatorRegistry.algo.ts:494", + "pc": [ + 1690 + ] + }, + { + "teal": 1447, + "source": "examples/reti/validatorRegistry.algo.ts:494", + "pc": [ + 1691, + 1692, + 1693 + ] + }, + { + "teal": 1454, + "source": "examples/reti/validatorRegistry.algo.ts:496", + "pc": [ + 1694, + 1695 + ] + }, + { + "teal": 1455, + "source": "examples/reti/validatorRegistry.algo.ts:496", + "pc": [ + 1696, + 1697 + ] + }, + { + "teal": 1456, + "source": "examples/reti/validatorRegistry.algo.ts:496", + "pc": [ + 1698, + 1699 + ] + }, + { + "teal": 1457, + "source": "examples/reti/validatorRegistry.algo.ts:496", + "pc": [ + 1700, + 1701, + 1702 + ] + }, + { + "teal": 1458, + "source": "examples/reti/validatorRegistry.algo.ts:496", + "pc": [ + 1703, + 1704 + ] + }, + { + "teal": 1459, + "source": "examples/reti/validatorRegistry.algo.ts:496", + "pc": [ + 1705 + ] + }, + { + "teal": 1460, + "source": "examples/reti/validatorRegistry.algo.ts:496", + "pc": [ + 1706 + ] + }, + { + "teal": 1461, + "source": "examples/reti/validatorRegistry.algo.ts:496", + "pc": [ + 1707, + 1708 + ] + }, + { + "teal": 1462, + "source": "examples/reti/validatorRegistry.algo.ts:496", + "pc": [ + 1709 + ] + }, + { + "teal": 1463, + "source": "examples/reti/validatorRegistry.algo.ts:496", + "pc": [ + 1710 + ] + }, + { + "teal": 1466, + "source": "examples/reti/validatorRegistry.algo.ts:495", + "errorMessage": "can only be called by validator owner", + "pc": [ + 1711 + ] + }, + { + "teal": 1470, + "source": "examples/reti/validatorRegistry.algo.ts:499", + "pc": [ + 1712, + 1713, + 1714 + ] + }, + { + "teal": 1471, + "source": "examples/reti/validatorRegistry.algo.ts:499", + "pc": [ + 1715, + 1716 + ] + }, + { + "teal": 1472, + "source": "examples/reti/validatorRegistry.algo.ts:499", + "pc": [ + 1717 + ] + }, + { + "teal": 1473, + "source": "examples/reti/validatorRegistry.algo.ts:499", + "pc": [ + 1718, + 1719, + 1720 + ] + }, + { + "teal": 1474, + "source": "examples/reti/validatorRegistry.algo.ts:499", + "pc": [ + 1721, + 1722 + ] + }, + { + "teal": 1475, + "source": "examples/reti/validatorRegistry.algo.ts:499", + "pc": [ + 1723 + ] + }, + { + "teal": 1476, + "source": "examples/reti/validatorRegistry.algo.ts:499", + "pc": [ + 1724 + ] + }, + { + "teal": 1477, + "source": "examples/reti/validatorRegistry.algo.ts:499", + "pc": [ + 1725, + 1726 + ] + }, + { + "teal": 1478, + "source": "examples/reti/validatorRegistry.algo.ts:499", + "pc": [ + 1727 + ] + }, + { + "teal": 1482, + "source": "examples/reti/validatorRegistry.algo.ts:500", + "pc": [ + 1728, + 1729, + 1730 + ] + }, + { + "teal": 1483, + "source": "examples/reti/validatorRegistry.algo.ts:500", + "pc": [ + 1731, + 1732 + ] + }, + { + "teal": 1484, + "source": "examples/reti/validatorRegistry.algo.ts:500", + "pc": [ + 1733 + ] + }, + { + "teal": 1485, + "source": "examples/reti/validatorRegistry.algo.ts:500", + "pc": [ + 1734, + 1735, + 1736 + ] + }, + { + "teal": 1486, + "source": "examples/reti/validatorRegistry.algo.ts:500", + "pc": [ + 1737, + 1738 + ] + }, + { + "teal": 1487, + "source": "examples/reti/validatorRegistry.algo.ts:500", + "pc": [ + 1739 + ] + }, + { + "teal": 1488, + "source": "examples/reti/validatorRegistry.algo.ts:500", + "pc": [ + 1740 + ] + }, + { + "teal": 1489, + "source": "examples/reti/validatorRegistry.algo.ts:500", + "pc": [ + 1741, + 1742 + ] + }, + { + "teal": 1490, + "source": "examples/reti/validatorRegistry.algo.ts:500", + "pc": [ + 1743 + ] + }, + { + "teal": 1491, + "source": "examples/reti/validatorRegistry.algo.ts:494", + "pc": [ + 1744 + ] + }, + { + "teal": 1496, + "source": "examples/reti/validatorRegistry.algo.ts:511", + "pc": [ + 1745, + 1746, + 1747 + ] + }, + { + "teal": 1497, + "source": "examples/reti/validatorRegistry.algo.ts:511", + "pc": [ + 1748, + 1749, + 1750 + ] + }, + { + "teal": 1500, + "source": "examples/reti/validatorRegistry.algo.ts:511", + "pc": [ + 1751, + 1752, + 1753 + ] + }, + { + "teal": 1501, + "source": "examples/reti/validatorRegistry.algo.ts:511", + "pc": [ + 1754 + ] + }, + { + "teal": 1504, + "source": "examples/reti/validatorRegistry.algo.ts:511", + "pc": [ + 1755, + 1756, + 1757 + ] + }, + { + "teal": 1505, + "source": "examples/reti/validatorRegistry.algo.ts:511", + "pc": [ + 1758 + ] + }, + { + "teal": 1508, + "source": "examples/reti/validatorRegistry.algo.ts:511", + "pc": [ + 1759, + 1760, + 1761 + ] + }, + { + "teal": 1509, + "source": "examples/reti/validatorRegistry.algo.ts:511", + "pc": [ + 1762, + 1763 + ] + }, + { + "teal": 1510, + "source": "examples/reti/validatorRegistry.algo.ts:511", + "pc": [ + 1764 + ] + }, + { + "teal": 1521, + "source": "examples/reti/validatorRegistry.algo.ts:511", + "pc": [ + 1765, + 1766, + 1767 + ] + }, + { + "teal": 1528, + "source": "examples/reti/validatorRegistry.algo.ts:514", + "pc": [ + 1768, + 1769 + ] + }, + { + "teal": 1529, + "source": "examples/reti/validatorRegistry.algo.ts:514", + "pc": [ + 1770, + 1771 + ] + }, + { + "teal": 1530, + "source": "examples/reti/validatorRegistry.algo.ts:514", + "pc": [ + 1772, + 1773 + ] + }, + { + "teal": 1531, + "source": "examples/reti/validatorRegistry.algo.ts:514", + "pc": [ + 1774, + 1775, + 1776 + ] + }, + { + "teal": 1532, + "source": "examples/reti/validatorRegistry.algo.ts:514", + "pc": [ + 1777, + 1778 + ] + }, + { + "teal": 1533, + "source": "examples/reti/validatorRegistry.algo.ts:514", + "pc": [ + 1779 + ] + }, + { + "teal": 1534, + "source": "examples/reti/validatorRegistry.algo.ts:514", + "pc": [ + 1780 + ] + }, + { + "teal": 1535, + "source": "examples/reti/validatorRegistry.algo.ts:514", + "pc": [ + 1781, + 1782 + ] + }, + { + "teal": 1536, + "source": "examples/reti/validatorRegistry.algo.ts:514", + "pc": [ + 1783 + ] + }, + { + "teal": 1537, + "source": "examples/reti/validatorRegistry.algo.ts:514", + "pc": [ + 1784 + ] + }, + { + "teal": 1540, + "source": "examples/reti/validatorRegistry.algo.ts:513", + "errorMessage": "can only be called by validator owner", + "pc": [ + 1785 + ] + }, + { + "teal": 1548, + "source": "examples/reti/validatorRegistry.algo.ts:518", + "pc": [ + 1786 + ] + }, + { + "teal": 1549, + "source": "examples/reti/validatorRegistry.algo.ts:518", + "pc": [ + 1787, + 1788 + ] + }, + { + "teal": 1550, + "source": "examples/reti/validatorRegistry.algo.ts:518", + "pc": [ + 1789, + 1790 + ] + }, + { + "teal": 1554, + "source": "examples/reti/validatorRegistry.algo.ts:519", + "pc": [ + 1791 + ] + }, + { + "teal": 1555, + "source": "examples/reti/validatorRegistry.algo.ts:519", + "pc": [ + 1792, + 1793 + ] + }, + { + "teal": 1559, + "source": "examples/reti/validatorRegistry.algo.ts:520", + "pc": [ + 1794, + 1795, + 1796, + 1797, + 1798, + 1799, + 1800, + 1801, + 1802, + 1803, + 1804, + 1805, + 1806, + 1807, + 1808, + 1809, + 1810, + 1811, + 1812, + 1813 + ] + }, + { + "teal": 1560, + "source": "examples/reti/validatorRegistry.algo.ts:520", + "pc": [ + 1814, + 1815 + ] + }, + { + "teal": 1561, + "source": "examples/reti/validatorRegistry.algo.ts:520", + "pc": [ + 1816, + 1817 + ] + }, + { + "teal": 1562, + "source": "examples/reti/validatorRegistry.algo.ts:520", + "pc": [ + 1818, + 1819 + ] + }, + { + "teal": 1563, + "source": "examples/reti/validatorRegistry.algo.ts:520", + "pc": [ + 1820, + 1821 + ] + }, + { + "teal": 1564, + "source": "examples/reti/validatorRegistry.algo.ts:520", + "pc": [ + 1822 + ] + }, + { + "teal": 1565, + "source": "examples/reti/validatorRegistry.algo.ts:520", + "pc": [ + 1823, + 1824 + ] + }, + { + "teal": 1569, + "source": "examples/reti/validatorRegistry.algo.ts:521", + "pc": [ + 1825, + 1826 + ] + }, + { + "teal": 1570, + "source": "examples/reti/validatorRegistry.algo.ts:521", + "pc": [ + 1827, + 1828 + ] + }, + { + "teal": 1573, + "source": "examples/reti/validatorRegistry.algo.ts:518", + "pc": [ + 1829, + 1830 + ] + }, + { + "teal": 1574, + "source": "examples/reti/validatorRegistry.algo.ts:518", + "pc": [ + 1831, + 1832 + ] + }, + { + "teal": 1577, + "source": "examples/reti/validatorRegistry.algo.ts:518", + "pc": [ + 1833 + ] + }, + { + "teal": 1584, + "source": "examples/reti/validatorRegistry.algo.ts:525", + "pc": [ + 1834, + 1835 + ] + }, + { + "teal": 1585, + "source": "examples/reti/validatorRegistry.algo.ts:525", + "pc": [ + 1836, + 1837 + ] + }, + { + "teal": 1586, + "source": "examples/reti/validatorRegistry.algo.ts:525", + "pc": [ + 1838, + 1839, + 1840, + 1841, + 1842, + 1843, + 1844, + 1845, + 1846, + 1847, + 1848 + ] + }, + { + "teal": 1587, + "source": "examples/reti/validatorRegistry.algo.ts:525", + "pc": [ + 1849 + ] + }, + { + "teal": 1590, + "source": "examples/reti/validatorRegistry.algo.ts:525", + "errorMessage": "global state value does not exist: AppID.fromUint64(nfdAppID).globalState('i.owner.a')", + "pc": [ + 1850 + ] + }, + { + "teal": 1591, + "source": "examples/reti/validatorRegistry.algo.ts:525", + "pc": [ + 1851 + ] + }, + { + "teal": 1594, + "source": "examples/reti/validatorRegistry.algo.ts:524", + "errorMessage": "If specifying NFD, account adding validator must be owner", + "pc": [ + 1852 + ] + }, + { + "teal": 1598, + "source": "examples/reti/validatorRegistry.algo.ts:528", + "pc": [ + 1853, + 1854 + ] + }, + { + "teal": 1599, + "source": "examples/reti/validatorRegistry.algo.ts:528", + "pc": [ + 1855, + 1856 + ] + }, + { + "teal": 1600, + "source": "examples/reti/validatorRegistry.algo.ts:528", + "pc": [ + 1857 + ] + }, + { + "teal": 1601, + "source": "examples/reti/validatorRegistry.algo.ts:528", + "pc": [ + 1858, + 1859, + 1860 + ] + }, + { + "teal": 1602, + "source": "examples/reti/validatorRegistry.algo.ts:528", + "pc": [ + 1861, + 1862 + ] + }, + { + "teal": 1603, + "source": "examples/reti/validatorRegistry.algo.ts:528", + "pc": [ + 1863 + ] + }, + { + "teal": 1604, + "source": "examples/reti/validatorRegistry.algo.ts:528", + "pc": [ + 1864 + ] + }, + { + "teal": 1605, + "source": "examples/reti/validatorRegistry.algo.ts:528", + "pc": [ + 1865, + 1866 + ] + }, + { + "teal": 1606, + "source": "examples/reti/validatorRegistry.algo.ts:528", + "pc": [ + 1867 + ] + }, + { + "teal": 1607, + "source": "examples/reti/validatorRegistry.algo.ts:511", + "pc": [ + 1868 + ] + }, + { + "teal": 1612, + "source": "examples/reti/validatorRegistry.algo.ts:535", + "pc": [ + 1869, + 1870, + 1871 + ] + }, + { + "teal": 1613, + "source": "examples/reti/validatorRegistry.algo.ts:535", + "pc": [ + 1872 + ] + }, + { + "teal": 1614, + "source": "examples/reti/validatorRegistry.algo.ts:535", + "pc": [ + 1873 + ] + }, + { + "teal": 1615, + "source": "examples/reti/validatorRegistry.algo.ts:535", + "pc": [ + 1874, + 1875 + ] + }, + { + "teal": 1616, + "source": "examples/reti/validatorRegistry.algo.ts:535", + "pc": [ + 1876 + ] + }, + { + "teal": 1619, + "source": "examples/reti/validatorRegistry.algo.ts:535", + "errorMessage": "argument 0 (commissionAddress) for changeValidatorCommissionAddress must be a address", + "pc": [ + 1877 + ] + }, + { + "teal": 1622, + "source": "examples/reti/validatorRegistry.algo.ts:535", + "pc": [ + 1878, + 1879, + 1880 + ] + }, + { + "teal": 1623, + "source": "examples/reti/validatorRegistry.algo.ts:535", + "pc": [ + 1881 + ] + }, + { + "teal": 1626, + "source": "examples/reti/validatorRegistry.algo.ts:535", + "pc": [ + 1882, + 1883, + 1884 + ] + }, + { + "teal": 1627, + "source": "examples/reti/validatorRegistry.algo.ts:535", + "pc": [ + 1885, + 1886 + ] + }, + { + "teal": 1628, + "source": "examples/reti/validatorRegistry.algo.ts:535", + "pc": [ + 1887 + ] + }, + { + "teal": 1635, + "source": "examples/reti/validatorRegistry.algo.ts:535", + "pc": [ + 1888, + 1889, + 1890 + ] + }, + { + "teal": 1642, + "source": "examples/reti/validatorRegistry.algo.ts:537", + "pc": [ + 1891, + 1892 + ] + }, + { + "teal": 1643, + "source": "examples/reti/validatorRegistry.algo.ts:537", + "pc": [ + 1893, + 1894 + ] + }, + { + "teal": 1644, + "source": "examples/reti/validatorRegistry.algo.ts:537", + "pc": [ + 1895, + 1896 + ] + }, + { + "teal": 1645, + "source": "examples/reti/validatorRegistry.algo.ts:537", + "pc": [ + 1897, + 1898, + 1899 + ] + }, + { + "teal": 1646, + "source": "examples/reti/validatorRegistry.algo.ts:537", + "pc": [ + 1900, + 1901 + ] + }, + { + "teal": 1647, + "source": "examples/reti/validatorRegistry.algo.ts:537", + "pc": [ + 1902 + ] + }, + { + "teal": 1648, + "source": "examples/reti/validatorRegistry.algo.ts:537", + "pc": [ + 1903 + ] + }, + { + "teal": 1649, + "source": "examples/reti/validatorRegistry.algo.ts:537", + "pc": [ + 1904, + 1905 + ] + }, + { + "teal": 1650, + "source": "examples/reti/validatorRegistry.algo.ts:537", + "pc": [ + 1906 + ] + }, + { + "teal": 1651, + "source": "examples/reti/validatorRegistry.algo.ts:537", + "pc": [ + 1907 + ] + }, + { + "teal": 1654, + "source": "examples/reti/validatorRegistry.algo.ts:536", + "errorMessage": "can only be called by validator owner", + "pc": [ + 1908 + ] + }, + { + "teal": 1658, + "source": "examples/reti/validatorRegistry.algo.ts:540", + "pc": [ + 1909, + 1910 + ] + }, + { + "teal": 1659, + "source": "examples/reti/validatorRegistry.algo.ts:540", + "pc": [ + 1911, + 1912 + ] + }, + { + "teal": 1660, + "source": "examples/reti/validatorRegistry.algo.ts:540", + "pc": [ + 1913 + ] + }, + { + "teal": 1661, + "source": "examples/reti/validatorRegistry.algo.ts:540", + "pc": [ + 1914 + ] + }, + { + "teal": 1665, + "source": "examples/reti/validatorRegistry.algo.ts:541", + "pc": [ + 1915, + 1916, + 1917 + ] + }, + { + "teal": 1666, + "source": "examples/reti/validatorRegistry.algo.ts:541", + "pc": [ + 1918, + 1919 + ] + }, + { + "teal": 1667, + "source": "examples/reti/validatorRegistry.algo.ts:541", + "pc": [ + 1920, + 1921, + 1922 + ] + }, + { + "teal": 1668, + "source": "examples/reti/validatorRegistry.algo.ts:541", + "pc": [ + 1923, + 1924 + ] + }, + { + "teal": 1669, + "source": "examples/reti/validatorRegistry.algo.ts:541", + "pc": [ + 1925 + ] + }, + { + "teal": 1670, + "source": "examples/reti/validatorRegistry.algo.ts:541", + "pc": [ + 1926 + ] + }, + { + "teal": 1671, + "source": "examples/reti/validatorRegistry.algo.ts:541", + "pc": [ + 1927, + 1928 + ] + }, + { + "teal": 1672, + "source": "examples/reti/validatorRegistry.algo.ts:541", + "pc": [ + 1929 + ] + }, + { + "teal": 1673, + "source": "examples/reti/validatorRegistry.algo.ts:535", + "pc": [ + 1930 + ] + }, + { + "teal": 1678, + "source": "examples/reti/validatorRegistry.algo.ts:554", + "pc": [ + 1931, + 1932, + 1933 + ] + }, + { + "teal": 1679, + "source": "examples/reti/validatorRegistry.algo.ts:554", + "pc": [ + 1934 + ] + }, + { + "teal": 1682, + "source": "examples/reti/validatorRegistry.algo.ts:553", + "pc": [ + 1935, + 1936, + 1937 + ] + }, + { + "teal": 1683, + "source": "examples/reti/validatorRegistry.algo.ts:553", + "pc": [ + 1938 + ] + }, + { + "teal": 1686, + "source": "examples/reti/validatorRegistry.algo.ts:552", + "pc": [ + 1939, + 1940, + 1941 + ] + }, + { + "teal": 1687, + "source": "examples/reti/validatorRegistry.algo.ts:552", + "pc": [ + 1942 + ] + }, + { + "teal": 1688, + "source": "examples/reti/validatorRegistry.algo.ts:552", + "pc": [ + 1943 + ] + }, + { + "teal": 1689, + "source": "examples/reti/validatorRegistry.algo.ts:552", + "pc": [ + 1944, + 1945 + ] + }, + { + "teal": 1690, + "source": "examples/reti/validatorRegistry.algo.ts:552", + "pc": [ + 1946 + ] + }, + { + "teal": 1693, + "source": "examples/reti/validatorRegistry.algo.ts:552", + "errorMessage": "argument 2 (EntryGatingAssets) for changeValidatorRewardInfo must be a uint64[4]", + "pc": [ + 1947 + ] + }, + { + "teal": 1696, + "source": "examples/reti/validatorRegistry.algo.ts:551", + "pc": [ + 1948, + 1949, + 1950 + ] + }, + { + "teal": 1697, + "source": "examples/reti/validatorRegistry.algo.ts:551", + "pc": [ + 1951 + ] + }, + { + "teal": 1698, + "source": "examples/reti/validatorRegistry.algo.ts:551", + "pc": [ + 1952 + ] + }, + { + "teal": 1699, + "source": "examples/reti/validatorRegistry.algo.ts:551", + "pc": [ + 1953, + 1954 + ] + }, + { + "teal": 1700, + "source": "examples/reti/validatorRegistry.algo.ts:551", + "pc": [ + 1955 + ] + }, + { + "teal": 1703, + "source": "examples/reti/validatorRegistry.algo.ts:551", + "errorMessage": "argument 3 (EntryGatingAddress) for changeValidatorRewardInfo must be a address", + "pc": [ + 1956 + ] + }, + { + "teal": 1706, + "source": "examples/reti/validatorRegistry.algo.ts:550", + "pc": [ + 1957, + 1958, + 1959 + ] + }, + { + "teal": 1707, + "source": "examples/reti/validatorRegistry.algo.ts:550", + "pc": [ + 1960 + ] + }, + { + "teal": 1708, + "source": "examples/reti/validatorRegistry.algo.ts:550", + "pc": [ + 1961 + ] + }, + { + "teal": 1709, + "source": "examples/reti/validatorRegistry.algo.ts:550", + "pc": [ + 1962, + 1963 + ] + }, + { + "teal": 1710, + "source": "examples/reti/validatorRegistry.algo.ts:550", + "pc": [ + 1964 + ] + }, + { + "teal": 1713, + "source": "examples/reti/validatorRegistry.algo.ts:550", + "errorMessage": "argument 4 (EntryGatingType) for changeValidatorRewardInfo must be a uint8", + "pc": [ + 1965 + ] + }, + { + "teal": 1714, + "source": "examples/reti/validatorRegistry.algo.ts:550", + "pc": [ + 1966 + ] + }, + { + "teal": 1717, + "source": "examples/reti/validatorRegistry.algo.ts:549", + "pc": [ + 1967, + 1968, + 1969 + ] + }, + { + "teal": 1718, + "source": "examples/reti/validatorRegistry.algo.ts:549", + "pc": [ + 1970 + ] + }, + { + "teal": 1721, + "source": "examples/reti/validatorRegistry.algo.ts:548", + "pc": [ + 1971, + 1972, + 1973 + ] + }, + { + "teal": 1722, + "source": "examples/reti/validatorRegistry.algo.ts:548", + "pc": [ + 1974, + 1975 + ] + }, + { + "teal": 1723, + "source": "examples/reti/validatorRegistry.algo.ts:548", + "pc": [ + 1976 + ] + }, + { + "teal": 1730, + "source": "examples/reti/validatorRegistry.algo.ts:548", + "pc": [ + 1977, + 1978, + 1979 + ] + }, + { + "teal": 1737, + "source": "examples/reti/validatorRegistry.algo.ts:557", + "pc": [ + 1980, + 1981 + ] + }, + { + "teal": 1738, + "source": "examples/reti/validatorRegistry.algo.ts:557", + "pc": [ + 1982, + 1983 + ] + }, + { + "teal": 1739, + "source": "examples/reti/validatorRegistry.algo.ts:557", + "pc": [ + 1984, + 1985 + ] + }, + { + "teal": 1740, + "source": "examples/reti/validatorRegistry.algo.ts:557", + "pc": [ + 1986, + 1987, + 1988 + ] + }, + { + "teal": 1741, + "source": "examples/reti/validatorRegistry.algo.ts:557", + "pc": [ + 1989, + 1990 + ] + }, + { + "teal": 1742, + "source": "examples/reti/validatorRegistry.algo.ts:557", + "pc": [ + 1991 + ] + }, + { + "teal": 1743, + "source": "examples/reti/validatorRegistry.algo.ts:557", + "pc": [ + 1992 + ] + }, + { + "teal": 1744, + "source": "examples/reti/validatorRegistry.algo.ts:557", + "pc": [ + 1993, + 1994 + ] + }, + { + "teal": 1745, + "source": "examples/reti/validatorRegistry.algo.ts:557", + "pc": [ + 1995 + ] + }, + { + "teal": 1746, + "source": "examples/reti/validatorRegistry.algo.ts:557", + "pc": [ + 1996 + ] + }, + { + "teal": 1749, + "source": "examples/reti/validatorRegistry.algo.ts:556", + "errorMessage": "can only be called by validator owner", + "pc": [ + 1997 + ] + }, + { + "teal": 1753, + "source": "examples/reti/validatorRegistry.algo.ts:561", + "pc": [ + 1998, + 1999 + ] + }, + { + "teal": 1754, + "source": "examples/reti/validatorRegistry.algo.ts:561", + "pc": [ + 2000, + 2001 + ] + }, + { + "teal": 1755, + "source": "examples/reti/validatorRegistry.algo.ts:561", + "pc": [ + 2002 + ] + }, + { + "teal": 1756, + "source": "examples/reti/validatorRegistry.algo.ts:561", + "pc": [ + 2003, + 2004, + 2005 + ] + }, + { + "teal": 1757, + "source": "examples/reti/validatorRegistry.algo.ts:561", + "pc": [ + 2006, + 2007, + 2008 + ] + }, + { + "teal": 1758, + "source": "examples/reti/validatorRegistry.algo.ts:561", + "pc": [ + 2009, + 2010 + ] + }, + { + "teal": 1759, + "source": "examples/reti/validatorRegistry.algo.ts:561", + "pc": [ + 2011 + ] + }, + { + "teal": 1760, + "source": "examples/reti/validatorRegistry.algo.ts:561", + "pc": [ + 2012 + ] + }, + { + "teal": 1761, + "source": "examples/reti/validatorRegistry.algo.ts:561", + "pc": [ + 2013, + 2014 + ] + }, + { + "teal": 1762, + "source": "examples/reti/validatorRegistry.algo.ts:561", + "pc": [ + 2015 + ] + }, + { + "teal": 1766, + "source": "examples/reti/validatorRegistry.algo.ts:562", + "pc": [ + 2016, + 2017 + ] + }, + { + "teal": 1767, + "source": "examples/reti/validatorRegistry.algo.ts:562", + "pc": [ + 2018, + 2019 + ] + }, + { + "teal": 1768, + "source": "examples/reti/validatorRegistry.algo.ts:562", + "pc": [ + 2020, + 2021, + 2022 + ] + }, + { + "teal": 1769, + "source": "examples/reti/validatorRegistry.algo.ts:562", + "pc": [ + 2023, + 2024 + ] + }, + { + "teal": 1770, + "source": "examples/reti/validatorRegistry.algo.ts:562", + "pc": [ + 2025 + ] + }, + { + "teal": 1771, + "source": "examples/reti/validatorRegistry.algo.ts:562", + "pc": [ + 2026 + ] + }, + { + "teal": 1772, + "source": "examples/reti/validatorRegistry.algo.ts:562", + "pc": [ + 2027, + 2028 + ] + }, + { + "teal": 1773, + "source": "examples/reti/validatorRegistry.algo.ts:562", + "pc": [ + 2029 + ] + }, + { + "teal": 1777, + "source": "examples/reti/validatorRegistry.algo.ts:563", + "pc": [ + 2030, + 2031 + ] + }, + { + "teal": 1778, + "source": "examples/reti/validatorRegistry.algo.ts:563", + "pc": [ + 2032, + 2033 + ] + }, + { + "teal": 1779, + "source": "examples/reti/validatorRegistry.algo.ts:563", + "pc": [ + 2034, + 2035, + 2036 + ] + }, + { + "teal": 1780, + "source": "examples/reti/validatorRegistry.algo.ts:563", + "pc": [ + 2037, + 2038 + ] + }, + { + "teal": 1781, + "source": "examples/reti/validatorRegistry.algo.ts:563", + "pc": [ + 2039 + ] + }, + { + "teal": 1782, + "source": "examples/reti/validatorRegistry.algo.ts:563", + "pc": [ + 2040 + ] + }, + { + "teal": 1783, + "source": "examples/reti/validatorRegistry.algo.ts:563", + "pc": [ + 2041, + 2042 + ] + }, + { + "teal": 1784, + "source": "examples/reti/validatorRegistry.algo.ts:563", + "pc": [ + 2043 + ] + }, + { + "teal": 1788, + "source": "examples/reti/validatorRegistry.algo.ts:564", + "pc": [ + 2044, + 2045, + 2046 + ] + }, + { + "teal": 1789, + "source": "examples/reti/validatorRegistry.algo.ts:564", + "pc": [ + 2047, + 2048 + ] + }, + { + "teal": 1790, + "source": "examples/reti/validatorRegistry.algo.ts:564", + "pc": [ + 2049 + ] + }, + { + "teal": 1791, + "source": "examples/reti/validatorRegistry.algo.ts:564", + "pc": [ + 2050, + 2051, + 2052 + ] + }, + { + "teal": 1792, + "source": "examples/reti/validatorRegistry.algo.ts:564", + "pc": [ + 2053, + 2054 + ] + }, + { + "teal": 1793, + "source": "examples/reti/validatorRegistry.algo.ts:564", + "pc": [ + 2055 + ] + }, + { + "teal": 1794, + "source": "examples/reti/validatorRegistry.algo.ts:564", + "pc": [ + 2056 + ] + }, + { + "teal": 1795, + "source": "examples/reti/validatorRegistry.algo.ts:564", + "pc": [ + 2057, + 2058 + ] + }, + { + "teal": 1796, + "source": "examples/reti/validatorRegistry.algo.ts:564", + "pc": [ + 2059 + ] + }, + { + "teal": 1800, + "source": "examples/reti/validatorRegistry.algo.ts:565", + "pc": [ + 2060, + 2061, + 2062 + ] + }, + { + "teal": 1801, + "source": "examples/reti/validatorRegistry.algo.ts:565", + "pc": [ + 2063, + 2064 + ] + }, + { + "teal": 1802, + "source": "examples/reti/validatorRegistry.algo.ts:565", + "pc": [ + 2065 + ] + }, + { + "teal": 1803, + "source": "examples/reti/validatorRegistry.algo.ts:565", + "pc": [ + 2066, + 2067, + 2068 + ] + }, + { + "teal": 1804, + "source": "examples/reti/validatorRegistry.algo.ts:565", + "pc": [ + 2069, + 2070 + ] + }, + { + "teal": 1805, + "source": "examples/reti/validatorRegistry.algo.ts:565", + "pc": [ + 2071 + ] + }, + { + "teal": 1806, + "source": "examples/reti/validatorRegistry.algo.ts:565", + "pc": [ + 2072 + ] + }, + { + "teal": 1807, + "source": "examples/reti/validatorRegistry.algo.ts:565", + "pc": [ + 2073, + 2074 + ] + }, + { + "teal": 1808, + "source": "examples/reti/validatorRegistry.algo.ts:565", + "pc": [ + 2075 + ] + }, + { + "teal": 1809, + "source": "examples/reti/validatorRegistry.algo.ts:548", + "pc": [ + 2076 + ] + }, + { + "teal": 1814, + "source": "examples/reti/validatorRegistry.algo.ts:579", + "pc": [ + 2077, + 2078, + 2079, + 2080, + 2081, + 2082 + ] + }, + { + "teal": 1817, + "source": "examples/reti/validatorRegistry.algo.ts:579", + "pc": [ + 2083, + 2084, + 2085 + ] + }, + { + "teal": 1818, + "source": "examples/reti/validatorRegistry.algo.ts:579", + "pc": [ + 2086 + ] + }, + { + "teal": 1821, + "source": "examples/reti/validatorRegistry.algo.ts:579", + "pc": [ + 2087, + 2088, + 2089 + ] + }, + { + "teal": 1822, + "source": "examples/reti/validatorRegistry.algo.ts:579", + "pc": [ + 2090 + ] + }, + { + "teal": 1825, + "source": "examples/reti/validatorRegistry.algo.ts:579", + "pc": [ + 2091, + 2092 + ] + }, + { + "teal": 1826, + "source": "examples/reti/validatorRegistry.algo.ts:579", + "pc": [ + 2093, + 2094 + ] + }, + { + "teal": 1827, + "source": "examples/reti/validatorRegistry.algo.ts:579", + "pc": [ + 2095 + ] + }, + { + "teal": 1828, + "source": "examples/reti/validatorRegistry.algo.ts:579", + "pc": [ + 2096 + ] + }, + { + "teal": 1829, + "source": "examples/reti/validatorRegistry.algo.ts:579", + "pc": [ + 2097, + 2098 + ] + }, + { + "teal": 1830, + "source": "examples/reti/validatorRegistry.algo.ts:579", + "pc": [ + 2099, + 2100 + ] + }, + { + "teal": 1831, + "source": "examples/reti/validatorRegistry.algo.ts:579", + "pc": [ + 2101 + ] + }, + { + "teal": 1834, + "source": "examples/reti/validatorRegistry.algo.ts:579", + "errorMessage": "argument 2 (mbrPayment) for addPool must be a pay transaction", + "pc": [ + 2102 + ] + }, + { + "teal": 1837, + "source": "examples/reti/validatorRegistry.algo.ts:579", + "pc": [ + 2103, + 2104, + 2105 + ] + }, + { + "teal": 1838, + "source": "examples/reti/validatorRegistry.algo.ts:579", + "pc": [ + 2106 + ] + }, + { + "teal": 1839, + "source": "examples/reti/validatorRegistry.algo.ts:579", + "pc": [ + 2107 + ] + }, + { + "teal": 1840, + "source": "examples/reti/validatorRegistry.algo.ts:579", + "pc": [ + 2108, + 2109 + ] + }, + { + "teal": 1841, + "source": "examples/reti/validatorRegistry.algo.ts:579", + "pc": [ + 2110 + ] + }, + { + "teal": 1854, + "source": "examples/reti/validatorRegistry.algo.ts:579", + "pc": [ + 2111, + 2112, + 2113 + ] + }, + { + "teal": 1857, + "source": "examples/reti/validatorRegistry.algo.ts:579", + "pc": [ + 2114, + 2115 + ] + }, + { + "teal": 1858, + "source": "examples/reti/validatorRegistry.algo.ts:579", + "pc": [ + 2116 + ] + }, + { + "teal": 1866, + "source": "examples/reti/validatorRegistry.algo.ts:582", + "pc": [ + 2117, + 2118 + ] + }, + { + "teal": 1867, + "source": "examples/reti/validatorRegistry.algo.ts:582", + "pc": [ + 2119, + 2120 + ] + }, + { + "teal": 1868, + "source": "examples/reti/validatorRegistry.algo.ts:582", + "pc": [ + 2121, + 2122 + ] + }, + { + "teal": 1869, + "source": "examples/reti/validatorRegistry.algo.ts:582", + "pc": [ + 2123, + 2124, + 2125 + ] + }, + { + "teal": 1870, + "source": "examples/reti/validatorRegistry.algo.ts:582", + "pc": [ + 2126, + 2127 + ] + }, + { + "teal": 1871, + "source": "examples/reti/validatorRegistry.algo.ts:582", + "pc": [ + 2128 + ] + }, + { + "teal": 1872, + "source": "examples/reti/validatorRegistry.algo.ts:582", + "pc": [ + 2129 + ] + }, + { + "teal": 1873, + "source": "examples/reti/validatorRegistry.algo.ts:582", + "pc": [ + 2130, + 2131 + ] + }, + { + "teal": 1874, + "source": "examples/reti/validatorRegistry.algo.ts:582", + "pc": [ + 2132 + ] + }, + { + "teal": 1875, + "source": "examples/reti/validatorRegistry.algo.ts:582", + "pc": [ + 2133 + ] + }, + { + "teal": 1876, + "source": "examples/reti/validatorRegistry.algo.ts:582", + "pc": [ + 2134 + ] + }, + { + "teal": 1877, + "source": "examples/reti/validatorRegistry.algo.ts:582", + "pc": [ + 2135, + 2136, + 2137 + ] + }, + { + "teal": 1878, + "source": "examples/reti/validatorRegistry.algo.ts:583", + "pc": [ + 2138, + 2139 + ] + }, + { + "teal": 1879, + "source": "examples/reti/validatorRegistry.algo.ts:583", + "pc": [ + 2140, + 2141 + ] + }, + { + "teal": 1880, + "source": "examples/reti/validatorRegistry.algo.ts:583", + "pc": [ + 2142, + 2143 + ] + }, + { + "teal": 1881, + "source": "examples/reti/validatorRegistry.algo.ts:583", + "pc": [ + 2144, + 2145, + 2146 + ] + }, + { + "teal": 1882, + "source": "examples/reti/validatorRegistry.algo.ts:583", + "pc": [ + 2147, + 2148 + ] + }, + { + "teal": 1883, + "source": "examples/reti/validatorRegistry.algo.ts:583", + "pc": [ + 2149 + ] + }, + { + "teal": 1884, + "source": "examples/reti/validatorRegistry.algo.ts:583", + "pc": [ + 2150 + ] + }, + { + "teal": 1885, + "source": "examples/reti/validatorRegistry.algo.ts:583", + "pc": [ + 2151, + 2152 + ] + }, + { + "teal": 1886, + "source": "examples/reti/validatorRegistry.algo.ts:583", + "pc": [ + 2153 + ] + }, + { + "teal": 1887, + "source": "examples/reti/validatorRegistry.algo.ts:583", + "pc": [ + 2154 + ] + }, + { + "teal": 1888, + "source": "examples/reti/validatorRegistry.algo.ts:582", + "pc": [ + 2155 + ] + }, + { + "teal": 1892, + "source": "examples/reti/validatorRegistry.algo.ts:581", + "errorMessage": "can only be called by owner or manager of validator", + "pc": [ + 2156 + ] + }, + { + "teal": 1897, + "source": "examples/reti/validatorRegistry.algo.ts:588", + "pc": [ + 2157, + 2158 + ] + }, + { + "teal": 1898, + "source": "examples/reti/validatorRegistry.algo.ts:588", + "pc": [ + 2159, + 2160 + ] + }, + { + "teal": 1899, + "source": "examples/reti/validatorRegistry.algo.ts:588", + "pc": [ + 2161, + 2162, + 2163 + ] + }, + { + "teal": 1900, + "source": "examples/reti/validatorRegistry.algo.ts:588", + "pc": [ + 2164, + 2165, + 2166 + ] + }, + { + "teal": 1901, + "source": "examples/reti/validatorRegistry.algo.ts:588", + "pc": [ + 2167 + ] + }, + { + "teal": 1902, + "source": "examples/reti/validatorRegistry.algo.ts:588", + "pc": [ + 2168 + ] + }, + { + "teal": 1905, + "source": "examples/reti/validatorRegistry.algo.ts:588", + "errorMessage": "transaction verification failed: {\"txn\":\"mbrPayment\",\"field\":\"amount\",\"expected\":\"this.getMbrAmounts().addPoolMbr\"}", + "pc": [ + 2169 + ] + }, + { + "teal": 1908, + "source": "examples/reti/validatorRegistry.algo.ts:588", + "pc": [ + 2170, + 2171 + ] + }, + { + "teal": 1909, + "source": "examples/reti/validatorRegistry.algo.ts:588", + "pc": [ + 2172, + 2173 + ] + }, + { + "teal": 1910, + "source": "examples/reti/validatorRegistry.algo.ts:588", + "pc": [ + 2174, + 2175 + ] + }, + { + "teal": 1911, + "source": "examples/reti/validatorRegistry.algo.ts:588", + "pc": [ + 2176 + ] + }, + { + "teal": 1914, + "source": "examples/reti/validatorRegistry.algo.ts:588", + "errorMessage": "transaction verification failed: {\"txn\":\"mbrPayment\",\"field\":\"receiver\",\"expected\":\"this.app.address\"}", + "pc": [ + 2177 + ] + }, + { + "teal": 1918, + "source": "examples/reti/validatorRegistry.algo.ts:590", + "pc": [ + 2178, + 2179, + 2180 + ] + }, + { + "teal": 1919, + "source": "examples/reti/validatorRegistry.algo.ts:590", + "pc": [ + 2181, + 2182 + ] + }, + { + "teal": 1920, + "source": "examples/reti/validatorRegistry.algo.ts:590", + "pc": [ + 2183 + ] + }, + { + "teal": 1921, + "source": "examples/reti/validatorRegistry.algo.ts:590", + "pc": [ + 2184 + ] + }, + { + "teal": 1922, + "source": "examples/reti/validatorRegistry.algo.ts:590", + "pc": [ + 2185 + ] + }, + { + "teal": 1923, + "source": "examples/reti/validatorRegistry.algo.ts:590", + "pc": [ + 2186 + ] + }, + { + "teal": 1924, + "source": "examples/reti/validatorRegistry.algo.ts:590", + "pc": [ + 2187 + ] + }, + { + "teal": 1927, + "source": "examples/reti/validatorRegistry.algo.ts:590", + "errorMessage": "specified validator id isn't valid", + "pc": [ + 2188 + ] + }, + { + "teal": 1931, + "source": "examples/reti/validatorRegistry.algo.ts:592", + "pc": [ + 2189, + 2190, + 2191 + ] + }, + { + "teal": 1932, + "source": "examples/reti/validatorRegistry.algo.ts:592", + "pc": [ + 2192, + 2193 + ] + }, + { + "teal": 1933, + "source": "examples/reti/validatorRegistry.algo.ts:592", + "pc": [ + 2194, + 2195, + 2196 + ] + }, + { + "teal": 1934, + "source": "examples/reti/validatorRegistry.algo.ts:592", + "pc": [ + 2197, + 2198 + ] + }, + { + "teal": 1935, + "source": "examples/reti/validatorRegistry.algo.ts:592", + "pc": [ + 2199 + ] + }, + { + "teal": 1936, + "source": "examples/reti/validatorRegistry.algo.ts:592", + "pc": [ + 2200 + ] + }, + { + "teal": 1937, + "source": "examples/reti/validatorRegistry.algo.ts:592", + "pc": [ + 2201, + 2202 + ] + }, + { + "teal": 1938, + "source": "examples/reti/validatorRegistry.algo.ts:592", + "pc": [ + 2203 + ] + }, + { + "teal": 1939, + "source": "examples/reti/validatorRegistry.algo.ts:592", + "pc": [ + 2204 + ] + }, + { + "teal": 1940, + "source": "examples/reti/validatorRegistry.algo.ts:592", + "pc": [ + 2205, + 2206 + ] + }, + { + "teal": 1945, + "source": "examples/reti/validatorRegistry.algo.ts:593", + "pc": [ + 2207, + 2208 + ] + }, + { + "teal": 1946, + "source": "examples/reti/validatorRegistry.algo.ts:32", + "pc": [ + 2209, + 2210 + ] + }, + { + "teal": 1947, + "source": "examples/reti/validatorRegistry.algo.ts:593", + "pc": [ + 2211 + ] + }, + { + "teal": 1948, + "source": "examples/reti/validatorRegistry.algo.ts:593", + "pc": [ + 2212, + 2213, + 2214 + ] + }, + { + "teal": 1952, + "source": "examples/reti/validatorRegistry.algo.ts:594", + "errorMessage": "already at max pool size", + "pc": [ + 2215 + ] + }, + { + "teal": 1957, + "source": "examples/reti/validatorRegistry.algo.ts:596", + "pc": [ + 2216, + 2217 + ] + }, + { + "teal": 1958, + "source": "examples/reti/validatorRegistry.algo.ts:596", + "pc": [ + 2218, + 2219 + ] + }, + { + "teal": 1959, + "source": "examples/reti/validatorRegistry.algo.ts:596", + "pc": [ + 2220 + ] + }, + { + "teal": 1960, + "source": "examples/reti/validatorRegistry.algo.ts:596", + "pc": [ + 2221, + 2222 + ] + }, + { + "teal": 1982, + "source": "examples/reti/validatorRegistry.algo.ts:599", + "pc": [ + 2223 + ] + }, + { + "teal": 1983, + "source": "examples/reti/validatorRegistry.algo.ts:599", + "pc": [ + 2224, + 2225 + ] + }, + { + "teal": 1984, + "source": "examples/reti/validatorRegistry.algo.ts:599", + "pc": [ + 2226, + 2227 + ] + }, + { + "teal": 1988, + "source": "examples/reti/validatorRegistry.algo.ts:600", + "pc": [ + 2228, + 2229 + ] + }, + { + "teal": 1989, + "source": "examples/reti/validatorRegistry.algo.ts:600", + "pc": [ + 2230, + 2231 + ] + }, + { + "teal": 1996, + "source": "examples/reti/validatorRegistry.algo.ts:602", + "pc": [ + 2232, + 2233, + 2234, + 2235, + 2236, + 2237, + 2238, + 2239, + 2240, + 2241, + 2242, + 2243, + 2244, + 2245, + 2246, + 2247, + 2248, + 2249, + 2250, + 2251, + 2252, + 2253, + 2254, + 2255, + 2256, + 2257, + 2258 + ] + }, + { + "teal": 1997, + "source": "examples/reti/validatorRegistry.algo.ts:602", + "pc": [ + 2259, + 2260 + ] + }, + { + "teal": 1998, + "source": "examples/reti/validatorRegistry.algo.ts:602", + "pc": [ + 2261, + 2262, + 2263 + ] + }, + { + "teal": 1999, + "source": "examples/reti/validatorRegistry.algo.ts:602", + "pc": [ + 2264 + ] + }, + { + "teal": 2000, + "source": "examples/reti/validatorRegistry.algo.ts:602", + "pc": [ + 2265, + 2266 + ] + }, + { + "teal": 2001, + "source": "examples/reti/validatorRegistry.algo.ts:603", + "pc": [ + 2267, + 2268, + 2269, + 2270, + 2271, + 2272, + 2273, + 2274, + 2275, + 2276, + 2277, + 2278, + 2279, + 2280, + 2281, + 2282, + 2283, + 2284, + 2285, + 2286, + 2287, + 2288, + 2289, + 2290, + 2291, + 2292, + 2293 + ] + }, + { + "teal": 2002, + "source": "examples/reti/validatorRegistry.algo.ts:603", + "pc": [ + 2294, + 2295, + 2296 + ] + }, + { + "teal": 2003, + "source": "examples/reti/validatorRegistry.algo.ts:603", + "pc": [ + 2297, + 2298, + 2299, + 2300, + 2301, + 2302, + 2303, + 2304, + 2305, + 2306, + 2307, + 2308, + 2309, + 2310, + 2311, + 2312, + 2313, + 2314, + 2315, + 2316, + 2317, + 2318, + 2319, + 2320, + 2321, + 2322, + 2323 + ] + }, + { + "teal": 2004, + "source": "examples/reti/validatorRegistry.algo.ts:603", + "pc": [ + 2324 + ] + }, + { + "teal": 2007, + "source": "examples/reti/validatorRegistry.algo.ts:603", + "errorMessage": "box value does not exist: this.stakingPoolApprovalProgram.size", + "pc": [ + 2325 + ] + }, + { + "teal": 2008, + "source": "examples/reti/validatorRegistry.algo.ts:603", + "pc": [ + 2326, + 2327, + 2328 + ] + }, + { + "teal": 2009, + "source": "examples/reti/validatorRegistry.algo.ts:603", + "pc": [ + 2329 + ] + }, + { + "teal": 2010, + "source": "examples/reti/validatorRegistry.algo.ts:603", + "pc": [ + 2330 + ] + }, + { + "teal": 2011, + "source": "examples/reti/validatorRegistry.algo.ts:603", + "pc": [ + 2331, + 2332 + ] + }, + { + "teal": 2015, + "source": "examples/reti/validatorRegistry.algo.ts:605", + "pc": [ + 2333, + 2334, + 2335 + ] + }, + { + "teal": 2016, + "source": "examples/reti/validatorRegistry.algo.ts:605", + "pc": [ + 2336, + 2337 + ] + }, + { + "teal": 2020, + "source": "examples/reti/validatorRegistry.algo.ts:606", + "pc": [ + 2338, + 2339 + ] + }, + { + "teal": 2021, + "source": "examples/reti/validatorRegistry.algo.ts:606", + "pc": [ + 2340, + 2341 + ] + }, + { + "teal": 2025, + "source": "examples/reti/validatorRegistry.algo.ts:607", + "pc": [ + 2342, + 2343 + ] + }, + { + "teal": 2026, + "source": "examples/reti/validatorRegistry.algo.ts:607", + "pc": [ + 2344, + 2345 + ] + }, + { + "teal": 2030, + "source": "examples/reti/validatorRegistry.algo.ts:608", + "pc": [ + 2346, + 2347 + ] + }, + { + "teal": 2031, + "source": "examples/reti/validatorRegistry.algo.ts:608", + "pc": [ + 2348, + 2349 + ] + }, + { + "teal": 2042, + "source": "examples/reti/validatorRegistry.algo.ts:611", + "pc": [ + 2350, + 2351, + 2352, + 2353, + 2354, + 2355 + ] + }, + { + "teal": 2043, + "source": "examples/reti/validatorRegistry.algo.ts:611", + "pc": [ + 2356, + 2357 + ] + }, + { + "teal": 2044, + "source": "examples/reti/validatorRegistry.algo.ts:612", + "pc": [ + 2358, + 2359, + 2360 + ] + }, + { + "teal": 2045, + "source": "examples/reti/validatorRegistry.algo.ts:612", + "pc": [ + 2361 + ] + }, + { + "teal": 2046, + "source": "examples/reti/validatorRegistry.algo.ts:612", + "pc": [ + 2362, + 2363 + ] + }, + { + "teal": 2047, + "source": "examples/reti/validatorRegistry.algo.ts:613", + "pc": [ + 2364, + 2365 + ] + }, + { + "teal": 2048, + "source": "examples/reti/validatorRegistry.algo.ts:613", + "pc": [ + 2366 + ] + }, + { + "teal": 2049, + "source": "examples/reti/validatorRegistry.algo.ts:613", + "pc": [ + 2367, + 2368 + ] + }, + { + "teal": 2050, + "source": "examples/reti/validatorRegistry.algo.ts:614", + "pc": [ + 2369, + 2370 + ] + }, + { + "teal": 2051, + "source": "examples/reti/validatorRegistry.algo.ts:614", + "pc": [ + 2371 + ] + }, + { + "teal": 2052, + "source": "examples/reti/validatorRegistry.algo.ts:614", + "pc": [ + 2372, + 2373 + ] + }, + { + "teal": 2053, + "source": "examples/reti/validatorRegistry.algo.ts:615", + "pc": [ + 2374, + 2375, + 2376 + ] + }, + { + "teal": 2054, + "source": "examples/reti/validatorRegistry.algo.ts:615", + "pc": [ + 2377, + 2378 + ] + }, + { + "teal": 2055, + "source": "examples/reti/validatorRegistry.algo.ts:615", + "pc": [ + 2379, + 2380, + 2381 + ] + }, + { + "teal": 2056, + "source": "examples/reti/validatorRegistry.algo.ts:615", + "pc": [ + 2382, + 2383 + ] + }, + { + "teal": 2057, + "source": "examples/reti/validatorRegistry.algo.ts:615", + "pc": [ + 2384 + ] + }, + { + "teal": 2058, + "source": "examples/reti/validatorRegistry.algo.ts:615", + "pc": [ + 2385 + ] + }, + { + "teal": 2059, + "source": "examples/reti/validatorRegistry.algo.ts:615", + "pc": [ + 2386, + 2387 + ] + }, + { + "teal": 2060, + "source": "examples/reti/validatorRegistry.algo.ts:615", + "pc": [ + 2388 + ] + }, + { + "teal": 2061, + "source": "examples/reti/validatorRegistry.algo.ts:615", + "pc": [ + 2389 + ] + }, + { + "teal": 2062, + "source": "examples/reti/validatorRegistry.algo.ts:615", + "pc": [ + 2390 + ] + }, + { + "teal": 2063, + "source": "examples/reti/validatorRegistry.algo.ts:615", + "pc": [ + 2391, + 2392 + ] + }, + { + "teal": 2066, + "source": "examples/reti/validatorRegistry.algo.ts:599", + "pc": [ + 2393, + 2394 + ] + }, + { + "teal": 2067, + "source": "examples/reti/validatorRegistry.algo.ts:599", + "pc": [ + 2395, + 2396 + ] + }, + { + "teal": 2070, + "source": "examples/reti/validatorRegistry.algo.ts:599", + "pc": [ + 2397 + ] + }, + { + "teal": 2074, + "source": "examples/reti/validatorRegistry.algo.ts:619", + "pc": [ + 2398, + 2399, + 2400 + ] + }, + { + "teal": 2075, + "source": "examples/reti/validatorRegistry.algo.ts:619", + "pc": [ + 2401, + 2402 + ] + }, + { + "teal": 2076, + "source": "examples/reti/validatorRegistry.algo.ts:619", + "pc": [ + 2403 + ] + }, + { + "teal": 2077, + "source": "examples/reti/validatorRegistry.algo.ts:619", + "pc": [ + 2404, + 2405, + 2406 + ] + }, + { + "teal": 2078, + "source": "examples/reti/validatorRegistry.algo.ts:619", + "pc": [ + 2407, + 2408, + 2409 + ] + }, + { + "teal": 2079, + "source": "examples/reti/validatorRegistry.algo.ts:619", + "pc": [ + 2410, + 2411 + ] + }, + { + "teal": 2080, + "source": "examples/reti/validatorRegistry.algo.ts:619", + "pc": [ + 2412 + ] + }, + { + "teal": 2081, + "source": "examples/reti/validatorRegistry.algo.ts:619", + "pc": [ + 2413 + ] + }, + { + "teal": 2082, + "source": "examples/reti/validatorRegistry.algo.ts:619", + "pc": [ + 2414, + 2415 + ] + }, + { + "teal": 2083, + "source": "examples/reti/validatorRegistry.algo.ts:619", + "pc": [ + 2416 + ] + }, + { + "teal": 2087, + "source": "examples/reti/validatorRegistry.algo.ts:622", + "pc": [ + 2417, + 2418 + ] + }, + { + "teal": 2088, + "source": "examples/reti/validatorRegistry.algo.ts:622", + "pc": [ + 2419, + 2420 + ] + }, + { + "teal": 2092, + "source": "examples/reti/validatorRegistry.algo.ts:623", + "pc": [ + 2421, + 2422, + 2423 + ] + }, + { + "teal": 2093, + "source": "examples/reti/validatorRegistry.algo.ts:623", + "pc": [ + 2424, + 2425 + ] + }, + { + "teal": 2094, + "source": "examples/reti/validatorRegistry.algo.ts:623", + "pc": [ + 2426, + 2427 + ] + }, + { + "teal": 2095, + "source": "examples/reti/validatorRegistry.algo.ts:623", + "pc": [ + 2428 + ] + }, + { + "teal": 2096, + "source": "examples/reti/validatorRegistry.algo.ts:623", + "pc": [ + 2429, + 2430 + ] + }, + { + "teal": 2097, + "source": "examples/reti/validatorRegistry.algo.ts:623", + "pc": [ + 2431 + ] + }, + { + "teal": 2098, + "source": "examples/reti/validatorRegistry.algo.ts:623", + "pc": [ + 2432 + ] + }, + { + "teal": 2099, + "source": "examples/reti/validatorRegistry.algo.ts:623", + "pc": [ + 2433, + 2434 + ] + }, + { + "teal": 2100, + "source": "examples/reti/validatorRegistry.algo.ts:623", + "pc": [ + 2435 + ] + }, + { + "teal": 2101, + "source": "examples/reti/validatorRegistry.algo.ts:623", + "pc": [ + 2436, + 2437 + ] + }, + { + "teal": 2102, + "source": "examples/reti/validatorRegistry.algo.ts:623", + "pc": [ + 2438 + ] + }, + { + "teal": 2103, + "source": "examples/reti/validatorRegistry.algo.ts:623", + "pc": [ + 2439, + 2440, + 2441 + ] + }, + { + "teal": 2104, + "source": "examples/reti/validatorRegistry.algo.ts:623", + "pc": [ + 2442, + 2443 + ] + }, + { + "teal": 2105, + "source": "examples/reti/validatorRegistry.algo.ts:623", + "pc": [ + 2444 + ] + }, + { + "teal": 2106, + "source": "examples/reti/validatorRegistry.algo.ts:623", + "pc": [ + 2445 + ] + }, + { + "teal": 2107, + "source": "examples/reti/validatorRegistry.algo.ts:623", + "pc": [ + 2446, + 2447 + ] + }, + { + "teal": 2108, + "source": "examples/reti/validatorRegistry.algo.ts:623", + "pc": [ + 2448 + ] + }, + { + "teal": 2112, + "source": "examples/reti/validatorRegistry.algo.ts:624", + "pc": [ + 2449, + 2450 + ] + }, + { + "teal": 2113, + "source": "examples/reti/validatorRegistry.algo.ts:624", + "pc": [ + 2451, + 2452 + ] + }, + { + "teal": 2114, + "source": "examples/reti/validatorRegistry.algo.ts:624", + "pc": [ + 2453, + 2454 + ] + }, + { + "teal": 2115, + "source": "examples/reti/validatorRegistry.algo.ts:624", + "pc": [ + 2455, + 2456, + 2457 + ] + }, + { + "teal": 2119, + "source": "examples/reti/validatorRegistry.algo.ts:632", + "pc": [ + 2458, + 2459 + ] + }, + { + "teal": 2120, + "source": "examples/reti/validatorRegistry.algo.ts:632", + "pc": [ + 2460 + ] + }, + { + "teal": 2121, + "source": "examples/reti/validatorRegistry.algo.ts:632", + "pc": [ + 2461, + 2462 + ] + }, + { + "teal": 2122, + "source": "examples/reti/validatorRegistry.algo.ts:632", + "pc": [ + 2463 + ] + }, + { + "teal": 2123, + "source": "examples/reti/validatorRegistry.algo.ts:632", + "pc": [ + 2464 + ] + }, + { + "teal": 2124, + "source": "examples/reti/validatorRegistry.algo.ts:632", + "pc": [ + 2465, + 2466 + ] + }, + { + "teal": 2125, + "source": "examples/reti/validatorRegistry.algo.ts:632", + "pc": [ + 2467 + ] + }, + { + "teal": 2126, + "source": "examples/reti/validatorRegistry.algo.ts:632", + "pc": [ + 2468 + ] + }, + { + "teal": 2129, + "source": "examples/reti/validatorRegistry.algo.ts:579", + "pc": [ + 2469, + 2470 + ] + }, + { + "teal": 2132, + "source": "examples/reti/validatorRegistry.algo.ts:579", + "pc": [ + 2471, + 2472 + ] + }, + { + "teal": 2133, + "source": "examples/reti/validatorRegistry.algo.ts:579", + "pc": [ + 2473 + ] + }, + { + "teal": 2138, + "source": "examples/reti/validatorRegistry.algo.ts:644", + "pc": [ + 2474, + 2475, + 2476, + 2477, + 2478, + 2479 + ] + }, + { + "teal": 2141, + "source": "examples/reti/validatorRegistry.algo.ts:644", + "pc": [ + 2480, + 2481, + 2482 + ] + }, + { + "teal": 2142, + "source": "examples/reti/validatorRegistry.algo.ts:644", + "pc": [ + 2483 + ] + }, + { + "teal": 2145, + "source": "examples/reti/validatorRegistry.algo.ts:644", + "pc": [ + 2484, + 2485, + 2486 + ] + }, + { + "teal": 2146, + "source": "examples/reti/validatorRegistry.algo.ts:644", + "pc": [ + 2487 + ] + }, + { + "teal": 2149, + "source": "examples/reti/validatorRegistry.algo.ts:644", + "pc": [ + 2488, + 2489 + ] + }, + { + "teal": 2150, + "source": "examples/reti/validatorRegistry.algo.ts:644", + "pc": [ + 2490, + 2491 + ] + }, + { + "teal": 2151, + "source": "examples/reti/validatorRegistry.algo.ts:644", + "pc": [ + 2492 + ] + }, + { + "teal": 2152, + "source": "examples/reti/validatorRegistry.algo.ts:644", + "pc": [ + 2493 + ] + }, + { + "teal": 2153, + "source": "examples/reti/validatorRegistry.algo.ts:644", + "pc": [ + 2494, + 2495 + ] + }, + { + "teal": 2154, + "source": "examples/reti/validatorRegistry.algo.ts:644", + "pc": [ + 2496, + 2497 + ] + }, + { + "teal": 2155, + "source": "examples/reti/validatorRegistry.algo.ts:644", + "pc": [ + 2498 + ] + }, + { + "teal": 2158, + "source": "examples/reti/validatorRegistry.algo.ts:644", + "errorMessage": "argument 2 (stakedAmountPayment) for addStake must be a pay transaction", + "pc": [ + 2499 + ] + }, + { + "teal": 2161, + "source": "examples/reti/validatorRegistry.algo.ts:644", + "pc": [ + 2500, + 2501, + 2502 + ] + }, + { + "teal": 2162, + "source": "examples/reti/validatorRegistry.algo.ts:644", + "pc": [ + 2503 + ] + }, + { + "teal": 2163, + "source": "examples/reti/validatorRegistry.algo.ts:644", + "pc": [ + 2504 + ] + }, + { + "teal": 2164, + "source": "examples/reti/validatorRegistry.algo.ts:644", + "pc": [ + 2505, + 2506 + ] + }, + { + "teal": 2165, + "source": "examples/reti/validatorRegistry.algo.ts:644", + "pc": [ + 2507 + ] + }, + { + "teal": 2177, + "source": "examples/reti/validatorRegistry.algo.ts:644", + "pc": [ + 2508, + 2509, + 2510 + ] + }, + { + "teal": 2180, + "source": "examples/reti/validatorRegistry.algo.ts:644", + "pc": [ + 2511, + 2512 + ] + }, + { + "teal": 2181, + "source": "examples/reti/validatorRegistry.algo.ts:644", + "pc": [ + 2513, + 2514 + ] + }, + { + "teal": 2185, + "source": "examples/reti/validatorRegistry.algo.ts:645", + "pc": [ + 2515, + 2516, + 2517 + ] + }, + { + "teal": 2186, + "source": "examples/reti/validatorRegistry.algo.ts:645", + "pc": [ + 2518, + 2519 + ] + }, + { + "teal": 2187, + "source": "examples/reti/validatorRegistry.algo.ts:645", + "pc": [ + 2520 + ] + }, + { + "teal": 2188, + "source": "examples/reti/validatorRegistry.algo.ts:645", + "pc": [ + 2521 + ] + }, + { + "teal": 2189, + "source": "examples/reti/validatorRegistry.algo.ts:645", + "pc": [ + 2522 + ] + }, + { + "teal": 2190, + "source": "examples/reti/validatorRegistry.algo.ts:645", + "pc": [ + 2523 + ] + }, + { + "teal": 2191, + "source": "examples/reti/validatorRegistry.algo.ts:645", + "pc": [ + 2524 + ] + }, + { + "teal": 2194, + "source": "examples/reti/validatorRegistry.algo.ts:645", + "errorMessage": "specified validator id isn't valid", + "pc": [ + 2525 + ] + }, + { + "teal": 2199, + "source": "examples/reti/validatorRegistry.algo.ts:648", + "pc": [ + 2526, + 2527, + 2528 + ] + }, + { + "teal": 2200, + "source": "examples/reti/validatorRegistry.algo.ts:648", + "pc": [ + 2529, + 2530 + ] + }, + { + "teal": 2201, + "source": "examples/reti/validatorRegistry.algo.ts:648", + "pc": [ + 2531, + 2532, + 2533 + ] + }, + { + "teal": 2202, + "source": "examples/reti/validatorRegistry.algo.ts:648", + "pc": [ + 2534, + 2535 + ] + }, + { + "teal": 2203, + "source": "examples/reti/validatorRegistry.algo.ts:648", + "pc": [ + 2536 + ] + }, + { + "teal": 2204, + "source": "examples/reti/validatorRegistry.algo.ts:648", + "pc": [ + 2537 + ] + }, + { + "teal": 2205, + "source": "examples/reti/validatorRegistry.algo.ts:648", + "pc": [ + 2538, + 2539 + ] + }, + { + "teal": 2206, + "source": "examples/reti/validatorRegistry.algo.ts:648", + "pc": [ + 2540 + ] + }, + { + "teal": 2207, + "source": "examples/reti/validatorRegistry.algo.ts:648", + "pc": [ + 2541 + ] + }, + { + "teal": 2208, + "source": "examples/reti/validatorRegistry.algo.ts:648", + "pc": [ + 2542, + 2543 + ] + }, + { + "teal": 2209, + "source": "examples/reti/validatorRegistry.algo.ts:648", + "pc": [ + 2544 + ] + }, + { + "teal": 2210, + "source": "examples/reti/validatorRegistry.algo.ts:648", + "pc": [ + 2545, + 2546, + 2547 + ] + }, + { + "teal": 2218, + "source": "examples/reti/validatorRegistry.algo.ts:650", + "pc": [ + 2548, + 2549, + 2550 + ] + }, + { + "teal": 2219, + "source": "examples/reti/validatorRegistry.algo.ts:650", + "pc": [ + 2551, + 2552 + ] + }, + { + "teal": 2220, + "source": "examples/reti/validatorRegistry.algo.ts:650", + "pc": [ + 2553, + 2554, + 2555 + ] + }, + { + "teal": 2221, + "source": "examples/reti/validatorRegistry.algo.ts:650", + "pc": [ + 2556, + 2557 + ] + }, + { + "teal": 2222, + "source": "examples/reti/validatorRegistry.algo.ts:650", + "pc": [ + 2558 + ] + }, + { + "teal": 2223, + "source": "examples/reti/validatorRegistry.algo.ts:650", + "pc": [ + 2559 + ] + }, + { + "teal": 2224, + "source": "examples/reti/validatorRegistry.algo.ts:650", + "pc": [ + 2560, + 2561 + ] + }, + { + "teal": 2225, + "source": "examples/reti/validatorRegistry.algo.ts:650", + "pc": [ + 2562 + ] + }, + { + "teal": 2226, + "source": "examples/reti/validatorRegistry.algo.ts:650", + "pc": [ + 2563 + ] + }, + { + "teal": 2227, + "source": "examples/reti/validatorRegistry.algo.ts:650", + "pc": [ + 2564, + 2565 + ] + }, + { + "teal": 2228, + "source": "examples/reti/validatorRegistry.algo.ts:650", + "pc": [ + 2566 + ] + }, + { + "teal": 2231, + "source": "examples/reti/validatorRegistry.algo.ts:649", + "errorMessage": "can't stake with a validator that is past its sunsetting time", + "pc": [ + 2567 + ] + }, + { + "teal": 2236, + "source": "examples/reti/validatorRegistry.algo.ts:655", + "pc": [ + 2568, + 2569 + ] + }, + { + "teal": 2237, + "source": "examples/reti/validatorRegistry.algo.ts:655", + "pc": [ + 2570, + 2571 + ] + }, + { + "teal": 2245, + "source": "examples/reti/validatorRegistry.algo.ts:659", + "pc": [ + 2572, + 2573 + ] + }, + { + "teal": 2246, + "source": "examples/reti/validatorRegistry.algo.ts:660", + "pc": [ + 2574, + 2575 + ] + }, + { + "teal": 2247, + "source": "examples/reti/validatorRegistry.algo.ts:660", + "pc": [ + 2576, + 2577 + ] + }, + { + "teal": 2248, + "source": "examples/reti/validatorRegistry.algo.ts:660", + "pc": [ + 2578 + ] + }, + { + "teal": 2251, + "source": "examples/reti/validatorRegistry.algo.ts:660", + "errorMessage": "transaction verification failed: {\"txn\":\"stakedAmountPayment\",\"field\":\"sender\",\"expected\":\"staker\"}", + "pc": [ + 2579 + ] + }, + { + "teal": 2254, + "source": "examples/reti/validatorRegistry.algo.ts:659", + "pc": [ + 2580, + 2581 + ] + }, + { + "teal": 2255, + "source": "examples/reti/validatorRegistry.algo.ts:661", + "pc": [ + 2582, + 2583 + ] + }, + { + "teal": 2256, + "source": "examples/reti/validatorRegistry.algo.ts:661", + "pc": [ + 2584, + 2585 + ] + }, + { + "teal": 2257, + "source": "examples/reti/validatorRegistry.algo.ts:661", + "pc": [ + 2586 + ] + }, + { + "teal": 2260, + "source": "examples/reti/validatorRegistry.algo.ts:661", + "errorMessage": "transaction verification failed: {\"txn\":\"stakedAmountPayment\",\"field\":\"receiver\",\"expected\":\"this.app.address\"}", + "pc": [ + 2587 + ] + }, + { + "teal": 2267, + "source": "examples/reti/validatorRegistry.algo.ts:667", + "pc": [ + 2588, + 2589, + 2590 + ] + }, + { + "teal": 2268, + "source": "examples/reti/validatorRegistry.algo.ts:667", + "pc": [ + 2591, + 2592 + ] + }, + { + "teal": 2269, + "source": "examples/reti/validatorRegistry.algo.ts:667", + "pc": [ + 2593, + 2594, + 2595 + ] + }, + { + "teal": 2270, + "source": "examples/reti/validatorRegistry.algo.ts:667", + "pc": [ + 2596, + 2597 + ] + }, + { + "teal": 2271, + "source": "examples/reti/validatorRegistry.algo.ts:667", + "pc": [ + 2598 + ] + }, + { + "teal": 2272, + "source": "examples/reti/validatorRegistry.algo.ts:667", + "pc": [ + 2599 + ] + }, + { + "teal": 2273, + "source": "examples/reti/validatorRegistry.algo.ts:667", + "pc": [ + 2600, + 2601 + ] + }, + { + "teal": 2274, + "source": "examples/reti/validatorRegistry.algo.ts:667", + "pc": [ + 2602 + ] + }, + { + "teal": 2275, + "source": "examples/reti/validatorRegistry.algo.ts:667", + "pc": [ + 2603 + ] + }, + { + "teal": 2276, + "source": "examples/reti/validatorRegistry.algo.ts:667", + "pc": [ + 2604, + 2605, + 2606 + ] + }, + { + "teal": 2277, + "source": "examples/reti/validatorRegistry.algo.ts:667", + "pc": [ + 2607 + ] + }, + { + "teal": 2280, + "source": "examples/reti/validatorRegistry.algo.ts:666", + "errorMessage": "total staked for all of a validators pools may not exceed hard cap", + "pc": [ + 2608 + ] + }, + { + "teal": 2284, + "source": "examples/reti/validatorRegistry.algo.ts:673", + "pc": [ + 2609, + 2610 + ] + }, + { + "teal": 2285, + "source": "examples/reti/validatorRegistry.algo.ts:673", + "pc": [ + 2611, + 2612 + ] + }, + { + "teal": 2286, + "source": "examples/reti/validatorRegistry.algo.ts:673", + "pc": [ + 2613, + 2614, + 2615 + ] + }, + { + "teal": 2290, + "source": "examples/reti/validatorRegistry.algo.ts:675", + "pc": [ + 2616, + 2617 + ] + }, + { + "teal": 2291, + "source": "examples/reti/validatorRegistry.algo.ts:675", + "pc": [ + 2618, + 2619 + ] + }, + { + "teal": 2292, + "source": "examples/reti/validatorRegistry.algo.ts:675", + "pc": [ + 2620, + 2621 + ] + }, + { + "teal": 2296, + "source": "examples/reti/validatorRegistry.algo.ts:676", + "pc": [ + 2622, + 2623 + ] + }, + { + "teal": 2297, + "source": "examples/reti/validatorRegistry.algo.ts:676", + "pc": [ + 2624, + 2625 + ] + }, + { + "teal": 2302, + "source": "examples/reti/validatorRegistry.algo.ts:678", + "pc": [ + 2626, + 2627, + 2628, + 2629, + 2630 + ] + }, + { + "teal": 2303, + "source": "examples/reti/validatorRegistry.algo.ts:678", + "pc": [ + 2631, + 2632 + ] + }, + { + "teal": 2304, + "source": "examples/reti/validatorRegistry.algo.ts:678", + "pc": [ + 2633 + ] + }, + { + "teal": 2305, + "source": "examples/reti/validatorRegistry.algo.ts:678", + "pc": [ + 2634 + ] + }, + { + "teal": 2306, + "source": "examples/reti/validatorRegistry.algo.ts:678", + "pc": [ + 2635 + ] + }, + { + "teal": 2307, + "source": "examples/reti/validatorRegistry.algo.ts:678", + "pc": [ + 2636 + ] + }, + { + "teal": 2308, + "source": "examples/reti/validatorRegistry.algo.ts:678", + "pc": [ + 2637 + ] + }, + { + "teal": 2309, + "source": "examples/reti/validatorRegistry.algo.ts:678", + "pc": [ + 2638, + 2639, + 2640 + ] + }, + { + "teal": 2314, + "source": "examples/reti/validatorRegistry.algo.ts:681", + "pc": [ + 2641, + 2642, + 2643 + ] + }, + { + "teal": 2315, + "source": "examples/reti/validatorRegistry.algo.ts:681", + "pc": [ + 2644, + 2645, + 2646 + ] + }, + { + "teal": 2316, + "source": "examples/reti/validatorRegistry.algo.ts:681", + "pc": [ + 2647 + ] + }, + { + "teal": 2317, + "source": "examples/reti/validatorRegistry.algo.ts:681", + "pc": [ + 2648, + 2649 + ] + }, + { + "teal": 2321, + "source": "examples/reti/validatorRegistry.algo.ts:682", + "pc": [ + 2650, + 2651 + ] + }, + { + "teal": 2322, + "source": "examples/reti/validatorRegistry.algo.ts:682", + "pc": [ + 2652, + 2653 + ] + }, + { + "teal": 2323, + "source": "examples/reti/validatorRegistry.algo.ts:682", + "pc": [ + 2654 + ] + }, + { + "teal": 2324, + "source": "examples/reti/validatorRegistry.algo.ts:682", + "pc": [ + 2655, + 2656 + ] + }, + { + "teal": 2328, + "source": "examples/reti/validatorRegistry.algo.ts:683", + "pc": [ + 2657, + 2658, + 2659, + 2660, + 2661 + ] + }, + { + "teal": 2329, + "source": "examples/reti/validatorRegistry.algo.ts:683", + "pc": [ + 2662, + 2663 + ] + }, + { + "teal": 2330, + "source": "examples/reti/validatorRegistry.algo.ts:683", + "pc": [ + 2664 + ] + }, + { + "teal": 2331, + "source": "examples/reti/validatorRegistry.algo.ts:683", + "pc": [ + 2665, + 2666, + 2667 + ] + }, + { + "teal": 2332, + "source": "examples/reti/validatorRegistry.algo.ts:683", + "pc": [ + 2668 + ] + }, + { + "teal": 2333, + "source": "examples/reti/validatorRegistry.algo.ts:683", + "pc": [ + 2669 + ] + }, + { + "teal": 2338, + "source": "examples/reti/validatorRegistry.algo.ts:687", + "pc": [ + 2670, + 2671 + ] + }, + { + "teal": 2339, + "source": "examples/reti/validatorRegistry.algo.ts:687", + "pc": [ + 2672, + 2673 + ] + }, + { + "teal": 2340, + "source": "examples/reti/validatorRegistry.algo.ts:687", + "pc": [ + 2674, + 2675 + ] + }, + { + "teal": 2341, + "source": "examples/reti/validatorRegistry.algo.ts:687", + "pc": [ + 2676, + 2677, + 2678 + ] + }, + { + "teal": 2342, + "source": "examples/reti/validatorRegistry.algo.ts:687", + "pc": [ + 2679, + 2680 + ] + }, + { + "teal": 2348, + "source": "examples/reti/validatorRegistry.algo.ts:689", + "pc": [ + 2681, + 2682 + ] + }, + { + "teal": 2349, + "source": "examples/reti/validatorRegistry.algo.ts:689", + "pc": [ + 2683, + 2684 + ] + }, + { + "teal": 2350, + "source": "examples/reti/validatorRegistry.algo.ts:689", + "pc": [ + 2685, + 2686 + ] + }, + { + "teal": 2351, + "source": "examples/reti/validatorRegistry.algo.ts:689", + "pc": [ + 2687, + 2688, + 2689 + ] + }, + { + "teal": 2352, + "source": "examples/reti/validatorRegistry.algo.ts:689", + "pc": [ + 2690 + ] + }, + { + "teal": 2353, + "source": "examples/reti/validatorRegistry.algo.ts:689", + "pc": [ + 2691, + 2692 + ] + }, + { + "teal": 2357, + "source": "examples/reti/validatorRegistry.algo.ts:690", + "pc": [ + 2693, + 2694 + ] + }, + { + "teal": 2358, + "source": "examples/reti/validatorRegistry.algo.ts:690", + "pc": [ + 2695, + 2696 + ] + }, + { + "teal": 2359, + "source": "examples/reti/validatorRegistry.algo.ts:690", + "pc": [ + 2697, + 2698 + ] + }, + { + "teal": 2360, + "source": "examples/reti/validatorRegistry.algo.ts:690", + "pc": [ + 2699, + 2700, + 2701 + ] + }, + { + "teal": 2361, + "source": "examples/reti/validatorRegistry.algo.ts:690", + "pc": [ + 2702 + ] + }, + { + "teal": 2362, + "source": "examples/reti/validatorRegistry.algo.ts:690", + "pc": [ + 2703, + 2704 + ] + }, + { + "teal": 2367, + "source": "examples/reti/validatorRegistry.algo.ts:691", + "pc": [ + 2705, + 2706 + ] + }, + { + "teal": 2368, + "source": "examples/reti/validatorRegistry.algo.ts:691", + "pc": [ + 2707, + 2708 + ] + }, + { + "teal": 2369, + "source": "examples/reti/validatorRegistry.algo.ts:691", + "pc": [ + 2709, + 2710 + ] + }, + { + "teal": 2370, + "source": "examples/reti/validatorRegistry.algo.ts:691", + "pc": [ + 2711, + 2712, + 2713 + ] + }, + { + "teal": 2371, + "source": "examples/reti/validatorRegistry.algo.ts:691", + "pc": [ + 2714 + ] + }, + { + "teal": 2372, + "source": "examples/reti/validatorRegistry.algo.ts:691", + "pc": [ + 2715, + 2716 + ] + }, + { + "teal": 2373, + "source": "examples/reti/validatorRegistry.algo.ts:691", + "pc": [ + 2717 + ] + }, + { + "teal": 2374, + "source": "examples/reti/validatorRegistry.algo.ts:691", + "pc": [ + 2718, + 2719, + 2720 + ] + }, + { + "teal": 2378, + "source": "examples/reti/validatorRegistry.algo.ts:692", + "errorMessage": "No pool available with free stake. Validator needs to add another pool", + "pc": [ + 2721 + ] + }, + { + "teal": 2383, + "source": "examples/reti/validatorRegistry.algo.ts:696", + "pc": [ + 2722, + 2723 + ] + }, + { + "teal": 2384, + "source": "examples/reti/validatorRegistry.algo.ts:696", + "pc": [ + 2724, + 2725 + ] + }, + { + "teal": 2385, + "source": "examples/reti/validatorRegistry.algo.ts:696", + "pc": [ + 2726, + 2727 + ] + }, + { + "teal": 2386, + "source": "examples/reti/validatorRegistry.algo.ts:696", + "pc": [ + 2728, + 2729, + 2730 + ] + }, + { + "teal": 2387, + "source": "examples/reti/validatorRegistry.algo.ts:696", + "pc": [ + 2731, + 2732 + ] + }, + { + "teal": 2388, + "source": "examples/reti/validatorRegistry.algo.ts:696", + "pc": [ + 2733, + 2734, + 2735 + ] + }, + { + "teal": 2398, + "source": "examples/reti/validatorRegistry.algo.ts:704", + "pc": [ + 2736, + 2737 + ] + }, + { + "teal": 2399, + "source": "examples/reti/validatorRegistry.algo.ts:703", + "pc": [ + 2738, + 2739 + ] + }, + { + "teal": 2400, + "source": "examples/reti/validatorRegistry.algo.ts:702", + "pc": [ + 2740, + 2741 + ] + }, + { + "teal": 2401, + "source": "examples/reti/validatorRegistry.algo.ts:701", + "pc": [ + 2742, + 2743 + ] + }, + { + "teal": 2402, + "source": "examples/reti/validatorRegistry.algo.ts:701", + "pc": [ + 2744, + 2745 + ] + }, + { + "teal": 2403, + "source": "examples/reti/validatorRegistry.algo.ts:701", + "pc": [ + 2746, + 2747 + ] + }, + { + "teal": 2404, + "source": "examples/reti/validatorRegistry.algo.ts:701", + "pc": [ + 2748, + 2749, + 2750 + ] + }, + { + "teal": 2405, + "source": "examples/reti/validatorRegistry.algo.ts:700", + "pc": [ + 2751, + 2752 + ] + }, + { + "teal": 2406, + "source": "examples/reti/validatorRegistry.algo.ts:699", + "pc": [ + 2753, + 2754, + 2755 + ] + }, + { + "teal": 2410, + "source": "examples/reti/validatorRegistry.algo.ts:714", + "pc": [ + 2756, + 2757 + ] + }, + { + "teal": 2411, + "source": "examples/reti/validatorRegistry.algo.ts:714", + "pc": [ + 2758, + 2759 + ] + }, + { + "teal": 2412, + "source": "examples/reti/validatorRegistry.algo.ts:714", + "pc": [ + 2760, + 2761 + ] + }, + { + "teal": 2413, + "source": "examples/reti/validatorRegistry.algo.ts:714", + "pc": [ + 2762, + 2763, + 2764 + ] + }, + { + "teal": 2416, + "source": "examples/reti/validatorRegistry.algo.ts:644", + "pc": [ + 2765, + 2766 + ] + }, + { + "teal": 2419, + "source": "examples/reti/validatorRegistry.algo.ts:644", + "pc": [ + 2767, + 2768 + ] + }, + { + "teal": 2420, + "source": "examples/reti/validatorRegistry.algo.ts:644", + "pc": [ + 2769 + ] + }, + { + "teal": 2425, + "source": "examples/reti/validatorRegistry.algo.ts:732", + "pc": [ + 2770, + 2771, + 2772, + 2773, + 2774, + 2775 + ] + }, + { + "teal": 2428, + "source": "examples/reti/validatorRegistry.algo.ts:732", + "pc": [ + 2776, + 2777, + 2778 + ] + }, + { + "teal": 2429, + "source": "examples/reti/validatorRegistry.algo.ts:732", + "pc": [ + 2779 + ] + }, + { + "teal": 2432, + "source": "examples/reti/validatorRegistry.algo.ts:732", + "pc": [ + 2780, + 2781, + 2782 + ] + }, + { + "teal": 2433, + "source": "examples/reti/validatorRegistry.algo.ts:732", + "pc": [ + 2783 + ] + }, + { + "teal": 2434, + "source": "examples/reti/validatorRegistry.algo.ts:732", + "pc": [ + 2784 + ] + }, + { + "teal": 2435, + "source": "examples/reti/validatorRegistry.algo.ts:732", + "pc": [ + 2785, + 2786 + ] + }, + { + "teal": 2436, + "source": "examples/reti/validatorRegistry.algo.ts:732", + "pc": [ + 2787 + ] + }, + { + "teal": 2454, + "source": "examples/reti/validatorRegistry.algo.ts:732", + "pc": [ + 2788, + 2789, + 2790 + ] + }, + { + "teal": 2457, + "source": "examples/reti/validatorRegistry.algo.ts:732", + "pc": [ + 2791, + 2792 + ] + }, + { + "teal": 2458, + "source": "examples/reti/validatorRegistry.algo.ts:732", + "pc": [ + 2793, + 2794 + ] + }, + { + "teal": 2462, + "source": "examples/reti/validatorRegistry.algo.ts:734", + "pc": [ + 2795, + 2796, + 2797 + ] + }, + { + "teal": 2463, + "source": "examples/reti/validatorRegistry.algo.ts:734", + "pc": [ + 2798, + 2799 + ] + }, + { + "teal": 2464, + "source": "examples/reti/validatorRegistry.algo.ts:734", + "pc": [ + 2800, + 2801, + 2802 + ] + }, + { + "teal": 2465, + "source": "examples/reti/validatorRegistry.algo.ts:734", + "pc": [ + 2803, + 2804 + ] + }, + { + "teal": 2466, + "source": "examples/reti/validatorRegistry.algo.ts:734", + "pc": [ + 2805 + ] + }, + { + "teal": 2467, + "source": "examples/reti/validatorRegistry.algo.ts:734", + "pc": [ + 2806 + ] + }, + { + "teal": 2468, + "source": "examples/reti/validatorRegistry.algo.ts:734", + "pc": [ + 2807, + 2808 + ] + }, + { + "teal": 2469, + "source": "examples/reti/validatorRegistry.algo.ts:734", + "pc": [ + 2809 + ] + }, + { + "teal": 2470, + "source": "examples/reti/validatorRegistry.algo.ts:734", + "pc": [ + 2810 + ] + }, + { + "teal": 2471, + "source": "examples/reti/validatorRegistry.algo.ts:734", + "pc": [ + 2811, + 2812 + ] + }, + { + "teal": 2475, + "source": "examples/reti/validatorRegistry.algo.ts:735", + "pc": [ + 2813, + 2814 + ] + }, + { + "teal": 2476, + "source": "examples/reti/validatorRegistry.algo.ts:735", + "pc": [ + 2815, + 2816 + ] + }, + { + "teal": 2477, + "source": "examples/reti/validatorRegistry.algo.ts:735", + "pc": [ + 2817 + ] + }, + { + "teal": 2478, + "source": "examples/reti/validatorRegistry.algo.ts:735", + "pc": [ + 2818 + ] + }, + { + "teal": 2483, + "source": "examples/reti/validatorRegistry.algo.ts:737", + "pc": [ + 2819, + 2820 + ] + }, + { + "teal": 2484, + "source": "examples/reti/validatorRegistry.algo.ts:737", + "pc": [ + 2821, + 2822 + ] + }, + { + "teal": 2485, + "source": "examples/reti/validatorRegistry.algo.ts:737", + "pc": [ + 2823, + 2824 + ] + }, + { + "teal": 2486, + "source": "examples/reti/validatorRegistry.algo.ts:737", + "pc": [ + 2825 + ] + }, + { + "teal": 2487, + "source": "examples/reti/validatorRegistry.algo.ts:737", + "pc": [ + 2826 + ] + }, + { + "teal": 2488, + "source": "examples/reti/validatorRegistry.algo.ts:737", + "pc": [ + 2827, + 2828, + 2829 + ] + }, + { + "teal": 2493, + "source": "examples/reti/validatorRegistry.algo.ts:738", + "pc": [ + 2830, + 2831, + 2832 + ] + }, + { + "teal": 2494, + "source": "examples/reti/validatorRegistry.algo.ts:738", + "pc": [ + 2833, + 2834, + 2835 + ] + }, + { + "teal": 2495, + "source": "examples/reti/validatorRegistry.algo.ts:738", + "pc": [ + 2836, + 2837, + 2838 + ] + }, + { + "teal": 2496, + "source": "examples/reti/validatorRegistry.algo.ts:738", + "pc": [ + 2839, + 2840 + ] + }, + { + "teal": 2497, + "source": "examples/reti/validatorRegistry.algo.ts:738", + "pc": [ + 2841 + ] + }, + { + "teal": 2498, + "source": "examples/reti/validatorRegistry.algo.ts:738", + "pc": [ + 2842 + ] + }, + { + "teal": 2499, + "source": "examples/reti/validatorRegistry.algo.ts:738", + "pc": [ + 2843, + 2844 + ] + }, + { + "teal": 2500, + "source": "examples/reti/validatorRegistry.algo.ts:738", + "pc": [ + 2845 + ] + }, + { + "teal": 2501, + "source": "examples/reti/validatorRegistry.algo.ts:738", + "pc": [ + 2846, + 2847, + 2848 + ] + }, + { + "teal": 2506, + "source": "examples/reti/validatorRegistry.algo.ts:744", + "pc": [ + 2849, + 2850 + ] + }, + { + "teal": 2507, + "source": "examples/reti/validatorRegistry.algo.ts:744", + "pc": [ + 2851, + 2852 + ] + }, + { + "teal": 2511, + "source": "examples/reti/validatorRegistry.algo.ts:745", + "pc": [ + 2853, + 2854, + 2855 + ] + }, + { + "teal": 2512, + "source": "examples/reti/validatorRegistry.algo.ts:745", + "pc": [ + 2856, + 2857 + ] + }, + { + "teal": 2513, + "source": "examples/reti/validatorRegistry.algo.ts:745", + "pc": [ + 2858, + 2859, + 2860 + ] + }, + { + "teal": 2514, + "source": "examples/reti/validatorRegistry.algo.ts:745", + "pc": [ + 2861, + 2862 + ] + }, + { + "teal": 2515, + "source": "examples/reti/validatorRegistry.algo.ts:745", + "pc": [ + 2863 + ] + }, + { + "teal": 2516, + "source": "examples/reti/validatorRegistry.algo.ts:745", + "pc": [ + 2864 + ] + }, + { + "teal": 2517, + "source": "examples/reti/validatorRegistry.algo.ts:745", + "pc": [ + 2865, + 2866 + ] + }, + { + "teal": 2518, + "source": "examples/reti/validatorRegistry.algo.ts:745", + "pc": [ + 2867 + ] + }, + { + "teal": 2519, + "source": "examples/reti/validatorRegistry.algo.ts:745", + "pc": [ + 2868 + ] + }, + { + "teal": 2520, + "source": "examples/reti/validatorRegistry.algo.ts:745", + "pc": [ + 2869, + 2870 + ] + }, + { + "teal": 2525, + "source": "examples/reti/validatorRegistry.algo.ts:746", + "pc": [ + 2871, + 2872 + ] + }, + { + "teal": 2526, + "source": "examples/reti/validatorRegistry.algo.ts:746", + "pc": [ + 2873, + 2874 + ] + }, + { + "teal": 2527, + "source": "examples/reti/validatorRegistry.algo.ts:746", + "pc": [ + 2875 + ] + }, + { + "teal": 2528, + "source": "examples/reti/validatorRegistry.algo.ts:746", + "pc": [ + 2876, + 2877, + 2878 + ] + }, + { + "teal": 2534, + "source": "examples/reti/validatorRegistry.algo.ts:748", + "pc": [ + 2879, + 2880 + ] + }, + { + "teal": 2535, + "source": "examples/reti/validatorRegistry.algo.ts:748", + "pc": [ + 2881, + 2882, + 2883, + 2884, + 2885, + 2886, + 2887, + 2888, + 2889, + 2890, + 2891, + 2892 + ] + }, + { + "teal": 2536, + "source": "examples/reti/validatorRegistry.algo.ts:748", + "pc": [ + 2893 + ] + }, + { + "teal": 2539, + "source": "examples/reti/validatorRegistry.algo.ts:748", + "errorMessage": "global state value does not exist: AppID.fromUint64(pool1AppID).globalState('lastPayout')", + "pc": [ + 2894 + ] + }, + { + "teal": 2540, + "source": "examples/reti/validatorRegistry.algo.ts:748", + "pc": [ + 2895, + 2896 + ] + }, + { + "teal": 2541, + "source": "examples/reti/validatorRegistry.algo.ts:748", + "pc": [ + 2897 + ] + }, + { + "teal": 2542, + "source": "examples/reti/validatorRegistry.algo.ts:748", + "pc": [ + 2898, + 2899, + 2900 + ] + }, + { + "teal": 2547, + "source": "examples/reti/validatorRegistry.algo.ts:749", + "pc": [ + 2901, + 2902, + 2903 + ] + }, + { + "teal": 2548, + "source": "examples/reti/validatorRegistry.algo.ts:749", + "pc": [ + 2904, + 2905, + 2906 + ] + }, + { + "teal": 2549, + "source": "examples/reti/validatorRegistry.algo.ts:749", + "pc": [ + 2907, + 2908, + 2909 + ] + }, + { + "teal": 2550, + "source": "examples/reti/validatorRegistry.algo.ts:749", + "pc": [ + 2910, + 2911 + ] + }, + { + "teal": 2551, + "source": "examples/reti/validatorRegistry.algo.ts:749", + "pc": [ + 2912 + ] + }, + { + "teal": 2552, + "source": "examples/reti/validatorRegistry.algo.ts:749", + "pc": [ + 2913 + ] + }, + { + "teal": 2553, + "source": "examples/reti/validatorRegistry.algo.ts:749", + "pc": [ + 2914, + 2915 + ] + }, + { + "teal": 2554, + "source": "examples/reti/validatorRegistry.algo.ts:749", + "pc": [ + 2916 + ] + }, + { + "teal": 2555, + "source": "examples/reti/validatorRegistry.algo.ts:749", + "pc": [ + 2917, + 2918, + 2919 + ] + }, + { + "teal": 2560, + "source": "examples/reti/validatorRegistry.algo.ts:751", + "pc": [ + 2920, + 2921, + 2922 + ] + }, + { + "teal": 2561, + "source": "examples/reti/validatorRegistry.algo.ts:751", + "pc": [ + 2923, + 2924 + ] + }, + { + "teal": 2562, + "source": "examples/reti/validatorRegistry.algo.ts:751", + "pc": [ + 2925, + 2926, + 2927 + ] + }, + { + "teal": 2563, + "source": "examples/reti/validatorRegistry.algo.ts:751", + "pc": [ + 2928, + 2929 + ] + }, + { + "teal": 2564, + "source": "examples/reti/validatorRegistry.algo.ts:751", + "pc": [ + 2930 + ] + }, + { + "teal": 2565, + "source": "examples/reti/validatorRegistry.algo.ts:751", + "pc": [ + 2931 + ] + }, + { + "teal": 2566, + "source": "examples/reti/validatorRegistry.algo.ts:751", + "pc": [ + 2932, + 2933 + ] + }, + { + "teal": 2567, + "source": "examples/reti/validatorRegistry.algo.ts:751", + "pc": [ + 2934 + ] + }, + { + "teal": 2568, + "source": "examples/reti/validatorRegistry.algo.ts:751", + "pc": [ + 2935 + ] + }, + { + "teal": 2569, + "source": "examples/reti/validatorRegistry.algo.ts:751", + "pc": [ + 2936, + 2937 + ] + }, + { + "teal": 2573, + "source": "examples/reti/validatorRegistry.algo.ts:752", + "pc": [ + 2938, + 2939 + ] + }, + { + "teal": 2574, + "source": "examples/reti/validatorRegistry.algo.ts:752", + "pc": [ + 2940, + 2941 + ] + }, + { + "teal": 2575, + "source": "examples/reti/validatorRegistry.algo.ts:752", + "pc": [ + 2942, + 2943 + ] + }, + { + "teal": 2576, + "source": "examples/reti/validatorRegistry.algo.ts:752", + "pc": [ + 2944 + ] + }, + { + "teal": 2577, + "source": "examples/reti/validatorRegistry.algo.ts:752", + "pc": [ + 2945 + ] + }, + { + "teal": 2578, + "source": "examples/reti/validatorRegistry.algo.ts:752", + "pc": [ + 2946, + 2947 + ] + }, + { + "teal": 2583, + "source": "examples/reti/validatorRegistry.algo.ts:754", + "pc": [ + 2948, + 2949 + ] + }, + { + "teal": 2584, + "source": "examples/reti/validatorRegistry.algo.ts:754", + "pc": [ + 2950, + 2951 + ] + }, + { + "teal": 2585, + "source": "examples/reti/validatorRegistry.algo.ts:754", + "pc": [ + 2952, + 2953 + ] + }, + { + "teal": 2586, + "source": "examples/reti/validatorRegistry.algo.ts:754", + "pc": [ + 2954 + ] + }, + { + "teal": 2587, + "source": "examples/reti/validatorRegistry.algo.ts:754", + "pc": [ + 2955 + ] + }, + { + "teal": 2588, + "source": "examples/reti/validatorRegistry.algo.ts:754", + "pc": [ + 2956, + 2957 + ] + }, + { + "teal": 2589, + "source": "examples/reti/validatorRegistry.algo.ts:754", + "pc": [ + 2958 + ] + }, + { + "teal": 2590, + "source": "examples/reti/validatorRegistry.algo.ts:754", + "pc": [ + 2959, + 2960, + 2961 + ] + }, + { + "teal": 2595, + "source": "examples/reti/validatorRegistry.algo.ts:755", + "pc": [ + 2962, + 2963, + 2964 + ] + }, + { + "teal": 2596, + "source": "examples/reti/validatorRegistry.algo.ts:755", + "pc": [ + 2965, + 2966, + 2967 + ] + }, + { + "teal": 2597, + "source": "examples/reti/validatorRegistry.algo.ts:755", + "pc": [ + 2968, + 2969, + 2970 + ] + }, + { + "teal": 2598, + "source": "examples/reti/validatorRegistry.algo.ts:755", + "pc": [ + 2971, + 2972 + ] + }, + { + "teal": 2599, + "source": "examples/reti/validatorRegistry.algo.ts:755", + "pc": [ + 2973 + ] + }, + { + "teal": 2600, + "source": "examples/reti/validatorRegistry.algo.ts:755", + "pc": [ + 2974 + ] + }, + { + "teal": 2601, + "source": "examples/reti/validatorRegistry.algo.ts:755", + "pc": [ + 2975, + 2976 + ] + }, + { + "teal": 2602, + "source": "examples/reti/validatorRegistry.algo.ts:755", + "pc": [ + 2977 + ] + }, + { + "teal": 2603, + "source": "examples/reti/validatorRegistry.algo.ts:755", + "pc": [ + 2978, + 2979, + 2980 + ] + }, + { + "teal": 2610, + "source": "examples/reti/validatorRegistry.algo.ts:758", + "pc": [ + 2981, + 2982, + 2983 + ] + }, + { + "teal": 2611, + "source": "examples/reti/validatorRegistry.algo.ts:758", + "pc": [ + 2984, + 2985 + ] + }, + { + "teal": 2612, + "source": "examples/reti/validatorRegistry.algo.ts:758", + "pc": [ + 2986 + ] + }, + { + "teal": 2613, + "source": "examples/reti/validatorRegistry.algo.ts:758", + "pc": [ + 2987, + 2988, + 2989 + ] + }, + { + "teal": 2614, + "source": "examples/reti/validatorRegistry.algo.ts:758", + "pc": [ + 2990, + 2991 + ] + }, + { + "teal": 2615, + "source": "examples/reti/validatorRegistry.algo.ts:758", + "pc": [ + 2992 + ] + }, + { + "teal": 2616, + "source": "examples/reti/validatorRegistry.algo.ts:758", + "pc": [ + 2993 + ] + }, + { + "teal": 2617, + "source": "examples/reti/validatorRegistry.algo.ts:758", + "pc": [ + 2994, + 2995 + ] + }, + { + "teal": 2618, + "source": "examples/reti/validatorRegistry.algo.ts:758", + "pc": [ + 2996 + ] + }, + { + "teal": 2622, + "source": "examples/reti/validatorRegistry.algo.ts:760", + "pc": [ + 2997, + 2998, + 2999 + ] + }, + { + "teal": 2623, + "source": "examples/reti/validatorRegistry.algo.ts:760", + "pc": [ + 3000, + 3001 + ] + }, + { + "teal": 2624, + "source": "examples/reti/validatorRegistry.algo.ts:760", + "pc": [ + 3002, + 3003, + 3004 + ] + }, + { + "teal": 2625, + "source": "examples/reti/validatorRegistry.algo.ts:760", + "pc": [ + 3005, + 3006 + ] + }, + { + "teal": 2626, + "source": "examples/reti/validatorRegistry.algo.ts:760", + "pc": [ + 3007 + ] + }, + { + "teal": 2627, + "source": "examples/reti/validatorRegistry.algo.ts:760", + "pc": [ + 3008 + ] + }, + { + "teal": 2628, + "source": "examples/reti/validatorRegistry.algo.ts:760", + "pc": [ + 3009, + 3010 + ] + }, + { + "teal": 2629, + "source": "examples/reti/validatorRegistry.algo.ts:760", + "pc": [ + 3011 + ] + }, + { + "teal": 2630, + "source": "examples/reti/validatorRegistry.algo.ts:760", + "pc": [ + 3012 + ] + }, + { + "teal": 2631, + "source": "examples/reti/validatorRegistry.algo.ts:760", + "pc": [ + 3013, + 3014 + ] + }, + { + "teal": 2635, + "source": "examples/reti/validatorRegistry.algo.ts:761", + "pc": [ + 3015, + 3016, + 3017 + ] + }, + { + "teal": 2636, + "source": "examples/reti/validatorRegistry.algo.ts:761", + "pc": [ + 3018, + 3019 + ] + }, + { + "teal": 2637, + "source": "examples/reti/validatorRegistry.algo.ts:761", + "pc": [ + 3020, + 3021, + 3022 + ] + }, + { + "teal": 2638, + "source": "examples/reti/validatorRegistry.algo.ts:761", + "pc": [ + 3023, + 3024 + ] + }, + { + "teal": 2639, + "source": "examples/reti/validatorRegistry.algo.ts:761", + "pc": [ + 3025 + ] + }, + { + "teal": 2640, + "source": "examples/reti/validatorRegistry.algo.ts:761", + "pc": [ + 3026 + ] + }, + { + "teal": 2641, + "source": "examples/reti/validatorRegistry.algo.ts:761", + "pc": [ + 3027, + 3028 + ] + }, + { + "teal": 2642, + "source": "examples/reti/validatorRegistry.algo.ts:761", + "pc": [ + 3029 + ] + }, + { + "teal": 2643, + "source": "examples/reti/validatorRegistry.algo.ts:761", + "pc": [ + 3030 + ] + }, + { + "teal": 2644, + "source": "examples/reti/validatorRegistry.algo.ts:761", + "pc": [ + 3031, + 3032 + ] + }, + { + "teal": 2648, + "source": "examples/reti/validatorRegistry.algo.ts:762", + "pc": [ + 3033, + 3034 + ] + }, + { + "teal": 2649, + "source": "examples/reti/validatorRegistry.algo.ts:762", + "pc": [ + 3035, + 3036 + ] + }, + { + "teal": 2654, + "source": "examples/reti/validatorRegistry.algo.ts:762", + "pc": [ + 3037, + 3038 + ] + }, + { + "teal": 2655, + "source": "examples/reti/validatorRegistry.algo.ts:762", + "pc": [ + 3039, + 3040 + ] + }, + { + "teal": 2656, + "source": "examples/reti/validatorRegistry.algo.ts:762", + "pc": [ + 3041 + ] + }, + { + "teal": 2657, + "source": "examples/reti/validatorRegistry.algo.ts:762", + "pc": [ + 3042, + 3043, + 3044 + ] + }, + { + "teal": 2664, + "source": "examples/reti/validatorRegistry.algo.ts:768", + "pc": [ + 3045, + 3046, + 3047 + ] + }, + { + "teal": 2665, + "source": "examples/reti/validatorRegistry.algo.ts:768", + "pc": [ + 3048, + 3049 + ] + }, + { + "teal": 2666, + "source": "examples/reti/validatorRegistry.algo.ts:768", + "pc": [ + 3050, + 3051 + ] + }, + { + "teal": 2667, + "source": "examples/reti/validatorRegistry.algo.ts:768", + "pc": [ + 3052 + ] + }, + { + "teal": 2668, + "source": "examples/reti/validatorRegistry.algo.ts:768", + "pc": [ + 3053 + ] + }, + { + "teal": 2669, + "source": "examples/reti/validatorRegistry.algo.ts:768", + "pc": [ + 3054, + 3055 + ] + }, + { + "teal": 2670, + "source": "examples/reti/validatorRegistry.algo.ts:768", + "pc": [ + 3056 + ] + }, + { + "teal": 2671, + "source": "examples/reti/validatorRegistry.algo.ts:768", + "pc": [ + 3057, + 3058 + ] + }, + { + "teal": 2672, + "source": "examples/reti/validatorRegistry.algo.ts:768", + "pc": [ + 3059, + 3060, + 3061 + ] + }, + { + "teal": 2673, + "source": "examples/reti/validatorRegistry.algo.ts:768", + "pc": [ + 3062, + 3063 + ] + }, + { + "teal": 2674, + "source": "examples/reti/validatorRegistry.algo.ts:768", + "pc": [ + 3064 + ] + }, + { + "teal": 2675, + "source": "examples/reti/validatorRegistry.algo.ts:768", + "pc": [ + 3065 + ] + }, + { + "teal": 2676, + "source": "examples/reti/validatorRegistry.algo.ts:768", + "pc": [ + 3066, + 3067 + ] + }, + { + "teal": 2677, + "source": "examples/reti/validatorRegistry.algo.ts:768", + "pc": [ + 3068 + ] + }, + { + "teal": 2678, + "source": "examples/reti/validatorRegistry.algo.ts:768", + "pc": [ + 3069 + ] + }, + { + "teal": 2679, + "source": "examples/reti/validatorRegistry.algo.ts:768", + "pc": [ + 3070, + 3071, + 3072, + 3073 + ] + }, + { + "teal": 2680, + "source": "examples/reti/validatorRegistry.algo.ts:767", + "pc": [ + 3074 + ] + }, + { + "teal": 2681, + "source": "examples/reti/validatorRegistry.algo.ts:767", + "pc": [ + 3075, + 3076 + ] + }, + { + "teal": 2682, + "source": "examples/reti/validatorRegistry.algo.ts:769", + "pc": [ + 3077, + 3078 + ] + }, + { + "teal": 2683, + "source": "examples/reti/validatorRegistry.algo.ts:767", + "pc": [ + 3079 + ] + }, + { + "teal": 2684, + "source": "examples/reti/validatorRegistry.algo.ts:767", + "pc": [ + 3080 + ] + }, + { + "teal": 2685, + "source": "examples/reti/validatorRegistry.algo.ts:767", + "pc": [ + 3081 + ] + }, + { + "teal": 2686, + "source": "examples/reti/validatorRegistry.algo.ts:767", + "pc": [ + 3082 + ] + }, + { + "teal": 2687, + "source": "examples/reti/validatorRegistry.algo.ts:767", + "pc": [ + 3083 + ] + }, + { + "teal": 2690, + "source": "examples/reti/validatorRegistry.algo.ts:767", + "errorMessage": "wideRatio failed", + "pc": [ + 3084 + ] + }, + { + "teal": 2691, + "source": "examples/reti/validatorRegistry.algo.ts:767", + "pc": [ + 3085, + 3086 + ] + }, + { + "teal": 2695, + "source": "examples/reti/validatorRegistry.algo.ts:771", + "pc": [ + 3087, + 3088, + 3089 + ] + }, + { + "teal": 2696, + "source": "examples/reti/validatorRegistry.algo.ts:771", + "pc": [ + 3090, + 3091 + ] + }, + { + "teal": 2697, + "source": "examples/reti/validatorRegistry.algo.ts:771", + "pc": [ + 3092, + 3093 + ] + }, + { + "teal": 2698, + "source": "examples/reti/validatorRegistry.algo.ts:771", + "pc": [ + 3094 + ] + }, + { + "teal": 2699, + "source": "examples/reti/validatorRegistry.algo.ts:771", + "pc": [ + 3095 + ] + }, + { + "teal": 2700, + "source": "examples/reti/validatorRegistry.algo.ts:771", + "pc": [ + 3096, + 3097 + ] + }, + { + "teal": 2701, + "source": "examples/reti/validatorRegistry.algo.ts:771", + "pc": [ + 3098 + ] + }, + { + "teal": 2702, + "source": "examples/reti/validatorRegistry.algo.ts:771", + "pc": [ + 3099, + 3100, + 3101 + ] + }, + { + "teal": 2703, + "source": "examples/reti/validatorRegistry.algo.ts:771", + "pc": [ + 3102, + 3103 + ] + }, + { + "teal": 2704, + "source": "examples/reti/validatorRegistry.algo.ts:771", + "pc": [ + 3104 + ] + }, + { + "teal": 2705, + "source": "examples/reti/validatorRegistry.algo.ts:771", + "pc": [ + 3105 + ] + }, + { + "teal": 2706, + "source": "examples/reti/validatorRegistry.algo.ts:771", + "pc": [ + 3106, + 3107 + ] + }, + { + "teal": 2707, + "source": "examples/reti/validatorRegistry.algo.ts:771", + "pc": [ + 3108 + ] + }, + { + "teal": 2712, + "source": "examples/reti/validatorRegistry.algo.ts:762", + "pc": [ + 3109, + 3110 + ] + }, + { + "teal": 2713, + "source": "examples/reti/validatorRegistry.algo.ts:762", + "pc": [ + 3111, + 3112 + ] + }, + { + "teal": 2714, + "source": "examples/reti/validatorRegistry.algo.ts:762", + "pc": [ + 3113 + ] + }, + { + "teal": 2715, + "source": "examples/reti/validatorRegistry.algo.ts:762", + "pc": [ + 3114, + 3115 + ] + }, + { + "teal": 2716, + "source": "examples/reti/validatorRegistry.algo.ts:762", + "pc": [ + 3116, + 3117, + 3118 + ] + }, + { + "teal": 2721, + "source": "examples/reti/validatorRegistry.algo.ts:773", + "pc": [ + 3119, + 3120, + 3121 + ] + }, + { + "teal": 2722, + "source": "examples/reti/validatorRegistry.algo.ts:773", + "pc": [ + 3122, + 3123, + 3124 + ] + }, + { + "teal": 2723, + "source": "examples/reti/validatorRegistry.algo.ts:773", + "pc": [ + 3125, + 3126, + 3127 + ] + }, + { + "teal": 2724, + "source": "examples/reti/validatorRegistry.algo.ts:773", + "pc": [ + 3128, + 3129 + ] + }, + { + "teal": 2725, + "source": "examples/reti/validatorRegistry.algo.ts:773", + "pc": [ + 3130 + ] + }, + { + "teal": 2726, + "source": "examples/reti/validatorRegistry.algo.ts:773", + "pc": [ + 3131 + ] + }, + { + "teal": 2727, + "source": "examples/reti/validatorRegistry.algo.ts:773", + "pc": [ + 3132, + 3133 + ] + }, + { + "teal": 2728, + "source": "examples/reti/validatorRegistry.algo.ts:773", + "pc": [ + 3134 + ] + }, + { + "teal": 2732, + "source": "examples/reti/validatorRegistry.algo.ts:732", + "pc": [ + 3135, + 3136 + ] + }, + { + "teal": 2735, + "source": "examples/reti/validatorRegistry.algo.ts:732", + "pc": [ + 3137, + 3138 + ] + }, + { + "teal": 2736, + "source": "examples/reti/validatorRegistry.algo.ts:732", + "pc": [ + 3139 + ] + }, + { + "teal": 2741, + "source": "examples/reti/validatorRegistry.algo.ts:792", + "pc": [ + 3140, + 3141, + 3142 + ] + }, + { + "teal": 2742, + "source": "examples/reti/validatorRegistry.algo.ts:792", + "pc": [ + 3143 + ] + }, + { + "teal": 2745, + "source": "examples/reti/validatorRegistry.algo.ts:791", + "pc": [ + 3144, + 3145, + 3146 + ] + }, + { + "teal": 2746, + "source": "examples/reti/validatorRegistry.algo.ts:791", + "pc": [ + 3147 + ] + }, + { + "teal": 2749, + "source": "examples/reti/validatorRegistry.algo.ts:790", + "pc": [ + 3148, + 3149, + 3150 + ] + }, + { + "teal": 2750, + "source": "examples/reti/validatorRegistry.algo.ts:790", + "pc": [ + 3151 + ] + }, + { + "teal": 2753, + "source": "examples/reti/validatorRegistry.algo.ts:789", + "pc": [ + 3152, + 3153, + 3154 + ] + }, + { + "teal": 2754, + "source": "examples/reti/validatorRegistry.algo.ts:789", + "pc": [ + 3155 + ] + }, + { + "teal": 2757, + "source": "examples/reti/validatorRegistry.algo.ts:788", + "pc": [ + 3156, + 3157, + 3158 + ] + }, + { + "teal": 2758, + "source": "examples/reti/validatorRegistry.algo.ts:788", + "pc": [ + 3159 + ] + }, + { + "teal": 2759, + "source": "examples/reti/validatorRegistry.algo.ts:788", + "pc": [ + 3160 + ] + }, + { + "teal": 2760, + "source": "examples/reti/validatorRegistry.algo.ts:788", + "pc": [ + 3161, + 3162 + ] + }, + { + "teal": 2761, + "source": "examples/reti/validatorRegistry.algo.ts:788", + "pc": [ + 3163 + ] + }, + { + "teal": 2764, + "source": "examples/reti/validatorRegistry.algo.ts:788", + "errorMessage": "argument 4 (poolKey) for stakeUpdatedViaRewards must be a (uint64,uint64,uint64)", + "pc": [ + 3164 + ] + }, + { + "teal": 2767, + "source": "examples/reti/validatorRegistry.algo.ts:787", + "pc": [ + 3165, + 3166, + 3167 + ] + }, + { + "teal": 2768, + "source": "examples/reti/validatorRegistry.algo.ts:787", + "pc": [ + 3168, + 3169 + ] + }, + { + "teal": 2769, + "source": "examples/reti/validatorRegistry.algo.ts:787", + "pc": [ + 3170 + ] + }, + { + "teal": 2783, + "source": "examples/reti/validatorRegistry.algo.ts:787", + "pc": [ + 3171, + 3172, + 3173 + ] + }, + { + "teal": 2787, + "source": "examples/reti/validatorRegistry.algo.ts:794", + "pc": [ + 3174, + 3175 + ] + }, + { + "teal": 2788, + "source": "examples/reti/validatorRegistry.algo.ts:794", + "pc": [ + 3176, + 3177, + 3178 + ] + }, + { + "teal": 2792, + "source": "examples/reti/validatorRegistry.algo.ts:797", + "pc": [ + 3179, + 3180, + 3181 + ] + }, + { + "teal": 2793, + "source": "examples/reti/validatorRegistry.algo.ts:797", + "pc": [ + 3182, + 3183 + ] + }, + { + "teal": 2794, + "source": "examples/reti/validatorRegistry.algo.ts:797", + "pc": [ + 3184, + 3185, + 3186 + ] + }, + { + "teal": 2795, + "source": "examples/reti/validatorRegistry.algo.ts:797", + "pc": [ + 3187 + ] + }, + { + "teal": 2796, + "source": "examples/reti/validatorRegistry.algo.ts:797", + "pc": [ + 3188, + 3189 + ] + }, + { + "teal": 2797, + "source": "examples/reti/validatorRegistry.algo.ts:797", + "pc": [ + 3190 + ] + }, + { + "teal": 2798, + "source": "examples/reti/validatorRegistry.algo.ts:797", + "pc": [ + 3191, + 3192 + ] + }, + { + "teal": 2799, + "source": "examples/reti/validatorRegistry.algo.ts:797", + "pc": [ + 3193 + ] + }, + { + "teal": 2800, + "source": "examples/reti/validatorRegistry.algo.ts:797", + "pc": [ + 3194 + ] + }, + { + "teal": 2801, + "source": "examples/reti/validatorRegistry.algo.ts:797", + "pc": [ + 3195, + 3196 + ] + }, + { + "teal": 2802, + "source": "examples/reti/validatorRegistry.algo.ts:797", + "pc": [ + 3197 + ] + }, + { + "teal": 2803, + "source": "examples/reti/validatorRegistry.algo.ts:797", + "pc": [ + 3198, + 3199, + 3200 + ] + }, + { + "teal": 2804, + "source": "examples/reti/validatorRegistry.algo.ts:797", + "pc": [ + 3201, + 3202 + ] + }, + { + "teal": 2805, + "source": "examples/reti/validatorRegistry.algo.ts:797", + "pc": [ + 3203, + 3204, + 3205 + ] + }, + { + "teal": 2806, + "source": "examples/reti/validatorRegistry.algo.ts:797", + "pc": [ + 3206 + ] + }, + { + "teal": 2807, + "source": "examples/reti/validatorRegistry.algo.ts:797", + "pc": [ + 3207, + 3208 + ] + }, + { + "teal": 2808, + "source": "examples/reti/validatorRegistry.algo.ts:797", + "pc": [ + 3209 + ] + }, + { + "teal": 2809, + "source": "examples/reti/validatorRegistry.algo.ts:797", + "pc": [ + 3210, + 3211 + ] + }, + { + "teal": 2810, + "source": "examples/reti/validatorRegistry.algo.ts:797", + "pc": [ + 3212 + ] + }, + { + "teal": 2811, + "source": "examples/reti/validatorRegistry.algo.ts:797", + "pc": [ + 3213 + ] + }, + { + "teal": 2812, + "source": "examples/reti/validatorRegistry.algo.ts:797", + "pc": [ + 3214, + 3215 + ] + }, + { + "teal": 2813, + "source": "examples/reti/validatorRegistry.algo.ts:797", + "pc": [ + 3216 + ] + }, + { + "teal": 2814, + "source": "examples/reti/validatorRegistry.algo.ts:797", + "pc": [ + 3217, + 3218 + ] + }, + { + "teal": 2815, + "source": "examples/reti/validatorRegistry.algo.ts:797", + "pc": [ + 3219, + 3220, + 3221 + ] + }, + { + "teal": 2816, + "source": "examples/reti/validatorRegistry.algo.ts:797", + "pc": [ + 3222, + 3223 + ] + }, + { + "teal": 2817, + "source": "examples/reti/validatorRegistry.algo.ts:797", + "pc": [ + 3224, + 3225, + 3226 + ] + }, + { + "teal": 2818, + "source": "examples/reti/validatorRegistry.algo.ts:797", + "pc": [ + 3227 + ] + }, + { + "teal": 2819, + "source": "examples/reti/validatorRegistry.algo.ts:797", + "pc": [ + 3228 + ] + }, + { + "teal": 2820, + "source": "examples/reti/validatorRegistry.algo.ts:797", + "pc": [ + 3229 + ] + }, + { + "teal": 2821, + "source": "examples/reti/validatorRegistry.algo.ts:797", + "pc": [ + 3230, + 3231 + ] + }, + { + "teal": 2822, + "source": "examples/reti/validatorRegistry.algo.ts:797", + "pc": [ + 3232 + ] + }, + { + "teal": 2823, + "source": "examples/reti/validatorRegistry.algo.ts:797", + "pc": [ + 3233 + ] + }, + { + "teal": 2824, + "source": "examples/reti/validatorRegistry.algo.ts:797", + "pc": [ + 3234, + 3235 + ] + }, + { + "teal": 2825, + "source": "examples/reti/validatorRegistry.algo.ts:797", + "pc": [ + 3236 + ] + }, + { + "teal": 2826, + "source": "examples/reti/validatorRegistry.algo.ts:797", + "pc": [ + 3237 + ] + }, + { + "teal": 2827, + "source": "examples/reti/validatorRegistry.algo.ts:797", + "pc": [ + 3238, + 3239, + 3240 + ] + }, + { + "teal": 2828, + "source": "examples/reti/validatorRegistry.algo.ts:797", + "pc": [ + 3241, + 3242 + ] + }, + { + "teal": 2829, + "source": "examples/reti/validatorRegistry.algo.ts:797", + "pc": [ + 3243, + 3244, + 3245 + ] + }, + { + "teal": 2830, + "source": "examples/reti/validatorRegistry.algo.ts:797", + "pc": [ + 3246 + ] + }, + { + "teal": 2831, + "source": "examples/reti/validatorRegistry.algo.ts:797", + "pc": [ + 3247 + ] + }, + { + "teal": 2832, + "source": "examples/reti/validatorRegistry.algo.ts:797", + "pc": [ + 3248 + ] + }, + { + "teal": 2833, + "source": "examples/reti/validatorRegistry.algo.ts:797", + "pc": [ + 3249, + 3250 + ] + }, + { + "teal": 2834, + "source": "examples/reti/validatorRegistry.algo.ts:797", + "pc": [ + 3251 + ] + }, + { + "teal": 2838, + "source": "examples/reti/validatorRegistry.algo.ts:798", + "pc": [ + 3252, + 3253, + 3254 + ] + }, + { + "teal": 2839, + "source": "examples/reti/validatorRegistry.algo.ts:798", + "pc": [ + 3255 + ] + }, + { + "teal": 2840, + "source": "examples/reti/validatorRegistry.algo.ts:798", + "pc": [ + 3256, + 3257 + ] + }, + { + "teal": 2841, + "source": "examples/reti/validatorRegistry.algo.ts:798", + "pc": [ + 3258, + 3259, + 3260 + ] + }, + { + "teal": 2842, + "source": "examples/reti/validatorRegistry.algo.ts:798", + "pc": [ + 3261, + 3262 + ] + }, + { + "teal": 2843, + "source": "examples/reti/validatorRegistry.algo.ts:798", + "pc": [ + 3263, + 3264, + 3265 + ] + }, + { + "teal": 2844, + "source": "examples/reti/validatorRegistry.algo.ts:798", + "pc": [ + 3266 + ] + }, + { + "teal": 2845, + "source": "examples/reti/validatorRegistry.algo.ts:798", + "pc": [ + 3267 + ] + }, + { + "teal": 2846, + "source": "examples/reti/validatorRegistry.algo.ts:798", + "pc": [ + 3268 + ] + }, + { + "teal": 2847, + "source": "examples/reti/validatorRegistry.algo.ts:798", + "pc": [ + 3269, + 3270 + ] + }, + { + "teal": 2848, + "source": "examples/reti/validatorRegistry.algo.ts:798", + "pc": [ + 3271 + ] + }, + { + "teal": 2849, + "source": "examples/reti/validatorRegistry.algo.ts:798", + "pc": [ + 3272 + ] + }, + { + "teal": 2850, + "source": "examples/reti/validatorRegistry.algo.ts:798", + "pc": [ + 3273, + 3274 + ] + }, + { + "teal": 2851, + "source": "examples/reti/validatorRegistry.algo.ts:798", + "pc": [ + 3275 + ] + }, + { + "teal": 2852, + "source": "examples/reti/validatorRegistry.algo.ts:798", + "pc": [ + 3276 + ] + }, + { + "teal": 2853, + "source": "examples/reti/validatorRegistry.algo.ts:798", + "pc": [ + 3277, + 3278, + 3279 + ] + }, + { + "teal": 2854, + "source": "examples/reti/validatorRegistry.algo.ts:798", + "pc": [ + 3280, + 3281 + ] + }, + { + "teal": 2855, + "source": "examples/reti/validatorRegistry.algo.ts:798", + "pc": [ + 3282, + 3283, + 3284 + ] + }, + { + "teal": 2856, + "source": "examples/reti/validatorRegistry.algo.ts:798", + "pc": [ + 3285 + ] + }, + { + "teal": 2857, + "source": "examples/reti/validatorRegistry.algo.ts:798", + "pc": [ + 3286 + ] + }, + { + "teal": 2858, + "source": "examples/reti/validatorRegistry.algo.ts:798", + "pc": [ + 3287 + ] + }, + { + "teal": 2859, + "source": "examples/reti/validatorRegistry.algo.ts:798", + "pc": [ + 3288, + 3289 + ] + }, + { + "teal": 2860, + "source": "examples/reti/validatorRegistry.algo.ts:798", + "pc": [ + 3290 + ] + }, + { + "teal": 2864, + "source": "examples/reti/validatorRegistry.algo.ts:799", + "pc": [ + 3291, + 3292, + 3293 + ] + }, + { + "teal": 2865, + "source": "examples/reti/validatorRegistry.algo.ts:799", + "pc": [ + 3294 + ] + }, + { + "teal": 2866, + "source": "examples/reti/validatorRegistry.algo.ts:799", + "pc": [ + 3295, + 3296 + ] + }, + { + "teal": 2867, + "source": "examples/reti/validatorRegistry.algo.ts:799", + "pc": [ + 3297, + 3298, + 3299 + ] + }, + { + "teal": 2868, + "source": "examples/reti/validatorRegistry.algo.ts:799", + "pc": [ + 3300, + 3301 + ] + }, + { + "teal": 2869, + "source": "examples/reti/validatorRegistry.algo.ts:799", + "pc": [ + 3302, + 3303, + 3304 + ] + }, + { + "teal": 2870, + "source": "examples/reti/validatorRegistry.algo.ts:799", + "pc": [ + 3305 + ] + }, + { + "teal": 2871, + "source": "examples/reti/validatorRegistry.algo.ts:799", + "pc": [ + 3306 + ] + }, + { + "teal": 2872, + "source": "examples/reti/validatorRegistry.algo.ts:799", + "pc": [ + 3307 + ] + }, + { + "teal": 2873, + "source": "examples/reti/validatorRegistry.algo.ts:799", + "pc": [ + 3308, + 3309 + ] + }, + { + "teal": 2874, + "source": "examples/reti/validatorRegistry.algo.ts:799", + "pc": [ + 3310 + ] + }, + { + "teal": 2875, + "source": "examples/reti/validatorRegistry.algo.ts:799", + "pc": [ + 3311 + ] + }, + { + "teal": 2876, + "source": "examples/reti/validatorRegistry.algo.ts:799", + "pc": [ + 3312, + 3313 + ] + }, + { + "teal": 2877, + "source": "examples/reti/validatorRegistry.algo.ts:799", + "pc": [ + 3314 + ] + }, + { + "teal": 2878, + "source": "examples/reti/validatorRegistry.algo.ts:799", + "pc": [ + 3315 + ] + }, + { + "teal": 2879, + "source": "examples/reti/validatorRegistry.algo.ts:799", + "pc": [ + 3316, + 3317, + 3318 + ] + }, + { + "teal": 2880, + "source": "examples/reti/validatorRegistry.algo.ts:799", + "pc": [ + 3319, + 3320 + ] + }, + { + "teal": 2881, + "source": "examples/reti/validatorRegistry.algo.ts:799", + "pc": [ + 3321, + 3322, + 3323 + ] + }, + { + "teal": 2882, + "source": "examples/reti/validatorRegistry.algo.ts:799", + "pc": [ + 3324 + ] + }, + { + "teal": 2883, + "source": "examples/reti/validatorRegistry.algo.ts:799", + "pc": [ + 3325 + ] + }, + { + "teal": 2884, + "source": "examples/reti/validatorRegistry.algo.ts:799", + "pc": [ + 3326 + ] + }, + { + "teal": 2885, + "source": "examples/reti/validatorRegistry.algo.ts:799", + "pc": [ + 3327, + 3328 + ] + }, + { + "teal": 2886, + "source": "examples/reti/validatorRegistry.algo.ts:799", + "pc": [ + 3329 + ] + }, + { + "teal": 2890, + "source": "examples/reti/validatorRegistry.algo.ts:801", + "pc": [ + 3330, + 3331, + 3332, + 3333, + 3334, + 3335, + 3336, + 3337 + ] + }, + { + "teal": 2891, + "source": "examples/reti/validatorRegistry.algo.ts:801", + "pc": [ + 3338 + ] + }, + { + "teal": 2892, + "source": "examples/reti/validatorRegistry.algo.ts:801", + "pc": [ + 3339, + 3340 + ] + }, + { + "teal": 2893, + "source": "examples/reti/validatorRegistry.algo.ts:801", + "pc": [ + 3341 + ] + }, + { + "teal": 2894, + "source": "examples/reti/validatorRegistry.algo.ts:801", + "pc": [ + 3342, + 3343, + 3344, + 3345, + 3346, + 3347, + 3348, + 3349 + ] + }, + { + "teal": 2895, + "source": "examples/reti/validatorRegistry.algo.ts:801", + "pc": [ + 3350 + ] + }, + { + "teal": 2896, + "source": "examples/reti/validatorRegistry.algo.ts:801", + "pc": [ + 3351 + ] + }, + { + "teal": 2900, + "source": "examples/reti/validatorRegistry.algo.ts:804", + "pc": [ + 3352, + 3353 + ] + }, + { + "teal": 2901, + "source": "examples/reti/validatorRegistry.algo.ts:804", + "pc": [ + 3354, + 3355, + 3356 + ] + }, + { + "teal": 2902, + "source": "examples/reti/validatorRegistry.algo.ts:804", + "pc": [ + 3357 + ] + }, + { + "teal": 2903, + "source": "examples/reti/validatorRegistry.algo.ts:804", + "pc": [ + 3358, + 3359, + 3360 + ] + }, + { + "teal": 2904, + "source": "examples/reti/validatorRegistry.algo.ts:787", + "pc": [ + 3361 + ] + }, + { + "teal": 2909, + "source": "examples/reti/validatorRegistry.algo.ts:834", + "pc": [ + 3362, + 3363, + 3364 + ] + }, + { + "teal": 2910, + "source": "examples/reti/validatorRegistry.algo.ts:834", + "pc": [ + 3365 + ] + }, + { + "teal": 2911, + "source": "examples/reti/validatorRegistry.algo.ts:834", + "pc": [ + 3366 + ] + }, + { + "teal": 2912, + "source": "examples/reti/validatorRegistry.algo.ts:834", + "pc": [ + 3367, + 3368 + ] + }, + { + "teal": 2913, + "source": "examples/reti/validatorRegistry.algo.ts:834", + "pc": [ + 3369 + ] + }, + { + "teal": 2916, + "source": "examples/reti/validatorRegistry.algo.ts:834", + "errorMessage": "argument 0 (stakerRemoved) for stakeRemoved must be a bool", + "pc": [ + 3370 + ] + }, + { + "teal": 2917, + "source": "examples/reti/validatorRegistry.algo.ts:834", + "pc": [ + 3371, + 3372 + ] + }, + { + "teal": 2918, + "source": "examples/reti/validatorRegistry.algo.ts:834", + "pc": [ + 3373 + ] + }, + { + "teal": 2921, + "source": "examples/reti/validatorRegistry.algo.ts:833", + "pc": [ + 3374, + 3375, + 3376 + ] + }, + { + "teal": 2922, + "source": "examples/reti/validatorRegistry.algo.ts:833", + "pc": [ + 3377 + ] + }, + { + "teal": 2925, + "source": "examples/reti/validatorRegistry.algo.ts:832", + "pc": [ + 3378, + 3379, + 3380 + ] + }, + { + "teal": 2926, + "source": "examples/reti/validatorRegistry.algo.ts:832", + "pc": [ + 3381 + ] + }, + { + "teal": 2929, + "source": "examples/reti/validatorRegistry.algo.ts:831", + "pc": [ + 3382, + 3383, + 3384 + ] + }, + { + "teal": 2930, + "source": "examples/reti/validatorRegistry.algo.ts:831", + "pc": [ + 3385 + ] + }, + { + "teal": 2931, + "source": "examples/reti/validatorRegistry.algo.ts:831", + "pc": [ + 3386 + ] + }, + { + "teal": 2932, + "source": "examples/reti/validatorRegistry.algo.ts:831", + "pc": [ + 3387, + 3388 + ] + }, + { + "teal": 2933, + "source": "examples/reti/validatorRegistry.algo.ts:831", + "pc": [ + 3389 + ] + }, + { + "teal": 2936, + "source": "examples/reti/validatorRegistry.algo.ts:831", + "errorMessage": "argument 3 (staker) for stakeRemoved must be a address", + "pc": [ + 3390 + ] + }, + { + "teal": 2939, + "source": "examples/reti/validatorRegistry.algo.ts:830", + "pc": [ + 3391, + 3392, + 3393 + ] + }, + { + "teal": 2940, + "source": "examples/reti/validatorRegistry.algo.ts:830", + "pc": [ + 3394 + ] + }, + { + "teal": 2941, + "source": "examples/reti/validatorRegistry.algo.ts:830", + "pc": [ + 3395 + ] + }, + { + "teal": 2942, + "source": "examples/reti/validatorRegistry.algo.ts:830", + "pc": [ + 3396, + 3397 + ] + }, + { + "teal": 2943, + "source": "examples/reti/validatorRegistry.algo.ts:830", + "pc": [ + 3398 + ] + }, + { + "teal": 2946, + "source": "examples/reti/validatorRegistry.algo.ts:830", + "errorMessage": "argument 4 (poolKey) for stakeRemoved must be a (uint64,uint64,uint64)", + "pc": [ + 3399 + ] + }, + { + "teal": 2949, + "source": "examples/reti/validatorRegistry.algo.ts:829", + "pc": [ + 3400, + 3401, + 3402 + ] + }, + { + "teal": 2950, + "source": "examples/reti/validatorRegistry.algo.ts:829", + "pc": [ + 3403, + 3404 + ] + }, + { + "teal": 2951, + "source": "examples/reti/validatorRegistry.algo.ts:829", + "pc": [ + 3405 + ] + }, + { + "teal": 2966, + "source": "examples/reti/validatorRegistry.algo.ts:829", + "pc": [ + 3406, + 3407, + 3408 + ] + }, + { + "teal": 2969, + "source": "examples/reti/validatorRegistry.algo.ts:829", + "pc": [ + 3409, + 3410 + ] + }, + { + "teal": 2970, + "source": "examples/reti/validatorRegistry.algo.ts:829", + "pc": [ + 3411, + 3412 + ] + }, + { + "teal": 2975, + "source": "examples/reti/validatorRegistry.algo.ts:836", + "pc": [ + 3413, + 3414 + ] + }, + { + "teal": 2976, + "source": "examples/reti/validatorRegistry.algo.ts:836", + "pc": [ + 3415, + 3416, + 3417 + ] + }, + { + "teal": 2977, + "source": "examples/reti/validatorRegistry.algo.ts:836", + "pc": [ + 3418 + ] + }, + { + "teal": 2978, + "source": "examples/reti/validatorRegistry.algo.ts:836", + "pc": [ + 3419, + 3420, + 3421 + ] + }, + { + "teal": 2983, + "source": "examples/reti/validatorRegistry.algo.ts:837", + "pc": [ + 3422 + ] + }, + { + "teal": 2984, + "source": "examples/reti/validatorRegistry.algo.ts:837", + "pc": [ + 3423, + 3424 + ] + }, + { + "teal": 2985, + "source": "examples/reti/validatorRegistry.algo.ts:837", + "pc": [ + 3425, + 3426 + ] + }, + { + "teal": 2986, + "source": "examples/reti/validatorRegistry.algo.ts:837", + "pc": [ + 3427, + 3428 + ] + }, + { + "teal": 2987, + "source": "examples/reti/validatorRegistry.algo.ts:837", + "pc": [ + 3429, + 3430 + ] + }, + { + "teal": 2988, + "source": "examples/reti/validatorRegistry.algo.ts:837", + "pc": [ + 3431, + 3432, + 3433, + 3434, + 3435 + ] + }, + { + "teal": 2989, + "source": "examples/reti/validatorRegistry.algo.ts:837", + "pc": [ + 3436 + ] + }, + { + "teal": 2990, + "source": "examples/reti/validatorRegistry.algo.ts:837", + "pc": [ + 3437, + 3438 + ] + }, + { + "teal": 2991, + "source": "examples/reti/validatorRegistry.algo.ts:837", + "pc": [ + 3439, + 3440 + ] + }, + { + "teal": 2992, + "source": "examples/reti/validatorRegistry.algo.ts:837", + "pc": [ + 3441, + 3442 + ] + }, + { + "teal": 2993, + "source": "examples/reti/validatorRegistry.algo.ts:837", + "pc": [ + 3443, + 3444 + ] + }, + { + "teal": 2994, + "source": "examples/reti/validatorRegistry.algo.ts:837", + "pc": [ + 3445 + ] + }, + { + "teal": 2999, + "source": "examples/reti/validatorRegistry.algo.ts:839", + "pc": [ + 3446, + 3447 + ] + }, + { + "teal": 3000, + "source": "examples/reti/validatorRegistry.algo.ts:839", + "pc": [ + 3448, + 3449, + 3450 + ] + }, + { + "teal": 3004, + "source": "examples/reti/validatorRegistry.algo.ts:843", + "pc": [ + 3451, + 3452 + ] + }, + { + "teal": 3005, + "source": "examples/reti/validatorRegistry.algo.ts:843", + "pc": [ + 3453, + 3454 + ] + }, + { + "teal": 3006, + "source": "examples/reti/validatorRegistry.algo.ts:843", + "pc": [ + 3455 + ] + }, + { + "teal": 3007, + "source": "examples/reti/validatorRegistry.algo.ts:843", + "pc": [ + 3456 + ] + }, + { + "teal": 3008, + "source": "examples/reti/validatorRegistry.algo.ts:843", + "pc": [ + 3457, + 3458, + 3459 + ] + }, + { + "teal": 3009, + "source": "examples/reti/validatorRegistry.algo.ts:843", + "pc": [ + 3460, + 3461 + ] + }, + { + "teal": 3010, + "source": "examples/reti/validatorRegistry.algo.ts:843", + "pc": [ + 3462, + 3463 + ] + }, + { + "teal": 3011, + "source": "examples/reti/validatorRegistry.algo.ts:843", + "pc": [ + 3464 + ] + }, + { + "teal": 3012, + "source": "examples/reti/validatorRegistry.algo.ts:843", + "pc": [ + 3465 + ] + }, + { + "teal": 3016, + "source": "examples/reti/validatorRegistry.algo.ts:843", + "errorMessage": "should only be called if algo or reward was removed", + "pc": [ + 3466 + ] + }, + { + "teal": 3020, + "source": "examples/reti/validatorRegistry.algo.ts:846", + "pc": [ + 3467, + 3468, + 3469 + ] + }, + { + "teal": 3021, + "source": "examples/reti/validatorRegistry.algo.ts:846", + "pc": [ + 3470, + 3471 + ] + }, + { + "teal": 3022, + "source": "examples/reti/validatorRegistry.algo.ts:846", + "pc": [ + 3472, + 3473, + 3474 + ] + }, + { + "teal": 3023, + "source": "examples/reti/validatorRegistry.algo.ts:846", + "pc": [ + 3475 + ] + }, + { + "teal": 3024, + "source": "examples/reti/validatorRegistry.algo.ts:846", + "pc": [ + 3476, + 3477 + ] + }, + { + "teal": 3025, + "source": "examples/reti/validatorRegistry.algo.ts:846", + "pc": [ + 3478 + ] + }, + { + "teal": 3026, + "source": "examples/reti/validatorRegistry.algo.ts:846", + "pc": [ + 3479, + 3480 + ] + }, + { + "teal": 3027, + "source": "examples/reti/validatorRegistry.algo.ts:846", + "pc": [ + 3481 + ] + }, + { + "teal": 3028, + "source": "examples/reti/validatorRegistry.algo.ts:846", + "pc": [ + 3482 + ] + }, + { + "teal": 3029, + "source": "examples/reti/validatorRegistry.algo.ts:846", + "pc": [ + 3483, + 3484 + ] + }, + { + "teal": 3030, + "source": "examples/reti/validatorRegistry.algo.ts:846", + "pc": [ + 3485 + ] + }, + { + "teal": 3031, + "source": "examples/reti/validatorRegistry.algo.ts:846", + "pc": [ + 3486, + 3487, + 3488 + ] + }, + { + "teal": 3032, + "source": "examples/reti/validatorRegistry.algo.ts:846", + "pc": [ + 3489, + 3490 + ] + }, + { + "teal": 3033, + "source": "examples/reti/validatorRegistry.algo.ts:846", + "pc": [ + 3491, + 3492, + 3493 + ] + }, + { + "teal": 3034, + "source": "examples/reti/validatorRegistry.algo.ts:846", + "pc": [ + 3494 + ] + }, + { + "teal": 3035, + "source": "examples/reti/validatorRegistry.algo.ts:846", + "pc": [ + 3495, + 3496 + ] + }, + { + "teal": 3036, + "source": "examples/reti/validatorRegistry.algo.ts:846", + "pc": [ + 3497 + ] + }, + { + "teal": 3037, + "source": "examples/reti/validatorRegistry.algo.ts:846", + "pc": [ + 3498, + 3499 + ] + }, + { + "teal": 3038, + "source": "examples/reti/validatorRegistry.algo.ts:846", + "pc": [ + 3500 + ] + }, + { + "teal": 3039, + "source": "examples/reti/validatorRegistry.algo.ts:846", + "pc": [ + 3501 + ] + }, + { + "teal": 3040, + "source": "examples/reti/validatorRegistry.algo.ts:846", + "pc": [ + 3502, + 3503 + ] + }, + { + "teal": 3041, + "source": "examples/reti/validatorRegistry.algo.ts:846", + "pc": [ + 3504 + ] + }, + { + "teal": 3042, + "source": "examples/reti/validatorRegistry.algo.ts:846", + "pc": [ + 3505, + 3506 + ] + }, + { + "teal": 3043, + "source": "examples/reti/validatorRegistry.algo.ts:846", + "pc": [ + 3507, + 3508, + 3509 + ] + }, + { + "teal": 3044, + "source": "examples/reti/validatorRegistry.algo.ts:846", + "pc": [ + 3510, + 3511 + ] + }, + { + "teal": 3045, + "source": "examples/reti/validatorRegistry.algo.ts:846", + "pc": [ + 3512, + 3513, + 3514 + ] + }, + { + "teal": 3046, + "source": "examples/reti/validatorRegistry.algo.ts:846", + "pc": [ + 3515 + ] + }, + { + "teal": 3047, + "source": "examples/reti/validatorRegistry.algo.ts:846", + "pc": [ + 3516 + ] + }, + { + "teal": 3048, + "source": "examples/reti/validatorRegistry.algo.ts:846", + "pc": [ + 3517 + ] + }, + { + "teal": 3049, + "source": "examples/reti/validatorRegistry.algo.ts:846", + "pc": [ + 3518, + 3519 + ] + }, + { + "teal": 3050, + "source": "examples/reti/validatorRegistry.algo.ts:846", + "pc": [ + 3520 + ] + }, + { + "teal": 3051, + "source": "examples/reti/validatorRegistry.algo.ts:846", + "pc": [ + 3521 + ] + }, + { + "teal": 3052, + "source": "examples/reti/validatorRegistry.algo.ts:846", + "pc": [ + 3522, + 3523 + ] + }, + { + "teal": 3053, + "source": "examples/reti/validatorRegistry.algo.ts:846", + "pc": [ + 3524 + ] + }, + { + "teal": 3054, + "source": "examples/reti/validatorRegistry.algo.ts:846", + "pc": [ + 3525 + ] + }, + { + "teal": 3055, + "source": "examples/reti/validatorRegistry.algo.ts:846", + "pc": [ + 3526, + 3527, + 3528 + ] + }, + { + "teal": 3056, + "source": "examples/reti/validatorRegistry.algo.ts:846", + "pc": [ + 3529, + 3530 + ] + }, + { + "teal": 3057, + "source": "examples/reti/validatorRegistry.algo.ts:846", + "pc": [ + 3531, + 3532, + 3533 + ] + }, + { + "teal": 3058, + "source": "examples/reti/validatorRegistry.algo.ts:846", + "pc": [ + 3534 + ] + }, + { + "teal": 3059, + "source": "examples/reti/validatorRegistry.algo.ts:846", + "pc": [ + 3535 + ] + }, + { + "teal": 3060, + "source": "examples/reti/validatorRegistry.algo.ts:846", + "pc": [ + 3536 + ] + }, + { + "teal": 3061, + "source": "examples/reti/validatorRegistry.algo.ts:846", + "pc": [ + 3537, + 3538 + ] + }, + { + "teal": 3062, + "source": "examples/reti/validatorRegistry.algo.ts:846", + "pc": [ + 3539 + ] + }, + { + "teal": 3066, + "source": "examples/reti/validatorRegistry.algo.ts:847", + "pc": [ + 3540, + 3541, + 3542 + ] + }, + { + "teal": 3067, + "source": "examples/reti/validatorRegistry.algo.ts:847", + "pc": [ + 3543 + ] + }, + { + "teal": 3068, + "source": "examples/reti/validatorRegistry.algo.ts:847", + "pc": [ + 3544, + 3545 + ] + }, + { + "teal": 3069, + "source": "examples/reti/validatorRegistry.algo.ts:847", + "pc": [ + 3546, + 3547, + 3548 + ] + }, + { + "teal": 3070, + "source": "examples/reti/validatorRegistry.algo.ts:847", + "pc": [ + 3549, + 3550 + ] + }, + { + "teal": 3071, + "source": "examples/reti/validatorRegistry.algo.ts:847", + "pc": [ + 3551, + 3552, + 3553 + ] + }, + { + "teal": 3072, + "source": "examples/reti/validatorRegistry.algo.ts:847", + "pc": [ + 3554 + ] + }, + { + "teal": 3073, + "source": "examples/reti/validatorRegistry.algo.ts:847", + "pc": [ + 3555 + ] + }, + { + "teal": 3074, + "source": "examples/reti/validatorRegistry.algo.ts:847", + "pc": [ + 3556 + ] + }, + { + "teal": 3075, + "source": "examples/reti/validatorRegistry.algo.ts:847", + "pc": [ + 3557, + 3558 + ] + }, + { + "teal": 3076, + "source": "examples/reti/validatorRegistry.algo.ts:847", + "pc": [ + 3559 + ] + }, + { + "teal": 3077, + "source": "examples/reti/validatorRegistry.algo.ts:847", + "pc": [ + 3560 + ] + }, + { + "teal": 3078, + "source": "examples/reti/validatorRegistry.algo.ts:847", + "pc": [ + 3561, + 3562 + ] + }, + { + "teal": 3079, + "source": "examples/reti/validatorRegistry.algo.ts:847", + "pc": [ + 3563 + ] + }, + { + "teal": 3080, + "source": "examples/reti/validatorRegistry.algo.ts:847", + "pc": [ + 3564 + ] + }, + { + "teal": 3081, + "source": "examples/reti/validatorRegistry.algo.ts:847", + "pc": [ + 3565, + 3566, + 3567 + ] + }, + { + "teal": 3082, + "source": "examples/reti/validatorRegistry.algo.ts:847", + "pc": [ + 3568, + 3569 + ] + }, + { + "teal": 3083, + "source": "examples/reti/validatorRegistry.algo.ts:847", + "pc": [ + 3570, + 3571, + 3572 + ] + }, + { + "teal": 3084, + "source": "examples/reti/validatorRegistry.algo.ts:847", + "pc": [ + 3573 + ] + }, + { + "teal": 3085, + "source": "examples/reti/validatorRegistry.algo.ts:847", + "pc": [ + 3574 + ] + }, + { + "teal": 3086, + "source": "examples/reti/validatorRegistry.algo.ts:847", + "pc": [ + 3575 + ] + }, + { + "teal": 3087, + "source": "examples/reti/validatorRegistry.algo.ts:847", + "pc": [ + 3576, + 3577 + ] + }, + { + "teal": 3088, + "source": "examples/reti/validatorRegistry.algo.ts:847", + "pc": [ + 3578 + ] + }, + { + "teal": 3092, + "source": "examples/reti/validatorRegistry.algo.ts:848", + "pc": [ + 3579, + 3580, + 3581, + 3582, + 3583, + 3584, + 3585, + 3586 + ] + }, + { + "teal": 3093, + "source": "examples/reti/validatorRegistry.algo.ts:848", + "pc": [ + 3587 + ] + }, + { + "teal": 3094, + "source": "examples/reti/validatorRegistry.algo.ts:848", + "pc": [ + 3588, + 3589 + ] + }, + { + "teal": 3095, + "source": "examples/reti/validatorRegistry.algo.ts:848", + "pc": [ + 3590 + ] + }, + { + "teal": 3096, + "source": "examples/reti/validatorRegistry.algo.ts:848", + "pc": [ + 3591, + 3592, + 3593, + 3594, + 3595, + 3596, + 3597, + 3598 + ] + }, + { + "teal": 3097, + "source": "examples/reti/validatorRegistry.algo.ts:848", + "pc": [ + 3599 + ] + }, + { + "teal": 3098, + "source": "examples/reti/validatorRegistry.algo.ts:848", + "pc": [ + 3600 + ] + }, + { + "teal": 3103, + "source": "examples/reti/validatorRegistry.algo.ts:850", + "pc": [ + 3601, + 3602 + ] + }, + { + "teal": 3104, + "source": "examples/reti/validatorRegistry.algo.ts:850", + "pc": [ + 3603, + 3604 + ] + }, + { + "teal": 3105, + "source": "examples/reti/validatorRegistry.algo.ts:850", + "pc": [ + 3605 + ] + }, + { + "teal": 3106, + "source": "examples/reti/validatorRegistry.algo.ts:850", + "pc": [ + 3606, + 3607, + 3608 + ] + }, + { + "teal": 3111, + "source": "examples/reti/validatorRegistry.algo.ts:851", + "pc": [ + 3609, + 3610, + 3611 + ] + }, + { + "teal": 3112, + "source": "examples/reti/validatorRegistry.algo.ts:851", + "pc": [ + 3612, + 3613 + ] + }, + { + "teal": 3113, + "source": "examples/reti/validatorRegistry.algo.ts:851", + "pc": [ + 3614, + 3615, + 3616 + ] + }, + { + "teal": 3114, + "source": "examples/reti/validatorRegistry.algo.ts:851", + "pc": [ + 3617, + 3618 + ] + }, + { + "teal": 3115, + "source": "examples/reti/validatorRegistry.algo.ts:851", + "pc": [ + 3619, + 3620, + 3621 + ] + }, + { + "teal": 3116, + "source": "examples/reti/validatorRegistry.algo.ts:851", + "pc": [ + 3622 + ] + }, + { + "teal": 3117, + "source": "examples/reti/validatorRegistry.algo.ts:851", + "pc": [ + 3623 + ] + }, + { + "teal": 3118, + "source": "examples/reti/validatorRegistry.algo.ts:851", + "pc": [ + 3624 + ] + }, + { + "teal": 3119, + "source": "examples/reti/validatorRegistry.algo.ts:851", + "pc": [ + 3625, + 3626 + ] + }, + { + "teal": 3120, + "source": "examples/reti/validatorRegistry.algo.ts:851", + "pc": [ + 3627 + ] + }, + { + "teal": 3121, + "source": "examples/reti/validatorRegistry.algo.ts:851", + "pc": [ + 3628 + ] + }, + { + "teal": 3122, + "source": "examples/reti/validatorRegistry.algo.ts:851", + "pc": [ + 3629, + 3630 + ] + }, + { + "teal": 3126, + "source": "examples/reti/validatorRegistry.algo.ts:852", + "pc": [ + 3631, + 3632 + ] + }, + { + "teal": 3127, + "source": "examples/reti/validatorRegistry.algo.ts:852", + "pc": [ + 3633, + 3634 + ] + }, + { + "teal": 3128, + "source": "examples/reti/validatorRegistry.algo.ts:852", + "pc": [ + 3635 + ] + }, + { + "teal": 3131, + "source": "examples/reti/validatorRegistry.algo.ts:852", + "errorMessage": "rewardRemoved can't be set if validator doesn't have reward token!", + "pc": [ + 3636 + ] + }, + { + "teal": 3138, + "source": "examples/reti/validatorRegistry.algo.ts:854", + "pc": [ + 3637, + 3638, + 3639 + ] + }, + { + "teal": 3139, + "source": "examples/reti/validatorRegistry.algo.ts:854", + "pc": [ + 3640, + 3641 + ] + }, + { + "teal": 3140, + "source": "examples/reti/validatorRegistry.algo.ts:854", + "pc": [ + 3642, + 3643, + 3644 + ] + }, + { + "teal": 3141, + "source": "examples/reti/validatorRegistry.algo.ts:854", + "pc": [ + 3645, + 3646 + ] + }, + { + "teal": 3142, + "source": "examples/reti/validatorRegistry.algo.ts:854", + "pc": [ + 3647, + 3648, + 3649 + ] + }, + { + "teal": 3143, + "source": "examples/reti/validatorRegistry.algo.ts:854", + "pc": [ + 3650 + ] + }, + { + "teal": 3144, + "source": "examples/reti/validatorRegistry.algo.ts:854", + "pc": [ + 3651 + ] + }, + { + "teal": 3145, + "source": "examples/reti/validatorRegistry.algo.ts:854", + "pc": [ + 3652 + ] + }, + { + "teal": 3146, + "source": "examples/reti/validatorRegistry.algo.ts:854", + "pc": [ + 3653, + 3654 + ] + }, + { + "teal": 3147, + "source": "examples/reti/validatorRegistry.algo.ts:854", + "pc": [ + 3655 + ] + }, + { + "teal": 3148, + "source": "examples/reti/validatorRegistry.algo.ts:854", + "pc": [ + 3656 + ] + }, + { + "teal": 3149, + "source": "examples/reti/validatorRegistry.algo.ts:854", + "pc": [ + 3657, + 3658 + ] + }, + { + "teal": 3150, + "source": "examples/reti/validatorRegistry.algo.ts:854", + "pc": [ + 3659 + ] + }, + { + "teal": 3153, + "source": "examples/reti/validatorRegistry.algo.ts:853", + "errorMessage": "reward being removed must be covered by hold back amount", + "pc": [ + 3660 + ] + }, + { + "teal": 3157, + "source": "examples/reti/validatorRegistry.algo.ts:859", + "pc": [ + 3661, + 3662, + 3663 + ] + }, + { + "teal": 3158, + "source": "examples/reti/validatorRegistry.algo.ts:859", + "pc": [ + 3664 + ] + }, + { + "teal": 3159, + "source": "examples/reti/validatorRegistry.algo.ts:859", + "pc": [ + 3665, + 3666 + ] + }, + { + "teal": 3160, + "source": "examples/reti/validatorRegistry.algo.ts:859", + "pc": [ + 3667, + 3668, + 3669 + ] + }, + { + "teal": 3161, + "source": "examples/reti/validatorRegistry.algo.ts:859", + "pc": [ + 3670, + 3671 + ] + }, + { + "teal": 3162, + "source": "examples/reti/validatorRegistry.algo.ts:859", + "pc": [ + 3672, + 3673, + 3674 + ] + }, + { + "teal": 3163, + "source": "examples/reti/validatorRegistry.algo.ts:859", + "pc": [ + 3675 + ] + }, + { + "teal": 3164, + "source": "examples/reti/validatorRegistry.algo.ts:859", + "pc": [ + 3676 + ] + }, + { + "teal": 3165, + "source": "examples/reti/validatorRegistry.algo.ts:859", + "pc": [ + 3677 + ] + }, + { + "teal": 3166, + "source": "examples/reti/validatorRegistry.algo.ts:859", + "pc": [ + 3678, + 3679 + ] + }, + { + "teal": 3167, + "source": "examples/reti/validatorRegistry.algo.ts:859", + "pc": [ + 3680 + ] + }, + { + "teal": 3168, + "source": "examples/reti/validatorRegistry.algo.ts:859", + "pc": [ + 3681 + ] + }, + { + "teal": 3169, + "source": "examples/reti/validatorRegistry.algo.ts:859", + "pc": [ + 3682, + 3683 + ] + }, + { + "teal": 3170, + "source": "examples/reti/validatorRegistry.algo.ts:859", + "pc": [ + 3684 + ] + }, + { + "teal": 3171, + "source": "examples/reti/validatorRegistry.algo.ts:859", + "pc": [ + 3685 + ] + }, + { + "teal": 3172, + "source": "examples/reti/validatorRegistry.algo.ts:859", + "pc": [ + 3686, + 3687, + 3688 + ] + }, + { + "teal": 3173, + "source": "examples/reti/validatorRegistry.algo.ts:859", + "pc": [ + 3689, + 3690 + ] + }, + { + "teal": 3174, + "source": "examples/reti/validatorRegistry.algo.ts:859", + "pc": [ + 3691, + 3692, + 3693 + ] + }, + { + "teal": 3175, + "source": "examples/reti/validatorRegistry.algo.ts:859", + "pc": [ + 3694 + ] + }, + { + "teal": 3176, + "source": "examples/reti/validatorRegistry.algo.ts:859", + "pc": [ + 3695 + ] + }, + { + "teal": 3177, + "source": "examples/reti/validatorRegistry.algo.ts:859", + "pc": [ + 3696 + ] + }, + { + "teal": 3178, + "source": "examples/reti/validatorRegistry.algo.ts:859", + "pc": [ + 3697, + 3698 + ] + }, + { + "teal": 3179, + "source": "examples/reti/validatorRegistry.algo.ts:859", + "pc": [ + 3699 + ] + }, + { + "teal": 3184, + "source": "examples/reti/validatorRegistry.algo.ts:864", + "pc": [ + 3700, + 3701 + ] + }, + { + "teal": 3185, + "source": "examples/reti/validatorRegistry.algo.ts:864", + "pc": [ + 3702, + 3703, + 3704 + ] + }, + { + "teal": 3186, + "source": "examples/reti/validatorRegistry.algo.ts:864", + "pc": [ + 3705 + ] + }, + { + "teal": 3187, + "source": "examples/reti/validatorRegistry.algo.ts:864", + "pc": [ + 3706, + 3707 + ] + }, + { + "teal": 3188, + "source": "examples/reti/validatorRegistry.algo.ts:864", + "pc": [ + 3708 + ] + }, + { + "teal": 3189, + "source": "examples/reti/validatorRegistry.algo.ts:864", + "pc": [ + 3709, + 3710, + 3711 + ] + }, + { + "teal": 3197, + "source": "examples/reti/validatorRegistry.algo.ts:865", + "pc": [ + 3712 + ] + }, + { + "teal": 3198, + "source": "examples/reti/validatorRegistry.algo.ts:865", + "pc": [ + 3713, + 3714 + ] + }, + { + "teal": 3199, + "source": "examples/reti/validatorRegistry.algo.ts:865", + "pc": [ + 3715, + 3716 + ] + }, + { + "teal": 3200, + "source": "examples/reti/validatorRegistry.algo.ts:865", + "pc": [ + 3717, + 3718, + 3719, + 3720, + 3721, + 3722 + ] + }, + { + "teal": 3201, + "source": "examples/reti/validatorRegistry.algo.ts:865", + "pc": [ + 3723, + 3724 + ] + }, + { + "teal": 3205, + "source": "examples/reti/validatorRegistry.algo.ts:866", + "pc": [ + 3725, + 3726, + 3727 + ] + }, + { + "teal": 3206, + "source": "examples/reti/validatorRegistry.algo.ts:866", + "pc": [ + 3728, + 3729 + ] + }, + { + "teal": 3207, + "source": "examples/reti/validatorRegistry.algo.ts:866", + "pc": [ + 3730, + 3731, + 3732 + ] + }, + { + "teal": 3208, + "source": "examples/reti/validatorRegistry.algo.ts:866", + "pc": [ + 3733, + 3734 + ] + }, + { + "teal": 3209, + "source": "examples/reti/validatorRegistry.algo.ts:866", + "pc": [ + 3735, + 3736, + 3737 + ] + }, + { + "teal": 3210, + "source": "examples/reti/validatorRegistry.algo.ts:866", + "pc": [ + 3738 + ] + }, + { + "teal": 3211, + "source": "examples/reti/validatorRegistry.algo.ts:866", + "pc": [ + 3739 + ] + }, + { + "teal": 3212, + "source": "examples/reti/validatorRegistry.algo.ts:866", + "pc": [ + 3740 + ] + }, + { + "teal": 3213, + "source": "examples/reti/validatorRegistry.algo.ts:866", + "pc": [ + 3741, + 3742 + ] + }, + { + "teal": 3214, + "source": "examples/reti/validatorRegistry.algo.ts:866", + "pc": [ + 3743 + ] + }, + { + "teal": 3215, + "source": "examples/reti/validatorRegistry.algo.ts:866", + "pc": [ + 3744 + ] + }, + { + "teal": 3216, + "source": "examples/reti/validatorRegistry.algo.ts:866", + "pc": [ + 3745, + 3746 + ] + }, + { + "teal": 3220, + "source": "examples/reti/validatorRegistry.algo.ts:867", + "pc": [ + 3747, + 3748 + ] + }, + { + "teal": 3221, + "source": "examples/reti/validatorRegistry.algo.ts:867", + "pc": [ + 3749, + 3750 + ] + }, + { + "teal": 3222, + "source": "examples/reti/validatorRegistry.algo.ts:867", + "pc": [ + 3751, + 3752 + ] + }, + { + "teal": 3223, + "source": "examples/reti/validatorRegistry.algo.ts:867", + "pc": [ + 3753 + ] + }, + { + "teal": 3224, + "source": "examples/reti/validatorRegistry.algo.ts:867", + "pc": [ + 3754, + 3755 + ] + }, + { + "teal": 3225, + "source": "examples/reti/validatorRegistry.algo.ts:867", + "pc": [ + 3756, + 3757 + ] + }, + { + "teal": 3226, + "source": "examples/reti/validatorRegistry.algo.ts:867", + "pc": [ + 3758 + ] + }, + { + "teal": 3227, + "source": "examples/reti/validatorRegistry.algo.ts:867", + "pc": [ + 3759, + 3760 + ] + }, + { + "teal": 3230, + "source": "examples/reti/validatorRegistry.algo.ts:865", + "pc": [ + 3761, + 3762 + ] + }, + { + "teal": 3231, + "source": "examples/reti/validatorRegistry.algo.ts:865", + "pc": [ + 3763, + 3764 + ] + }, + { + "teal": 3234, + "source": "examples/reti/validatorRegistry.algo.ts:865", + "pc": [ + 3765 + ] + }, + { + "teal": 3237, + "source": "examples/reti/validatorRegistry.algo.ts:850", + "pc": [ + 3766, + 3767, + 3768 + ] + }, + { + "teal": 3245, + "source": "examples/reti/validatorRegistry.algo.ts:892", + "pc": [ + 3769, + 3770 + ] + }, + { + "teal": 3246, + "source": "examples/reti/validatorRegistry.algo.ts:892", + "pc": [ + 3771, + 3772, + 3773 + ] + }, + { + "teal": 3251, + "source": "examples/reti/validatorRegistry.algo.ts:894", + "pc": [ + 3774, + 3775, + 3776 + ] + }, + { + "teal": 3252, + "source": "examples/reti/validatorRegistry.algo.ts:894", + "pc": [ + 3777, + 3778 + ] + }, + { + "teal": 3253, + "source": "examples/reti/validatorRegistry.algo.ts:894", + "pc": [ + 3779, + 3780, + 3781 + ] + }, + { + "teal": 3254, + "source": "examples/reti/validatorRegistry.algo.ts:894", + "pc": [ + 3782 + ] + }, + { + "teal": 3255, + "source": "examples/reti/validatorRegistry.algo.ts:894", + "pc": [ + 3783, + 3784 + ] + }, + { + "teal": 3256, + "source": "examples/reti/validatorRegistry.algo.ts:894", + "pc": [ + 3785 + ] + }, + { + "teal": 3257, + "source": "examples/reti/validatorRegistry.algo.ts:894", + "pc": [ + 3786, + 3787 + ] + }, + { + "teal": 3258, + "source": "examples/reti/validatorRegistry.algo.ts:894", + "pc": [ + 3788 + ] + }, + { + "teal": 3259, + "source": "examples/reti/validatorRegistry.algo.ts:894", + "pc": [ + 3789 + ] + }, + { + "teal": 3260, + "source": "examples/reti/validatorRegistry.algo.ts:894", + "pc": [ + 3790, + 3791 + ] + }, + { + "teal": 3261, + "source": "examples/reti/validatorRegistry.algo.ts:894", + "pc": [ + 3792 + ] + }, + { + "teal": 3262, + "source": "examples/reti/validatorRegistry.algo.ts:894", + "pc": [ + 3793, + 3794, + 3795 + ] + }, + { + "teal": 3263, + "source": "examples/reti/validatorRegistry.algo.ts:894", + "pc": [ + 3796, + 3797 + ] + }, + { + "teal": 3264, + "source": "examples/reti/validatorRegistry.algo.ts:894", + "pc": [ + 3798, + 3799, + 3800 + ] + }, + { + "teal": 3265, + "source": "examples/reti/validatorRegistry.algo.ts:894", + "pc": [ + 3801 + ] + }, + { + "teal": 3266, + "source": "examples/reti/validatorRegistry.algo.ts:894", + "pc": [ + 3802, + 3803 + ] + }, + { + "teal": 3267, + "source": "examples/reti/validatorRegistry.algo.ts:894", + "pc": [ + 3804 + ] + }, + { + "teal": 3268, + "source": "examples/reti/validatorRegistry.algo.ts:894", + "pc": [ + 3805, + 3806 + ] + }, + { + "teal": 3269, + "source": "examples/reti/validatorRegistry.algo.ts:894", + "pc": [ + 3807 + ] + }, + { + "teal": 3270, + "source": "examples/reti/validatorRegistry.algo.ts:894", + "pc": [ + 3808 + ] + }, + { + "teal": 3271, + "source": "examples/reti/validatorRegistry.algo.ts:894", + "pc": [ + 3809, + 3810 + ] + }, + { + "teal": 3272, + "source": "examples/reti/validatorRegistry.algo.ts:894", + "pc": [ + 3811 + ] + }, + { + "teal": 3273, + "source": "examples/reti/validatorRegistry.algo.ts:894", + "pc": [ + 3812, + 3813 + ] + }, + { + "teal": 3274, + "source": "examples/reti/validatorRegistry.algo.ts:894", + "pc": [ + 3814, + 3815, + 3816 + ] + }, + { + "teal": 3275, + "source": "examples/reti/validatorRegistry.algo.ts:894", + "pc": [ + 3817, + 3818 + ] + }, + { + "teal": 3276, + "source": "examples/reti/validatorRegistry.algo.ts:894", + "pc": [ + 3819, + 3820, + 3821 + ] + }, + { + "teal": 3277, + "source": "examples/reti/validatorRegistry.algo.ts:894", + "pc": [ + 3822 + ] + }, + { + "teal": 3278, + "source": "examples/reti/validatorRegistry.algo.ts:894", + "pc": [ + 3823 + ] + }, + { + "teal": 3279, + "source": "examples/reti/validatorRegistry.algo.ts:894", + "pc": [ + 3824 + ] + }, + { + "teal": 3280, + "source": "examples/reti/validatorRegistry.algo.ts:894", + "pc": [ + 3825, + 3826 + ] + }, + { + "teal": 3281, + "source": "examples/reti/validatorRegistry.algo.ts:894", + "pc": [ + 3827 + ] + }, + { + "teal": 3282, + "source": "examples/reti/validatorRegistry.algo.ts:894", + "pc": [ + 3828 + ] + }, + { + "teal": 3283, + "source": "examples/reti/validatorRegistry.algo.ts:894", + "pc": [ + 3829, + 3830 + ] + }, + { + "teal": 3284, + "source": "examples/reti/validatorRegistry.algo.ts:894", + "pc": [ + 3831 + ] + }, + { + "teal": 3285, + "source": "examples/reti/validatorRegistry.algo.ts:894", + "pc": [ + 3832 + ] + }, + { + "teal": 3286, + "source": "examples/reti/validatorRegistry.algo.ts:894", + "pc": [ + 3833, + 3834, + 3835 + ] + }, + { + "teal": 3287, + "source": "examples/reti/validatorRegistry.algo.ts:894", + "pc": [ + 3836, + 3837, + 3838 + ] + }, + { + "teal": 3288, + "source": "examples/reti/validatorRegistry.algo.ts:894", + "pc": [ + 3839, + 3840 + ] + }, + { + "teal": 3289, + "source": "examples/reti/validatorRegistry.algo.ts:894", + "pc": [ + 3841, + 3842, + 3843 + ] + }, + { + "teal": 3290, + "source": "examples/reti/validatorRegistry.algo.ts:894", + "pc": [ + 3844 + ] + }, + { + "teal": 3291, + "source": "examples/reti/validatorRegistry.algo.ts:894", + "pc": [ + 3845 + ] + }, + { + "teal": 3292, + "source": "examples/reti/validatorRegistry.algo.ts:894", + "pc": [ + 3846 + ] + }, + { + "teal": 3293, + "source": "examples/reti/validatorRegistry.algo.ts:894", + "pc": [ + 3847, + 3848 + ] + }, + { + "teal": 3294, + "source": "examples/reti/validatorRegistry.algo.ts:894", + "pc": [ + 3849 + ] + }, + { + "teal": 3302, + "source": "examples/reti/validatorRegistry.algo.ts:897", + "pc": [ + 3850, + 3851 + ] + }, + { + "teal": 3303, + "source": "examples/reti/validatorRegistry.algo.ts:897", + "pc": [ + 3852, + 3853, + 3854 + ] + }, + { + "teal": 3304, + "source": "examples/reti/validatorRegistry.algo.ts:897", + "pc": [ + 3855 + ] + }, + { + "teal": 3305, + "source": "examples/reti/validatorRegistry.algo.ts:897", + "pc": [ + 3856 + ] + }, + { + "teal": 3306, + "source": "examples/reti/validatorRegistry.algo.ts:898", + "pc": [ + 3857, + 3858 + ] + }, + { + "teal": 3307, + "source": "examples/reti/validatorRegistry.algo.ts:898", + "pc": [ + 3859, + 3860, + 3861 + ] + }, + { + "teal": 3308, + "source": "examples/reti/validatorRegistry.algo.ts:898", + "pc": [ + 3862 + ] + }, + { + "teal": 3309, + "source": "examples/reti/validatorRegistry.algo.ts:898", + "pc": [ + 3863 + ] + }, + { + "teal": 3310, + "source": "examples/reti/validatorRegistry.algo.ts:898", + "pc": [ + 3864 + ] + }, + { + "teal": 3311, + "source": "examples/reti/validatorRegistry.algo.ts:899", + "pc": [ + 3865, + 3866 + ] + }, + { + "teal": 3312, + "source": "examples/reti/validatorRegistry.algo.ts:899", + "pc": [ + 3867, + 3868, + 3869 + ] + }, + { + "teal": 3313, + "source": "examples/reti/validatorRegistry.algo.ts:899", + "pc": [ + 3870 + ] + }, + { + "teal": 3314, + "source": "examples/reti/validatorRegistry.algo.ts:899", + "pc": [ + 3871 + ] + }, + { + "teal": 3315, + "source": "examples/reti/validatorRegistry.algo.ts:899", + "pc": [ + 3872 + ] + }, + { + "teal": 3316, + "source": "examples/reti/validatorRegistry.algo.ts:896", + "pc": [ + 3873, + 3874 + ] + }, + { + "teal": 3317, + "source": "examples/reti/validatorRegistry.algo.ts:896", + "pc": [ + 3875, + 3876, + 3877 + ] + }, + { + "teal": 3318, + "source": "examples/reti/validatorRegistry.algo.ts:896", + "pc": [ + 3878, + 3879 + ] + }, + { + "teal": 3322, + "source": "examples/reti/validatorRegistry.algo.ts:901", + "pc": [ + 3880, + 3881 + ] + }, + { + "teal": 3323, + "source": "examples/reti/validatorRegistry.algo.ts:901", + "pc": [ + 3882, + 3883 + ] + }, + { + "teal": 3324, + "source": "examples/reti/validatorRegistry.algo.ts:901", + "pc": [ + 3884, + 3885 + ] + }, + { + "teal": 3325, + "source": "examples/reti/validatorRegistry.algo.ts:901", + "pc": [ + 3886, + 3887 + ] + }, + { + "teal": 3326, + "source": "examples/reti/validatorRegistry.algo.ts:901", + "pc": [ + 3888 + ] + }, + { + "teal": 3327, + "source": "examples/reti/validatorRegistry.algo.ts:901", + "pc": [ + 3889, + 3890 + ] + }, + { + "teal": 3331, + "source": "examples/reti/validatorRegistry.algo.ts:902", + "pc": [ + 3891, + 3892 + ] + }, + { + "teal": 3332, + "source": "examples/reti/validatorRegistry.algo.ts:902", + "pc": [ + 3893, + 3894 + ] + }, + { + "teal": 3333, + "source": "examples/reti/validatorRegistry.algo.ts:902", + "pc": [ + 3895, + 3896 + ] + }, + { + "teal": 3334, + "source": "examples/reti/validatorRegistry.algo.ts:902", + "pc": [ + 3897, + 3898 + ] + }, + { + "teal": 3335, + "source": "examples/reti/validatorRegistry.algo.ts:902", + "pc": [ + 3899 + ] + }, + { + "teal": 3336, + "source": "examples/reti/validatorRegistry.algo.ts:902", + "pc": [ + 3900, + 3901 + ] + }, + { + "teal": 3341, + "source": "examples/reti/validatorRegistry.algo.ts:904", + "pc": [ + 3902, + 3903 + ] + }, + { + "teal": 3342, + "source": "examples/reti/validatorRegistry.algo.ts:904", + "pc": [ + 3904, + 3905, + 3906 + ] + }, + { + "teal": 3347, + "source": "examples/reti/validatorRegistry.algo.ts:905", + "pc": [ + 3907, + 3908, + 3909 + ] + }, + { + "teal": 3348, + "source": "examples/reti/validatorRegistry.algo.ts:905", + "pc": [ + 3910, + 3911, + 3912 + ] + }, + { + "teal": 3349, + "source": "examples/reti/validatorRegistry.algo.ts:905", + "pc": [ + 3913, + 3914 + ] + }, + { + "teal": 3350, + "source": "examples/reti/validatorRegistry.algo.ts:905", + "pc": [ + 3915, + 3916, + 3917 + ] + }, + { + "teal": 3351, + "source": "examples/reti/validatorRegistry.algo.ts:905", + "pc": [ + 3918, + 3919 + ] + }, + { + "teal": 3352, + "source": "examples/reti/validatorRegistry.algo.ts:905", + "pc": [ + 3920, + 3921, + 3922 + ] + }, + { + "teal": 3353, + "source": "examples/reti/validatorRegistry.algo.ts:905", + "pc": [ + 3923 + ] + }, + { + "teal": 3354, + "source": "examples/reti/validatorRegistry.algo.ts:905", + "pc": [ + 3924 + ] + }, + { + "teal": 3355, + "source": "examples/reti/validatorRegistry.algo.ts:905", + "pc": [ + 3925 + ] + }, + { + "teal": 3356, + "source": "examples/reti/validatorRegistry.algo.ts:905", + "pc": [ + 3926, + 3927 + ] + }, + { + "teal": 3357, + "source": "examples/reti/validatorRegistry.algo.ts:905", + "pc": [ + 3928 + ] + }, + { + "teal": 3358, + "source": "examples/reti/validatorRegistry.algo.ts:905", + "pc": [ + 3929 + ] + }, + { + "teal": 3359, + "source": "examples/reti/validatorRegistry.algo.ts:905", + "pc": [ + 3930, + 3931 + ] + }, + { + "teal": 3360, + "source": "examples/reti/validatorRegistry.algo.ts:905", + "pc": [ + 3932 + ] + }, + { + "teal": 3361, + "source": "examples/reti/validatorRegistry.algo.ts:905", + "pc": [ + 3933 + ] + }, + { + "teal": 3362, + "source": "examples/reti/validatorRegistry.algo.ts:905", + "pc": [ + 3934, + 3935, + 3936 + ] + }, + { + "teal": 3363, + "source": "examples/reti/validatorRegistry.algo.ts:905", + "pc": [ + 3937, + 3938 + ] + }, + { + "teal": 3364, + "source": "examples/reti/validatorRegistry.algo.ts:905", + "pc": [ + 3939, + 3940, + 3941 + ] + }, + { + "teal": 3365, + "source": "examples/reti/validatorRegistry.algo.ts:905", + "pc": [ + 3942 + ] + }, + { + "teal": 3366, + "source": "examples/reti/validatorRegistry.algo.ts:905", + "pc": [ + 3943 + ] + }, + { + "teal": 3367, + "source": "examples/reti/validatorRegistry.algo.ts:905", + "pc": [ + 3944 + ] + }, + { + "teal": 3368, + "source": "examples/reti/validatorRegistry.algo.ts:905", + "pc": [ + 3945, + 3946 + ] + }, + { + "teal": 3369, + "source": "examples/reti/validatorRegistry.algo.ts:905", + "pc": [ + 3947 + ] + }, + { + "teal": 3375, + "source": "examples/reti/validatorRegistry.algo.ts:908", + "pc": [ + 3948, + 3949 + ] + }, + { + "teal": 3376, + "source": "examples/reti/validatorRegistry.algo.ts:908", + "pc": [ + 3950, + 3951, + 3952 + ] + }, + { + "teal": 3381, + "source": "examples/reti/validatorRegistry.algo.ts:909", + "pc": [ + 3953, + 3954, + 3955, + 3956, + 3957, + 3958, + 3959, + 3960, + 3961, + 3962, + 3963, + 3964 + ] + }, + { + "teal": 3382, + "source": "examples/reti/validatorRegistry.algo.ts:909", + "pc": [ + 3965 + ] + }, + { + "teal": 3383, + "source": "examples/reti/validatorRegistry.algo.ts:909", + "pc": [ + 3966, + 3967 + ] + }, + { + "teal": 3384, + "source": "examples/reti/validatorRegistry.algo.ts:909", + "pc": [ + 3968 + ] + }, + { + "teal": 3385, + "source": "examples/reti/validatorRegistry.algo.ts:909", + "pc": [ + 3969, + 3970, + 3971, + 3972, + 3973, + 3974, + 3975, + 3976, + 3977, + 3978, + 3979, + 3980 + ] + }, + { + "teal": 3386, + "source": "examples/reti/validatorRegistry.algo.ts:909", + "pc": [ + 3981 + ] + }, + { + "teal": 3387, + "source": "examples/reti/validatorRegistry.algo.ts:909", + "pc": [ + 3982 + ] + }, + { + "teal": 3392, + "source": "examples/reti/validatorRegistry.algo.ts:829", + "pc": [ + 3983 + ] + }, + { + "teal": 3397, + "source": "examples/reti/validatorRegistry.algo.ts:925", + "pc": [ + 3984, + 3985, + 3986, + 3987, + 3988, + 3989 + ] + }, + { + "teal": 3400, + "source": "examples/reti/validatorRegistry.algo.ts:928", + "pc": [ + 3990, + 3991, + 3992 + ] + }, + { + "teal": 3401, + "source": "examples/reti/validatorRegistry.algo.ts:928", + "pc": [ + 3993 + ] + }, + { + "teal": 3404, + "source": "examples/reti/validatorRegistry.algo.ts:927", + "pc": [ + 3994, + 3995, + 3996 + ] + }, + { + "teal": 3405, + "source": "examples/reti/validatorRegistry.algo.ts:927", + "pc": [ + 3997 + ] + }, + { + "teal": 3406, + "source": "examples/reti/validatorRegistry.algo.ts:927", + "pc": [ + 3998 + ] + }, + { + "teal": 3407, + "source": "examples/reti/validatorRegistry.algo.ts:927", + "pc": [ + 3999, + 4000 + ] + }, + { + "teal": 3408, + "source": "examples/reti/validatorRegistry.algo.ts:927", + "pc": [ + 4001 + ] + }, + { + "teal": 3411, + "source": "examples/reti/validatorRegistry.algo.ts:927", + "errorMessage": "argument 1 (staker) for findPoolForStaker must be a address", + "pc": [ + 4002 + ] + }, + { + "teal": 3414, + "source": "examples/reti/validatorRegistry.algo.ts:926", + "pc": [ + 4003, + 4004, + 4005 + ] + }, + { + "teal": 3415, + "source": "examples/reti/validatorRegistry.algo.ts:926", + "pc": [ + 4006 + ] + }, + { + "teal": 3418, + "source": "examples/reti/validatorRegistry.algo.ts:925", + "pc": [ + 4007, + 4008, + 4009 + ] + }, + { + "teal": 3419, + "source": "examples/reti/validatorRegistry.algo.ts:925", + "pc": [ + 4010 + ] + }, + { + "teal": 3420, + "source": "examples/reti/validatorRegistry.algo.ts:925", + "pc": [ + 4011 + ] + }, + { + "teal": 3421, + "source": "examples/reti/validatorRegistry.algo.ts:925", + "pc": [ + 4012, + 4013 + ] + }, + { + "teal": 3422, + "source": "examples/reti/validatorRegistry.algo.ts:925", + "pc": [ + 4014 + ] + }, + { + "teal": 3436, + "source": "examples/reti/validatorRegistry.algo.ts:925", + "pc": [ + 4015, + 4016, + 4017 + ] + }, + { + "teal": 3439, + "source": "examples/reti/validatorRegistry.algo.ts:925", + "pc": [ + 4018, + 4019 + ] + }, + { + "teal": 3440, + "source": "examples/reti/validatorRegistry.algo.ts:925", + "pc": [ + 4020, + 4021 + ] + }, + { + "teal": 3444, + "source": "examples/reti/validatorRegistry.algo.ts:930", + "pc": [ + 4022, + 4023 + ] + }, + { + "teal": 3445, + "source": "examples/reti/validatorRegistry.algo.ts:930", + "pc": [ + 4024, + 4025 + ] + }, + { + "teal": 3449, + "source": "examples/reti/validatorRegistry.algo.ts:931", + "pc": [ + 4026, + 4027 + ] + }, + { + "teal": 3450, + "source": "examples/reti/validatorRegistry.algo.ts:931", + "pc": [ + 4028, + 4029 + ] + }, + { + "teal": 3454, + "source": "examples/reti/validatorRegistry.algo.ts:939", + "pc": [ + 4030, + 4031 + ] + }, + { + "teal": 3455, + "source": "examples/reti/validatorRegistry.algo.ts:939", + "pc": [ + 4032, + 4033, + 4034 + ] + }, + { + "teal": 3456, + "source": "examples/reti/validatorRegistry.algo.ts:939", + "pc": [ + 4035, + 4036 + ] + }, + { + "teal": 3461, + "source": "examples/reti/validatorRegistry.algo.ts:942", + "pc": [ + 4037, + 4038, + 4039, + 4040, + 4041 + ] + }, + { + "teal": 3462, + "source": "examples/reti/validatorRegistry.algo.ts:942", + "pc": [ + 4042, + 4043 + ] + }, + { + "teal": 3463, + "source": "examples/reti/validatorRegistry.algo.ts:942", + "pc": [ + 4044 + ] + }, + { + "teal": 3464, + "source": "examples/reti/validatorRegistry.algo.ts:942", + "pc": [ + 4045 + ] + }, + { + "teal": 3465, + "source": "examples/reti/validatorRegistry.algo.ts:942", + "pc": [ + 4046 + ] + }, + { + "teal": 3466, + "source": "examples/reti/validatorRegistry.algo.ts:942", + "pc": [ + 4047 + ] + }, + { + "teal": 3467, + "source": "examples/reti/validatorRegistry.algo.ts:942", + "pc": [ + 4048, + 4049, + 4050 + ] + }, + { + "teal": 3472, + "source": "examples/reti/validatorRegistry.algo.ts:943", + "pc": [ + 4051, + 4052, + 4053, + 4054, + 4055 + ] + }, + { + "teal": 3473, + "source": "examples/reti/validatorRegistry.algo.ts:943", + "pc": [ + 4056, + 4057 + ] + }, + { + "teal": 3474, + "source": "examples/reti/validatorRegistry.algo.ts:943", + "pc": [ + 4058 + ] + }, + { + "teal": 3475, + "source": "examples/reti/validatorRegistry.algo.ts:943", + "pc": [ + 4059 + ] + }, + { + "teal": 3478, + "source": "examples/reti/validatorRegistry.algo.ts:943", + "errorMessage": "box value does not exist: this.stakerPoolSet(staker).value", + "pc": [ + 4060 + ] + }, + { + "teal": 3479, + "source": "examples/reti/validatorRegistry.algo.ts:943", + "pc": [ + 4061, + 4062 + ] + }, + { + "teal": 3483, + "source": "examples/reti/validatorRegistry.algo.ts:944", + "pc": [ + 4063, + 4064 + ] + }, + { + "teal": 3484, + "source": "examples/reti/validatorRegistry.algo.ts:944", + "pc": [ + 4065, + 4066 + ] + }, + { + "teal": 3485, + "source": "examples/reti/validatorRegistry.algo.ts:944", + "pc": [ + 4067 + ] + }, + { + "teal": 3486, + "source": "examples/reti/validatorRegistry.algo.ts:944", + "pc": [ + 4068 + ] + }, + { + "teal": 3490, + "source": "examples/reti/validatorRegistry.algo.ts:945", + "pc": [ + 4069, + 4070 + ] + }, + { + "teal": 3491, + "source": "examples/reti/validatorRegistry.algo.ts:945", + "pc": [ + 4071, + 4072 + ] + }, + { + "teal": 3496, + "source": "examples/reti/validatorRegistry.algo.ts:945", + "pc": [ + 4073, + 4074 + ] + }, + { + "teal": 3497, + "source": "examples/reti/validatorRegistry.algo.ts:945", + "pc": [ + 4075, + 4076 + ] + }, + { + "teal": 3498, + "source": "examples/reti/validatorRegistry.algo.ts:945", + "pc": [ + 4077 + ] + }, + { + "teal": 3499, + "source": "examples/reti/validatorRegistry.algo.ts:945", + "pc": [ + 4078, + 4079, + 4080 + ] + }, + { + "teal": 3504, + "source": "examples/reti/validatorRegistry.algo.ts:946", + "pc": [ + 4081, + 4082 + ] + }, + { + "teal": 3505, + "source": "examples/reti/validatorRegistry.algo.ts:946", + "pc": [ + 4083, + 4084, + 4085 + ] + }, + { + "teal": 3506, + "source": "examples/reti/validatorRegistry.algo.ts:946", + "pc": [ + 4086 + ] + }, + { + "teal": 3507, + "source": "examples/reti/validatorRegistry.algo.ts:946", + "pc": [ + 4087, + 4088, + 4089 + ] + }, + { + "teal": 3512, + "source": "examples/reti/validatorRegistry.algo.ts:947", + "pc": [ + 4090 + ] + }, + { + "teal": 3513, + "source": "examples/reti/validatorRegistry.algo.ts:947", + "pc": [ + 4091, + 4092 + ] + }, + { + "teal": 3514, + "source": "examples/reti/validatorRegistry.algo.ts:947", + "pc": [ + 4093, + 4094 + ] + }, + { + "teal": 3515, + "source": "examples/reti/validatorRegistry.algo.ts:947", + "pc": [ + 4095, + 4096 + ] + }, + { + "teal": 3516, + "source": "examples/reti/validatorRegistry.algo.ts:947", + "pc": [ + 4097, + 4098 + ] + }, + { + "teal": 3517, + "source": "examples/reti/validatorRegistry.algo.ts:947", + "pc": [ + 4099, + 4100, + 4101, + 4102, + 4103 + ] + }, + { + "teal": 3518, + "source": "examples/reti/validatorRegistry.algo.ts:947", + "pc": [ + 4104 + ] + }, + { + "teal": 3519, + "source": "examples/reti/validatorRegistry.algo.ts:947", + "pc": [ + 4105, + 4106 + ] + }, + { + "teal": 3520, + "source": "examples/reti/validatorRegistry.algo.ts:947", + "pc": [ + 4107, + 4108 + ] + }, + { + "teal": 3521, + "source": "examples/reti/validatorRegistry.algo.ts:947", + "pc": [ + 4109, + 4110 + ] + }, + { + "teal": 3522, + "source": "examples/reti/validatorRegistry.algo.ts:947", + "pc": [ + 4111, + 4112 + ] + }, + { + "teal": 3523, + "source": "examples/reti/validatorRegistry.algo.ts:947", + "pc": [ + 4113 + ] + }, + { + "teal": 3529, + "source": "examples/reti/validatorRegistry.algo.ts:949", + "pc": [ + 4114, + 4115 + ] + }, + { + "teal": 3530, + "source": "examples/reti/validatorRegistry.algo.ts:949", + "pc": [ + 4116, + 4117 + ] + }, + { + "teal": 3531, + "source": "examples/reti/validatorRegistry.algo.ts:949", + "pc": [ + 4118, + 4119 + ] + }, + { + "teal": 3532, + "source": "examples/reti/validatorRegistry.algo.ts:949", + "pc": [ + 4120 + ] + }, + { + "teal": 3533, + "source": "examples/reti/validatorRegistry.algo.ts:949", + "pc": [ + 4121, + 4122 + ] + }, + { + "teal": 3534, + "source": "examples/reti/validatorRegistry.algo.ts:949", + "pc": [ + 4123 + ] + }, + { + "teal": 3535, + "source": "examples/reti/validatorRegistry.algo.ts:949", + "pc": [ + 4124, + 4125 + ] + }, + { + "teal": 3536, + "source": "examples/reti/validatorRegistry.algo.ts:949", + "pc": [ + 4126 + ] + }, + { + "teal": 3537, + "source": "examples/reti/validatorRegistry.algo.ts:949", + "pc": [ + 4127 + ] + }, + { + "teal": 3538, + "source": "examples/reti/validatorRegistry.algo.ts:949", + "pc": [ + 4128, + 4129 + ] + }, + { + "teal": 3539, + "source": "examples/reti/validatorRegistry.algo.ts:949", + "pc": [ + 4130 + ] + }, + { + "teal": 3540, + "source": "examples/reti/validatorRegistry.algo.ts:949", + "pc": [ + 4131, + 4132, + 4133 + ] + }, + { + "teal": 3543, + "source": "examples/reti/validatorRegistry.algo.ts:950", + "pc": [ + 4134, + 4135, + 4136 + ] + }, + { + "teal": 3548, + "source": "examples/reti/validatorRegistry.algo.ts:952", + "pc": [ + 4137, + 4138 + ] + }, + { + "teal": 3549, + "source": "examples/reti/validatorRegistry.algo.ts:952", + "pc": [ + 4139, + 4140 + ] + }, + { + "teal": 3554, + "source": "examples/reti/validatorRegistry.algo.ts:953", + "pc": [ + 4141, + 4142 + ] + }, + { + "teal": 3555, + "source": "examples/reti/validatorRegistry.algo.ts:953", + "pc": [ + 4143, + 4144 + ] + }, + { + "teal": 3556, + "source": "examples/reti/validatorRegistry.algo.ts:953", + "pc": [ + 4145, + 4146 + ] + }, + { + "teal": 3557, + "source": "examples/reti/validatorRegistry.algo.ts:953", + "pc": [ + 4147 + ] + }, + { + "teal": 3558, + "source": "examples/reti/validatorRegistry.algo.ts:953", + "pc": [ + 4148, + 4149 + ] + }, + { + "teal": 3559, + "source": "examples/reti/validatorRegistry.algo.ts:953", + "pc": [ + 4150 + ] + }, + { + "teal": 3560, + "source": "examples/reti/validatorRegistry.algo.ts:953", + "pc": [ + 4151, + 4152 + ] + }, + { + "teal": 3561, + "source": "examples/reti/validatorRegistry.algo.ts:953", + "pc": [ + 4153 + ] + }, + { + "teal": 3562, + "source": "examples/reti/validatorRegistry.algo.ts:953", + "pc": [ + 4154 + ] + }, + { + "teal": 3563, + "source": "examples/reti/validatorRegistry.algo.ts:953", + "pc": [ + 4155, + 4156 + ] + }, + { + "teal": 3564, + "source": "examples/reti/validatorRegistry.algo.ts:953", + "pc": [ + 4157 + ] + }, + { + "teal": 3565, + "source": "examples/reti/validatorRegistry.algo.ts:953", + "pc": [ + 4158, + 4159, + 4160 + ] + }, + { + "teal": 3570, + "source": "examples/reti/validatorRegistry.algo.ts:955", + "pc": [ + 4161, + 4162 + ] + }, + { + "teal": 3571, + "source": "examples/reti/validatorRegistry.algo.ts:955", + "pc": [ + 4163, + 4164 + ] + }, + { + "teal": 3577, + "source": "examples/reti/validatorRegistry.algo.ts:957", + "pc": [ + 4165, + 4166, + 4167 + ] + }, + { + "teal": 3578, + "source": "examples/reti/validatorRegistry.algo.ts:957", + "pc": [ + 4168, + 4169 + ] + }, + { + "teal": 3579, + "source": "examples/reti/validatorRegistry.algo.ts:957", + "pc": [ + 4170, + 4171 + ] + }, + { + "teal": 3580, + "source": "examples/reti/validatorRegistry.algo.ts:957", + "pc": [ + 4172, + 4173 + ] + }, + { + "teal": 3581, + "source": "examples/reti/validatorRegistry.algo.ts:957", + "pc": [ + 4174 + ] + }, + { + "teal": 3582, + "source": "examples/reti/validatorRegistry.algo.ts:957", + "pc": [ + 4175, + 4176 + ] + }, + { + "teal": 3583, + "source": "examples/reti/validatorRegistry.algo.ts:957", + "pc": [ + 4177 + ] + }, + { + "teal": 3584, + "source": "examples/reti/validatorRegistry.algo.ts:957", + "pc": [ + 4178, + 4179 + ] + }, + { + "teal": 3585, + "source": "examples/reti/validatorRegistry.algo.ts:957", + "pc": [ + 4180 + ] + }, + { + "teal": 3586, + "source": "examples/reti/validatorRegistry.algo.ts:957", + "pc": [ + 4181 + ] + }, + { + "teal": 3587, + "source": "examples/reti/validatorRegistry.algo.ts:957", + "pc": [ + 4182, + 4183 + ] + }, + { + "teal": 3588, + "source": "examples/reti/validatorRegistry.algo.ts:957", + "pc": [ + 4184 + ] + }, + { + "teal": 3589, + "source": "examples/reti/validatorRegistry.algo.ts:957", + "pc": [ + 4185, + 4186 + ] + }, + { + "teal": 3590, + "source": "examples/reti/validatorRegistry.algo.ts:957", + "pc": [ + 4187 + ] + }, + { + "teal": 3591, + "source": "examples/reti/validatorRegistry.algo.ts:957", + "pc": [ + 4188 + ] + }, + { + "teal": 3592, + "source": "examples/reti/validatorRegistry.algo.ts:957", + "pc": [ + 4189, + 4190 + ] + }, + { + "teal": 3593, + "source": "examples/reti/validatorRegistry.algo.ts:957", + "pc": [ + 4191 + ] + }, + { + "teal": 3594, + "source": "examples/reti/validatorRegistry.algo.ts:957", + "pc": [ + 4192, + 4193 + ] + }, + { + "teal": 3595, + "source": "examples/reti/validatorRegistry.algo.ts:957", + "pc": [ + 4194, + 4195, + 4196 + ] + }, + { + "teal": 3596, + "source": "examples/reti/validatorRegistry.algo.ts:957", + "pc": [ + 4197, + 4198 + ] + }, + { + "teal": 3597, + "source": "examples/reti/validatorRegistry.algo.ts:957", + "pc": [ + 4199 + ] + }, + { + "teal": 3598, + "source": "examples/reti/validatorRegistry.algo.ts:957", + "pc": [ + 4200 + ] + }, + { + "teal": 3599, + "source": "examples/reti/validatorRegistry.algo.ts:957", + "pc": [ + 4201, + 4202 + ] + }, + { + "teal": 3600, + "source": "examples/reti/validatorRegistry.algo.ts:957", + "pc": [ + 4203 + ] + }, + { + "teal": 3601, + "source": "examples/reti/validatorRegistry.algo.ts:957", + "pc": [ + 4204 + ] + }, + { + "teal": 3602, + "source": "examples/reti/validatorRegistry.algo.ts:957", + "pc": [ + 4205, + 4206 + ] + }, + { + "teal": 3603, + "source": "examples/reti/validatorRegistry.algo.ts:957", + "pc": [ + 4207 + ] + }, + { + "teal": 3604, + "source": "examples/reti/validatorRegistry.algo.ts:958", + "pc": [ + 4208, + 4209 + ] + }, + { + "teal": 3605, + "source": "examples/reti/validatorRegistry.algo.ts:957", + "pc": [ + 4210 + ] + }, + { + "teal": 3606, + "source": "examples/reti/validatorRegistry.algo.ts:956", + "pc": [ + 4211, + 4212, + 4213 + ] + }, + { + "teal": 3611, + "source": "examples/reti/validatorRegistry.algo.ts:960", + "pc": [ + 4214, + 4215 + ] + }, + { + "teal": 3612, + "source": "examples/reti/validatorRegistry.algo.ts:960", + "pc": [ + 4216, + 4217 + ] + }, + { + "teal": 3613, + "source": "examples/reti/validatorRegistry.algo.ts:960", + "pc": [ + 4218, + 4219 + ] + }, + { + "teal": 3614, + "source": "examples/reti/validatorRegistry.algo.ts:960", + "pc": [ + 4220 + ] + }, + { + "teal": 3615, + "source": "examples/reti/validatorRegistry.algo.ts:960", + "pc": [ + 4221, + 4222 + ] + }, + { + "teal": 3616, + "source": "examples/reti/validatorRegistry.algo.ts:960", + "pc": [ + 4223 + ] + }, + { + "teal": 3617, + "source": "examples/reti/validatorRegistry.algo.ts:960", + "pc": [ + 4224, + 4225, + 4226 + ] + }, + { + "teal": 3618, + "source": "examples/reti/validatorRegistry.algo.ts:960", + "pc": [ + 4227, + 4228 + ] + }, + { + "teal": 3619, + "source": "examples/reti/validatorRegistry.algo.ts:960", + "pc": [ + 4229, + 4230 + ] + }, + { + "teal": 3620, + "source": "examples/reti/validatorRegistry.algo.ts:960", + "pc": [ + 4231 + ] + }, + { + "teal": 3621, + "source": "examples/reti/validatorRegistry.algo.ts:960", + "pc": [ + 4232, + 4233 + ] + }, + { + "teal": 3622, + "source": "examples/reti/validatorRegistry.algo.ts:960", + "pc": [ + 4234, + 4235 + ] + }, + { + "teal": 3623, + "source": "examples/reti/validatorRegistry.algo.ts:960", + "pc": [ + 4236 + ] + }, + { + "teal": 3624, + "source": "examples/reti/validatorRegistry.algo.ts:960", + "pc": [ + 4237 + ] + }, + { + "teal": 3625, + "source": "examples/reti/validatorRegistry.algo.ts:960", + "pc": [ + 4238, + 4239, + 4240 + ] + }, + { + "teal": 3634, + "source": "examples/reti/validatorRegistry.algo.ts:945", + "pc": [ + 4241, + 4242 + ] + }, + { + "teal": 3635, + "source": "examples/reti/validatorRegistry.algo.ts:945", + "pc": [ + 4243, + 4244 + ] + }, + { + "teal": 3636, + "source": "examples/reti/validatorRegistry.algo.ts:945", + "pc": [ + 4245 + ] + }, + { + "teal": 3637, + "source": "examples/reti/validatorRegistry.algo.ts:945", + "pc": [ + 4246, + 4247 + ] + }, + { + "teal": 3638, + "source": "examples/reti/validatorRegistry.algo.ts:945", + "pc": [ + 4248, + 4249, + 4250 + ] + }, + { + "teal": 3648, + "source": "examples/reti/validatorRegistry.algo.ts:968", + "pc": [ + 4251, + 4252 + ] + }, + { + "teal": 3649, + "source": "examples/reti/validatorRegistry.algo.ts:968", + "pc": [ + 4253, + 4254, + 4255 + ] + }, + { + "teal": 3650, + "source": "examples/reti/validatorRegistry.algo.ts:968", + "pc": [ + 4256, + 4257 + ] + }, + { + "teal": 3651, + "source": "examples/reti/validatorRegistry.algo.ts:968", + "pc": [ + 4258, + 4259, + 4260 + ] + }, + { + "teal": 3652, + "source": "examples/reti/validatorRegistry.algo.ts:968", + "pc": [ + 4261, + 4262 + ] + }, + { + "teal": 3653, + "source": "examples/reti/validatorRegistry.algo.ts:968", + "pc": [ + 4263 + ] + }, + { + "teal": 3654, + "source": "examples/reti/validatorRegistry.algo.ts:968", + "pc": [ + 4264 + ] + }, + { + "teal": 3655, + "source": "examples/reti/validatorRegistry.algo.ts:968", + "pc": [ + 4265, + 4266 + ] + }, + { + "teal": 3656, + "source": "examples/reti/validatorRegistry.algo.ts:968", + "pc": [ + 4267 + ] + }, + { + "teal": 3657, + "source": "examples/reti/validatorRegistry.algo.ts:968", + "pc": [ + 4268 + ] + }, + { + "teal": 3658, + "source": "examples/reti/validatorRegistry.algo.ts:968", + "pc": [ + 4269 + ] + }, + { + "teal": 3661, + "source": "examples/reti/validatorRegistry.algo.ts:967", + "errorMessage": "must stake at least the minimum for this pool", + "pc": [ + 4270 + ] + }, + { + "teal": 3665, + "source": "examples/reti/validatorRegistry.algo.ts:973", + "pc": [ + 4271, + 4272, + 4273 + ] + }, + { + "teal": 3666, + "source": "examples/reti/validatorRegistry.algo.ts:973", + "pc": [ + 4274, + 4275, + 4276 + ] + }, + { + "teal": 3667, + "source": "examples/reti/validatorRegistry.algo.ts:973", + "pc": [ + 4277, + 4278, + 4279 + ] + }, + { + "teal": 3668, + "source": "examples/reti/validatorRegistry.algo.ts:973", + "pc": [ + 4280, + 4281 + ] + }, + { + "teal": 3669, + "source": "examples/reti/validatorRegistry.algo.ts:973", + "pc": [ + 4282 + ] + }, + { + "teal": 3670, + "source": "examples/reti/validatorRegistry.algo.ts:973", + "pc": [ + 4283 + ] + }, + { + "teal": 3671, + "source": "examples/reti/validatorRegistry.algo.ts:973", + "pc": [ + 4284, + 4285 + ] + }, + { + "teal": 3672, + "source": "examples/reti/validatorRegistry.algo.ts:973", + "pc": [ + 4286 + ] + }, + { + "teal": 3673, + "source": "examples/reti/validatorRegistry.algo.ts:973", + "pc": [ + 4287, + 4288 + ] + }, + { + "teal": 3677, + "source": "examples/reti/validatorRegistry.algo.ts:974", + "pc": [ + 4289, + 4290, + 4291 + ] + }, + { + "teal": 3678, + "source": "examples/reti/validatorRegistry.algo.ts:974", + "pc": [ + 4292, + 4293 + ] + }, + { + "teal": 3679, + "source": "examples/reti/validatorRegistry.algo.ts:974", + "pc": [ + 4294, + 4295, + 4296 + ] + }, + { + "teal": 3680, + "source": "examples/reti/validatorRegistry.algo.ts:974", + "pc": [ + 4297, + 4298 + ] + }, + { + "teal": 3681, + "source": "examples/reti/validatorRegistry.algo.ts:974", + "pc": [ + 4299 + ] + }, + { + "teal": 3682, + "source": "examples/reti/validatorRegistry.algo.ts:974", + "pc": [ + 4300 + ] + }, + { + "teal": 3683, + "source": "examples/reti/validatorRegistry.algo.ts:974", + "pc": [ + 4301, + 4302 + ] + }, + { + "teal": 3684, + "source": "examples/reti/validatorRegistry.algo.ts:974", + "pc": [ + 4303 + ] + }, + { + "teal": 3685, + "source": "examples/reti/validatorRegistry.algo.ts:974", + "pc": [ + 4304 + ] + }, + { + "teal": 3686, + "source": "examples/reti/validatorRegistry.algo.ts:974", + "pc": [ + 4305, + 4306 + ] + }, + { + "teal": 3690, + "source": "examples/reti/validatorRegistry.algo.ts:975", + "pc": [ + 4307, + 4308 + ] + }, + { + "teal": 3691, + "source": "examples/reti/validatorRegistry.algo.ts:975", + "pc": [ + 4309, + 4310 + ] + }, + { + "teal": 3696, + "source": "examples/reti/validatorRegistry.algo.ts:975", + "pc": [ + 4311, + 4312 + ] + }, + { + "teal": 3697, + "source": "examples/reti/validatorRegistry.algo.ts:975", + "pc": [ + 4313, + 4314 + ] + }, + { + "teal": 3698, + "source": "examples/reti/validatorRegistry.algo.ts:975", + "pc": [ + 4315 + ] + }, + { + "teal": 3699, + "source": "examples/reti/validatorRegistry.algo.ts:975", + "pc": [ + 4316, + 4317, + 4318 + ] + }, + { + "teal": 3704, + "source": "examples/reti/validatorRegistry.algo.ts:976", + "pc": [ + 4319, + 4320 + ] + }, + { + "teal": 3705, + "source": "examples/reti/validatorRegistry.algo.ts:976", + "pc": [ + 4321, + 4322 + ] + }, + { + "teal": 3706, + "source": "examples/reti/validatorRegistry.algo.ts:976", + "pc": [ + 4323, + 4324 + ] + }, + { + "teal": 3707, + "source": "examples/reti/validatorRegistry.algo.ts:976", + "pc": [ + 4325 + ] + }, + { + "teal": 3708, + "source": "examples/reti/validatorRegistry.algo.ts:976", + "pc": [ + 4326, + 4327 + ] + }, + { + "teal": 3709, + "source": "examples/reti/validatorRegistry.algo.ts:976", + "pc": [ + 4328 + ] + }, + { + "teal": 3710, + "source": "examples/reti/validatorRegistry.algo.ts:976", + "pc": [ + 4329, + 4330 + ] + }, + { + "teal": 3711, + "source": "examples/reti/validatorRegistry.algo.ts:976", + "pc": [ + 4331 + ] + }, + { + "teal": 3712, + "source": "examples/reti/validatorRegistry.algo.ts:976", + "pc": [ + 4332 + ] + }, + { + "teal": 3713, + "source": "examples/reti/validatorRegistry.algo.ts:976", + "pc": [ + 4333, + 4334 + ] + }, + { + "teal": 3714, + "source": "examples/reti/validatorRegistry.algo.ts:976", + "pc": [ + 4335 + ] + }, + { + "teal": 3715, + "source": "examples/reti/validatorRegistry.algo.ts:976", + "pc": [ + 4336, + 4337 + ] + }, + { + "teal": 3716, + "source": "examples/reti/validatorRegistry.algo.ts:976", + "pc": [ + 4338 + ] + }, + { + "teal": 3717, + "source": "examples/reti/validatorRegistry.algo.ts:976", + "pc": [ + 4339, + 4340, + 4341 + ] + }, + { + "teal": 3726, + "source": "examples/reti/validatorRegistry.algo.ts:978", + "pc": [ + 4342, + 4343 + ] + }, + { + "teal": 3727, + "source": "examples/reti/validatorRegistry.algo.ts:978", + "pc": [ + 4344 + ] + }, + { + "teal": 3728, + "source": "examples/reti/validatorRegistry.algo.ts:978", + "pc": [ + 4345, + 4346 + ] + }, + { + "teal": 3729, + "source": "examples/reti/validatorRegistry.algo.ts:978", + "pc": [ + 4347, + 4348 + ] + }, + { + "teal": 3730, + "source": "examples/reti/validatorRegistry.algo.ts:978", + "pc": [ + 4349 + ] + }, + { + "teal": 3731, + "source": "examples/reti/validatorRegistry.algo.ts:978", + "pc": [ + 4350 + ] + }, + { + "teal": 3732, + "source": "examples/reti/validatorRegistry.algo.ts:978", + "pc": [ + 4351 + ] + }, + { + "teal": 3733, + "source": "examples/reti/validatorRegistry.algo.ts:978", + "pc": [ + 4352, + 4353 + ] + }, + { + "teal": 3734, + "source": "examples/reti/validatorRegistry.algo.ts:978", + "pc": [ + 4354, + 4355 + ] + }, + { + "teal": 3735, + "source": "examples/reti/validatorRegistry.algo.ts:978", + "pc": [ + 4356, + 4357 + ] + }, + { + "teal": 3736, + "source": "examples/reti/validatorRegistry.algo.ts:978", + "pc": [ + 4358 + ] + }, + { + "teal": 3737, + "source": "examples/reti/validatorRegistry.algo.ts:978", + "pc": [ + 4359, + 4360 + ] + }, + { + "teal": 3738, + "source": "examples/reti/validatorRegistry.algo.ts:978", + "pc": [ + 4361 + ] + }, + { + "teal": 3739, + "source": "examples/reti/validatorRegistry.algo.ts:978", + "pc": [ + 4362, + 4363 + ] + }, + { + "teal": 3740, + "source": "examples/reti/validatorRegistry.algo.ts:978", + "pc": [ + 4364 + ] + }, + { + "teal": 3741, + "source": "examples/reti/validatorRegistry.algo.ts:978", + "pc": [ + 4365 + ] + }, + { + "teal": 3742, + "source": "examples/reti/validatorRegistry.algo.ts:978", + "pc": [ + 4366 + ] + }, + { + "teal": 3743, + "source": "examples/reti/validatorRegistry.algo.ts:978", + "pc": [ + 4367 + ] + }, + { + "teal": 3744, + "source": "examples/reti/validatorRegistry.algo.ts:979", + "pc": [ + 4368, + 4369, + 4370 + ] + }, + { + "teal": 3745, + "source": "examples/reti/validatorRegistry.algo.ts:979", + "pc": [ + 4371, + 4372 + ] + }, + { + "teal": 3746, + "source": "examples/reti/validatorRegistry.algo.ts:979", + "pc": [ + 4373, + 4374 + ] + }, + { + "teal": 3747, + "source": "examples/reti/validatorRegistry.algo.ts:979", + "pc": [ + 4375 + ] + }, + { + "teal": 3748, + "source": "examples/reti/validatorRegistry.algo.ts:980", + "pc": [ + 4376, + 4377 + ] + }, + { + "teal": 3749, + "source": "examples/reti/validatorRegistry.algo.ts:980", + "pc": [ + 4378, + 4379 + ] + }, + { + "teal": 3750, + "source": "examples/reti/validatorRegistry.algo.ts:980", + "pc": [ + 4380 + ] + }, + { + "teal": 3751, + "source": "examples/reti/validatorRegistry.algo.ts:977", + "pc": [ + 4381 + ] + }, + { + "teal": 3752, + "source": "examples/reti/validatorRegistry.algo.ts:977", + "pc": [ + 4382, + 4383, + 4384 + ] + }, + { + "teal": 3759, + "source": "examples/reti/validatorRegistry.algo.ts:975", + "pc": [ + 4385, + 4386 + ] + }, + { + "teal": 3760, + "source": "examples/reti/validatorRegistry.algo.ts:975", + "pc": [ + 4387, + 4388 + ] + }, + { + "teal": 3761, + "source": "examples/reti/validatorRegistry.algo.ts:975", + "pc": [ + 4389 + ] + }, + { + "teal": 3762, + "source": "examples/reti/validatorRegistry.algo.ts:975", + "pc": [ + 4390, + 4391 + ] + }, + { + "teal": 3763, + "source": "examples/reti/validatorRegistry.algo.ts:975", + "pc": [ + 4392, + 4393, + 4394 + ] + }, + { + "teal": 3768, + "source": "examples/reti/validatorRegistry.algo.ts:985", + "pc": [ + 4395, + 4396 + ] + }, + { + "teal": 3769, + "source": "examples/reti/validatorRegistry.algo.ts:985", + "pc": [ + 4397 + ] + }, + { + "teal": 3770, + "source": "examples/reti/validatorRegistry.algo.ts:985", + "pc": [ + 4398, + 4399, + 4400, + 4401, + 4402, + 4403, + 4404, + 4405, + 4406, + 4407 + ] + }, + { + "teal": 3771, + "source": "examples/reti/validatorRegistry.algo.ts:985", + "pc": [ + 4408 + ] + }, + { + "teal": 3772, + "source": "examples/reti/validatorRegistry.algo.ts:985", + "pc": [ + 4409, + 4410, + 4411, + 4412, + 4413, + 4414, + 4415, + 4416, + 4417, + 4418 + ] + }, + { + "teal": 3773, + "source": "examples/reti/validatorRegistry.algo.ts:985", + "pc": [ + 4419 + ] + }, + { + "teal": 3774, + "source": "examples/reti/validatorRegistry.algo.ts:985", + "pc": [ + 4420, + 4421, + 4422 + ] + }, + { + "teal": 3775, + "source": "examples/reti/validatorRegistry.algo.ts:985", + "pc": [ + 4423, + 4424 + ] + }, + { + "teal": 3776, + "source": "examples/reti/validatorRegistry.algo.ts:985", + "pc": [ + 4425, + 4426 + ] + }, + { + "teal": 3777, + "source": "examples/reti/validatorRegistry.algo.ts:985", + "pc": [ + 4427 + ] + }, + { + "teal": 3778, + "source": "examples/reti/validatorRegistry.algo.ts:985", + "pc": [ + 4428, + 4429 + ] + }, + { + "teal": 3779, + "source": "examples/reti/validatorRegistry.algo.ts:985", + "pc": [ + 4430, + 4431 + ] + }, + { + "teal": 3780, + "source": "examples/reti/validatorRegistry.algo.ts:985", + "pc": [ + 4432 + ] + }, + { + "teal": 3781, + "source": "examples/reti/validatorRegistry.algo.ts:985", + "pc": [ + 4433 + ] + }, + { + "teal": 3785, + "source": "examples/reti/validatorRegistry.algo.ts:925", + "pc": [ + 4434, + 4435 + ] + }, + { + "teal": 3788, + "source": "examples/reti/validatorRegistry.algo.ts:925", + "pc": [ + 4436, + 4437 + ] + }, + { + "teal": 3789, + "source": "examples/reti/validatorRegistry.algo.ts:925", + "pc": [ + 4438 + ] + }, + { + "teal": 3794, + "source": "examples/reti/validatorRegistry.algo.ts:999", + "pc": [ + 4439, + 4440, + 4441 + ] + }, + { + "teal": 3795, + "source": "examples/reti/validatorRegistry.algo.ts:999", + "pc": [ + 4442 + ] + }, + { + "teal": 3798, + "source": "examples/reti/validatorRegistry.algo.ts:999", + "pc": [ + 4443, + 4444, + 4445 + ] + }, + { + "teal": 3799, + "source": "examples/reti/validatorRegistry.algo.ts:999", + "pc": [ + 4446 + ] + }, + { + "teal": 3802, + "source": "examples/reti/validatorRegistry.algo.ts:999", + "pc": [ + 4447, + 4448, + 4449 + ] + }, + { + "teal": 3803, + "source": "examples/reti/validatorRegistry.algo.ts:999", + "pc": [ + 4450 + ] + }, + { + "teal": 3806, + "source": "examples/reti/validatorRegistry.algo.ts:999", + "pc": [ + 4451, + 4452, + 4453 + ] + }, + { + "teal": 3807, + "source": "examples/reti/validatorRegistry.algo.ts:999", + "pc": [ + 4454, + 4455 + ] + }, + { + "teal": 3808, + "source": "examples/reti/validatorRegistry.algo.ts:999", + "pc": [ + 4456 + ] + }, + { + "teal": 3822, + "source": "examples/reti/validatorRegistry.algo.ts:999", + "pc": [ + 4457, + 4458, + 4459 + ] + }, + { + "teal": 3825, + "source": "examples/reti/validatorRegistry.algo.ts:999", + "pc": [ + 4460, + 4461 + ] + }, + { + "teal": 3826, + "source": "examples/reti/validatorRegistry.algo.ts:999", + "pc": [ + 4462, + 4463 + ] + }, + { + "teal": 3834, + "source": "examples/reti/validatorRegistry.algo.ts:1002", + "pc": [ + 4464, + 4465 + ] + }, + { + "teal": 3835, + "source": "examples/reti/validatorRegistry.algo.ts:1002", + "pc": [ + 4466, + 4467 + ] + }, + { + "teal": 3836, + "source": "examples/reti/validatorRegistry.algo.ts:1002", + "pc": [ + 4468, + 4469 + ] + }, + { + "teal": 3837, + "source": "examples/reti/validatorRegistry.algo.ts:1002", + "pc": [ + 4470, + 4471, + 4472 + ] + }, + { + "teal": 3838, + "source": "examples/reti/validatorRegistry.algo.ts:1002", + "pc": [ + 4473, + 4474 + ] + }, + { + "teal": 3839, + "source": "examples/reti/validatorRegistry.algo.ts:1002", + "pc": [ + 4475 + ] + }, + { + "teal": 3840, + "source": "examples/reti/validatorRegistry.algo.ts:1002", + "pc": [ + 4476 + ] + }, + { + "teal": 3841, + "source": "examples/reti/validatorRegistry.algo.ts:1002", + "pc": [ + 4477, + 4478 + ] + }, + { + "teal": 3842, + "source": "examples/reti/validatorRegistry.algo.ts:1002", + "pc": [ + 4479 + ] + }, + { + "teal": 3843, + "source": "examples/reti/validatorRegistry.algo.ts:1002", + "pc": [ + 4480 + ] + }, + { + "teal": 3844, + "source": "examples/reti/validatorRegistry.algo.ts:1002", + "pc": [ + 4481 + ] + }, + { + "teal": 3845, + "source": "examples/reti/validatorRegistry.algo.ts:1002", + "pc": [ + 4482, + 4483, + 4484 + ] + }, + { + "teal": 3846, + "source": "examples/reti/validatorRegistry.algo.ts:1003", + "pc": [ + 4485, + 4486 + ] + }, + { + "teal": 3847, + "source": "examples/reti/validatorRegistry.algo.ts:1003", + "pc": [ + 4487, + 4488 + ] + }, + { + "teal": 3848, + "source": "examples/reti/validatorRegistry.algo.ts:1003", + "pc": [ + 4489, + 4490 + ] + }, + { + "teal": 3849, + "source": "examples/reti/validatorRegistry.algo.ts:1003", + "pc": [ + 4491, + 4492, + 4493 + ] + }, + { + "teal": 3850, + "source": "examples/reti/validatorRegistry.algo.ts:1003", + "pc": [ + 4494, + 4495 + ] + }, + { + "teal": 3851, + "source": "examples/reti/validatorRegistry.algo.ts:1003", + "pc": [ + 4496 + ] + }, + { + "teal": 3852, + "source": "examples/reti/validatorRegistry.algo.ts:1003", + "pc": [ + 4497 + ] + }, + { + "teal": 3853, + "source": "examples/reti/validatorRegistry.algo.ts:1003", + "pc": [ + 4498, + 4499 + ] + }, + { + "teal": 3854, + "source": "examples/reti/validatorRegistry.algo.ts:1003", + "pc": [ + 4500 + ] + }, + { + "teal": 3855, + "source": "examples/reti/validatorRegistry.algo.ts:1003", + "pc": [ + 4501 + ] + }, + { + "teal": 3856, + "source": "examples/reti/validatorRegistry.algo.ts:1002", + "pc": [ + 4502 + ] + }, + { + "teal": 3860, + "source": "examples/reti/validatorRegistry.algo.ts:1001", + "errorMessage": "can only be called by owner or manager of validator", + "pc": [ + 4503 + ] + }, + { + "teal": 3864, + "source": "examples/reti/validatorRegistry.algo.ts:1007", + "pc": [ + 4504, + 4505, + 4506 + ] + }, + { + "teal": 3865, + "source": "examples/reti/validatorRegistry.algo.ts:1007", + "pc": [ + 4507, + 4508, + 4509 + ] + }, + { + "teal": 3866, + "source": "examples/reti/validatorRegistry.algo.ts:1007", + "pc": [ + 4510, + 4511, + 4512 + ] + }, + { + "teal": 3867, + "source": "examples/reti/validatorRegistry.algo.ts:1007", + "pc": [ + 4513, + 4514 + ] + }, + { + "teal": 3868, + "source": "examples/reti/validatorRegistry.algo.ts:1007", + "pc": [ + 4515 + ] + }, + { + "teal": 3869, + "source": "examples/reti/validatorRegistry.algo.ts:1007", + "pc": [ + 4516 + ] + }, + { + "teal": 3870, + "source": "examples/reti/validatorRegistry.algo.ts:1007", + "pc": [ + 4517, + 4518 + ] + }, + { + "teal": 3871, + "source": "examples/reti/validatorRegistry.algo.ts:1007", + "pc": [ + 4519 + ] + }, + { + "teal": 3872, + "source": "examples/reti/validatorRegistry.algo.ts:1007", + "pc": [ + 4520, + 4521 + ] + }, + { + "teal": 3876, + "source": "examples/reti/validatorRegistry.algo.ts:1008", + "pc": [ + 4522, + 4523 + ] + }, + { + "teal": 3877, + "source": "examples/reti/validatorRegistry.algo.ts:1008", + "pc": [ + 4524, + 4525 + ] + }, + { + "teal": 3878, + "source": "examples/reti/validatorRegistry.algo.ts:1008", + "pc": [ + 4526 + ] + }, + { + "teal": 3879, + "source": "examples/reti/validatorRegistry.algo.ts:1008", + "pc": [ + 4527 + ] + }, + { + "teal": 3880, + "source": "examples/reti/validatorRegistry.algo.ts:1008", + "pc": [ + 4528, + 4529, + 4530 + ] + }, + { + "teal": 3881, + "source": "examples/reti/validatorRegistry.algo.ts:1008", + "pc": [ + 4531, + 4532 + ] + }, + { + "teal": 3882, + "source": "examples/reti/validatorRegistry.algo.ts:1008", + "pc": [ + 4533, + 4534 + ] + }, + { + "teal": 3883, + "source": "examples/reti/validatorRegistry.algo.ts:1008", + "pc": [ + 4535 + ] + }, + { + "teal": 3884, + "source": "examples/reti/validatorRegistry.algo.ts:1008", + "pc": [ + 4536 + ] + }, + { + "teal": 3888, + "source": "examples/reti/validatorRegistry.algo.ts:1008", + "errorMessage": "node number out of allowable range", + "pc": [ + 4537 + ] + }, + { + "teal": 3892, + "source": "examples/reti/validatorRegistry.algo.ts:1010", + "pc": [ + 4538, + 4539 + ] + }, + { + "teal": 3893, + "source": "examples/reti/validatorRegistry.algo.ts:1010", + "pc": [ + 4540, + 4541 + ] + }, + { + "teal": 3898, + "source": "examples/reti/validatorRegistry.algo.ts:1010", + "pc": [ + 4542, + 4543 + ] + }, + { + "teal": 3899, + "source": "examples/reti/validatorRegistry.algo.ts:1010", + "pc": [ + 4544, + 4545 + ] + }, + { + "teal": 3900, + "source": "examples/reti/validatorRegistry.algo.ts:1010", + "pc": [ + 4546 + ] + }, + { + "teal": 3901, + "source": "examples/reti/validatorRegistry.algo.ts:1010", + "pc": [ + 4547, + 4548, + 4549 + ] + }, + { + "teal": 3905, + "source": "examples/reti/validatorRegistry.algo.ts:1011", + "pc": [ + 4550, + 4551 + ] + }, + { + "teal": 3906, + "source": "examples/reti/validatorRegistry.algo.ts:1011", + "pc": [ + 4552, + 4553 + ] + }, + { + "teal": 3911, + "source": "examples/reti/validatorRegistry.algo.ts:1011", + "pc": [ + 4554, + 4555 + ] + }, + { + "teal": 3912, + "source": "examples/reti/validatorRegistry.algo.ts:1011", + "pc": [ + 4556, + 4557 + ] + }, + { + "teal": 3913, + "source": "examples/reti/validatorRegistry.algo.ts:1011", + "pc": [ + 4558 + ] + }, + { + "teal": 3914, + "source": "examples/reti/validatorRegistry.algo.ts:1011", + "pc": [ + 4559, + 4560, + 4561 + ] + }, + { + "teal": 3919, + "source": "examples/reti/validatorRegistry.algo.ts:1012", + "pc": [ + 4562, + 4563 + ] + }, + { + "teal": 3920, + "source": "examples/reti/validatorRegistry.algo.ts:1012", + "pc": [ + 4564, + 4565 + ] + }, + { + "teal": 3921, + "source": "examples/reti/validatorRegistry.algo.ts:1012", + "pc": [ + 4566, + 4567 + ] + }, + { + "teal": 3922, + "source": "examples/reti/validatorRegistry.algo.ts:1012", + "pc": [ + 4568, + 4569 + ] + }, + { + "teal": 3923, + "source": "examples/reti/validatorRegistry.algo.ts:1012", + "pc": [ + 4570 + ] + }, + { + "teal": 3924, + "source": "examples/reti/validatorRegistry.algo.ts:1012", + "pc": [ + 4571 + ] + }, + { + "teal": 3925, + "source": "examples/reti/validatorRegistry.algo.ts:1012", + "pc": [ + 4572, + 4573 + ] + }, + { + "teal": 3926, + "source": "examples/reti/validatorRegistry.algo.ts:1012", + "pc": [ + 4574 + ] + }, + { + "teal": 3927, + "source": "examples/reti/validatorRegistry.algo.ts:1012", + "pc": [ + 4575, + 4576 + ] + }, + { + "teal": 3928, + "source": "examples/reti/validatorRegistry.algo.ts:1012", + "pc": [ + 4577, + 4578 + ] + }, + { + "teal": 3929, + "source": "examples/reti/validatorRegistry.algo.ts:1012", + "pc": [ + 4579 + ] + }, + { + "teal": 3930, + "source": "examples/reti/validatorRegistry.algo.ts:1012", + "pc": [ + 4580 + ] + }, + { + "teal": 3931, + "source": "examples/reti/validatorRegistry.algo.ts:1012", + "pc": [ + 4581, + 4582 + ] + }, + { + "teal": 3932, + "source": "examples/reti/validatorRegistry.algo.ts:1012", + "pc": [ + 4583 + ] + }, + { + "teal": 3933, + "source": "examples/reti/validatorRegistry.algo.ts:1012", + "pc": [ + 4584 + ] + }, + { + "teal": 3934, + "source": "examples/reti/validatorRegistry.algo.ts:1012", + "pc": [ + 4585, + 4586 + ] + }, + { + "teal": 3935, + "source": "examples/reti/validatorRegistry.algo.ts:1012", + "pc": [ + 4587 + ] + }, + { + "teal": 3936, + "source": "examples/reti/validatorRegistry.algo.ts:1012", + "pc": [ + 4588, + 4589, + 4590 + ] + }, + { + "teal": 3941, + "source": "examples/reti/validatorRegistry.algo.ts:1013", + "pc": [ + 4591, + 4592 + ] + }, + { + "teal": 3942, + "source": "examples/reti/validatorRegistry.algo.ts:1013", + "pc": [ + 4593, + 4594 + ] + }, + { + "teal": 3943, + "source": "examples/reti/validatorRegistry.algo.ts:1013", + "pc": [ + 4595 + ] + }, + { + "teal": 3944, + "source": "examples/reti/validatorRegistry.algo.ts:1013", + "pc": [ + 4596, + 4597 + ] + }, + { + "teal": 3945, + "source": "examples/reti/validatorRegistry.algo.ts:1013", + "pc": [ + 4598 + ] + }, + { + "teal": 3948, + "source": "examples/reti/validatorRegistry.algo.ts:1013", + "errorMessage": "can't move to same node", + "pc": [ + 4599 + ] + }, + { + "teal": 3952, + "source": "examples/reti/validatorRegistry.algo.ts:1015", + "pc": [ + 4600, + 4601, + 4602 + ] + }, + { + "teal": 3953, + "source": "examples/reti/validatorRegistry.algo.ts:1015", + "pc": [ + 4603, + 4604 + ] + }, + { + "teal": 3954, + "source": "examples/reti/validatorRegistry.algo.ts:1015", + "pc": [ + 4605, + 4606 + ] + }, + { + "teal": 3955, + "source": "examples/reti/validatorRegistry.algo.ts:1015", + "pc": [ + 4607 + ] + }, + { + "teal": 3956, + "source": "examples/reti/validatorRegistry.algo.ts:1015", + "pc": [ + 4608 + ] + }, + { + "teal": 3957, + "source": "examples/reti/validatorRegistry.algo.ts:1015", + "pc": [ + 4609, + 4610 + ] + }, + { + "teal": 3958, + "source": "examples/reti/validatorRegistry.algo.ts:1015", + "pc": [ + 4611 + ] + }, + { + "teal": 3959, + "source": "examples/reti/validatorRegistry.algo.ts:1015", + "pc": [ + 4612, + 4613 + ] + }, + { + "teal": 3960, + "source": "examples/reti/validatorRegistry.algo.ts:1015", + "pc": [ + 4614, + 4615 + ] + }, + { + "teal": 3961, + "source": "examples/reti/validatorRegistry.algo.ts:1015", + "pc": [ + 4616 + ] + }, + { + "teal": 3962, + "source": "examples/reti/validatorRegistry.algo.ts:1015", + "pc": [ + 4617 + ] + }, + { + "teal": 3963, + "source": "examples/reti/validatorRegistry.algo.ts:1015", + "pc": [ + 4618, + 4619, + 4620, + 4621, + 4622, + 4623, + 4624, + 4625, + 4626, + 4627 + ] + }, + { + "teal": 3964, + "source": "examples/reti/validatorRegistry.algo.ts:1015", + "pc": [ + 4628, + 4629, + 4630 + ] + }, + { + "teal": 3965, + "source": "examples/reti/validatorRegistry.algo.ts:1015", + "pc": [ + 4631, + 4632 + ] + }, + { + "teal": 3966, + "source": "examples/reti/validatorRegistry.algo.ts:1015", + "pc": [ + 4633 + ] + }, + { + "teal": 3967, + "source": "examples/reti/validatorRegistry.algo.ts:1015", + "pc": [ + 4634 + ] + }, + { + "teal": 3968, + "source": "examples/reti/validatorRegistry.algo.ts:1015", + "pc": [ + 4635, + 4636 + ] + }, + { + "teal": 3969, + "source": "examples/reti/validatorRegistry.algo.ts:1015", + "pc": [ + 4637 + ] + }, + { + "teal": 3975, + "source": "examples/reti/validatorRegistry.algo.ts:1018", + "pc": [ + 4638 + ] + }, + { + "teal": 3976, + "source": "examples/reti/validatorRegistry.algo.ts:1018", + "pc": [ + 4639, + 4640 + ] + }, + { + "teal": 3977, + "source": "examples/reti/validatorRegistry.algo.ts:1018", + "pc": [ + 4641, + 4642 + ] + }, + { + "teal": 3978, + "source": "examples/reti/validatorRegistry.algo.ts:1018", + "pc": [ + 4643, + 4644, + 4645, + 4646, + 4647, + 4648 + ] + }, + { + "teal": 3979, + "source": "examples/reti/validatorRegistry.algo.ts:1018", + "pc": [ + 4649, + 4650 + ] + }, + { + "teal": 3983, + "source": "examples/reti/validatorRegistry.algo.ts:1019", + "pc": [ + 4651, + 4652 + ] + }, + { + "teal": 3984, + "source": "examples/reti/validatorRegistry.algo.ts:1019", + "pc": [ + 4653, + 4654 + ] + }, + { + "teal": 3987, + "source": "examples/reti/validatorRegistry.algo.ts:1018", + "pc": [ + 4655, + 4656 + ] + }, + { + "teal": 3988, + "source": "examples/reti/validatorRegistry.algo.ts:1018", + "pc": [ + 4657, + 4658 + ] + }, + { + "teal": 3991, + "source": "examples/reti/validatorRegistry.algo.ts:1018", + "pc": [ + 4659 + ] + }, + { + "teal": 3995, + "source": "examples/reti/validatorRegistry.algo.ts:1023", + "pc": [ + 4660, + 4661 + ] + }, + { + "teal": 3996, + "source": "examples/reti/validatorRegistry.algo.ts:1023", + "pc": [ + 4662, + 4663 + ] + }, + { + "teal": 3997, + "source": "examples/reti/validatorRegistry.algo.ts:1023", + "pc": [ + 4664, + 4665 + ] + }, + { + "teal": 3998, + "source": "examples/reti/validatorRegistry.algo.ts:1023", + "pc": [ + 4666, + 4667, + 4668 + ] + }, + { + "teal": 4002, + "source": "examples/reti/validatorRegistry.algo.ts:1024", + "pc": [ + 4669 + ] + }, + { + "teal": 4009, + "source": "examples/reti/validatorRegistry.algo.ts:1011", + "pc": [ + 4670, + 4671 + ] + }, + { + "teal": 4010, + "source": "examples/reti/validatorRegistry.algo.ts:1011", + "pc": [ + 4672, + 4673 + ] + }, + { + "teal": 4011, + "source": "examples/reti/validatorRegistry.algo.ts:1011", + "pc": [ + 4674 + ] + }, + { + "teal": 4012, + "source": "examples/reti/validatorRegistry.algo.ts:1011", + "pc": [ + 4675, + 4676 + ] + }, + { + "teal": 4013, + "source": "examples/reti/validatorRegistry.algo.ts:1011", + "pc": [ + 4677, + 4678, + 4679 + ] + }, + { + "teal": 4020, + "source": "examples/reti/validatorRegistry.algo.ts:1010", + "pc": [ + 4680, + 4681 + ] + }, + { + "teal": 4021, + "source": "examples/reti/validatorRegistry.algo.ts:1010", + "pc": [ + 4682, + 4683 + ] + }, + { + "teal": 4022, + "source": "examples/reti/validatorRegistry.algo.ts:1010", + "pc": [ + 4684 + ] + }, + { + "teal": 4023, + "source": "examples/reti/validatorRegistry.algo.ts:1010", + "pc": [ + 4685, + 4686 + ] + }, + { + "teal": 4024, + "source": "examples/reti/validatorRegistry.algo.ts:1010", + "pc": [ + 4687, + 4688, + 4689 + ] + }, + { + "teal": 4028, + "source": "examples/reti/validatorRegistry.algo.ts:1028", + "errorMessage": "couldn't find pool app id in nodes to move", + "pc": [ + 4690 + ] + }, + { + "teal": 4029, + "source": "examples/reti/validatorRegistry.algo.ts:999", + "pc": [ + 4691 + ] + }, + { + "teal": 4034, + "source": "examples/reti/validatorRegistry.algo.ts:1042", + "pc": [ + 4692, + 4693, + 4694, + 4695, + 4696, + 4697 + ] + }, + { + "teal": 4037, + "source": "examples/reti/validatorRegistry.algo.ts:1042", + "pc": [ + 4698, + 4699, + 4700 + ] + }, + { + "teal": 4038, + "source": "examples/reti/validatorRegistry.algo.ts:1042", + "pc": [ + 4701 + ] + }, + { + "teal": 4039, + "source": "examples/reti/validatorRegistry.algo.ts:1042", + "pc": [ + 4702 + ] + }, + { + "teal": 4040, + "source": "examples/reti/validatorRegistry.algo.ts:1042", + "pc": [ + 4703, + 4704 + ] + }, + { + "teal": 4041, + "source": "examples/reti/validatorRegistry.algo.ts:1042", + "pc": [ + 4705 + ] + }, + { + "teal": 4044, + "source": "examples/reti/validatorRegistry.algo.ts:1042", + "errorMessage": "argument 0 (receiver) for emptyTokenRewards must be a address", + "pc": [ + 4706 + ] + }, + { + "teal": 4047, + "source": "examples/reti/validatorRegistry.algo.ts:1042", + "pc": [ + 4707, + 4708, + 4709 + ] + }, + { + "teal": 4048, + "source": "examples/reti/validatorRegistry.algo.ts:1042", + "pc": [ + 4710 + ] + }, + { + "teal": 4051, + "source": "examples/reti/validatorRegistry.algo.ts:1042", + "pc": [ + 4711, + 4712, + 4713 + ] + }, + { + "teal": 4052, + "source": "examples/reti/validatorRegistry.algo.ts:1042", + "pc": [ + 4714 + ] + }, + { + "teal": 4053, + "source": "examples/reti/validatorRegistry.algo.ts:1042", + "pc": [ + 4715 + ] + }, + { + "teal": 4054, + "source": "examples/reti/validatorRegistry.algo.ts:1042", + "pc": [ + 4716 + ] + }, + { + "teal": 4055, + "source": "examples/reti/validatorRegistry.algo.ts:1042", + "pc": [ + 4717, + 4718 + ] + }, + { + "teal": 4056, + "source": "examples/reti/validatorRegistry.algo.ts:1042", + "pc": [ + 4719 + ] + }, + { + "teal": 4070, + "source": "examples/reti/validatorRegistry.algo.ts:1042", + "pc": [ + 4720, + 4721, + 4722 + ] + }, + { + "teal": 4073, + "source": "examples/reti/validatorRegistry.algo.ts:1042", + "pc": [ + 4723, + 4724 + ] + }, + { + "teal": 4074, + "source": "examples/reti/validatorRegistry.algo.ts:1042", + "pc": [ + 4725, + 4726 + ] + }, + { + "teal": 4081, + "source": "examples/reti/validatorRegistry.algo.ts:1044", + "pc": [ + 4727, + 4728 + ] + }, + { + "teal": 4082, + "source": "examples/reti/validatorRegistry.algo.ts:1044", + "pc": [ + 4729, + 4730 + ] + }, + { + "teal": 4083, + "source": "examples/reti/validatorRegistry.algo.ts:1044", + "pc": [ + 4731, + 4732 + ] + }, + { + "teal": 4084, + "source": "examples/reti/validatorRegistry.algo.ts:1044", + "pc": [ + 4733, + 4734, + 4735 + ] + }, + { + "teal": 4085, + "source": "examples/reti/validatorRegistry.algo.ts:1044", + "pc": [ + 4736, + 4737 + ] + }, + { + "teal": 4086, + "source": "examples/reti/validatorRegistry.algo.ts:1044", + "pc": [ + 4738 + ] + }, + { + "teal": 4087, + "source": "examples/reti/validatorRegistry.algo.ts:1044", + "pc": [ + 4739 + ] + }, + { + "teal": 4088, + "source": "examples/reti/validatorRegistry.algo.ts:1044", + "pc": [ + 4740, + 4741 + ] + }, + { + "teal": 4089, + "source": "examples/reti/validatorRegistry.algo.ts:1044", + "pc": [ + 4742 + ] + }, + { + "teal": 4090, + "source": "examples/reti/validatorRegistry.algo.ts:1044", + "pc": [ + 4743 + ] + }, + { + "teal": 4093, + "source": "examples/reti/validatorRegistry.algo.ts:1043", + "errorMessage": "can only be called by validator owner", + "pc": [ + 4744 + ] + }, + { + "teal": 4097, + "source": "examples/reti/validatorRegistry.algo.ts:1047", + "pc": [ + 4745, + 4746, + 4747 + ] + }, + { + "teal": 4098, + "source": "examples/reti/validatorRegistry.algo.ts:1047", + "pc": [ + 4748, + 4749 + ] + }, + { + "teal": 4099, + "source": "examples/reti/validatorRegistry.algo.ts:1047", + "pc": [ + 4750, + 4751, + 4752 + ] + }, + { + "teal": 4100, + "source": "examples/reti/validatorRegistry.algo.ts:1047", + "pc": [ + 4753, + 4754 + ] + }, + { + "teal": 4101, + "source": "examples/reti/validatorRegistry.algo.ts:1047", + "pc": [ + 4755 + ] + }, + { + "teal": 4102, + "source": "examples/reti/validatorRegistry.algo.ts:1047", + "pc": [ + 4756 + ] + }, + { + "teal": 4103, + "source": "examples/reti/validatorRegistry.algo.ts:1047", + "pc": [ + 4757, + 4758 + ] + }, + { + "teal": 4104, + "source": "examples/reti/validatorRegistry.algo.ts:1047", + "pc": [ + 4759 + ] + }, + { + "teal": 4105, + "source": "examples/reti/validatorRegistry.algo.ts:1047", + "pc": [ + 4760 + ] + }, + { + "teal": 4106, + "source": "examples/reti/validatorRegistry.algo.ts:1047", + "pc": [ + 4761, + 4762 + ] + }, + { + "teal": 4110, + "source": "examples/reti/validatorRegistry.algo.ts:1048", + "pc": [ + 4763, + 4764, + 4765 + ] + }, + { + "teal": 4111, + "source": "examples/reti/validatorRegistry.algo.ts:1048", + "pc": [ + 4766, + 4767 + ] + }, + { + "teal": 4112, + "source": "examples/reti/validatorRegistry.algo.ts:1048", + "pc": [ + 4768, + 4769, + 4770 + ] + }, + { + "teal": 4113, + "source": "examples/reti/validatorRegistry.algo.ts:1048", + "pc": [ + 4771, + 4772 + ] + }, + { + "teal": 4114, + "source": "examples/reti/validatorRegistry.algo.ts:1048", + "pc": [ + 4773 + ] + }, + { + "teal": 4115, + "source": "examples/reti/validatorRegistry.algo.ts:1048", + "pc": [ + 4774 + ] + }, + { + "teal": 4116, + "source": "examples/reti/validatorRegistry.algo.ts:1048", + "pc": [ + 4775, + 4776 + ] + }, + { + "teal": 4117, + "source": "examples/reti/validatorRegistry.algo.ts:1048", + "pc": [ + 4777 + ] + }, + { + "teal": 4118, + "source": "examples/reti/validatorRegistry.algo.ts:1048", + "pc": [ + 4778 + ] + }, + { + "teal": 4119, + "source": "examples/reti/validatorRegistry.algo.ts:1048", + "pc": [ + 4779, + 4780 + ] + }, + { + "teal": 4123, + "source": "examples/reti/validatorRegistry.algo.ts:1049", + "pc": [ + 4781, + 4782 + ] + }, + { + "teal": 4124, + "source": "examples/reti/validatorRegistry.algo.ts:1049", + "pc": [ + 4783, + 4784 + ] + }, + { + "teal": 4125, + "source": "examples/reti/validatorRegistry.algo.ts:1049", + "pc": [ + 4785 + ] + }, + { + "teal": 4128, + "source": "examples/reti/validatorRegistry.algo.ts:1049", + "errorMessage": "this validator doesn't have a reward token defined", + "pc": [ + 4786 + ] + }, + { + "teal": 4132, + "source": "examples/reti/validatorRegistry.algo.ts:1050", + "pc": [ + 4787, + 4788, + 4789 + ] + }, + { + "teal": 4133, + "source": "examples/reti/validatorRegistry.algo.ts:1050", + "pc": [ + 4790, + 4791 + ] + }, + { + "teal": 4134, + "source": "examples/reti/validatorRegistry.algo.ts:1050", + "pc": [ + 4792, + 4793, + 4794 + ] + }, + { + "teal": 4135, + "source": "examples/reti/validatorRegistry.algo.ts:1050", + "pc": [ + 4795, + 4796 + ] + }, + { + "teal": 4136, + "source": "examples/reti/validatorRegistry.algo.ts:1050", + "pc": [ + 4797 + ] + }, + { + "teal": 4137, + "source": "examples/reti/validatorRegistry.algo.ts:1050", + "pc": [ + 4798 + ] + }, + { + "teal": 4138, + "source": "examples/reti/validatorRegistry.algo.ts:1050", + "pc": [ + 4799, + 4800 + ] + }, + { + "teal": 4139, + "source": "examples/reti/validatorRegistry.algo.ts:1050", + "pc": [ + 4801 + ] + }, + { + "teal": 4140, + "source": "examples/reti/validatorRegistry.algo.ts:1050", + "pc": [ + 4802 + ] + }, + { + "teal": 4141, + "source": "examples/reti/validatorRegistry.algo.ts:1050", + "pc": [ + 4803, + 4804 + ] + }, + { + "teal": 4145, + "source": "examples/reti/validatorRegistry.algo.ts:1052", + "pc": [ + 4805, + 4806 + ] + }, + { + "teal": 4146, + "source": "examples/reti/validatorRegistry.algo.ts:1052", + "pc": [ + 4807, + 4808 + ] + }, + { + "teal": 4147, + "source": "examples/reti/validatorRegistry.algo.ts:1052", + "pc": [ + 4809 + ] + }, + { + "teal": 4148, + "source": "examples/reti/validatorRegistry.algo.ts:1052", + "pc": [ + 4810, + 4811 + ] + }, + { + "teal": 4149, + "source": "examples/reti/validatorRegistry.algo.ts:1052", + "pc": [ + 4812, + 4813 + ] + }, + { + "teal": 4150, + "source": "examples/reti/validatorRegistry.algo.ts:1052", + "pc": [ + 4814 + ] + }, + { + "teal": 4151, + "source": "examples/reti/validatorRegistry.algo.ts:1052", + "pc": [ + 4815, + 4816 + ] + }, + { + "teal": 4152, + "source": "examples/reti/validatorRegistry.algo.ts:1052", + "pc": [ + 4817 + ] + }, + { + "teal": 4153, + "source": "examples/reti/validatorRegistry.algo.ts:1052", + "pc": [ + 4818, + 4819 + ] + }, + { + "teal": 4160, + "source": "examples/reti/validatorRegistry.algo.ts:1055", + "pc": [ + 4820 + ] + }, + { + "teal": 4161, + "source": "examples/reti/validatorRegistry.algo.ts:1055", + "pc": [ + 4821, + 4822 + ] + }, + { + "teal": 4162, + "source": "examples/reti/validatorRegistry.algo.ts:1055", + "pc": [ + 4823, + 4824 + ] + }, + { + "teal": 4163, + "source": "examples/reti/validatorRegistry.algo.ts:1055", + "pc": [ + 4825, + 4826, + 4827, + 4828, + 4829, + 4830 + ] + }, + { + "teal": 4164, + "source": "examples/reti/validatorRegistry.algo.ts:1055", + "pc": [ + 4831, + 4832 + ] + }, + { + "teal": 4168, + "source": "examples/reti/validatorRegistry.algo.ts:1056", + "pc": [ + 4833, + 4834 + ] + }, + { + "teal": 4169, + "source": "examples/reti/validatorRegistry.algo.ts:1056", + "pc": [ + 4835, + 4836 + ] + }, + { + "teal": 4173, + "source": "examples/reti/validatorRegistry.algo.ts:1057", + "pc": [ + 4837, + 4838 + ] + }, + { + "teal": 4174, + "source": "examples/reti/validatorRegistry.algo.ts:1057", + "pc": [ + 4839, + 4840 + ] + }, + { + "teal": 4175, + "source": "examples/reti/validatorRegistry.algo.ts:1057", + "pc": [ + 4841, + 4842 + ] + }, + { + "teal": 4176, + "source": "examples/reti/validatorRegistry.algo.ts:1057", + "pc": [ + 4843 + ] + }, + { + "teal": 4177, + "source": "examples/reti/validatorRegistry.algo.ts:1057", + "pc": [ + 4844, + 4845 + ] + }, + { + "teal": 4178, + "source": "examples/reti/validatorRegistry.algo.ts:1057", + "pc": [ + 4846, + 4847 + ] + }, + { + "teal": 4179, + "source": "examples/reti/validatorRegistry.algo.ts:1057", + "pc": [ + 4848 + ] + }, + { + "teal": 4180, + "source": "examples/reti/validatorRegistry.algo.ts:1057", + "pc": [ + 4849, + 4850 + ] + }, + { + "teal": 4183, + "source": "examples/reti/validatorRegistry.algo.ts:1055", + "pc": [ + 4851, + 4852 + ] + }, + { + "teal": 4184, + "source": "examples/reti/validatorRegistry.algo.ts:1055", + "pc": [ + 4853, + 4854 + ] + }, + { + "teal": 4187, + "source": "examples/reti/validatorRegistry.algo.ts:1055", + "pc": [ + 4855 + ] + }, + { + "teal": 4194, + "source": "examples/reti/validatorRegistry.algo.ts:1060", + "pc": [ + 4856, + 4857 + ] + }, + { + "teal": 4195, + "source": "examples/reti/validatorRegistry.algo.ts:1060", + "pc": [ + 4858, + 4859 + ] + }, + { + "teal": 4196, + "source": "examples/reti/validatorRegistry.algo.ts:1060", + "pc": [ + 4860 + ] + }, + { + "teal": 4197, + "source": "examples/reti/validatorRegistry.algo.ts:1060", + "pc": [ + 4861, + 4862 + ] + }, + { + "teal": 4198, + "source": "examples/reti/validatorRegistry.algo.ts:1060", + "pc": [ + 4863, + 4864 + ] + }, + { + "teal": 4199, + "source": "examples/reti/validatorRegistry.algo.ts:1060", + "pc": [ + 4865 + ] + }, + { + "teal": 4200, + "source": "examples/reti/validatorRegistry.algo.ts:1060", + "pc": [ + 4866, + 4867 + ] + }, + { + "teal": 4201, + "source": "examples/reti/validatorRegistry.algo.ts:1060", + "pc": [ + 4868 + ] + }, + { + "teal": 4204, + "source": "examples/reti/validatorRegistry.algo.ts:1059", + "errorMessage": "balance of remaining reward tokens should match the held back amount", + "pc": [ + 4869 + ] + }, + { + "teal": 4208, + "source": "examples/reti/validatorRegistry.algo.ts:1063", + "pc": [ + 4870, + 4871 + ] + }, + { + "teal": 4211, + "source": "examples/reti/validatorRegistry.algo.ts:1042", + "pc": [ + 4872, + 4873 + ] + }, + { + "teal": 4214, + "source": "examples/reti/validatorRegistry.algo.ts:1042", + "pc": [ + 4874, + 4875 + ] + }, + { + "teal": 4215, + "source": "examples/reti/validatorRegistry.algo.ts:1042", + "pc": [ + 4876 + ] + }, + { + "teal": 4226, + "source": "examples/reti/validatorRegistry.algo.ts:1160", + "pc": [ + 4877, + 4878, + 4879 + ] + }, + { + "teal": 4230, + "source": "examples/reti/validatorRegistry.algo.ts:1161", + "pc": [ + 4880, + 4881, + 4882 + ] + }, + { + "teal": 4231, + "source": "examples/reti/validatorRegistry.algo.ts:1161", + "pc": [ + 4883, + 4884 + ] + }, + { + "teal": 4232, + "source": "examples/reti/validatorRegistry.algo.ts:1161", + "pc": [ + 4885, + 4886, + 4887 + ] + }, + { + "teal": 4233, + "source": "examples/reti/validatorRegistry.algo.ts:1161", + "pc": [ + 4888 + ] + }, + { + "teal": 4234, + "source": "examples/reti/validatorRegistry.algo.ts:1161", + "pc": [ + 4889 + ] + }, + { + "teal": 4235, + "source": "examples/reti/validatorRegistry.algo.ts:1161", + "pc": [ + 4890 + ] + }, + { + "teal": 4236, + "source": "examples/reti/validatorRegistry.algo.ts:1161", + "pc": [ + 4891 + ] + }, + { + "teal": 4237, + "source": "examples/reti/validatorRegistry.algo.ts:1161", + "pc": [ + 4892 + ] + }, + { + "teal": 4238, + "source": "examples/reti/validatorRegistry.algo.ts:1161", + "pc": [ + 4893 + ] + }, + { + "teal": 4241, + "source": "examples/reti/validatorRegistry.algo.ts:1161", + "errorMessage": "the specified validator id isn't valid", + "pc": [ + 4894 + ] + }, + { + "teal": 4245, + "source": "examples/reti/validatorRegistry.algo.ts:1162", + "pc": [ + 4895, + 4896 + ] + }, + { + "teal": 4246, + "source": "examples/reti/validatorRegistry.algo.ts:1162", + "pc": [ + 4897, + 4898, + 4899 + ] + }, + { + "teal": 4247, + "source": "examples/reti/validatorRegistry.algo.ts:1162", + "pc": [ + 4900 + ] + }, + { + "teal": 4248, + "source": "examples/reti/validatorRegistry.algo.ts:32", + "pc": [ + 4901, + 4902 + ] + }, + { + "teal": 4249, + "source": "examples/reti/validatorRegistry.algo.ts:1162", + "pc": [ + 4903 + ] + }, + { + "teal": 4252, + "source": "examples/reti/validatorRegistry.algo.ts:1162", + "errorMessage": "pool id not in valid range", + "pc": [ + 4904 + ] + }, + { + "teal": 4259, + "source": "examples/reti/validatorRegistry.algo.ts:1164", + "pc": [ + 4905, + 4906 + ] + }, + { + "teal": 4260, + "source": "examples/reti/validatorRegistry.algo.ts:1164", + "pc": [ + 4907, + 4908, + 4909 + ] + }, + { + "teal": 4261, + "source": "examples/reti/validatorRegistry.algo.ts:1164", + "pc": [ + 4910 + ] + }, + { + "teal": 4262, + "source": "examples/reti/validatorRegistry.algo.ts:1164", + "pc": [ + 4911, + 4912 + ] + }, + { + "teal": 4263, + "source": "examples/reti/validatorRegistry.algo.ts:1164", + "pc": [ + 4913 + ] + }, + { + "teal": 4264, + "source": "examples/reti/validatorRegistry.algo.ts:1164", + "pc": [ + 4914 + ] + }, + { + "teal": 4265, + "source": "examples/reti/validatorRegistry.algo.ts:1164", + "pc": [ + 4915, + 4916, + 4917 + ] + }, + { + "teal": 4266, + "source": "examples/reti/validatorRegistry.algo.ts:1164", + "pc": [ + 4918, + 4919 + ] + }, + { + "teal": 4267, + "source": "examples/reti/validatorRegistry.algo.ts:1164", + "pc": [ + 4920, + 4921, + 4922 + ] + }, + { + "teal": 4268, + "source": "examples/reti/validatorRegistry.algo.ts:1164", + "pc": [ + 4923 + ] + }, + { + "teal": 4269, + "source": "examples/reti/validatorRegistry.algo.ts:1164", + "pc": [ + 4924, + 4925, + 4926 + ] + }, + { + "teal": 4270, + "source": "examples/reti/validatorRegistry.algo.ts:1164", + "pc": [ + 4927, + 4928 + ] + }, + { + "teal": 4271, + "source": "examples/reti/validatorRegistry.algo.ts:1164", + "pc": [ + 4929, + 4930, + 4931 + ] + }, + { + "teal": 4272, + "source": "examples/reti/validatorRegistry.algo.ts:1164", + "pc": [ + 4932, + 4933 + ] + }, + { + "teal": 4273, + "source": "examples/reti/validatorRegistry.algo.ts:1164", + "pc": [ + 4934, + 4935, + 4936 + ] + }, + { + "teal": 4274, + "source": "examples/reti/validatorRegistry.algo.ts:1164", + "pc": [ + 4937 + ] + }, + { + "teal": 4275, + "source": "examples/reti/validatorRegistry.algo.ts:1164", + "pc": [ + 4938 + ] + }, + { + "teal": 4276, + "source": "examples/reti/validatorRegistry.algo.ts:1164", + "pc": [ + 4939 + ] + }, + { + "teal": 4277, + "source": "examples/reti/validatorRegistry.algo.ts:1164", + "pc": [ + 4940, + 4941 + ] + }, + { + "teal": 4278, + "source": "examples/reti/validatorRegistry.algo.ts:1164", + "pc": [ + 4942 + ] + }, + { + "teal": 4279, + "source": "examples/reti/validatorRegistry.algo.ts:1164", + "pc": [ + 4943 + ] + }, + { + "teal": 4280, + "source": "examples/reti/validatorRegistry.algo.ts:1164", + "pc": [ + 4944 + ] + }, + { + "teal": 4281, + "source": "examples/reti/validatorRegistry.algo.ts:1164", + "pc": [ + 4945 + ] + }, + { + "teal": 4285, + "source": "examples/reti/validatorRegistry.algo.ts:1163", + "errorMessage": "pool id outside of range of pools created for this validator", + "pc": [ + 4946 + ] + }, + { + "teal": 4292, + "source": "examples/reti/validatorRegistry.algo.ts:1170", + "pc": [ + 4947, + 4948 + ] + }, + { + "teal": 4293, + "source": "examples/reti/validatorRegistry.algo.ts:1170", + "pc": [ + 4949, + 4950, + 4951 + ] + }, + { + "teal": 4294, + "source": "examples/reti/validatorRegistry.algo.ts:1170", + "pc": [ + 4952 + ] + }, + { + "teal": 4295, + "source": "examples/reti/validatorRegistry.algo.ts:1170", + "pc": [ + 4953, + 4954, + 4955 + ] + }, + { + "teal": 4296, + "source": "examples/reti/validatorRegistry.algo.ts:1170", + "pc": [ + 4956, + 4957 + ] + }, + { + "teal": 4297, + "source": "examples/reti/validatorRegistry.algo.ts:1170", + "pc": [ + 4958, + 4959, + 4960 + ] + }, + { + "teal": 4298, + "source": "examples/reti/validatorRegistry.algo.ts:1170", + "pc": [ + 4961 + ] + }, + { + "teal": 4299, + "source": "examples/reti/validatorRegistry.algo.ts:1170", + "pc": [ + 4962, + 4963 + ] + }, + { + "teal": 4300, + "source": "examples/reti/validatorRegistry.algo.ts:1170", + "pc": [ + 4964 + ] + }, + { + "teal": 4301, + "source": "examples/reti/validatorRegistry.algo.ts:1170", + "pc": [ + 4965, + 4966 + ] + }, + { + "teal": 4302, + "source": "examples/reti/validatorRegistry.algo.ts:1170", + "pc": [ + 4967 + ] + }, + { + "teal": 4303, + "source": "examples/reti/validatorRegistry.algo.ts:1170", + "pc": [ + 4968 + ] + }, + { + "teal": 4304, + "source": "examples/reti/validatorRegistry.algo.ts:1170", + "pc": [ + 4969, + 4970 + ] + }, + { + "teal": 4305, + "source": "examples/reti/validatorRegistry.algo.ts:1170", + "pc": [ + 4971 + ] + }, + { + "teal": 4306, + "source": "examples/reti/validatorRegistry.algo.ts:1170", + "pc": [ + 4972, + 4973 + ] + }, + { + "teal": 4307, + "source": "examples/reti/validatorRegistry.algo.ts:1170", + "pc": [ + 4974, + 4975, + 4976 + ] + }, + { + "teal": 4308, + "source": "examples/reti/validatorRegistry.algo.ts:1170", + "pc": [ + 4977, + 4978 + ] + }, + { + "teal": 4309, + "source": "examples/reti/validatorRegistry.algo.ts:1170", + "pc": [ + 4979, + 4980, + 4981 + ] + }, + { + "teal": 4310, + "source": "examples/reti/validatorRegistry.algo.ts:1170", + "pc": [ + 4982 + ] + }, + { + "teal": 4311, + "source": "examples/reti/validatorRegistry.algo.ts:1170", + "pc": [ + 4983 + ] + }, + { + "teal": 4312, + "source": "examples/reti/validatorRegistry.algo.ts:1170", + "pc": [ + 4984 + ] + }, + { + "teal": 4313, + "source": "examples/reti/validatorRegistry.algo.ts:1170", + "pc": [ + 4985, + 4986 + ] + }, + { + "teal": 4314, + "source": "examples/reti/validatorRegistry.algo.ts:1170", + "pc": [ + 4987 + ] + }, + { + "teal": 4315, + "source": "examples/reti/validatorRegistry.algo.ts:1170", + "pc": [ + 4988 + ] + }, + { + "teal": 4316, + "source": "examples/reti/validatorRegistry.algo.ts:1170", + "pc": [ + 4989 + ] + }, + { + "teal": 4319, + "source": "examples/reti/validatorRegistry.algo.ts:1169", + "errorMessage": "The passed in app id doesn't match the passed in ids", + "pc": [ + 4990 + ] + }, + { + "teal": 4323, + "source": "examples/reti/validatorRegistry.algo.ts:1174", + "pc": [ + 4991, + 4992 + ] + }, + { + "teal": 4324, + "source": "examples/reti/validatorRegistry.algo.ts:1174", + "pc": [ + 4993, + 4994 + ] + }, + { + "teal": 4325, + "source": "examples/reti/validatorRegistry.algo.ts:1174", + "pc": [ + 4995, + 4996, + 4997 + ] + }, + { + "teal": 4326, + "source": "examples/reti/validatorRegistry.algo.ts:1174", + "pc": [ + 4998 + ] + }, + { + "teal": 4327, + "source": "examples/reti/validatorRegistry.algo.ts:1174", + "pc": [ + 4999, + 5000 + ] + }, + { + "teal": 4328, + "source": "examples/reti/validatorRegistry.algo.ts:1174", + "pc": [ + 5001 + ] + }, + { + "teal": 4329, + "source": "examples/reti/validatorRegistry.algo.ts:1174", + "pc": [ + 5002 + ] + }, + { + "teal": 4330, + "source": "examples/reti/validatorRegistry.algo.ts:1174", + "pc": [ + 5003 + ] + }, + { + "teal": 4334, + "source": "examples/reti/validatorRegistry.algo.ts:1176", + "pc": [ + 5004, + 5005 + ] + }, + { + "teal": 4335, + "source": "examples/reti/validatorRegistry.algo.ts:1176", + "pc": [ + 5006, + 5007, + 5008 + ] + }, + { + "teal": 4336, + "source": "examples/reti/validatorRegistry.algo.ts:1176", + "pc": [ + 5009 + ] + }, + { + "teal": 4337, + "source": "examples/reti/validatorRegistry.algo.ts:1176", + "pc": [ + 5010, + 5011 + ] + }, + { + "teal": 4338, + "source": "examples/reti/validatorRegistry.algo.ts:1176", + "pc": [ + 5012, + 5013, + 5014 + ] + }, + { + "teal": 4339, + "source": "examples/reti/validatorRegistry.algo.ts:1176", + "pc": [ + 5015 + ] + }, + { + "teal": 4340, + "source": "examples/reti/validatorRegistry.algo.ts:1176", + "pc": [ + 5016, + 5017, + 5018, + 5019, + 5020, + 5021, + 5022, + 5023, + 5024, + 5025, + 5026, + 5027, + 5028 + ] + }, + { + "teal": 4341, + "source": "examples/reti/validatorRegistry.algo.ts:1176", + "pc": [ + 5029 + ] + }, + { + "teal": 4344, + "source": "examples/reti/validatorRegistry.algo.ts:1176", + "errorMessage": "global state value does not exist: AppID.fromUint64(poolKey.poolAppId).globalState('validatorId')", + "pc": [ + 5030 + ] + }, + { + "teal": 4345, + "source": "examples/reti/validatorRegistry.algo.ts:1176", + "pc": [ + 5031 + ] + }, + { + "teal": 4346, + "source": "examples/reti/validatorRegistry.algo.ts:1176", + "pc": [ + 5032 + ] + }, + { + "teal": 4350, + "source": "examples/reti/validatorRegistry.algo.ts:1177", + "pc": [ + 5033, + 5034 + ] + }, + { + "teal": 4351, + "source": "examples/reti/validatorRegistry.algo.ts:1177", + "pc": [ + 5035, + 5036, + 5037 + ] + }, + { + "teal": 4352, + "source": "examples/reti/validatorRegistry.algo.ts:1177", + "pc": [ + 5038 + ] + }, + { + "teal": 4353, + "source": "examples/reti/validatorRegistry.algo.ts:1177", + "pc": [ + 5039, + 5040 + ] + }, + { + "teal": 4354, + "source": "examples/reti/validatorRegistry.algo.ts:1177", + "pc": [ + 5041, + 5042, + 5043 + ] + }, + { + "teal": 4355, + "source": "examples/reti/validatorRegistry.algo.ts:1177", + "pc": [ + 5044 + ] + }, + { + "teal": 4356, + "source": "examples/reti/validatorRegistry.algo.ts:1177", + "pc": [ + 5045, + 5046, + 5047, + 5048, + 5049, + 5050, + 5051, + 5052 + ] + }, + { + "teal": 4357, + "source": "examples/reti/validatorRegistry.algo.ts:1177", + "pc": [ + 5053 + ] + }, + { + "teal": 4360, + "source": "examples/reti/validatorRegistry.algo.ts:1177", + "errorMessage": "global state value does not exist: AppID.fromUint64(poolKey.poolAppId).globalState('poolId')", + "pc": [ + 5054 + ] + }, + { + "teal": 4361, + "source": "examples/reti/validatorRegistry.algo.ts:1177", + "pc": [ + 5055 + ] + }, + { + "teal": 4362, + "source": "examples/reti/validatorRegistry.algo.ts:1177", + "pc": [ + 5056 + ] + }, + { + "teal": 4363, + "source": "examples/reti/validatorRegistry.algo.ts:1160", + "pc": [ + 5057 + ] + }, + { + "teal": 4372, + "source": "examples/reti/validatorRegistry.algo.ts:1186", + "pc": [ + 5058, + 5059, + 5060 + ] + }, + { + "teal": 4375, + "source": "examples/reti/validatorRegistry.algo.ts:1186", + "pc": [ + 5061, + 5062 + ] + }, + { + "teal": 4376, + "source": "examples/reti/validatorRegistry.algo.ts:1186", + "pc": [ + 5063 + ] + }, + { + "teal": 4380, + "source": "examples/reti/validatorRegistry.algo.ts:1187", + "pc": [ + 5064, + 5065, + 5066 + ] + }, + { + "teal": 4381, + "source": "examples/reti/validatorRegistry.algo.ts:1187", + "pc": [ + 5067, + 5068 + ] + }, + { + "teal": 4382, + "source": "examples/reti/validatorRegistry.algo.ts:1187", + "pc": [ + 5069 + ] + }, + { + "teal": 4383, + "source": "examples/reti/validatorRegistry.algo.ts:1187", + "pc": [ + 5070 + ] + }, + { + "teal": 4384, + "source": "examples/reti/validatorRegistry.algo.ts:1187", + "pc": [ + 5071, + 5072 + ] + }, + { + "teal": 4389, + "source": "examples/reti/validatorRegistry.algo.ts:1188", + "pc": [ + 5073, + 5074 + ] + }, + { + "teal": 4390, + "source": "examples/reti/validatorRegistry.algo.ts:1188", + "pc": [ + 5075, + 5076 + ] + }, + { + "teal": 4391, + "source": "examples/reti/validatorRegistry.algo.ts:1187", + "pc": [ + 5077, + 5078, + 5079 + ] + }, + { + "teal": 4392, + "source": "examples/reti/validatorRegistry.algo.ts:1187", + "pc": [ + 5080, + 5081 + ] + }, + { + "teal": 4393, + "source": "examples/reti/validatorRegistry.algo.ts:1187", + "pc": [ + 5082 + ] + }, + { + "teal": 4394, + "source": "examples/reti/validatorRegistry.algo.ts:1187", + "pc": [ + 5083 + ] + }, + { + "teal": 4395, + "source": "examples/reti/validatorRegistry.algo.ts:1187", + "pc": [ + 5084, + 5085 + ] + }, + { + "teal": 4396, + "source": "examples/reti/validatorRegistry.algo.ts:1187", + "pc": [ + 5086 + ] + }, + { + "teal": 4397, + "source": "examples/reti/validatorRegistry.algo.ts:1188", + "pc": [ + 5087 + ] + }, + { + "teal": 4398, + "source": "examples/reti/validatorRegistry.algo.ts:1188", + "pc": [ + 5088, + 5089 + ] + }, + { + "teal": 4399, + "source": "examples/reti/validatorRegistry.algo.ts:1188", + "pc": [ + 5090 + ] + }, + { + "teal": 4400, + "source": "examples/reti/validatorRegistry.algo.ts:1188", + "pc": [ + 5091, + 5092, + 5093 + ] + }, + { + "teal": 4405, + "source": "examples/reti/validatorRegistry.algo.ts:1191", + "pc": [ + 5094, + 5095 + ] + }, + { + "teal": 4406, + "source": "examples/reti/validatorRegistry.algo.ts:1191", + "pc": [ + 5096, + 5097 + ] + }, + { + "teal": 4407, + "source": "examples/reti/validatorRegistry.algo.ts:1187", + "pc": [ + 5098, + 5099, + 5100 + ] + }, + { + "teal": 4408, + "source": "examples/reti/validatorRegistry.algo.ts:1187", + "pc": [ + 5101, + 5102 + ] + }, + { + "teal": 4409, + "source": "examples/reti/validatorRegistry.algo.ts:1187", + "pc": [ + 5103 + ] + }, + { + "teal": 4410, + "source": "examples/reti/validatorRegistry.algo.ts:1187", + "pc": [ + 5104 + ] + }, + { + "teal": 4411, + "source": "examples/reti/validatorRegistry.algo.ts:1187", + "pc": [ + 5105, + 5106 + ] + }, + { + "teal": 4412, + "source": "examples/reti/validatorRegistry.algo.ts:1187", + "pc": [ + 5107 + ] + }, + { + "teal": 4413, + "source": "examples/reti/validatorRegistry.algo.ts:1191", + "pc": [ + 5108 + ] + }, + { + "teal": 4414, + "source": "examples/reti/validatorRegistry.algo.ts:1191", + "pc": [ + 5109, + 5110, + 5111, + 5112, + 5113, + 5114, + 5115, + 5116, + 5117, + 5118, + 5119 + ] + }, + { + "teal": 4415, + "source": "examples/reti/validatorRegistry.algo.ts:1191", + "pc": [ + 5120 + ] + }, + { + "teal": 4418, + "source": "examples/reti/validatorRegistry.algo.ts:1191", + "errorMessage": "global state value does not exist: AppID.fromUint64(validatorConfig.nfdForInfo).globalState('i.owner.a')", + "pc": [ + 5121 + ] + }, + { + "teal": 4419, + "source": "examples/reti/validatorRegistry.algo.ts:1191", + "pc": [ + 5122, + 5123 + ] + }, + { + "teal": 4424, + "source": "examples/reti/validatorRegistry.algo.ts:1193", + "pc": [ + 5124, + 5125 + ] + }, + { + "teal": 4425, + "source": "examples/reti/validatorRegistry.algo.ts:1193", + "pc": [ + 5126, + 5127 + ] + }, + { + "teal": 4426, + "source": "examples/reti/validatorRegistry.algo.ts:1187", + "pc": [ + 5128, + 5129, + 5130 + ] + }, + { + "teal": 4427, + "source": "examples/reti/validatorRegistry.algo.ts:1187", + "pc": [ + 5131, + 5132 + ] + }, + { + "teal": 4428, + "source": "examples/reti/validatorRegistry.algo.ts:1187", + "pc": [ + 5133 + ] + }, + { + "teal": 4429, + "source": "examples/reti/validatorRegistry.algo.ts:1187", + "pc": [ + 5134 + ] + }, + { + "teal": 4430, + "source": "examples/reti/validatorRegistry.algo.ts:1187", + "pc": [ + 5135, + 5136 + ] + }, + { + "teal": 4431, + "source": "examples/reti/validatorRegistry.algo.ts:1187", + "pc": [ + 5137 + ] + }, + { + "teal": 4432, + "source": "examples/reti/validatorRegistry.algo.ts:1193", + "pc": [ + 5138, + 5139 + ] + }, + { + "teal": 4433, + "source": "examples/reti/validatorRegistry.algo.ts:1193", + "pc": [ + 5140 + ] + }, + { + "teal": 4434, + "source": "examples/reti/validatorRegistry.algo.ts:1193", + "pc": [ + 5141 + ] + }, + { + "teal": 4435, + "source": "examples/reti/validatorRegistry.algo.ts:1193", + "pc": [ + 5142, + 5143, + 5144 + ] + }, + { + "teal": 4436, + "source": "examples/reti/validatorRegistry.algo.ts:1193", + "pc": [ + 5145, + 5146 + ] + }, + { + "teal": 4437, + "source": "examples/reti/validatorRegistry.algo.ts:1193", + "pc": [ + 5147, + 5148 + ] + }, + { + "teal": 4438, + "source": "examples/reti/validatorRegistry.algo.ts:1187", + "pc": [ + 5149, + 5150, + 5151 + ] + }, + { + "teal": 4439, + "source": "examples/reti/validatorRegistry.algo.ts:1187", + "pc": [ + 5152, + 5153 + ] + }, + { + "teal": 4440, + "source": "examples/reti/validatorRegistry.algo.ts:1187", + "pc": [ + 5154 + ] + }, + { + "teal": 4441, + "source": "examples/reti/validatorRegistry.algo.ts:1187", + "pc": [ + 5155 + ] + }, + { + "teal": 4442, + "source": "examples/reti/validatorRegistry.algo.ts:1187", + "pc": [ + 5156, + 5157 + ] + }, + { + "teal": 4443, + "source": "examples/reti/validatorRegistry.algo.ts:1187", + "pc": [ + 5158 + ] + }, + { + "teal": 4444, + "source": "examples/reti/validatorRegistry.algo.ts:1193", + "pc": [ + 5159, + 5160 + ] + }, + { + "teal": 4445, + "source": "examples/reti/validatorRegistry.algo.ts:1193", + "pc": [ + 5161 + ] + }, + { + "teal": 4446, + "source": "examples/reti/validatorRegistry.algo.ts:1193", + "pc": [ + 5162 + ] + }, + { + "teal": 4449, + "source": "examples/reti/validatorRegistry.algo.ts:1193", + "pc": [ + 5163, + 5164, + 5165 + ] + }, + { + "teal": 4454, + "source": "examples/reti/validatorRegistry.algo.ts:1195", + "pc": [ + 5166, + 5167 + ] + }, + { + "teal": 4455, + "source": "examples/reti/validatorRegistry.algo.ts:1195", + "pc": [ + 5168, + 5169, + 5170, + 5171, + 5172, + 5173, + 5174, + 5175, + 5176, + 5177 + ] + }, + { + "teal": 4456, + "source": "examples/reti/validatorRegistry.algo.ts:1195", + "pc": [ + 5178, + 5179, + 5180 + ] + }, + { + "teal": 4457, + "source": "examples/reti/validatorRegistry.algo.ts:1195", + "pc": [ + 5181, + 5182 + ] + }, + { + "teal": 4458, + "source": "examples/reti/validatorRegistry.algo.ts:1195", + "pc": [ + 5183 + ] + }, + { + "teal": 4459, + "source": "examples/reti/validatorRegistry.algo.ts:1195", + "pc": [ + 5184 + ] + }, + { + "teal": 4460, + "source": "examples/reti/validatorRegistry.algo.ts:1195", + "pc": [ + 5185, + 5186 + ] + }, + { + "teal": 4461, + "source": "examples/reti/validatorRegistry.algo.ts:1195", + "pc": [ + 5187 + ] + }, + { + "teal": 4466, + "source": "examples/reti/validatorRegistry.algo.ts:1186", + "pc": [ + 5188 + ] + }, + { + "teal": 4470, + "source": "examples/reti/validatorRegistry.algo.ts:1200", + "pc": [ + 5189, + 5190, + 5191 + ] + }, + { + "teal": 4477, + "source": "examples/reti/validatorRegistry.algo.ts:1203", + "pc": [ + 5192, + 5193 + ] + }, + { + "teal": 4478, + "source": "examples/reti/validatorRegistry.algo.ts:1203", + "pc": [ + 5194, + 5195, + 5196 + ] + }, + { + "teal": 4479, + "source": "examples/reti/validatorRegistry.algo.ts:1203", + "pc": [ + 5197 + ] + }, + { + "teal": 4480, + "source": "examples/reti/validatorRegistry.algo.ts:1203", + "pc": [ + 5198, + 5199 + ] + }, + { + "teal": 4481, + "source": "examples/reti/validatorRegistry.algo.ts:1203", + "pc": [ + 5200 + ] + }, + { + "teal": 4482, + "source": "examples/reti/validatorRegistry.algo.ts:1203", + "pc": [ + 5201 + ] + }, + { + "teal": 4483, + "source": "examples/reti/validatorRegistry.algo.ts:1203", + "pc": [ + 5202, + 5203, + 5204 + ] + }, + { + "teal": 4484, + "source": "examples/reti/validatorRegistry.algo.ts:1203", + "pc": [ + 5205, + 5206 + ] + }, + { + "teal": 4485, + "source": "examples/reti/validatorRegistry.algo.ts:1203", + "pc": [ + 5207, + 5208, + 5209 + ] + }, + { + "teal": 4486, + "source": "examples/reti/validatorRegistry.algo.ts:1203", + "pc": [ + 5210 + ] + }, + { + "teal": 4487, + "source": "examples/reti/validatorRegistry.algo.ts:1203", + "pc": [ + 5211, + 5212 + ] + }, + { + "teal": 4488, + "source": "examples/reti/validatorRegistry.algo.ts:1203", + "pc": [ + 5213 + ] + }, + { + "teal": 4489, + "source": "examples/reti/validatorRegistry.algo.ts:1203", + "pc": [ + 5214 + ] + }, + { + "teal": 4493, + "source": "examples/reti/validatorRegistry.algo.ts:1202", + "errorMessage": "gating type not valid", + "pc": [ + 5215 + ] + }, + { + "teal": 4500, + "source": "examples/reti/validatorRegistry.algo.ts:1207", + "pc": [ + 5216, + 5217 + ] + }, + { + "teal": 4501, + "source": "examples/reti/validatorRegistry.algo.ts:1207", + "pc": [ + 5218, + 5219, + 5220 + ] + }, + { + "teal": 4502, + "source": "examples/reti/validatorRegistry.algo.ts:1207", + "pc": [ + 5221 + ] + }, + { + "teal": 4503, + "source": "examples/reti/validatorRegistry.algo.ts:1207", + "pc": [ + 5222, + 5223 + ] + }, + { + "teal": 4504, + "source": "examples/reti/validatorRegistry.algo.ts:1207", + "pc": [ + 5224 + ] + }, + { + "teal": 4505, + "source": "examples/reti/validatorRegistry.algo.ts:1207", + "pc": [ + 5225 + ] + }, + { + "teal": 4506, + "source": "examples/reti/validatorRegistry.algo.ts:1207", + "pc": [ + 5226, + 5227, + 5228 + ] + }, + { + "teal": 4507, + "source": "examples/reti/validatorRegistry.algo.ts:1207", + "pc": [ + 5229, + 5230 + ] + }, + { + "teal": 4508, + "source": "examples/reti/validatorRegistry.algo.ts:1207", + "pc": [ + 5231, + 5232, + 5233 + ] + }, + { + "teal": 4509, + "source": "examples/reti/validatorRegistry.algo.ts:1207", + "pc": [ + 5234 + ] + }, + { + "teal": 4510, + "source": "examples/reti/validatorRegistry.algo.ts:1207", + "pc": [ + 5235, + 5236, + 5237, + 5238 + ] + }, + { + "teal": 4511, + "source": "examples/reti/validatorRegistry.algo.ts:1207", + "pc": [ + 5239 + ] + }, + { + "teal": 4512, + "source": "examples/reti/validatorRegistry.algo.ts:1207", + "pc": [ + 5240 + ] + }, + { + "teal": 4516, + "source": "examples/reti/validatorRegistry.algo.ts:1206", + "errorMessage": "epoch length not in allowable range", + "pc": [ + 5241 + ] + }, + { + "teal": 4523, + "source": "examples/reti/validatorRegistry.algo.ts:1211", + "pc": [ + 5242, + 5243 + ] + }, + { + "teal": 4524, + "source": "examples/reti/validatorRegistry.algo.ts:1211", + "pc": [ + 5244, + 5245, + 5246 + ] + }, + { + "teal": 4525, + "source": "examples/reti/validatorRegistry.algo.ts:1211", + "pc": [ + 5247 + ] + }, + { + "teal": 4526, + "source": "examples/reti/validatorRegistry.algo.ts:1211", + "pc": [ + 5248, + 5249 + ] + }, + { + "teal": 4527, + "source": "examples/reti/validatorRegistry.algo.ts:1211", + "pc": [ + 5250 + ] + }, + { + "teal": 4528, + "source": "examples/reti/validatorRegistry.algo.ts:1211", + "pc": [ + 5251 + ] + }, + { + "teal": 4529, + "source": "examples/reti/validatorRegistry.algo.ts:1211", + "pc": [ + 5252, + 5253, + 5254 + ] + }, + { + "teal": 4530, + "source": "examples/reti/validatorRegistry.algo.ts:1211", + "pc": [ + 5255, + 5256 + ] + }, + { + "teal": 4531, + "source": "examples/reti/validatorRegistry.algo.ts:1211", + "pc": [ + 5257, + 5258, + 5259 + ] + }, + { + "teal": 4532, + "source": "examples/reti/validatorRegistry.algo.ts:1211", + "pc": [ + 5260 + ] + }, + { + "teal": 4533, + "source": "examples/reti/validatorRegistry.algo.ts:1211", + "pc": [ + 5261, + 5262, + 5263, + 5264 + ] + }, + { + "teal": 4534, + "source": "examples/reti/validatorRegistry.algo.ts:1211", + "pc": [ + 5265 + ] + }, + { + "teal": 4535, + "source": "examples/reti/validatorRegistry.algo.ts:1211", + "pc": [ + 5266 + ] + }, + { + "teal": 4539, + "source": "examples/reti/validatorRegistry.algo.ts:1210", + "errorMessage": "commission percentage not valid", + "pc": [ + 5267 + ] + }, + { + "teal": 4544, + "source": "examples/reti/validatorRegistry.algo.ts:1214", + "pc": [ + 5268, + 5269 + ] + }, + { + "teal": 4545, + "source": "examples/reti/validatorRegistry.algo.ts:1214", + "pc": [ + 5270, + 5271, + 5272 + ] + }, + { + "teal": 4546, + "source": "examples/reti/validatorRegistry.algo.ts:1214", + "pc": [ + 5273 + ] + }, + { + "teal": 4547, + "source": "examples/reti/validatorRegistry.algo.ts:1214", + "pc": [ + 5274, + 5275 + ] + }, + { + "teal": 4548, + "source": "examples/reti/validatorRegistry.algo.ts:1214", + "pc": [ + 5276 + ] + }, + { + "teal": 4549, + "source": "examples/reti/validatorRegistry.algo.ts:1214", + "pc": [ + 5277, + 5278, + 5279 + ] + }, + { + "teal": 4557, + "source": "examples/reti/validatorRegistry.algo.ts:1216", + "pc": [ + 5280, + 5281 + ] + }, + { + "teal": 4558, + "source": "examples/reti/validatorRegistry.algo.ts:1216", + "pc": [ + 5282, + 5283, + 5284 + ] + }, + { + "teal": 4559, + "source": "examples/reti/validatorRegistry.algo.ts:1216", + "pc": [ + 5285, + 5286 + ] + }, + { + "teal": 4560, + "source": "examples/reti/validatorRegistry.algo.ts:1216", + "pc": [ + 5287 + ] + }, + { + "teal": 4563, + "source": "examples/reti/validatorRegistry.algo.ts:1215", + "errorMessage": "validatorCommissionAddress must be set if percent to validator is not 0", + "pc": [ + 5288 + ] + }, + { + "teal": 4568, + "source": "examples/reti/validatorRegistry.algo.ts:1220", + "pc": [ + 5289, + 5290 + ] + }, + { + "teal": 4569, + "source": "examples/reti/validatorRegistry.algo.ts:1220", + "pc": [ + 5291, + 5292, + 5293 + ] + }, + { + "teal": 4570, + "source": "examples/reti/validatorRegistry.algo.ts:1220", + "pc": [ + 5294 + ] + }, + { + "teal": 4571, + "source": "examples/reti/validatorRegistry.algo.ts:1220", + "pc": [ + 5295, + 5296, + 5297, + 5298 + ] + }, + { + "teal": 4572, + "source": "examples/reti/validatorRegistry.algo.ts:1220", + "pc": [ + 5299 + ] + }, + { + "teal": 4575, + "source": "examples/reti/validatorRegistry.algo.ts:1220", + "errorMessage": "staking pool must have minimum entry of 1 algo", + "pc": [ + 5300 + ] + }, + { + "teal": 4582, + "source": "examples/reti/validatorRegistry.algo.ts:1223", + "pc": [ + 5301, + 5302 + ] + }, + { + "teal": 4583, + "source": "examples/reti/validatorRegistry.algo.ts:1223", + "pc": [ + 5303, + 5304, + 5305 + ] + }, + { + "teal": 4584, + "source": "examples/reti/validatorRegistry.algo.ts:1223", + "pc": [ + 5306 + ] + }, + { + "teal": 4585, + "source": "examples/reti/validatorRegistry.algo.ts:1223", + "pc": [ + 5307, + 5308 + ] + }, + { + "teal": 4586, + "source": "examples/reti/validatorRegistry.algo.ts:1223", + "pc": [ + 5309 + ] + }, + { + "teal": 4587, + "source": "examples/reti/validatorRegistry.algo.ts:1223", + "pc": [ + 5310 + ] + }, + { + "teal": 4588, + "source": "examples/reti/validatorRegistry.algo.ts:1223", + "pc": [ + 5311, + 5312, + 5313 + ] + }, + { + "teal": 4589, + "source": "examples/reti/validatorRegistry.algo.ts:1223", + "pc": [ + 5314, + 5315 + ] + }, + { + "teal": 4590, + "source": "examples/reti/validatorRegistry.algo.ts:1223", + "pc": [ + 5316, + 5317, + 5318 + ] + }, + { + "teal": 4591, + "source": "examples/reti/validatorRegistry.algo.ts:1223", + "pc": [ + 5319 + ] + }, + { + "teal": 4592, + "source": "examples/reti/validatorRegistry.algo.ts:1223", + "pc": [ + 5320, + 5321 + ] + }, + { + "teal": 4593, + "source": "examples/reti/validatorRegistry.algo.ts:1223", + "pc": [ + 5322 + ] + }, + { + "teal": 4594, + "source": "examples/reti/validatorRegistry.algo.ts:1223", + "pc": [ + 5323 + ] + }, + { + "teal": 4598, + "source": "examples/reti/validatorRegistry.algo.ts:1222", + "errorMessage": "number of pools per node exceeds allowed number", + "pc": [ + 5324 + ] + }, + { + "teal": 4603, + "source": "examples/reti/validatorRegistry.algo.ts:1226", + "pc": [ + 5325, + 5326 + ] + }, + { + "teal": 4604, + "source": "examples/reti/validatorRegistry.algo.ts:1226", + "pc": [ + 5327, + 5328, + 5329 + ] + }, + { + "teal": 4605, + "source": "examples/reti/validatorRegistry.algo.ts:1226", + "pc": [ + 5330 + ] + }, + { + "teal": 4606, + "source": "examples/reti/validatorRegistry.algo.ts:1226", + "pc": [ + 5331, + 5332 + ] + }, + { + "teal": 4607, + "source": "examples/reti/validatorRegistry.algo.ts:1226", + "pc": [ + 5333 + ] + }, + { + "teal": 4608, + "source": "examples/reti/validatorRegistry.algo.ts:1226", + "pc": [ + 5334, + 5335, + 5336 + ] + }, + { + "teal": 4613, + "source": "examples/reti/validatorRegistry.algo.ts:1227", + "pc": [ + 5337, + 5338 + ] + }, + { + "teal": 4614, + "source": "examples/reti/validatorRegistry.algo.ts:1227", + "pc": [ + 5339, + 5340, + 5341 + ] + }, + { + "teal": 4615, + "source": "examples/reti/validatorRegistry.algo.ts:1227", + "pc": [ + 5342 + ] + }, + { + "teal": 4616, + "source": "examples/reti/validatorRegistry.algo.ts:1227", + "pc": [ + 5343, + 5344 + ] + }, + { + "teal": 4617, + "source": "examples/reti/validatorRegistry.algo.ts:1227", + "pc": [ + 5345 + ] + }, + { + "teal": 4620, + "source": "examples/reti/validatorRegistry.algo.ts:1227", + "errorMessage": "sunsettingOn must be later than now if set", + "pc": [ + 5346 + ] + }, + { + "teal": 4623, + "source": "examples/reti/validatorRegistry.algo.ts:1200", + "pc": [ + 5347 + ] + }, + { + "teal": 4637, + "source": "examples/reti/validatorRegistry.algo.ts:1242", + "pc": [ + 5348, + 5349, + 5350 + ] + }, + { + "teal": 4640, + "source": "examples/reti/validatorRegistry.algo.ts:1242", + "pc": [ + 5351, + 5352 + ] + }, + { + "teal": 4641, + "source": "examples/reti/validatorRegistry.algo.ts:1242", + "pc": [ + 5353, + 5354 + ] + }, + { + "teal": 4645, + "source": "examples/reti/validatorRegistry.algo.ts:1249", + "pc": [ + 5355, + 5356, + 5357 + ] + }, + { + "teal": 4646, + "source": "examples/reti/validatorRegistry.algo.ts:1249", + "pc": [ + 5358, + 5359 + ] + }, + { + "teal": 4647, + "source": "examples/reti/validatorRegistry.algo.ts:1249", + "pc": [ + 5360, + 5361, + 5362 + ] + }, + { + "teal": 4648, + "source": "examples/reti/validatorRegistry.algo.ts:1249", + "pc": [ + 5363 + ] + }, + { + "teal": 4649, + "source": "examples/reti/validatorRegistry.algo.ts:1249", + "pc": [ + 5364, + 5365 + ] + }, + { + "teal": 4650, + "source": "examples/reti/validatorRegistry.algo.ts:1249", + "pc": [ + 5366 + ] + }, + { + "teal": 4651, + "source": "examples/reti/validatorRegistry.algo.ts:1249", + "pc": [ + 5367, + 5368 + ] + }, + { + "teal": 4652, + "source": "examples/reti/validatorRegistry.algo.ts:1249", + "pc": [ + 5369 + ] + }, + { + "teal": 4653, + "source": "examples/reti/validatorRegistry.algo.ts:1249", + "pc": [ + 5370 + ] + }, + { + "teal": 4654, + "source": "examples/reti/validatorRegistry.algo.ts:1249", + "pc": [ + 5371, + 5372 + ] + }, + { + "teal": 4655, + "source": "examples/reti/validatorRegistry.algo.ts:1249", + "pc": [ + 5373 + ] + }, + { + "teal": 4656, + "source": "examples/reti/validatorRegistry.algo.ts:1249", + "pc": [ + 5374, + 5375 + ] + }, + { + "teal": 4657, + "source": "examples/reti/validatorRegistry.algo.ts:1249", + "pc": [ + 5376, + 5377, + 5378 + ] + }, + { + "teal": 4658, + "source": "examples/reti/validatorRegistry.algo.ts:1249", + "pc": [ + 5379, + 5380 + ] + }, + { + "teal": 4659, + "source": "examples/reti/validatorRegistry.algo.ts:1249", + "pc": [ + 5381, + 5382, + 5383 + ] + }, + { + "teal": 4660, + "source": "examples/reti/validatorRegistry.algo.ts:1249", + "pc": [ + 5384 + ] + }, + { + "teal": 4661, + "source": "examples/reti/validatorRegistry.algo.ts:1249", + "pc": [ + 5385 + ] + }, + { + "teal": 4662, + "source": "examples/reti/validatorRegistry.algo.ts:1249", + "pc": [ + 5386 + ] + }, + { + "teal": 4663, + "source": "examples/reti/validatorRegistry.algo.ts:1249", + "pc": [ + 5387, + 5388 + ] + }, + { + "teal": 4664, + "source": "examples/reti/validatorRegistry.algo.ts:1249", + "pc": [ + 5389 + ] + }, + { + "teal": 4665, + "source": "examples/reti/validatorRegistry.algo.ts:1249", + "pc": [ + 5390 + ] + }, + { + "teal": 4666, + "source": "examples/reti/validatorRegistry.algo.ts:1249", + "pc": [ + 5391, + 5392 + ] + }, + { + "teal": 4679, + "source": "examples/reti/validatorRegistry.algo.ts:1258", + "pc": [ + 5393 + ] + }, + { + "teal": 4680, + "source": "examples/reti/validatorRegistry.algo.ts:1258", + "pc": [ + 5394, + 5395 + ] + }, + { + "teal": 4681, + "source": "examples/reti/validatorRegistry.algo.ts:1258", + "pc": [ + 5396, + 5397 + ] + }, + { + "teal": 4685, + "source": "examples/reti/validatorRegistry.algo.ts:1258", + "pc": [ + 5398, + 5399 + ] + }, + { + "teal": 4686, + "source": "examples/reti/validatorRegistry.algo.ts:1258", + "pc": [ + 5400, + 5401 + ] + }, + { + "teal": 4687, + "source": "examples/reti/validatorRegistry.algo.ts:1258", + "pc": [ + 5402, + 5403 + ] + }, + { + "teal": 4688, + "source": "examples/reti/validatorRegistry.algo.ts:1258", + "pc": [ + 5404 + ] + }, + { + "teal": 4689, + "source": "examples/reti/validatorRegistry.algo.ts:1258", + "pc": [ + 5405, + 5406 + ] + }, + { + "teal": 4693, + "source": "examples/reti/validatorRegistry.algo.ts:1258", + "pc": [ + 5407, + 5408 + ] + }, + { + "teal": 4694, + "source": "examples/reti/validatorRegistry.algo.ts:1258", + "pc": [ + 5409, + 5410 + ] + }, + { + "teal": 4695, + "source": "examples/reti/validatorRegistry.algo.ts:1258", + "pc": [ + 5411 + ] + }, + { + "teal": 4696, + "source": "examples/reti/validatorRegistry.algo.ts:1258", + "pc": [ + 5412, + 5413 + ] + }, + { + "teal": 4699, + "source": "examples/reti/validatorRegistry.algo.ts:1258", + "pc": [ + 5414, + 5415 + ] + }, + { + "teal": 4700, + "source": "examples/reti/validatorRegistry.algo.ts:1258", + "pc": [ + 5416, + 5417 + ] + }, + { + "teal": 4701, + "source": "examples/reti/validatorRegistry.algo.ts:1253", + "pc": [ + 5418 + ] + }, + { + "teal": 4702, + "source": "examples/reti/validatorRegistry.algo.ts:1253", + "pc": [ + 5419, + 5420 + ] + }, + { + "teal": 4703, + "source": "examples/reti/validatorRegistry.algo.ts:1253", + "pc": [ + 5421, + 5422 + ] + }, + { + "teal": 4704, + "source": "examples/reti/validatorRegistry.algo.ts:1253", + "pc": [ + 5423, + 5424, + 5425, + 5426, + 5427, + 5428 + ] + }, + { + "teal": 4705, + "source": "examples/reti/validatorRegistry.algo.ts:1253", + "pc": [ + 5429, + 5430 + ] + }, + { + "teal": 4709, + "source": "examples/reti/validatorRegistry.algo.ts:1254", + "pc": [ + 5431, + 5432 + ] + }, + { + "teal": 4710, + "source": "examples/reti/validatorRegistry.algo.ts:1254", + "pc": [ + 5433, + 5434 + ] + }, + { + "teal": 4720, + "source": "examples/reti/validatorRegistry.algo.ts:1260", + "pc": [ + 5435, + 5436 + ] + }, + { + "teal": 4721, + "source": "examples/reti/validatorRegistry.algo.ts:1260", + "pc": [ + 5437, + 5438 + ] + }, + { + "teal": 4722, + "source": "examples/reti/validatorRegistry.algo.ts:1260", + "pc": [ + 5439, + 5440 + ] + }, + { + "teal": 4725, + "source": "examples/reti/validatorRegistry.algo.ts:1253", + "pc": [ + 5441, + 5442 + ] + }, + { + "teal": 4726, + "source": "examples/reti/validatorRegistry.algo.ts:1253", + "pc": [ + 5443, + 5444 + ] + }, + { + "teal": 4729, + "source": "examples/reti/validatorRegistry.algo.ts:1253", + "pc": [ + 5445 + ] + }, + { + "teal": 4730, + "source": "examples/reti/validatorRegistry.algo.ts:1253", + "pc": [ + 5446, + 5447 + ] + }, + { + "teal": 4731, + "source": "examples/reti/validatorRegistry.algo.ts:1253", + "pc": [ + 5448, + 5449 + ] + }, + { + "teal": 4732, + "source": "examples/reti/validatorRegistry.algo.ts:1253", + "pc": [ + 5450 + ] + }, + { + "teal": 4733, + "source": "examples/reti/validatorRegistry.algo.ts:1253", + "pc": [ + 5451, + 5452 + ] + }, + { + "teal": 4734, + "source": "examples/reti/validatorRegistry.algo.ts:1253", + "pc": [ + 5453, + 5454, + 5455 + ] + }, + { + "teal": 4735, + "source": "examples/reti/validatorRegistry.algo.ts:1253", + "pc": [ + 5456 + ] + }, + { + "teal": 4740, + "source": "examples/reti/validatorRegistry.algo.ts:1263", + "pc": [ + 5457, + 5458 + ] + }, + { + "teal": 4741, + "source": "examples/reti/validatorRegistry.algo.ts:1263", + "pc": [ + 5459, + 5460, + 5461 + ] + }, + { + "teal": 4742, + "source": "examples/reti/validatorRegistry.algo.ts:1263", + "pc": [ + 5462 + ] + }, + { + "teal": 4743, + "source": "examples/reti/validatorRegistry.algo.ts:1263", + "pc": [ + 5463, + 5464, + 5465 + ] + }, + { + "teal": 4748, + "source": "examples/reti/validatorRegistry.algo.ts:1264", + "pc": [ + 5466 + ] + }, + { + "teal": 4749, + "source": "examples/reti/validatorRegistry.algo.ts:1264", + "pc": [ + 5467, + 5468 + ] + }, + { + "teal": 4750, + "source": "examples/reti/validatorRegistry.algo.ts:1264", + "pc": [ + 5469, + 5470 + ] + }, + { + "teal": 4751, + "source": "examples/reti/validatorRegistry.algo.ts:1264", + "pc": [ + 5471, + 5472 + ] + }, + { + "teal": 4752, + "source": "examples/reti/validatorRegistry.algo.ts:1264", + "pc": [ + 5473, + 5474 + ] + }, + { + "teal": 4753, + "source": "examples/reti/validatorRegistry.algo.ts:1264", + "pc": [ + 5475, + 5476, + 5477, + 5478, + 5479 + ] + }, + { + "teal": 4754, + "source": "examples/reti/validatorRegistry.algo.ts:1264", + "pc": [ + 5480 + ] + }, + { + "teal": 4755, + "source": "examples/reti/validatorRegistry.algo.ts:1264", + "pc": [ + 5481, + 5482 + ] + }, + { + "teal": 4756, + "source": "examples/reti/validatorRegistry.algo.ts:1264", + "pc": [ + 5483, + 5484 + ] + }, + { + "teal": 4757, + "source": "examples/reti/validatorRegistry.algo.ts:1264", + "pc": [ + 5485, + 5486 + ] + }, + { + "teal": 4758, + "source": "examples/reti/validatorRegistry.algo.ts:1264", + "pc": [ + 5487, + 5488 + ] + }, + { + "teal": 4759, + "source": "examples/reti/validatorRegistry.algo.ts:1264", + "pc": [ + 5489 + ] + }, + { + "teal": 4764, + "source": "examples/reti/validatorRegistry.algo.ts:1268", + "pc": [ + 5490, + 5491 + ] + }, + { + "teal": 4765, + "source": "examples/reti/validatorRegistry.algo.ts:1268", + "pc": [ + 5492, + 5493, + 5494, + 5495, + 5496, + 5497, + 5498, + 5499, + 5500, + 5501, + 5502, + 5503 + ] + }, + { + "teal": 4766, + "source": "examples/reti/validatorRegistry.algo.ts:1268", + "pc": [ + 5504 + ] + }, + { + "teal": 4769, + "source": "examples/reti/validatorRegistry.algo.ts:1268", + "errorMessage": "global state value does not exist: AppID.fromUint64(poolAppId).globalState('numStakers')", + "pc": [ + 5505 + ] + }, + { + "teal": 4770, + "source": "examples/reti/validatorRegistry.algo.ts:1268", + "pc": [ + 5506, + 5507 + ] + }, + { + "teal": 4774, + "source": "examples/reti/validatorRegistry.algo.ts:1269", + "pc": [ + 5508, + 5509 + ] + }, + { + "teal": 4775, + "source": "examples/reti/validatorRegistry.algo.ts:1269", + "pc": [ + 5510, + 5511, + 5512, + 5513, + 5514, + 5515, + 5516, + 5517 + ] + }, + { + "teal": 4776, + "source": "examples/reti/validatorRegistry.algo.ts:1269", + "pc": [ + 5518 + ] + }, + { + "teal": 4779, + "source": "examples/reti/validatorRegistry.algo.ts:1269", + "errorMessage": "global state value does not exist: AppID.fromUint64(poolAppId).globalState('staked')", + "pc": [ + 5519 + ] + }, + { + "teal": 4780, + "source": "examples/reti/validatorRegistry.algo.ts:1269", + "pc": [ + 5520, + 5521 + ] + }, + { + "teal": 4784, + "source": "examples/reti/validatorRegistry.algo.ts:1270", + "pc": [ + 5522, + 5523, + 5524 + ] + }, + { + "teal": 4785, + "source": "examples/reti/validatorRegistry.algo.ts:1270", + "pc": [ + 5525, + 5526 + ] + }, + { + "teal": 4786, + "source": "examples/reti/validatorRegistry.algo.ts:1270", + "pc": [ + 5527, + 5528, + 5529 + ] + }, + { + "teal": 4787, + "source": "examples/reti/validatorRegistry.algo.ts:1270", + "pc": [ + 5530 + ] + }, + { + "teal": 4788, + "source": "examples/reti/validatorRegistry.algo.ts:1270", + "pc": [ + 5531, + 5532 + ] + }, + { + "teal": 4789, + "source": "examples/reti/validatorRegistry.algo.ts:1270", + "pc": [ + 5533 + ] + }, + { + "teal": 4790, + "source": "examples/reti/validatorRegistry.algo.ts:1270", + "pc": [ + 5534, + 5535 + ] + }, + { + "teal": 4791, + "source": "examples/reti/validatorRegistry.algo.ts:1270", + "pc": [ + 5536 + ] + }, + { + "teal": 4792, + "source": "examples/reti/validatorRegistry.algo.ts:1270", + "pc": [ + 5537 + ] + }, + { + "teal": 4793, + "source": "examples/reti/validatorRegistry.algo.ts:1270", + "pc": [ + 5538, + 5539 + ] + }, + { + "teal": 4794, + "source": "examples/reti/validatorRegistry.algo.ts:1270", + "pc": [ + 5540 + ] + }, + { + "teal": 4795, + "source": "examples/reti/validatorRegistry.algo.ts:1270", + "pc": [ + 5541, + 5542 + ] + }, + { + "teal": 4796, + "source": "examples/reti/validatorRegistry.algo.ts:1270", + "pc": [ + 5543 + ] + }, + { + "teal": 4797, + "source": "examples/reti/validatorRegistry.algo.ts:1270", + "pc": [ + 5544, + 5545, + 5546 + ] + }, + { + "teal": 4798, + "source": "examples/reti/validatorRegistry.algo.ts:1270", + "pc": [ + 5547, + 5548, + 5549 + ] + }, + { + "teal": 4799, + "source": "examples/reti/validatorRegistry.algo.ts:1270", + "pc": [ + 5550, + 5551 + ] + }, + { + "teal": 4800, + "source": "examples/reti/validatorRegistry.algo.ts:1270", + "pc": [ + 5552, + 5553, + 5554 + ] + }, + { + "teal": 4801, + "source": "examples/reti/validatorRegistry.algo.ts:1270", + "pc": [ + 5555 + ] + }, + { + "teal": 4802, + "source": "examples/reti/validatorRegistry.algo.ts:1270", + "pc": [ + 5556 + ] + }, + { + "teal": 4803, + "source": "examples/reti/validatorRegistry.algo.ts:1270", + "pc": [ + 5557 + ] + }, + { + "teal": 4804, + "source": "examples/reti/validatorRegistry.algo.ts:1270", + "pc": [ + 5558, + 5559 + ] + }, + { + "teal": 4805, + "source": "examples/reti/validatorRegistry.algo.ts:1270", + "pc": [ + 5560 + ] + }, + { + "teal": 4809, + "source": "examples/reti/validatorRegistry.algo.ts:1271", + "pc": [ + 5561, + 5562, + 5563 + ] + }, + { + "teal": 4810, + "source": "examples/reti/validatorRegistry.algo.ts:1271", + "pc": [ + 5564, + 5565 + ] + }, + { + "teal": 4811, + "source": "examples/reti/validatorRegistry.algo.ts:1271", + "pc": [ + 5566, + 5567, + 5568 + ] + }, + { + "teal": 4812, + "source": "examples/reti/validatorRegistry.algo.ts:1271", + "pc": [ + 5569 + ] + }, + { + "teal": 4813, + "source": "examples/reti/validatorRegistry.algo.ts:1271", + "pc": [ + 5570, + 5571 + ] + }, + { + "teal": 4814, + "source": "examples/reti/validatorRegistry.algo.ts:1271", + "pc": [ + 5572 + ] + }, + { + "teal": 4815, + "source": "examples/reti/validatorRegistry.algo.ts:1271", + "pc": [ + 5573, + 5574 + ] + }, + { + "teal": 4816, + "source": "examples/reti/validatorRegistry.algo.ts:1271", + "pc": [ + 5575 + ] + }, + { + "teal": 4817, + "source": "examples/reti/validatorRegistry.algo.ts:1271", + "pc": [ + 5576 + ] + }, + { + "teal": 4818, + "source": "examples/reti/validatorRegistry.algo.ts:1271", + "pc": [ + 5577, + 5578 + ] + }, + { + "teal": 4819, + "source": "examples/reti/validatorRegistry.algo.ts:1271", + "pc": [ + 5579 + ] + }, + { + "teal": 4820, + "source": "examples/reti/validatorRegistry.algo.ts:1271", + "pc": [ + 5580, + 5581 + ] + }, + { + "teal": 4821, + "source": "examples/reti/validatorRegistry.algo.ts:1271", + "pc": [ + 5582 + ] + }, + { + "teal": 4822, + "source": "examples/reti/validatorRegistry.algo.ts:1271", + "pc": [ + 5583, + 5584, + 5585 + ] + }, + { + "teal": 4823, + "source": "examples/reti/validatorRegistry.algo.ts:1271", + "pc": [ + 5586, + 5587 + ] + }, + { + "teal": 4824, + "source": "examples/reti/validatorRegistry.algo.ts:1271", + "pc": [ + 5588, + 5589, + 5590 + ] + }, + { + "teal": 4825, + "source": "examples/reti/validatorRegistry.algo.ts:1271", + "pc": [ + 5591 + ] + }, + { + "teal": 4826, + "source": "examples/reti/validatorRegistry.algo.ts:1271", + "pc": [ + 5592 + ] + }, + { + "teal": 4827, + "source": "examples/reti/validatorRegistry.algo.ts:1271", + "pc": [ + 5593 + ] + }, + { + "teal": 4828, + "source": "examples/reti/validatorRegistry.algo.ts:1271", + "pc": [ + 5594, + 5595 + ] + }, + { + "teal": 4829, + "source": "examples/reti/validatorRegistry.algo.ts:1271", + "pc": [ + 5596 + ] + }, + { + "teal": 4834, + "source": "examples/reti/validatorRegistry.algo.ts:1274", + "pc": [ + 5597, + 5598 + ] + }, + { + "teal": 4835, + "source": "examples/reti/validatorRegistry.algo.ts:1274", + "pc": [ + 5599, + 5600, + 5601 + ] + }, + { + "teal": 4840, + "source": "examples/reti/validatorRegistry.algo.ts:1275", + "pc": [ + 5602, + 5603, + 5604 + ] + }, + { + "teal": 4841, + "source": "examples/reti/validatorRegistry.algo.ts:1275", + "pc": [ + 5605, + 5606, + 5607 + ] + }, + { + "teal": 4842, + "source": "examples/reti/validatorRegistry.algo.ts:1275", + "pc": [ + 5608, + 5609 + ] + }, + { + "teal": 4843, + "source": "examples/reti/validatorRegistry.algo.ts:1275", + "pc": [ + 5610, + 5611, + 5612 + ] + }, + { + "teal": 4844, + "source": "examples/reti/validatorRegistry.algo.ts:1275", + "pc": [ + 5613, + 5614 + ] + }, + { + "teal": 4845, + "source": "examples/reti/validatorRegistry.algo.ts:1275", + "pc": [ + 5615, + 5616, + 5617 + ] + }, + { + "teal": 4846, + "source": "examples/reti/validatorRegistry.algo.ts:1275", + "pc": [ + 5618 + ] + }, + { + "teal": 4847, + "source": "examples/reti/validatorRegistry.algo.ts:1275", + "pc": [ + 5619 + ] + }, + { + "teal": 4848, + "source": "examples/reti/validatorRegistry.algo.ts:1275", + "pc": [ + 5620 + ] + }, + { + "teal": 4849, + "source": "examples/reti/validatorRegistry.algo.ts:1275", + "pc": [ + 5621, + 5622 + ] + }, + { + "teal": 4850, + "source": "examples/reti/validatorRegistry.algo.ts:1275", + "pc": [ + 5623 + ] + }, + { + "teal": 4851, + "source": "examples/reti/validatorRegistry.algo.ts:1275", + "pc": [ + 5624 + ] + }, + { + "teal": 4852, + "source": "examples/reti/validatorRegistry.algo.ts:1275", + "pc": [ + 5625, + 5626 + ] + }, + { + "teal": 4853, + "source": "examples/reti/validatorRegistry.algo.ts:1275", + "pc": [ + 5627 + ] + }, + { + "teal": 4854, + "source": "examples/reti/validatorRegistry.algo.ts:1275", + "pc": [ + 5628 + ] + }, + { + "teal": 4855, + "source": "examples/reti/validatorRegistry.algo.ts:1275", + "pc": [ + 5629, + 5630, + 5631 + ] + }, + { + "teal": 4856, + "source": "examples/reti/validatorRegistry.algo.ts:1275", + "pc": [ + 5632, + 5633 + ] + }, + { + "teal": 4857, + "source": "examples/reti/validatorRegistry.algo.ts:1275", + "pc": [ + 5634, + 5635, + 5636 + ] + }, + { + "teal": 4858, + "source": "examples/reti/validatorRegistry.algo.ts:1275", + "pc": [ + 5637 + ] + }, + { + "teal": 4859, + "source": "examples/reti/validatorRegistry.algo.ts:1275", + "pc": [ + 5638 + ] + }, + { + "teal": 4860, + "source": "examples/reti/validatorRegistry.algo.ts:1275", + "pc": [ + 5639 + ] + }, + { + "teal": 4861, + "source": "examples/reti/validatorRegistry.algo.ts:1275", + "pc": [ + 5640, + 5641 + ] + }, + { + "teal": 4862, + "source": "examples/reti/validatorRegistry.algo.ts:1275", + "pc": [ + 5642 + ] + }, + { + "teal": 4868, + "source": "examples/reti/validatorRegistry.algo.ts:1277", + "pc": [ + 5643, + 5644 + ] + }, + { + "teal": 4869, + "source": "examples/reti/validatorRegistry.algo.ts:1277", + "pc": [ + 5645, + 5646, + 5647 + ] + }, + { + "teal": 4874, + "source": "examples/reti/validatorRegistry.algo.ts:1278", + "pc": [ + 5648, + 5649, + 5650, + 5651, + 5652, + 5653, + 5654, + 5655, + 5656, + 5657, + 5658, + 5659 + ] + }, + { + "teal": 4875, + "source": "examples/reti/validatorRegistry.algo.ts:1278", + "pc": [ + 5660 + ] + }, + { + "teal": 4876, + "source": "examples/reti/validatorRegistry.algo.ts:1278", + "pc": [ + 5661, + 5662 + ] + }, + { + "teal": 4877, + "source": "examples/reti/validatorRegistry.algo.ts:1278", + "pc": [ + 5663 + ] + }, + { + "teal": 4878, + "source": "examples/reti/validatorRegistry.algo.ts:1278", + "pc": [ + 5664, + 5665, + 5666, + 5667, + 5668, + 5669, + 5670, + 5671, + 5672, + 5673, + 5674, + 5675 + ] + }, + { + "teal": 4879, + "source": "examples/reti/validatorRegistry.algo.ts:1278", + "pc": [ + 5676 + ] + }, + { + "teal": 4880, + "source": "examples/reti/validatorRegistry.algo.ts:1278", + "pc": [ + 5677 + ] + }, + { + "teal": 4885, + "source": "examples/reti/validatorRegistry.algo.ts:1280", + "pc": [ + 5678, + 5679, + 5680 + ] + }, + { + "teal": 4886, + "source": "examples/reti/validatorRegistry.algo.ts:1280", + "pc": [ + 5681 + ] + }, + { + "teal": 4887, + "source": "examples/reti/validatorRegistry.algo.ts:1280", + "pc": [ + 5682, + 5683 + ] + }, + { + "teal": 4888, + "source": "examples/reti/validatorRegistry.algo.ts:1280", + "pc": [ + 5684, + 5685, + 5686 + ] + }, + { + "teal": 4889, + "source": "examples/reti/validatorRegistry.algo.ts:1280", + "pc": [ + 5687, + 5688 + ] + }, + { + "teal": 4890, + "source": "examples/reti/validatorRegistry.algo.ts:1280", + "pc": [ + 5689, + 5690, + 5691 + ] + }, + { + "teal": 4891, + "source": "examples/reti/validatorRegistry.algo.ts:1280", + "pc": [ + 5692 + ] + }, + { + "teal": 4892, + "source": "examples/reti/validatorRegistry.algo.ts:1280", + "pc": [ + 5693 + ] + }, + { + "teal": 4893, + "source": "examples/reti/validatorRegistry.algo.ts:1280", + "pc": [ + 5694 + ] + }, + { + "teal": 4894, + "source": "examples/reti/validatorRegistry.algo.ts:1280", + "pc": [ + 5695, + 5696 + ] + }, + { + "teal": 4895, + "source": "examples/reti/validatorRegistry.algo.ts:1280", + "pc": [ + 5697 + ] + }, + { + "teal": 4896, + "source": "examples/reti/validatorRegistry.algo.ts:1280", + "pc": [ + 5698 + ] + }, + { + "teal": 4897, + "source": "examples/reti/validatorRegistry.algo.ts:1280", + "pc": [ + 5699, + 5700 + ] + }, + { + "teal": 4898, + "source": "examples/reti/validatorRegistry.algo.ts:1280", + "pc": [ + 5701, + 5702 + ] + }, + { + "teal": 4899, + "source": "examples/reti/validatorRegistry.algo.ts:1280", + "pc": [ + 5703, + 5704 + ] + }, + { + "teal": 4900, + "source": "examples/reti/validatorRegistry.algo.ts:1280", + "pc": [ + 5705 + ] + }, + { + "teal": 4901, + "source": "examples/reti/validatorRegistry.algo.ts:1280", + "pc": [ + 5706 + ] + }, + { + "teal": 4902, + "source": "examples/reti/validatorRegistry.algo.ts:1280", + "pc": [ + 5707 + ] + }, + { + "teal": 4903, + "source": "examples/reti/validatorRegistry.algo.ts:1280", + "pc": [ + 5708, + 5709, + 5710 + ] + }, + { + "teal": 4904, + "source": "examples/reti/validatorRegistry.algo.ts:1280", + "pc": [ + 5711, + 5712 + ] + }, + { + "teal": 4905, + "source": "examples/reti/validatorRegistry.algo.ts:1280", + "pc": [ + 5713, + 5714, + 5715 + ] + }, + { + "teal": 4906, + "source": "examples/reti/validatorRegistry.algo.ts:1280", + "pc": [ + 5716 + ] + }, + { + "teal": 4907, + "source": "examples/reti/validatorRegistry.algo.ts:1280", + "pc": [ + 5717 + ] + }, + { + "teal": 4908, + "source": "examples/reti/validatorRegistry.algo.ts:1280", + "pc": [ + 5718 + ] + }, + { + "teal": 4909, + "source": "examples/reti/validatorRegistry.algo.ts:1280", + "pc": [ + 5719, + 5720 + ] + }, + { + "teal": 4910, + "source": "examples/reti/validatorRegistry.algo.ts:1280", + "pc": [ + 5721 + ] + }, + { + "teal": 4914, + "source": "examples/reti/validatorRegistry.algo.ts:1281", + "pc": [ + 5722, + 5723, + 5724, + 5725, + 5726, + 5727, + 5728, + 5729 + ] + }, + { + "teal": 4915, + "source": "examples/reti/validatorRegistry.algo.ts:1281", + "pc": [ + 5730 + ] + }, + { + "teal": 4916, + "source": "examples/reti/validatorRegistry.algo.ts:1281", + "pc": [ + 5731, + 5732 + ] + }, + { + "teal": 4917, + "source": "examples/reti/validatorRegistry.algo.ts:1281", + "pc": [ + 5733, + 5734 + ] + }, + { + "teal": 4918, + "source": "examples/reti/validatorRegistry.algo.ts:1281", + "pc": [ + 5735, + 5736 + ] + }, + { + "teal": 4919, + "source": "examples/reti/validatorRegistry.algo.ts:1281", + "pc": [ + 5737 + ] + }, + { + "teal": 4920, + "source": "examples/reti/validatorRegistry.algo.ts:1281", + "pc": [ + 5738 + ] + }, + { + "teal": 4921, + "source": "examples/reti/validatorRegistry.algo.ts:1281", + "pc": [ + 5739, + 5740, + 5741, + 5742, + 5743, + 5744, + 5745, + 5746 + ] + }, + { + "teal": 4922, + "source": "examples/reti/validatorRegistry.algo.ts:1281", + "pc": [ + 5747 + ] + }, + { + "teal": 4923, + "source": "examples/reti/validatorRegistry.algo.ts:1281", + "pc": [ + 5748 + ] + }, + { + "teal": 4924, + "source": "examples/reti/validatorRegistry.algo.ts:1242", + "pc": [ + 5749 + ] + }, + { + "teal": 4928, + "source": "examples/reti/validatorRegistry.algo.ts:1284", + "pc": [ + 5750, + 5751, + 5752 + ] + }, + { + "teal": 4931, + "source": "examples/reti/validatorRegistry.algo.ts:1284", + "pc": [ + 5753, + 5754 + ] + }, + { + "teal": 4932, + "source": "examples/reti/validatorRegistry.algo.ts:1284", + "pc": [ + 5755, + 5756 + ] + }, + { + "teal": 4936, + "source": "examples/reti/validatorRegistry.algo.ts:1285", + "pc": [ + 5757, + 5758, + 5759, + 5760, + 5761 + ] + }, + { + "teal": 4937, + "source": "examples/reti/validatorRegistry.algo.ts:1285", + "pc": [ + 5762, + 5763 + ] + }, + { + "teal": 4938, + "source": "examples/reti/validatorRegistry.algo.ts:1285", + "pc": [ + 5764 + ] + }, + { + "teal": 4939, + "source": "examples/reti/validatorRegistry.algo.ts:1285", + "pc": [ + 5765 + ] + }, + { + "teal": 4940, + "source": "examples/reti/validatorRegistry.algo.ts:1285", + "pc": [ + 5766 + ] + }, + { + "teal": 4941, + "source": "examples/reti/validatorRegistry.algo.ts:1285", + "pc": [ + 5767 + ] + }, + { + "teal": 4942, + "source": "examples/reti/validatorRegistry.algo.ts:1285", + "pc": [ + 5768 + ] + }, + { + "teal": 4946, + "source": "examples/reti/validatorRegistry.algo.ts:1287", + "pc": [ + 5769, + 5770, + 5771, + 5772, + 5773 + ] + }, + { + "teal": 4947, + "source": "examples/reti/validatorRegistry.algo.ts:1287", + "pc": [ + 5774, + 5775 + ] + }, + { + "teal": 4948, + "source": "examples/reti/validatorRegistry.algo.ts:1287", + "pc": [ + 5776 + ] + }, + { + "teal": 4949, + "source": "examples/reti/validatorRegistry.algo.ts:1287", + "pc": [ + 5777 + ] + }, + { + "teal": 4952, + "source": "examples/reti/validatorRegistry.algo.ts:1287", + "errorMessage": "box value does not exist: this.stakerPoolSet(staker).value", + "pc": [ + 5778 + ] + }, + { + "teal": 4953, + "source": "examples/reti/validatorRegistry.algo.ts:1287", + "pc": [ + 5779, + 5780 + ] + }, + { + "teal": 4957, + "source": "examples/reti/validatorRegistry.algo.ts:1288", + "pc": [ + 5781, + 5782 + ] + }, + { + "teal": 4958, + "source": "examples/reti/validatorRegistry.algo.ts:1288", + "pc": [ + 5783, + 5784 + ] + }, + { + "teal": 4962, + "source": "examples/reti/validatorRegistry.algo.ts:1289", + "pc": [ + 5785, + 5786 + ] + }, + { + "teal": 4963, + "source": "examples/reti/validatorRegistry.algo.ts:1289", + "pc": [ + 5787, + 5788 + ] + }, + { + "teal": 4968, + "source": "examples/reti/validatorRegistry.algo.ts:1289", + "pc": [ + 5789, + 5790 + ] + }, + { + "teal": 4969, + "source": "examples/reti/validatorRegistry.algo.ts:1289", + "pc": [ + 5791, + 5792 + ] + }, + { + "teal": 4970, + "source": "examples/reti/validatorRegistry.algo.ts:1289", + "pc": [ + 5793 + ] + }, + { + "teal": 4971, + "source": "examples/reti/validatorRegistry.algo.ts:1289", + "pc": [ + 5794, + 5795, + 5796 + ] + }, + { + "teal": 4976, + "source": "examples/reti/validatorRegistry.algo.ts:1290", + "pc": [ + 5797, + 5798 + ] + }, + { + "teal": 4977, + "source": "examples/reti/validatorRegistry.algo.ts:1290", + "pc": [ + 5799, + 5800 + ] + }, + { + "teal": 4978, + "source": "examples/reti/validatorRegistry.algo.ts:1290", + "pc": [ + 5801, + 5802 + ] + }, + { + "teal": 4979, + "source": "examples/reti/validatorRegistry.algo.ts:1290", + "pc": [ + 5803 + ] + }, + { + "teal": 4980, + "source": "examples/reti/validatorRegistry.algo.ts:1290", + "pc": [ + 5804, + 5805 + ] + }, + { + "teal": 4981, + "source": "examples/reti/validatorRegistry.algo.ts:1290", + "pc": [ + 5806 + ] + }, + { + "teal": 4982, + "source": "examples/reti/validatorRegistry.algo.ts:1290", + "pc": [ + 5807, + 5808 + ] + }, + { + "teal": 4983, + "source": "examples/reti/validatorRegistry.algo.ts:1290", + "pc": [ + 5809 + ] + }, + { + "teal": 4984, + "source": "examples/reti/validatorRegistry.algo.ts:1290", + "pc": [ + 5810, + 5811, + 5812 + ] + }, + { + "teal": 4989, + "source": "examples/reti/validatorRegistry.algo.ts:1292", + "pc": [ + 5813 + ] + }, + { + "teal": 4995, + "source": "examples/reti/validatorRegistry.algo.ts:1294", + "pc": [ + 5814, + 5815 + ] + }, + { + "teal": 4996, + "source": "examples/reti/validatorRegistry.algo.ts:1294", + "pc": [ + 5816, + 5817 + ] + }, + { + "teal": 4997, + "source": "examples/reti/validatorRegistry.algo.ts:1294", + "pc": [ + 5818 + ] + }, + { + "teal": 4998, + "source": "examples/reti/validatorRegistry.algo.ts:1294", + "pc": [ + 5819 + ] + }, + { + "teal": 4999, + "source": "examples/reti/validatorRegistry.algo.ts:1294", + "pc": [ + 5820, + 5821, + 5822 + ] + }, + { + "teal": 5000, + "source": "examples/reti/validatorRegistry.algo.ts:1294", + "pc": [ + 5823, + 5824 + ] + }, + { + "teal": 5001, + "source": "examples/reti/validatorRegistry.algo.ts:1294", + "pc": [ + 5825, + 5826 + ] + }, + { + "teal": 5002, + "source": "examples/reti/validatorRegistry.algo.ts:1294", + "pc": [ + 5827, + 5828 + ] + }, + { + "teal": 5003, + "source": "examples/reti/validatorRegistry.algo.ts:1294", + "pc": [ + 5829 + ] + }, + { + "teal": 5004, + "source": "examples/reti/validatorRegistry.algo.ts:1294", + "pc": [ + 5830, + 5831 + ] + }, + { + "teal": 5005, + "source": "examples/reti/validatorRegistry.algo.ts:1294", + "pc": [ + 5832 + ] + }, + { + "teal": 5006, + "source": "examples/reti/validatorRegistry.algo.ts:1294", + "pc": [ + 5833, + 5834 + ] + }, + { + "teal": 5007, + "source": "examples/reti/validatorRegistry.algo.ts:1294", + "pc": [ + 5835 + ] + }, + { + "teal": 5008, + "source": "examples/reti/validatorRegistry.algo.ts:1294", + "pc": [ + 5836 + ] + }, + { + "teal": 5009, + "source": "examples/reti/validatorRegistry.algo.ts:1294", + "pc": [ + 5837, + 5838 + ] + }, + { + "teal": 5010, + "source": "examples/reti/validatorRegistry.algo.ts:1294", + "pc": [ + 5839 + ] + }, + { + "teal": 5011, + "source": "examples/reti/validatorRegistry.algo.ts:1294", + "pc": [ + 5840 + ] + }, + { + "teal": 5014, + "source": "examples/reti/validatorRegistry.algo.ts:1294", + "pc": [ + 5841, + 5842, + 5843 + ] + }, + { + "teal": 5019, + "source": "examples/reti/validatorRegistry.algo.ts:1295", + "pc": [ + 5844, + 5845 + ] + }, + { + "teal": 5020, + "source": "examples/reti/validatorRegistry.algo.ts:1295", + "pc": [ + 5846, + 5847 + ] + }, + { + "teal": 5021, + "source": "examples/reti/validatorRegistry.algo.ts:1295", + "pc": [ + 5848 + ] + }, + { + "teal": 5022, + "source": "examples/reti/validatorRegistry.algo.ts:1295", + "pc": [ + 5849, + 5850 + ] + }, + { + "teal": 5029, + "source": "examples/reti/validatorRegistry.algo.ts:1289", + "pc": [ + 5851, + 5852 + ] + }, + { + "teal": 5030, + "source": "examples/reti/validatorRegistry.algo.ts:1289", + "pc": [ + 5853, + 5854 + ] + }, + { + "teal": 5031, + "source": "examples/reti/validatorRegistry.algo.ts:1289", + "pc": [ + 5855 + ] + }, + { + "teal": 5032, + "source": "examples/reti/validatorRegistry.algo.ts:1289", + "pc": [ + 5856, + 5857 + ] + }, + { + "teal": 5033, + "source": "examples/reti/validatorRegistry.algo.ts:1289", + "pc": [ + 5858, + 5859, + 5860 + ] + }, + { + "teal": 5039, + "source": "examples/reti/validatorRegistry.algo.ts:1298", + "pc": [ + 5861, + 5862 + ] + }, + { + "teal": 5040, + "source": "examples/reti/validatorRegistry.algo.ts:1298", + "pc": [ + 5863, + 5864 + ] + }, + { + "teal": 5041, + "source": "examples/reti/validatorRegistry.algo.ts:1298", + "pc": [ + 5865 + ] + }, + { + "teal": 5042, + "source": "examples/reti/validatorRegistry.algo.ts:1298", + "pc": [ + 5866, + 5867, + 5868 + ] + }, + { + "teal": 5046, + "source": "examples/reti/validatorRegistry.algo.ts:1299", + "errorMessage": "No empty slot available in the staker pool set", + "pc": [ + 5869 + ] + }, + { + "teal": 5051, + "source": "examples/reti/validatorRegistry.algo.ts:1301", + "pc": [ + 5870, + 5871 + ] + }, + { + "teal": 5052, + "source": "examples/reti/validatorRegistry.algo.ts:1301", + "pc": [ + 5872, + 5873 + ] + }, + { + "teal": 5053, + "source": "examples/reti/validatorRegistry.algo.ts:1301", + "pc": [ + 5874 + ] + }, + { + "teal": 5054, + "source": "examples/reti/validatorRegistry.algo.ts:1301", + "pc": [ + 5875, + 5876 + ] + }, + { + "teal": 5055, + "source": "examples/reti/validatorRegistry.algo.ts:1301", + "pc": [ + 5877 + ] + }, + { + "teal": 5056, + "source": "examples/reti/validatorRegistry.algo.ts:1301", + "pc": [ + 5878, + 5879 + ] + }, + { + "teal": 5057, + "source": "examples/reti/validatorRegistry.algo.ts:1301", + "pc": [ + 5880, + 5881, + 5882, + 5883, + 5884 + ] + }, + { + "teal": 5058, + "source": "examples/reti/validatorRegistry.algo.ts:1301", + "pc": [ + 5885, + 5886 + ] + }, + { + "teal": 5059, + "source": "examples/reti/validatorRegistry.algo.ts:1301", + "pc": [ + 5887 + ] + }, + { + "teal": 5060, + "source": "examples/reti/validatorRegistry.algo.ts:1301", + "pc": [ + 5888, + 5889 + ] + }, + { + "teal": 5061, + "source": "examples/reti/validatorRegistry.algo.ts:1301", + "pc": [ + 5890 + ] + }, + { + "teal": 5062, + "source": "examples/reti/validatorRegistry.algo.ts:1284", + "pc": [ + 5891 + ] + }, + { + "teal": 5073, + "source": "examples/reti/validatorRegistry.algo.ts:1312", + "pc": [ + 5892, + 5893, + 5894 + ] + }, + { + "teal": 5076, + "source": "examples/reti/validatorRegistry.algo.ts:1312", + "pc": [ + 5895, + 5896 + ] + }, + { + "teal": 5077, + "source": "examples/reti/validatorRegistry.algo.ts:1312", + "pc": [ + 5897, + 5898 + ] + }, + { + "teal": 5081, + "source": "examples/reti/validatorRegistry.algo.ts:1314", + "pc": [ + 5899, + 5900 + ] + }, + { + "teal": 5082, + "source": "examples/reti/validatorRegistry.algo.ts:1314", + "pc": [ + 5901, + 5902 + ] + }, + { + "teal": 5086, + "source": "examples/reti/validatorRegistry.algo.ts:1315", + "pc": [ + 5903, + 5904 + ] + }, + { + "teal": 5087, + "source": "examples/reti/validatorRegistry.algo.ts:1315", + "pc": [ + 5905, + 5906 + ] + }, + { + "teal": 5091, + "source": "examples/reti/validatorRegistry.algo.ts:1316", + "pc": [ + 5907, + 5908 + ] + }, + { + "teal": 5092, + "source": "examples/reti/validatorRegistry.algo.ts:1316", + "pc": [ + 5909, + 5910 + ] + }, + { + "teal": 5096, + "source": "examples/reti/validatorRegistry.algo.ts:1318", + "pc": [ + 5911, + 5912, + 5913, + 5914, + 5915 + ] + }, + { + "teal": 5097, + "source": "examples/reti/validatorRegistry.algo.ts:1318", + "pc": [ + 5916, + 5917 + ] + }, + { + "teal": 5098, + "source": "examples/reti/validatorRegistry.algo.ts:1318", + "pc": [ + 5918 + ] + }, + { + "teal": 5099, + "source": "examples/reti/validatorRegistry.algo.ts:1318", + "pc": [ + 5919 + ] + }, + { + "teal": 5102, + "source": "examples/reti/validatorRegistry.algo.ts:1318", + "errorMessage": "box value does not exist: this.stakerPoolSet(staker).value", + "pc": [ + 5920 + ] + }, + { + "teal": 5103, + "source": "examples/reti/validatorRegistry.algo.ts:1318", + "pc": [ + 5921, + 5922 + ] + }, + { + "teal": 5107, + "source": "examples/reti/validatorRegistry.algo.ts:1319", + "pc": [ + 5923, + 5924 + ] + }, + { + "teal": 5108, + "source": "examples/reti/validatorRegistry.algo.ts:1319", + "pc": [ + 5925, + 5926 + ] + }, + { + "teal": 5113, + "source": "examples/reti/validatorRegistry.algo.ts:1319", + "pc": [ + 5927, + 5928 + ] + }, + { + "teal": 5114, + "source": "examples/reti/validatorRegistry.algo.ts:1319", + "pc": [ + 5929, + 5930 + ] + }, + { + "teal": 5115, + "source": "examples/reti/validatorRegistry.algo.ts:1319", + "pc": [ + 5931 + ] + }, + { + "teal": 5116, + "source": "examples/reti/validatorRegistry.algo.ts:1319", + "pc": [ + 5932, + 5933, + 5934 + ] + }, + { + "teal": 5121, + "source": "examples/reti/validatorRegistry.algo.ts:1320", + "pc": [ + 5935, + 5936 + ] + }, + { + "teal": 5122, + "source": "examples/reti/validatorRegistry.algo.ts:1320", + "pc": [ + 5937, + 5938 + ] + }, + { + "teal": 5123, + "source": "examples/reti/validatorRegistry.algo.ts:1320", + "pc": [ + 5939, + 5940 + ] + }, + { + "teal": 5124, + "source": "examples/reti/validatorRegistry.algo.ts:1320", + "pc": [ + 5941 + ] + }, + { + "teal": 5125, + "source": "examples/reti/validatorRegistry.algo.ts:1320", + "pc": [ + 5942, + 5943 + ] + }, + { + "teal": 5126, + "source": "examples/reti/validatorRegistry.algo.ts:1320", + "pc": [ + 5944 + ] + }, + { + "teal": 5127, + "source": "examples/reti/validatorRegistry.algo.ts:1320", + "pc": [ + 5945, + 5946 + ] + }, + { + "teal": 5128, + "source": "examples/reti/validatorRegistry.algo.ts:1320", + "pc": [ + 5947 + ] + }, + { + "teal": 5129, + "source": "examples/reti/validatorRegistry.algo.ts:1320", + "pc": [ + 5948 + ] + }, + { + "teal": 5130, + "source": "examples/reti/validatorRegistry.algo.ts:1320", + "pc": [ + 5949, + 5950 + ] + }, + { + "teal": 5131, + "source": "examples/reti/validatorRegistry.algo.ts:1320", + "pc": [ + 5951 + ] + }, + { + "teal": 5132, + "source": "examples/reti/validatorRegistry.algo.ts:1320", + "pc": [ + 5952, + 5953, + 5954 + ] + }, + { + "teal": 5135, + "source": "examples/reti/validatorRegistry.algo.ts:1321", + "pc": [ + 5955, + 5956, + 5957 + ] + }, + { + "teal": 5140, + "source": "examples/reti/validatorRegistry.algo.ts:1323", + "pc": [ + 5958, + 5959 + ] + }, + { + "teal": 5141, + "source": "examples/reti/validatorRegistry.algo.ts:1323", + "pc": [ + 5960, + 5961 + ] + }, + { + "teal": 5142, + "source": "examples/reti/validatorRegistry.algo.ts:1323", + "pc": [ + 5962 + ] + }, + { + "teal": 5143, + "source": "examples/reti/validatorRegistry.algo.ts:1323", + "pc": [ + 5963, + 5964 + ] + }, + { + "teal": 5148, + "source": "examples/reti/validatorRegistry.algo.ts:1324", + "pc": [ + 5965, + 5966 + ] + }, + { + "teal": 5149, + "source": "examples/reti/validatorRegistry.algo.ts:1324", + "pc": [ + 5967, + 5968 + ] + }, + { + "teal": 5150, + "source": "examples/reti/validatorRegistry.algo.ts:1324", + "pc": [ + 5969, + 5970 + ] + }, + { + "teal": 5151, + "source": "examples/reti/validatorRegistry.algo.ts:1324", + "pc": [ + 5971 + ] + }, + { + "teal": 5152, + "source": "examples/reti/validatorRegistry.algo.ts:1324", + "pc": [ + 5972, + 5973 + ] + }, + { + "teal": 5153, + "source": "examples/reti/validatorRegistry.algo.ts:1324", + "pc": [ + 5974 + ] + }, + { + "teal": 5154, + "source": "examples/reti/validatorRegistry.algo.ts:1324", + "pc": [ + 5975, + 5976 + ] + }, + { + "teal": 5155, + "source": "examples/reti/validatorRegistry.algo.ts:1324", + "pc": [ + 5977 + ] + }, + { + "teal": 5156, + "source": "examples/reti/validatorRegistry.algo.ts:1324", + "pc": [ + 5978 + ] + }, + { + "teal": 5157, + "source": "examples/reti/validatorRegistry.algo.ts:1324", + "pc": [ + 5979, + 5980 + ] + }, + { + "teal": 5158, + "source": "examples/reti/validatorRegistry.algo.ts:1324", + "pc": [ + 5981, + 5982, + 5983 + ] + }, + { + "teal": 5159, + "source": "examples/reti/validatorRegistry.algo.ts:1324", + "pc": [ + 5984 + ] + }, + { + "teal": 5160, + "source": "examples/reti/validatorRegistry.algo.ts:1324", + "pc": [ + 5985 + ] + }, + { + "teal": 5161, + "source": "examples/reti/validatorRegistry.algo.ts:1324", + "pc": [ + 5986, + 5987, + 5988 + ] + }, + { + "teal": 5167, + "source": "examples/reti/validatorRegistry.algo.ts:1325", + "pc": [ + 5989, + 5990 + ] + }, + { + "teal": 5168, + "source": "examples/reti/validatorRegistry.algo.ts:1325", + "pc": [ + 5991, + 5992 + ] + }, + { + "teal": 5169, + "source": "examples/reti/validatorRegistry.algo.ts:1325", + "pc": [ + 5993, + 5994 + ] + }, + { + "teal": 5170, + "source": "examples/reti/validatorRegistry.algo.ts:1325", + "pc": [ + 5995 + ] + }, + { + "teal": 5171, + "source": "examples/reti/validatorRegistry.algo.ts:1325", + "pc": [ + 5996, + 5997 + ] + }, + { + "teal": 5172, + "source": "examples/reti/validatorRegistry.algo.ts:1325", + "pc": [ + 5998 + ] + }, + { + "teal": 5173, + "source": "examples/reti/validatorRegistry.algo.ts:1325", + "pc": [ + 5999, + 6000 + ] + }, + { + "teal": 5174, + "source": "examples/reti/validatorRegistry.algo.ts:1325", + "pc": [ + 6001 + ] + }, + { + "teal": 5175, + "source": "examples/reti/validatorRegistry.algo.ts:1325", + "pc": [ + 6002, + 6003, + 6004 + ] + }, + { + "teal": 5180, + "source": "examples/reti/validatorRegistry.algo.ts:1326", + "pc": [ + 6005, + 6006 + ] + }, + { + "teal": 5181, + "source": "examples/reti/validatorRegistry.algo.ts:1326", + "pc": [ + 6007, + 6008 + ] + }, + { + "teal": 5185, + "source": "examples/reti/validatorRegistry.algo.ts:1328", + "pc": [ + 6009, + 6010 + ] + }, + { + "teal": 5186, + "source": "examples/reti/validatorRegistry.algo.ts:1328", + "pc": [ + 6011, + 6012 + ] + }, + { + "teal": 5187, + "source": "examples/reti/validatorRegistry.algo.ts:1328", + "pc": [ + 6013 + ] + }, + { + "teal": 5188, + "source": "examples/reti/validatorRegistry.algo.ts:1328", + "pc": [ + 6014, + 6015, + 6016, + 6017, + 6018, + 6019, + 6020, + 6021, + 6022, + 6023, + 6024, + 6025, + 6026, + 6027, + 6028, + 6029, + 6030, + 6031, + 6032, + 6033, + 6034, + 6035, + 6036, + 6037, + 6038, + 6039 + ] + }, + { + "teal": 5189, + "source": "examples/reti/validatorRegistry.algo.ts:1328", + "pc": [ + 6040, + 6041, + 6042, + 6043, + 6044 + ] + }, + { + "teal": 5190, + "source": "examples/reti/validatorRegistry.algo.ts:1328", + "pc": [ + 6045, + 6046 + ] + }, + { + "teal": 5191, + "source": "examples/reti/validatorRegistry.algo.ts:1328", + "pc": [ + 6047 + ] + }, + { + "teal": 5192, + "source": "examples/reti/validatorRegistry.algo.ts:1328", + "pc": [ + 6048, + 6049 + ] + }, + { + "teal": 5193, + "source": "examples/reti/validatorRegistry.algo.ts:1328", + "pc": [ + 6050 + ] + }, + { + "teal": 5194, + "source": "examples/reti/validatorRegistry.algo.ts:1325", + "pc": [ + 6051, + 6052, + 6053 + ] + }, + { + "teal": 5199, + "source": "examples/reti/validatorRegistry.algo.ts:1330", + "pc": [ + 6054, + 6055 + ] + }, + { + "teal": 5200, + "source": "examples/reti/validatorRegistry.algo.ts:1330", + "pc": [ + 6056, + 6057 + ] + }, + { + "teal": 5201, + "source": "examples/reti/validatorRegistry.algo.ts:1330", + "pc": [ + 6058 + ] + }, + { + "teal": 5202, + "source": "examples/reti/validatorRegistry.algo.ts:1330", + "pc": [ + 6059, + 6060 + ] + }, + { + "teal": 5211, + "source": "examples/reti/validatorRegistry.algo.ts:1319", + "pc": [ + 6061, + 6062 + ] + }, + { + "teal": 5212, + "source": "examples/reti/validatorRegistry.algo.ts:1319", + "pc": [ + 6063, + 6064 + ] + }, + { + "teal": 5213, + "source": "examples/reti/validatorRegistry.algo.ts:1319", + "pc": [ + 6065 + ] + }, + { + "teal": 5214, + "source": "examples/reti/validatorRegistry.algo.ts:1319", + "pc": [ + 6066, + 6067 + ] + }, + { + "teal": 5215, + "source": "examples/reti/validatorRegistry.algo.ts:1319", + "pc": [ + 6068, + 6069, + 6070 + ] + }, + { + "teal": 5221, + "source": "examples/reti/validatorRegistry.algo.ts:1334", + "pc": [ + 6071, + 6072 + ] + }, + { + "teal": 5222, + "source": "examples/reti/validatorRegistry.algo.ts:1334", + "pc": [ + 6073 + ] + }, + { + "teal": 5223, + "source": "examples/reti/validatorRegistry.algo.ts:1334", + "pc": [ + 6074, + 6075, + 6076 + ] + }, + { + "teal": 5227, + "source": "examples/reti/validatorRegistry.algo.ts:1335", + "errorMessage": "No matching slot found when told to remove a pool from the stakers set", + "pc": [ + 6077 + ] + }, + { + "teal": 5232, + "source": "examples/reti/validatorRegistry.algo.ts:1338", + "pc": [ + 6078, + 6079, + 6080 + ] + }, + { + "teal": 5233, + "source": "examples/reti/validatorRegistry.algo.ts:1338", + "pc": [ + 6081, + 6082 + ] + }, + { + "teal": 5234, + "source": "examples/reti/validatorRegistry.algo.ts:1338", + "pc": [ + 6083, + 6084 + ] + }, + { + "teal": 5235, + "source": "examples/reti/validatorRegistry.algo.ts:1338", + "pc": [ + 6085, + 6086 + ] + }, + { + "teal": 5236, + "source": "examples/reti/validatorRegistry.algo.ts:1338", + "pc": [ + 6087 + ] + }, + { + "teal": 5237, + "source": "examples/reti/validatorRegistry.algo.ts:1338", + "pc": [ + 6088 + ] + }, + { + "teal": 5238, + "source": "examples/reti/validatorRegistry.algo.ts:1338", + "pc": [ + 6089, + 6090 + ] + }, + { + "teal": 5239, + "source": "examples/reti/validatorRegistry.algo.ts:1338", + "pc": [ + 6091, + 6092 + ] + }, + { + "teal": 5240, + "source": "examples/reti/validatorRegistry.algo.ts:1338", + "pc": [ + 6093, + 6094 + ] + }, + { + "teal": 5241, + "source": "examples/reti/validatorRegistry.algo.ts:1338", + "pc": [ + 6095 + ] + }, + { + "teal": 5242, + "source": "examples/reti/validatorRegistry.algo.ts:1338", + "pc": [ + 6096 + ] + }, + { + "teal": 5245, + "source": "examples/reti/validatorRegistry.algo.ts:1312", + "pc": [ + 6097, + 6098 + ] + }, + { + "teal": 5248, + "source": "examples/reti/validatorRegistry.algo.ts:1312", + "pc": [ + 6099, + 6100 + ] + }, + { + "teal": 5249, + "source": "examples/reti/validatorRegistry.algo.ts:1312", + "pc": [ + 6101 + ] + }, + { + "teal": 5253, + "source": "examples/reti/validatorRegistry.algo.ts:1341", + "pc": [ + 6102, + 6103, + 6104 + ] + }, + { + "teal": 5256, + "source": "examples/reti/validatorRegistry.algo.ts:1341", + "pc": [ + 6105, + 6106 + ] + }, + { + "teal": 5257, + "source": "examples/reti/validatorRegistry.algo.ts:1341", + "pc": [ + 6107, + 6108 + ] + }, + { + "teal": 5261, + "source": "examples/reti/validatorRegistry.algo.ts:1342", + "pc": [ + 6109, + 6110, + 6111 + ] + }, + { + "teal": 5262, + "source": "examples/reti/validatorRegistry.algo.ts:1342", + "pc": [ + 6112, + 6113, + 6114 + ] + }, + { + "teal": 5263, + "source": "examples/reti/validatorRegistry.algo.ts:1342", + "pc": [ + 6115, + 6116, + 6117 + ] + }, + { + "teal": 5264, + "source": "examples/reti/validatorRegistry.algo.ts:1342", + "pc": [ + 6118, + 6119 + ] + }, + { + "teal": 5265, + "source": "examples/reti/validatorRegistry.algo.ts:1342", + "pc": [ + 6120 + ] + }, + { + "teal": 5266, + "source": "examples/reti/validatorRegistry.algo.ts:1342", + "pc": [ + 6121 + ] + }, + { + "teal": 5267, + "source": "examples/reti/validatorRegistry.algo.ts:1342", + "pc": [ + 6122, + 6123 + ] + }, + { + "teal": 5268, + "source": "examples/reti/validatorRegistry.algo.ts:1342", + "pc": [ + 6124 + ] + }, + { + "teal": 5269, + "source": "examples/reti/validatorRegistry.algo.ts:1342", + "pc": [ + 6125, + 6126 + ] + }, + { + "teal": 5273, + "source": "examples/reti/validatorRegistry.algo.ts:1343", + "pc": [ + 6127, + 6128, + 6129 + ] + }, + { + "teal": 5274, + "source": "examples/reti/validatorRegistry.algo.ts:1343", + "pc": [ + 6130, + 6131 + ] + }, + { + "teal": 5275, + "source": "examples/reti/validatorRegistry.algo.ts:1343", + "pc": [ + 6132, + 6133, + 6134 + ] + }, + { + "teal": 5276, + "source": "examples/reti/validatorRegistry.algo.ts:1343", + "pc": [ + 6135, + 6136 + ] + }, + { + "teal": 5277, + "source": "examples/reti/validatorRegistry.algo.ts:1343", + "pc": [ + 6137 + ] + }, + { + "teal": 5278, + "source": "examples/reti/validatorRegistry.algo.ts:1343", + "pc": [ + 6138 + ] + }, + { + "teal": 5279, + "source": "examples/reti/validatorRegistry.algo.ts:1343", + "pc": [ + 6139, + 6140 + ] + }, + { + "teal": 5280, + "source": "examples/reti/validatorRegistry.algo.ts:1343", + "pc": [ + 6141 + ] + }, + { + "teal": 5281, + "source": "examples/reti/validatorRegistry.algo.ts:1343", + "pc": [ + 6142 + ] + }, + { + "teal": 5282, + "source": "examples/reti/validatorRegistry.algo.ts:1343", + "pc": [ + 6143, + 6144 + ] + }, + { + "teal": 5286, + "source": "examples/reti/validatorRegistry.algo.ts:1345", + "pc": [ + 6145, + 6146 + ] + }, + { + "teal": 5287, + "source": "examples/reti/validatorRegistry.algo.ts:1345", + "pc": [ + 6147, + 6148 + ] + }, + { + "teal": 5288, + "source": "examples/reti/validatorRegistry.algo.ts:1345", + "pc": [ + 6149 + ] + }, + { + "teal": 5289, + "source": "examples/reti/validatorRegistry.algo.ts:1345", + "pc": [ + 6150 + ] + }, + { + "teal": 5290, + "source": "examples/reti/validatorRegistry.algo.ts:1345", + "pc": [ + 6151, + 6152, + 6153 + ] + }, + { + "teal": 5291, + "source": "examples/reti/validatorRegistry.algo.ts:1345", + "pc": [ + 6154, + 6155 + ] + }, + { + "teal": 5292, + "source": "examples/reti/validatorRegistry.algo.ts:1345", + "pc": [ + 6156, + 6157 + ] + }, + { + "teal": 5293, + "source": "examples/reti/validatorRegistry.algo.ts:1345", + "pc": [ + 6158 + ] + }, + { + "teal": 5294, + "source": "examples/reti/validatorRegistry.algo.ts:1345", + "pc": [ + 6159 + ] + }, + { + "teal": 5298, + "source": "examples/reti/validatorRegistry.algo.ts:1345", + "errorMessage": "node number not in valid range", + "pc": [ + 6160 + ] + }, + { + "teal": 5302, + "source": "examples/reti/validatorRegistry.algo.ts:1347", + "pc": [ + 6161, + 6162 + ] + }, + { + "teal": 5303, + "source": "examples/reti/validatorRegistry.algo.ts:1347", + "pc": [ + 6163, + 6164 + ] + }, + { + "teal": 5308, + "source": "examples/reti/validatorRegistry.algo.ts:1347", + "pc": [ + 6165, + 6166 + ] + }, + { + "teal": 5309, + "source": "examples/reti/validatorRegistry.algo.ts:1347", + "pc": [ + 6167, + 6168 + ] + }, + { + "teal": 5310, + "source": "examples/reti/validatorRegistry.algo.ts:1347", + "pc": [ + 6169 + ] + }, + { + "teal": 5311, + "source": "examples/reti/validatorRegistry.algo.ts:1347", + "pc": [ + 6170, + 6171, + 6172 + ] + }, + { + "teal": 5316, + "source": "examples/reti/validatorRegistry.algo.ts:1348", + "pc": [ + 6173, + 6174 + ] + }, + { + "teal": 5317, + "source": "examples/reti/validatorRegistry.algo.ts:1348", + "pc": [ + 6175, + 6176 + ] + }, + { + "teal": 5318, + "source": "examples/reti/validatorRegistry.algo.ts:1348", + "pc": [ + 6177, + 6178 + ] + }, + { + "teal": 5319, + "source": "examples/reti/validatorRegistry.algo.ts:1348", + "pc": [ + 6179, + 6180 + ] + }, + { + "teal": 5320, + "source": "examples/reti/validatorRegistry.algo.ts:1348", + "pc": [ + 6181 + ] + }, + { + "teal": 5321, + "source": "examples/reti/validatorRegistry.algo.ts:1348", + "pc": [ + 6182, + 6183 + ] + }, + { + "teal": 5322, + "source": "examples/reti/validatorRegistry.algo.ts:1348", + "pc": [ + 6184 + ] + }, + { + "teal": 5323, + "source": "examples/reti/validatorRegistry.algo.ts:1348", + "pc": [ + 6185 + ] + }, + { + "teal": 5324, + "source": "examples/reti/validatorRegistry.algo.ts:1348", + "pc": [ + 6186, + 6187 + ] + }, + { + "teal": 5325, + "source": "examples/reti/validatorRegistry.algo.ts:1348", + "pc": [ + 6188 + ] + }, + { + "teal": 5326, + "source": "examples/reti/validatorRegistry.algo.ts:1348", + "pc": [ + 6189, + 6190 + ] + }, + { + "teal": 5327, + "source": "examples/reti/validatorRegistry.algo.ts:1348", + "pc": [ + 6191, + 6192 + ] + }, + { + "teal": 5328, + "source": "examples/reti/validatorRegistry.algo.ts:1348", + "pc": [ + 6193 + ] + }, + { + "teal": 5329, + "source": "examples/reti/validatorRegistry.algo.ts:1348", + "pc": [ + 6194 + ] + }, + { + "teal": 5330, + "source": "examples/reti/validatorRegistry.algo.ts:1348", + "pc": [ + 6195, + 6196 + ] + }, + { + "teal": 5331, + "source": "examples/reti/validatorRegistry.algo.ts:1348", + "pc": [ + 6197 + ] + }, + { + "teal": 5332, + "source": "examples/reti/validatorRegistry.algo.ts:1348", + "pc": [ + 6198 + ] + }, + { + "teal": 5333, + "source": "examples/reti/validatorRegistry.algo.ts:1348", + "pc": [ + 6199, + 6200 + ] + }, + { + "teal": 5334, + "source": "examples/reti/validatorRegistry.algo.ts:1348", + "pc": [ + 6201 + ] + }, + { + "teal": 5335, + "source": "examples/reti/validatorRegistry.algo.ts:1348", + "pc": [ + 6202, + 6203, + 6204 + ] + }, + { + "teal": 5340, + "source": "examples/reti/validatorRegistry.algo.ts:1350", + "pc": [ + 6205, + 6206, + 6207 + ] + }, + { + "teal": 5341, + "source": "examples/reti/validatorRegistry.algo.ts:1350", + "pc": [ + 6208, + 6209 + ] + }, + { + "teal": 5342, + "source": "examples/reti/validatorRegistry.algo.ts:1350", + "pc": [ + 6210, + 6211 + ] + }, + { + "teal": 5343, + "source": "examples/reti/validatorRegistry.algo.ts:1350", + "pc": [ + 6212 + ] + }, + { + "teal": 5344, + "source": "examples/reti/validatorRegistry.algo.ts:1350", + "pc": [ + 6213, + 6214 + ] + }, + { + "teal": 5345, + "source": "examples/reti/validatorRegistry.algo.ts:1350", + "pc": [ + 6215 + ] + }, + { + "teal": 5346, + "source": "examples/reti/validatorRegistry.algo.ts:1350", + "pc": [ + 6216 + ] + }, + { + "teal": 5347, + "source": "examples/reti/validatorRegistry.algo.ts:1350", + "pc": [ + 6217, + 6218 + ] + }, + { + "teal": 5348, + "source": "examples/reti/validatorRegistry.algo.ts:1350", + "pc": [ + 6219 + ] + }, + { + "teal": 5349, + "source": "examples/reti/validatorRegistry.algo.ts:1350", + "pc": [ + 6220, + 6221 + ] + }, + { + "teal": 5350, + "source": "examples/reti/validatorRegistry.algo.ts:1350", + "pc": [ + 6222, + 6223 + ] + }, + { + "teal": 5351, + "source": "examples/reti/validatorRegistry.algo.ts:1350", + "pc": [ + 6224 + ] + }, + { + "teal": 5352, + "source": "examples/reti/validatorRegistry.algo.ts:1350", + "pc": [ + 6225 + ] + }, + { + "teal": 5353, + "source": "examples/reti/validatorRegistry.algo.ts:1350", + "pc": [ + 6226, + 6227 + ] + }, + { + "teal": 5354, + "source": "examples/reti/validatorRegistry.algo.ts:1350", + "pc": [ + 6228 + ] + }, + { + "teal": 5355, + "source": "examples/reti/validatorRegistry.algo.ts:1350", + "pc": [ + 6229, + 6230, + 6231 + ] + }, + { + "teal": 5356, + "source": "examples/reti/validatorRegistry.algo.ts:1350", + "pc": [ + 6232, + 6233 + ] + }, + { + "teal": 5357, + "source": "examples/reti/validatorRegistry.algo.ts:1350", + "pc": [ + 6234 + ] + }, + { + "teal": 5358, + "source": "examples/reti/validatorRegistry.algo.ts:1350", + "pc": [ + 6235 + ] + }, + { + "teal": 5359, + "source": "examples/reti/validatorRegistry.algo.ts:1350", + "pc": [ + 6236, + 6237 + ] + }, + { + "teal": 5360, + "source": "examples/reti/validatorRegistry.algo.ts:1350", + "pc": [ + 6238 + ] + }, + { + "teal": 5364, + "source": "examples/reti/validatorRegistry.algo.ts:1351", + "pc": [ + 6239 + ] + }, + { + "teal": 5371, + "source": "examples/reti/validatorRegistry.algo.ts:1347", + "pc": [ + 6240, + 6241 + ] + }, + { + "teal": 5372, + "source": "examples/reti/validatorRegistry.algo.ts:1347", + "pc": [ + 6242, + 6243 + ] + }, + { + "teal": 5373, + "source": "examples/reti/validatorRegistry.algo.ts:1347", + "pc": [ + 6244 + ] + }, + { + "teal": 5374, + "source": "examples/reti/validatorRegistry.algo.ts:1347", + "pc": [ + 6245, + 6246 + ] + }, + { + "teal": 5375, + "source": "examples/reti/validatorRegistry.algo.ts:1347", + "pc": [ + 6247, + 6248, + 6249 + ] + }, + { + "teal": 5379, + "source": "examples/reti/validatorRegistry.algo.ts:1354", + "errorMessage": "no available space in specified node for this pool", + "pc": [ + 6250 + ] + }, + { + "teal": 5380, + "source": "examples/reti/validatorRegistry.algo.ts:1341", + "pc": [ + 6251 + ] + }, + { + "teal": 5390, + "source": "examples/reti/validatorRegistry.algo.ts:1364", + "pc": [ + 6252, + 6253, + 6254 + ] + }, + { + "teal": 5393, + "source": "examples/reti/validatorRegistry.algo.ts:1364", + "pc": [ + 6255, + 6256 + ] + }, + { + "teal": 5394, + "source": "examples/reti/validatorRegistry.algo.ts:1364", + "pc": [ + 6257, + 6258 + ] + }, + { + "teal": 5398, + "source": "examples/reti/validatorRegistry.algo.ts:1365", + "pc": [ + 6259, + 6260 + ] + }, + { + "teal": 5399, + "source": "examples/reti/validatorRegistry.algo.ts:1365", + "pc": [ + 6261, + 6262 + ] + }, + { + "teal": 5400, + "source": "examples/reti/validatorRegistry.algo.ts:1365", + "pc": [ + 6263, + 6264, + 6265 + ] + }, + { + "teal": 5401, + "source": "examples/reti/validatorRegistry.algo.ts:1365", + "pc": [ + 6266, + 6267 + ] + }, + { + "teal": 5402, + "source": "examples/reti/validatorRegistry.algo.ts:1365", + "pc": [ + 6268 + ] + }, + { + "teal": 5403, + "source": "examples/reti/validatorRegistry.algo.ts:1365", + "pc": [ + 6269 + ] + }, + { + "teal": 5404, + "source": "examples/reti/validatorRegistry.algo.ts:1365", + "pc": [ + 6270, + 6271 + ] + }, + { + "teal": 5405, + "source": "examples/reti/validatorRegistry.algo.ts:1365", + "pc": [ + 6272 + ] + }, + { + "teal": 5406, + "source": "examples/reti/validatorRegistry.algo.ts:1365", + "pc": [ + 6273 + ] + }, + { + "teal": 5407, + "source": "examples/reti/validatorRegistry.algo.ts:1365", + "pc": [ + 6274, + 6275 + ] + }, + { + "teal": 5412, + "source": "examples/reti/validatorRegistry.algo.ts:1366", + "pc": [ + 6276, + 6277 + ] + }, + { + "teal": 5413, + "source": "examples/reti/validatorRegistry.algo.ts:1366", + "pc": [ + 6278, + 6279 + ] + }, + { + "teal": 5414, + "source": "examples/reti/validatorRegistry.algo.ts:1366", + "pc": [ + 6280 + ] + }, + { + "teal": 5415, + "source": "examples/reti/validatorRegistry.algo.ts:1366", + "pc": [ + 6281, + 6282, + 6283 + ] + }, + { + "teal": 5420, + "source": "examples/reti/validatorRegistry.algo.ts:1367", + "pc": [ + 6284 + ] + }, + { + "teal": 5425, + "source": "examples/reti/validatorRegistry.algo.ts:1369", + "pc": [ + 6285, + 6286 + ] + }, + { + "teal": 5426, + "source": "examples/reti/validatorRegistry.algo.ts:1369", + "pc": [ + 6287, + 6288 + ] + }, + { + "teal": 5430, + "source": "examples/reti/validatorRegistry.algo.ts:1370", + "pc": [ + 6289, + 6290 + ] + }, + { + "teal": 5431, + "source": "examples/reti/validatorRegistry.algo.ts:1370", + "pc": [ + 6291, + 6292, + 6293 + ] + }, + { + "teal": 5432, + "source": "examples/reti/validatorRegistry.algo.ts:1370", + "pc": [ + 6294, + 6295, + 6296 + ] + }, + { + "teal": 5433, + "source": "examples/reti/validatorRegistry.algo.ts:1370", + "pc": [ + 6297, + 6298 + ] + }, + { + "teal": 5434, + "source": "examples/reti/validatorRegistry.algo.ts:1370", + "pc": [ + 6299 + ] + }, + { + "teal": 5435, + "source": "examples/reti/validatorRegistry.algo.ts:1370", + "pc": [ + 6300 + ] + }, + { + "teal": 5436, + "source": "examples/reti/validatorRegistry.algo.ts:1370", + "pc": [ + 6301, + 6302 + ] + }, + { + "teal": 5437, + "source": "examples/reti/validatorRegistry.algo.ts:1370", + "pc": [ + 6303 + ] + }, + { + "teal": 5438, + "source": "examples/reti/validatorRegistry.algo.ts:1370", + "pc": [ + 6304, + 6305 + ] + }, + { + "teal": 5445, + "source": "examples/reti/validatorRegistry.algo.ts:1374", + "pc": [ + 6306, + 6307 + ] + }, + { + "teal": 5446, + "source": "examples/reti/validatorRegistry.algo.ts:1374", + "pc": [ + 6308, + 6309 + ] + }, + { + "teal": 5447, + "source": "examples/reti/validatorRegistry.algo.ts:1374", + "pc": [ + 6310 + ] + }, + { + "teal": 5448, + "source": "examples/reti/validatorRegistry.algo.ts:1374", + "pc": [ + 6311 + ] + }, + { + "teal": 5449, + "source": "examples/reti/validatorRegistry.algo.ts:1374", + "pc": [ + 6312, + 6313, + 6314 + ] + }, + { + "teal": 5450, + "source": "examples/reti/validatorRegistry.algo.ts:1375", + "pc": [ + 6315, + 6316 + ] + }, + { + "teal": 5451, + "source": "examples/reti/validatorRegistry.algo.ts:1375", + "pc": [ + 6317, + 6318 + ] + }, + { + "teal": 5452, + "source": "examples/reti/validatorRegistry.algo.ts:1375", + "pc": [ + 6319 + ] + }, + { + "teal": 5453, + "source": "examples/reti/validatorRegistry.algo.ts:1374", + "pc": [ + 6320 + ] + }, + { + "teal": 5456, + "source": "examples/reti/validatorRegistry.algo.ts:1375", + "pc": [ + 6321 + ] + }, + { + "teal": 5457, + "source": "examples/reti/validatorRegistry.algo.ts:1375", + "pc": [ + 6322, + 6323, + 6324 + ] + }, + { + "teal": 5458, + "source": "examples/reti/validatorRegistry.algo.ts:1376", + "pc": [ + 6325, + 6326 + ] + }, + { + "teal": 5459, + "source": "examples/reti/validatorRegistry.algo.ts:1376", + "pc": [ + 6327, + 6328 + ] + }, + { + "teal": 5460, + "source": "examples/reti/validatorRegistry.algo.ts:1376", + "pc": [ + 6329 + ] + }, + { + "teal": 5461, + "source": "examples/reti/validatorRegistry.algo.ts:1375", + "pc": [ + 6330 + ] + }, + { + "teal": 5464, + "source": "examples/reti/validatorRegistry.algo.ts:1373", + "pc": [ + 6331, + 6332, + 6333 + ] + }, + { + "teal": 5469, + "source": "examples/reti/validatorRegistry.algo.ts:1378", + "pc": [ + 6334, + 6335 + ] + }, + { + "teal": 5470, + "source": "examples/reti/validatorRegistry.algo.ts:1378", + "pc": [ + 6336, + 6337 + ] + }, + { + "teal": 5471, + "source": "examples/reti/validatorRegistry.algo.ts:1378", + "pc": [ + 6338 + ] + }, + { + "teal": 5472, + "source": "examples/reti/validatorRegistry.algo.ts:1378", + "pc": [ + 6339 + ] + }, + { + "teal": 5476, + "source": "examples/reti/validatorRegistry.algo.ts:1379", + "pc": [ + 6340, + 6341, + 6342 + ] + }, + { + "teal": 5477, + "source": "examples/reti/validatorRegistry.algo.ts:1379", + "pc": [ + 6343, + 6344 + ] + }, + { + "teal": 5478, + "source": "examples/reti/validatorRegistry.algo.ts:1379", + "pc": [ + 6345, + 6346, + 6347 + ] + }, + { + "teal": 5479, + "source": "examples/reti/validatorRegistry.algo.ts:1379", + "pc": [ + 6348, + 6349 + ] + }, + { + "teal": 5480, + "source": "examples/reti/validatorRegistry.algo.ts:1379", + "pc": [ + 6350 + ] + }, + { + "teal": 5481, + "source": "examples/reti/validatorRegistry.algo.ts:1379", + "pc": [ + 6351 + ] + }, + { + "teal": 5482, + "source": "examples/reti/validatorRegistry.algo.ts:1379", + "pc": [ + 6352, + 6353 + ] + }, + { + "teal": 5483, + "source": "examples/reti/validatorRegistry.algo.ts:1379", + "pc": [ + 6354 + ] + }, + { + "teal": 5484, + "source": "examples/reti/validatorRegistry.algo.ts:1379", + "pc": [ + 6355 + ] + }, + { + "teal": 5485, + "source": "examples/reti/validatorRegistry.algo.ts:1379", + "pc": [ + 6356, + 6357 + ] + }, + { + "teal": 5490, + "source": "examples/reti/validatorRegistry.algo.ts:1380", + "pc": [ + 6358, + 6359 + ] + }, + { + "teal": 5491, + "source": "examples/reti/validatorRegistry.algo.ts:1380", + "pc": [ + 6360, + 6361 + ] + }, + { + "teal": 5492, + "source": "examples/reti/validatorRegistry.algo.ts:1380", + "pc": [ + 6362 + ] + }, + { + "teal": 5493, + "source": "examples/reti/validatorRegistry.algo.ts:1380", + "pc": [ + 6363, + 6364, + 6365 + ] + }, + { + "teal": 5498, + "source": "examples/reti/validatorRegistry.algo.ts:1381", + "pc": [ + 6366, + 6367 + ] + }, + { + "teal": 5499, + "source": "examples/reti/validatorRegistry.algo.ts:1381", + "pc": [ + 6368, + 6369 + ] + }, + { + "teal": 5507, + "source": "examples/reti/validatorRegistry.algo.ts:1384", + "pc": [ + 6370, + 6371 + ] + }, + { + "teal": 5508, + "source": "examples/reti/validatorRegistry.algo.ts:1384", + "pc": [ + 6372, + 6373 + ] + }, + { + "teal": 5509, + "source": "examples/reti/validatorRegistry.algo.ts:1384", + "pc": [ + 6374, + 6375 + ] + }, + { + "teal": 5510, + "source": "examples/reti/validatorRegistry.algo.ts:1384", + "pc": [ + 6376 + ] + }, + { + "teal": 5511, + "source": "examples/reti/validatorRegistry.algo.ts:1384", + "pc": [ + 6377, + 6378 + ] + }, + { + "teal": 5512, + "source": "examples/reti/validatorRegistry.algo.ts:1384", + "pc": [ + 6379 + ] + }, + { + "teal": 5515, + "source": "examples/reti/validatorRegistry.algo.ts:1383", + "errorMessage": "must have required minimum balance of validator defined token to add stake", + "pc": [ + 6380 + ] + }, + { + "teal": 5521, + "source": "examples/reti/validatorRegistry.algo.ts:1388", + "pc": [ + 6381, + 6382 + ] + }, + { + "teal": 5522, + "source": "examples/reti/validatorRegistry.algo.ts:1388", + "pc": [ + 6383, + 6384 + ] + }, + { + "teal": 5523, + "source": "examples/reti/validatorRegistry.algo.ts:1388", + "pc": [ + 6385 + ] + }, + { + "teal": 5524, + "source": "examples/reti/validatorRegistry.algo.ts:1388", + "pc": [ + 6386, + 6387, + 6388 + ] + }, + { + "teal": 5532, + "source": "examples/reti/validatorRegistry.algo.ts:1390", + "pc": [ + 6389, + 6390 + ] + }, + { + "teal": 5533, + "source": "examples/reti/validatorRegistry.algo.ts:1390", + "pc": [ + 6391, + 6392 + ] + }, + { + "teal": 5534, + "source": "examples/reti/validatorRegistry.algo.ts:1390", + "pc": [ + 6393 + ] + }, + { + "teal": 5535, + "source": "examples/reti/validatorRegistry.algo.ts:1390", + "pc": [ + 6394, + 6395 + ] + }, + { + "teal": 5536, + "source": "examples/reti/validatorRegistry.algo.ts:1390", + "pc": [ + 6396, + 6397, + 6398 + ] + }, + { + "teal": 5537, + "source": "examples/reti/validatorRegistry.algo.ts:1390", + "pc": [ + 6399 + ] + }, + { + "teal": 5540, + "source": "examples/reti/validatorRegistry.algo.ts:1389", + "errorMessage": "specified asset must be created by creator that the validator defined as a requirement to stake", + "pc": [ + 6400 + ] + }, + { + "teal": 5546, + "source": "examples/reti/validatorRegistry.algo.ts:1394", + "pc": [ + 6401, + 6402 + ] + }, + { + "teal": 5547, + "source": "examples/reti/validatorRegistry.algo.ts:1394", + "pc": [ + 6403, + 6404 + ] + }, + { + "teal": 5548, + "source": "examples/reti/validatorRegistry.algo.ts:1394", + "pc": [ + 6405 + ] + }, + { + "teal": 5549, + "source": "examples/reti/validatorRegistry.algo.ts:1394", + "pc": [ + 6406, + 6407, + 6408 + ] + }, + { + "teal": 5554, + "source": "examples/reti/validatorRegistry.algo.ts:1395", + "pc": [ + 6409, + 6410 + ] + }, + { + "teal": 5555, + "source": "examples/reti/validatorRegistry.algo.ts:1395", + "pc": [ + 6411, + 6412 + ] + }, + { + "teal": 5556, + "source": "examples/reti/validatorRegistry.algo.ts:1395", + "pc": [ + 6413 + ] + }, + { + "teal": 5557, + "source": "examples/reti/validatorRegistry.algo.ts:1395", + "pc": [ + 6414 + ] + }, + { + "teal": 5561, + "source": "examples/reti/validatorRegistry.algo.ts:1396", + "pc": [ + 6415, + 6416 + ] + }, + { + "teal": 5562, + "source": "examples/reti/validatorRegistry.algo.ts:1396", + "pc": [ + 6417, + 6418 + ] + }, + { + "teal": 5566, + "source": "examples/reti/validatorRegistry.algo.ts:1397", + "pc": [ + 6419, + 6420 + ] + }, + { + "teal": 5567, + "source": "examples/reti/validatorRegistry.algo.ts:1397", + "pc": [ + 6421, + 6422, + 6423 + ] + }, + { + "teal": 5568, + "source": "examples/reti/validatorRegistry.algo.ts:1397", + "pc": [ + 6424 + ] + }, + { + "teal": 5569, + "source": "examples/reti/validatorRegistry.algo.ts:1397", + "pc": [ + 6425, + 6426 + ] + }, + { + "teal": 5570, + "source": "examples/reti/validatorRegistry.algo.ts:1397", + "pc": [ + 6427, + 6428, + 6429 + ] + }, + { + "teal": 5571, + "source": "examples/reti/validatorRegistry.algo.ts:1397", + "pc": [ + 6430 + ] + }, + { + "teal": 5572, + "source": "examples/reti/validatorRegistry.algo.ts:1397", + "pc": [ + 6431, + 6432 + ] + }, + { + "teal": 5573, + "source": "examples/reti/validatorRegistry.algo.ts:1397", + "pc": [ + 6433, + 6434 + ] + }, + { + "teal": 5574, + "source": "examples/reti/validatorRegistry.algo.ts:1397", + "pc": [ + 6435, + 6436 + ] + }, + { + "teal": 5580, + "source": "examples/reti/validatorRegistry.algo.ts:1398", + "pc": [ + 6437, + 6438 + ] + }, + { + "teal": 5581, + "source": "examples/reti/validatorRegistry.algo.ts:1398", + "pc": [ + 6439, + 6440 + ] + }, + { + "teal": 5582, + "source": "examples/reti/validatorRegistry.algo.ts:1398", + "pc": [ + 6441 + ] + }, + { + "teal": 5583, + "source": "examples/reti/validatorRegistry.algo.ts:1398", + "pc": [ + 6442, + 6443, + 6444 + ] + }, + { + "teal": 5588, + "source": "examples/reti/validatorRegistry.algo.ts:1399", + "pc": [ + 6445, + 6446 + ] + }, + { + "teal": 5589, + "source": "examples/reti/validatorRegistry.algo.ts:1399", + "pc": [ + 6447, + 6448 + ] + }, + { + "teal": 5590, + "source": "examples/reti/validatorRegistry.algo.ts:1400", + "pc": [ + 6449, + 6450, + 6451 + ] + }, + { + "teal": 5596, + "source": "examples/reti/validatorRegistry.algo.ts:1397", + "pc": [ + 6452, + 6453 + ] + }, + { + "teal": 5597, + "source": "examples/reti/validatorRegistry.algo.ts:1397", + "pc": [ + 6454, + 6455 + ] + }, + { + "teal": 5598, + "source": "examples/reti/validatorRegistry.algo.ts:1397", + "pc": [ + 6456 + ] + }, + { + "teal": 5599, + "source": "examples/reti/validatorRegistry.algo.ts:1397", + "pc": [ + 6457 + ] + }, + { + "teal": 5600, + "source": "examples/reti/validatorRegistry.algo.ts:1397", + "pc": [ + 6458, + 6459 + ] + }, + { + "teal": 5601, + "source": "examples/reti/validatorRegistry.algo.ts:1397", + "pc": [ + 6460 + ] + }, + { + "teal": 5602, + "source": "examples/reti/validatorRegistry.algo.ts:1397", + "pc": [ + 6461, + 6462, + 6463 + ] + }, + { + "teal": 5603, + "source": "examples/reti/validatorRegistry.algo.ts:1397", + "pc": [ + 6464, + 6465 + ] + }, + { + "teal": 5604, + "source": "examples/reti/validatorRegistry.algo.ts:1397", + "pc": [ + 6466, + 6467 + ] + }, + { + "teal": 5605, + "source": "examples/reti/validatorRegistry.algo.ts:1397", + "pc": [ + 6468, + 6469 + ] + }, + { + "teal": 5606, + "source": "examples/reti/validatorRegistry.algo.ts:1397", + "pc": [ + 6470, + 6471 + ] + }, + { + "teal": 5607, + "source": "examples/reti/validatorRegistry.algo.ts:1397", + "pc": [ + 6472 + ] + }, + { + "teal": 5608, + "source": "examples/reti/validatorRegistry.algo.ts:1397", + "pc": [ + 6473 + ] + }, + { + "teal": 5609, + "source": "examples/reti/validatorRegistry.algo.ts:1397", + "pc": [ + 6474, + 6475 + ] + }, + { + "teal": 5610, + "source": "examples/reti/validatorRegistry.algo.ts:1397", + "pc": [ + 6476, + 6477, + 6478 + ] + }, + { + "teal": 5615, + "source": "examples/reti/validatorRegistry.algo.ts:1403", + "pc": [ + 6479, + 6480 + ] + }, + { + "teal": 5618, + "source": "examples/reti/validatorRegistry.algo.ts:1403", + "errorMessage": "specified asset must be identical to the asset id defined as a requirement to stake", + "pc": [ + 6481 + ] + }, + { + "teal": 5624, + "source": "examples/reti/validatorRegistry.algo.ts:1405", + "pc": [ + 6482, + 6483 + ] + }, + { + "teal": 5625, + "source": "examples/reti/validatorRegistry.algo.ts:1405", + "pc": [ + 6484, + 6485 + ] + }, + { + "teal": 5626, + "source": "examples/reti/validatorRegistry.algo.ts:1405", + "pc": [ + 6486 + ] + }, + { + "teal": 5627, + "source": "examples/reti/validatorRegistry.algo.ts:1405", + "pc": [ + 6487, + 6488, + 6489 + ] + }, + { + "teal": 5635, + "source": "examples/reti/validatorRegistry.algo.ts:1409", + "pc": [ + 6490, + 6491 + ] + }, + { + "teal": 5636, + "source": "examples/reti/validatorRegistry.algo.ts:1409", + "pc": [ + 6492, + 6493 + ] + }, + { + "teal": 5637, + "source": "examples/reti/validatorRegistry.algo.ts:1409", + "pc": [ + 6494 + ] + }, + { + "teal": 5638, + "source": "examples/reti/validatorRegistry.algo.ts:1409", + "pc": [ + 6495, + 6496 + ] + }, + { + "teal": 5639, + "source": "examples/reti/validatorRegistry.algo.ts:1409", + "pc": [ + 6497, + 6498, + 6499 + ] + }, + { + "teal": 5640, + "source": "examples/reti/validatorRegistry.algo.ts:1409", + "pc": [ + 6500 + ] + }, + { + "teal": 5641, + "source": "examples/reti/validatorRegistry.algo.ts:1409", + "pc": [ + 6501, + 6502, + 6503 + ] + }, + { + "teal": 5644, + "source": "examples/reti/validatorRegistry.algo.ts:1408", + "errorMessage": "specified asset must be created by creator that is one of the linked addresses in an nfd", + "pc": [ + 6504 + ] + }, + { + "teal": 5650, + "source": "examples/reti/validatorRegistry.algo.ts:1413", + "pc": [ + 6505, + 6506 + ] + }, + { + "teal": 5651, + "source": "examples/reti/validatorRegistry.algo.ts:1413", + "pc": [ + 6507, + 6508 + ] + }, + { + "teal": 5652, + "source": "examples/reti/validatorRegistry.algo.ts:1413", + "pc": [ + 6509 + ] + }, + { + "teal": 5653, + "source": "examples/reti/validatorRegistry.algo.ts:1413", + "pc": [ + 6510, + 6511, + 6512 + ] + }, + { + "teal": 5658, + "source": "examples/reti/validatorRegistry.algo.ts:1415", + "pc": [ + 6513, + 6514 + ] + }, + { + "teal": 5659, + "source": "examples/reti/validatorRegistry.algo.ts:1415", + "pc": [ + 6515, + 6516 + ] + }, + { + "teal": 5663, + "source": "examples/reti/validatorRegistry.algo.ts:1416", + "pc": [ + 6517, + 6518 + ] + }, + { + "teal": 5664, + "source": "examples/reti/validatorRegistry.algo.ts:1416", + "pc": [ + 6519, + 6520, + 6521 + ] + }, + { + "teal": 5667, + "source": "examples/reti/validatorRegistry.algo.ts:1416", + "errorMessage": "provided NFD must be valid", + "pc": [ + 6522 + ] + }, + { + "teal": 5675, + "source": "examples/reti/validatorRegistry.algo.ts:1420", + "pc": [ + 6523, + 6524 + ] + }, + { + "teal": 5676, + "source": "examples/reti/validatorRegistry.algo.ts:1420", + "pc": [ + 6525, + 6526, + 6527, + 6528, + 6529, + 6530, + 6531, + 6532, + 6533, + 6534, + 6535 + ] + }, + { + "teal": 5677, + "source": "examples/reti/validatorRegistry.algo.ts:1420", + "pc": [ + 6536 + ] + }, + { + "teal": 5680, + "source": "examples/reti/validatorRegistry.algo.ts:1420", + "errorMessage": "global state value does not exist: AppID.fromUint64(userOfferedNFDAppID).globalState('i.owner.a')", + "pc": [ + 6537 + ] + }, + { + "teal": 5681, + "source": "examples/reti/validatorRegistry.algo.ts:1420", + "pc": [ + 6538, + 6539 + ] + }, + { + "teal": 5682, + "source": "examples/reti/validatorRegistry.algo.ts:1420", + "pc": [ + 6540 + ] + }, + { + "teal": 5683, + "source": "examples/reti/validatorRegistry.algo.ts:1420", + "pc": [ + 6541 + ] + }, + { + "teal": 5684, + "source": "examples/reti/validatorRegistry.algo.ts:1420", + "pc": [ + 6542, + 6543, + 6544 + ] + }, + { + "teal": 5685, + "source": "examples/reti/validatorRegistry.algo.ts:1421", + "pc": [ + 6545, + 6546 + ] + }, + { + "teal": 5686, + "source": "examples/reti/validatorRegistry.algo.ts:1421", + "pc": [ + 6547, + 6548 + ] + }, + { + "teal": 5687, + "source": "examples/reti/validatorRegistry.algo.ts:1421", + "pc": [ + 6549, + 6550, + 6551 + ] + }, + { + "teal": 5688, + "source": "examples/reti/validatorRegistry.algo.ts:1420", + "pc": [ + 6552 + ] + }, + { + "teal": 5692, + "source": "examples/reti/validatorRegistry.algo.ts:1419", + "errorMessage": "provided nfd for entry isn't owned or linked to the staker", + "pc": [ + 6553 + ] + }, + { + "teal": 5700, + "source": "examples/reti/validatorRegistry.algo.ts:1427", + "pc": [ + 6554, + 6555 + ] + }, + { + "teal": 5701, + "source": "examples/reti/validatorRegistry.algo.ts:1427", + "pc": [ + 6556, + 6557, + 6558, + 6559, + 6560, + 6561, + 6562, + 6563, + 6564, + 6565, + 6566, + 6567, + 6568, + 6569, + 6570 + ] + }, + { + "teal": 5702, + "source": "examples/reti/validatorRegistry.algo.ts:1427", + "pc": [ + 6571 + ] + }, + { + "teal": 5705, + "source": "examples/reti/validatorRegistry.algo.ts:1427", + "errorMessage": "global state value does not exist: AppID.fromUint64(userOfferedNFDAppID).globalState('i.parentAppID')", + "pc": [ + 6572 + ] + }, + { + "teal": 5706, + "source": "examples/reti/validatorRegistry.algo.ts:1427", + "pc": [ + 6573 + ] + }, + { + "teal": 5707, + "source": "examples/reti/validatorRegistry.algo.ts:1428", + "pc": [ + 6574, + 6575 + ] + }, + { + "teal": 5708, + "source": "examples/reti/validatorRegistry.algo.ts:1428", + "pc": [ + 6576, + 6577, + 6578 + ] + }, + { + "teal": 5709, + "source": "examples/reti/validatorRegistry.algo.ts:1428", + "pc": [ + 6579 + ] + }, + { + "teal": 5710, + "source": "examples/reti/validatorRegistry.algo.ts:1427", + "pc": [ + 6580 + ] + }, + { + "teal": 5713, + "source": "examples/reti/validatorRegistry.algo.ts:1426", + "errorMessage": "specified nfd must be a segment of the nfd the validator specified as a requirement", + "pc": [ + 6581 + ] + }, + { + "teal": 5716, + "source": "examples/reti/validatorRegistry.algo.ts:1364", + "pc": [ + 6582 + ] + }, + { + "teal": 5728, + "source": "examples/reti/validatorRegistry.algo.ts:1443", + "pc": [ + 6583, + 6584, + 6585 + ] + }, + { + "teal": 5731, + "source": "examples/reti/validatorRegistry.algo.ts:1443", + "pc": [ + 6586, + 6587 + ] + }, + { + "teal": 5735, + "source": "examples/reti/validatorRegistry.algo.ts:1445", + "pc": [ + 6588, + 6589 + ] + }, + { + "teal": 5736, + "source": "examples/reti/validatorRegistry.algo.ts:1445", + "pc": [ + 6590, + 6591, + 6592, + 6593, + 6594, + 6595, + 6596, + 6597 + ] + }, + { + "teal": 5737, + "source": "examples/reti/validatorRegistry.algo.ts:1445", + "pc": [ + 6598 + ] + }, + { + "teal": 5740, + "source": "examples/reti/validatorRegistry.algo.ts:1445", + "errorMessage": "global state value does not exist: AppID.fromUint64(nfdAppID).globalState('i.name')", + "pc": [ + 6599 + ] + }, + { + "teal": 5741, + "source": "examples/reti/validatorRegistry.algo.ts:1445", + "pc": [ + 6600, + 6601 + ] + }, + { + "teal": 5749, + "source": "examples/reti/validatorRegistry.algo.ts:1447", + "pc": [ + 6602 + ] + }, + { + "teal": 5750, + "source": "examples/reti/validatorRegistry.algo.ts:1447", + "pc": [ + 6603, + 6604 + ] + }, + { + "teal": 5751, + "source": "examples/reti/validatorRegistry.algo.ts:1447", + "pc": [ + 6605, + 6606 + ] + }, + { + "teal": 5755, + "source": "examples/reti/validatorRegistry.algo.ts:1448", + "pc": [ + 6607 + ] + }, + { + "teal": 5756, + "source": "examples/reti/validatorRegistry.algo.ts:1448", + "pc": [ + 6608, + 6609 + ] + }, + { + "teal": 5760, + "source": "examples/reti/validatorRegistry.algo.ts:1449", + "pc": [ + 6610, + 6611, + 6612, + 6613, + 6614, + 6615, + 6616, + 6617, + 6618, + 6619, + 6620, + 6621, + 6622, + 6623, + 6624, + 6625, + 6626, + 6627, + 6628, + 6629 + ] + }, + { + "teal": 5761, + "source": "examples/reti/validatorRegistry.algo.ts:1449", + "pc": [ + 6630, + 6631 + ] + }, + { + "teal": 5762, + "source": "examples/reti/validatorRegistry.algo.ts:1449", + "pc": [ + 6632, + 6633 + ] + }, + { + "teal": 5763, + "source": "examples/reti/validatorRegistry.algo.ts:1449", + "pc": [ + 6634, + 6635 + ] + }, + { + "teal": 5764, + "source": "examples/reti/validatorRegistry.algo.ts:1449", + "pc": [ + 6636, + 6637 + ] + }, + { + "teal": 5765, + "source": "examples/reti/validatorRegistry.algo.ts:1449", + "pc": [ + 6638 + ] + }, + { + "teal": 5766, + "source": "examples/reti/validatorRegistry.algo.ts:1449", + "pc": [ + 6639, + 6640 + ] + }, + { + "teal": 5770, + "source": "examples/reti/validatorRegistry.algo.ts:1450", + "pc": [ + 6641, + 6642 + ] + }, + { + "teal": 5771, + "source": "examples/reti/validatorRegistry.algo.ts:1450", + "pc": [ + 6643, + 6644 + ] + }, + { + "teal": 5774, + "source": "examples/reti/validatorRegistry.algo.ts:1447", + "pc": [ + 6645, + 6646 + ] + }, + { + "teal": 5775, + "source": "examples/reti/validatorRegistry.algo.ts:1447", + "pc": [ + 6647, + 6648 + ] + }, + { + "teal": 5778, + "source": "examples/reti/validatorRegistry.algo.ts:1447", + "pc": [ + 6649 + ] + }, + { + "teal": 5782, + "source": "examples/reti/validatorRegistry.algo.ts:1452", + "pc": [ + 6650, + 6651 + ] + }, + { + "teal": 5783, + "source": "examples/reti/validatorRegistry.algo.ts:1452", + "pc": [ + 6652 + ] + }, + { + "teal": 5784, + "source": "examples/reti/validatorRegistry.algo.ts:1452", + "pc": [ + 6653, + 6654 + ] + }, + { + "teal": 5785, + "source": "examples/reti/validatorRegistry.algo.ts:1452", + "pc": [ + 6655 + ] + }, + { + "teal": 5788, + "source": "examples/reti/validatorRegistry.algo.ts:1443", + "pc": [ + 6656, + 6657 + ] + }, + { + "teal": 5789, + "source": "examples/reti/validatorRegistry.algo.ts:1443", + "pc": [ + 6658 + ] + }, + { + "teal": 5800, + "source": "examples/reti/validatorRegistry.algo.ts:1463", + "pc": [ + 6659, + 6660, + 6661 + ] + }, + { + "teal": 5803, + "source": "examples/reti/validatorRegistry.algo.ts:1463", + "pc": [ + 6662, + 6663 + ] + }, + { + "teal": 5804, + "source": "examples/reti/validatorRegistry.algo.ts:1463", + "pc": [ + 6664, + 6665 + ] + }, + { + "teal": 5811, + "source": "examples/reti/validatorRegistry.algo.ts:1464", + "pc": [ + 6666 + ] + }, + { + "teal": 5812, + "source": "examples/reti/validatorRegistry.algo.ts:1464", + "pc": [ + 6667, + 6668 + ] + }, + { + "teal": 5813, + "source": "examples/reti/validatorRegistry.algo.ts:1464", + "pc": [ + 6669, + 6670 + ] + }, + { + "teal": 5817, + "source": "examples/reti/validatorRegistry.algo.ts:1465", + "pc": [ + 6671, + 6672 + ] + }, + { + "teal": 5818, + "source": "examples/reti/validatorRegistry.algo.ts:1465", + "pc": [ + 6673, + 6674 + ] + }, + { + "teal": 5822, + "source": "examples/reti/validatorRegistry.algo.ts:1466", + "pc": [ + 6675, + 6676, + 6677, + 6678, + 6679, + 6680, + 6681, + 6682, + 6683, + 6684, + 6685, + 6686, + 6687, + 6688, + 6689 + ] + }, + { + "teal": 5823, + "source": "examples/reti/validatorRegistry.algo.ts:1466", + "pc": [ + 6690, + 6691 + ] + }, + { + "teal": 5824, + "source": "examples/reti/validatorRegistry.algo.ts:1466", + "pc": [ + 6692, + 6693, + 6694, + 6695, + 6696, + 6697, + 6698, + 6699, + 6700, + 6701, + 6702, + 6703, + 6704, + 6705, + 6706 + ] + }, + { + "teal": 5825, + "source": "examples/reti/validatorRegistry.algo.ts:1466", + "pc": [ + 6707, + 6708 + ] + }, + { + "teal": 5828, + "source": "examples/reti/validatorRegistry.algo.ts:1464", + "pc": [ + 6709, + 6710 + ] + }, + { + "teal": 5829, + "source": "examples/reti/validatorRegistry.algo.ts:1464", + "pc": [ + 6711, + 6712 + ] + }, + { + "teal": 5832, + "source": "examples/reti/validatorRegistry.algo.ts:1464", + "pc": [ + 6713 + ] + }, + { + "teal": 5836, + "source": "examples/reti/validatorRegistry.algo.ts:1468", + "pc": [ + 6714, + 6715 + ] + }, + { + "teal": 5837, + "source": "examples/reti/validatorRegistry.algo.ts:1468", + "pc": [ + 6716, + 6717 + ] + }, + { + "teal": 5841, + "source": "examples/reti/validatorRegistry.algo.ts:1469", + "pc": [ + 6718, + 6719 + ] + }, + { + "teal": 5842, + "source": "examples/reti/validatorRegistry.algo.ts:1469", + "pc": [ + 6720, + 6721 + ] + }, + { + "teal": 5847, + "source": "examples/reti/validatorRegistry.algo.ts:1469", + "pc": [ + 6722, + 6723 + ] + }, + { + "teal": 5848, + "source": "examples/reti/validatorRegistry.algo.ts:1469", + "pc": [ + 6724, + 6725 + ] + }, + { + "teal": 5849, + "source": "examples/reti/validatorRegistry.algo.ts:1469", + "pc": [ + 6726 + ] + }, + { + "teal": 5850, + "source": "examples/reti/validatorRegistry.algo.ts:1469", + "pc": [ + 6727 + ] + }, + { + "teal": 5851, + "source": "examples/reti/validatorRegistry.algo.ts:1469", + "pc": [ + 6728, + 6729, + 6730 + ] + }, + { + "teal": 5855, + "source": "examples/reti/validatorRegistry.algo.ts:1470", + "pc": [ + 6731, + 6732 + ] + }, + { + "teal": 5856, + "source": "examples/reti/validatorRegistry.algo.ts:1470", + "pc": [ + 6733, + 6734 + ] + }, + { + "teal": 5857, + "source": "examples/reti/validatorRegistry.algo.ts:1470", + "pc": [ + 6735, + 6736 + ] + }, + { + "teal": 5858, + "source": "examples/reti/validatorRegistry.algo.ts:1470", + "pc": [ + 6737 + ] + }, + { + "teal": 5859, + "source": "examples/reti/validatorRegistry.algo.ts:1470", + "pc": [ + 6738, + 6739 + ] + }, + { + "teal": 5864, + "source": "examples/reti/validatorRegistry.algo.ts:1471", + "pc": [ + 6740, + 6741 + ] + }, + { + "teal": 5865, + "source": "examples/reti/validatorRegistry.algo.ts:1471", + "pc": [ + 6742, + 6743 + ] + }, + { + "teal": 5866, + "source": "examples/reti/validatorRegistry.algo.ts:1471", + "pc": [ + 6744 + ] + }, + { + "teal": 5867, + "source": "examples/reti/validatorRegistry.algo.ts:1471", + "pc": [ + 6745 + ] + }, + { + "teal": 5868, + "source": "examples/reti/validatorRegistry.algo.ts:1471", + "pc": [ + 6746, + 6747, + 6748 + ] + }, + { + "teal": 5869, + "source": "examples/reti/validatorRegistry.algo.ts:1471", + "pc": [ + 6749, + 6750 + ] + }, + { + "teal": 5870, + "source": "examples/reti/validatorRegistry.algo.ts:1471", + "pc": [ + 6751, + 6752 + ] + }, + { + "teal": 5871, + "source": "examples/reti/validatorRegistry.algo.ts:1471", + "pc": [ + 6753 + ] + }, + { + "teal": 5872, + "source": "examples/reti/validatorRegistry.algo.ts:1471", + "pc": [ + 6754 + ] + }, + { + "teal": 5875, + "source": "examples/reti/validatorRegistry.algo.ts:1471", + "pc": [ + 6755, + 6756, + 6757 + ] }, { + "teal": 5880, + "source": "examples/reti/validatorRegistry.algo.ts:1472", "pc": [ - 827 - ], - "errorMessage": "pool id must be between 1 and number of pools for this validator" + 6758, + 6759 + ] }, { + "teal": 5881, + "source": "examples/reti/validatorRegistry.algo.ts:1472", "pc": [ - 871 - ], - "errorMessage": "argument 0 (poolKey) for getPoolInfo must be a (uint64,uint64,uint64)" + 6760, + 6761, + 6762 + ] }, { + "teal": 5888, + "source": "examples/reti/validatorRegistry.algo.ts:1469", "pc": [ - 1032 - ], - "errorMessage": "argument 0 (staker) for doesStakerNeedToPayMBR must be a address" + 6763, + 6764 + ] }, { + "teal": 5889, + "source": "examples/reti/validatorRegistry.algo.ts:1469", "pc": [ - 1079 - ], - "errorMessage": "argument 0 (staker) for getStakedPoolsForAccount must be a address" + 6765, + 6766 + ] }, { + "teal": 5890, + "source": "examples/reti/validatorRegistry.algo.ts:1469", "pc": [ - 1139 - ], - "errorMessage": "box value does not exist: this.stakerPoolSet(staker).value" + 6767 + ] }, { + "teal": 5891, + "source": "examples/reti/validatorRegistry.algo.ts:1469", "pc": [ - 1275 - ], - "errorMessage": "the specified validator id doesn't exist" + 6768, + 6769 + ] }, { + "teal": 5892, + "source": "examples/reti/validatorRegistry.algo.ts:1469", "pc": [ - 1328 - ], - "errorMessage": "argument 0 (config) for addValidator must be a (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)" + 6770, + 6771, + 6772 + ] }, { + "teal": 5897, + "source": "examples/reti/validatorRegistry.algo.ts:1475", "pc": [ - 1346 - ], - "errorMessage": "argument 2 (mbrPayment) for addValidator must be a pay transaction" + 6773, + 6774 + ] }, { + "teal": 5901, + "source": "examples/reti/validatorRegistry.algo.ts:1463", "pc": [ - 1392 - ], - "errorMessage": "sender must be owner to add new validator" + 6775, + 6776 + ] }, { + "teal": 5904, + "source": "examples/reti/validatorRegistry.algo.ts:1463", "pc": [ - 1405 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"mbrPayment\",\"field\":\"amount\",\"expected\":\"this.getMbrAmounts().addValidatorMbr\"}" + 6777, + 6778 + ] }, { + "teal": 5905, + "source": "examples/reti/validatorRegistry.algo.ts:1463", "pc": [ - 1416 - ], - "errorMessage": "fee must be 10 ALGO or more to prevent spamming of validators" + 6779 + ] }, { + "teal": 5913, + "source": "examples/reti/validatorRegistry.algo.ts:1483", "pc": [ - 1553 - ], - "errorMessage": "provided NFD isn't valid" + 6780, + 6781, + 6782 + ] }, { + "teal": 5916, + "source": "examples/reti/validatorRegistry.algo.ts:1483", "pc": [ - 1574 - ], - "errorMessage": "global state value does not exist: AppID.fromUint64(config.nfdForInfo).globalState('i.owner.a')" + 6783, + 6784 + ] }, { + "teal": 5920, + "source": "examples/reti/validatorRegistry.algo.ts:1484", "pc": [ - 1576 - ], - "errorMessage": "If specifying NFD, account adding validator must be owner" + 6785, + 6786, + 6787 + ] }, { + "teal": 5921, + "source": "examples/reti/validatorRegistry.algo.ts:1484", "pc": [ - 1612 - ], - "errorMessage": "provided NFD App id for gating must be valid NFD" + 6788, + 6789 + ] }, { + "teal": 5925, + "source": "examples/reti/validatorRegistry.algo.ts:1486", "pc": [ - 1626 - ], - "errorMessage": "argument 0 (manager) for changeValidatorManager must be a address" + 6790, + 6791 + ] }, { + "teal": 5926, + "source": "examples/reti/validatorRegistry.algo.ts:1486", "pc": [ - 1657 - ], - "errorMessage": "can only be called by validator owner" + 6792, + 6793 + ] }, { + "teal": 5927, + "source": "examples/reti/validatorRegistry.algo.ts:1486", "pc": [ - 1711 - ], - "errorMessage": "can only be called by validator owner" + 6794 + ] }, { + "teal": 5928, + "source": "examples/reti/validatorRegistry.algo.ts:1486", "pc": [ - 1785 - ], - "errorMessage": "can only be called by validator owner" + 6795, + 6796 + ] }, { + "teal": 5929, + "source": "examples/reti/validatorRegistry.algo.ts:1486", "pc": [ - 1850 - ], - "errorMessage": "global state value does not exist: AppID.fromUint64(nfdAppID).globalState('i.owner.a')" + 6797, + 6798, + 6799 + ] }, { + "teal": 5930, + "source": "examples/reti/validatorRegistry.algo.ts:1486", "pc": [ - 1852 - ], - "errorMessage": "If specifying NFD, account adding validator must be owner" + 6800 + ] }, { + "teal": 5931, + "source": "examples/reti/validatorRegistry.algo.ts:1486", "pc": [ - 1877 - ], - "errorMessage": "argument 0 (commissionAddress) for changeValidatorCommissionAddress must be a address" + 6801 + ] }, { + "teal": 5932, + "source": "examples/reti/validatorRegistry.algo.ts:1486", "pc": [ - 1908 - ], - "errorMessage": "can only be called by validator owner" + 6802 + ] }, { + "teal": 5933, + "source": "examples/reti/validatorRegistry.algo.ts:1486", "pc": [ - 1947 - ], - "errorMessage": "argument 2 (EntryGatingAssets) for changeValidatorRewardInfo must be a uint64[4]" + 6803 + ] }, { + "teal": 5934, + "source": "examples/reti/validatorRegistry.algo.ts:1486", "pc": [ - 1956 - ], - "errorMessage": "argument 3 (EntryGatingAddress) for changeValidatorRewardInfo must be a address" + 6804 + ] }, { + "teal": 5937, + "source": "examples/reti/validatorRegistry.algo.ts:1486", + "errorMessage": "wideRatio failed", "pc": [ - 1965 - ], - "errorMessage": "argument 4 (EntryGatingType) for changeValidatorRewardInfo must be a uint8" + 6805 + ] }, { + "teal": 5940, + "source": "examples/reti/validatorRegistry.algo.ts:1483", "pc": [ - 1997 - ], - "errorMessage": "can only be called by validator owner" + 6806, + 6807 + ] }, { + "teal": 5941, + "source": "examples/reti/validatorRegistry.algo.ts:1483", "pc": [ - 2102 - ], - "errorMessage": "argument 2 (mbrPayment) for addPool must be a pay transaction" + 6808 + ] }, { + "teal": 5948, + "source": "examples/reti/validatorRegistry.algo.ts:1493", "pc": [ - 2156 - ], - "errorMessage": "can only be called by owner or manager of validator" + 6809, + 6810, + 6811 + ] }, { + "teal": 5951, + "source": "examples/reti/validatorRegistry.algo.ts:1493", "pc": [ - 2169 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"mbrPayment\",\"field\":\"amount\",\"expected\":\"this.getMbrAmounts().addPoolMbr\"}" + 6812, + 6813 + ] }, { + "teal": 5955, + "source": "examples/reti/validatorRegistry.algo.ts:1494", "pc": [ - 2177 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"mbrPayment\",\"field\":\"receiver\",\"expected\":\"this.app.address\"}" + 6814, + 6815, + 6816 + ] }, { + "teal": 5956, + "source": "examples/reti/validatorRegistry.algo.ts:1494", "pc": [ - 2188 - ], - "errorMessage": "specified validator id isn't valid" + 6817, + 6818 + ] }, { + "teal": 5960, + "source": "examples/reti/validatorRegistry.algo.ts:1496", "pc": [ - 2215 - ], - "errorMessage": "already at max pool size" + 6819, + 6820 + ] }, { + "teal": 5961, + "source": "examples/reti/validatorRegistry.algo.ts:1496", "pc": [ - 2325 - ], - "errorMessage": "box value does not exist: this.stakingPoolApprovalProgram.size" + 6821, + 6822, + 6823 + ] }, { + "teal": 5962, + "source": "examples/reti/validatorRegistry.algo.ts:1496", "pc": [ - 2499 - ], - "errorMessage": "argument 2 (stakedAmountPayment) for addStake must be a pay transaction" + 6824 + ] }, { + "teal": 5963, + "source": "examples/reti/validatorRegistry.algo.ts:1496", "pc": [ - 2525 - ], - "errorMessage": "specified validator id isn't valid" + 6825, + 6826 + ] }, { + "teal": 5964, + "source": "examples/reti/validatorRegistry.algo.ts:1496", "pc": [ - 2567 - ], - "errorMessage": "can't stake with a validator that is past its sunsetting time" + 6827, + 6828, + 6829 + ] }, { + "teal": 5965, + "source": "examples/reti/validatorRegistry.algo.ts:1496", "pc": [ - 2579 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"stakedAmountPayment\",\"field\":\"sender\",\"expected\":\"staker\"}" + 6830 + ] }, { + "teal": 5966, + "source": "examples/reti/validatorRegistry.algo.ts:1496", "pc": [ - 2587 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"stakedAmountPayment\",\"field\":\"receiver\",\"expected\":\"this.app.address\"}" + 6831 + ] }, { + "teal": 5967, + "source": "examples/reti/validatorRegistry.algo.ts:1496", "pc": [ - 2608 - ], - "errorMessage": "total staked for all of a validators pools may not exceed hard cap" + 6832 + ] }, { + "teal": 5968, + "source": "examples/reti/validatorRegistry.algo.ts:1496", "pc": [ - 2721 - ], - "errorMessage": "No pool available with free stake. Validator needs to add another pool" + 6833 + ] }, { + "teal": 5969, + "source": "examples/reti/validatorRegistry.algo.ts:1496", "pc": [ - 2894 - ], - "errorMessage": "global state value does not exist: AppID.fromUint64(pool1AppID).globalState('lastPayout')" + 6834 + ] }, { + "teal": 5972, + "source": "examples/reti/validatorRegistry.algo.ts:1496", + "errorMessage": "wideRatio failed", "pc": [ - 3084 - ], - "errorMessage": "wideRatio failed" + 6835 + ] }, { + "teal": 5975, + "source": "examples/reti/validatorRegistry.algo.ts:1493", "pc": [ - 3164 - ], - "errorMessage": "argument 4 (poolKey) for stakeUpdatedViaRewards must be a (uint64,uint64,uint64)" + 6836, + 6837 + ] }, { + "teal": 5976, + "source": "examples/reti/validatorRegistry.algo.ts:1493", "pc": [ - 3370 - ], - "errorMessage": "argument 0 (stakerRemoved) for stakeRemoved must be a bool" + 6838 + ] }, { + "teal": 5982, + "source": "examples/reti/validatorRegistry.algo.ts:1502", "pc": [ - 3390 - ], - "errorMessage": "argument 3 (staker) for stakeRemoved must be a address" + 6839, + 6840, + 6841 + ] }, { + "teal": 5986, + "source": "examples/reti/validatorRegistry.algo.ts:1504", "pc": [ - 3399 - ], - "errorMessage": "argument 4 (poolKey) for stakeRemoved must be a (uint64,uint64,uint64)" + 6842, + 6843, + 6844, + 6845, + 6846, + 6847, + 6848, + 6849 + ] }, { + "teal": 5987, + "source": "examples/reti/validatorRegistry.algo.ts:1502", "pc": [ - 3466 - ], - "errorMessage": "should only be called if algo or reward was removed" + 6850 + ] }, { + "teal": 5991, + "source": "examples/reti/validatorRegistry.algo.ts:1507", "pc": [ - 3636 - ], - "errorMessage": "rewardRemoved can't be set if validator doesn't have reward token!" + 6851, + 6852, + 6853 + ] }, { + "teal": 5995, + "source": "examples/reti/validatorRegistry.algo.ts:1509", "pc": [ - 3660 - ], - "errorMessage": "reward being removed must be covered by hold back amount" + 6854, + 6855, + 6856, + 6857, + 6858, + 6859, + 6860, + 6861, + 6862 + ] }, { + "teal": 5996, + "source": "examples/reti/validatorRegistry.algo.ts:1507", "pc": [ - 4002 - ], - "errorMessage": "argument 1 (staker) for findPoolForStaker must be a address" + 6863 + ] }, { + "teal": 6000, + "source": "examples/reti/validatorRegistry.algo.ts:1512", "pc": [ - 4060 - ], - "errorMessage": "box value does not exist: this.stakerPoolSet(staker).value" + 6864, + 6865, + 6866 + ] }, { + "teal": 6003, + "source": "examples/reti/validatorRegistry.algo.ts:1512", "pc": [ - 4270 - ], - "errorMessage": "must stake at least the minimum for this pool" + 6867, + 6868 + ] }, { + "teal": 6007, + "source": "examples/reti/validatorRegistry.algo.ts:1521", "pc": [ - 4503 - ], - "errorMessage": "can only be called by owner or manager of validator" + 6869, + 6870, + 6871, + 6872 + ] }, { + "teal": 6008, + "source": "examples/reti/validatorRegistry.algo.ts:1521", "pc": [ - 4537 - ], - "errorMessage": "node number out of allowable range" + 6873, + 6874 + ] }, { + "teal": 6012, + "source": "examples/reti/validatorRegistry.algo.ts:1522", "pc": [ - 4599 - ], - "errorMessage": "can't move to same node" + 6875, + 6876 + ] }, { + "teal": 6013, + "source": "examples/reti/validatorRegistry.algo.ts:1522", "pc": [ - 4690 - ], - "errorMessage": "couldn't find pool app id in nodes to move" + 6877, + 6878 + ] }, { + "teal": 6014, + "source": "examples/reti/validatorRegistry.algo.ts:1522", "pc": [ - 4706 - ], - "errorMessage": "argument 0 (receiver) for emptyTokenRewards must be a address" + 6879, + 6880, + 6881, + 6882 + ] }, { + "teal": 6015, + "source": "examples/reti/validatorRegistry.algo.ts:1522", "pc": [ - 4744 - ], - "errorMessage": "can only be called by validator owner" + 6883 + ] }, { + "teal": 6016, + "source": "examples/reti/validatorRegistry.algo.ts:1522", "pc": [ - 4786 - ], - "errorMessage": "this validator doesn't have a reward token defined" + 6884 + ] }, { + "teal": 6017, + "source": "examples/reti/validatorRegistry.algo.ts:1522", "pc": [ - 4869 - ], - "errorMessage": "balance of remaining reward tokens should match the held back amount" + 6885, + 6886 + ] }, { + "teal": 6021, + "source": "examples/reti/validatorRegistry.algo.ts:1523", "pc": [ - 4894 - ], - "errorMessage": "the specified validator id isn't valid" + 6887, + 6888 + ] }, { + "teal": 6022, + "source": "examples/reti/validatorRegistry.algo.ts:1523", "pc": [ - 4904 - ], - "errorMessage": "pool id not in valid range" + 6889, + 6890 + ] }, { + "teal": 6023, + "source": "examples/reti/validatorRegistry.algo.ts:1523", "pc": [ - 4946 - ], - "errorMessage": "pool id outside of range of pools created for this validator" + 6891, + 6892, + 6893, + 6894 + ] }, { + "teal": 6024, + "source": "examples/reti/validatorRegistry.algo.ts:1523", "pc": [ - 4990 - ], - "errorMessage": "The passed in app id doesn't match the passed in ids" + 6895 + ] }, { + "teal": 6025, + "source": "examples/reti/validatorRegistry.algo.ts:1523", "pc": [ - 5030 - ], - "errorMessage": "global state value does not exist: AppID.fromUint64(poolKey.poolAppId).globalState('validatorId')" + 6896 + ] }, { + "teal": 6026, + "source": "examples/reti/validatorRegistry.algo.ts:1523", "pc": [ - 5054 - ], - "errorMessage": "global state value does not exist: AppID.fromUint64(poolKey.poolAppId).globalState('poolId')" + 6897, + 6898 + ] }, { + "teal": 6030, + "source": "examples/reti/validatorRegistry.algo.ts:1524", "pc": [ - 5121 - ], - "errorMessage": "global state value does not exist: AppID.fromUint64(validatorConfig.nfdForInfo).globalState('i.owner.a')" + 6899, + 6900 + ] }, { + "teal": 6031, + "source": "examples/reti/validatorRegistry.algo.ts:1524", "pc": [ - 5215 - ], - "errorMessage": "gating type not valid" + 6901, + 6902 + ] }, { + "teal": 6032, + "source": "examples/reti/validatorRegistry.algo.ts:1524", "pc": [ - 5241 - ], - "errorMessage": "epoch length not in allowable range" + 6903, + 6904, + 6905, + 6906 + ] }, { + "teal": 6033, + "source": "examples/reti/validatorRegistry.algo.ts:1524", "pc": [ - 5267 - ], - "errorMessage": "commission percentage not valid" + 6907 + ] }, { + "teal": 6034, + "source": "examples/reti/validatorRegistry.algo.ts:1524", "pc": [ - 5288 - ], - "errorMessage": "validatorCommissionAddress must be set if percent to validator is not 0" + 6908 + ] }, { + "teal": 6035, + "source": "examples/reti/validatorRegistry.algo.ts:1524", "pc": [ - 5300 - ], - "errorMessage": "staking pool must have minimum entry of 1 algo" + 6909, + 6910 + ] }, { + "teal": 6039, + "source": "examples/reti/validatorRegistry.algo.ts:1525", "pc": [ - 5324 - ], - "errorMessage": "number of pools per node exceeds allowed number" + 6911, + 6912 + ] }, { + "teal": 6040, + "source": "examples/reti/validatorRegistry.algo.ts:1525", "pc": [ - 5346 - ], - "errorMessage": "sunsettingOn must be later than now if set" + 6913, + 6914 + ] }, { + "teal": 6041, + "source": "examples/reti/validatorRegistry.algo.ts:1525", "pc": [ - 5505 - ], - "errorMessage": "global state value does not exist: AppID.fromUint64(poolAppId).globalState('numStakers')" + 6915, + 6916, + 6917, + 6918 + ] }, { + "teal": 6042, + "source": "examples/reti/validatorRegistry.algo.ts:1525", "pc": [ - 5519 - ], - "errorMessage": "global state value does not exist: AppID.fromUint64(poolAppId).globalState('staked')" + 6919 + ] }, { + "teal": 6043, + "source": "examples/reti/validatorRegistry.algo.ts:1525", "pc": [ - 5778 - ], - "errorMessage": "box value does not exist: this.stakerPoolSet(staker).value" + 6920 + ] }, { + "teal": 6044, + "source": "examples/reti/validatorRegistry.algo.ts:1525", "pc": [ - 5869 - ], - "errorMessage": "No empty slot available in the staker pool set" + 6921, + 6922 + ] }, { + "teal": 6048, + "source": "examples/reti/validatorRegistry.algo.ts:1526", "pc": [ - 5920 - ], - "errorMessage": "box value does not exist: this.stakerPoolSet(staker).value" + 6923, + 6924 + ] }, { + "teal": 6049, + "source": "examples/reti/validatorRegistry.algo.ts:1526", "pc": [ - 6077 - ], - "errorMessage": "No matching slot found when told to remove a pool from the stakers set" + 6925, + 6926 + ] }, { + "teal": 6050, + "source": "examples/reti/validatorRegistry.algo.ts:1526", "pc": [ - 6160 - ], - "errorMessage": "node number not in valid range" + 6927, + 6928, + 6929, + 6930 + ] }, { + "teal": 6051, + "source": "examples/reti/validatorRegistry.algo.ts:1526", "pc": [ - 6250 - ], - "errorMessage": "no available space in specified node for this pool" + 6931 + ] }, { + "teal": 6052, + "source": "examples/reti/validatorRegistry.algo.ts:1526", "pc": [ - 6380 - ], - "errorMessage": "must have required minimum balance of validator defined token to add stake" + 6932 + ] }, { + "teal": 6053, + "source": "examples/reti/validatorRegistry.algo.ts:1526", "pc": [ - 6400 - ], - "errorMessage": "specified asset must be created by creator that the validator defined as a requirement to stake" + 6933, + 6934 + ] }, { + "teal": 6057, + "source": "examples/reti/validatorRegistry.algo.ts:1527", "pc": [ - 6481 - ], - "errorMessage": "specified asset must be identical to the asset id defined as a requirement to stake" + 6935, + 6936 + ] }, { + "teal": 6058, + "source": "examples/reti/validatorRegistry.algo.ts:1527", "pc": [ - 6504 - ], - "errorMessage": "specified asset must be created by creator that is one of the linked addresses in an nfd" + 6937, + 6938 + ] }, { + "teal": 6059, + "source": "examples/reti/validatorRegistry.algo.ts:1527", "pc": [ - 6522 - ], - "errorMessage": "provided NFD must be valid" + 6939, + 6940, + 6941, + 6942 + ] }, { + "teal": 6060, + "source": "examples/reti/validatorRegistry.algo.ts:1527", "pc": [ - 6537 - ], - "errorMessage": "global state value does not exist: AppID.fromUint64(userOfferedNFDAppID).globalState('i.owner.a')" + 6943 + ] }, { + "teal": 6061, + "source": "examples/reti/validatorRegistry.algo.ts:1527", "pc": [ - 6553 - ], - "errorMessage": "provided nfd for entry isn't owned or linked to the staker" + 6944 + ] }, { + "teal": 6062, + "source": "examples/reti/validatorRegistry.algo.ts:1527", "pc": [ - 6572 - ], - "errorMessage": "global state value does not exist: AppID.fromUint64(userOfferedNFDAppID).globalState('i.parentAppID')" + 6945, + 6946 + ] }, { + "teal": 6066, + "source": "examples/reti/validatorRegistry.algo.ts:1528", "pc": [ - 6581 - ], - "errorMessage": "specified nfd must be a segment of the nfd the validator specified as a requirement" + 6947, + 6948 + ] }, { + "teal": 6067, + "source": "examples/reti/validatorRegistry.algo.ts:1528", "pc": [ - 6599 - ], - "errorMessage": "global state value does not exist: AppID.fromUint64(nfdAppID).globalState('i.name')" + 6949, + 6950 + ] }, { + "teal": 6068, + "source": "examples/reti/validatorRegistry.algo.ts:1528", "pc": [ - 6805 - ], - "errorMessage": "wideRatio failed" + 6951, + 6952, + 6953, + 6954 + ] }, { + "teal": 6069, + "source": "examples/reti/validatorRegistry.algo.ts:1528", "pc": [ - 6835 - ], - "errorMessage": "wideRatio failed" + 6955 + ] + }, + { + "teal": 6070, + "source": "examples/reti/validatorRegistry.algo.ts:1528", + "pc": [ + 6956 + ] + }, + { + "teal": 6071, + "source": "examples/reti/validatorRegistry.algo.ts:1528", + "pc": [ + 6957, + 6958 + ] + }, + { + "teal": 6075, + "source": "examples/reti/validatorRegistry.algo.ts:1529", + "pc": [ + 6959, + 6960 + ] + }, + { + "teal": 6078, + "source": "examples/reti/validatorRegistry.algo.ts:1512", + "pc": [ + 6961, + 6962 + ] + }, + { + "teal": 6079, + "source": "examples/reti/validatorRegistry.algo.ts:1512", + "pc": [ + 6963 + ] + }, + { + "teal": 6083, + "source": "examples/reti/validatorRegistry.algo.ts:1532", + "pc": [ + 6964, + 6965, + 6966 + ] + }, + { + "teal": 6087, + "source": "examples/reti/validatorRegistry.algo.ts:1536", + "pc": [ + 6967, + 6968, + 6969 + ] + }, + { + "teal": 6088, + "source": "examples/reti/validatorRegistry.algo.ts:1536", + "pc": [ + 6970, + 6971 + ] + }, + { + "teal": 6089, + "source": "examples/reti/validatorRegistry.algo.ts:1536", + "pc": [ + 6972, + 6973, + 6974 + ] + }, + { + "teal": 6090, + "source": "examples/reti/validatorRegistry.algo.ts:1536", + "pc": [ + 6975 + ] + }, + { + "teal": 6091, + "source": "examples/reti/validatorRegistry.algo.ts:1536", + "pc": [ + 6976 + ] + }, + { + "teal": 6092, + "source": "examples/reti/validatorRegistry.algo.ts:1532", + "pc": [ + 6977 + ] + }, + { + "teal": 6095, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "pc": [ + 6978, + 6979, + 6980, + 6981, + 6982, + 6983 + ] }, { + "teal": 6096, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "pc": [ + 6984, + 6985, + 6986 + ] + }, + { + "teal": 6097, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "pc": [ + 6987, + 6988, + 6989, + 6990 + ] + }, + { + "teal": 6100, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 6991 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 6103, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "pc": [ + 6992, + 6993, + 6994, + 6995, + 6996, + 6997 + ] + }, + { + "teal": 6104, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "pc": [ + 6998, + 6999, + 7000, + 7001, + 7002, + 7003 + ] + }, + { + "teal": 6105, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "pc": [ + 7004, + 7005, + 7006, + 7007, + 7008, + 7009 + ] + }, + { + "teal": 6106, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "pc": [ + 7010, + 7011, + 7012, + 7013, + 7014, + 7015 + ] + }, + { + "teal": 6107, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "pc": [ + 7016, + 7017, + 7018, + 7019, + 7020, + 7021 + ] + }, + { + "teal": 6108, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "pc": [ + 7022, + 7023, + 7024, + 7025, + 7026, + 7027 + ] + }, + { + "teal": 6109, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "pc": [ + 7028, + 7029, + 7030, + 7031, + 7032, + 7033 + ] + }, + { + "teal": 6110, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "pc": [ + 7034, + 7035, + 7036, + 7037, + 7038, + 7039 + ] + }, + { + "teal": 6111, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "pc": [ + 7040, + 7041, + 7042, + 7043, + 7044, + 7045 + ] + }, + { + "teal": 6112, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "pc": [ + 7046, + 7047, + 7048, + 7049, + 7050, + 7051 + ] + }, + { + "teal": 6113, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "pc": [ + 7052, + 7053, + 7054, + 7055, + 7056, + 7057 + ] + }, + { + "teal": 6114, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "pc": [ + 7058, + 7059, + 7060, + 7061, + 7062, + 7063 + ] + }, + { + "teal": 6115, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "pc": [ + 7064, + 7065, + 7066, + 7067, + 7068, + 7069 + ] + }, + { + "teal": 6116, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "pc": [ + 7070, + 7071, + 7072, + 7073, + 7074, + 7075 + ] + }, + { + "teal": 6117, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "pc": [ + 7076, + 7077, + 7078, + 7079, + 7080, + 7081 + ] + }, + { + "teal": 6118, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "pc": [ + 7082, + 7083, + 7084, + 7085, + 7086, + 7087 + ] + }, + { + "teal": 6119, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "pc": [ + 7088, + 7089, + 7090, + 7091, + 7092, + 7093 + ] + }, + { + "teal": 6120, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "pc": [ + 7094, + 7095, + 7096, + 7097, + 7098, + 7099 + ] + }, + { + "teal": 6121, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "pc": [ + 7100, + 7101, + 7102, + 7103, + 7104, + 7105 + ] + }, + { + "teal": 6122, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "pc": [ + 7106, + 7107, + 7108, + 7109, + 7110, + 7111 + ] + }, + { + "teal": 6123, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "pc": [ + 7112, + 7113, + 7114, + 7115, + 7116, + 7117 + ] + }, + { + "teal": 6124, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "pc": [ + 7118, + 7119, + 7120, + 7121, + 7122, + 7123 + ] + }, + { + "teal": 6125, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "pc": [ + 7124, + 7125, + 7126, + 7127, + 7128, + 7129 + ] + }, + { + "teal": 6126, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "pc": [ + 7130, + 7131, + 7132, + 7133, + 7134, + 7135 + ] + }, + { + "teal": 6127, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "pc": [ + 7136, + 7137, + 7138, + 7139, + 7140, + 7141 + ] + }, + { + "teal": 6128, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "pc": [ + 7142, + 7143, + 7144, + 7145, + 7146, + 7147 + ] + }, + { + "teal": 6129, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "pc": [ + 7148, + 7149, + 7150, + 7151, + 7152, + 7153 + ] + }, + { + "teal": 6130, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "pc": [ + 7154, + 7155, + 7156, + 7157, + 7158, + 7159 + ] + }, + { + "teal": 6131, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "pc": [ + 7160, + 7161, + 7162, + 7163, + 7164, + 7165 + ] + }, + { + "teal": 6132, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "pc": [ + 7166, + 7167, + 7168, + 7169, + 7170, + 7171 + ] + }, + { + "teal": 6133, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "pc": [ + 7172, + 7173, + 7174, + 7175, + 7176, + 7177 + ] + }, + { + "teal": 6134, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "pc": [ + 7178, + 7179, + 7180, + 7181, + 7182, + 7183 + ] + }, + { + "teal": 6135, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "pc": [ + 7184, + 7185, + 7186, + 7187, + 7188, + 7189 + ] + }, + { + "teal": 6136, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "pc": [ + 7190, + 7191, + 7192 + ] }, { + "teal": 6137, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "pc": [ + 7193, + 7194, + 7195, + 7196, + 7197, + 7198, + 7199, + 7200, + 7201, + 7202, + 7203, + 7204, + 7205, + 7206, + 7207, + 7208, + 7209, + 7210, + 7211, + 7212, + 7213, + 7214, + 7215, + 7216, + 7217, + 7218, + 7219, + 7220, + 7221, + 7222, + 7223, + 7224, + 7225, + 7226, + 7227, + 7228, + 7229, + 7230, + 7231, + 7232, + 7233, + 7234, + 7235, + 7236, + 7237, + 7238, + 7239, + 7240, + 7241, + 7242, + 7243, + 7244, + 7245, + 7246, + 7247, + 7248, + 7249, + 7250, + 7251, + 7252, + 7253, + 7254, + 7255, + 7256, + 7257, + 7258, + 7259, + 7260 + ] + }, + { + "teal": 6140, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 7261 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] + }, + { + "teal": 6143, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "pc": [ + 7262, + 7263, + 7264, + 7265, + 7266, + 7267 + ] + }, + { + "teal": 6144, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "pc": [ + 7268, + 7269, + 7270 + ] + }, + { + "teal": 6145, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "pc": [ + 7271, + 7272, + 7273, + 7274 + ] }, { + "teal": 6148, + "source": "examples/reti/validatorRegistry.algo.ts:168", + "errorMessage": "this contract does not implement the given ABI method for call UpdateApplication", "pc": [ 7275 - ], - "errorMessage": "this contract does not implement the given ABI method for call UpdateApplication" + ] } ], "pcOffsetMethod": "cblocks" diff --git a/examples/simple/artifacts/Simple.arc56_draft.json b/examples/simple/artifacts/Simple.arc56_draft.json index 1f8379614..c6b9ab38e 100644 --- a/examples/simple/artifacts/Simple.arc56_draft.json +++ b/examples/simple/artifacts/Simple.arc56_draft.json @@ -137,58 +137,1164 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "examples/simple/simple.algo.ts:3", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "examples/simple/simple.algo.ts:3", + "pc": [ + 1, + 2, + 3, + 4, + 5, + 6, + 7, + 8, + 9, + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38, + 39, + 40, + 41, + 42, + 43, + 44, + 45, + 46, + 47, + 48 + ] + }, + { + "teal": 14, + "source": "examples/simple/simple.algo.ts:3", + "pc": [ + 49, + 50 + ] + }, + { + "teal": 15, + "source": "examples/simple/simple.algo.ts:3", + "pc": [ + 51 + ] + }, + { + "teal": 16, + "source": "examples/simple/simple.algo.ts:3", + "pc": [ + 52, + 53 + ] + }, + { + "teal": 17, + "source": "examples/simple/simple.algo.ts:3", + "pc": [ + 54 + ] + }, + { + "teal": 18, + "source": "examples/simple/simple.algo.ts:3", + "pc": [ + 55, + 56 + ] + }, + { + "teal": 19, + "source": "examples/simple/simple.algo.ts:3", + "pc": [ + 57 + ] + }, + { + "teal": 20, + "source": "examples/simple/simple.algo.ts:3", + "pc": [ + 58, + 59, + 60, + 61, + 62, + 63, + 64, + 65, + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82, + 83 + ] + }, + { + "teal": 24, + "source": "examples/simple/simple.algo.ts:3", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 84 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "examples/simple/simple.algo.ts:6", + "pc": [ + 85, + 86, + 87 + ] + }, + { + "teal": 32, + "source": "examples/simple/simple.algo.ts:7", + "pc": [ + 88, + 89, + 90, + 91, + 92, + 93, + 94, + 95, + 96 + ] + }, + { + "teal": 33, + "source": "examples/simple/simple.algo.ts:7", + "pc": [ + 97 + ] + }, + { + "teal": 34, + "source": "examples/simple/simple.algo.ts:7", + "pc": [ + 98 + ] + }, + { + "teal": 35, + "source": "examples/simple/simple.algo.ts:7", + "pc": [ + 99, + 100 + ] + }, + { + "teal": 36, + "source": "examples/simple/simple.algo.ts:7", + "pc": [ + 101 + ] }, { + "teal": 37, + "source": "examples/simple/simple.algo.ts:7", + "pc": [ + 102 + ] + }, + { + "teal": 38, + "source": "examples/simple/simple.algo.ts:6", + "pc": [ + 103 + ] + }, + { + "teal": 43, + "source": "examples/simple/simple.algo.ts:10", + "pc": [ + 104, + 105, + 106 + ] + }, + { + "teal": 44, + "source": "examples/simple/simple.algo.ts:10", + "pc": [ + 107 + ] + }, + { + "teal": 47, + "source": "examples/simple/simple.algo.ts:10", + "pc": [ + 108, + 109, + 110 + ] + }, + { + "teal": 48, + "source": "examples/simple/simple.algo.ts:10", + "pc": [ + 111, + 112 + ] + }, + { + "teal": 49, + "source": "examples/simple/simple.algo.ts:10", + "pc": [ + 113 + ] + }, + { + "teal": 53, + "source": "examples/simple/simple.algo.ts:10", + "pc": [ + 114, + 115, + 116 + ] + }, + { + "teal": 57, + "source": "examples/simple/simple.algo.ts:11", + "pc": [ + 117, + 118 + ] + }, + { + "teal": 58, + "source": "examples/simple/simple.algo.ts:11", + "pc": [ + 119, + 120, + 121 + ] + }, + { + "teal": 59, + "source": "examples/simple/simple.algo.ts:10", + "pc": [ + 122 + ] + }, + { + "teal": 64, + "source": "examples/simple/simple.algo.ts:14", + "pc": [ + 123, + 124, + 125 + ] + }, + { + "teal": 65, + "source": "examples/simple/simple.algo.ts:14", + "pc": [ + 126 + ] + }, + { + "teal": 68, + "source": "examples/simple/simple.algo.ts:14", + "pc": [ + 127, + 128, + 129 + ] + }, + { + "teal": 69, + "source": "examples/simple/simple.algo.ts:14", + "pc": [ + 130, + 131 + ] + }, + { + "teal": 70, + "source": "examples/simple/simple.algo.ts:14", + "pc": [ + 132 + ] + }, + { + "teal": 74, + "source": "examples/simple/simple.algo.ts:14", + "pc": [ + 133, + 134, + 135 + ] + }, + { + "teal": 78, + "source": "examples/simple/simple.algo.ts:15", + "pc": [ + 136, + 137, + 138, + 139, + 140, + 141, + 142, + 143, + 144 + ] + }, + { + "teal": 79, + "source": "examples/simple/simple.algo.ts:15", + "pc": [ + 145 + ] + }, + { + "teal": 80, + "source": "examples/simple/simple.algo.ts:15", + "pc": [ + 146 + ] + }, + { + "teal": 81, + "source": "examples/simple/simple.algo.ts:15", + "pc": [ + 147, + 148 + ] + }, + { + "teal": 82, + "source": "examples/simple/simple.algo.ts:15", + "pc": [ + 149 + ] + }, + { + "teal": 83, + "source": "examples/simple/simple.algo.ts:15", + "pc": [ + 150 + ] + }, + { + "teal": 84, + "source": "examples/simple/simple.algo.ts:14", + "pc": [ + 151 + ] + }, + { + "teal": 89, + "source": "examples/simple/simple.algo.ts:18", + "pc": [ + 152, + 153, + 154, + 155, + 156, + 157 + ] + }, + { + "teal": 92, + "source": "examples/simple/simple.algo.ts:18", + "pc": [ + 158, + 159, + 160 + ] + }, + { + "teal": 93, + "source": "examples/simple/simple.algo.ts:18", + "pc": [ + 161 + ] + }, + { + "teal": 94, + "source": "examples/simple/simple.algo.ts:18", + "pc": [ + 162 + ] + }, + { + "teal": 95, + "source": "examples/simple/simple.algo.ts:18", + "pc": [ + 163, + 164 + ] + }, + { + "teal": 96, + "source": "examples/simple/simple.algo.ts:18", + "pc": [ + 165 + ] + }, + { + "teal": 99, + "source": "examples/simple/simple.algo.ts:18", + "errorMessage": "argument 0 (b) for add must be a uint256", "pc": [ 166 - ], - "errorMessage": "argument 0 (b) for add must be a uint256" + ] + }, + { + "teal": 102, + "source": "examples/simple/simple.algo.ts:18", + "pc": [ + 167, + 168, + 169 + ] + }, + { + "teal": 103, + "source": "examples/simple/simple.algo.ts:18", + "pc": [ + 170 + ] + }, + { + "teal": 104, + "source": "examples/simple/simple.algo.ts:18", + "pc": [ + 171 + ] }, { + "teal": 105, + "source": "examples/simple/simple.algo.ts:18", + "pc": [ + 172, + 173 + ] + }, + { + "teal": 106, + "source": "examples/simple/simple.algo.ts:18", + "pc": [ + 174 + ] + }, + { + "teal": 109, + "source": "examples/simple/simple.algo.ts:18", + "errorMessage": "argument 1 (a) for add must be a uint256", "pc": [ 175 - ], - "errorMessage": "argument 1 (a) for add must be a uint256" + ] + }, + { + "teal": 112, + "source": "examples/simple/simple.algo.ts:18", + "pc": [ + 176, + 177, + 178 + ] + }, + { + "teal": 113, + "source": "examples/simple/simple.algo.ts:18", + "pc": [ + 179 + ] + }, + { + "teal": 114, + "source": "examples/simple/simple.algo.ts:18", + "pc": [ + 180 + ] }, { + "teal": 115, + "source": "examples/simple/simple.algo.ts:18", + "pc": [ + 181, + 182, + 183 + ] + }, + { + "teal": 116, + "source": "examples/simple/simple.algo.ts:18", + "pc": [ + 184 + ] + }, + { + "teal": 119, + "source": "examples/simple/simple.algo.ts:18", + "errorMessage": "add return value overflowed 256 bits", "pc": [ 185 - ], - "errorMessage": "add return value overflowed 256 bits" + ] + }, + { + "teal": 120, + "source": "examples/simple/simple.algo.ts:18", + "pc": [ + 186, + 187, + 188, + 189, + 190, + 191, + 192, + 193, + 194, + 195, + 196, + 197, + 198, + 199, + 200, + 201, + 202, + 203, + 204, + 205, + 206, + 207, + 208, + 209, + 210, + 211, + 212, + 213, + 214, + 215, + 216, + 217, + 218, + 219 + ] + }, + { + "teal": 121, + "source": "examples/simple/simple.algo.ts:18", + "pc": [ + 220 + ] + }, + { + "teal": 122, + "source": "examples/simple/simple.algo.ts:18", + "pc": [ + 221 + ] + }, + { + "teal": 123, + "source": "examples/simple/simple.algo.ts:18", + "pc": [ + 222 + ] }, { + "teal": 124, + "source": "examples/simple/simple.algo.ts:18", + "pc": [ + 223 + ] + }, + { + "teal": 125, + "source": "examples/simple/simple.algo.ts:18", + "pc": [ + 224, + 225 + ] + }, + { + "teal": 126, + "source": "examples/simple/simple.algo.ts:18", + "pc": [ + 226 + ] + }, + { + "teal": 127, + "source": "examples/simple/simple.algo.ts:18", + "pc": [ + 227 + ] + }, + { + "teal": 128, + "source": "examples/simple/simple.algo.ts:18", + "pc": [ + 228 + ] + }, + { + "teal": 129, + "source": "examples/simple/simple.algo.ts:18", + "pc": [ + 229 + ] + }, + { + "teal": 130, + "source": "examples/simple/simple.algo.ts:18", + "pc": [ + 230 + ] + }, + { + "teal": 131, + "source": "examples/simple/simple.algo.ts:18", + "pc": [ + 231, + 232 + ] + }, + { + "teal": 132, + "source": "examples/simple/simple.algo.ts:18", + "pc": [ + 233 + ] + }, + { + "teal": 136, + "source": "examples/simple/simple.algo.ts:18", + "pc": [ + 234, + 235, + 236 + ] + }, + { + "teal": 140, + "source": "examples/simple/simple.algo.ts:19", + "pc": [ + 237, + 238 + ] + }, + { + "teal": 141, + "source": "examples/simple/simple.algo.ts:19", + "pc": [ + 239, + 240 + ] + }, + { + "teal": 142, + "source": "examples/simple/simple.algo.ts:19", + "pc": [ + 241 + ] + }, + { + "teal": 143, + "source": "examples/simple/simple.algo.ts:18", + "pc": [ + 242 + ] + }, + { + "teal": 148, + "source": "examples/simple/simple.algo.ts:22", + "pc": [ + 243, + 244, + 245, + 246, + 247, + 248 + ] + }, + { + "teal": 151, + "source": "examples/simple/simple.algo.ts:22", + "pc": [ + 249, + 250, + 251 + ] + }, + { + "teal": 152, + "source": "examples/simple/simple.algo.ts:22", + "pc": [ + 252 + ] + }, + { + "teal": 153, + "source": "examples/simple/simple.algo.ts:22", + "pc": [ + 253 + ] + }, + { + "teal": 154, + "source": "examples/simple/simple.algo.ts:22", + "pc": [ + 254, + 255 + ] + }, + { + "teal": 155, + "source": "examples/simple/simple.algo.ts:22", + "pc": [ + 256 + ] + }, + { + "teal": 158, + "source": "examples/simple/simple.algo.ts:22", + "errorMessage": "argument 0 (b) for sub must be a uint256", "pc": [ 257 - ], - "errorMessage": "argument 0 (b) for sub must be a uint256" + ] + }, + { + "teal": 161, + "source": "examples/simple/simple.algo.ts:22", + "pc": [ + 258, + 259, + 260 + ] + }, + { + "teal": 162, + "source": "examples/simple/simple.algo.ts:22", + "pc": [ + 261 + ] + }, + { + "teal": 163, + "source": "examples/simple/simple.algo.ts:22", + "pc": [ + 262 + ] + }, + { + "teal": 164, + "source": "examples/simple/simple.algo.ts:22", + "pc": [ + 263, + 264 + ] }, { + "teal": 165, + "source": "examples/simple/simple.algo.ts:22", + "pc": [ + 265 + ] + }, + { + "teal": 168, + "source": "examples/simple/simple.algo.ts:22", + "errorMessage": "argument 1 (a) for sub must be a uint256", "pc": [ 266 - ], - "errorMessage": "argument 1 (a) for sub must be a uint256" + ] + }, + { + "teal": 171, + "source": "examples/simple/simple.algo.ts:22", + "pc": [ + 267, + 268, + 269 + ] }, { + "teal": 172, + "source": "examples/simple/simple.algo.ts:22", + "pc": [ + 270 + ] + }, + { + "teal": 173, + "source": "examples/simple/simple.algo.ts:22", + "pc": [ + 271 + ] + }, + { + "teal": 174, + "source": "examples/simple/simple.algo.ts:22", + "pc": [ + 272, + 273, + 274 + ] + }, + { + "teal": 175, + "source": "examples/simple/simple.algo.ts:22", + "pc": [ + 275 + ] + }, + { + "teal": 178, + "source": "examples/simple/simple.algo.ts:22", + "errorMessage": "sub return value overflowed 256 bits", "pc": [ 276 - ], - "errorMessage": "sub return value overflowed 256 bits" + ] + }, + { + "teal": 179, + "source": "examples/simple/simple.algo.ts:22", + "pc": [ + 277, + 278, + 279, + 280, + 281, + 282, + 283, + 284, + 285, + 286, + 287, + 288, + 289, + 290, + 291, + 292, + 293, + 294, + 295, + 296, + 297, + 298, + 299, + 300, + 301, + 302, + 303, + 304, + 305, + 306, + 307, + 308, + 309, + 310 + ] + }, + { + "teal": 180, + "source": "examples/simple/simple.algo.ts:22", + "pc": [ + 311 + ] + }, + { + "teal": 181, + "source": "examples/simple/simple.algo.ts:22", + "pc": [ + 312 + ] + }, + { + "teal": 182, + "source": "examples/simple/simple.algo.ts:22", + "pc": [ + 313 + ] + }, + { + "teal": 183, + "source": "examples/simple/simple.algo.ts:22", + "pc": [ + 314 + ] + }, + { + "teal": 184, + "source": "examples/simple/simple.algo.ts:22", + "pc": [ + 315, + 316 + ] + }, + { + "teal": 185, + "source": "examples/simple/simple.algo.ts:22", + "pc": [ + 317 + ] + }, + { + "teal": 186, + "source": "examples/simple/simple.algo.ts:22", + "pc": [ + 318 + ] + }, + { + "teal": 187, + "source": "examples/simple/simple.algo.ts:22", + "pc": [ + 319 + ] + }, + { + "teal": 188, + "source": "examples/simple/simple.algo.ts:22", + "pc": [ + 320 + ] + }, + { + "teal": 189, + "source": "examples/simple/simple.algo.ts:22", + "pc": [ + 321 + ] + }, + { + "teal": 190, + "source": "examples/simple/simple.algo.ts:22", + "pc": [ + 322, + 323 + ] + }, + { + "teal": 191, + "source": "examples/simple/simple.algo.ts:22", + "pc": [ + 324 + ] + }, + { + "teal": 195, + "source": "examples/simple/simple.algo.ts:22", + "pc": [ + 325, + 326, + 327 + ] + }, + { + "teal": 199, + "source": "examples/simple/simple.algo.ts:23", + "pc": [ + 328, + 329 + ] + }, + { + "teal": 200, + "source": "examples/simple/simple.algo.ts:23", + "pc": [ + 330, + 331 + ] + }, + { + "teal": 201, + "source": "examples/simple/simple.algo.ts:23", + "pc": [ + 332 + ] + }, + { + "teal": 202, + "source": "examples/simple/simple.algo.ts:22", + "pc": [ + 333 + ] + }, + { + "teal": 205, + "source": "examples/simple/simple.algo.ts:3", + "pc": [ + 334, + 335 + ] + }, + { + "teal": 206, + "source": "examples/simple/simple.algo.ts:3", + "pc": [ + 336 + ] + }, + { + "teal": 209, + "source": "examples/simple/simple.algo.ts:3", + "pc": [ + 337, + 338, + 339, + 340, + 341, + 342 + ] + }, + { + "teal": 210, + "source": "examples/simple/simple.algo.ts:3", + "pc": [ + 343, + 344, + 345 + ] + }, + { + "teal": 211, + "source": "examples/simple/simple.algo.ts:3", + "pc": [ + 346, + 347, + 348, + 349 + ] }, { + "teal": 214, + "source": "examples/simple/simple.algo.ts:3", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 350 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 217, + "source": "examples/simple/simple.algo.ts:3", + "pc": [ + 351, + 352, + 353, + 354, + 355, + 356 + ] + }, + { + "teal": 218, + "source": "examples/simple/simple.algo.ts:3", + "pc": [ + 357, + 358, + 359, + 360, + 361, + 362 + ] + }, + { + "teal": 219, + "source": "examples/simple/simple.algo.ts:3", + "pc": [ + 363, + 364, + 365, + 366, + 367, + 368 + ] + }, + { + "teal": 220, + "source": "examples/simple/simple.algo.ts:3", + "pc": [ + 369, + 370, + 371, + 372, + 373, + 374 + ] + }, + { + "teal": 221, + "source": "examples/simple/simple.algo.ts:3", + "pc": [ + 375, + 376, + 377 + ] + }, + { + "teal": 222, + "source": "examples/simple/simple.algo.ts:3", + "pc": [ + 378, + 379, + 380, + 381, + 382, + 383, + 384, + 385, + 386, + 387 + ] }, { + "teal": 225, + "source": "examples/simple/simple.algo.ts:3", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 388 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/examples/tuple_in_box/tealscript_artifacts/ContactsApp.arc56_draft.json b/examples/tuple_in_box/tealscript_artifacts/ContactsApp.arc56_draft.json index f0946c296..2a74bdf79 100644 --- a/examples/tuple_in_box/tealscript_artifacts/ContactsApp.arc56_draft.json +++ b/examples/tuple_in_box/tealscript_artifacts/ContactsApp.arc56_draft.json @@ -169,64 +169,2732 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 1, + 2, + 3 + ] + }, + { + "teal": 3, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 4, + 5, + 6, + 7, + 8, + 9 + ] + }, + { + "teal": 15, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 10, + 11 + ] + }, + { + "teal": 16, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 12 + ] + }, + { + "teal": 17, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 13, + 14 + ] + }, + { + "teal": 18, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 15 + ] + }, + { + "teal": 19, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 16, + 17 + ] + }, + { + "teal": 20, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 18 + ] + }, + { + "teal": 21, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38, + 39, + 40, + 41, + 42, + 43, + 44 + ] + }, + { + "teal": 25, + "source": "examples/tuple_in_box/app.algo.ts:6", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 45 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 30, + "source": "examples/tuple_in_box/app.algo.ts:11", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 31, + "source": "examples/tuple_in_box/app.algo.ts:11", + "pc": [ + 49, + 50, + 51 + ] + }, + { + "teal": 34, + "source": "examples/tuple_in_box/app.algo.ts:11", + "pc": [ + 52, + 53, + 54 + ] + }, + { + "teal": 35, + "source": "examples/tuple_in_box/app.algo.ts:11", + "pc": [ + 55, + 56, + 57 + ] + }, + { + "teal": 38, + "source": "examples/tuple_in_box/app.algo.ts:11", + "pc": [ + 58, + 59, + 60 + ] + }, + { + "teal": 39, + "source": "examples/tuple_in_box/app.algo.ts:11", + "pc": [ + 61, + 62 + ] + }, + { + "teal": 40, + "source": "examples/tuple_in_box/app.algo.ts:11", + "pc": [ + 63 + ] + }, + { + "teal": 44, + "source": "examples/tuple_in_box/app.algo.ts:11", + "pc": [ + 64, + 65, + 66 + ] + }, + { + "teal": 47, + "source": "examples/tuple_in_box/app.algo.ts:11", + "pc": [ + 67, + 68 + ] + }, + { + "teal": 51, + "source": "examples/tuple_in_box/app.algo.ts:12", + "pc": [ + 69, + 70 + ] + }, + { + "teal": 52, + "source": "examples/tuple_in_box/app.algo.ts:12", + "pc": [ + 71, + 72 + ] + }, + { + "teal": 53, + "source": "examples/tuple_in_box/app.algo.ts:12", + "pc": [ + 73, + 74, + 75, + 76 + ] + }, + { + "teal": 54, + "source": "examples/tuple_in_box/app.algo.ts:12", + "pc": [ + 77, + 78 + ] + }, + { + "teal": 55, + "source": "examples/tuple_in_box/app.algo.ts:12", + "pc": [ + 79 + ] + }, + { + "teal": 56, + "source": "examples/tuple_in_box/app.algo.ts:12", + "pc": [ + 80 + ] + }, + { + "teal": 57, + "source": "examples/tuple_in_box/app.algo.ts:12", + "pc": [ + 81 + ] + }, + { + "teal": 58, + "source": "examples/tuple_in_box/app.algo.ts:12", + "pc": [ + 82, + 83, + 84 + ] + }, + { + "teal": 59, + "source": "examples/tuple_in_box/app.algo.ts:12", + "pc": [ + 85 + ] + }, + { + "teal": 60, + "source": "examples/tuple_in_box/app.algo.ts:12", + "pc": [ + 86 + ] + }, + { + "teal": 61, + "source": "examples/tuple_in_box/app.algo.ts:12", + "pc": [ + 87, + 88, + 89 + ] + }, + { + "teal": 62, + "source": "examples/tuple_in_box/app.algo.ts:12", + "pc": [ + 90, + 91 + ] + }, + { + "teal": 63, + "source": "examples/tuple_in_box/app.algo.ts:12", + "pc": [ + 92 + ] + }, + { + "teal": 64, + "source": "examples/tuple_in_box/app.algo.ts:12", + "pc": [ + 93 + ] + }, + { + "teal": 65, + "source": "examples/tuple_in_box/app.algo.ts:12", + "pc": [ + 94 + ] + }, + { + "teal": 66, + "source": "examples/tuple_in_box/app.algo.ts:12", + "pc": [ + 95, + 96, + 97 + ] + }, + { + "teal": 67, + "source": "examples/tuple_in_box/app.algo.ts:12", + "pc": [ + 98 + ] + }, + { + "teal": 68, + "source": "examples/tuple_in_box/app.algo.ts:12", + "pc": [ + 99 + ] + }, + { + "teal": 69, + "source": "examples/tuple_in_box/app.algo.ts:12", + "pc": [ + 100, + 101, + 102 + ] + }, + { + "teal": 70, + "source": "examples/tuple_in_box/app.algo.ts:12", + "pc": [ + 103 + ] + }, + { + "teal": 71, + "source": "examples/tuple_in_box/app.algo.ts:12", + "pc": [ + 104 + ] + }, + { + "teal": 72, + "source": "examples/tuple_in_box/app.algo.ts:12", + "pc": [ + 105, + 106 + ] + }, + { + "teal": 76, + "source": "examples/tuple_in_box/app.algo.ts:14", + "pc": [ + 107, + 108, + 109, + 110, + 111, + 112, + 113, + 114, + 115, + 116, + 117 + ] + }, + { + "teal": 77, + "source": "examples/tuple_in_box/app.algo.ts:14", + "pc": [ + 118, + 119 + ] + }, + { + "teal": 78, + "source": "examples/tuple_in_box/app.algo.ts:14", + "pc": [ + 120 + ] + }, + { + "teal": 82, + "source": "examples/tuple_in_box/app.algo.ts:15", + "pc": [ + 121, + 122 + ] + }, + { + "teal": 83, + "source": "examples/tuple_in_box/app.algo.ts:15", + "pc": [ + 123 + ] + }, + { + "teal": 84, + "source": "examples/tuple_in_box/app.algo.ts:15", + "pc": [ + 124 + ] + }, + { + "teal": 85, + "source": "examples/tuple_in_box/app.algo.ts:15", + "pc": [ + 125 + ] + }, + { + "teal": 86, + "source": "examples/tuple_in_box/app.algo.ts:15", + "pc": [ + 126, + 127 + ] + }, + { + "teal": 87, + "source": "examples/tuple_in_box/app.algo.ts:15", + "pc": [ + 128 + ] + }, + { + "teal": 88, + "source": "examples/tuple_in_box/app.algo.ts:11", + "pc": [ + 129 + ] + }, + { + "teal": 93, + "source": "examples/tuple_in_box/app.algo.ts:18", + "pc": [ + 130, + 131, + 132 + ] + }, + { + "teal": 94, + "source": "examples/tuple_in_box/app.algo.ts:18", + "pc": [ + 133 + ] + }, + { + "teal": 95, + "source": "examples/tuple_in_box/app.algo.ts:18", + "pc": [ + 134 + ] + }, + { + "teal": 96, + "source": "examples/tuple_in_box/app.algo.ts:18", + "pc": [ + 135, + 136 + ] + }, + { + "teal": 97, + "source": "examples/tuple_in_box/app.algo.ts:18", + "pc": [ + 137 + ] + }, + { + "teal": 100, + "source": "examples/tuple_in_box/app.algo.ts:18", + "errorMessage": "argument 0 (address) for addContact must be a address", + "pc": [ + 138 + ] + }, + { + "teal": 103, + "source": "examples/tuple_in_box/app.algo.ts:18", + "pc": [ + 139, + 140, + 141 + ] + }, + { + "teal": 104, + "source": "examples/tuple_in_box/app.algo.ts:18", + "pc": [ + 142, + 143, + 144 + ] + }, + { + "teal": 107, + "source": "examples/tuple_in_box/app.algo.ts:18", + "pc": [ + 145, + 146, + 147 + ] + }, + { + "teal": 108, + "source": "examples/tuple_in_box/app.algo.ts:18", + "pc": [ + 148, + 149, + 150 + ] + }, + { + "teal": 111, + "source": "examples/tuple_in_box/app.algo.ts:18", + "pc": [ + 151, + 152, + 153 + ] + }, + { + "teal": 112, + "source": "examples/tuple_in_box/app.algo.ts:18", + "pc": [ + 154, + 155 + ] + }, + { + "teal": 113, + "source": "examples/tuple_in_box/app.algo.ts:18", + "pc": [ + 156 + ] + }, + { + "teal": 117, + "source": "examples/tuple_in_box/app.algo.ts:18", + "pc": [ + 157, + 158, + 159 + ] + }, + { + "teal": 120, + "source": "examples/tuple_in_box/app.algo.ts:18", + "pc": [ + 160, + 161 + ] + }, + { + "teal": 124, + "source": "examples/tuple_in_box/app.algo.ts:19", + "pc": [ + 162, + 163 + ] + }, + { + "teal": 125, + "source": "examples/tuple_in_box/app.algo.ts:19", + "pc": [ + 164, + 165 + ] + }, + { + "teal": 126, + "source": "examples/tuple_in_box/app.algo.ts:19", + "pc": [ + 166, + 167, + 168, + 169 + ] + }, + { + "teal": 127, + "source": "examples/tuple_in_box/app.algo.ts:19", + "pc": [ + 170, + 171 + ] + }, + { + "teal": 128, + "source": "examples/tuple_in_box/app.algo.ts:19", + "pc": [ + 172 + ] + }, + { + "teal": 129, + "source": "examples/tuple_in_box/app.algo.ts:19", + "pc": [ + 173 + ] + }, + { + "teal": 130, + "source": "examples/tuple_in_box/app.algo.ts:19", + "pc": [ + 174 + ] + }, + { + "teal": 131, + "source": "examples/tuple_in_box/app.algo.ts:19", + "pc": [ + 175, + 176, + 177 + ] + }, + { + "teal": 132, + "source": "examples/tuple_in_box/app.algo.ts:19", + "pc": [ + 178 + ] + }, + { + "teal": 133, + "source": "examples/tuple_in_box/app.algo.ts:19", + "pc": [ + 179 + ] + }, + { + "teal": 134, + "source": "examples/tuple_in_box/app.algo.ts:19", + "pc": [ + 180, + 181, + 182 + ] + }, + { + "teal": 135, + "source": "examples/tuple_in_box/app.algo.ts:19", + "pc": [ + 183, + 184 + ] + }, + { + "teal": 136, + "source": "examples/tuple_in_box/app.algo.ts:19", + "pc": [ + 185 + ] + }, + { + "teal": 137, + "source": "examples/tuple_in_box/app.algo.ts:19", + "pc": [ + 186 + ] + }, + { + "teal": 138, + "source": "examples/tuple_in_box/app.algo.ts:19", + "pc": [ + 187 + ] + }, + { + "teal": 139, + "source": "examples/tuple_in_box/app.algo.ts:19", + "pc": [ + 188, + 189, + 190 + ] + }, + { + "teal": 140, + "source": "examples/tuple_in_box/app.algo.ts:19", + "pc": [ + 191 + ] + }, + { + "teal": 141, + "source": "examples/tuple_in_box/app.algo.ts:19", + "pc": [ + 192 + ] + }, + { + "teal": 142, + "source": "examples/tuple_in_box/app.algo.ts:19", + "pc": [ + 193, + 194, + 195 + ] + }, + { + "teal": 143, + "source": "examples/tuple_in_box/app.algo.ts:19", + "pc": [ + 196 + ] + }, + { + "teal": 144, + "source": "examples/tuple_in_box/app.algo.ts:19", + "pc": [ + 197 + ] + }, + { + "teal": 145, + "source": "examples/tuple_in_box/app.algo.ts:19", + "pc": [ + 198, + 199 + ] + }, + { + "teal": 149, + "source": "examples/tuple_in_box/app.algo.ts:20", + "pc": [ + 200, + 201 + ] + }, + { + "teal": 150, + "source": "examples/tuple_in_box/app.algo.ts:20", + "pc": [ + 202 + ] + }, + { + "teal": 151, + "source": "examples/tuple_in_box/app.algo.ts:20", + "pc": [ + 203 + ] + }, + { + "teal": 152, + "source": "examples/tuple_in_box/app.algo.ts:20", + "pc": [ + 204 + ] + }, + { + "teal": 153, + "source": "examples/tuple_in_box/app.algo.ts:20", + "pc": [ + 205, + 206 + ] + }, + { + "teal": 154, + "source": "examples/tuple_in_box/app.algo.ts:20", + "pc": [ + 207 + ] + }, + { + "teal": 155, + "source": "examples/tuple_in_box/app.algo.ts:18", + "pc": [ + 208 + ] + }, + { + "teal": 160, + "source": "examples/tuple_in_box/app.algo.ts:23", + "pc": [ + 209, + 210, + 211 + ] + }, + { + "teal": 161, + "source": "examples/tuple_in_box/app.algo.ts:23", + "pc": [ + 212 + ] + }, + { + "teal": 162, + "source": "examples/tuple_in_box/app.algo.ts:23", + "pc": [ + 213 + ] + }, + { + "teal": 163, + "source": "examples/tuple_in_box/app.algo.ts:23", + "pc": [ + 214, + 215 + ] + }, + { + "teal": 164, + "source": "examples/tuple_in_box/app.algo.ts:23", + "pc": [ + 216 + ] + }, + { + "teal": 167, + "source": "examples/tuple_in_box/app.algo.ts:23", + "errorMessage": "argument 0 (address) for updateContactField must be a address", + "pc": [ + 217 + ] + }, + { + "teal": 170, + "source": "examples/tuple_in_box/app.algo.ts:23", + "pc": [ + 218, + 219, + 220 + ] + }, + { + "teal": 171, + "source": "examples/tuple_in_box/app.algo.ts:23", + "pc": [ + 221, + 222, + 223 + ] + }, + { + "teal": 174, + "source": "examples/tuple_in_box/app.algo.ts:23", + "pc": [ + 224, + 225, + 226 + ] + }, + { + "teal": 175, + "source": "examples/tuple_in_box/app.algo.ts:23", + "pc": [ + 227, + 228, + 229 + ] + }, + { + "teal": 178, + "source": "examples/tuple_in_box/app.algo.ts:23", + "pc": [ + 230, + 231, + 232 + ] + }, + { + "teal": 179, + "source": "examples/tuple_in_box/app.algo.ts:23", + "pc": [ + 233, + 234 + ] + }, + { + "teal": 180, + "source": "examples/tuple_in_box/app.algo.ts:23", + "pc": [ + 235 + ] + }, + { + "teal": 184, + "source": "examples/tuple_in_box/app.algo.ts:23", + "pc": [ + 236, + 237, + 238 + ] + }, + { + "teal": 189, + "source": "examples/tuple_in_box/app.algo.ts:24", + "pc": [ + 239, + 240 + ] + }, + { + "teal": 190, + "source": "examples/tuple_in_box/app.algo.ts:24", + "pc": [ + 241, + 242, + 243, + 244, + 245, + 246 + ] + }, + { + "teal": 191, + "source": "examples/tuple_in_box/app.algo.ts:24", + "pc": [ + 247 + ] + }, + { + "teal": 192, + "source": "examples/tuple_in_box/app.algo.ts:24", + "pc": [ + 248, + 249, + 250 + ] + }, + { + "teal": 197, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 251, + 252 + ] + }, + { + "teal": 198, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 253 + ] + }, + { + "teal": 201, + "source": "examples/tuple_in_box/app.algo.ts:25", + "errorMessage": "box value does not exist: this.contacts(address).value", + "pc": [ + 254 + ] + }, + { + "teal": 202, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 255, + 256 + ] + }, + { + "teal": 203, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 257, + 258 + ] + }, + { + "teal": 204, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 259 + ] + }, + { + "teal": 205, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 260, + 261 + ] + }, + { + "teal": 206, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 262, + 263 + ] + }, + { + "teal": 207, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 264, + 265 + ] + }, + { + "teal": 208, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 266, + 267 + ] + }, + { + "teal": 209, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 268 + ] + }, + { + "teal": 210, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 269 + ] + }, + { + "teal": 211, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 270, + 271 + ] + }, + { + "teal": 212, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 272 + ] + }, + { + "teal": 213, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 273, + 274 + ] + }, + { + "teal": 214, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 275 + ] + }, + { + "teal": 215, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 276 + ] + }, + { + "teal": 216, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 277, + 278 + ] + }, + { + "teal": 217, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 279 + ] + }, + { + "teal": 218, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 280, + 281 + ] + }, + { + "teal": 219, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 282 + ] + }, + { + "teal": 220, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 283, + 284 + ] + }, + { + "teal": 221, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 285, + 286 + ] + }, + { + "teal": 222, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 287, + 288 + ] + }, + { + "teal": 223, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 289, + 290 + ] + }, + { + "teal": 224, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 291 + ] + }, + { + "teal": 225, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 292, + 293 + ] + }, + { + "teal": 226, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 294 + ] + }, + { + "teal": 227, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 295 + ] + }, + { + "teal": 228, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 296 + ] + }, + { + "teal": 229, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 297, + 298, + 299 + ] + }, + { + "teal": 230, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 300 + ] + }, + { + "teal": 231, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 301 + ] + }, + { + "teal": 232, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 302 + ] + }, + { + "teal": 233, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 303, + 304 + ] + }, + { + "teal": 234, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 305, + 306 + ] + }, + { + "teal": 235, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 307, + 308 + ] + }, + { + "teal": 236, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 309, + 310 + ] + }, + { + "teal": 237, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 311 + ] + }, + { + "teal": 238, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 312, + 313 + ] + }, + { + "teal": 239, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 314 + ] + }, + { + "teal": 240, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 315 + ] + }, + { + "teal": 241, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 316 + ] + }, + { + "teal": 242, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 317 + ] + }, + { + "teal": 243, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 318, + 319 + ] + }, + { + "teal": 244, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 320, + 321, + 322 + ] + }, + { + "teal": 245, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 323, + 324 + ] + }, + { + "teal": 246, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 325, + 326 + ] + }, + { + "teal": 247, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 327, + 328 + ] + }, + { + "teal": 248, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 329 + ] + }, + { + "teal": 249, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 330, + 331, + 332 + ] + }, + { + "teal": 250, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 333, + 334 + ] + }, + { + "teal": 251, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 335, + 336 + ] + }, + { + "teal": 252, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 337 + ] + }, + { + "teal": 253, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 338 + ] + }, + { + "teal": 254, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 339 + ] + }, + { + "teal": 255, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 340 + ] + }, + { + "teal": 256, + "source": "examples/tuple_in_box/app.algo.ts:25", + "pc": [ + 341 + ] + }, + { + "teal": 257, + "source": "examples/tuple_in_box/app.algo.ts:24", + "pc": [ + 342, + 343, + 344 + ] + }, + { + "teal": 262, + "source": "examples/tuple_in_box/app.algo.ts:26", + "pc": [ + 345, + 346 + ] + }, + { + "teal": 263, + "source": "examples/tuple_in_box/app.algo.ts:26", + "pc": [ + 347, + 348, + 349, + 350, + 351, + 352, + 353, + 354, + 355 + ] + }, + { + "teal": 264, + "source": "examples/tuple_in_box/app.algo.ts:26", + "pc": [ + 356 + ] + }, + { + "teal": 265, + "source": "examples/tuple_in_box/app.algo.ts:26", + "pc": [ + 357, + 358, + 359 + ] + }, + { + "teal": 270, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 360, + 361 + ] + }, + { + "teal": 271, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 362 + ] + }, + { + "teal": 274, + "source": "examples/tuple_in_box/app.algo.ts:27", + "errorMessage": "box value does not exist: this.contacts(address).value", + "pc": [ + 363 + ] + }, + { + "teal": 275, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 364, + 365 + ] + }, + { + "teal": 276, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 366, + 367 + ] + }, + { + "teal": 277, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 368 + ] + }, + { + "teal": 278, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 369, + 370 + ] + }, + { + "teal": 279, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 371, + 372 + ] + }, + { + "teal": 280, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 373, + 374 + ] + }, + { + "teal": 281, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 375, + 376 + ] + }, + { + "teal": 282, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 377 + ] + }, + { + "teal": 283, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 378 + ] + }, + { + "teal": 284, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 379, + 380 + ] + }, + { + "teal": 285, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 381 + ] + }, + { + "teal": 286, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 382, + 383 + ] + }, + { + "teal": 287, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 384 + ] + }, + { + "teal": 288, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 385 + ] + }, + { + "teal": 289, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 386, + 387 + ] + }, + { + "teal": 290, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 388 + ] + }, + { + "teal": 291, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 389, + 390 + ] + }, + { + "teal": 292, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 391 + ] + }, + { + "teal": 293, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 392, + 393 + ] + }, + { + "teal": 294, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 394, + 395 + ] + }, + { + "teal": 295, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 396, + 397 + ] + }, + { + "teal": 296, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 398, + 399 + ] + }, + { + "teal": 297, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 400 + ] + }, + { + "teal": 298, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 401, + 402 + ] + }, + { + "teal": 299, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 403 + ] + }, + { + "teal": 300, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 404 + ] + }, + { + "teal": 301, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 405 + ] + }, + { + "teal": 302, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 406, + 407, + 408 + ] + }, + { + "teal": 303, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 409 + ] + }, + { + "teal": 304, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 410 + ] + }, + { + "teal": 305, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 411 + ] + }, + { + "teal": 306, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 412, + 413 + ] + }, + { + "teal": 307, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 414, + 415 + ] + }, + { + "teal": 308, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 416, + 417 + ] + }, + { + "teal": 309, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 418, + 419 + ] + }, + { + "teal": 310, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 420 + ] + }, + { + "teal": 311, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 421, + 422 + ] + }, + { + "teal": 312, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 423 + ] + }, + { + "teal": 313, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 424 + ] + }, + { + "teal": 314, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 425 + ] + }, + { + "teal": 315, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 426 + ] + }, + { + "teal": 316, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 427, + 428 + ] + }, + { + "teal": 317, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 429, + 430, + 431 + ] + }, + { + "teal": 318, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 432, + 433 + ] + }, + { + "teal": 319, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 434, + 435 + ] + }, + { + "teal": 320, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 436 + ] + }, + { + "teal": 321, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 437 + ] + }, + { + "teal": 322, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 438 + ] + }, + { + "teal": 323, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 439 + ] + }, + { + "teal": 324, + "source": "examples/tuple_in_box/app.algo.ts:27", + "pc": [ + 440 + ] + }, + { + "teal": 325, + "source": "examples/tuple_in_box/app.algo.ts:26", + "pc": [ + 441, + 442, + 443 + ] + }, + { + "teal": 329, + "source": "examples/tuple_in_box/app.algo.ts:28", + "errorMessage": "Invalid field", + "pc": [ + 444 + ] + }, + { + "teal": 332, + "source": "examples/tuple_in_box/app.algo.ts:23", + "pc": [ + 445 + ] + }, + { + "teal": 337, + "source": "examples/tuple_in_box/app.algo.ts:31", + "pc": [ + 446, + 447, + 448 + ] + }, + { + "teal": 338, + "source": "examples/tuple_in_box/app.algo.ts:31", + "pc": [ + 449 + ] + }, + { + "teal": 339, + "source": "examples/tuple_in_box/app.algo.ts:31", + "pc": [ + 450 + ] + }, + { + "teal": 340, + "source": "examples/tuple_in_box/app.algo.ts:31", + "pc": [ + 451, + 452 + ] + }, + { + "teal": 341, + "source": "examples/tuple_in_box/app.algo.ts:31", + "pc": [ + 453 + ] + }, + { + "teal": 344, + "source": "examples/tuple_in_box/app.algo.ts:31", + "errorMessage": "argument 0 (address) for verifyContactName must be a address", + "pc": [ + 454 + ] + }, + { + "teal": 347, + "source": "examples/tuple_in_box/app.algo.ts:31", + "pc": [ + 455, + 456, + 457 + ] + }, + { + "teal": 348, + "source": "examples/tuple_in_box/app.algo.ts:31", + "pc": [ + 458, + 459, + 460 + ] + }, + { + "teal": 351, + "source": "examples/tuple_in_box/app.algo.ts:31", + "pc": [ + 461, + 462, + 463 + ] + }, + { + "teal": 352, + "source": "examples/tuple_in_box/app.algo.ts:31", + "pc": [ + 464, + 465 + ] + }, + { + "teal": 353, + "source": "examples/tuple_in_box/app.algo.ts:31", + "pc": [ + 466 + ] + }, + { + "teal": 357, + "source": "examples/tuple_in_box/app.algo.ts:31", + "pc": [ + 467, + 468, + 469 + ] + }, + { + "teal": 361, + "source": "examples/tuple_in_box/app.algo.ts:32", + "pc": [ + 470, + 471 + ] + }, + { + "teal": 362, + "source": "examples/tuple_in_box/app.algo.ts:32", + "pc": [ + 472 + ] + }, + { + "teal": 365, + "source": "examples/tuple_in_box/app.algo.ts:32", + "errorMessage": "box value does not exist: this.contacts(address).value", + "pc": [ + 473 + ] + }, + { + "teal": 366, + "source": "examples/tuple_in_box/app.algo.ts:32", + "pc": [ + 474, + 475 + ] + }, + { + "teal": 367, + "source": "examples/tuple_in_box/app.algo.ts:32", + "pc": [ + 476, + 477 + ] }, { + "teal": 368, + "source": "examples/tuple_in_box/app.algo.ts:32", "pc": [ - 138 - ], - "errorMessage": "argument 0 (address) for addContact must be a address" + 478, + 479 + ] }, { + "teal": 369, + "source": "examples/tuple_in_box/app.algo.ts:32", "pc": [ - 217 - ], - "errorMessage": "argument 0 (address) for updateContactField must be a address" + 480, + 481 + ] }, { + "teal": 370, + "source": "examples/tuple_in_box/app.algo.ts:32", "pc": [ - 254 - ], - "errorMessage": "box value does not exist: this.contacts(address).value" + 482, + 483 + ] }, { + "teal": 371, + "source": "examples/tuple_in_box/app.algo.ts:32", "pc": [ - 363 - ], - "errorMessage": "box value does not exist: this.contacts(address).value" + 484 + ] }, { + "teal": 372, + "source": "examples/tuple_in_box/app.algo.ts:32", "pc": [ - 444 - ], - "errorMessage": "Invalid field" + 485 + ] }, { + "teal": 373, + "source": "examples/tuple_in_box/app.algo.ts:32", "pc": [ - 454 - ], - "errorMessage": "argument 0 (address) for verifyContactName must be a address" + 486, + 487 + ] }, { + "teal": 374, + "source": "examples/tuple_in_box/app.algo.ts:32", "pc": [ - 473 - ], - "errorMessage": "box value does not exist: this.contacts(address).value" + 488 + ] + }, + { + "teal": 375, + "source": "examples/tuple_in_box/app.algo.ts:32", + "pc": [ + 489 + ] + }, + { + "teal": 376, + "source": "examples/tuple_in_box/app.algo.ts:32", + "pc": [ + 490, + 491 + ] + }, + { + "teal": 377, + "source": "examples/tuple_in_box/app.algo.ts:32", + "pc": [ + 492 + ] + }, + { + "teal": 378, + "source": "examples/tuple_in_box/app.algo.ts:32", + "pc": [ + 493, + 494 + ] + }, + { + "teal": 379, + "source": "examples/tuple_in_box/app.algo.ts:32", + "pc": [ + 495 + ] + }, + { + "teal": 380, + "source": "examples/tuple_in_box/app.algo.ts:32", + "pc": [ + 496 + ] + }, + { + "teal": 381, + "source": "examples/tuple_in_box/app.algo.ts:32", + "pc": [ + 497, + 498, + 499 + ] + }, + { + "teal": 382, + "source": "examples/tuple_in_box/app.algo.ts:32", + "pc": [ + 500, + 501 + ] + }, + { + "teal": 383, + "source": "examples/tuple_in_box/app.algo.ts:32", + "pc": [ + 502 + ] + }, + { + "teal": 384, + "source": "examples/tuple_in_box/app.algo.ts:32", + "pc": [ + 503 + ] + }, + { + "teal": 385, + "source": "examples/tuple_in_box/app.algo.ts:31", + "pc": [ + 504 + ] + }, + { + "teal": 388, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 505, + 506 + ] + }, + { + "teal": 389, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 507 + ] + }, + { + "teal": 392, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 508, + 509, + 510, + 511, + 512, + 513 + ] + }, + { + "teal": 393, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 514, + 515, + 516 + ] }, { + "teal": 394, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 517, + 518, + 519, + 520 + ] + }, + { + "teal": 397, + "source": "examples/tuple_in_box/app.algo.ts:6", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 521 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 400, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 522, + 523, + 524, + 525, + 526, + 527 + ] + }, + { + "teal": 401, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 528, + 529, + 530, + 531, + 532, + 533 + ] + }, + { + "teal": 402, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 534, + 535, + 536, + 537, + 538, + 539 + ] }, { + "teal": 403, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 540, + 541, + 542, + 543, + 544, + 545 + ] + }, + { + "teal": 404, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 546, + 547, + 548 + ] + }, + { + "teal": 405, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 549, + 550, + 551, + 552, + 553, + 554, + 555, + 556, + 557, + 558 + ] + }, + { + "teal": 408, + "source": "examples/tuple_in_box/app.algo.ts:6", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 559 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] + }, + { + "teal": 411, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 560, + 561, + 562 + ] + }, + { + "teal": 412, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 563, + 564 + ] + }, + { + "teal": 413, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 565, + 566 + ] + }, + { + "teal": 414, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 567 + ] + }, + { + "teal": 415, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 568, + 569 + ] + }, + { + "teal": 416, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 570, + 571 + ] + }, + { + "teal": 417, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 572 + ] + }, + { + "teal": 418, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 573 + ] + }, + { + "teal": 419, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 574, + 575 + ] + }, + { + "teal": 420, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 576 + ] + }, + { + "teal": 421, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 577 + ] + }, + { + "teal": 422, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 578 + ] + }, + { + "teal": 423, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 579, + 580, + 581 + ] + }, + { + "teal": 424, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 582, + 583 + ] + }, + { + "teal": 425, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 584, + 585 + ] + }, + { + "teal": 426, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 586 + ] + }, + { + "teal": 427, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 587 + ] + }, + { + "teal": 428, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 588, + 589 + ] + }, + { + "teal": 429, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 590, + 591 + ] + }, + { + "teal": 430, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 592, + 593 + ] + }, + { + "teal": 431, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 594, + 595 + ] + }, + { + "teal": 432, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 596 + ] + }, + { + "teal": 435, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 597, + 598, + 599 + ] + }, + { + "teal": 436, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 600, + 601 + ] + }, + { + "teal": 437, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 602, + 603 + ] + }, + { + "teal": 438, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 604, + 605 + ] + }, + { + "teal": 439, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 606 + ] + }, + { + "teal": 440, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 607, + 608 + ] + }, + { + "teal": 441, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 609, + 610, + 611 + ] + }, + { + "teal": 442, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 612 + ] + }, + { + "teal": 443, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 613, + 614, + 615 + ] + }, + { + "teal": 446, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 616 + ] + }, + { + "teal": 447, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 617 + ] + }, + { + "teal": 450, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 618 + ] + }, + { + "teal": 451, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 619, + 620, + 621 + ] + }, + { + "teal": 452, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 622, + 623 + ] + }, + { + "teal": 453, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 624 + ] + }, + { + "teal": 454, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 625, + 626 + ] + }, + { + "teal": 455, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 627 + ] + }, + { + "teal": 456, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 628 + ] + }, + { + "teal": 457, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 629, + 630 + ] + }, + { + "teal": 458, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 631 + ] + }, + { + "teal": 461, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 632, + 633 + ] + }, + { + "teal": 462, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 634 + ] + }, + { + "teal": 463, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 635, + 636 + ] + }, + { + "teal": 464, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 637 + ] + }, + { + "teal": 465, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 638, + 639, + 640 + ] + }, + { + "teal": 466, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 641, + 642 + ] + }, + { + "teal": 467, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 643 + ] + }, + { + "teal": 468, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 644, + 645 + ] + }, + { + "teal": 469, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 646, + 647 + ] + }, + { + "teal": 470, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 648, + 649 + ] + }, + { + "teal": 471, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 650, + 651, + 652 + ] + }, + { + "teal": 474, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 653, + 654 + ] + }, + { + "teal": 475, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 655, + 656 + ] + }, + { + "teal": 476, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 657 + ] + }, + { + "teal": 477, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 658, + 659 + ] + }, + { + "teal": 478, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 660, + 661 + ] + }, + { + "teal": 481, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 662 + ] + }, + { + "teal": 482, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 663, + 664 + ] + }, + { + "teal": 483, + "source": "examples/tuple_in_box/app.algo.ts:6", + "pc": [ + 665 + ] } ], "pcOffsetMethod": "none" diff --git a/src/lib/compiler.ts b/src/lib/compiler.ts index aec36c95c..c625af767 100644 --- a/src/lib/compiler.ts +++ b/src/lib/compiler.ts @@ -7679,12 +7679,7 @@ declare type AssetFreezeTxn = Required; }, }; - const arc56SourceInfo: { pc: number[]; errorMessage: string }[] = this.sourceInfo - .filter((s) => s.errorMessage) - .map((s) => ({ - pc: s.pc as number[], - errorMessage: s.errorMessage as string, - })); + const sourceInfo = this.sourceInfo.filter((s) => s.pc !== undefined); const arc56: ARC56Contract = { ...this.arc4Description(), @@ -7694,7 +7689,11 @@ declare type AssetFreezeTxn = Required; bareActions: { create: [], call: [] }, // TODO: clear source mapping sourceInfo: { - approval: { sourceInfo: arc56SourceInfo, pcOffsetMethod: this.hasDynamicTemplateVar ? 'cblocks' : 'none' }, + approval: { + // @ts-expect-error Undefined PCs are filtered out above + sourceInfo, + pcOffsetMethod: this.hasDynamicTemplateVar ? 'cblocks' : 'none', + }, clear: { sourceInfo: [], pcOffsetMethod: 'none' }, }, source: { diff --git a/src/types/arc56.d.ts b/src/types/arc56.d.ts index f8f7ee123..0f369c7b1 100644 --- a/src/types/arc56.d.ts +++ b/src/types/arc56.d.ts @@ -246,11 +246,15 @@ export interface StorageMap { prefix?: string; } -export interface SourceInfo { - /** The program counter offset(s) that correspond to this line of TEAL */ - pc?: Array; - /** A human-readable string that describes the error when the program fails at this given line of TEAL */ - errorMessage: string; +interface SourceInfo { + /** The program counter value(s). Could be offset if pcOffsetMethod is not "none" */ + pc: Array; + /** A human-readable string that describes the error when the program fails at the given PC */ + errorMessage?: string; + /** The TEAL line number that corresponds to the given PC. RECOMMENDED to be used for development purposes, but not required for clients */ + teal?: number; + /** The original source file and line number that corresponds to the given PC. RECOMMENDED to be used for development purposes, but not required for clients */ + source?: string; } export interface ProgramSourceInfo { diff --git a/tests/contracts/artifacts/A.arc56_draft.json b/tests/contracts/artifacts/A.arc56_draft.json index c50f21ad9..07523b57b 100644 --- a/tests/contracts/artifacts/A.arc56_draft.json +++ b/tests/contracts/artifacts/A.arc56_draft.json @@ -70,22 +70,254 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/inheritance.algo.ts:12", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/inheritance.algo.ts:12", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/inheritance.algo.ts:12", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/inheritance.algo.ts:12", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/inheritance.algo.ts:12", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/inheritance.algo.ts:12", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/inheritance.algo.ts:12", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/inheritance.algo.ts:12", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/inheritance.algo.ts:12", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/inheritance.algo.ts:15", + "pc": [ + 37, + 38, + 39 + ] + }, + { + "teal": 29, + "source": "tests/contracts/inheritance.algo.ts:15", + "pc": [ + 40, + 41 + ] + }, + { + "teal": 30, + "source": "tests/contracts/inheritance.algo.ts:15", + "pc": [ + 42 + ] + }, + { + "teal": 34, + "source": "tests/contracts/inheritance.algo.ts:15", + "pc": [ + 43, + 44, + 45 + ] }, { + "teal": 38, + "source": "tests/contracts/inheritance.algo.ts:16", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 39, + "source": "tests/contracts/inheritance.algo.ts:16", + "pc": [ + 49, + 50, + 51 + ] + }, + { + "teal": 40, + "source": "tests/contracts/inheritance.algo.ts:16", + "pc": [ + 52 + ] + }, + { + "teal": 41, + "source": "tests/contracts/inheritance.algo.ts:15", + "pc": [ + 53 + ] + }, + { + "teal": 44, + "source": "tests/contracts/inheritance.algo.ts:12", + "pc": [ + 54, + 55 + ] + }, + { + "teal": 45, + "source": "tests/contracts/inheritance.algo.ts:12", + "pc": [ + 56 + ] + }, + { + "teal": 48, + "source": "tests/contracts/inheritance.algo.ts:12", + "pc": [ + 57, + 58, + 59, + 60, + 61, + 62 + ] + }, + { + "teal": 49, + "source": "tests/contracts/inheritance.algo.ts:12", + "pc": [ + 63, + 64, + 65 + ] + }, + { + "teal": 50, + "source": "tests/contracts/inheritance.algo.ts:12", + "pc": [ + 66, + 67, + 68, + 69 + ] + }, + { + "teal": 53, + "source": "tests/contracts/inheritance.algo.ts:12", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 70 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 56, + "source": "tests/contracts/inheritance.algo.ts:12", + "pc": [ + 71, + 72, + 73, + 74, + 75, + 76 + ] + }, + { + "teal": 57, + "source": "tests/contracts/inheritance.algo.ts:12", + "pc": [ + 77, + 78, + 79 + ] + }, + { + "teal": 58, + "source": "tests/contracts/inheritance.algo.ts:12", + "pc": [ + 80, + 81, + 82, + 83 + ] }, { + "teal": 61, + "source": "tests/contracts/inheritance.algo.ts:12", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 84 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestAccesStringInTuple.arc56_draft.json b/tests/contracts/artifacts/ABITestAccesStringInTuple.arc56_draft.json index 0afa10267..6692503e0 100644 --- a/tests/contracts/artifacts/ABITestAccesStringInTuple.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestAccesStringInTuple.arc56_draft.json @@ -64,22 +64,980 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:548", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:548", + "pc": [ + 1, + 2, + 3 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:548", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:548", + "pc": [ + 6 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:548", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:548", + "pc": [ + 9 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:548", + "pc": [ + 10, + 11 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:548", + "pc": [ + 12 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:548", + "pc": [ + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:548", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 39 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:549", + "pc": [ + 40, + 41, + 42, + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:549", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:549", + "pc": [ + 49 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:549", + "pc": [ + 50 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:549", + "pc": [ + 51 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:549", + "pc": [ + 52, + 53, + 54 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:549", + "pc": [ + 55 + ] + }, + { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:549", + "pc": [ + 56 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:549", + "pc": [ + 57 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:549", + "pc": [ + 58 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:549", + "pc": [ + 59, + 60 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:549", + "pc": [ + 61 + ] + }, + { + "teal": 46, + "source": "tests/contracts/abi.algo.ts:549", + "pc": [ + 62, + 63, + 64 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:549", + "pc": [ + 65, + 66 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:550", + "pc": [ + 67, + 68 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:550", + "pc": [ + 69, + 70 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:550", + "pc": [ + 71, + 72, + 73, + 74 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:550", + "pc": [ + 75, + 76, + 77, + 78 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:550", + "pc": [ + 79, + 80, + 81 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:550", + "pc": [ + 82, + 83, + 84, + 85, + 86 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:550", + "pc": [ + 87, + 88, + 89 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:550", + "pc": [ + 90, + 91, + 92, + 93, + 94, + 95, + 96, + 97, + 98, + 99, + 100, + 101, + 102, + 103, + 104, + 105 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:550", + "pc": [ + 106, + 107, + 108 + ] }, { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:550", + "pc": [ + 109, + 110, + 111, + 112, + 113 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:550", + "pc": [ + 114, + 115, + 116 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:550", + "pc": [ + 117 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:550", + "pc": [ + 118 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:550", + "pc": [ + 119, + 120 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:552", + "pc": [ + 121, + 122 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:552", + "pc": [ + 123, + 124 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:552", + "pc": [ + 125, + 126 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:552", + "pc": [ + 127, + 128 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:552", + "pc": [ + 129, + 130 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:552", + "pc": [ + 131, + 132 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:552", + "pc": [ + 133 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:552", + "pc": [ + 134 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:552", + "pc": [ + 135, + 136 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:552", + "pc": [ + 137 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:552", + "pc": [ + 138 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:552", + "pc": [ + 139, + 140 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:552", + "pc": [ + 141 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:552", + "pc": [ + 142, + 143 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:552", + "pc": [ + 144 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:552", + "pc": [ + 145 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:552", + "pc": [ + 146, + 147, + 148 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:552", + "pc": [ + 149, + 150, + 151, + 152, + 153, + 154, + 155, + 156, + 157, + 158, + 159, + 160, + 161, + 162 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:552", + "pc": [ + 163 + ] + }, + { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:552", + "pc": [ + 164 + ] + }, + { + "teal": 93, + "source": "tests/contracts/abi.algo.ts:554", + "pc": [ + 165, + 166 + ] + }, + { + "teal": 94, + "source": "tests/contracts/abi.algo.ts:554", + "pc": [ + 167, + 168 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:554", + "pc": [ + 169, + 170 + ] + }, + { + "teal": 96, + "source": "tests/contracts/abi.algo.ts:554", + "pc": [ + 171, + 172 + ] + }, + { + "teal": 97, + "source": "tests/contracts/abi.algo.ts:554", + "pc": [ + 173, + 174 + ] + }, + { + "teal": 98, + "source": "tests/contracts/abi.algo.ts:554", + "pc": [ + 175, + 176 + ] + }, + { + "teal": 99, + "source": "tests/contracts/abi.algo.ts:554", + "pc": [ + 177 + ] + }, + { + "teal": 100, + "source": "tests/contracts/abi.algo.ts:554", + "pc": [ + 178 + ] + }, + { + "teal": 101, + "source": "tests/contracts/abi.algo.ts:554", + "pc": [ + 179, + 180 + ] + }, + { + "teal": 102, + "source": "tests/contracts/abi.algo.ts:554", + "pc": [ + 181 + ] + }, + { + "teal": 103, + "source": "tests/contracts/abi.algo.ts:554", + "pc": [ + 182 + ] + }, + { + "teal": 104, + "source": "tests/contracts/abi.algo.ts:554", + "pc": [ + 183, + 184 + ] + }, + { + "teal": 105, + "source": "tests/contracts/abi.algo.ts:554", + "pc": [ + 185 + ] + }, + { + "teal": 106, + "source": "tests/contracts/abi.algo.ts:554", + "pc": [ + 186, + 187 + ] + }, + { + "teal": 107, + "source": "tests/contracts/abi.algo.ts:554", + "pc": [ + 188 + ] + }, + { + "teal": 108, + "source": "tests/contracts/abi.algo.ts:554", + "pc": [ + 189 + ] + }, + { + "teal": 109, + "source": "tests/contracts/abi.algo.ts:554", + "pc": [ + 190, + 191, + 192 + ] + }, + { + "teal": 112, + "source": "tests/contracts/abi.algo.ts:549", + "pc": [ + 193, + 194 + ] + }, + { + "teal": 113, + "source": "tests/contracts/abi.algo.ts:549", + "pc": [ + 195 + ] + }, + { + "teal": 116, + "source": "tests/contracts/abi.algo.ts:548", + "pc": [ + 196, + 197 + ] + }, + { + "teal": 117, + "source": "tests/contracts/abi.algo.ts:548", + "pc": [ + 198 + ] + }, + { + "teal": 120, + "source": "tests/contracts/abi.algo.ts:548", + "pc": [ + 199, + 200, + 201, + 202, + 203, + 204 + ] + }, + { + "teal": 121, + "source": "tests/contracts/abi.algo.ts:548", + "pc": [ + 205, + 206, + 207 + ] + }, + { + "teal": 122, + "source": "tests/contracts/abi.algo.ts:548", + "pc": [ + 208, + 209, + 210, + 211 + ] + }, + { + "teal": 125, + "source": "tests/contracts/abi.algo.ts:548", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 212 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] }, { + "teal": 128, + "source": "tests/contracts/abi.algo.ts:548", + "pc": [ + 213, + 214, + 215, + 216, + 217, + 218 + ] + }, + { + "teal": 129, + "source": "tests/contracts/abi.algo.ts:548", + "pc": [ + 219, + 220, + 221 + ] + }, + { + "teal": 130, + "source": "tests/contracts/abi.algo.ts:548", + "pc": [ + 222, + 223, + 224, + 225 + ] + }, + { + "teal": 133, + "source": "tests/contracts/abi.algo.ts:548", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 226 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] + }, + { + "teal": 136, + "source": "tests/contracts/abi.algo.ts:548", + "pc": [ + 227, + 228, + 229 + ] + }, + { + "teal": 137, + "source": "tests/contracts/abi.algo.ts:548", + "pc": [ + 230, + 231 + ] + }, + { + "teal": 138, + "source": "tests/contracts/abi.algo.ts:548", + "pc": [ + 232, + 233 + ] + }, + { + "teal": 139, + "source": "tests/contracts/abi.algo.ts:548", + "pc": [ + 234 + ] + }, + { + "teal": 140, + "source": "tests/contracts/abi.algo.ts:548", + "pc": [ + 235, + 236 + ] + }, + { + "teal": 141, + "source": "tests/contracts/abi.algo.ts:548", + "pc": [ + 237, + 238 + ] + }, + { + "teal": 142, + "source": "tests/contracts/abi.algo.ts:548", + "pc": [ + 239 + ] + }, + { + "teal": 145, + "source": "tests/contracts/abi.algo.ts:548", + "pc": [ + 240, + 241, + 242 + ] + }, + { + "teal": 146, + "source": "tests/contracts/abi.algo.ts:548", + "pc": [ + 243, + 244 + ] + }, + { + "teal": 147, + "source": "tests/contracts/abi.algo.ts:548", + "pc": [ + 245, + 246 + ] + }, + { + "teal": 148, + "source": "tests/contracts/abi.algo.ts:548", + "pc": [ + 247 + ] + }, + { + "teal": 149, + "source": "tests/contracts/abi.algo.ts:548", + "pc": [ + 248, + 249 + ] + }, + { + "teal": 150, + "source": "tests/contracts/abi.algo.ts:548", + "pc": [ + 250, + 251 + ] + }, + { + "teal": 151, + "source": "tests/contracts/abi.algo.ts:548", + "pc": [ + 252 + ] + }, + { + "teal": 152, + "source": "tests/contracts/abi.algo.ts:548", + "pc": [ + 253 + ] + }, + { + "teal": 153, + "source": "tests/contracts/abi.algo.ts:548", + "pc": [ + 254, + 255 + ] + }, + { + "teal": 154, + "source": "tests/contracts/abi.algo.ts:548", + "pc": [ + 256 + ] + }, + { + "teal": 155, + "source": "tests/contracts/abi.algo.ts:548", + "pc": [ + 257 + ] + }, + { + "teal": 156, + "source": "tests/contracts/abi.algo.ts:548", + "pc": [ + 258 + ] + }, + { + "teal": 157, + "source": "tests/contracts/abi.algo.ts:548", + "pc": [ + 259, + 260, + 261 + ] + }, + { + "teal": 158, + "source": "tests/contracts/abi.algo.ts:548", + "pc": [ + 262, + 263 + ] + }, + { + "teal": 159, + "source": "tests/contracts/abi.algo.ts:548", + "pc": [ + 264, + 265 + ] + }, + { + "teal": 160, + "source": "tests/contracts/abi.algo.ts:548", + "pc": [ + 266 + ] + }, + { + "teal": 161, + "source": "tests/contracts/abi.algo.ts:548", + "pc": [ + 267 + ] + }, + { + "teal": 162, + "source": "tests/contracts/abi.algo.ts:548", + "pc": [ + 268, + 269 + ] + }, + { + "teal": 163, + "source": "tests/contracts/abi.algo.ts:548", + "pc": [ + 270, + 271 + ] + }, + { + "teal": 164, + "source": "tests/contracts/abi.algo.ts:548", + "pc": [ + 272, + 273 + ] + }, + { + "teal": 165, + "source": "tests/contracts/abi.algo.ts:548", + "pc": [ + 274, + 275 + ] + }, + { + "teal": 166, + "source": "tests/contracts/abi.algo.ts:548", + "pc": [ + 276 + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestAccessDynamicArrayElementInTuple.arc56_draft.json b/tests/contracts/artifacts/ABITestAccessDynamicArrayElementInTuple.arc56_draft.json index 1863fe380..f0ca52163 100644 --- a/tests/contracts/artifacts/ABITestAccessDynamicArrayElementInTuple.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestAccessDynamicArrayElementInTuple.arc56_draft.json @@ -64,28 +64,752 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:672", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:672", + "pc": [ + 1, + 2, + 3 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:672", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:672", + "pc": [ + 6 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:672", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:672", + "pc": [ + 9 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:672", + "pc": [ + 10, + 11 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:672", + "pc": [ + 12 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:672", + "pc": [ + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:672", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 39 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:673", + "pc": [ + 40, + 41, + 42, + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:673", + "pc": [ + 46, + 47, + 48 + ] }, { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:673", + "pc": [ + 49 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:673", + "pc": [ + 50 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:673", + "pc": [ + 51 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:673", + "pc": [ + 52, + 53 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:673", + "pc": [ + 54 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:673", + "errorMessage": "accessDynamicArrayElementInTuple return value overflowed 8 bits", "pc": [ 55 - ], - "errorMessage": "accessDynamicArrayElementInTuple return value overflowed 8 bits" + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:673", + "pc": [ + 56, + 57, + 58 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:673", + "pc": [ + 59 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:673", + "pc": [ + 60 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:673", + "pc": [ + 61, + 62 + ] + }, + { + "teal": 45, + "source": "tests/contracts/abi.algo.ts:673", + "pc": [ + 63 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:673", + "pc": [ + 64, + 65, + 66 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:673", + "pc": [ + 67, + 68 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:674", + "pc": [ + 69, + 70 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:674", + "pc": [ + 71, + 72 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:674", + "pc": [ + 73, + 74, + 75, + 76 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:674", + "pc": [ + 77, + 78, + 79, + 80 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:674", + "pc": [ + 81, + 82, + 83 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:674", + "pc": [ + 84, + 85, + 86, + 87, + 88, + 89, + 90 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:674", + "pc": [ + 91, + 92, + 93 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:674", + "pc": [ + 94 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:674", + "pc": [ + 95 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:674", + "pc": [ + 96, + 97 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:676", + "pc": [ + 98, + 99 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:676", + "pc": [ + 100, + 101 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:676", + "pc": [ + 102, + 103 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:676", + "pc": [ + 104, + 105 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:676", + "pc": [ + 106 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:676", + "pc": [ + 107, + 108 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:676", + "pc": [ + 109 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:676", + "pc": [ + 110, + 111 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:676", + "pc": [ + 112 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:676", + "pc": [ + 113, + 114 + ] }, { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:676", + "pc": [ + 115 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:676", + "pc": [ + 116, + 117 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:676", + "pc": [ + 118 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:676", + "pc": [ + 119 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:673", + "pc": [ + 120, + 121 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:673", + "pc": [ + 122 + ] + }, + { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:672", + "pc": [ + 123, + 124 + ] + }, + { + "teal": 90, + "source": "tests/contracts/abi.algo.ts:672", + "pc": [ + 125 + ] + }, + { + "teal": 93, + "source": "tests/contracts/abi.algo.ts:672", + "pc": [ + 126, + 127, + 128, + 129, + 130, + 131 + ] + }, + { + "teal": 94, + "source": "tests/contracts/abi.algo.ts:672", + "pc": [ + 132, + 133, + 134 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:672", + "pc": [ + 135, + 136, + 137, + 138 + ] + }, + { + "teal": 98, + "source": "tests/contracts/abi.algo.ts:672", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 139 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] }, { + "teal": 101, + "source": "tests/contracts/abi.algo.ts:672", + "pc": [ + 140, + 141, + 142, + 143, + 144, + 145 + ] + }, + { + "teal": 102, + "source": "tests/contracts/abi.algo.ts:672", + "pc": [ + 146, + 147, + 148 + ] + }, + { + "teal": 103, + "source": "tests/contracts/abi.algo.ts:672", + "pc": [ + 149, + 150, + 151, + 152 + ] + }, + { + "teal": 106, + "source": "tests/contracts/abi.algo.ts:672", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 153 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] + }, + { + "teal": 109, + "source": "tests/contracts/abi.algo.ts:672", + "pc": [ + 154, + 155, + 156 + ] + }, + { + "teal": 110, + "source": "tests/contracts/abi.algo.ts:672", + "pc": [ + 157, + 158 + ] + }, + { + "teal": 111, + "source": "tests/contracts/abi.algo.ts:672", + "pc": [ + 159, + 160 + ] + }, + { + "teal": 112, + "source": "tests/contracts/abi.algo.ts:672", + "pc": [ + 161 + ] + }, + { + "teal": 113, + "source": "tests/contracts/abi.algo.ts:672", + "pc": [ + 162, + 163 + ] + }, + { + "teal": 114, + "source": "tests/contracts/abi.algo.ts:672", + "pc": [ + 164, + 165 + ] + }, + { + "teal": 115, + "source": "tests/contracts/abi.algo.ts:672", + "pc": [ + 166 + ] + }, + { + "teal": 118, + "source": "tests/contracts/abi.algo.ts:672", + "pc": [ + 167, + 168, + 169 + ] + }, + { + "teal": 119, + "source": "tests/contracts/abi.algo.ts:672", + "pc": [ + 170, + 171 + ] + }, + { + "teal": 120, + "source": "tests/contracts/abi.algo.ts:672", + "pc": [ + 172, + 173 + ] + }, + { + "teal": 121, + "source": "tests/contracts/abi.algo.ts:672", + "pc": [ + 174 + ] + }, + { + "teal": 122, + "source": "tests/contracts/abi.algo.ts:672", + "pc": [ + 175, + 176 + ] + }, + { + "teal": 123, + "source": "tests/contracts/abi.algo.ts:672", + "pc": [ + 177, + 178 + ] + }, + { + "teal": 124, + "source": "tests/contracts/abi.algo.ts:672", + "pc": [ + 179 + ] + }, + { + "teal": 125, + "source": "tests/contracts/abi.algo.ts:672", + "pc": [ + 180 + ] + }, + { + "teal": 126, + "source": "tests/contracts/abi.algo.ts:672", + "pc": [ + 181, + 182 + ] + }, + { + "teal": 127, + "source": "tests/contracts/abi.algo.ts:672", + "pc": [ + 183 + ] + }, + { + "teal": 128, + "source": "tests/contracts/abi.algo.ts:672", + "pc": [ + 184 + ] + }, + { + "teal": 129, + "source": "tests/contracts/abi.algo.ts:672", + "pc": [ + 185 + ] + }, + { + "teal": 130, + "source": "tests/contracts/abi.algo.ts:672", + "pc": [ + 186, + 187, + 188 + ] + }, + { + "teal": 131, + "source": "tests/contracts/abi.algo.ts:672", + "pc": [ + 189, + 190 + ] + }, + { + "teal": 132, + "source": "tests/contracts/abi.algo.ts:672", + "pc": [ + 191, + 192 + ] + }, + { + "teal": 133, + "source": "tests/contracts/abi.algo.ts:672", + "pc": [ + 193 + ] + }, + { + "teal": 134, + "source": "tests/contracts/abi.algo.ts:672", + "pc": [ + 194 + ] + }, + { + "teal": 135, + "source": "tests/contracts/abi.algo.ts:672", + "pc": [ + 195, + 196 + ] + }, + { + "teal": 136, + "source": "tests/contracts/abi.algo.ts:672", + "pc": [ + 197, + 198 + ] + }, + { + "teal": 137, + "source": "tests/contracts/abi.algo.ts:672", + "pc": [ + 199, + 200 + ] + }, + { + "teal": 138, + "source": "tests/contracts/abi.algo.ts:672", + "pc": [ + 201, + 202 + ] + }, + { + "teal": 139, + "source": "tests/contracts/abi.algo.ts:672", + "pc": [ + 203 + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestAccessDynamicArrayInMiddleOfTuple.arc56_draft.json b/tests/contracts/artifacts/ABITestAccessDynamicArrayInMiddleOfTuple.arc56_draft.json index 27c780a0f..96f4e2bfd 100644 --- a/tests/contracts/artifacts/ABITestAccessDynamicArrayInMiddleOfTuple.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestAccessDynamicArrayInMiddleOfTuple.arc56_draft.json @@ -64,22 +64,784 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:664", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:664", + "pc": [ + 1, + 2, + 3 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:664", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:664", + "pc": [ + 6 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:664", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:664", + "pc": [ + 9 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:664", + "pc": [ + 10, + 11 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:664", + "pc": [ + 12 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:664", + "pc": [ + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:664", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 39 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:665", + "pc": [ + 40, + 41, + 42, + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:665", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:665", + "pc": [ + 49 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:665", + "pc": [ + 50 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:665", + "pc": [ + 51 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:665", + "pc": [ + 52, + 53, + 54 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:665", + "pc": [ + 55 + ] + }, + { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:665", + "pc": [ + 56 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:665", + "pc": [ + 57 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:665", + "pc": [ + 58 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:665", + "pc": [ + 59, + 60 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:665", + "pc": [ + 61 + ] + }, + { + "teal": 46, + "source": "tests/contracts/abi.algo.ts:665", + "pc": [ + 62, + 63, + 64 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:665", + "pc": [ + 65, + 66 + ] }, { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:666", + "pc": [ + 67, + 68 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:666", + "pc": [ + 69, + 70 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:666", + "pc": [ + 71, + 72, + 73, + 74 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:666", + "pc": [ + 75, + 76, + 77, + 78 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:666", + "pc": [ + 79, + 80, + 81 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:666", + "pc": [ + 82, + 83, + 84, + 85, + 86 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:666", + "pc": [ + 87, + 88, + 89 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:666", + "pc": [ + 90, + 91, + 92, + 93 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:666", + "pc": [ + 94, + 95, + 96 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:666", + "pc": [ + 97 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:666", + "pc": [ + 98 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:666", + "pc": [ + 99, + 100 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:668", + "pc": [ + 101, + 102 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:668", + "pc": [ + 103, + 104 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:668", + "pc": [ + 105, + 106 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:668", + "pc": [ + 107, + 108 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:668", + "pc": [ + 109, + 110 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:668", + "pc": [ + 111, + 112 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:668", + "pc": [ + 113 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:668", + "pc": [ + 114 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:668", + "pc": [ + 115, + 116 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:668", + "pc": [ + 117 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:668", + "pc": [ + 118 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:668", + "pc": [ + 119, + 120 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:668", + "pc": [ + 121 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:668", + "pc": [ + 122, + 123 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:668", + "pc": [ + 124 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:668", + "pc": [ + 125 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:668", + "pc": [ + 126, + 127, + 128 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:665", + "pc": [ + 129, + 130 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:665", + "pc": [ + 131 + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:664", + "pc": [ + 132, + 133 + ] + }, + { + "teal": 92, + "source": "tests/contracts/abi.algo.ts:664", + "pc": [ + 134 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:664", + "pc": [ + 135, + 136, + 137, + 138, + 139, + 140 + ] + }, + { + "teal": 96, + "source": "tests/contracts/abi.algo.ts:664", + "pc": [ + 141, + 142, + 143 + ] + }, + { + "teal": 97, + "source": "tests/contracts/abi.algo.ts:664", + "pc": [ + 144, + 145, + 146, + 147 + ] + }, + { + "teal": 100, + "source": "tests/contracts/abi.algo.ts:664", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 148 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 103, + "source": "tests/contracts/abi.algo.ts:664", + "pc": [ + 149, + 150, + 151, + 152, + 153, + 154 + ] }, { + "teal": 104, + "source": "tests/contracts/abi.algo.ts:664", + "pc": [ + 155, + 156, + 157 + ] + }, + { + "teal": 105, + "source": "tests/contracts/abi.algo.ts:664", + "pc": [ + 158, + 159, + 160, + 161 + ] + }, + { + "teal": 108, + "source": "tests/contracts/abi.algo.ts:664", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 162 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] + }, + { + "teal": 111, + "source": "tests/contracts/abi.algo.ts:664", + "pc": [ + 163, + 164, + 165 + ] + }, + { + "teal": 112, + "source": "tests/contracts/abi.algo.ts:664", + "pc": [ + 166, + 167 + ] + }, + { + "teal": 113, + "source": "tests/contracts/abi.algo.ts:664", + "pc": [ + 168, + 169 + ] + }, + { + "teal": 114, + "source": "tests/contracts/abi.algo.ts:664", + "pc": [ + 170 + ] + }, + { + "teal": 115, + "source": "tests/contracts/abi.algo.ts:664", + "pc": [ + 171, + 172 + ] + }, + { + "teal": 116, + "source": "tests/contracts/abi.algo.ts:664", + "pc": [ + 173, + 174 + ] + }, + { + "teal": 117, + "source": "tests/contracts/abi.algo.ts:664", + "pc": [ + 175 + ] + }, + { + "teal": 120, + "source": "tests/contracts/abi.algo.ts:664", + "pc": [ + 176, + 177, + 178 + ] + }, + { + "teal": 121, + "source": "tests/contracts/abi.algo.ts:664", + "pc": [ + 179, + 180 + ] + }, + { + "teal": 122, + "source": "tests/contracts/abi.algo.ts:664", + "pc": [ + 181, + 182 + ] + }, + { + "teal": 123, + "source": "tests/contracts/abi.algo.ts:664", + "pc": [ + 183 + ] + }, + { + "teal": 124, + "source": "tests/contracts/abi.algo.ts:664", + "pc": [ + 184, + 185 + ] + }, + { + "teal": 125, + "source": "tests/contracts/abi.algo.ts:664", + "pc": [ + 186, + 187 + ] + }, + { + "teal": 126, + "source": "tests/contracts/abi.algo.ts:664", + "pc": [ + 188 + ] + }, + { + "teal": 127, + "source": "tests/contracts/abi.algo.ts:664", + "pc": [ + 189 + ] + }, + { + "teal": 128, + "source": "tests/contracts/abi.algo.ts:664", + "pc": [ + 190, + 191 + ] + }, + { + "teal": 129, + "source": "tests/contracts/abi.algo.ts:664", + "pc": [ + 192 + ] + }, + { + "teal": 130, + "source": "tests/contracts/abi.algo.ts:664", + "pc": [ + 193 + ] + }, + { + "teal": 131, + "source": "tests/contracts/abi.algo.ts:664", + "pc": [ + 194 + ] + }, + { + "teal": 132, + "source": "tests/contracts/abi.algo.ts:664", + "pc": [ + 195, + 196, + 197 + ] + }, + { + "teal": 133, + "source": "tests/contracts/abi.algo.ts:664", + "pc": [ + 198, + 199 + ] + }, + { + "teal": 134, + "source": "tests/contracts/abi.algo.ts:664", + "pc": [ + 200, + 201 + ] + }, + { + "teal": 135, + "source": "tests/contracts/abi.algo.ts:664", + "pc": [ + 202 + ] + }, + { + "teal": 136, + "source": "tests/contracts/abi.algo.ts:664", + "pc": [ + 203 + ] + }, + { + "teal": 137, + "source": "tests/contracts/abi.algo.ts:664", + "pc": [ + 204, + 205 + ] + }, + { + "teal": 138, + "source": "tests/contracts/abi.algo.ts:664", + "pc": [ + 206, + 207 + ] + }, + { + "teal": 139, + "source": "tests/contracts/abi.algo.ts:664", + "pc": [ + 208, + 209 + ] + }, + { + "teal": 140, + "source": "tests/contracts/abi.algo.ts:664", + "pc": [ + 210, + 211 + ] + }, + { + "teal": 141, + "source": "tests/contracts/abi.algo.ts:664", + "pc": [ + 212 + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestAccessDynamicStringArray.arc56_draft.json b/tests/contracts/artifacts/ABITestAccessDynamicStringArray.arc56_draft.json index b052ec6df..db2c541a0 100644 --- a/tests/contracts/artifacts/ABITestAccessDynamicStringArray.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestAccessDynamicStringArray.arc56_draft.json @@ -64,22 +64,778 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:708", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:708", + "pc": [ + 1, + 2, + 3 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:708", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:708", + "pc": [ + 6 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:708", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:708", + "pc": [ + 9 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:708", + "pc": [ + 10, + 11 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:708", + "pc": [ + 12 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:708", + "pc": [ + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:708", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 39 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:709", + "pc": [ + 40, + 41, + 42, + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:709", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:709", + "pc": [ + 49 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:709", + "pc": [ + 50 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:709", + "pc": [ + 51 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:709", + "pc": [ + 52, + 53, + 54 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:709", + "pc": [ + 55 + ] + }, + { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:709", + "pc": [ + 56 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:709", + "pc": [ + 57 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:709", + "pc": [ + 58 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:709", + "pc": [ + 59, + 60 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:709", + "pc": [ + 61 + ] + }, + { + "teal": 46, + "source": "tests/contracts/abi.algo.ts:709", + "pc": [ + 62, + 63, + 64 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:709", + "pc": [ + 65, + 66 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:710", + "pc": [ + 67, + 68 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:710", + "pc": [ + 69, + 70 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:710", + "pc": [ + 71, + 72, + 73, + 74 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:710", + "pc": [ + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82, + 83 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:710", + "pc": [ + 84, + 85, + 86 + ] }, { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:710", + "pc": [ + 87, + 88, + 89, + 90, + 91, + 92, + 93, + 94, + 95 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:710", + "pc": [ + 96, + 97, + 98 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:710", + "pc": [ + 99, + 100, + 101, + 102, + 103 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:710", + "pc": [ + 104, + 105, + 106 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:710", + "pc": [ + 107 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:710", + "pc": [ + 108 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:710", + "pc": [ + 109, + 110, + 111, + 112 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:710", + "pc": [ + 113 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:710", + "pc": [ + 114 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:710", + "pc": [ + 115, + 116 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:712", + "pc": [ + 117, + 118 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:712", + "pc": [ + 119, + 120 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:712", + "pc": [ + 121, + 122 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:712", + "pc": [ + 123, + 124 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:712", + "pc": [ + 125, + 126 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:712", + "pc": [ + 127, + 128 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:712", + "pc": [ + 129 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:712", + "pc": [ + 130, + 131 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:712", + "pc": [ + 132 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:712", + "pc": [ + 133 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:712", + "pc": [ + 134, + 135 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:712", + "pc": [ + 136 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:712", + "pc": [ + 137 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:712", + "pc": [ + 138, + 139 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:712", + "pc": [ + 140 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:712", + "pc": [ + 141, + 142 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:712", + "pc": [ + 143 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:712", + "pc": [ + 144 + ] + }, + { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:712", + "pc": [ + 145, + 146, + 147 + ] + }, + { + "teal": 92, + "source": "tests/contracts/abi.algo.ts:709", + "pc": [ + 148, + 149 + ] + }, + { + "teal": 93, + "source": "tests/contracts/abi.algo.ts:709", + "pc": [ + 150 + ] + }, + { + "teal": 96, + "source": "tests/contracts/abi.algo.ts:708", + "pc": [ + 151, + 152 + ] + }, + { + "teal": 97, + "source": "tests/contracts/abi.algo.ts:708", + "pc": [ + 153 + ] + }, + { + "teal": 100, + "source": "tests/contracts/abi.algo.ts:708", + "pc": [ + 154, + 155, + 156, + 157, + 158, + 159 + ] + }, + { + "teal": 101, + "source": "tests/contracts/abi.algo.ts:708", + "pc": [ + 160, + 161, + 162 + ] + }, + { + "teal": 102, + "source": "tests/contracts/abi.algo.ts:708", + "pc": [ + 163, + 164, + 165, + 166 + ] + }, + { + "teal": 105, + "source": "tests/contracts/abi.algo.ts:708", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 167 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 108, + "source": "tests/contracts/abi.algo.ts:708", + "pc": [ + 168, + 169, + 170, + 171, + 172, + 173 + ] + }, + { + "teal": 109, + "source": "tests/contracts/abi.algo.ts:708", + "pc": [ + 174, + 175, + 176 + ] + }, + { + "teal": 110, + "source": "tests/contracts/abi.algo.ts:708", + "pc": [ + 177, + 178, + 179, + 180 + ] }, { + "teal": 113, + "source": "tests/contracts/abi.algo.ts:708", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 181 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] + }, + { + "teal": 116, + "source": "tests/contracts/abi.algo.ts:708", + "pc": [ + 182, + 183, + 184 + ] + }, + { + "teal": 117, + "source": "tests/contracts/abi.algo.ts:708", + "pc": [ + 185, + 186 + ] + }, + { + "teal": 118, + "source": "tests/contracts/abi.algo.ts:708", + "pc": [ + 187, + 188 + ] + }, + { + "teal": 119, + "source": "tests/contracts/abi.algo.ts:708", + "pc": [ + 189 + ] + }, + { + "teal": 120, + "source": "tests/contracts/abi.algo.ts:708", + "pc": [ + 190, + 191 + ] + }, + { + "teal": 121, + "source": "tests/contracts/abi.algo.ts:708", + "pc": [ + 192, + 193 + ] + }, + { + "teal": 122, + "source": "tests/contracts/abi.algo.ts:708", + "pc": [ + 194 + ] + }, + { + "teal": 123, + "source": "tests/contracts/abi.algo.ts:708", + "pc": [ + 195 + ] + }, + { + "teal": 124, + "source": "tests/contracts/abi.algo.ts:708", + "pc": [ + 196, + 197 + ] + }, + { + "teal": 125, + "source": "tests/contracts/abi.algo.ts:708", + "pc": [ + 198 + ] + }, + { + "teal": 126, + "source": "tests/contracts/abi.algo.ts:708", + "pc": [ + 199 + ] + }, + { + "teal": 127, + "source": "tests/contracts/abi.algo.ts:708", + "pc": [ + 200 + ] + }, + { + "teal": 128, + "source": "tests/contracts/abi.algo.ts:708", + "pc": [ + 201, + 202, + 203 + ] + }, + { + "teal": 129, + "source": "tests/contracts/abi.algo.ts:708", + "pc": [ + 204, + 205 + ] + }, + { + "teal": 130, + "source": "tests/contracts/abi.algo.ts:708", + "pc": [ + 206, + 207 + ] + }, + { + "teal": 131, + "source": "tests/contracts/abi.algo.ts:708", + "pc": [ + 208 + ] + }, + { + "teal": 132, + "source": "tests/contracts/abi.algo.ts:708", + "pc": [ + 209 + ] + }, + { + "teal": 133, + "source": "tests/contracts/abi.algo.ts:708", + "pc": [ + 210, + 211 + ] + }, + { + "teal": 134, + "source": "tests/contracts/abi.algo.ts:708", + "pc": [ + 212, + 213 + ] + }, + { + "teal": 135, + "source": "tests/contracts/abi.algo.ts:708", + "pc": [ + 214, + 215 + ] + }, + { + "teal": 136, + "source": "tests/contracts/abi.algo.ts:708", + "pc": [ + 216, + 217 + ] + }, + { + "teal": 137, + "source": "tests/contracts/abi.algo.ts:708", + "pc": [ + 218 + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestAccessStaticArrayInBoxInVariable.arc56_draft.json b/tests/contracts/artifacts/ABITestAccessStaticArrayInBoxInVariable.arc56_draft.json index 51a92d374..804eddbc3 100644 --- a/tests/contracts/artifacts/ABITestAccessStaticArrayInBoxInVariable.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestAccessStaticArrayInBoxInVariable.arc56_draft.json @@ -70,22 +70,406 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1511", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:1511", + "pc": [ + 1, + 2, + 3, + 4, + 5, + 6, + 7, + 8, + 9, + 10 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1511", + "pc": [ + 11, + 12 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1511", + "pc": [ + 13 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1511", + "pc": [ + 14, + 15 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1511", + "pc": [ + 16 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1511", + "pc": [ + 17, + 18 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1511", + "pc": [ + 19 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:1511", + "pc": [ + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38, + 39, + 40, + 41, + 42, + 43, + 44, + 45 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:1511", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 46 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:1514", + "pc": [ + 47, + 48, + 49, + 50, + 51, + 52 + ] }, { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1514", + "pc": [ + 53, + 54, + 55 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1514", + "pc": [ + 56 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1514", + "pc": [ + 57 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1514", + "pc": [ + 58 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:1514", + "pc": [ + 59, + 60 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:1514", + "pc": [ + 61 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:1514", + "pc": [ + 62, + 63, + 64 + ] + }, + { + "teal": 45, + "source": "tests/contracts/abi.algo.ts:1516", + "pc": [ + 65, + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73 + ] + }, + { + "teal": 46, + "source": "tests/contracts/abi.algo.ts:1516", + "pc": [ + 74, + 75 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:1516", + "pc": [ + 76 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:1516", + "pc": [ + 77 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:1517", + "pc": [ + 78, + 79, + 80, + 81, + 82, + 83, + 84, + 85, + 86 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:1517", + "pc": [ + 87, + 88 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:1517", + "pc": [ + 89, + 90, + 91, + 92, + 93, + 94, + 95, + 96, + 97, + 98 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:1517", + "pc": [ + 99 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:1517", + "pc": [ + 100, + 101, + 102, + 103, + 104, + 105, + 106, + 107, + 108 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:1517", + "pc": [ + 109, + 110 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:1517", + "pc": [ + 111, + 112 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:1517", + "pc": [ + 113 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:1521", + "pc": [ + 114 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:1514", + "pc": [ + 115 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:1511", + "pc": [ + 116, + 117 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:1511", + "pc": [ + 118 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:1511", + "pc": [ + 119, + 120, + 121, + 122, + 123, + 124 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:1511", + "pc": [ + 125, + 126, + 127 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:1511", + "pc": [ + 128, + 129, + 130, + 131 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:1511", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 132 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:1511", + "pc": [ + 133, + 134, + 135, + 136, + 137, + 138 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:1511", + "pc": [ + 139, + 140, + 141 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:1511", + "pc": [ + 142, + 143, + 144, + 145 + ] }, { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:1511", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 146 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestAngularCasting.arc56_draft.json b/tests/contracts/artifacts/ABITestAngularCasting.arc56_draft.json index 2d85da556..0ea63686f 100644 --- a/tests/contracts/artifacts/ABITestAngularCasting.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestAngularCasting.arc56_draft.json @@ -64,28 +64,462 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1031", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:1031", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1031", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1031", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1031", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1031", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1031", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1031", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:1031", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] }, { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:1032", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:1032", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1032", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1032", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1032", + "pc": [ + 48, + 49, + 50 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1032", + "pc": [ + 51 + ] + }, + { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:1032", + "errorMessage": "angularCasting return value overflowed 256 bits", "pc": [ 52 - ], - "errorMessage": "angularCasting return value overflowed 256 bits" + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:1032", + "pc": [ + 53, + 54, + 55, + 56, + 57, + 58, + 59, + 60, + 61, + 62, + 63, + 64, + 65, + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82, + 83, + 84, + 85, + 86 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:1032", + "pc": [ + 87 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:1032", + "pc": [ + 88 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:1032", + "pc": [ + 89 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:1032", + "pc": [ + 90 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:1032", + "pc": [ + 91, + 92 + ] + }, + { + "teal": 45, + "source": "tests/contracts/abi.algo.ts:1032", + "pc": [ + 93 + ] }, { + "teal": 46, + "source": "tests/contracts/abi.algo.ts:1032", + "pc": [ + 94 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:1032", + "pc": [ + 95 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:1032", + "pc": [ + 96 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:1032", + "pc": [ + 97 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:1032", + "pc": [ + 98, + 99 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:1032", + "pc": [ + 100 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:1032", + "pc": [ + 101, + 102, + 103 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:1032", + "pc": [ + 104, + 105 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:1033", + "pc": [ + 106, + 107, + 108, + 109, + 110, + 111, + 112, + 113, + 114, + 115, + 116, + 117, + 118, + 119, + 120, + 121, + 122, + 123, + 124, + 125, + 126, + 127, + 128, + 129, + 130, + 131, + 132, + 133, + 134, + 135, + 136, + 137, + 138, + 139 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:1033", + "pc": [ + 140, + 141 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:1035", + "pc": [ + 142, + 143 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:1032", + "pc": [ + 144, + 145 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:1032", + "pc": [ + 146 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:1031", + "pc": [ + 147, + 148 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:1031", + "pc": [ + 149 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:1031", + "pc": [ + 150, + 151, + 152, + 153, + 154, + 155 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:1031", + "pc": [ + 156, + 157, + 158 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:1031", + "pc": [ + 159, + 160, + 161, + 162 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:1031", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 163 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:1031", + "pc": [ + 164, + 165, + 166, + 167, + 168, + 169 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:1031", + "pc": [ + 170, + 171, + 172 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:1031", + "pc": [ + 173, + 174, + 175, + 176 + ] }, { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:1031", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 177 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestArrayInMethodCall.arc56_draft.json b/tests/contracts/artifacts/ABITestArrayInMethodCall.arc56_draft.json index ac254e114..ea4c3f227 100644 --- a/tests/contracts/artifacts/ABITestArrayInMethodCall.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestArrayInMethodCall.arc56_draft.json @@ -64,22 +64,431 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1391", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:1391", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1391", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1391", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1391", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1391", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1391", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1391", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:1391", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:1392", + "pc": [ + 37, + 38, + 39 + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:1392", + "pc": [ + 40, + 41 + ] + }, + { + "teal": 30, + "source": "tests/contracts/abi.algo.ts:1392", + "pc": [ + 42 + ] }, { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1392", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:1393", + "pc": [ + 46 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:1393", + "pc": [ + 47, + 48 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:1393", + "pc": [ + 49, + 50 + ] + }, + { + "teal": 45, + "source": "tests/contracts/abi.algo.ts:1395", + "pc": [ + 51, + 52, + 53, + 54, + 55, + 56 + ] + }, + { + "teal": 46, + "source": "tests/contracts/abi.algo.ts:1395", + "pc": [ + 57, + 58 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:1394", + "pc": [ + 59, + 60 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:1394", + "pc": [ + 61, + 62 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:1396", + "pc": [ + 63, + 64, + 65, + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79, + 80 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:1396", + "pc": [ + 81, + 82 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:1396", + "pc": [ + 83, + 84 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:1396", + "pc": [ + 85, + 86 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:1396", + "pc": [ + 87, + 88, + 89, + 90, + 91, + 92, + 93, + 94, + 95, + 96 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:1396", + "pc": [ + 97, + 98 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:1396", + "pc": [ + 99, + 100 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:1396", + "pc": [ + 101, + 102, + 103 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:1396", + "pc": [ + 104, + 105 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:1396", + "pc": [ + 106, + 107 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:1396", + "pc": [ + 108 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:1396", + "pc": [ + 109, + 110 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:1393", + "pc": [ + 111, + 112 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:1393", + "pc": [ + 113, + 114 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:1393", + "pc": [ + 115 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:1392", + "pc": [ + 116 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:1391", + "pc": [ + 117, + 118 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:1391", + "pc": [ + 119 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:1391", + "pc": [ + 120, + 121, + 122, + 123, + 124, + 125 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:1391", + "pc": [ + 126, + 127, + 128 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:1391", + "pc": [ + 129, + 130, + 131, + 132 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:1391", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 133 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:1391", + "pc": [ + 134, + 135, + 136, + 137, + 138, + 139 + ] + }, + { + "teal": 90, + "source": "tests/contracts/abi.algo.ts:1391", + "pc": [ + 140, + 141, + 142 + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:1391", + "pc": [ + 143, + 144, + 145, + 146 + ] }, { + "teal": 94, + "source": "tests/contracts/abi.algo.ts:1391", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 147 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestArrayInObjectInState.arc56_draft.json b/tests/contracts/artifacts/ABITestArrayInObjectInState.arc56_draft.json index 5bb01b4db..8b5712cdf 100644 --- a/tests/contracts/artifacts/ABITestArrayInObjectInState.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestArrayInObjectInState.arc56_draft.json @@ -76,22 +76,393 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1074", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:1074", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1074", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1074", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1074", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1074", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1074", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1074", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:1074", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:1077", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:1077", + "pc": [ + 43, + 44, + 45 + ] }, { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1077", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1077", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1077", + "pc": [ + 48 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1077", + "pc": [ + 49, + 50 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:1077", + "pc": [ + 51 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:1077", + "pc": [ + 52, + 53, + 54 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:1078", + "pc": [ + 55, + 56 + ] + }, + { + "teal": 45, + "source": "tests/contracts/abi.algo.ts:1078", + "pc": [ + 57, + 58, + 59, + 60, + 61, + 62, + 63, + 64, + 65, + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74 + ] + }, + { + "teal": 46, + "source": "tests/contracts/abi.algo.ts:1078", + "pc": [ + 75 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:1079", + "pc": [ + 76, + 77 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:1079", + "pc": [ + 78 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:1079", + "pc": [ + 79, + 80, + 81, + 82, + 83, + 84, + 85, + 86, + 87, + 88 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:1079", + "pc": [ + 89, + 90 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:1079", + "pc": [ + 91, + 92 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:1079", + "pc": [ + 93 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:1079", + "pc": [ + 94 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:1080", + "pc": [ + 95, + 96 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:1080", + "pc": [ + 97 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:1080", + "pc": [ + 98, + 99, + 100 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:1080", + "pc": [ + 101 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:1077", + "pc": [ + 102 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:1074", + "pc": [ + 103, + 104 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:1074", + "pc": [ + 105 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:1074", + "pc": [ + 106, + 107, + 108, + 109, + 110, + 111 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:1074", + "pc": [ + 112, + 113, + 114 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:1074", + "pc": [ + 115, + 116, + 117, + 118 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:1074", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 119 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:1074", + "pc": [ + 120, + 121, + 122, + 123, + 124, + 125 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:1074", + "pc": [ + 126, + 127, + 128 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:1074", + "pc": [ + 129, + 130, + 131, + 132 + ] }, { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:1074", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 133 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestArrayInTuple.arc56_draft.json b/tests/contracts/artifacts/ABITestArrayInTuple.arc56_draft.json index ba30bb3bd..ece329858 100644 --- a/tests/contracts/artifacts/ABITestArrayInTuple.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestArrayInTuple.arc56_draft.json @@ -64,22 +64,346 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:263", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:263", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:263", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:263", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:263", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:263", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:263", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:263", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:263", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:264", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:264", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:264", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:264", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:264", + "pc": [ + 48 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:264", + "pc": [ + 49, + 50 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:264", + "pc": [ + 51 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:264", + "pc": [ + 52, + 53, + 54 + ] }, { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:264", + "pc": [ + 55, + 56 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:265", + "pc": [ + 57, + 58, + 59, + 60, + 61, + 62, + 63, + 64, + 65, + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82, + 83, + 84, + 85, + 86 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:265", + "pc": [ + 87, + 88 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:267", + "pc": [ + 89, + 90 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:267", + "pc": [ + 91, + 92, + 93 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:267", + "pc": [ + 94 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:264", + "pc": [ + 95, + 96 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:264", + "pc": [ + 97 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:263", + "pc": [ + 98, + 99 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:263", + "pc": [ + 100 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:263", + "pc": [ + 101, + 102, + 103, + 104, + 105, + 106 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:263", + "pc": [ + 107, + 108, + 109 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:263", + "pc": [ + 110, + 111, + 112, + 113 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:263", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 114 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:263", + "pc": [ + 115, + 116, + 117, + 118, + 119, + 120 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:263", + "pc": [ + 121, + 122, + 123 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:263", + "pc": [ + 124, + 125, + 126, + 127 + ] }, { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:263", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 128 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestArrayLength.arc56_draft.json b/tests/contracts/artifacts/ABITestArrayLength.arc56_draft.json index 6ebe585f2..25f82c483 100644 --- a/tests/contracts/artifacts/ABITestArrayLength.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestArrayLength.arc56_draft.json @@ -64,22 +64,329 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:733", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:733", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:733", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:733", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:733", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:733", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:733", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:733", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:733", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:734", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] }, { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:734", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:734", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:734", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:734", + "pc": [ + 48 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:734", + "pc": [ + 49, + 50 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:734", + "pc": [ + 51 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:734", + "pc": [ + 52, + 53, + 54 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:734", + "pc": [ + 55, + 56 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:735", + "pc": [ + 57, + 58, + 59, + 60, + 61, + 62, + 63 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:735", + "pc": [ + 64, + 65 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:737", + "pc": [ + 66, + 67 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:737", + "pc": [ + 68 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:737", + "pc": [ + 69, + 70 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:737", + "pc": [ + 71 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:734", + "pc": [ + 72, + 73 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:734", + "pc": [ + 74 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:733", + "pc": [ + 75, + 76 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:733", + "pc": [ + 77 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:733", + "pc": [ + 78, + 79, + 80, + 81, + 82, + 83 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:733", + "pc": [ + 84, + 85, + 86 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:733", + "pc": [ + 87, + 88, + 89, + 90 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:733", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 91 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:733", + "pc": [ + 92, + 93, + 94, + 95, + 96, + 97 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:733", + "pc": [ + 98, + 99, + 100 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:733", + "pc": [ + 101, + 102, + 103, + 104 + ] }, { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:733", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 105 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestArrayPop.arc56_draft.json b/tests/contracts/artifacts/ABITestArrayPop.arc56_draft.json index 0ffc208ee..bb916be3b 100644 --- a/tests/contracts/artifacts/ABITestArrayPop.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestArrayPop.arc56_draft.json @@ -64,22 +64,427 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:437", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:437", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:437", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:437", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:437", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:437", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:437", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:437", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:437", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:438", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:438", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:438", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:438", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:438", + "pc": [ + 48, + 49 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:438", + "pc": [ + 50 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:438", + "pc": [ + 51 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:438", + "pc": [ + 52, + 53, + 54 + ] + }, + { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:438", + "pc": [ + 55 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:438", + "pc": [ + 56 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:438", + "pc": [ + 57 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:438", + "pc": [ + 58 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:438", + "pc": [ + 59, + 60 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:438", + "pc": [ + 61 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:438", + "pc": [ + 62, + 63, + 64 + ] }, { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:438", + "pc": [ + 65, + 66 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:439", + "pc": [ + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:439", + "pc": [ + 75, + 76 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:441", + "pc": [ + 77, + 78 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:441", + "pc": [ + 79 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:441", + "pc": [ + 80 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:441", + "pc": [ + 81, + 82 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:441", + "pc": [ + 83 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:441", + "pc": [ + 84, + 85 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:441", + "pc": [ + 86 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:441", + "pc": [ + 87 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:441", + "pc": [ + 88, + 89 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:443", + "pc": [ + 90, + 91 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:438", + "pc": [ + 92, + 93 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:438", + "pc": [ + 94 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:437", + "pc": [ + 95, + 96 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:437", + "pc": [ + 97 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:437", + "pc": [ + 98, + 99, + 100, + 101, + 102, + 103 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:437", + "pc": [ + 104, + 105, + 106 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:437", + "pc": [ + 107, + 108, + 109, + 110 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:437", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 111 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 90, + "source": "tests/contracts/abi.algo.ts:437", + "pc": [ + 112, + 113, + 114, + 115, + 116, + 117 + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:437", + "pc": [ + 118, + 119, + 120 + ] + }, + { + "teal": 92, + "source": "tests/contracts/abi.algo.ts:437", + "pc": [ + 121, + 122, + 123, + 124 + ] }, { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:437", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 125 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestArrayPopValue.arc56_draft.json b/tests/contracts/artifacts/ABITestArrayPopValue.arc56_draft.json index 1fda3b117..994a2066f 100644 --- a/tests/contracts/artifacts/ABITestArrayPopValue.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestArrayPopValue.arc56_draft.json @@ -64,28 +64,512 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:447", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:447", + "pc": [ + 1, + 2, + 3 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:447", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:447", + "pc": [ + 6 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:447", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:447", + "pc": [ + 9 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:447", + "pc": [ + 10, + 11 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:447", + "pc": [ + 12 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:447", + "pc": [ + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:447", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 39 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:448", + "pc": [ + 40, + 41, + 42, + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:448", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:448", + "pc": [ + 49 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:448", + "pc": [ + 50 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:448", + "pc": [ + 51 + ] }, { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:448", + "pc": [ + 52, + 53 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:448", + "pc": [ + 54 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:448", + "errorMessage": "arrayPopValue return value overflowed 16 bits", "pc": [ 55 - ], - "errorMessage": "arrayPopValue return value overflowed 16 bits" + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:448", + "pc": [ + 56, + 57, + 58 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:448", + "pc": [ + 59 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:448", + "pc": [ + 60 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:448", + "pc": [ + 61, + 62 + ] + }, + { + "teal": 45, + "source": "tests/contracts/abi.algo.ts:448", + "pc": [ + 63 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:448", + "pc": [ + 64, + 65, + 66 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:448", + "pc": [ + 67, + 68 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:448", + "pc": [ + 69 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:449", + "pc": [ + 70, + 71, + 72, + 73, + 74, + 75, + 76, + 77 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:449", + "pc": [ + 78, + 79 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:451", + "pc": [ + 80, + 81 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:451", + "pc": [ + 82 + ] }, { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:451", + "pc": [ + 83 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:451", + "pc": [ + 84, + 85 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:451", + "pc": [ + 86 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:451", + "pc": [ + 87, + 88 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:451", + "pc": [ + 89 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:451", + "pc": [ + 90 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:451", + "pc": [ + 91 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:451", + "pc": [ + 92 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:451", + "pc": [ + 93, + 94 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:451", + "pc": [ + 95, + 96 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:451", + "pc": [ + 97, + 98 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:451", + "pc": [ + 99 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:451", + "pc": [ + 100 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:451", + "pc": [ + 101, + 102 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:451", + "pc": [ + 103 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:451", + "pc": [ + 104, + 105 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:453", + "pc": [ + 106, + 107 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:448", + "pc": [ + 108, + 109 + ] + }, + { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:448", + "pc": [ + 110, + 111 + ] + }, + { + "teal": 90, + "source": "tests/contracts/abi.algo.ts:448", + "pc": [ + 112 + ] + }, + { + "teal": 93, + "source": "tests/contracts/abi.algo.ts:447", + "pc": [ + 113, + 114 + ] + }, + { + "teal": 94, + "source": "tests/contracts/abi.algo.ts:447", + "pc": [ + 115 + ] + }, + { + "teal": 97, + "source": "tests/contracts/abi.algo.ts:447", + "pc": [ + 116, + 117, + 118, + 119, + 120, + 121 + ] + }, + { + "teal": 98, + "source": "tests/contracts/abi.algo.ts:447", + "pc": [ + 122, + 123, + 124 + ] + }, + { + "teal": 99, + "source": "tests/contracts/abi.algo.ts:447", + "pc": [ + 125, + 126, + 127, + 128 + ] + }, + { + "teal": 102, + "source": "tests/contracts/abi.algo.ts:447", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 129 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 105, + "source": "tests/contracts/abi.algo.ts:447", + "pc": [ + 130, + 131, + 132, + 133, + 134, + 135 + ] + }, + { + "teal": 106, + "source": "tests/contracts/abi.algo.ts:447", + "pc": [ + 136, + 137, + 138 + ] + }, + { + "teal": 107, + "source": "tests/contracts/abi.algo.ts:447", + "pc": [ + 139, + 140, + 141, + 142 + ] }, { + "teal": 110, + "source": "tests/contracts/abi.algo.ts:447", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 143 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestArrayPush.arc56_draft.json b/tests/contracts/artifacts/ABITestArrayPush.arc56_draft.json index aaa71dad1..cd3250694 100644 --- a/tests/contracts/artifacts/ABITestArrayPush.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestArrayPush.arc56_draft.json @@ -64,22 +64,391 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:427", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:427", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:427", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:427", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:427", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:427", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:427", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:427", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:427", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:428", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:428", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:428", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:428", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:428", + "pc": [ + 48, + 49 + ] }, { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:428", + "pc": [ + 50 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:428", + "pc": [ + 51 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:428", + "pc": [ + 52, + 53, + 54 + ] + }, + { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:428", + "pc": [ + 55 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:428", + "pc": [ + 56 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:428", + "pc": [ + 57 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:428", + "pc": [ + 58 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:428", + "pc": [ + 59, + 60 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:428", + "pc": [ + 61 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:428", + "pc": [ + 62, + 63, + 64 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:428", + "pc": [ + 65, + 66 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:429", + "pc": [ + 67, + 68, + 69, + 70, + 71, + 72 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:429", + "pc": [ + 73, + 74 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:431", + "pc": [ + 75, + 76 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:431", + "pc": [ + 77, + 78, + 79, + 80 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:431", + "pc": [ + 81 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:431", + "pc": [ + 82, + 83 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:433", + "pc": [ + 84, + 85 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:428", + "pc": [ + 86, + 87 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:428", + "pc": [ + 88 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:427", + "pc": [ + 89, + 90 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:427", + "pc": [ + 91 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:427", + "pc": [ + 92, + 93, + 94, + 95, + 96, + 97 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:427", + "pc": [ + 98, + 99, + 100 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:427", + "pc": [ + 101, + 102, + 103, + 104 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:427", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 105 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:427", + "pc": [ + 106, + 107, + 108, + 109, + 110, + 111 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:427", + "pc": [ + 112, + 113, + 114 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:427", + "pc": [ + 115, + 116, + 117, + 118 + ] }, { + "teal": 90, + "source": "tests/contracts/abi.algo.ts:427", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 119 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestArrayRef.arc56_draft.json b/tests/contracts/artifacts/ABITestArrayRef.arc56_draft.json index 8b8b99b31..b62194498 100644 --- a/tests/contracts/artifacts/ABITestArrayRef.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestArrayRef.arc56_draft.json @@ -64,22 +64,391 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:748", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:748", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:748", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:748", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:748", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:748", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:748", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:748", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:748", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:749", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:749", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:749", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:749", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:749", + "pc": [ + 48 + ] }, { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:749", + "pc": [ + 49, + 50, + 51 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:749", + "pc": [ + 52 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:749", + "pc": [ + 53 + ] + }, + { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:749", + "pc": [ + 54 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:749", + "pc": [ + 55 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:749", + "pc": [ + 56, + 57 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:749", + "pc": [ + 58 + ] + }, + { + "teal": 45, + "source": "tests/contracts/abi.algo.ts:749", + "pc": [ + 59, + 60, + 61 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:749", + "pc": [ + 62, + 63 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:750", + "pc": [ + 64, + 65, + 66, + 67, + 68 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:750", + "pc": [ + 69, + 70 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:753", + "pc": [ + 71, + 72 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:753", + "pc": [ + 73, + 74 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:753", + "pc": [ + 75, + 76 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:753", + "pc": [ + 77, + 78, + 79 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:753", + "pc": [ + 80, + 81 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:753", + "pc": [ + 82, + 83 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:755", + "pc": [ + 84, + 85 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:749", + "pc": [ + 86, + 87 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:749", + "pc": [ + 88 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:748", + "pc": [ + 89, + 90 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:748", + "pc": [ + 91 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:748", + "pc": [ + 92, + 93, + 94, + 95, + 96, + 97 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:748", + "pc": [ + 98, + 99, + 100 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:748", + "pc": [ + 101, + 102, + 103, + 104 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:748", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 105 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:748", + "pc": [ + 106, + 107, + 108, + 109, + 110, + 111 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:748", + "pc": [ + 112, + 113, + 114 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:748", + "pc": [ + 115, + 116, + 117, + 118 + ] }, { + "teal": 90, + "source": "tests/contracts/abi.algo.ts:748", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 119 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestArraySplice.arc56_draft.json b/tests/contracts/artifacts/ABITestArraySplice.arc56_draft.json index e1f081174..4d4196b53 100644 --- a/tests/contracts/artifacts/ABITestArraySplice.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestArraySplice.arc56_draft.json @@ -64,22 +64,546 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:457", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:457", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:457", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:457", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:457", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:457", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:457", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:457", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:457", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:458", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:458", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:458", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:458", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:458", + "pc": [ + 48, + 49 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:458", + "pc": [ + 50 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:458", + "pc": [ + 51 + ] }, { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:458", + "pc": [ + 52, + 53, + 54 + ] + }, + { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:458", + "pc": [ + 55 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:458", + "pc": [ + 56 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:458", + "pc": [ + 57 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:458", + "pc": [ + 58 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:458", + "pc": [ + 59, + 60 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:458", + "pc": [ + 61 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:458", + "pc": [ + 62, + 63, + 64 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:458", + "pc": [ + 65, + 66 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:459", + "pc": [ + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82, + 83, + 84, + 85, + 86, + 87, + 88, + 89, + 90, + 91, + 92 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:459", + "pc": [ + 93, + 94 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:461", + "pc": [ + 95, + 96 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:461", + "pc": [ + 97, + 98 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:461", + "pc": [ + 99, + 100 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:461", + "pc": [ + 101, + 102 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:461", + "pc": [ + 103, + 104 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:461", + "pc": [ + 105, + 106 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:461", + "pc": [ + 107, + 108 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:461", + "pc": [ + 109, + 110 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:461", + "pc": [ + 111, + 112 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:461", + "pc": [ + 113 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:461", + "pc": [ + 114, + 115 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:461", + "pc": [ + 116 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:461", + "pc": [ + 117 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:461", + "pc": [ + 118, + 119 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:461", + "pc": [ + 120, + 121 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:461", + "pc": [ + 122 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:461", + "pc": [ + 123, + 124 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:461", + "pc": [ + 125 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:461", + "pc": [ + 126 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:461", + "pc": [ + 127 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:461", + "pc": [ + 128 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:461", + "pc": [ + 129, + 130 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:463", + "pc": [ + 131, + 132 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:458", + "pc": [ + 133, + 134 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:458", + "pc": [ + 135 + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:457", + "pc": [ + 136, + 137 + ] + }, + { + "teal": 92, + "source": "tests/contracts/abi.algo.ts:457", + "pc": [ + 138 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:457", + "pc": [ + 139, + 140, + 141, + 142, + 143, + 144 + ] + }, + { + "teal": 96, + "source": "tests/contracts/abi.algo.ts:457", + "pc": [ + 145, + 146, + 147 + ] + }, + { + "teal": 97, + "source": "tests/contracts/abi.algo.ts:457", + "pc": [ + 148, + 149, + 150, + 151 + ] + }, + { + "teal": 100, + "source": "tests/contracts/abi.algo.ts:457", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 152 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 103, + "source": "tests/contracts/abi.algo.ts:457", + "pc": [ + 153, + 154, + 155, + 156, + 157, + 158 + ] + }, + { + "teal": 104, + "source": "tests/contracts/abi.algo.ts:457", + "pc": [ + 159, + 160, + 161 + ] + }, + { + "teal": 105, + "source": "tests/contracts/abi.algo.ts:457", + "pc": [ + 162, + 163, + 164, + 165 + ] }, { + "teal": 108, + "source": "tests/contracts/abi.algo.ts:457", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 166 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestArraySpliceValue.arc56_draft.json b/tests/contracts/artifacts/ABITestArraySpliceValue.arc56_draft.json index c95585628..3df553cba 100644 --- a/tests/contracts/artifacts/ABITestArraySpliceValue.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestArraySpliceValue.arc56_draft.json @@ -64,22 +64,660 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:467", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:467", + "pc": [ + 1, + 2, + 3 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:467", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:467", + "pc": [ + 6 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:467", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:467", + "pc": [ + 9 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:467", + "pc": [ + 10, + 11 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:467", + "pc": [ + 12 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:467", + "pc": [ + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:467", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 39 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:468", + "pc": [ + 40, + 41, + 42, + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:468", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:468", + "pc": [ + 49 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:468", + "pc": [ + 50 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:468", + "pc": [ + 51, + 52 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:468", + "pc": [ + 53 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:468", + "pc": [ + 54 + ] + }, + { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:468", + "pc": [ + 55, + 56, + 57 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:468", + "pc": [ + 58 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:468", + "pc": [ + 59 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:468", + "pc": [ + 60 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:468", + "pc": [ + 61 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:468", + "pc": [ + 62, + 63 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:468", + "pc": [ + 64 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:468", + "pc": [ + 65, + 66, + 67 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:468", + "pc": [ + 68, + 69 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:468", + "pc": [ + 70, + 71 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:469", + "pc": [ + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82, + 83, + 84, + 85, + 86, + 87, + 88, + 89, + 90, + 91, + 92, + 93 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:469", + "pc": [ + 94, + 95 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:471", + "pc": [ + 96, + 97 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:471", + "pc": [ + 98, + 99 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:472", + "pc": [ + 100, + 101 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:472", + "pc": [ + 102, + 103 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:473", + "pc": [ + 104, + 105 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:473", + "pc": [ + 106, + 107 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:473", + "pc": [ + 108, + 109 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:473", + "pc": [ + 110, + 111 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:473", + "pc": [ + 112, + 113 + ] }, { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:473", + "pc": [ + 114, + 115 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:473", + "pc": [ + 116, + 117 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:473", + "pc": [ + 118, + 119 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:473", + "pc": [ + 120, + 121 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:473", + "pc": [ + 122 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:473", + "pc": [ + 123, + 124 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:473", + "pc": [ + 125 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:473", + "pc": [ + 126 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:473", + "pc": [ + 127, + 128 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:473", + "pc": [ + 129, + 130 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:473", + "pc": [ + 131 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:473", + "pc": [ + 132, + 133 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:473", + "pc": [ + 134 + ] + }, + { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:473", + "pc": [ + 135 + ] + }, + { + "teal": 90, + "source": "tests/contracts/abi.algo.ts:473", + "pc": [ + 136 + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:473", + "pc": [ + 137 + ] + }, + { + "teal": 92, + "source": "tests/contracts/abi.algo.ts:473", + "pc": [ + 138, + 139 + ] + }, + { + "teal": 93, + "source": "tests/contracts/abi.algo.ts:473", + "pc": [ + 140, + 141 + ] + }, + { + "teal": 94, + "source": "tests/contracts/abi.algo.ts:473", + "pc": [ + 142, + 143 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:473", + "pc": [ + 144, + 145 + ] + }, + { + "teal": 96, + "source": "tests/contracts/abi.algo.ts:473", + "pc": [ + 146 + ] + }, + { + "teal": 97, + "source": "tests/contracts/abi.algo.ts:473", + "pc": [ + 147 + ] + }, + { + "teal": 98, + "source": "tests/contracts/abi.algo.ts:473", + "pc": [ + 148 + ] + }, + { + "teal": 99, + "source": "tests/contracts/abi.algo.ts:473", + "pc": [ + 149, + 150 + ] + }, + { + "teal": 100, + "source": "tests/contracts/abi.algo.ts:473", + "pc": [ + 151, + 152 + ] + }, + { + "teal": 104, + "source": "tests/contracts/abi.algo.ts:475", + "pc": [ + 153, + 154 + ] + }, + { + "teal": 107, + "source": "tests/contracts/abi.algo.ts:468", + "pc": [ + 155, + 156 + ] + }, + { + "teal": 110, + "source": "tests/contracts/abi.algo.ts:468", + "pc": [ + 157, + 158 + ] + }, + { + "teal": 111, + "source": "tests/contracts/abi.algo.ts:468", + "pc": [ + 159 + ] + }, + { + "teal": 114, + "source": "tests/contracts/abi.algo.ts:467", + "pc": [ + 160, + 161 + ] + }, + { + "teal": 115, + "source": "tests/contracts/abi.algo.ts:467", + "pc": [ + 162 + ] + }, + { + "teal": 118, + "source": "tests/contracts/abi.algo.ts:467", + "pc": [ + 163, + 164, + 165, + 166, + 167, + 168 + ] + }, + { + "teal": 119, + "source": "tests/contracts/abi.algo.ts:467", + "pc": [ + 169, + 170, + 171 + ] + }, + { + "teal": 120, + "source": "tests/contracts/abi.algo.ts:467", + "pc": [ + 172, + 173, + 174, + 175 + ] + }, + { + "teal": 123, + "source": "tests/contracts/abi.algo.ts:467", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 176 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 126, + "source": "tests/contracts/abi.algo.ts:467", + "pc": [ + 177, + 178, + 179, + 180, + 181, + 182 + ] + }, + { + "teal": 127, + "source": "tests/contracts/abi.algo.ts:467", + "pc": [ + 183, + 184, + 185 + ] + }, + { + "teal": 128, + "source": "tests/contracts/abi.algo.ts:467", + "pc": [ + 186, + 187, + 188, + 189 + ] }, { + "teal": 131, + "source": "tests/contracts/abi.algo.ts:467", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 190 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestBiggerByteCasting.arc56_draft.json b/tests/contracts/artifacts/ABITestBiggerByteCasting.arc56_draft.json index bcdc2b2e4..809a3dce2 100644 --- a/tests/contracts/artifacts/ABITestBiggerByteCasting.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestBiggerByteCasting.arc56_draft.json @@ -69,28 +69,326 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1205", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:1205", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1205", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1205", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1205", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1205", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1205", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1205", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:1205", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] }, { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:1206", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:1206", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1206", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1206", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1206", + "pc": [ + 48, + 49 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1206", + "pc": [ + 50 + ] + }, + { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:1206", + "errorMessage": "argument 0 (a) for biggerByteCasting must be a byte[2]", "pc": [ 51 - ], - "errorMessage": "argument 0 (a) for biggerByteCasting must be a byte[2]" + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:1206", + "pc": [ + 52, + 53, + 54 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:1206", + "pc": [ + 55 + ] }, { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:1206", + "pc": [ + 56 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:1206", + "pc": [ + 57, + 58 + ] + }, + { + "teal": 45, + "source": "tests/contracts/abi.algo.ts:1206", + "pc": [ + 59 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:1206", + "pc": [ + 60, + 61, + 62 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:1207", + "pc": [ + 63, + 64 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:1207", + "pc": [ + 65, + 66, + 67, + 68 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:1207", + "pc": [ + 69 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:1206", + "pc": [ + 70 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:1205", + "pc": [ + 71, + 72 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:1205", + "pc": [ + 73 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:1205", + "pc": [ + 74, + 75, + 76, + 77, + 78, + 79 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:1205", + "pc": [ + 80, + 81, + 82 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:1205", + "pc": [ + 83, + 84, + 85, + 86 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:1205", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 87 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:1205", + "pc": [ + 88, + 89, + 90, + 91, + 92, + 93 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:1205", + "pc": [ + 94, + 95, + 96 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:1205", + "pc": [ + 97, + 98, + 99, + 100 + ] }, { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:1205", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 101 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestBoolFirstInTuple.arc56_draft.json b/tests/contracts/artifacts/ABITestBoolFirstInTuple.arc56_draft.json index a02672a4b..bbc4b59fe 100644 --- a/tests/contracts/artifacts/ABITestBoolFirstInTuple.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestBoolFirstInTuple.arc56_draft.json @@ -64,22 +64,365 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1580", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:1580", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1580", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1580", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1580", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1580", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1580", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1580", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:1580", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:1581", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:1581", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1581", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1581", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1581", + "pc": [ + 48, + 49 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1581", + "pc": [ + 50 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:1581", + "pc": [ + 51, + 52, + 53 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:1581", + "pc": [ + 54, + 55 + ] + }, + { + "teal": 46, + "source": "tests/contracts/abi.algo.ts:1582", + "pc": [ + 56, + 57, + 58 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:1582", + "pc": [ + 59, + 60 + ] }, { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:1582", + "pc": [ + 61, + 62 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:1582", + "pc": [ + 63 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:1582", + "pc": [ + 64, + 65, + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:1582", + "pc": [ + 74 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:1582", + "pc": [ + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82, + 83, + 84 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:1582", + "pc": [ + 85 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:1582", + "pc": [ + 86, + 87 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:1584", + "pc": [ + 88, + 89 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:1581", + "pc": [ + 90, + 91 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:1581", + "pc": [ + 92 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:1580", + "pc": [ + 93, + 94 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:1580", + "pc": [ + 95 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:1580", + "pc": [ + 96, + 97, + 98, + 99, + 100, + 101 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:1580", + "pc": [ + 102, + 103, + 104 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:1580", + "pc": [ + 105, + 106, + 107, + 108 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:1580", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 109 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:1580", + "pc": [ + 110, + 111, + 112, + 113, + 114, + 115 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:1580", + "pc": [ + 116, + 117, + 118 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:1580", + "pc": [ + 119, + 120, + 121, + 122 + ] }, { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:1580", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 123 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestBoolInNestedTuple.arc56_draft.json b/tests/contracts/artifacts/ABITestBoolInNestedTuple.arc56_draft.json index a292ab55b..7a7658e1a 100644 --- a/tests/contracts/artifacts/ABITestBoolInNestedTuple.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestBoolInNestedTuple.arc56_draft.json @@ -64,22 +64,567 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1440", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:1440", + "pc": [ + 1, + 2, + 3, + 4 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1440", + "pc": [ + 5, + 6 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1440", + "pc": [ + 7 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1440", + "pc": [ + 8, + 9 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1440", + "pc": [ + 10 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1440", + "pc": [ + 11, + 12 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1440", + "pc": [ + 13 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:1440", + "pc": [ + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38, + 39 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:1440", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 40 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:1441", + "pc": [ + 41, + 42, + 43, + 44, + 45, + 46 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1441", + "pc": [ + 47, + 48, + 49 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1441", + "pc": [ + 50, + 51, + 52 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1441", + "pc": [ + 53, + 54 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1441", + "pc": [ + 55, + 56 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:1441", + "pc": [ + 57 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:1441", + "pc": [ + 58 + ] + }, + { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:1441", + "pc": [ + 59 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:1441", + "pc": [ + 60, + 61 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:1441", + "pc": [ + 62 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:1441", + "pc": [ + 63, + 64, + 65 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:1441", + "pc": [ + 66, + 67 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:1442", + "pc": [ + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82, + 83, + 84, + 85, + 86, + 87, + 88, + 89, + 90, + 91, + 92, + 93 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:1442", + "pc": [ + 94, + 95, + 96 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:1442", + "pc": [ + 97, + 98 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:1442", + "pc": [ + 99, + 100 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:1442", + "pc": [ + 101 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:1442", + "pc": [ + 102, + 103 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:1442", + "pc": [ + 104, + 105 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:1442", + "pc": [ + 106 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:1442", + "pc": [ + 107 + ] }, { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:1442", + "pc": [ + 108, + 109 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:1444", + "pc": [ + 110, + 111 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:1444", + "pc": [ + 112, + 113 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:1444", + "pc": [ + 114, + 115 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:1444", + "pc": [ + 116, + 117, + 118 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:1444", + "pc": [ + 119, + 120 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:1444", + "pc": [ + 121 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:1444", + "pc": [ + 122, + 123 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:1445", + "pc": [ + 124, + 125 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:1445", + "pc": [ + 126, + 127 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:1445", + "pc": [ + 128, + 129 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:1445", + "pc": [ + 130, + 131, + 132 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:1445", + "pc": [ + 133, + 134 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:1445", + "pc": [ + 135 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:1445", + "pc": [ + 136, + 137 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:1447", + "pc": [ + 138, + 139 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:1447", + "pc": [ + 140, + 141 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:1447", + "pc": [ + 142, + 143 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:1447", + "pc": [ + 144, + 145, + 146 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:1447", + "pc": [ + 147 + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:1441", + "pc": [ + 148, + 149 + ] + }, + { + "teal": 92, + "source": "tests/contracts/abi.algo.ts:1441", + "pc": [ + 150 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:1440", + "pc": [ + 151, + 152 + ] + }, + { + "teal": 96, + "source": "tests/contracts/abi.algo.ts:1440", + "pc": [ + 153 + ] + }, + { + "teal": 99, + "source": "tests/contracts/abi.algo.ts:1440", + "pc": [ + 154, + 155, + 156, + 157, + 158, + 159 + ] + }, + { + "teal": 100, + "source": "tests/contracts/abi.algo.ts:1440", + "pc": [ + 160, + 161, + 162 + ] + }, + { + "teal": 101, + "source": "tests/contracts/abi.algo.ts:1440", + "pc": [ + 163, + 164, + 165, + 166 + ] + }, + { + "teal": 104, + "source": "tests/contracts/abi.algo.ts:1440", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 167 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 107, + "source": "tests/contracts/abi.algo.ts:1440", + "pc": [ + 168, + 169, + 170, + 171, + 172, + 173 + ] + }, + { + "teal": 108, + "source": "tests/contracts/abi.algo.ts:1440", + "pc": [ + 174, + 175, + 176 + ] + }, + { + "teal": 109, + "source": "tests/contracts/abi.algo.ts:1440", + "pc": [ + 177, + 178, + 179, + 180 + ] }, { + "teal": 112, + "source": "tests/contracts/abi.algo.ts:1440", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 181 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestBoolInObj.arc56_draft.json b/tests/contracts/artifacts/ABITestBoolInObj.arc56_draft.json index 92f6017a5..119b88621 100644 --- a/tests/contracts/artifacts/ABITestBoolInObj.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestBoolInObj.arc56_draft.json @@ -64,40 +64,572 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1223", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:1223", + "pc": [ + 1, + 2, + 3 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1223", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1223", + "pc": [ + 6 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1223", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1223", + "pc": [ + 9 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1223", + "pc": [ + 10, + 11 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1223", + "pc": [ + 12 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:1223", + "pc": [ + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:1223", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 39 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:1224", + "pc": [ + 40, + 41, + 42 + ] + }, + { + "teal": 30, + "source": "tests/contracts/abi.algo.ts:1224", + "pc": [ + 43, + 44 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:1224", + "pc": [ + 45 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1224", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:1224", + "pc": [ + 49, + 50 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:1225", + "pc": [ + 51, + 52, + 53 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:1225", + "pc": [ + 54, + 55 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:1225", + "pc": [ + 56, + 57 + ] + }, + { + "teal": 45, + "source": "tests/contracts/abi.algo.ts:1225", + "pc": [ + 58 + ] + }, + { + "teal": 46, + "source": "tests/contracts/abi.algo.ts:1225", + "pc": [ + 59, + 60 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:1225", + "pc": [ + 61 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:1225", + "pc": [ + 62 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:1225", + "pc": [ + 63, + 64 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:1225", + "pc": [ + 65, + 66 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:1225", + "pc": [ + 67 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:1225", + "pc": [ + 68, + 69 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:1226", + "pc": [ + 70, + 71 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:1226", + "pc": [ + 72, + 73 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:1226", + "pc": [ + 74, + 75 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:1226", + "pc": [ + 76, + 77 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:1226", + "pc": [ + 78, + 79 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:1226", + "pc": [ + 80 + ] }, { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:1226", + "pc": [ + 81, + 82 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:1227", + "pc": [ + 83, + 84 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:1227", + "pc": [ + 85, + 86 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:1227", + "pc": [ + 87, + 88 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:1227", + "pc": [ + 89, + 90 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:1227", + "pc": [ + 91 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:1227", + "pc": [ + 92, + 93 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:1227", + "pc": [ + 94 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:1227", + "errorMessage": "asserts failed: asserts(x.foo === true, x.bar === false, x.baz === true)", "pc": [ 95 - ], - "errorMessage": "asserts failed: asserts(x.foo === true, x.bar === false, x.baz === true)" + ] }, { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:1227", + "pc": [ + 96, + 97 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:1227", + "pc": [ + 98, + 99 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:1227", + "pc": [ + 100, + 101 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:1227", + "pc": [ + 102, + 103 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:1227", + "pc": [ + 104 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:1227", + "pc": [ + 105, + 106 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:1227", + "pc": [ + 107 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:1227", + "errorMessage": "asserts failed: asserts(x.foo === true, x.bar === false, x.baz === true)", "pc": [ 108 - ], - "errorMessage": "asserts failed: asserts(x.foo === true, x.bar === false, x.baz === true)" + ] }, { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:1227", + "pc": [ + 109, + 110 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:1227", + "pc": [ + 111, + 112 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:1227", + "pc": [ + 113, + 114 + ] + }, + { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:1227", + "pc": [ + 115, + 116 + ] + }, + { + "teal": 90, + "source": "tests/contracts/abi.algo.ts:1227", + "pc": [ + 117 + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:1227", + "pc": [ + 118, + 119 + ] + }, + { + "teal": 92, + "source": "tests/contracts/abi.algo.ts:1227", + "pc": [ + 120 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:1227", + "errorMessage": "asserts failed: asserts(x.foo === true, x.bar === false, x.baz === true)", "pc": [ 121 - ], - "errorMessage": "asserts failed: asserts(x.foo === true, x.bar === false, x.baz === true)" + ] + }, + { + "teal": 96, + "source": "tests/contracts/abi.algo.ts:1224", + "pc": [ + 122 + ] + }, + { + "teal": 99, + "source": "tests/contracts/abi.algo.ts:1223", + "pc": [ + 123, + 124 + ] + }, + { + "teal": 100, + "source": "tests/contracts/abi.algo.ts:1223", + "pc": [ + 125 + ] + }, + { + "teal": 103, + "source": "tests/contracts/abi.algo.ts:1223", + "pc": [ + 126, + 127, + 128, + 129, + 130, + 131 + ] + }, + { + "teal": 104, + "source": "tests/contracts/abi.algo.ts:1223", + "pc": [ + 132, + 133, + 134 + ] }, { + "teal": 105, + "source": "tests/contracts/abi.algo.ts:1223", + "pc": [ + 135, + 136, + 137, + 138 + ] + }, + { + "teal": 108, + "source": "tests/contracts/abi.algo.ts:1223", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 139 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 111, + "source": "tests/contracts/abi.algo.ts:1223", + "pc": [ + 140, + 141, + 142, + 143, + 144, + 145 + ] + }, + { + "teal": 112, + "source": "tests/contracts/abi.algo.ts:1223", + "pc": [ + 146, + 147, + 148 + ] + }, + { + "teal": 113, + "source": "tests/contracts/abi.algo.ts:1223", + "pc": [ + 149, + 150, + 151, + 152 + ] }, { + "teal": 116, + "source": "tests/contracts/abi.algo.ts:1223", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 153 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestBoolTuple.arc56_draft.json b/tests/contracts/artifacts/ABITestBoolTuple.arc56_draft.json index cf0fc8282..2fc84ef71 100644 --- a/tests/contracts/artifacts/ABITestBoolTuple.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestBoolTuple.arc56_draft.json @@ -64,22 +64,504 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:877", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:877", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:877", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:877", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:877", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:877", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:877", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:877", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:877", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:878", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:878", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:878", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:878", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:878", + "pc": [ + 48, + 49 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:878", + "pc": [ + 50 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:878", + "pc": [ + 51, + 52, + 53 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:878", + "pc": [ + 54, + 55 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:880", + "pc": [ + 56, + 57, + 58, + 59 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:880", + "pc": [ + 60, + 61 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:880", + "pc": [ + 62, + 63 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:880", + "pc": [ + 64 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:881", + "pc": [ + 65, + 66 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:881", + "pc": [ + 67, + 68 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:881", + "pc": [ + 69 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:882", + "pc": [ + 70, + 71 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:882", + "pc": [ + 72, + 73 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:882", + "pc": [ + 74 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:883", + "pc": [ + 75, + 76 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:883", + "pc": [ + 77, + 78 + ] }, { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:883", + "pc": [ + 79 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:884", + "pc": [ + 80, + 81 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:884", + "pc": [ + 82, + 83 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:884", + "pc": [ + 84 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:885", + "pc": [ + 85, + 86 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:885", + "pc": [ + 87, + 88 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:885", + "pc": [ + 89 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:886", + "pc": [ + 90, + 91 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:886", + "pc": [ + 92, + 93 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:886", + "pc": [ + 94 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:887", + "pc": [ + 95, + 96 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:887", + "pc": [ + 97, + 98 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:887", + "pc": [ + 99 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:888", + "pc": [ + 100, + 101 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:888", + "pc": [ + 102, + 103 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:888", + "pc": [ + 104 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:879", + "pc": [ + 105, + 106 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:891", + "pc": [ + 107, + 108 + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:878", + "pc": [ + 109, + 110 + ] + }, + { + "teal": 92, + "source": "tests/contracts/abi.algo.ts:878", + "pc": [ + 111 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:877", + "pc": [ + 112, + 113 + ] + }, + { + "teal": 96, + "source": "tests/contracts/abi.algo.ts:877", + "pc": [ + 114 + ] + }, + { + "teal": 99, + "source": "tests/contracts/abi.algo.ts:877", + "pc": [ + 115, + 116, + 117, + 118, + 119, + 120 + ] + }, + { + "teal": 100, + "source": "tests/contracts/abi.algo.ts:877", + "pc": [ + 121, + 122, + 123 + ] + }, + { + "teal": 101, + "source": "tests/contracts/abi.algo.ts:877", + "pc": [ + 124, + 125, + 126, + 127 + ] + }, + { + "teal": 104, + "source": "tests/contracts/abi.algo.ts:877", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 128 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 107, + "source": "tests/contracts/abi.algo.ts:877", + "pc": [ + 129, + 130, + 131, + 132, + 133, + 134 + ] + }, + { + "teal": 108, + "source": "tests/contracts/abi.algo.ts:877", + "pc": [ + 135, + 136, + 137 + ] + }, + { + "teal": 109, + "source": "tests/contracts/abi.algo.ts:877", + "pc": [ + 138, + 139, + 140, + 141 + ] }, { + "teal": 112, + "source": "tests/contracts/abi.algo.ts:877", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 142 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestBoolTupleAccess.arc56_draft.json b/tests/contracts/artifacts/ABITestBoolTupleAccess.arc56_draft.json index 312573e55..4515fe055 100644 --- a/tests/contracts/artifacts/ABITestBoolTupleAccess.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestBoolTupleAccess.arc56_draft.json @@ -64,22 +64,575 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:903", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:903", + "pc": [ + 1, + 2, + 3 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:903", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:903", + "pc": [ + 6 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:903", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:903", + "pc": [ + 9 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:903", + "pc": [ + 10, + 11 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:903", + "pc": [ + 12 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:903", + "pc": [ + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:903", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 39 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:904", + "pc": [ + 40, + 41, + 42, + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:904", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:904", + "pc": [ + 49, + 50, + 51 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:904", + "pc": [ + 52, + 53 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:904", + "pc": [ + 54, + 55 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:904", + "pc": [ + 56 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:904", + "pc": [ + 57 + ] + }, + { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:904", + "pc": [ + 58 + ] }, { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:904", + "pc": [ + 59, + 60 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:904", + "pc": [ + 61 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:904", + "pc": [ + 62, + 63, + 64 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:904", + "pc": [ + 65, + 66 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:906", + "pc": [ + 67, + 68, + 69, + 70 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:906", + "pc": [ + 71, + 72 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:906", + "pc": [ + 73 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:906", + "pc": [ + 74 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:907", + "pc": [ + 75, + 76 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:907", + "pc": [ + 77, + 78 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:907", + "pc": [ + 79 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:908", + "pc": [ + 80, + 81 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:908", + "pc": [ + 82, + 83 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:908", + "pc": [ + 84 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:909", + "pc": [ + 85, + 86 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:909", + "pc": [ + 87, + 88 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:909", + "pc": [ + 89 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:910", + "pc": [ + 90, + 91 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:910", + "pc": [ + 92, + 93 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:910", + "pc": [ + 94 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:911", + "pc": [ + 95, + 96 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:911", + "pc": [ + 97, + 98 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:911", + "pc": [ + 99 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:912", + "pc": [ + 100, + 101 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:912", + "pc": [ + 102, + 103 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:912", + "pc": [ + 104 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:913", + "pc": [ + 105, + 106 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:913", + "pc": [ + 107, + 108 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:913", + "pc": [ + 109 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:914", + "pc": [ + 110, + 111 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:914", + "pc": [ + 112, + 113 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:914", + "pc": [ + 114 + ] + }, + { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:905", + "pc": [ + 115, + 116 + ] + }, + { + "teal": 93, + "source": "tests/contracts/abi.algo.ts:917", + "pc": [ + 117, + 118 + ] + }, + { + "teal": 94, + "source": "tests/contracts/abi.algo.ts:917", + "pc": [ + 119, + 120 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:917", + "pc": [ + 121, + 122 + ] + }, + { + "teal": 96, + "source": "tests/contracts/abi.algo.ts:917", + "pc": [ + 123, + 124 + ] + }, + { + "teal": 97, + "source": "tests/contracts/abi.algo.ts:917", + "pc": [ + 125 + ] + }, + { + "teal": 100, + "source": "tests/contracts/abi.algo.ts:904", + "pc": [ + 126, + 127 + ] + }, + { + "teal": 101, + "source": "tests/contracts/abi.algo.ts:904", + "pc": [ + 128 + ] + }, + { + "teal": 104, + "source": "tests/contracts/abi.algo.ts:903", + "pc": [ + 129, + 130 + ] + }, + { + "teal": 105, + "source": "tests/contracts/abi.algo.ts:903", + "pc": [ + 131 + ] + }, + { + "teal": 108, + "source": "tests/contracts/abi.algo.ts:903", + "pc": [ + 132, + 133, + 134, + 135, + 136, + 137 + ] + }, + { + "teal": 109, + "source": "tests/contracts/abi.algo.ts:903", + "pc": [ + 138, + 139, + 140 + ] + }, + { + "teal": 110, + "source": "tests/contracts/abi.algo.ts:903", + "pc": [ + 141, + 142, + 143, + 144 + ] + }, + { + "teal": 113, + "source": "tests/contracts/abi.algo.ts:903", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 145 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 116, + "source": "tests/contracts/abi.algo.ts:903", + "pc": [ + 146, + 147, + 148, + 149, + 150, + 151 + ] + }, + { + "teal": 117, + "source": "tests/contracts/abi.algo.ts:903", + "pc": [ + 152, + 153, + 154 + ] + }, + { + "teal": 118, + "source": "tests/contracts/abi.algo.ts:903", + "pc": [ + 155, + 156, + 157, + 158 + ] }, { + "teal": 121, + "source": "tests/contracts/abi.algo.ts:903", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 159 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestBoolTupleUpdate.arc56_draft.json b/tests/contracts/artifacts/ABITestBoolTupleUpdate.arc56_draft.json index 7bc20d88b..97fa3e5c5 100644 --- a/tests/contracts/artifacts/ABITestBoolTupleUpdate.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestBoolTupleUpdate.arc56_draft.json @@ -64,22 +64,568 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:965", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:965", + "pc": [ + 1, + 2, + 3 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:965", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:965", + "pc": [ + 6 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:965", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:965", + "pc": [ + 9 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:965", + "pc": [ + 10, + 11 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:965", + "pc": [ + 12 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:965", + "pc": [ + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:965", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 39 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:966", + "pc": [ + 40, + 41, + 42, + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:966", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:966", + "pc": [ + 49 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:966", + "pc": [ + 50 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:966", + "pc": [ + 51, + 52 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:966", + "pc": [ + 53 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:966", + "pc": [ + 54, + 55, + 56 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:966", + "pc": [ + 57, + 58 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:968", + "pc": [ + 59, + 60, + 61, + 62 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:968", + "pc": [ + 63, + 64 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:968", + "pc": [ + 65, + 66 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:968", + "pc": [ + 67 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:969", + "pc": [ + 68, + 69 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:969", + "pc": [ + 70, + 71 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:969", + "pc": [ + 72 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:970", + "pc": [ + 73, + 74 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:970", + "pc": [ + 75, + 76 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:970", + "pc": [ + 77 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:971", + "pc": [ + 78, + 79 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:971", + "pc": [ + 80, + 81 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:971", + "pc": [ + 82 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:972", + "pc": [ + 83, + 84 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:972", + "pc": [ + 85, + 86 + ] }, { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:972", + "pc": [ + 87 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:973", + "pc": [ + 88, + 89 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:973", + "pc": [ + 90, + 91 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:973", + "pc": [ + 92 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:974", + "pc": [ + 93, + 94 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:974", + "pc": [ + 95, + 96 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:974", + "pc": [ + 97 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:975", + "pc": [ + 98, + 99 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:975", + "pc": [ + 100, + 101 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:975", + "pc": [ + 102 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:976", + "pc": [ + 103, + 104 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:976", + "pc": [ + 105, + 106 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:976", + "pc": [ + 107 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:967", + "pc": [ + 108, + 109 + ] + }, + { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:979", + "pc": [ + 110, + 111 + ] + }, + { + "teal": 90, + "source": "tests/contracts/abi.algo.ts:979", + "pc": [ + 112, + 113 + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:979", + "pc": [ + 114, + 115 + ] + }, + { + "teal": 92, + "source": "tests/contracts/abi.algo.ts:979", + "pc": [ + 116, + 117 + ] + }, + { + "teal": 93, + "source": "tests/contracts/abi.algo.ts:979", + "pc": [ + 118, + 119 + ] + }, + { + "teal": 94, + "source": "tests/contracts/abi.algo.ts:979", + "pc": [ + 120 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:979", + "pc": [ + 121, + 122 + ] + }, + { + "teal": 99, + "source": "tests/contracts/abi.algo.ts:980", + "pc": [ + 123, + 124 + ] + }, + { + "teal": 102, + "source": "tests/contracts/abi.algo.ts:966", + "pc": [ + 125, + 126 + ] + }, + { + "teal": 103, + "source": "tests/contracts/abi.algo.ts:966", + "pc": [ + 127 + ] + }, + { + "teal": 106, + "source": "tests/contracts/abi.algo.ts:965", + "pc": [ + 128, + 129 + ] + }, + { + "teal": 107, + "source": "tests/contracts/abi.algo.ts:965", + "pc": [ + 130 + ] + }, + { + "teal": 110, + "source": "tests/contracts/abi.algo.ts:965", + "pc": [ + 131, + 132, + 133, + 134, + 135, + 136 + ] + }, + { + "teal": 111, + "source": "tests/contracts/abi.algo.ts:965", + "pc": [ + 137, + 138, + 139 + ] + }, + { + "teal": 112, + "source": "tests/contracts/abi.algo.ts:965", + "pc": [ + 140, + 141, + 142, + 143 + ] + }, + { + "teal": 115, + "source": "tests/contracts/abi.algo.ts:965", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 144 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 118, + "source": "tests/contracts/abi.algo.ts:965", + "pc": [ + 145, + 146, + 147, + 148, + 149, + 150 + ] + }, + { + "teal": 119, + "source": "tests/contracts/abi.algo.ts:965", + "pc": [ + 151, + 152, + 153 + ] + }, + { + "teal": 120, + "source": "tests/contracts/abi.algo.ts:965", + "pc": [ + 154, + 155, + 156, + 157 + ] }, { + "teal": 123, + "source": "tests/contracts/abi.algo.ts:965", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 158 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestBooleanArgAndReturn.arc56_draft.json b/tests/contracts/artifacts/ABITestBooleanArgAndReturn.arc56_draft.json index 37b3506ed..9c604a09e 100644 --- a/tests/contracts/artifacts/ABITestBooleanArgAndReturn.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestBooleanArgAndReturn.arc56_draft.json @@ -69,28 +69,356 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:871", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:871", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:871", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:871", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:871", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:871", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:871", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:871", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:871", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:872", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] }, { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:872", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:872", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:872", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:872", + "pc": [ + 48, + 49 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:872", + "pc": [ + 50 + ] + }, + { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:872", + "errorMessage": "argument 0 (a) for booleanArgAndReturn must be a bool", "pc": [ 51 - ], - "errorMessage": "argument 0 (a) for booleanArgAndReturn must be a bool" + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:872", + "pc": [ + 52, + 53 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:872", + "pc": [ + 54 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:872", + "pc": [ + 55, + 56, + 57 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:872", + "pc": [ + 58, + 59, + 60 + ] }, { + "teal": 45, + "source": "tests/contracts/abi.algo.ts:872", + "pc": [ + 61, + 62 + ] + }, + { + "teal": 46, + "source": "tests/contracts/abi.algo.ts:872", + "pc": [ + 63, + 64 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:872", + "pc": [ + 65 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:872", + "pc": [ + 66 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:872", + "pc": [ + 67 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:872", + "pc": [ + 68, + 69 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:872", + "pc": [ + 70 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:872", + "pc": [ + 71, + 72, + 73 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:873", + "pc": [ + 74, + 75 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:872", + "pc": [ + 76 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:871", + "pc": [ + 77, + 78 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:871", + "pc": [ + 79 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:871", + "pc": [ + 80, + 81, + 82, + 83, + 84, + 85 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:871", + "pc": [ + 86, + 87, + 88 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:871", + "pc": [ + 89, + 90, + 91, + 92 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:871", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 93 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:871", + "pc": [ + 94, + 95, + 96, + 97, + 98, + 99 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:871", + "pc": [ + 100, + 101, + 102 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:871", + "pc": [ + 103, + 104, + 105, + 106 + ] }, { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:871", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 107 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestBooleanLastInObj.arc56_draft.json b/tests/contracts/artifacts/ABITestBooleanLastInObj.arc56_draft.json index 4362a1b7a..9b388d485 100644 --- a/tests/contracts/artifacts/ABITestBooleanLastInObj.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestBooleanLastInObj.arc56_draft.json @@ -76,22 +76,310 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1263", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:1263", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1263", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1263", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1263", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1263", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1263", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1263", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:1263", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:1264", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:1264", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1264", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1264", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1264", + "pc": [ + 48, + 49 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1264", + "pc": [ + 50 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:1264", + "pc": [ + 51, + 52, + 53 + ] }, { + "teal": 46, + "source": "tests/contracts/abi.algo.ts:1266", + "pc": [ + 54, + 55, + 56, + 57, + 58, + 59, + 60, + 61, + 62, + 63 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:1267", + "pc": [ + 64, + 65, + 66 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:1267", + "pc": [ + 67, + 68 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:1267", + "pc": [ + 69, + 70 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:1267", + "pc": [ + 71 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:1265", + "pc": [ + 72 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:1264", + "pc": [ + 73 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:1263", + "pc": [ + 74, + 75 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:1263", + "pc": [ + 76 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:1263", + "pc": [ + 77, + 78, + 79, + 80, + 81, + 82 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:1263", + "pc": [ + 83, + 84, + 85 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:1263", + "pc": [ + 86, + 87, + 88, + 89 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:1263", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 90 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:1263", + "pc": [ + 91, + 92, + 93, + 94, + 95, + 96 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:1263", + "pc": [ + 97, + 98, + 99 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:1263", + "pc": [ + 100, + 101, + 102, + 103 + ] }, { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:1263", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 104 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestBytesCasting.arc56_draft.json b/tests/contracts/artifacts/ABITestBytesCasting.arc56_draft.json index 5d2b792f5..b6d678893 100644 --- a/tests/contracts/artifacts/ABITestBytesCasting.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestBytesCasting.arc56_draft.json @@ -69,22 +69,345 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1199", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:1199", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1199", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1199", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1199", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1199", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1199", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1199", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:1199", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:1200", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] }, { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:1200", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1200", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1200", + "pc": [ + 49, + 50, + 51 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:1200", + "pc": [ + 52 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:1200", + "pc": [ + 53 + ] + }, + { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:1200", + "pc": [ + 54, + 55 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:1200", + "pc": [ + 56 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:1200", + "pc": [ + 57, + 58, + 59 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:1201", + "pc": [ + 60, + 61 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:1201", + "pc": [ + 62, + 63, + 64, + 65 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:1201", + "pc": [ + 66 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:1201", + "pc": [ + 67 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:1201", + "pc": [ + 68, + 69, + 70 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:1201", + "pc": [ + 71, + 72 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:1201", + "pc": [ + 73 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:1201", + "pc": [ + 74 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:1201", + "pc": [ + 75, + 76, + 77 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:1200", + "pc": [ + 78 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:1199", + "pc": [ + 79, + 80 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:1199", + "pc": [ + 81 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:1199", + "pc": [ + 82, + 83, + 84, + 85, + 86, + 87 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:1199", + "pc": [ + 88, + 89, + 90 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:1199", + "pc": [ + 91, + 92, + 93, + 94 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:1199", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 95 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:1199", + "pc": [ + 96, + 97, + 98, + 99, + 100, + 101 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:1199", + "pc": [ + 102, + 103, + 104 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:1199", + "pc": [ + 105, + 106, + 107, + 108 + ] }, { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:1199", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 109 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestBytesReturn.arc56_draft.json b/tests/contracts/artifacts/ABITestBytesReturn.arc56_draft.json index e9b0d43fe..a811a157e 100644 --- a/tests/contracts/artifacts/ABITestBytesReturn.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestBytesReturn.arc56_draft.json @@ -64,22 +64,310 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1124", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:1124", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1124", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1124", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1124", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1124", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1124", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1124", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:1124", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] }, { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:1125", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:1125", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1125", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1125", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1125", + "pc": [ + 48 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1125", + "pc": [ + 49, + 50, + 51 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:1125", + "pc": [ + 52 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:1125", + "pc": [ + 53 + ] + }, + { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:1125", + "pc": [ + 54 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:1125", + "pc": [ + 55 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:1125", + "pc": [ + 56, + 57 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:1125", + "pc": [ + 58 + ] + }, + { + "teal": 45, + "source": "tests/contracts/abi.algo.ts:1125", + "pc": [ + 59, + 60, + 61 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:1126", + "pc": [ + 62, + 63, + 64, + 65, + 66 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:1125", + "pc": [ + 67 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:1124", + "pc": [ + 68, + 69 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:1124", + "pc": [ + 70 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:1124", + "pc": [ + 71, + 72, + 73, + 74, + 75, + 76 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:1124", + "pc": [ + 77, + 78, + 79 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:1124", + "pc": [ + 80, + 81, + 82, + 83 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:1124", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 84 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:1124", + "pc": [ + 85, + 86, + 87, + 88, + 89, + 90 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:1124", + "pc": [ + 91, + 92, + 93 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:1124", + "pc": [ + 94, + 95, + 96, + 97 + ] }, { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:1124", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 98 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestCastBytesFunction.arc56_draft.json b/tests/contracts/artifacts/ABITestCastBytesFunction.arc56_draft.json index 41160a744..59a943abd 100644 --- a/tests/contracts/artifacts/ABITestCastBytesFunction.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestCastBytesFunction.arc56_draft.json @@ -64,22 +64,266 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1045", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:1045", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1045", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1045", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1045", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1045", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1045", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1045", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:1045", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] }, { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:1046", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:1046", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1046", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1046", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1046", + "pc": [ + 48, + 49 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1046", + "pc": [ + 50 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:1046", + "pc": [ + 51, + 52, + 53 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:1047", + "pc": [ + 54, + 55, + 56, + 57, + 58 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:1046", + "pc": [ + 59 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:1045", + "pc": [ + 60, + 61 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:1045", + "pc": [ + 62 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:1045", + "pc": [ + 63, + 64, + 65, + 66, + 67, + 68 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:1045", + "pc": [ + 69, + 70, + 71 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:1045", + "pc": [ + 72, + 73, + 74, + 75 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:1045", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 76 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:1045", + "pc": [ + 77, + 78, + 79, + 80, + 81, + 82 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:1045", + "pc": [ + 83, + 84, + 85 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:1045", + "pc": [ + 86, + 87, + 88, + 89 + ] }, { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:1045", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 90 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestChainedPropertyAfterTuple.arc56_draft.json b/tests/contracts/artifacts/ABITestChainedPropertyAfterTuple.arc56_draft.json index 456c8ffa1..dac9daa19 100644 --- a/tests/contracts/artifacts/ABITestChainedPropertyAfterTuple.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestChainedPropertyAfterTuple.arc56_draft.json @@ -69,22 +69,330 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1171", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:1171", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1171", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1171", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1171", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1171", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1171", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1171", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:1171", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:1172", + "pc": [ + 37, + 38, + 39 + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:1172", + "pc": [ + 40 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1172", + "pc": [ + 41, + 42, + 43 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1172", + "pc": [ + 44, + 45 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1172", + "pc": [ + 46 + ] + }, + { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:1172", + "pc": [ + 47, + 48, + 49 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:1172", + "pc": [ + 50, + 51 + ] + }, + { + "teal": 45, + "source": "tests/contracts/abi.algo.ts:1173", + "pc": [ + 52, + 53 + ] + }, + { + "teal": 46, + "source": "tests/contracts/abi.algo.ts:1173", + "pc": [ + 54, + 55 + ] }, { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:1175", + "pc": [ + 56, + 57 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:1175", + "pc": [ + 58, + 59, + 60 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:1175", + "pc": [ + 61, + 62 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:1175", + "pc": [ + 63, + 64 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:1175", + "pc": [ + 65 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:1175", + "pc": [ + 66 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:1175", + "pc": [ + 67 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:1175", + "pc": [ + 68 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:1172", + "pc": [ + 69 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:1171", + "pc": [ + 70, + 71 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:1171", + "pc": [ + 72 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:1171", + "pc": [ + 73, + 74, + 75, + 76, + 77, + 78 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:1171", + "pc": [ + 79, + 80, + 81 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:1171", + "pc": [ + 82, + 83, + 84, + 85 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:1171", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 86 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:1171", + "pc": [ + 87, + 88, + 89, + 90, + 91, + 92 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:1171", + "pc": [ + 93, + 94, + 95 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:1171", + "pc": [ + 96, + 97, + 98, + 99 + ] }, { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:1171", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 100 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestCustomTypes.arc56_draft.json b/tests/contracts/artifacts/ABITestCustomTypes.arc56_draft.json index 1837ecf2a..de1dd984e 100644 --- a/tests/contracts/artifacts/ABITestCustomTypes.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestCustomTypes.arc56_draft.json @@ -64,22 +64,1250 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 1, + 2, + 3, + 4, + 5, + 6, + 7, + 8, + 9, + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 19, + 20 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 21 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 22, + 23 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 24 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 25, + 26 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 27 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38, + 39, + 40, + 41, + 42, + 43, + 44, + 45, + 46, + 47, + 48, + 49, + 50, + 51, + 52, + 53 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:630", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 54 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:631", + "pc": [ + 55, + 56, + 57, + 58, + 59, + 60 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:631", + "pc": [ + 61, + 62, + 63 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:631", + "pc": [ + 64 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:631", + "pc": [ + 65 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:631", + "pc": [ + 66 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:631", + "pc": [ + 67, + 68, + 69 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:631", + "pc": [ + 70 + ] + }, + { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:631", + "pc": [ + 71 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:631", + "pc": [ + 72 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:631", + "pc": [ + 73 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:631", + "pc": [ + 74, + 75 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:631", + "pc": [ + 76 + ] + }, + { + "teal": 46, + "source": "tests/contracts/abi.algo.ts:631", + "pc": [ + 77, + 78, + 79 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:631", + "pc": [ + 80, + 81 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:632", + "pc": [ + 82, + 83 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:632", + "pc": [ + 84, + 85 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:632", + "pc": [ + 86, + 87, + 88, + 89 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:633", + "pc": [ + 90, + 91, + 92, + 93 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:633", + "pc": [ + 94, + 95, + 96 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:634", + "pc": [ + 97, + 98, + 99, + 100, + 101, + 102, + 103 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:634", + "pc": [ + 104, + 105, + 106 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:632", + "pc": [ + 107 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:632", + "pc": [ + 108 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:632", + "pc": [ + 109, + 110 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:637", + "pc": [ + 111, + 112 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:637", + "pc": [ + 113, + 114 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:637", + "pc": [ + 115, + 116 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:637", + "pc": [ + 117 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:637", + "pc": [ + 118, + 119 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:637", + "pc": [ + 120, + 121 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:637", + "pc": [ + 122, + 123 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:637", + "pc": [ + 124, + 125 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:637", + "pc": [ + 126 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:637", + "pc": [ + 127 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:637", + "pc": [ + 128, + 129 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:637", + "pc": [ + 130 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:637", + "pc": [ + 131, + 132 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:637", + "pc": [ + 133 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:637", + "pc": [ + 134 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:637", + "pc": [ + 135, + 136 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:637", + "pc": [ + 137 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:637", + "pc": [ + 138, + 139 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:637", + "pc": [ + 140 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:637", + "pc": [ + 141, + 142 + ] + }, + { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:637", + "pc": [ + 143, + 144 + ] + }, + { + "teal": 90, + "source": "tests/contracts/abi.algo.ts:637", + "pc": [ + 145, + 146 + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:637", + "pc": [ + 147, + 148 + ] + }, + { + "teal": 92, + "source": "tests/contracts/abi.algo.ts:637", + "pc": [ + 149 + ] + }, + { + "teal": 93, + "source": "tests/contracts/abi.algo.ts:637", + "pc": [ + 150, + 151, + 152, + 153, + 154, + 155, + 156, + 157, + 158, + 159, + 160, + 161, + 162, + 163, + 164, + 165 + ] + }, + { + "teal": 94, + "source": "tests/contracts/abi.algo.ts:637", + "pc": [ + 166 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:637", + "pc": [ + 167, + 168 + ] + }, + { + "teal": 96, + "source": "tests/contracts/abi.algo.ts:637", + "pc": [ + 169, + 170 + ] + }, + { + "teal": 97, + "source": "tests/contracts/abi.algo.ts:637", + "pc": [ + 171, + 172 + ] + }, + { + "teal": 98, + "source": "tests/contracts/abi.algo.ts:637", + "pc": [ + 173, + 174 + ] + }, + { + "teal": 99, + "source": "tests/contracts/abi.algo.ts:637", + "pc": [ + 175 + ] + }, + { + "teal": 100, + "source": "tests/contracts/abi.algo.ts:637", + "pc": [ + 176, + 177 + ] + }, + { + "teal": 101, + "source": "tests/contracts/abi.algo.ts:637", + "pc": [ + 178 + ] + }, + { + "teal": 102, + "source": "tests/contracts/abi.algo.ts:637", + "pc": [ + 179 + ] + }, + { + "teal": 103, + "source": "tests/contracts/abi.algo.ts:637", + "pc": [ + 180 + ] + }, + { + "teal": 104, + "source": "tests/contracts/abi.algo.ts:637", + "pc": [ + 181 + ] + }, + { + "teal": 105, + "source": "tests/contracts/abi.algo.ts:637", + "pc": [ + 182, + 183 + ] + }, + { + "teal": 106, + "source": "tests/contracts/abi.algo.ts:637", + "pc": [ + 184, + 185, + 186 + ] + }, + { + "teal": 107, + "source": "tests/contracts/abi.algo.ts:637", + "pc": [ + 187, + 188 + ] + }, + { + "teal": 108, + "source": "tests/contracts/abi.algo.ts:637", + "pc": [ + 189, + 190 + ] + }, + { + "teal": 112, + "source": "tests/contracts/abi.algo.ts:639", + "pc": [ + 191, + 192 + ] }, { + "teal": 113, + "source": "tests/contracts/abi.algo.ts:639", + "pc": [ + 193, + 194 + ] + }, + { + "teal": 114, + "source": "tests/contracts/abi.algo.ts:639", + "pc": [ + 195, + 196 + ] + }, + { + "teal": 115, + "source": "tests/contracts/abi.algo.ts:639", + "pc": [ + 197, + 198 + ] + }, + { + "teal": 116, + "source": "tests/contracts/abi.algo.ts:639", + "pc": [ + 199, + 200 + ] + }, + { + "teal": 117, + "source": "tests/contracts/abi.algo.ts:639", + "pc": [ + 201, + 202 + ] + }, + { + "teal": 118, + "source": "tests/contracts/abi.algo.ts:639", + "pc": [ + 203 + ] + }, + { + "teal": 119, + "source": "tests/contracts/abi.algo.ts:639", + "pc": [ + 204 + ] + }, + { + "teal": 120, + "source": "tests/contracts/abi.algo.ts:639", + "pc": [ + 205, + 206 + ] + }, + { + "teal": 121, + "source": "tests/contracts/abi.algo.ts:639", + "pc": [ + 207 + ] + }, + { + "teal": 122, + "source": "tests/contracts/abi.algo.ts:639", + "pc": [ + 208 + ] + }, + { + "teal": 123, + "source": "tests/contracts/abi.algo.ts:639", + "pc": [ + 209, + 210 + ] + }, + { + "teal": 124, + "source": "tests/contracts/abi.algo.ts:639", + "pc": [ + 211 + ] + }, + { + "teal": 125, + "source": "tests/contracts/abi.algo.ts:639", + "pc": [ + 212, + 213 + ] + }, + { + "teal": 126, + "source": "tests/contracts/abi.algo.ts:639", + "pc": [ + 214 + ] + }, + { + "teal": 127, + "source": "tests/contracts/abi.algo.ts:639", + "pc": [ + 215 + ] + }, + { + "teal": 128, + "source": "tests/contracts/abi.algo.ts:639", + "pc": [ + 216, + 217, + 218 + ] + }, + { + "teal": 131, + "source": "tests/contracts/abi.algo.ts:631", + "pc": [ + 219, + 220 + ] + }, + { + "teal": 132, + "source": "tests/contracts/abi.algo.ts:631", + "pc": [ + 221 + ] + }, + { + "teal": 135, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 222, + 223 + ] + }, + { + "teal": 136, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 224 + ] + }, + { + "teal": 139, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 225, + 226, + 227, + 228, + 229, + 230 + ] + }, + { + "teal": 140, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 231, + 232, + 233 + ] + }, + { + "teal": 141, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 234, + 235, + 236, + 237 + ] + }, + { + "teal": 144, + "source": "tests/contracts/abi.algo.ts:630", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 238 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 147, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 239, + 240, + 241, + 242, + 243, + 244 + ] + }, + { + "teal": 148, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 245, + 246, + 247 + ] + }, + { + "teal": 149, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 248, + 249, + 250, + 251 + ] }, { + "teal": 152, + "source": "tests/contracts/abi.algo.ts:630", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 252 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] + }, + { + "teal": 155, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 253, + 254, + 255 + ] + }, + { + "teal": 156, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 256, + 257 + ] + }, + { + "teal": 157, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 258, + 259 + ] + }, + { + "teal": 158, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 260 + ] + }, + { + "teal": 159, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 261, + 262 + ] + }, + { + "teal": 160, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 263, + 264 + ] + }, + { + "teal": 161, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 265 + ] + }, + { + "teal": 164, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 266, + 267, + 268 + ] + }, + { + "teal": 165, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 269, + 270 + ] + }, + { + "teal": 166, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 271, + 272 + ] + }, + { + "teal": 167, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 273 + ] + }, + { + "teal": 168, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 274, + 275 + ] + }, + { + "teal": 169, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 276, + 277 + ] + }, + { + "teal": 170, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 278 + ] + }, + { + "teal": 171, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 279 + ] + }, + { + "teal": 172, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 280, + 281 + ] + }, + { + "teal": 173, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 282 + ] + }, + { + "teal": 174, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 283 + ] + }, + { + "teal": 175, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 284 + ] + }, + { + "teal": 176, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 285, + 286, + 287 + ] + }, + { + "teal": 177, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 288, + 289 + ] + }, + { + "teal": 178, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 290, + 291 + ] + }, + { + "teal": 179, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 292 + ] + }, + { + "teal": 180, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 293 + ] + }, + { + "teal": 181, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 294, + 295 + ] + }, + { + "teal": 182, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 296, + 297 + ] + }, + { + "teal": 183, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 298, + 299 + ] + }, + { + "teal": 184, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 300, + 301 + ] + }, + { + "teal": 185, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 302 + ] + }, + { + "teal": 188, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 303, + 304 + ] + }, + { + "teal": 189, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 305 + ] + }, + { + "teal": 190, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 306, + 307 + ] + }, + { + "teal": 191, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 308 + ] + }, + { + "teal": 192, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 309, + 310, + 311 + ] + }, + { + "teal": 193, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 312, + 313 + ] + }, + { + "teal": 194, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 314 + ] + }, + { + "teal": 195, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 315, + 316 + ] + }, + { + "teal": 196, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 317, + 318 + ] + }, + { + "teal": 197, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 319, + 320 + ] + }, + { + "teal": 198, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 321, + 322, + 323 + ] + }, + { + "teal": 201, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 324, + 325 + ] + }, + { + "teal": 202, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 326, + 327 + ] + }, + { + "teal": 203, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 328 + ] + }, + { + "teal": 204, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 329, + 330 + ] + }, + { + "teal": 205, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 331, + 332 + ] + }, + { + "teal": 208, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 333 + ] + }, + { + "teal": 209, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 334, + 335 + ] + }, + { + "teal": 210, + "source": "tests/contracts/abi.algo.ts:630", + "pc": [ + 336 + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestDisgusting.arc56_draft.json b/tests/contracts/artifacts/ABITestDisgusting.arc56_draft.json index db8ac082f..3429dc6b5 100644 --- a/tests/contracts/artifacts/ABITestDisgusting.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestDisgusting.arc56_draft.json @@ -64,22 +64,474 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:302", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:302", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:302", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:302", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:302", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:302", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:302", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:302", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:302", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:303", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:303", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:303", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:303", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:303", + "pc": [ + 48 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:303", + "pc": [ + 49, + 50 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:303", + "pc": [ + 51 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:303", + "pc": [ + 52, + 53, + 54 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:303", + "pc": [ + 55, + 56 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:307", + "pc": [ + 57, + 58, + 59, + 60, + 61, + 62, + 63, + 64, + 65, + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82, + 83, + 84, + 85, + 86, + 87, + 88, + 89, + 90, + 91, + 92, + 93, + 94, + 95, + 96, + 97, + 98, + 99, + 100, + 101, + 102, + 103, + 104, + 105, + 106, + 107, + 108, + 109, + 110, + 111, + 112, + 113, + 114, + 115, + 116, + 117, + 118, + 119, + 120, + 121, + 122, + 123, + 124, + 125, + 126, + 127, + 128, + 129, + 130, + 131, + 132, + 133, + 134, + 135, + 136, + 137, + 138, + 139, + 140, + 141, + 142, + 143, + 144, + 145, + 146, + 147, + 148, + 149, + 150, + 151, + 152, + 153, + 154, + 155, + 156, + 157, + 158, + 159, + 160, + 161, + 162, + 163, + 164, + 165, + 166 + ] }, { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:304", + "pc": [ + 167, + 168 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:328", + "pc": [ + 169, + 170 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:328", + "pc": [ + 171, + 172, + 173, + 174, + 175, + 176, + 177, + 178, + 179, + 180, + 181, + 182, + 183, + 184, + 185, + 186, + 187, + 188 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:328", + "pc": [ + 189, + 190 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:328", + "pc": [ + 191, + 192 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:329", + "pc": [ + 193, + 194 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:329", + "pc": [ + 195, + 196, + 197 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:329", + "pc": [ + 198 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:303", + "pc": [ + 199, + 200 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:303", + "pc": [ + 201 + ] + }, + { + "teal": 90, + "source": "tests/contracts/abi.algo.ts:302", + "pc": [ + 202, + 203 + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:302", + "pc": [ + 204 + ] + }, + { + "teal": 94, + "source": "tests/contracts/abi.algo.ts:302", + "pc": [ + 205, + 206, + 207, + 208, + 209, + 210 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:302", + "pc": [ + 211, + 212, + 213 + ] + }, + { + "teal": 96, + "source": "tests/contracts/abi.algo.ts:302", + "pc": [ + 214, + 215, + 216, + 217 + ] + }, + { + "teal": 99, + "source": "tests/contracts/abi.algo.ts:302", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 218 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 102, + "source": "tests/contracts/abi.algo.ts:302", + "pc": [ + 219, + 220, + 221, + 222, + 223, + 224 + ] + }, + { + "teal": 103, + "source": "tests/contracts/abi.algo.ts:302", + "pc": [ + 225, + 226, + 227 + ] + }, + { + "teal": 104, + "source": "tests/contracts/abi.algo.ts:302", + "pc": [ + 228, + 229, + 230, + 231 + ] }, { + "teal": 107, + "source": "tests/contracts/abi.algo.ts:302", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 232 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestDynamicAccessOfDynamicElementInStaticArray.arc56_draft.json b/tests/contracts/artifacts/ABITestDynamicAccessOfDynamicElementInStaticArray.arc56_draft.json index a2b8ff4d2..2adf81ca1 100644 --- a/tests/contracts/artifacts/ABITestDynamicAccessOfDynamicElementInStaticArray.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestDynamicAccessOfDynamicElementInStaticArray.arc56_draft.json @@ -69,22 +69,500 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:649", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:649", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:649", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:649", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:649", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:649", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:649", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:649", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:649", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:650", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:650", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:650", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:650", + "pc": [ + 49 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:650", + "pc": [ + 50 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:650", + "pc": [ + 51 + ] + }, + { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:650", + "pc": [ + 52, + 53, + 54 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:650", + "pc": [ + 55 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:650", + "pc": [ + 56 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:650", + "pc": [ + 57 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:650", + "pc": [ + 58 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:650", + "pc": [ + 59, + 60 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:650", + "pc": [ + 61 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:650", + "pc": [ + 62, + 63, + 64 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:650", + "pc": [ + 65, + 66 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:651", + "pc": [ + 67, + 68 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:651", + "pc": [ + 69, + 70 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:652", + "pc": [ + 71, + 72 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:652", + "pc": [ + 73, + 74 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:652", + "pc": [ + 75, + 76 + ] }, { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:652", + "pc": [ + 77, + 78 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:652", + "pc": [ + 79, + 80 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:652", + "pc": [ + 81 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:652", + "pc": [ + 82 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:652", + "pc": [ + 83, + 84 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:652", + "pc": [ + 85, + 86 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:652", + "pc": [ + 87, + 88 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:652", + "pc": [ + 89 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:652", + "pc": [ + 90 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:652", + "pc": [ + 91, + 92 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:652", + "pc": [ + 93 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:652", + "pc": [ + 94 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:652", + "pc": [ + 95, + 96 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:652", + "pc": [ + 97 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:652", + "pc": [ + 98, + 99 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:652", + "pc": [ + 100 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:652", + "pc": [ + 101 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:652", + "pc": [ + 102, + 103, + 104 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:650", + "pc": [ + 105, + 106 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:650", + "pc": [ + 107 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:649", + "pc": [ + 108, + 109 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:649", + "pc": [ + 110 + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:649", + "pc": [ + 111, + 112, + 113, + 114, + 115, + 116 + ] + }, + { + "teal": 92, + "source": "tests/contracts/abi.algo.ts:649", + "pc": [ + 117, + 118, + 119 + ] + }, + { + "teal": 93, + "source": "tests/contracts/abi.algo.ts:649", + "pc": [ + 120, + 121, + 122, + 123 + ] + }, + { + "teal": 96, + "source": "tests/contracts/abi.algo.ts:649", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 124 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 99, + "source": "tests/contracts/abi.algo.ts:649", + "pc": [ + 125, + 126, + 127, + 128, + 129, + 130 + ] + }, + { + "teal": 100, + "source": "tests/contracts/abi.algo.ts:649", + "pc": [ + 131, + 132, + 133 + ] + }, + { + "teal": 101, + "source": "tests/contracts/abi.algo.ts:649", + "pc": [ + 134, + 135, + 136, + 137 + ] }, { + "teal": 104, + "source": "tests/contracts/abi.algo.ts:649", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 138 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestDynamicArray.arc56_draft.json b/tests/contracts/artifacts/ABITestDynamicArray.arc56_draft.json index 7ed78ce09..66c8bbece 100644 --- a/tests/contracts/artifacts/ABITestDynamicArray.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestDynamicArray.arc56_draft.json @@ -64,22 +64,358 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:346", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:346", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:346", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:346", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:346", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:346", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:346", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:346", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:346", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:347", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:347", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:347", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:347", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:347", + "pc": [ + 48 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:347", + "pc": [ + 49, + 50 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:347", + "pc": [ + 51 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:347", + "pc": [ + 52, + 53, + 54 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:347", + "pc": [ + 55, + 56 + ] }, { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:348", + "pc": [ + 57, + 58, + 59, + 60, + 61, + 62, + 63, + 64, + 65, + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:348", + "pc": [ + 83, + 84 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:350", + "pc": [ + 85, + 86 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:350", + "pc": [ + 87, + 88 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:350", + "pc": [ + 89, + 90 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:350", + "pc": [ + 91, + 92, + 93 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:350", + "pc": [ + 94 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:347", + "pc": [ + 95, + 96 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:347", + "pc": [ + 97 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:346", + "pc": [ + 98, + 99 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:346", + "pc": [ + 100 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:346", + "pc": [ + 101, + 102, + 103, + 104, + 105, + 106 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:346", + "pc": [ + 107, + 108, + 109 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:346", + "pc": [ + 110, + 111, + 112, + 113 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:346", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 114 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:346", + "pc": [ + 115, + 116, + 117, + 118, + 119, + 120 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:346", + "pc": [ + 121, + 122, + 123 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:346", + "pc": [ + 124, + 125, + 126, + 127 + ] }, { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:346", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 128 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestDynamicArrayArg.arc56_draft.json b/tests/contracts/artifacts/ABITestDynamicArrayArg.arc56_draft.json index 3e72c9ac5..1840a90a8 100644 --- a/tests/contracts/artifacts/ABITestDynamicArrayArg.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestDynamicArrayArg.arc56_draft.json @@ -69,22 +69,320 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:361", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:361", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:361", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:361", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:361", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:361", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:361", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:361", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:361", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:362", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:362", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:362", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:362", + "pc": [ + 49, + 50, + 51 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:362", + "pc": [ + 52 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:362", + "pc": [ + 53 + ] + }, + { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:362", + "pc": [ + 54 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:362", + "pc": [ + 55, + 56 + ] }, { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:362", + "pc": [ + 57 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:362", + "pc": [ + 58, + 59, + 60 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:363", + "pc": [ + 61, + 62 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:363", + "pc": [ + 63, + 64 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:363", + "pc": [ + 65, + 66 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:363", + "pc": [ + 67, + 68, + 69 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:363", + "pc": [ + 70 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:362", + "pc": [ + 71 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:361", + "pc": [ + 72, + 73 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:361", + "pc": [ + 74 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:361", + "pc": [ + 75, + 76, + 77, + 78, + 79, + 80 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:361", + "pc": [ + 81, + 82, + 83 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:361", + "pc": [ + 84, + 85, + 86, + 87 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:361", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 88 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:361", + "pc": [ + 89, + 90, + 91, + 92, + 93, + 94 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:361", + "pc": [ + 95, + 96, + 97 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:361", + "pc": [ + 98, + 99, + 100, + 101 + ] }, { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:361", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 102 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestDynamicArrayElements.arc56_draft.json b/tests/contracts/artifacts/ABITestDynamicArrayElements.arc56_draft.json index 1c70f402c..c47c805d3 100644 --- a/tests/contracts/artifacts/ABITestDynamicArrayElements.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestDynamicArrayElements.arc56_draft.json @@ -64,22 +64,574 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:479", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:479", + "pc": [ + 1, + 2, + 3 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:479", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:479", + "pc": [ + 6 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:479", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:479", + "pc": [ + 9 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:479", + "pc": [ + 10, + 11 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:479", + "pc": [ + 12 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:479", + "pc": [ + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:479", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 39 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:480", + "pc": [ + 40, + 41, + 42, + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:480", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:480", + "pc": [ + 49 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:480", + "pc": [ + 50 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:480", + "pc": [ + 51, + 52 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:480", + "pc": [ + 53 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:480", + "pc": [ + 54 + ] + }, + { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:480", + "pc": [ + 55, + 56, + 57 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:480", + "pc": [ + 58 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:480", + "pc": [ + 59 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:480", + "pc": [ + 60 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:480", + "pc": [ + 61 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:480", + "pc": [ + 62, + 63 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:480", + "pc": [ + 64 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:480", + "pc": [ + 65, + 66, + 67 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:480", + "pc": [ + 68, + 69 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:480", + "pc": [ + 70 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:481", + "pc": [ + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:481", + "pc": [ + 79, + 80 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:482", + "pc": [ + 81, + 82 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:482", + "pc": [ + 83, + 84 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:482", + "pc": [ + 85, + 86 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:482", + "pc": [ + 87, + 88, + 89 + ] }, { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:482", + "pc": [ + 90 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:482", + "pc": [ + 91 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:482", + "pc": [ + 92, + 93, + 94 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:482", + "pc": [ + 95, + 96 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:482", + "pc": [ + 97, + 98 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:482", + "pc": [ + 99, + 100 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:482", + "pc": [ + 101, + 102, + 103 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:482", + "pc": [ + 104 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:482", + "pc": [ + 105 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:482", + "pc": [ + 106, + 107, + 108 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:482", + "pc": [ + 109 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:482", + "pc": [ + 110, + 111 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:482", + "pc": [ + 112, + 113 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:482", + "pc": [ + 114, + 115 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:482", + "pc": [ + 116, + 117, + 118 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:482", + "pc": [ + 119 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:482", + "pc": [ + 120 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:482", + "pc": [ + 121, + 122, + 123 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:482", + "pc": [ + 124 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:482", + "pc": [ + 125, + 126 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:484", + "pc": [ + 127, + 128 + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:480", + "pc": [ + 129, + 130 + ] + }, + { + "teal": 94, + "source": "tests/contracts/abi.algo.ts:480", + "pc": [ + 131, + 132 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:480", + "pc": [ + 133 + ] + }, + { + "teal": 98, + "source": "tests/contracts/abi.algo.ts:479", + "pc": [ + 134, + 135 + ] + }, + { + "teal": 99, + "source": "tests/contracts/abi.algo.ts:479", + "pc": [ + 136 + ] + }, + { + "teal": 102, + "source": "tests/contracts/abi.algo.ts:479", + "pc": [ + 137, + 138, + 139, + 140, + 141, + 142 + ] + }, + { + "teal": 103, + "source": "tests/contracts/abi.algo.ts:479", + "pc": [ + 143, + 144, + 145 + ] + }, + { + "teal": 104, + "source": "tests/contracts/abi.algo.ts:479", + "pc": [ + 146, + 147, + 148, + 149 + ] + }, + { + "teal": 107, + "source": "tests/contracts/abi.algo.ts:479", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 150 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 110, + "source": "tests/contracts/abi.algo.ts:479", + "pc": [ + 151, + 152, + 153, + 154, + 155, + 156 + ] + }, + { + "teal": 111, + "source": "tests/contracts/abi.algo.ts:479", + "pc": [ + 157, + 158, + 159 + ] + }, + { + "teal": 112, + "source": "tests/contracts/abi.algo.ts:479", + "pc": [ + 160, + 161, + 162, + 163 + ] }, { + "teal": 115, + "source": "tests/contracts/abi.algo.ts:479", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 164 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestDynamicArrayInMiddleOfTuple.arc56_draft.json b/tests/contracts/artifacts/ABITestDynamicArrayInMiddleOfTuple.arc56_draft.json index 93e12a7d6..213466d0c 100644 --- a/tests/contracts/artifacts/ABITestDynamicArrayInMiddleOfTuple.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestDynamicArrayInMiddleOfTuple.arc56_draft.json @@ -64,22 +64,618 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:656", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:656", + "pc": [ + 1, + 2, + 3 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:656", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:656", + "pc": [ + 6 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:656", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:656", + "pc": [ + 9 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:656", + "pc": [ + 10, + 11 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:656", + "pc": [ + 12 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:656", + "pc": [ + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:656", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 39 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:657", + "pc": [ + 40, + 41, + 42, + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:657", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:657", + "pc": [ + 49 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:657", + "pc": [ + 50 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:657", + "pc": [ + 51, + 52 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:657", + "pc": [ + 53 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:657", + "pc": [ + 54, + 55, + 56 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:657", + "pc": [ + 57, + 58 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:658", + "pc": [ + 59, + 60 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:658", + "pc": [ + 61, + 62 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:658", + "pc": [ + 63, + 64, + 65, + 66 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:658", + "pc": [ + 67, + 68, + 69, + 70 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:658", + "pc": [ + 71, + 72, + 73 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:658", + "pc": [ + 74, + 75, + 76, + 77, + 78 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:658", + "pc": [ + 79, + 80, + 81 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:658", + "pc": [ + 82, + 83, + 84, + 85 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:658", + "pc": [ + 86, + 87, + 88 + ] }, { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:658", + "pc": [ + 89 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:658", + "pc": [ + 90 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:658", + "pc": [ + 91, + 92 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:660", + "pc": [ + 93, + 94 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:657", + "pc": [ + 95, + 96 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:657", + "pc": [ + 97 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:656", + "pc": [ + 98, + 99 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:656", + "pc": [ + 100 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:656", + "pc": [ + 101, + 102, + 103, + 104, + 105, + 106 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:656", + "pc": [ + 107, + 108, + 109 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:656", + "pc": [ + 110, + 111, + 112, + 113 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:656", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 114 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:656", + "pc": [ + 115, + 116, + 117, + 118, + 119, + 120 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:656", + "pc": [ + 121, + 122, + 123 + ] }, { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:656", + "pc": [ + 124, + 125, + 126, + 127 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:656", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 128 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] + }, + { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:656", + "pc": [ + 129, + 130, + 131 + ] + }, + { + "teal": 90, + "source": "tests/contracts/abi.algo.ts:656", + "pc": [ + 132, + 133 + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:656", + "pc": [ + 134, + 135 + ] + }, + { + "teal": 92, + "source": "tests/contracts/abi.algo.ts:656", + "pc": [ + 136 + ] + }, + { + "teal": 93, + "source": "tests/contracts/abi.algo.ts:656", + "pc": [ + 137, + 138 + ] + }, + { + "teal": 94, + "source": "tests/contracts/abi.algo.ts:656", + "pc": [ + 139, + 140 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:656", + "pc": [ + 141 + ] + }, + { + "teal": 98, + "source": "tests/contracts/abi.algo.ts:656", + "pc": [ + 142, + 143, + 144 + ] + }, + { + "teal": 99, + "source": "tests/contracts/abi.algo.ts:656", + "pc": [ + 145, + 146 + ] + }, + { + "teal": 100, + "source": "tests/contracts/abi.algo.ts:656", + "pc": [ + 147, + 148 + ] + }, + { + "teal": 101, + "source": "tests/contracts/abi.algo.ts:656", + "pc": [ + 149 + ] + }, + { + "teal": 102, + "source": "tests/contracts/abi.algo.ts:656", + "pc": [ + 150, + 151 + ] + }, + { + "teal": 103, + "source": "tests/contracts/abi.algo.ts:656", + "pc": [ + 152, + 153 + ] + }, + { + "teal": 104, + "source": "tests/contracts/abi.algo.ts:656", + "pc": [ + 154 + ] + }, + { + "teal": 105, + "source": "tests/contracts/abi.algo.ts:656", + "pc": [ + 155 + ] + }, + { + "teal": 106, + "source": "tests/contracts/abi.algo.ts:656", + "pc": [ + 156, + 157 + ] + }, + { + "teal": 107, + "source": "tests/contracts/abi.algo.ts:656", + "pc": [ + 158 + ] + }, + { + "teal": 108, + "source": "tests/contracts/abi.algo.ts:656", + "pc": [ + 159 + ] + }, + { + "teal": 109, + "source": "tests/contracts/abi.algo.ts:656", + "pc": [ + 160 + ] + }, + { + "teal": 110, + "source": "tests/contracts/abi.algo.ts:656", + "pc": [ + 161, + 162, + 163 + ] + }, + { + "teal": 111, + "source": "tests/contracts/abi.algo.ts:656", + "pc": [ + 164, + 165 + ] + }, + { + "teal": 112, + "source": "tests/contracts/abi.algo.ts:656", + "pc": [ + 166, + 167 + ] + }, + { + "teal": 113, + "source": "tests/contracts/abi.algo.ts:656", + "pc": [ + 168 + ] + }, + { + "teal": 114, + "source": "tests/contracts/abi.algo.ts:656", + "pc": [ + 169 + ] + }, + { + "teal": 115, + "source": "tests/contracts/abi.algo.ts:656", + "pc": [ + 170, + 171 + ] + }, + { + "teal": 116, + "source": "tests/contracts/abi.algo.ts:656", + "pc": [ + 172, + 173 + ] + }, + { + "teal": 117, + "source": "tests/contracts/abi.algo.ts:656", + "pc": [ + 174, + 175 + ] + }, + { + "teal": 118, + "source": "tests/contracts/abi.algo.ts:656", + "pc": [ + 176, + 177 + ] + }, + { + "teal": 119, + "source": "tests/contracts/abi.algo.ts:656", + "pc": [ + 178 + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestDynamicArrayIteration.arc56_draft.json b/tests/contracts/artifacts/ABITestDynamicArrayIteration.arc56_draft.json index 584618746..8633dded5 100644 --- a/tests/contracts/artifacts/ABITestDynamicArrayIteration.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestDynamicArrayIteration.arc56_draft.json @@ -64,22 +64,990 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1598", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:1598", + "pc": [ + 1, + 2, + 3 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1598", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1598", + "pc": [ + 6 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1598", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1598", + "pc": [ + 9 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1598", + "pc": [ + 10, + 11 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1598", + "pc": [ + 12 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:1598", + "pc": [ + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:1598", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 39 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:1599", + "pc": [ + 40, + 41, + 42, + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1599", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1599", + "pc": [ + 49 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1599", + "pc": [ + 50 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1599", + "pc": [ + 51 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:1599", + "pc": [ + 52, + 53, + 54 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:1599", + "pc": [ + 55 + ] + }, + { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:1599", + "pc": [ + 56 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:1599", + "pc": [ + 57 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:1599", + "pc": [ + 58 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:1599", + "pc": [ + 59, + 60 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:1599", + "pc": [ + 61 + ] + }, + { + "teal": 46, + "source": "tests/contracts/abi.algo.ts:1599", + "pc": [ + 62, + 63, + 64 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:1599", + "pc": [ + 65, + 66 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:1599", + "pc": [ + 67, + 68 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:1600", + "pc": [ + 69, + 70 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:1600", + "pc": [ + 71, + 72 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:1600", + "pc": [ + 73, + 74, + 75, + 76 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:1600", + "pc": [ + 77, + 78, + 79, + 80, + 81, + 82, + 83, + 84, + 85, + 86 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:1600", + "pc": [ + 87, + 88, + 89 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:1600", + "pc": [ + 90, + 91, + 92, + 93, + 94, + 95, + 96, + 97, + 98 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:1600", + "pc": [ + 99, + 100, + 101 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:1600", + "pc": [ + 102, + 103, + 104, + 105, + 106 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:1600", + "pc": [ + 107, + 108, + 109 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:1600", + "pc": [ + 110 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:1600", + "pc": [ + 111 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:1600", + "pc": [ + 112, + 113, + 114, + 115 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:1600", + "pc": [ + 116 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:1600", + "pc": [ + 117 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:1600", + "pc": [ + 118, + 119 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:1601", + "pc": [ + 120, + 121 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:1601", + "pc": [ + 122, + 123 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:1603", + "pc": [ + 124, + 125 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:1603", + "pc": [ + 126, + 127 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:1603", + "pc": [ + 128, + 129 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:1603", + "pc": [ + 130, + 131 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:1603", + "pc": [ + 132, + 133 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:1603", + "pc": [ + 134 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:1603", + "pc": [ + 135 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:1603", + "pc": [ + 136, + 137, + 138 + ] + }, + { + "teal": 92, + "source": "tests/contracts/abi.algo.ts:1604", + "pc": [ + 139, + 140 + ] + }, + { + "teal": 93, + "source": "tests/contracts/abi.algo.ts:1604", + "pc": [ + 141, + 142 + ] + }, + { + "teal": 94, + "source": "tests/contracts/abi.algo.ts:1604", + "pc": [ + 143, + 144 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:1604", + "pc": [ + 145, + 146 + ] + }, + { + "teal": 96, + "source": "tests/contracts/abi.algo.ts:1604", + "pc": [ + 147, + 148 + ] + }, + { + "teal": 97, + "source": "tests/contracts/abi.algo.ts:1604", + "pc": [ + 149, + 150 + ] + }, + { + "teal": 98, + "source": "tests/contracts/abi.algo.ts:1604", + "pc": [ + 151 + ] + }, + { + "teal": 99, + "source": "tests/contracts/abi.algo.ts:1604", + "pc": [ + 152 + ] + }, + { + "teal": 100, + "source": "tests/contracts/abi.algo.ts:1604", + "pc": [ + 153, + 154 + ] }, { + "teal": 101, + "source": "tests/contracts/abi.algo.ts:1604", + "pc": [ + 155 + ] + }, + { + "teal": 102, + "source": "tests/contracts/abi.algo.ts:1604", + "pc": [ + 156, + 157 + ] + }, + { + "teal": 103, + "source": "tests/contracts/abi.algo.ts:1604", + "pc": [ + 158, + 159 + ] + }, + { + "teal": 104, + "source": "tests/contracts/abi.algo.ts:1604", + "pc": [ + 160, + 161 + ] + }, + { + "teal": 105, + "source": "tests/contracts/abi.algo.ts:1604", + "pc": [ + 162 + ] + }, + { + "teal": 106, + "source": "tests/contracts/abi.algo.ts:1604", + "pc": [ + 163, + 164 + ] + }, + { + "teal": 107, + "source": "tests/contracts/abi.algo.ts:1604", + "pc": [ + 165 + ] + }, + { + "teal": 108, + "source": "tests/contracts/abi.algo.ts:1604", + "pc": [ + 166 + ] + }, + { + "teal": 109, + "source": "tests/contracts/abi.algo.ts:1604", + "pc": [ + 167, + 168 + ] + }, + { + "teal": 110, + "source": "tests/contracts/abi.algo.ts:1604", + "pc": [ + 169 + ] + }, + { + "teal": 111, + "source": "tests/contracts/abi.algo.ts:1604", + "pc": [ + 170 + ] + }, + { + "teal": 112, + "source": "tests/contracts/abi.algo.ts:1604", + "pc": [ + 171, + 172 + ] + }, + { + "teal": 113, + "source": "tests/contracts/abi.algo.ts:1604", + "pc": [ + 173 + ] + }, + { + "teal": 114, + "source": "tests/contracts/abi.algo.ts:1604", + "pc": [ + 174, + 175 + ] + }, + { + "teal": 115, + "source": "tests/contracts/abi.algo.ts:1604", + "pc": [ + 176 + ] + }, + { + "teal": 116, + "source": "tests/contracts/abi.algo.ts:1604", + "pc": [ + 177 + ] + }, + { + "teal": 117, + "source": "tests/contracts/abi.algo.ts:1604", + "pc": [ + 178, + 179, + 180 + ] + }, + { + "teal": 118, + "source": "tests/contracts/abi.algo.ts:1604", + "pc": [ + 181 + ] + }, + { + "teal": 119, + "source": "tests/contracts/abi.algo.ts:1604", + "pc": [ + 182, + 183 + ] + }, + { + "teal": 124, + "source": "tests/contracts/abi.algo.ts:1603", + "pc": [ + 184, + 185 + ] + }, + { + "teal": 125, + "source": "tests/contracts/abi.algo.ts:1603", + "pc": [ + 186, + 187 + ] + }, + { + "teal": 126, + "source": "tests/contracts/abi.algo.ts:1603", + "pc": [ + 188 + ] + }, + { + "teal": 127, + "source": "tests/contracts/abi.algo.ts:1603", + "pc": [ + 189, + 190 + ] + }, + { + "teal": 128, + "source": "tests/contracts/abi.algo.ts:1603", + "pc": [ + 191, + 192, + 193 + ] + }, + { + "teal": 133, + "source": "tests/contracts/abi.algo.ts:1607", + "pc": [ + 194, + 195 + ] + }, + { + "teal": 136, + "source": "tests/contracts/abi.algo.ts:1599", + "pc": [ + 196, + 197 + ] + }, + { + "teal": 139, + "source": "tests/contracts/abi.algo.ts:1599", + "pc": [ + 198, + 199 + ] + }, + { + "teal": 140, + "source": "tests/contracts/abi.algo.ts:1599", + "pc": [ + 200 + ] + }, + { + "teal": 143, + "source": "tests/contracts/abi.algo.ts:1598", + "pc": [ + 201, + 202 + ] + }, + { + "teal": 144, + "source": "tests/contracts/abi.algo.ts:1598", + "pc": [ + 203 + ] + }, + { + "teal": 147, + "source": "tests/contracts/abi.algo.ts:1598", + "pc": [ + 204, + 205, + 206, + 207, + 208, + 209 + ] + }, + { + "teal": 148, + "source": "tests/contracts/abi.algo.ts:1598", + "pc": [ + 210, + 211, + 212 + ] + }, + { + "teal": 149, + "source": "tests/contracts/abi.algo.ts:1598", + "pc": [ + 213, + 214, + 215, + 216 + ] + }, + { + "teal": 152, + "source": "tests/contracts/abi.algo.ts:1598", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 217 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 155, + "source": "tests/contracts/abi.algo.ts:1598", + "pc": [ + 218, + 219, + 220, + 221, + 222, + 223 + ] }, { + "teal": 156, + "source": "tests/contracts/abi.algo.ts:1598", + "pc": [ + 224, + 225, + 226 + ] + }, + { + "teal": 157, + "source": "tests/contracts/abi.algo.ts:1598", + "pc": [ + 227, + 228, + 229, + 230 + ] + }, + { + "teal": 160, + "source": "tests/contracts/abi.algo.ts:1598", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 231 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] + }, + { + "teal": 163, + "source": "tests/contracts/abi.algo.ts:1598", + "pc": [ + 232, + 233, + 234 + ] + }, + { + "teal": 164, + "source": "tests/contracts/abi.algo.ts:1598", + "pc": [ + 235, + 236 + ] + }, + { + "teal": 165, + "source": "tests/contracts/abi.algo.ts:1598", + "pc": [ + 237, + 238 + ] + }, + { + "teal": 166, + "source": "tests/contracts/abi.algo.ts:1598", + "pc": [ + 239 + ] + }, + { + "teal": 167, + "source": "tests/contracts/abi.algo.ts:1598", + "pc": [ + 240, + 241 + ] + }, + { + "teal": 168, + "source": "tests/contracts/abi.algo.ts:1598", + "pc": [ + 242, + 243 + ] + }, + { + "teal": 169, + "source": "tests/contracts/abi.algo.ts:1598", + "pc": [ + 244 + ] + }, + { + "teal": 170, + "source": "tests/contracts/abi.algo.ts:1598", + "pc": [ + 245 + ] + }, + { + "teal": 171, + "source": "tests/contracts/abi.algo.ts:1598", + "pc": [ + 246, + 247 + ] + }, + { + "teal": 172, + "source": "tests/contracts/abi.algo.ts:1598", + "pc": [ + 248 + ] + }, + { + "teal": 173, + "source": "tests/contracts/abi.algo.ts:1598", + "pc": [ + 249 + ] + }, + { + "teal": 174, + "source": "tests/contracts/abi.algo.ts:1598", + "pc": [ + 250 + ] + }, + { + "teal": 175, + "source": "tests/contracts/abi.algo.ts:1598", + "pc": [ + 251, + 252, + 253 + ] + }, + { + "teal": 176, + "source": "tests/contracts/abi.algo.ts:1598", + "pc": [ + 254, + 255 + ] + }, + { + "teal": 177, + "source": "tests/contracts/abi.algo.ts:1598", + "pc": [ + 256, + 257 + ] + }, + { + "teal": 178, + "source": "tests/contracts/abi.algo.ts:1598", + "pc": [ + 258 + ] + }, + { + "teal": 179, + "source": "tests/contracts/abi.algo.ts:1598", + "pc": [ + 259 + ] + }, + { + "teal": 180, + "source": "tests/contracts/abi.algo.ts:1598", + "pc": [ + 260, + 261 + ] + }, + { + "teal": 181, + "source": "tests/contracts/abi.algo.ts:1598", + "pc": [ + 262, + 263 + ] + }, + { + "teal": 182, + "source": "tests/contracts/abi.algo.ts:1598", + "pc": [ + 264, + 265 + ] + }, + { + "teal": 183, + "source": "tests/contracts/abi.algo.ts:1598", + "pc": [ + 266, + 267 + ] + }, + { + "teal": 184, + "source": "tests/contracts/abi.algo.ts:1598", + "pc": [ + 268 + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestDynamicArrayLength.arc56_draft.json b/tests/contracts/artifacts/ABITestDynamicArrayLength.arc56_draft.json index c41226f0c..c6cceb388 100644 --- a/tests/contracts/artifacts/ABITestDynamicArrayLength.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestDynamicArrayLength.arc56_draft.json @@ -64,22 +64,964 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1588", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:1588", + "pc": [ + 1, + 2, + 3 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1588", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1588", + "pc": [ + 6 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1588", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1588", + "pc": [ + 9 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1588", + "pc": [ + 10, + 11 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1588", + "pc": [ + 12 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:1588", + "pc": [ + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:1588", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 39 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:1589", + "pc": [ + 40, + 41, + 42, + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1589", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1589", + "pc": [ + 49 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1589", + "pc": [ + 50 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1589", + "pc": [ + 51 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:1589", + "pc": [ + 52, + 53 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:1589", + "pc": [ + 54 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:1589", + "pc": [ + 55, + 56, + 57 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:1589", + "pc": [ + 58, + 59 + ] + }, + { + "teal": 45, + "source": "tests/contracts/abi.algo.ts:1589", + "pc": [ + 60 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:1590", + "pc": [ + 61, + 62 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:1590", + "pc": [ + 63, + 64 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:1590", + "pc": [ + 65, + 66, + 67, + 68 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:1590", + "pc": [ + 69, + 70, + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:1590", + "pc": [ + 79, + 80, + 81 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:1590", + "pc": [ + 82, + 83, + 84, + 85, + 86, + 87, + 88, + 89, + 90, + 91, + 92, + 93, + 94, + 95, + 96, + 97, + 98, + 99, + 100, + 101, + 102, + 103, + 104, + 105, + 106, + 107, + 108, + 109 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:1590", + "pc": [ + 110, + 111, + 112 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:1590", + "pc": [ + 113 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:1590", + "pc": [ + 114 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:1590", + "pc": [ + 115, + 116 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:1592", + "pc": [ + 117, + 118 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:1592", + "pc": [ + 119, + 120 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:1592", + "pc": [ + 121, + 122, + 123, + 124 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:1592", + "pc": [ + 125, + 126, + 127, + 128, + 129, + 130, + 131, + 132, + 133 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:1592", + "pc": [ + 134, + 135, + 136 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:1592", + "pc": [ + 137, + 138, + 139, + 140, + 141, + 142, + 143, + 144, + 145 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:1592", + "pc": [ + 146, + 147, + 148 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:1592", + "pc": [ + 149, + 150, + 151, + 152, + 153 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:1592", + "pc": [ + 154, + 155, + 156 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:1592", + "pc": [ + 157 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:1592", + "pc": [ + 158 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:1592", + "pc": [ + 159, + 160, + 161, + 162 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:1592", + "pc": [ + 163 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:1592", + "pc": [ + 164 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:1592", + "pc": [ + 165, + 166 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:1594", + "pc": [ + 167, + 168 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:1594", + "pc": [ + 169, + 170 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:1594", + "pc": [ + 171 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:1594", + "pc": [ + 172, + 173 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:1594", + "pc": [ + 174, + 175 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:1594", + "pc": [ + 176, + 177 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:1594", + "pc": [ + 178, + 179 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:1594", + "pc": [ + 180, + 181 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:1594", + "pc": [ + 182, + 183 + ] + }, + { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:1594", + "pc": [ + 184 + ] }, { + "teal": 90, + "source": "tests/contracts/abi.algo.ts:1594", + "pc": [ + 185 + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:1594", + "pc": [ + 186, + 187 + ] + }, + { + "teal": 92, + "source": "tests/contracts/abi.algo.ts:1594", + "pc": [ + 188 + ] + }, + { + "teal": 93, + "source": "tests/contracts/abi.algo.ts:1594", + "pc": [ + 189 + ] + }, + { + "teal": 94, + "source": "tests/contracts/abi.algo.ts:1594", + "pc": [ + 190, + 191 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:1594", + "pc": [ + 192 + ] + }, + { + "teal": 96, + "source": "tests/contracts/abi.algo.ts:1594", + "pc": [ + 193, + 194 + ] + }, + { + "teal": 97, + "source": "tests/contracts/abi.algo.ts:1594", + "pc": [ + 195 + ] + }, + { + "teal": 98, + "source": "tests/contracts/abi.algo.ts:1594", + "pc": [ + 196 + ] + }, + { + "teal": 99, + "source": "tests/contracts/abi.algo.ts:1594", + "pc": [ + 197, + 198, + 199 + ] + }, + { + "teal": 100, + "source": "tests/contracts/abi.algo.ts:1594", + "pc": [ + 200 + ] + }, + { + "teal": 101, + "source": "tests/contracts/abi.algo.ts:1594", + "pc": [ + 201, + 202 + ] + }, + { + "teal": 102, + "source": "tests/contracts/abi.algo.ts:1594", + "pc": [ + 203 + ] + }, + { + "teal": 103, + "source": "tests/contracts/abi.algo.ts:1594", + "pc": [ + 204 + ] + }, + { + "teal": 106, + "source": "tests/contracts/abi.algo.ts:1589", + "pc": [ + 205, + 206 + ] + }, + { + "teal": 109, + "source": "tests/contracts/abi.algo.ts:1589", + "pc": [ + 207, + 208 + ] + }, + { + "teal": 110, + "source": "tests/contracts/abi.algo.ts:1589", + "pc": [ + 209 + ] + }, + { + "teal": 113, + "source": "tests/contracts/abi.algo.ts:1588", + "pc": [ + 210, + 211 + ] + }, + { + "teal": 114, + "source": "tests/contracts/abi.algo.ts:1588", + "pc": [ + 212 + ] + }, + { + "teal": 117, + "source": "tests/contracts/abi.algo.ts:1588", + "pc": [ + 213, + 214, + 215, + 216, + 217, + 218 + ] + }, + { + "teal": 118, + "source": "tests/contracts/abi.algo.ts:1588", + "pc": [ + 219, + 220, + 221 + ] + }, + { + "teal": 119, + "source": "tests/contracts/abi.algo.ts:1588", + "pc": [ + 222, + 223, + 224, + 225 + ] + }, + { + "teal": 122, + "source": "tests/contracts/abi.algo.ts:1588", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 226 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 125, + "source": "tests/contracts/abi.algo.ts:1588", + "pc": [ + 227, + 228, + 229, + 230, + 231, + 232 + ] + }, + { + "teal": 126, + "source": "tests/contracts/abi.algo.ts:1588", + "pc": [ + 233, + 234, + 235 + ] }, { + "teal": 127, + "source": "tests/contracts/abi.algo.ts:1588", + "pc": [ + 236, + 237, + 238, + 239 + ] + }, + { + "teal": 130, + "source": "tests/contracts/abi.algo.ts:1588", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 240 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] + }, + { + "teal": 133, + "source": "tests/contracts/abi.algo.ts:1588", + "pc": [ + 241, + 242, + 243 + ] + }, + { + "teal": 134, + "source": "tests/contracts/abi.algo.ts:1588", + "pc": [ + 244, + 245 + ] + }, + { + "teal": 135, + "source": "tests/contracts/abi.algo.ts:1588", + "pc": [ + 246, + 247 + ] + }, + { + "teal": 136, + "source": "tests/contracts/abi.algo.ts:1588", + "pc": [ + 248 + ] + }, + { + "teal": 137, + "source": "tests/contracts/abi.algo.ts:1588", + "pc": [ + 249, + 250 + ] + }, + { + "teal": 138, + "source": "tests/contracts/abi.algo.ts:1588", + "pc": [ + 251, + 252 + ] + }, + { + "teal": 139, + "source": "tests/contracts/abi.algo.ts:1588", + "pc": [ + 253 + ] + }, + { + "teal": 142, + "source": "tests/contracts/abi.algo.ts:1588", + "pc": [ + 254, + 255, + 256 + ] + }, + { + "teal": 143, + "source": "tests/contracts/abi.algo.ts:1588", + "pc": [ + 257, + 258 + ] + }, + { + "teal": 144, + "source": "tests/contracts/abi.algo.ts:1588", + "pc": [ + 259, + 260 + ] + }, + { + "teal": 145, + "source": "tests/contracts/abi.algo.ts:1588", + "pc": [ + 261 + ] + }, + { + "teal": 146, + "source": "tests/contracts/abi.algo.ts:1588", + "pc": [ + 262, + 263 + ] + }, + { + "teal": 147, + "source": "tests/contracts/abi.algo.ts:1588", + "pc": [ + 264, + 265 + ] + }, + { + "teal": 148, + "source": "tests/contracts/abi.algo.ts:1588", + "pc": [ + 266 + ] + }, + { + "teal": 149, + "source": "tests/contracts/abi.algo.ts:1588", + "pc": [ + 267 + ] + }, + { + "teal": 150, + "source": "tests/contracts/abi.algo.ts:1588", + "pc": [ + 268, + 269 + ] + }, + { + "teal": 151, + "source": "tests/contracts/abi.algo.ts:1588", + "pc": [ + 270 + ] + }, + { + "teal": 152, + "source": "tests/contracts/abi.algo.ts:1588", + "pc": [ + 271 + ] + }, + { + "teal": 153, + "source": "tests/contracts/abi.algo.ts:1588", + "pc": [ + 272 + ] + }, + { + "teal": 154, + "source": "tests/contracts/abi.algo.ts:1588", + "pc": [ + 273, + 274, + 275 + ] + }, + { + "teal": 155, + "source": "tests/contracts/abi.algo.ts:1588", + "pc": [ + 276, + 277 + ] + }, + { + "teal": 156, + "source": "tests/contracts/abi.algo.ts:1588", + "pc": [ + 278, + 279 + ] + }, + { + "teal": 157, + "source": "tests/contracts/abi.algo.ts:1588", + "pc": [ + 280 + ] + }, + { + "teal": 158, + "source": "tests/contracts/abi.algo.ts:1588", + "pc": [ + 281 + ] + }, + { + "teal": 159, + "source": "tests/contracts/abi.algo.ts:1588", + "pc": [ + 282, + 283 + ] + }, + { + "teal": 160, + "source": "tests/contracts/abi.algo.ts:1588", + "pc": [ + 284, + 285 + ] + }, + { + "teal": 161, + "source": "tests/contracts/abi.algo.ts:1588", + "pc": [ + 286, + 287 + ] + }, + { + "teal": 162, + "source": "tests/contracts/abi.algo.ts:1588", + "pc": [ + 288, + 289 + ] + }, + { + "teal": 163, + "source": "tests/contracts/abi.algo.ts:1588", + "pc": [ + 290 + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestDynamicBoolArray.arc56_draft.json b/tests/contracts/artifacts/ABITestDynamicBoolArray.arc56_draft.json index a955b1510..8b5e8ca6c 100644 --- a/tests/contracts/artifacts/ABITestDynamicBoolArray.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestDynamicBoolArray.arc56_draft.json @@ -64,22 +64,521 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:929", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:929", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:929", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:929", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:929", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:929", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:929", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:929", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:929", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:930", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:930", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:930", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:930", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:930", + "pc": [ + 48, + 49 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:930", + "pc": [ + 50 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:930", + "pc": [ + 51, + 52, + 53 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:930", + "pc": [ + 54, + 55 + ] + }, + { + "teal": 46, + "source": "tests/contracts/abi.algo.ts:931", + "pc": [ + 56, + 57, + 58, + 59 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:931", + "pc": [ + 60, + 61, + 62, + 63 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:931", + "pc": [ + 64, + 65 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:931", + "pc": [ + 66, + 67 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:931", + "pc": [ + 68 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:931", + "pc": [ + 69, + 70 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:931", + "pc": [ + 71, + 72 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:931", + "pc": [ + 73 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:931", + "pc": [ + 74, + 75 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:931", + "pc": [ + 76, + 77 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:931", + "pc": [ + 78 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:931", + "pc": [ + 79, + 80 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:931", + "pc": [ + 81, + 82 + ] }, { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:931", + "pc": [ + 83 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:931", + "pc": [ + 84, + 85 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:931", + "pc": [ + 86, + 87 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:931", + "pc": [ + 88 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:931", + "pc": [ + 89, + 90 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:931", + "pc": [ + 91, + 92 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:931", + "pc": [ + 93 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:931", + "pc": [ + 94, + 95 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:931", + "pc": [ + 96, + 97 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:931", + "pc": [ + 98 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:931", + "pc": [ + 99, + 100 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:931", + "pc": [ + 101, + 102 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:931", + "pc": [ + 103 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:931", + "pc": [ + 104, + 105 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:931", + "pc": [ + 106, + 107 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:931", + "pc": [ + 108 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:931", + "pc": [ + 109 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:931", + "pc": [ + 110, + 111 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:933", + "pc": [ + 112, + 113 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:930", + "pc": [ + 114, + 115 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:930", + "pc": [ + 116 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:929", + "pc": [ + 117, + 118 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:929", + "pc": [ + 119 + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:929", + "pc": [ + 120, + 121, + 122, + 123, + 124, + 125 + ] + }, + { + "teal": 92, + "source": "tests/contracts/abi.algo.ts:929", + "pc": [ + 126, + 127, + 128 + ] + }, + { + "teal": 93, + "source": "tests/contracts/abi.algo.ts:929", + "pc": [ + 129, + 130, + 131, + 132 + ] + }, + { + "teal": 96, + "source": "tests/contracts/abi.algo.ts:929", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 133 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 99, + "source": "tests/contracts/abi.algo.ts:929", + "pc": [ + 134, + 135, + 136, + 137, + 138, + 139 + ] + }, + { + "teal": 100, + "source": "tests/contracts/abi.algo.ts:929", + "pc": [ + 140, + 141, + 142 + ] + }, + { + "teal": 101, + "source": "tests/contracts/abi.algo.ts:929", + "pc": [ + 143, + 144, + 145, + 146 + ] }, { + "teal": 104, + "source": "tests/contracts/abi.algo.ts:929", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 147 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestDynamicBoolArrayAccess.arc56_draft.json b/tests/contracts/artifacts/ABITestDynamicBoolArrayAccess.arc56_draft.json index 5b32300d2..ff8c68ca1 100644 --- a/tests/contracts/artifacts/ABITestDynamicBoolArrayAccess.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestDynamicBoolArrayAccess.arc56_draft.json @@ -64,22 +64,584 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:937", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:937", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:937", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:937", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:937", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:937", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:937", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:937", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:937", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:938", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:938", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:938", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:938", + "pc": [ + 49, + 50 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:938", + "pc": [ + 51, + 52 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:938", + "pc": [ + 53 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:938", + "pc": [ + 54 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:938", + "pc": [ + 55 + ] + }, + { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:938", + "pc": [ + 56, + 57 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:938", + "pc": [ + 58 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:938", + "pc": [ + 59, + 60, + 61 + ] + }, + { + "teal": 46, + "source": "tests/contracts/abi.algo.ts:938", + "pc": [ + 62, + 63 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:939", + "pc": [ + 64, + 65, + 66, + 67 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:939", + "pc": [ + 68, + 69, + 70, + 71 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:939", + "pc": [ + 72, + 73 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:939", + "pc": [ + 74, + 75 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:939", + "pc": [ + 76 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:939", + "pc": [ + 77, + 78 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:939", + "pc": [ + 79, + 80 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:939", + "pc": [ + 81 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:939", + "pc": [ + 82, + 83 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:939", + "pc": [ + 84, + 85 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:939", + "pc": [ + 86 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:939", + "pc": [ + 87, + 88 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:939", + "pc": [ + 89, + 90 + ] }, { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:939", + "pc": [ + 91 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:939", + "pc": [ + 92, + 93 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:939", + "pc": [ + 94, + 95 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:939", + "pc": [ + 96 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:939", + "pc": [ + 97, + 98 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:939", + "pc": [ + 99, + 100 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:939", + "pc": [ + 101 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:939", + "pc": [ + 102, + 103 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:939", + "pc": [ + 104, + 105 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:939", + "pc": [ + 106 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:939", + "pc": [ + 107, + 108 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:939", + "pc": [ + 109, + 110 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:939", + "pc": [ + 111 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:939", + "pc": [ + 112, + 113 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:939", + "pc": [ + 114, + 115 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:939", + "pc": [ + 116 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:939", + "pc": [ + 117 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:939", + "pc": [ + 118, + 119 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:941", + "pc": [ + 120, + 121 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:941", + "pc": [ + 122, + 123 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:941", + "pc": [ + 124, + 125 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:941", + "pc": [ + 126, + 127 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:941", + "pc": [ + 128 + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:938", + "pc": [ + 129, + 130 + ] + }, + { + "teal": 92, + "source": "tests/contracts/abi.algo.ts:938", + "pc": [ + 131 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:937", + "pc": [ + 132, + 133 + ] + }, + { + "teal": 96, + "source": "tests/contracts/abi.algo.ts:937", + "pc": [ + 134 + ] + }, + { + "teal": 99, + "source": "tests/contracts/abi.algo.ts:937", + "pc": [ + 135, + 136, + 137, + 138, + 139, + 140 + ] + }, + { + "teal": 100, + "source": "tests/contracts/abi.algo.ts:937", + "pc": [ + 141, + 142, + 143 + ] + }, + { + "teal": 101, + "source": "tests/contracts/abi.algo.ts:937", + "pc": [ + 144, + 145, + 146, + 147 + ] + }, + { + "teal": 104, + "source": "tests/contracts/abi.algo.ts:937", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 148 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 107, + "source": "tests/contracts/abi.algo.ts:937", + "pc": [ + 149, + 150, + 151, + 152, + 153, + 154 + ] + }, + { + "teal": 108, + "source": "tests/contracts/abi.algo.ts:937", + "pc": [ + 155, + 156, + 157 + ] + }, + { + "teal": 109, + "source": "tests/contracts/abi.algo.ts:937", + "pc": [ + 158, + 159, + 160, + 161 + ] }, { + "teal": 112, + "source": "tests/contracts/abi.algo.ts:937", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 162 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestDynamicBoolArrayUpdate.arc56_draft.json b/tests/contracts/artifacts/ABITestDynamicBoolArrayUpdate.arc56_draft.json index 4599466b8..32c2028f8 100644 --- a/tests/contracts/artifacts/ABITestDynamicBoolArrayUpdate.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestDynamicBoolArrayUpdate.arc56_draft.json @@ -64,22 +64,585 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:955", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:955", + "pc": [ + 1, + 2, + 3 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:955", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:955", + "pc": [ + 6 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:955", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:955", + "pc": [ + 9 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:955", + "pc": [ + 10, + 11 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:955", + "pc": [ + 12 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:955", + "pc": [ + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:955", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 39 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:956", + "pc": [ + 40, + 41, + 42, + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:956", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:956", + "pc": [ + 49 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:956", + "pc": [ + 50 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:956", + "pc": [ + 51, + 52 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:956", + "pc": [ + 53 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:956", + "pc": [ + 54, + 55, + 56 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:956", + "pc": [ + 57, + 58 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:957", + "pc": [ + 59, + 60, + 61, + 62 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:957", + "pc": [ + 63, + 64, + 65, + 66 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:957", + "pc": [ + 67, + 68 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:957", + "pc": [ + 69, + 70 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:957", + "pc": [ + 71 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:957", + "pc": [ + 72, + 73 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:957", + "pc": [ + 74, + 75 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:957", + "pc": [ + 76 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:957", + "pc": [ + 77, + 78 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:957", + "pc": [ + 79, + 80 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:957", + "pc": [ + 81 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:957", + "pc": [ + 82, + 83 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:957", + "pc": [ + 84, + 85 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:957", + "pc": [ + 86 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:957", + "pc": [ + 87, + 88 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:957", + "pc": [ + 89, + 90 + ] }, { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:957", + "pc": [ + 91 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:957", + "pc": [ + 92, + 93 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:957", + "pc": [ + 94, + 95 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:957", + "pc": [ + 96 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:957", + "pc": [ + 97, + 98 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:957", + "pc": [ + 99, + 100 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:957", + "pc": [ + 101 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:957", + "pc": [ + 102, + 103 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:957", + "pc": [ + 104, + 105 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:957", + "pc": [ + 106 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:957", + "pc": [ + 107, + 108 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:957", + "pc": [ + 109, + 110 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:957", + "pc": [ + 111 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:957", + "pc": [ + 112 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:957", + "pc": [ + 113, + 114 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:959", + "pc": [ + 115, + 116 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:959", + "pc": [ + 117, + 118 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:959", + "pc": [ + 119, + 120 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:959", + "pc": [ + 121, + 122 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:959", + "pc": [ + 123, + 124 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:959", + "pc": [ + 125 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:959", + "pc": [ + 126, + 127 + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:961", + "pc": [ + 128, + 129 + ] + }, + { + "teal": 94, + "source": "tests/contracts/abi.algo.ts:956", + "pc": [ + 130, + 131 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:956", + "pc": [ + 132 + ] + }, + { + "teal": 98, + "source": "tests/contracts/abi.algo.ts:955", + "pc": [ + 133, + 134 + ] + }, + { + "teal": 99, + "source": "tests/contracts/abi.algo.ts:955", + "pc": [ + 135 + ] + }, + { + "teal": 102, + "source": "tests/contracts/abi.algo.ts:955", + "pc": [ + 136, + 137, + 138, + 139, + 140, + 141 + ] + }, + { + "teal": 103, + "source": "tests/contracts/abi.algo.ts:955", + "pc": [ + 142, + 143, + 144 + ] + }, + { + "teal": 104, + "source": "tests/contracts/abi.algo.ts:955", + "pc": [ + 145, + 146, + 147, + 148 + ] + }, + { + "teal": 107, + "source": "tests/contracts/abi.algo.ts:955", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 149 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 110, + "source": "tests/contracts/abi.algo.ts:955", + "pc": [ + 150, + 151, + 152, + 153, + 154, + 155 + ] + }, + { + "teal": 111, + "source": "tests/contracts/abi.algo.ts:955", + "pc": [ + 156, + 157, + 158 + ] + }, + { + "teal": 112, + "source": "tests/contracts/abi.algo.ts:955", + "pc": [ + 159, + 160, + 161, + 162 + ] }, { + "teal": 115, + "source": "tests/contracts/abi.algo.ts:955", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 163 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestDynamicTupleArray.arc56_draft.json b/tests/contracts/artifacts/ABITestDynamicTupleArray.arc56_draft.json index c6be1805e..132abe638 100644 --- a/tests/contracts/artifacts/ABITestDynamicTupleArray.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestDynamicTupleArray.arc56_draft.json @@ -64,22 +64,354 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:377", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:377", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:377", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:377", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:377", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:377", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:377", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:377", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:377", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:378", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:378", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:378", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:378", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:378", + "pc": [ + 48 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:378", + "pc": [ + 49, + 50 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:378", + "pc": [ + 51 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:378", + "pc": [ + 52, + 53, + 54 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:378", + "pc": [ + 55, + 56 + ] }, { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:379", + "pc": [ + 57, + 58, + 59, + 60, + 61, + 62, + 63, + 64, + 65, + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:379", + "pc": [ + 79, + 80 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:384", + "pc": [ + 81, + 82 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:384", + "pc": [ + 83, + 84 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:384", + "pc": [ + 85, + 86 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:384", + "pc": [ + 87, + 88, + 89 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:384", + "pc": [ + 90 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:378", + "pc": [ + 91, + 92 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:378", + "pc": [ + 93 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:377", + "pc": [ + 94, + 95 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:377", + "pc": [ + 96 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:377", + "pc": [ + 97, + 98, + 99, + 100, + 101, + 102 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:377", + "pc": [ + 103, + 104, + 105 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:377", + "pc": [ + 106, + 107, + 108, + 109 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:377", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 110 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:377", + "pc": [ + 111, + 112, + 113, + 114, + 115, + 116 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:377", + "pc": [ + 117, + 118, + 119 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:377", + "pc": [ + 120, + 121, + 122, + 123 + ] }, { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:377", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 124 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestEmptyDynamicArray.arc56_draft.json b/tests/contracts/artifacts/ABITestEmptyDynamicArray.arc56_draft.json index 01f32dfd2..0225668c8 100644 --- a/tests/contracts/artifacts/ABITestEmptyDynamicArray.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestEmptyDynamicArray.arc56_draft.json @@ -64,22 +64,322 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:866", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:866", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:866", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:866", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:866", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:866", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:866", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:866", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:866", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:867", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] }, { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:867", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:867", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:867", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:867", + "pc": [ + 48, + 49 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:867", + "pc": [ + 50 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:867", + "pc": [ + 51 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:867", + "pc": [ + 52, + 53, + 54 + ] + }, + { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:867", + "pc": [ + 55 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:867", + "pc": [ + 56 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:867", + "pc": [ + 57 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:867", + "pc": [ + 58 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:867", + "pc": [ + 59, + 60 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:867", + "pc": [ + 61 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:867", + "pc": [ + 62, + 63, + 64 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:868", + "pc": [ + 65, + 66 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:867", + "pc": [ + 67 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:866", + "pc": [ + 68, + 69 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:866", + "pc": [ + 70 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:866", + "pc": [ + 71, + 72, + 73, + 74, + 75, + 76 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:866", + "pc": [ + 77, + 78, + 79 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:866", + "pc": [ + 80, + 81, + 82, + 83 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:866", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 84 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:866", + "pc": [ + 85, + 86, + 87, + 88, + 89, + 90 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:866", + "pc": [ + 91, + 92, + 93 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:866", + "pc": [ + 94, + 95, + 96, + 97 + ] }, { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:866", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 98 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestEmptyStaticArray.arc56_draft.json b/tests/contracts/artifacts/ABITestEmptyStaticArray.arc56_draft.json index 3383d2b8c..c5b6f27df 100644 --- a/tests/contracts/artifacts/ABITestEmptyStaticArray.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestEmptyStaticArray.arc56_draft.json @@ -64,22 +64,301 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:840", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:840", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:840", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:840", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:840", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:840", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:840", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:840", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:840", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:841", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:841", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:841", + "pc": [ + 46 + ] }, { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:841", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:841", + "pc": [ + 48, + 49 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:841", + "pc": [ + 50 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:841", + "pc": [ + 51, + 52, + 53 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:841", + "pc": [ + 54, + 55 + ] + }, + { + "teal": 46, + "source": "tests/contracts/abi.algo.ts:842", + "pc": [ + 56, + 57, + 58, + 59, + 60, + 61, + 62, + 63 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:842", + "pc": [ + 64, + 65 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:844", + "pc": [ + 66, + 67 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:841", + "pc": [ + 68, + 69 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:841", + "pc": [ + 70 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:840", + "pc": [ + 71, + 72 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:840", + "pc": [ + 73 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:840", + "pc": [ + 74, + 75, + 76, + 77, + 78, + 79 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:840", + "pc": [ + 80, + 81, + 82 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:840", + "pc": [ + 83, + 84, + 85, + 86 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:840", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 87 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:840", + "pc": [ + 88, + 89, + 90, + 91, + 92, + 93 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:840", + "pc": [ + 94, + 95, + 96 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:840", + "pc": [ + 97, + 98, + 99, + 100 + ] }, { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:840", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 101 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestExtractUint.arc56_draft.json b/tests/contracts/artifacts/ABITestExtractUint.arc56_draft.json index 78e950882..71f3e7b37 100644 --- a/tests/contracts/artifacts/ABITestExtractUint.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestExtractUint.arc56_draft.json @@ -69,28 +69,364 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1117", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:1117", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1117", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1117", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1117", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1117", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1117", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1117", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:1117", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:1118", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:1118", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1118", + "pc": [ + 46 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1118", + "pc": [ + 47, + 48, + 49 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:1118", + "pc": [ + 50 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:1118", + "pc": [ + 51 + ] }, { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:1118", + "pc": [ + 52 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:1118", + "pc": [ + 53, + 54 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:1118", + "pc": [ + 55 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:1118", + "errorMessage": "extractUint return value overflowed 8 bits", "pc": [ 56 - ], - "errorMessage": "extractUint return value overflowed 8 bits" + ] }, { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:1118", + "pc": [ + 57, + 58, + 59 + ] + }, + { + "teal": 45, + "source": "tests/contracts/abi.algo.ts:1118", + "pc": [ + 60 + ] + }, + { + "teal": 46, + "source": "tests/contracts/abi.algo.ts:1118", + "pc": [ + 61 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:1118", + "pc": [ + 62, + 63 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:1118", + "pc": [ + 64 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:1118", + "pc": [ + 65, + 66, + 67 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:1118", + "pc": [ + 68, + 69 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:1119", + "pc": [ + 70, + 71 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:1119", + "pc": [ + 72, + 73 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:1120", + "pc": [ + 74, + 75 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:1118", + "pc": [ + 76, + 77 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:1118", + "pc": [ + 78 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:1117", + "pc": [ + 79, + 80 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:1117", + "pc": [ + 81 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:1117", + "pc": [ + 82, + 83, + 84, + 85, + 86, + 87 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:1117", + "pc": [ + 88, + 89, + 90 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:1117", + "pc": [ + 91, + 92, + 93, + 94 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:1117", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 95 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:1117", + "pc": [ + 96, + 97, + 98, + 99, + 100, + 101 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:1117", + "pc": [ + 102, + 103, + 104 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:1117", + "pc": [ + 105, + 106, + 107, + 108 + ] }, { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:1117", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 109 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestForEachReturn.arc56_draft.json b/tests/contracts/artifacts/ABITestForEachReturn.arc56_draft.json index 6e8a704a4..04b5e0ef9 100644 --- a/tests/contracts/artifacts/ABITestForEachReturn.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestForEachReturn.arc56_draft.json @@ -64,22 +64,619 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1370", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:1370", + "pc": [ + 1, + 2, + 3 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1370", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1370", + "pc": [ + 6 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1370", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1370", + "pc": [ + 9 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1370", + "pc": [ + 10, + 11 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1370", + "pc": [ + 12 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:1370", + "pc": [ + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:1370", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 39 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:1371", + "pc": [ + 40, + 41, + 42, + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1371", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1371", + "pc": [ + 49 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1371", + "pc": [ + 50 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1371", + "pc": [ + 51 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:1371", + "pc": [ + 52, + 53 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:1371", + "pc": [ + 54 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:1371", + "pc": [ + 55, + 56, + 57 + ] }, { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:1371", + "pc": [ + 58, + 59 + ] + }, + { + "teal": 45, + "source": "tests/contracts/abi.algo.ts:1371", + "pc": [ + 60, + 61 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:1372", + "pc": [ + 62, + 63, + 64, + 65, + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82, + 83, + 84, + 85, + 86, + 87 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:1372", + "pc": [ + 88, + 89 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:1373", + "pc": [ + 90, + 91 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:1373", + "pc": [ + 92, + 93 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:1375", + "pc": [ + 94, + 95 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:1375", + "pc": [ + 96 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:1375", + "pc": [ + 97, + 98 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:1375", + "pc": [ + 99, + 100, + 101 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:1375", + "pc": [ + 102 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:1375", + "pc": [ + 103, + 104 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:1375", + "pc": [ + 105, + 106 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:1375", + "pc": [ + 107, + 108 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:1376", + "pc": [ + 109, + 110 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:1376", + "pc": [ + 111, + 112 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:1376", + "pc": [ + 113 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:1376", + "pc": [ + 114, + 115, + 116 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:1376", + "pc": [ + 117, + 118, + 119 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:1377", + "pc": [ + 120, + 121 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:1377", + "pc": [ + 122, + 123 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:1377", + "pc": [ + 124 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:1377", + "pc": [ + 125, + 126 + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:1375", + "pc": [ + 127, + 128 + ] + }, + { + "teal": 92, + "source": "tests/contracts/abi.algo.ts:1375", + "pc": [ + 129, + 130 + ] + }, + { + "teal": 93, + "source": "tests/contracts/abi.algo.ts:1375", + "pc": [ + 131 + ] + }, + { + "teal": 94, + "source": "tests/contracts/abi.algo.ts:1375", + "pc": [ + 132 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:1375", + "pc": [ + 133, + 134 + ] + }, + { + "teal": 96, + "source": "tests/contracts/abi.algo.ts:1375", + "pc": [ + 135 + ] + }, + { + "teal": 97, + "source": "tests/contracts/abi.algo.ts:1375", + "pc": [ + 136, + 137, + 138 + ] + }, + { + "teal": 98, + "source": "tests/contracts/abi.algo.ts:1375", + "pc": [ + 139, + 140 + ] + }, + { + "teal": 99, + "source": "tests/contracts/abi.algo.ts:1375", + "pc": [ + 141, + 142 + ] + }, + { + "teal": 100, + "source": "tests/contracts/abi.algo.ts:1375", + "pc": [ + 143, + 144 + ] + }, + { + "teal": 101, + "source": "tests/contracts/abi.algo.ts:1375", + "pc": [ + 145, + 146 + ] + }, + { + "teal": 102, + "source": "tests/contracts/abi.algo.ts:1375", + "pc": [ + 147 + ] + }, + { + "teal": 103, + "source": "tests/contracts/abi.algo.ts:1375", + "pc": [ + 148 + ] + }, + { + "teal": 104, + "source": "tests/contracts/abi.algo.ts:1375", + "pc": [ + 149, + 150 + ] + }, + { + "teal": 105, + "source": "tests/contracts/abi.algo.ts:1375", + "pc": [ + 151, + 152, + 153 + ] + }, + { + "teal": 110, + "source": "tests/contracts/abi.algo.ts:1379", + "pc": [ + 154, + 155 + ] + }, + { + "teal": 113, + "source": "tests/contracts/abi.algo.ts:1371", + "pc": [ + 156, + 157 + ] + }, + { + "teal": 116, + "source": "tests/contracts/abi.algo.ts:1371", + "pc": [ + 158, + 159 + ] + }, + { + "teal": 117, + "source": "tests/contracts/abi.algo.ts:1371", + "pc": [ + 160 + ] + }, + { + "teal": 120, + "source": "tests/contracts/abi.algo.ts:1370", + "pc": [ + 161, + 162 + ] + }, + { + "teal": 121, + "source": "tests/contracts/abi.algo.ts:1370", + "pc": [ + 163 + ] + }, + { + "teal": 124, + "source": "tests/contracts/abi.algo.ts:1370", + "pc": [ + 164, + 165, + 166, + 167, + 168, + 169 + ] + }, + { + "teal": 125, + "source": "tests/contracts/abi.algo.ts:1370", + "pc": [ + 170, + 171, + 172 + ] + }, + { + "teal": 126, + "source": "tests/contracts/abi.algo.ts:1370", + "pc": [ + 173, + 174, + 175, + 176 + ] + }, + { + "teal": 129, + "source": "tests/contracts/abi.algo.ts:1370", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 177 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 132, + "source": "tests/contracts/abi.algo.ts:1370", + "pc": [ + 178, + 179, + 180, + 181, + 182, + 183 + ] + }, + { + "teal": 133, + "source": "tests/contracts/abi.algo.ts:1370", + "pc": [ + 184, + 185, + 186 + ] + }, + { + "teal": 134, + "source": "tests/contracts/abi.algo.ts:1370", + "pc": [ + 187, + 188, + 189, + 190 + ] }, { + "teal": 137, + "source": "tests/contracts/abi.algo.ts:1370", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 191 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestForOfBreak.arc56_draft.json b/tests/contracts/artifacts/ABITestForOfBreak.arc56_draft.json index 433ea5b32..700a7f378 100644 --- a/tests/contracts/artifacts/ABITestForOfBreak.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestForOfBreak.arc56_draft.json @@ -64,22 +64,619 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1496", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:1496", + "pc": [ + 1, + 2, + 3 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1496", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1496", + "pc": [ + 6 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1496", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1496", + "pc": [ + 9 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1496", + "pc": [ + 10, + 11 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1496", + "pc": [ + 12 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:1496", + "pc": [ + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:1496", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 39 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:1497", + "pc": [ + 40, + 41, + 42, + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1497", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1497", + "pc": [ + 49 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1497", + "pc": [ + 50 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1497", + "pc": [ + 51 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:1497", + "pc": [ + 52, + 53 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:1497", + "pc": [ + 54 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:1497", + "pc": [ + 55, + 56, + 57 + ] }, { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:1497", + "pc": [ + 58, + 59 + ] + }, + { + "teal": 45, + "source": "tests/contracts/abi.algo.ts:1497", + "pc": [ + 60, + 61 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:1498", + "pc": [ + 62, + 63, + 64, + 65, + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82, + 83, + 84, + 85, + 86, + 87 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:1498", + "pc": [ + 88, + 89 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:1499", + "pc": [ + 90, + 91 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:1499", + "pc": [ + 92, + 93 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:1502", + "pc": [ + 94, + 95 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:1502", + "pc": [ + 96 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:1502", + "pc": [ + 97, + 98 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:1502", + "pc": [ + 99, + 100, + 101 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:1502", + "pc": [ + 102 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:1502", + "pc": [ + 103, + 104 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:1502", + "pc": [ + 105, + 106 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:1502", + "pc": [ + 107, + 108 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:1504", + "pc": [ + 109, + 110 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:1504", + "pc": [ + 111, + 112 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:1504", + "pc": [ + 113 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:1504", + "pc": [ + 114, + 115, + 116 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:1504", + "pc": [ + 117, + 118, + 119 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:1505", + "pc": [ + 120, + 121 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:1505", + "pc": [ + 122, + 123 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:1505", + "pc": [ + 124 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:1505", + "pc": [ + 125, + 126 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:1502", + "pc": [ + 127, + 128 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:1502", + "pc": [ + 129, + 130 + ] + }, + { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:1502", + "pc": [ + 131 + ] + }, + { + "teal": 90, + "source": "tests/contracts/abi.algo.ts:1502", + "pc": [ + 132 + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:1502", + "pc": [ + 133, + 134 + ] + }, + { + "teal": 92, + "source": "tests/contracts/abi.algo.ts:1502", + "pc": [ + 135 + ] + }, + { + "teal": 93, + "source": "tests/contracts/abi.algo.ts:1502", + "pc": [ + 136, + 137, + 138 + ] + }, + { + "teal": 94, + "source": "tests/contracts/abi.algo.ts:1502", + "pc": [ + 139, + 140 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:1502", + "pc": [ + 141, + 142 + ] + }, + { + "teal": 96, + "source": "tests/contracts/abi.algo.ts:1502", + "pc": [ + 143, + 144 + ] + }, + { + "teal": 97, + "source": "tests/contracts/abi.algo.ts:1502", + "pc": [ + 145, + 146 + ] + }, + { + "teal": 98, + "source": "tests/contracts/abi.algo.ts:1502", + "pc": [ + 147 + ] + }, + { + "teal": 99, + "source": "tests/contracts/abi.algo.ts:1502", + "pc": [ + 148 + ] + }, + { + "teal": 100, + "source": "tests/contracts/abi.algo.ts:1502", + "pc": [ + 149, + 150 + ] + }, + { + "teal": 101, + "source": "tests/contracts/abi.algo.ts:1502", + "pc": [ + 151, + 152, + 153 + ] + }, + { + "teal": 106, + "source": "tests/contracts/abi.algo.ts:1507", + "pc": [ + 154, + 155 + ] + }, + { + "teal": 109, + "source": "tests/contracts/abi.algo.ts:1497", + "pc": [ + 156, + 157 + ] + }, + { + "teal": 112, + "source": "tests/contracts/abi.algo.ts:1497", + "pc": [ + 158, + 159 + ] + }, + { + "teal": 113, + "source": "tests/contracts/abi.algo.ts:1497", + "pc": [ + 160 + ] + }, + { + "teal": 116, + "source": "tests/contracts/abi.algo.ts:1496", + "pc": [ + 161, + 162 + ] + }, + { + "teal": 117, + "source": "tests/contracts/abi.algo.ts:1496", + "pc": [ + 163 + ] + }, + { + "teal": 120, + "source": "tests/contracts/abi.algo.ts:1496", + "pc": [ + 164, + 165, + 166, + 167, + 168, + 169 + ] + }, + { + "teal": 121, + "source": "tests/contracts/abi.algo.ts:1496", + "pc": [ + 170, + 171, + 172 + ] + }, + { + "teal": 122, + "source": "tests/contracts/abi.algo.ts:1496", + "pc": [ + 173, + 174, + 175, + 176 + ] + }, + { + "teal": 125, + "source": "tests/contracts/abi.algo.ts:1496", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 177 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 128, + "source": "tests/contracts/abi.algo.ts:1496", + "pc": [ + 178, + 179, + 180, + 181, + 182, + 183 + ] + }, + { + "teal": 129, + "source": "tests/contracts/abi.algo.ts:1496", + "pc": [ + 184, + 185, + 186 + ] + }, + { + "teal": 130, + "source": "tests/contracts/abi.algo.ts:1496", + "pc": [ + 187, + 188, + 189, + 190 + ] }, { + "teal": 133, + "source": "tests/contracts/abi.algo.ts:1496", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 191 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestForOfContinue.arc56_draft.json b/tests/contracts/artifacts/ABITestForOfContinue.arc56_draft.json index b72095b52..e72b99db1 100644 --- a/tests/contracts/artifacts/ABITestForOfContinue.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestForOfContinue.arc56_draft.json @@ -64,22 +64,619 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1481", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:1481", + "pc": [ + 1, + 2, + 3 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1481", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1481", + "pc": [ + 6 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1481", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1481", + "pc": [ + 9 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1481", + "pc": [ + 10, + 11 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1481", + "pc": [ + 12 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:1481", + "pc": [ + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:1481", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 39 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:1482", + "pc": [ + 40, + 41, + 42, + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1482", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1482", + "pc": [ + 49 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1482", + "pc": [ + 50 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1482", + "pc": [ + 51 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:1482", + "pc": [ + 52, + 53 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:1482", + "pc": [ + 54 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:1482", + "pc": [ + 55, + 56, + 57 + ] }, { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:1482", + "pc": [ + 58, + 59 + ] + }, + { + "teal": 45, + "source": "tests/contracts/abi.algo.ts:1482", + "pc": [ + 60, + 61 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:1483", + "pc": [ + 62, + 63, + 64, + 65, + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82, + 83, + 84, + 85, + 86, + 87 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:1483", + "pc": [ + 88, + 89 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:1484", + "pc": [ + 90, + 91 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:1484", + "pc": [ + 92, + 93 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:1487", + "pc": [ + 94, + 95 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:1487", + "pc": [ + 96 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:1487", + "pc": [ + 97, + 98 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:1487", + "pc": [ + 99, + 100, + 101 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:1487", + "pc": [ + 102 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:1487", + "pc": [ + 103, + 104 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:1487", + "pc": [ + 105, + 106 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:1487", + "pc": [ + 107, + 108 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:1489", + "pc": [ + 109, + 110 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:1489", + "pc": [ + 111, + 112 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:1489", + "pc": [ + 113 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:1489", + "pc": [ + 114, + 115, + 116 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:1489", + "pc": [ + 117, + 118, + 119 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:1490", + "pc": [ + 120, + 121 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:1490", + "pc": [ + 122, + 123 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:1490", + "pc": [ + 124 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:1490", + "pc": [ + 125, + 126 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:1487", + "pc": [ + 127, + 128 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:1487", + "pc": [ + 129, + 130 + ] + }, + { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:1487", + "pc": [ + 131 + ] + }, + { + "teal": 90, + "source": "tests/contracts/abi.algo.ts:1487", + "pc": [ + 132 + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:1487", + "pc": [ + 133, + 134 + ] + }, + { + "teal": 92, + "source": "tests/contracts/abi.algo.ts:1487", + "pc": [ + 135 + ] + }, + { + "teal": 93, + "source": "tests/contracts/abi.algo.ts:1487", + "pc": [ + 136, + 137, + 138 + ] + }, + { + "teal": 94, + "source": "tests/contracts/abi.algo.ts:1487", + "pc": [ + 139, + 140 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:1487", + "pc": [ + 141, + 142 + ] + }, + { + "teal": 96, + "source": "tests/contracts/abi.algo.ts:1487", + "pc": [ + 143, + 144 + ] + }, + { + "teal": 97, + "source": "tests/contracts/abi.algo.ts:1487", + "pc": [ + 145, + 146 + ] + }, + { + "teal": 98, + "source": "tests/contracts/abi.algo.ts:1487", + "pc": [ + 147 + ] + }, + { + "teal": 99, + "source": "tests/contracts/abi.algo.ts:1487", + "pc": [ + 148 + ] + }, + { + "teal": 100, + "source": "tests/contracts/abi.algo.ts:1487", + "pc": [ + 149, + 150 + ] + }, + { + "teal": 101, + "source": "tests/contracts/abi.algo.ts:1487", + "pc": [ + 151, + 152, + 153 + ] + }, + { + "teal": 106, + "source": "tests/contracts/abi.algo.ts:1492", + "pc": [ + 154, + 155 + ] + }, + { + "teal": 109, + "source": "tests/contracts/abi.algo.ts:1482", + "pc": [ + 156, + 157 + ] + }, + { + "teal": 112, + "source": "tests/contracts/abi.algo.ts:1482", + "pc": [ + 158, + 159 + ] + }, + { + "teal": 113, + "source": "tests/contracts/abi.algo.ts:1482", + "pc": [ + 160 + ] + }, + { + "teal": 116, + "source": "tests/contracts/abi.algo.ts:1481", + "pc": [ + 161, + 162 + ] + }, + { + "teal": 117, + "source": "tests/contracts/abi.algo.ts:1481", + "pc": [ + 163 + ] + }, + { + "teal": 120, + "source": "tests/contracts/abi.algo.ts:1481", + "pc": [ + 164, + 165, + 166, + 167, + 168, + 169 + ] + }, + { + "teal": 121, + "source": "tests/contracts/abi.algo.ts:1481", + "pc": [ + 170, + 171, + 172 + ] + }, + { + "teal": 122, + "source": "tests/contracts/abi.algo.ts:1481", + "pc": [ + 173, + 174, + 175, + 176 + ] + }, + { + "teal": 125, + "source": "tests/contracts/abi.algo.ts:1481", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 177 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 128, + "source": "tests/contracts/abi.algo.ts:1481", + "pc": [ + 178, + 179, + 180, + 181, + 182, + 183 + ] + }, + { + "teal": 129, + "source": "tests/contracts/abi.algo.ts:1481", + "pc": [ + 184, + 185, + 186 + ] + }, + { + "teal": 130, + "source": "tests/contracts/abi.algo.ts:1481", + "pc": [ + 187, + 188, + 189, + 190 + ] }, { + "teal": 133, + "source": "tests/contracts/abi.algo.ts:1481", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 191 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestGlobalMethodInChain.arc56_draft.json b/tests/contracts/artifacts/ABITestGlobalMethodInChain.arc56_draft.json index 53fd924c8..df4e8329b 100644 --- a/tests/contracts/artifacts/ABITestGlobalMethodInChain.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestGlobalMethodInChain.arc56_draft.json @@ -64,28 +64,316 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1059", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:1059", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1059", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1059", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1059", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1059", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1059", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1059", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:1059", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] }, { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:1060", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:1060", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1060", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1060", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1060", + "pc": [ + 48 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1060", + "pc": [ + 49, + 50 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:1060", + "pc": [ + 51 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:1060", + "errorMessage": "globalMethodInChain return value overflowed 8 bits", "pc": [ 52 - ], - "errorMessage": "globalMethodInChain return value overflowed 8 bits" + ] }, { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:1060", + "pc": [ + 53, + 54, + 55 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:1060", + "pc": [ + 56 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:1060", + "pc": [ + 57 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:1060", + "pc": [ + 58, + 59 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:1060", + "pc": [ + 60 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:1060", + "pc": [ + 61, + 62, + 63 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:1061", + "pc": [ + 64, + 65 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:1060", + "pc": [ + 66 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:1059", + "pc": [ + 67, + 68 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:1059", + "pc": [ + 69 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:1059", + "pc": [ + 70, + 71, + 72, + 73, + 74, + 75 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:1059", + "pc": [ + 76, + 77, + 78 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:1059", + "pc": [ + 79, + 80, + 81, + 82 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:1059", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 83 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:1059", + "pc": [ + 84, + 85, + 86, + 87, + 88, + 89 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:1059", + "pc": [ + 90, + 91, + 92 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:1059", + "pc": [ + 93, + 94, + 95, + 96 + ] }, { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:1059", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 97 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestLargeNestedStaticForEachInBox.arc56_draft.json b/tests/contracts/artifacts/ABITestLargeNestedStaticForEachInBox.arc56_draft.json index e09143166..c716f8b09 100644 --- a/tests/contracts/artifacts/ABITestLargeNestedStaticForEachInBox.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestLargeNestedStaticForEachInBox.arc56_draft.json @@ -70,22 +70,729 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1354", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:1354", + "pc": [ + 1, + 2, + 3, + 4, + 5, + 6, + 7, + 8, + 9, + 10, + 11, + 12 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1354", + "pc": [ + 13, + 14 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1354", + "pc": [ + 15 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1354", + "pc": [ + 16, + 17 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1354", + "pc": [ + 18 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1354", + "pc": [ + 19, + 20 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1354", + "pc": [ + 21 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:1354", + "pc": [ + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38, + 39, + 40, + 41, + 42, + 43, + 44, + 45, + 46, + 47 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:1354", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 48 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:1357", + "pc": [ + 49, + 50, + 51, + 52, + 53, + 54 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1357", + "pc": [ + 55, + 56, + 57 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1357", + "pc": [ + 58 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1357", + "pc": [ + 59 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1357", + "pc": [ + 60 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:1357", + "pc": [ + 61, + 62 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:1357", + "pc": [ + 63 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:1357", + "pc": [ + 64, + 65, + 66 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:1357", + "pc": [ + 67, + 68 + ] + }, + { + "teal": 45, + "source": "tests/contracts/abi.algo.ts:1357", + "pc": [ + 69, + 70 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:1358", + "pc": [ + 71 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:1358", + "pc": [ + 72, + 73 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:1358", + "pc": [ + 74, + 75 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:1358", + "pc": [ + 76, + 77 + ] }, { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:1358", + "pc": [ + 78, + 79 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:1358", + "pc": [ + 80, + 81, + 82, + 83, + 84 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:1358", + "pc": [ + 85 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:1358", + "pc": [ + 86, + 87 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:1358", + "pc": [ + 88, + 89 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:1358", + "pc": [ + 90, + 91 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:1358", + "pc": [ + 92, + 93 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:1358", + "pc": [ + 94 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:1359", + "pc": [ + 95, + 96, + 97, + 98, + 99, + 100 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:1359", + "pc": [ + 101, + 102, + 103 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:1359", + "pc": [ + 104 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:1359", + "pc": [ + 105 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:1360", + "pc": [ + 106, + 107 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:1360", + "pc": [ + 108, + 109 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:1362", + "pc": [ + 110, + 111 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:1362", + "pc": [ + 112, + 113, + 114 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:1362", + "pc": [ + 115, + 116, + 117, + 118, + 119, + 120 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:1362", + "pc": [ + 121, + 122 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:1362", + "pc": [ + 123 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:1362", + "pc": [ + 124 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:1362", + "pc": [ + 125, + 126 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:1362", + "pc": [ + 127 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:1362", + "pc": [ + 128, + 129 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:1362", + "pc": [ + 130, + 131, + 132, + 133, + 134, + 135 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:1362", + "pc": [ + 136, + 137 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:1362", + "pc": [ + 138, + 139 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:1362", + "pc": [ + 140 + ] + }, + { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:1362", + "pc": [ + 141, + 142 + ] + }, + { + "teal": 94, + "source": "tests/contracts/abi.algo.ts:1363", + "pc": [ + 143, + 144 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:1363", + "pc": [ + 145, + 146 + ] + }, + { + "teal": 96, + "source": "tests/contracts/abi.algo.ts:1363", + "pc": [ + 147 + ] + }, + { + "teal": 97, + "source": "tests/contracts/abi.algo.ts:1363", + "pc": [ + 148, + 149 + ] + }, + { + "teal": 100, + "source": "tests/contracts/abi.algo.ts:1362", + "pc": [ + 150, + 151 + ] + }, + { + "teal": 101, + "source": "tests/contracts/abi.algo.ts:1362", + "pc": [ + 152, + 153 + ] + }, + { + "teal": 102, + "source": "tests/contracts/abi.algo.ts:1362", + "pc": [ + 154 + ] + }, + { + "teal": 103, + "source": "tests/contracts/abi.algo.ts:1362", + "pc": [ + 155 + ] + }, + { + "teal": 104, + "source": "tests/contracts/abi.algo.ts:1362", + "pc": [ + 156, + 157 + ] + }, + { + "teal": 105, + "source": "tests/contracts/abi.algo.ts:1362", + "pc": [ + 158 + ] + }, + { + "teal": 106, + "source": "tests/contracts/abi.algo.ts:1362", + "pc": [ + 159, + 160, + 161 + ] + }, + { + "teal": 107, + "source": "tests/contracts/abi.algo.ts:1362", + "pc": [ + 162, + 163 + ] + }, + { + "teal": 108, + "source": "tests/contracts/abi.algo.ts:1362", + "pc": [ + 164, + 165, + 166, + 167, + 168, + 169 + ] + }, + { + "teal": 109, + "source": "tests/contracts/abi.algo.ts:1362", + "pc": [ + 170, + 171 + ] + }, + { + "teal": 110, + "source": "tests/contracts/abi.algo.ts:1362", + "pc": [ + 172, + 173 + ] + }, + { + "teal": 111, + "source": "tests/contracts/abi.algo.ts:1362", + "pc": [ + 174 + ] + }, + { + "teal": 112, + "source": "tests/contracts/abi.algo.ts:1362", + "pc": [ + 175, + 176 + ] + }, + { + "teal": 113, + "source": "tests/contracts/abi.algo.ts:1362", + "pc": [ + 177, + 178, + 179 + ] + }, + { + "teal": 118, + "source": "tests/contracts/abi.algo.ts:1366", + "pc": [ + 180, + 181 + ] + }, + { + "teal": 121, + "source": "tests/contracts/abi.algo.ts:1357", + "pc": [ + 182, + 183 + ] + }, + { + "teal": 124, + "source": "tests/contracts/abi.algo.ts:1357", + "pc": [ + 184, + 185 + ] + }, + { + "teal": 125, + "source": "tests/contracts/abi.algo.ts:1357", + "pc": [ + 186 + ] + }, + { + "teal": 128, + "source": "tests/contracts/abi.algo.ts:1354", + "pc": [ + 187, + 188 + ] + }, + { + "teal": 129, + "source": "tests/contracts/abi.algo.ts:1354", + "pc": [ + 189 + ] + }, + { + "teal": 132, + "source": "tests/contracts/abi.algo.ts:1354", + "pc": [ + 190, + 191, + 192, + 193, + 194, + 195 + ] + }, + { + "teal": 133, + "source": "tests/contracts/abi.algo.ts:1354", + "pc": [ + 196, + 197, + 198 + ] + }, + { + "teal": 134, + "source": "tests/contracts/abi.algo.ts:1354", + "pc": [ + 199, + 200, + 201, + 202 + ] + }, + { + "teal": 137, + "source": "tests/contracts/abi.algo.ts:1354", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 203 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 140, + "source": "tests/contracts/abi.algo.ts:1354", + "pc": [ + 204, + 205, + 206, + 207, + 208, + 209 + ] + }, + { + "teal": 141, + "source": "tests/contracts/abi.algo.ts:1354", + "pc": [ + 210, + 211, + 212 + ] + }, + { + "teal": 142, + "source": "tests/contracts/abi.algo.ts:1354", + "pc": [ + 213, + 214, + 215, + 216 + ] }, { + "teal": 145, + "source": "tests/contracts/abi.algo.ts:1354", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 217 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestLargeNestedStaticForOfInBox.arc56_draft.json b/tests/contracts/artifacts/ABITestLargeNestedStaticForOfInBox.arc56_draft.json index b93f733ea..0f229f5a5 100644 --- a/tests/contracts/artifacts/ABITestLargeNestedStaticForOfInBox.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestLargeNestedStaticForOfInBox.arc56_draft.json @@ -70,22 +70,729 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1464", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:1464", + "pc": [ + 1, + 2, + 3, + 4, + 5, + 6, + 7, + 8, + 9, + 10, + 11, + 12 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1464", + "pc": [ + 13, + 14 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1464", + "pc": [ + 15 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1464", + "pc": [ + 16, + 17 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1464", + "pc": [ + 18 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1464", + "pc": [ + 19, + 20 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1464", + "pc": [ + 21 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:1464", + "pc": [ + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38, + 39, + 40, + 41, + 42, + 43, + 44, + 45, + 46, + 47 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:1464", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 48 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:1467", + "pc": [ + 49, + 50, + 51, + 52, + 53, + 54 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1467", + "pc": [ + 55, + 56, + 57 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1467", + "pc": [ + 58 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1467", + "pc": [ + 59 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1467", + "pc": [ + 60 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:1467", + "pc": [ + 61, + 62 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:1467", + "pc": [ + 63 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:1467", + "pc": [ + 64, + 65, + 66 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:1467", + "pc": [ + 67, + 68 + ] + }, + { + "teal": 45, + "source": "tests/contracts/abi.algo.ts:1467", + "pc": [ + 69, + 70 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:1468", + "pc": [ + 71 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:1468", + "pc": [ + 72, + 73 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:1468", + "pc": [ + 74, + 75 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:1468", + "pc": [ + 76, + 77 + ] }, { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:1468", + "pc": [ + 78, + 79 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:1468", + "pc": [ + 80, + 81, + 82, + 83, + 84 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:1468", + "pc": [ + 85 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:1468", + "pc": [ + 86, + 87 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:1468", + "pc": [ + 88, + 89 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:1468", + "pc": [ + 90, + 91 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:1468", + "pc": [ + 92, + 93 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:1468", + "pc": [ + 94 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:1469", + "pc": [ + 95, + 96, + 97, + 98, + 99, + 100 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:1469", + "pc": [ + 101, + 102, + 103 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:1469", + "pc": [ + 104 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:1469", + "pc": [ + 105 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:1470", + "pc": [ + 106, + 107 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:1470", + "pc": [ + 108, + 109 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:1473", + "pc": [ + 110, + 111 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:1473", + "pc": [ + 112, + 113, + 114 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:1473", + "pc": [ + 115, + 116, + 117, + 118, + 119, + 120 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:1473", + "pc": [ + 121, + 122 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:1473", + "pc": [ + 123 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:1473", + "pc": [ + 124 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:1473", + "pc": [ + 125, + 126 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:1473", + "pc": [ + 127 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:1473", + "pc": [ + 128, + 129 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:1473", + "pc": [ + 130, + 131, + 132, + 133, + 134, + 135 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:1473", + "pc": [ + 136, + 137 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:1473", + "pc": [ + 138, + 139 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:1473", + "pc": [ + 140 + ] + }, + { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:1473", + "pc": [ + 141, + 142 + ] + }, + { + "teal": 94, + "source": "tests/contracts/abi.algo.ts:1474", + "pc": [ + 143, + 144 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:1474", + "pc": [ + 145, + 146 + ] + }, + { + "teal": 96, + "source": "tests/contracts/abi.algo.ts:1474", + "pc": [ + 147 + ] + }, + { + "teal": 97, + "source": "tests/contracts/abi.algo.ts:1474", + "pc": [ + 148, + 149 + ] + }, + { + "teal": 101, + "source": "tests/contracts/abi.algo.ts:1473", + "pc": [ + 150, + 151 + ] + }, + { + "teal": 102, + "source": "tests/contracts/abi.algo.ts:1473", + "pc": [ + 152, + 153 + ] + }, + { + "teal": 103, + "source": "tests/contracts/abi.algo.ts:1473", + "pc": [ + 154 + ] + }, + { + "teal": 104, + "source": "tests/contracts/abi.algo.ts:1473", + "pc": [ + 155 + ] + }, + { + "teal": 105, + "source": "tests/contracts/abi.algo.ts:1473", + "pc": [ + 156, + 157 + ] + }, + { + "teal": 106, + "source": "tests/contracts/abi.algo.ts:1473", + "pc": [ + 158 + ] + }, + { + "teal": 107, + "source": "tests/contracts/abi.algo.ts:1473", + "pc": [ + 159, + 160, + 161 + ] + }, + { + "teal": 108, + "source": "tests/contracts/abi.algo.ts:1473", + "pc": [ + 162, + 163 + ] + }, + { + "teal": 109, + "source": "tests/contracts/abi.algo.ts:1473", + "pc": [ + 164, + 165, + 166, + 167, + 168, + 169 + ] + }, + { + "teal": 110, + "source": "tests/contracts/abi.algo.ts:1473", + "pc": [ + 170, + 171 + ] + }, + { + "teal": 111, + "source": "tests/contracts/abi.algo.ts:1473", + "pc": [ + 172, + 173 + ] + }, + { + "teal": 112, + "source": "tests/contracts/abi.algo.ts:1473", + "pc": [ + 174 + ] + }, + { + "teal": 113, + "source": "tests/contracts/abi.algo.ts:1473", + "pc": [ + 175, + 176 + ] + }, + { + "teal": 114, + "source": "tests/contracts/abi.algo.ts:1473", + "pc": [ + 177, + 178, + 179 + ] + }, + { + "teal": 119, + "source": "tests/contracts/abi.algo.ts:1477", + "pc": [ + 180, + 181 + ] + }, + { + "teal": 122, + "source": "tests/contracts/abi.algo.ts:1467", + "pc": [ + 182, + 183 + ] + }, + { + "teal": 125, + "source": "tests/contracts/abi.algo.ts:1467", + "pc": [ + 184, + 185 + ] + }, + { + "teal": 126, + "source": "tests/contracts/abi.algo.ts:1467", + "pc": [ + 186 + ] + }, + { + "teal": 129, + "source": "tests/contracts/abi.algo.ts:1464", + "pc": [ + 187, + 188 + ] + }, + { + "teal": 130, + "source": "tests/contracts/abi.algo.ts:1464", + "pc": [ + 189 + ] + }, + { + "teal": 133, + "source": "tests/contracts/abi.algo.ts:1464", + "pc": [ + 190, + 191, + 192, + 193, + 194, + 195 + ] + }, + { + "teal": 134, + "source": "tests/contracts/abi.algo.ts:1464", + "pc": [ + 196, + 197, + 198 + ] + }, + { + "teal": 135, + "source": "tests/contracts/abi.algo.ts:1464", + "pc": [ + 199, + 200, + 201, + 202 + ] + }, + { + "teal": 138, + "source": "tests/contracts/abi.algo.ts:1464", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 203 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 141, + "source": "tests/contracts/abi.algo.ts:1464", + "pc": [ + 204, + 205, + 206, + 207, + 208, + 209 + ] + }, + { + "teal": 142, + "source": "tests/contracts/abi.algo.ts:1464", + "pc": [ + 210, + 211, + 212 + ] + }, + { + "teal": 143, + "source": "tests/contracts/abi.algo.ts:1464", + "pc": [ + 213, + 214, + 215, + 216 + ] }, { + "teal": 146, + "source": "tests/contracts/abi.algo.ts:1464", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 217 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestMaxUfixed.arc56_draft.json b/tests/contracts/artifacts/ABITestMaxUfixed.arc56_draft.json index fc0979a72..251771b78 100644 --- a/tests/contracts/artifacts/ABITestMaxUfixed.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestMaxUfixed.arc56_draft.json @@ -64,22 +64,312 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1140", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:1140", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1140", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1140", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1140", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1140", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1140", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1140", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:1140", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] }, { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:1141", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:1141", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1141", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1141", + "pc": [ + 47, + 48, + 49 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1141", + "pc": [ + 50 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1141", + "pc": [ + 51 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:1141", + "pc": [ + 52, + 53 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:1141", + "pc": [ + 54 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:1141", + "pc": [ + 55, + 56, + 57 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:1141", + "pc": [ + 58, + 59 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:1142", + "pc": [ + 60, + 61, + 62 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:1142", + "pc": [ + 63, + 64 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:1144", + "pc": [ + 65, + 66 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:1141", + "pc": [ + 67, + 68 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:1141", + "pc": [ + 69 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:1140", + "pc": [ + 70, + 71 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:1140", + "pc": [ + 72 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:1140", + "pc": [ + 73, + 74, + 75, + 76, + 77, + 78 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:1140", + "pc": [ + 79, + 80, + 81 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:1140", + "pc": [ + 82, + 83, + 84, + 85 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:1140", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 86 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:1140", + "pc": [ + 87, + 88, + 89, + 90, + 91, + 92 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:1140", + "pc": [ + 93, + 94, + 95 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:1140", + "pc": [ + 96, + 97, + 98, + 99 + ] }, { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:1140", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 100 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestMixedStaticArrayElements.arc56_draft.json b/tests/contracts/artifacts/ABITestMixedStaticArrayElements.arc56_draft.json index 34b87a2f3..bbfdf1af8 100644 --- a/tests/contracts/artifacts/ABITestMixedStaticArrayElements.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestMixedStaticArrayElements.arc56_draft.json @@ -64,22 +64,614 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:42", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:42", + "pc": [ + 1, + 2, + 3 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:42", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:42", + "pc": [ + 6 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:42", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:42", + "pc": [ + 9 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:42", + "pc": [ + 10, + 11 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:42", + "pc": [ + 12 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:42", + "pc": [ + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:42", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 39 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:43", + "pc": [ + 40, + 41, + 42, + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:43", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:43", + "pc": [ + 49 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:43", + "pc": [ + 50 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:43", + "pc": [ + 51 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:43", + "pc": [ + 52, + 53 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:43", + "pc": [ + 54 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:43", + "pc": [ + 55, + 56, + 57 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:43", + "pc": [ + 58, + 59 + ] + }, + { + "teal": 45, + "source": "tests/contracts/abi.algo.ts:43", + "pc": [ + 60, + 61 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:44", + "pc": [ + 62, + 63 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:44", + "pc": [ + 64, + 65 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:45", + "pc": [ + 66, + 67 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:45", + "pc": [ + 68, + 69 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:46", + "pc": [ + 70, + 71 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:46", + "pc": [ + 72, + 73 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:47", + "pc": [ + 74, + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82, + 83, + 84, + 85, + 86, + 87, + 88, + 89, + 90, + 91, + 92, + 93, + 94, + 95, + 96, + 97, + 98, + 99 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:47", + "pc": [ + 100, + 101 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:47", + "pc": [ + 102 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:47", + "pc": [ + 103 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:47", + "pc": [ + 104, + 105, + 106, + 107, + 108, + 109, + 110, + 111, + 112, + 113 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:47", + "pc": [ + 114 + ] }, { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:47", + "pc": [ + 115, + 116, + 117, + 118, + 119, + 120, + 121, + 122, + 123, + 124 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:47", + "pc": [ + 125 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:47", + "pc": [ + 126, + 127, + 128, + 129, + 130, + 131, + 132, + 133, + 134, + 135 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:47", + "pc": [ + 136 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:47", + "pc": [ + 137, + 138, + 139, + 140, + 141, + 142, + 143, + 144, + 145, + 146 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:47", + "pc": [ + 147 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:47", + "pc": [ + 148, + 149, + 150, + 151, + 152, + 153, + 154, + 155, + 156, + 157 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:47", + "pc": [ + 158 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:47", + "pc": [ + 159, + 160 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:49", + "pc": [ + 161, + 162 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:49", + "pc": [ + 163, + 164, + 165 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:49", + "pc": [ + 166 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:49", + "pc": [ + 167, + 168 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:49", + "pc": [ + 169, + 170, + 171 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:49", + "pc": [ + 172 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:49", + "pc": [ + 173 + ] + }, + { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:49", + "pc": [ + 174, + 175 + ] + }, + { + "teal": 90, + "source": "tests/contracts/abi.algo.ts:49", + "pc": [ + 176, + 177, + 178 + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:49", + "pc": [ + 179 + ] + }, + { + "teal": 92, + "source": "tests/contracts/abi.algo.ts:49", + "pc": [ + 180 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:43", + "pc": [ + 181, + 182 + ] + }, + { + "teal": 98, + "source": "tests/contracts/abi.algo.ts:43", + "pc": [ + 183, + 184 + ] + }, + { + "teal": 99, + "source": "tests/contracts/abi.algo.ts:43", + "pc": [ + 185 + ] + }, + { + "teal": 102, + "source": "tests/contracts/abi.algo.ts:42", + "pc": [ + 186, + 187 + ] + }, + { + "teal": 103, + "source": "tests/contracts/abi.algo.ts:42", + "pc": [ + 188 + ] + }, + { + "teal": 106, + "source": "tests/contracts/abi.algo.ts:42", + "pc": [ + 189, + 190, + 191, + 192, + 193, + 194 + ] + }, + { + "teal": 107, + "source": "tests/contracts/abi.algo.ts:42", + "pc": [ + 195, + 196, + 197 + ] + }, + { + "teal": 108, + "source": "tests/contracts/abi.algo.ts:42", + "pc": [ + 198, + 199, + 200, + 201 + ] + }, + { + "teal": 111, + "source": "tests/contracts/abi.algo.ts:42", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 202 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 114, + "source": "tests/contracts/abi.algo.ts:42", + "pc": [ + 203, + 204, + 205, + 206, + 207, + 208 + ] + }, + { + "teal": 115, + "source": "tests/contracts/abi.algo.ts:42", + "pc": [ + 209, + 210, + 211 + ] + }, + { + "teal": 116, + "source": "tests/contracts/abi.algo.ts:42", + "pc": [ + 212, + 213, + 214, + 215 + ] }, { + "teal": 119, + "source": "tests/contracts/abi.algo.ts:42", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 216 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestMultiBytesTuple.arc56_draft.json b/tests/contracts/artifacts/ABITestMultiBytesTuple.arc56_draft.json index 2834b04a8..07d061c94 100644 --- a/tests/contracts/artifacts/ABITestMultiBytesTuple.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestMultiBytesTuple.arc56_draft.json @@ -64,22 +64,513 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1217", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:1217", + "pc": [ + 1, + 2, + 3 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1217", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1217", + "pc": [ + 6 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1217", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1217", + "pc": [ + 9 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1217", + "pc": [ + 10, + 11 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1217", + "pc": [ + 12 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:1217", + "pc": [ + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:1217", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 39 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:1218", + "pc": [ + 40, + 41, + 42, + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1218", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1218", + "pc": [ + 49 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1218", + "pc": [ + 50 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1218", + "pc": [ + 51, + 52 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:1218", + "pc": [ + 53 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:1218", + "pc": [ + 54, + 55, + 56 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:1219", + "pc": [ + 57, + 58 + ] + }, + { + "teal": 45, + "source": "tests/contracts/abi.algo.ts:1219", + "pc": [ + 59, + 60 + ] + }, + { + "teal": 46, + "source": "tests/contracts/abi.algo.ts:1219", + "pc": [ + 61, + 62, + 63, + 64 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:1219", + "pc": [ + 65, + 66, + 67, + 68, + 69 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:1219", + "pc": [ + 70, + 71, + 72 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:1219", + "pc": [ + 73, + 74, + 75, + 76, + 77 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:1219", + "pc": [ + 78, + 79, + 80 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:1219", + "pc": [ + 81 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:1219", + "pc": [ + 82 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:1218", + "pc": [ + 83 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:1217", + "pc": [ + 84, + 85 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:1217", + "pc": [ + 86 + ] }, { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:1217", + "pc": [ + 87, + 88, + 89, + 90, + 91, + 92 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:1217", + "pc": [ + 93, + 94, + 95 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:1217", + "pc": [ + 96, + 97, + 98, + 99 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:1217", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 100 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] }, { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:1217", + "pc": [ + 101, + 102, + 103, + 104, + 105, + 106 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:1217", + "pc": [ + 107, + 108, + 109 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:1217", + "pc": [ + 110, + 111, + 112, + 113 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:1217", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 114 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:1217", + "pc": [ + 115, + 116, + 117 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:1217", + "pc": [ + 118, + 119 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:1217", + "pc": [ + 120, + 121 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:1217", + "pc": [ + 122 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:1217", + "pc": [ + 123, + 124 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:1217", + "pc": [ + 125, + 126 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:1217", + "pc": [ + 127 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:1217", + "pc": [ + 128 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:1217", + "pc": [ + 129, + 130 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:1217", + "pc": [ + 131 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:1217", + "pc": [ + 132 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:1217", + "pc": [ + 133 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:1217", + "pc": [ + 134, + 135, + 136 + ] + }, + { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:1217", + "pc": [ + 137, + 138 + ] + }, + { + "teal": 90, + "source": "tests/contracts/abi.algo.ts:1217", + "pc": [ + 139, + 140 + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:1217", + "pc": [ + 141 + ] + }, + { + "teal": 92, + "source": "tests/contracts/abi.algo.ts:1217", + "pc": [ + 142 + ] + }, + { + "teal": 93, + "source": "tests/contracts/abi.algo.ts:1217", + "pc": [ + 143, + 144 + ] + }, + { + "teal": 94, + "source": "tests/contracts/abi.algo.ts:1217", + "pc": [ + 145, + 146 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:1217", + "pc": [ + 147, + 148 + ] + }, + { + "teal": 96, + "source": "tests/contracts/abi.algo.ts:1217", + "pc": [ + 149, + 150 + ] + }, + { + "teal": 97, + "source": "tests/contracts/abi.algo.ts:1217", + "pc": [ + 151 + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestMultiNestedArrayRef.arc56_draft.json b/tests/contracts/artifacts/ABITestMultiNestedArrayRef.arc56_draft.json index 218a0103f..e970da334 100644 --- a/tests/contracts/artifacts/ABITestMultiNestedArrayRef.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestMultiNestedArrayRef.arc56_draft.json @@ -64,22 +64,336 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:791", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:791", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:791", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:791", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:791", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:791", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:791", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:791", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:791", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:792", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] }, { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:792", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:792", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:792", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:792", + "pc": [ + 48, + 49 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:792", + "pc": [ + 50 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:792", + "pc": [ + 51, + 52, + 53 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:792", + "pc": [ + 54, + 55 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:793", + "pc": [ + 56, + 57, + 58, + 59, + 60, + 61, + 62, + 63, + 64, + 65 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:793", + "pc": [ + 66, + 67 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:807", + "pc": [ + 68, + 69 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:807", + "pc": [ + 70, + 71, + 72 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:807", + "pc": [ + 73, + 74 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:807", + "pc": [ + 75, + 76 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:809", + "pc": [ + 77, + 78 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:792", + "pc": [ + 79, + 80 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:792", + "pc": [ + 81 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:791", + "pc": [ + 82, + 83 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:791", + "pc": [ + 84 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:791", + "pc": [ + 85, + 86, + 87, + 88, + 89, + 90 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:791", + "pc": [ + 91, + 92, + 93 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:791", + "pc": [ + 94, + 95, + 96, + 97 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:791", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 98 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 90, + "source": "tests/contracts/abi.algo.ts:791", + "pc": [ + 99, + 100, + 101, + 102, + 103, + 104 + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:791", + "pc": [ + 105, + 106, + 107 + ] + }, + { + "teal": 92, + "source": "tests/contracts/abi.algo.ts:791", + "pc": [ + 108, + 109, + 110, + 111 + ] }, { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:791", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 112 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestNamedTuple.arc56_draft.json b/tests/contracts/artifacts/ABITestNamedTuple.arc56_draft.json index fc1cf015a..9f7007c09 100644 --- a/tests/contracts/artifacts/ABITestNamedTuple.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestNamedTuple.arc56_draft.json @@ -64,22 +64,776 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:600", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:600", + "pc": [ + 1, + 2, + 3 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:600", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:600", + "pc": [ + 6 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:600", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:600", + "pc": [ + 9 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:600", + "pc": [ + 10, + 11 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:600", + "pc": [ + 12 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:600", + "pc": [ + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:600", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 39 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:601", + "pc": [ + 40, + 41, + 42, + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:601", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:601", + "pc": [ + 49 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:601", + "pc": [ + 50 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:601", + "pc": [ + 51 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:601", + "pc": [ + 52, + 53, + 54 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:601", + "pc": [ + 55 + ] + }, + { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:601", + "pc": [ + 56 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:601", + "pc": [ + 57 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:601", + "pc": [ + 58 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:601", + "pc": [ + 59, + 60 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:601", + "pc": [ + 61 + ] + }, + { + "teal": 46, + "source": "tests/contracts/abi.algo.ts:601", + "pc": [ + 62, + 63, + 64 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:601", + "pc": [ + 65, + 66 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:605", + "pc": [ + 67, + 68 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:605", + "pc": [ + 69, + 70 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:605", + "pc": [ + 71, + 72, + 73, + 74 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:606", + "pc": [ + 75, + 76, + 77, + 78 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:606", + "pc": [ + 79, + 80, + 81 + ] }, { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:607", + "pc": [ + 82, + 83, + 84, + 85, + 86, + 87, + 88, + 89, + 90, + 91, + 92, + 93, + 94, + 95, + 96, + 97 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:607", + "pc": [ + 98, + 99, + 100 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:605", + "pc": [ + 101 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:605", + "pc": [ + 102 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:602", + "pc": [ + 103, + 104 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:610", + "pc": [ + 105, + 106 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:610", + "pc": [ + 107, + 108 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:610", + "pc": [ + 109, + 110 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:610", + "pc": [ + 111, + 112 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:610", + "pc": [ + 113, + 114 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:610", + "pc": [ + 115, + 116 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:610", + "pc": [ + 117 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:610", + "pc": [ + 118 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:610", + "pc": [ + 119, + 120 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:610", + "pc": [ + 121 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:610", + "pc": [ + 122 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:610", + "pc": [ + 123, + 124 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:610", + "pc": [ + 125 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:610", + "pc": [ + 126, + 127 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:610", + "pc": [ + 128 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:610", + "pc": [ + 129 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:610", + "pc": [ + 130, + 131, + 132 + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:601", + "pc": [ + 133, + 134 + ] + }, + { + "teal": 92, + "source": "tests/contracts/abi.algo.ts:601", + "pc": [ + 135 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:600", + "pc": [ + 136, + 137 + ] + }, + { + "teal": 96, + "source": "tests/contracts/abi.algo.ts:600", + "pc": [ + 138 + ] + }, + { + "teal": 99, + "source": "tests/contracts/abi.algo.ts:600", + "pc": [ + 139, + 140, + 141, + 142, + 143, + 144 + ] + }, + { + "teal": 100, + "source": "tests/contracts/abi.algo.ts:600", + "pc": [ + 145, + 146, + 147 + ] + }, + { + "teal": 101, + "source": "tests/contracts/abi.algo.ts:600", + "pc": [ + 148, + 149, + 150, + 151 + ] + }, + { + "teal": 104, + "source": "tests/contracts/abi.algo.ts:600", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 152 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 107, + "source": "tests/contracts/abi.algo.ts:600", + "pc": [ + 153, + 154, + 155, + 156, + 157, + 158 + ] + }, + { + "teal": 108, + "source": "tests/contracts/abi.algo.ts:600", + "pc": [ + 159, + 160, + 161 + ] }, { + "teal": 109, + "source": "tests/contracts/abi.algo.ts:600", + "pc": [ + 162, + 163, + 164, + 165 + ] + }, + { + "teal": 112, + "source": "tests/contracts/abi.algo.ts:600", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 166 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] + }, + { + "teal": 115, + "source": "tests/contracts/abi.algo.ts:600", + "pc": [ + 167, + 168, + 169 + ] + }, + { + "teal": 116, + "source": "tests/contracts/abi.algo.ts:600", + "pc": [ + 170, + 171 + ] + }, + { + "teal": 117, + "source": "tests/contracts/abi.algo.ts:600", + "pc": [ + 172, + 173 + ] + }, + { + "teal": 118, + "source": "tests/contracts/abi.algo.ts:600", + "pc": [ + 174 + ] + }, + { + "teal": 119, + "source": "tests/contracts/abi.algo.ts:600", + "pc": [ + 175, + 176 + ] + }, + { + "teal": 120, + "source": "tests/contracts/abi.algo.ts:600", + "pc": [ + 177, + 178 + ] + }, + { + "teal": 121, + "source": "tests/contracts/abi.algo.ts:600", + "pc": [ + 179 + ] + }, + { + "teal": 124, + "source": "tests/contracts/abi.algo.ts:600", + "pc": [ + 180, + 181, + 182 + ] + }, + { + "teal": 125, + "source": "tests/contracts/abi.algo.ts:600", + "pc": [ + 183, + 184 + ] + }, + { + "teal": 126, + "source": "tests/contracts/abi.algo.ts:600", + "pc": [ + 185, + 186 + ] + }, + { + "teal": 127, + "source": "tests/contracts/abi.algo.ts:600", + "pc": [ + 187 + ] + }, + { + "teal": 128, + "source": "tests/contracts/abi.algo.ts:600", + "pc": [ + 188, + 189 + ] + }, + { + "teal": 129, + "source": "tests/contracts/abi.algo.ts:600", + "pc": [ + 190, + 191 + ] + }, + { + "teal": 130, + "source": "tests/contracts/abi.algo.ts:600", + "pc": [ + 192 + ] + }, + { + "teal": 131, + "source": "tests/contracts/abi.algo.ts:600", + "pc": [ + 193 + ] + }, + { + "teal": 132, + "source": "tests/contracts/abi.algo.ts:600", + "pc": [ + 194, + 195 + ] + }, + { + "teal": 133, + "source": "tests/contracts/abi.algo.ts:600", + "pc": [ + 196 + ] + }, + { + "teal": 134, + "source": "tests/contracts/abi.algo.ts:600", + "pc": [ + 197 + ] + }, + { + "teal": 135, + "source": "tests/contracts/abi.algo.ts:600", + "pc": [ + 198 + ] + }, + { + "teal": 136, + "source": "tests/contracts/abi.algo.ts:600", + "pc": [ + 199, + 200, + 201 + ] + }, + { + "teal": 137, + "source": "tests/contracts/abi.algo.ts:600", + "pc": [ + 202, + 203 + ] + }, + { + "teal": 138, + "source": "tests/contracts/abi.algo.ts:600", + "pc": [ + 204, + 205 + ] + }, + { + "teal": 139, + "source": "tests/contracts/abi.algo.ts:600", + "pc": [ + 206 + ] + }, + { + "teal": 140, + "source": "tests/contracts/abi.algo.ts:600", + "pc": [ + 207 + ] + }, + { + "teal": 141, + "source": "tests/contracts/abi.algo.ts:600", + "pc": [ + 208, + 209 + ] + }, + { + "teal": 142, + "source": "tests/contracts/abi.algo.ts:600", + "pc": [ + 210, + 211 + ] + }, + { + "teal": 143, + "source": "tests/contracts/abi.algo.ts:600", + "pc": [ + 212, + 213 + ] + }, + { + "teal": 144, + "source": "tests/contracts/abi.algo.ts:600", + "pc": [ + 214, + 215 + ] + }, + { + "teal": 145, + "source": "tests/contracts/abi.algo.ts:600", + "pc": [ + 216 + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestNestedArrayLengthInObject.arc56_draft.json b/tests/contracts/artifacts/ABITestNestedArrayLengthInObject.arc56_draft.json index 533e112b6..dd1f5e915 100644 --- a/tests/contracts/artifacts/ABITestNestedArrayLengthInObject.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestNestedArrayLengthInObject.arc56_draft.json @@ -64,22 +64,315 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1424", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:1424", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1424", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1424", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1424", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1424", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1424", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1424", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:1424", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] }, { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:1425", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:1425", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1425", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1425", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1425", + "pc": [ + 48 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1425", + "pc": [ + 49, + 50 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:1425", + "pc": [ + 51 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:1425", + "pc": [ + 52, + 53, + 54 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:1425", + "pc": [ + 55, + 56 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:1426", + "pc": [ + 57, + 58, + 59, + 60, + 61, + 62, + 63 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:1426", + "pc": [ + 64, + 65 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:1428", + "pc": [ + 66, + 67 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:1428", + "pc": [ + 68, + 69 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:1425", + "pc": [ + 70, + 71 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:1425", + "pc": [ + 72 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:1424", + "pc": [ + 73, + 74 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:1424", + "pc": [ + 75 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:1424", + "pc": [ + 76, + 77, + 78, + 79, + 80, + 81 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:1424", + "pc": [ + 82, + 83, + 84 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:1424", + "pc": [ + 85, + 86, + 87, + 88 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:1424", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 89 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:1424", + "pc": [ + 90, + 91, + 92, + 93, + 94, + 95 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:1424", + "pc": [ + 96, + 97, + 98 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:1424", + "pc": [ + 99, + 100, + 101, + 102 + ] }, { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:1424", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 103 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestNestedArrayLengthInObjectVariable.arc56_draft.json b/tests/contracts/artifacts/ABITestNestedArrayLengthInObjectVariable.arc56_draft.json index 8d6be93f2..919e963fc 100644 --- a/tests/contracts/artifacts/ABITestNestedArrayLengthInObjectVariable.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestNestedArrayLengthInObjectVariable.arc56_draft.json @@ -64,22 +64,307 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1432", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:1432", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1432", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1432", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1432", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1432", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1432", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1432", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:1432", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:1433", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:1433", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1433", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1433", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1433", + "pc": [ + 48 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1433", + "pc": [ + 49, + 50 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:1433", + "pc": [ + 51 + ] }, { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:1433", + "pc": [ + 52, + 53, + 54 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:1433", + "pc": [ + 55, + 56 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:1434", + "pc": [ + 57, + 58, + 59, + 60, + 61, + 62, + 63 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:1434", + "pc": [ + 64, + 65 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:1437", + "pc": [ + 66, + 67 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:1433", + "pc": [ + 68, + 69 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:1433", + "pc": [ + 70 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:1432", + "pc": [ + 71, + 72 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:1432", + "pc": [ + 73 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:1432", + "pc": [ + 74, + 75, + 76, + 77, + 78, + 79 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:1432", + "pc": [ + 80, + 81, + 82 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:1432", + "pc": [ + 83, + 84, + 85, + 86 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:1432", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 87 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:1432", + "pc": [ + 88, + 89, + 90, + 91, + 92, + 93 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:1432", + "pc": [ + 94, + 95, + 96 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:1432", + "pc": [ + 97, + 98, + 99, + 100 + ] }, { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:1432", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 101 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestNestedArrayRef.arc56_draft.json b/tests/contracts/artifacts/ABITestNestedArrayRef.arc56_draft.json index 7510b893b..fcbc73fa4 100644 --- a/tests/contracts/artifacts/ABITestNestedArrayRef.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestNestedArrayRef.arc56_draft.json @@ -64,22 +64,332 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:759", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:759", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:759", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:759", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:759", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:759", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:759", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:759", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:759", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:760", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] }, { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:760", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:760", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:760", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:760", + "pc": [ + 48, + 49 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:760", + "pc": [ + 50 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:760", + "pc": [ + 51, + 52, + 53 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:760", + "pc": [ + 54, + 55 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:761", + "pc": [ + 56, + 57, + 58, + 59, + 60, + 61 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:761", + "pc": [ + 62, + 63 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:767", + "pc": [ + 64, + 65 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:767", + "pc": [ + 66, + 67, + 68 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:767", + "pc": [ + 69, + 70 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:767", + "pc": [ + 71, + 72 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:769", + "pc": [ + 73, + 74 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:760", + "pc": [ + 75, + 76 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:760", + "pc": [ + 77 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:759", + "pc": [ + 78, + 79 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:759", + "pc": [ + 80 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:759", + "pc": [ + 81, + 82, + 83, + 84, + 85, + 86 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:759", + "pc": [ + 87, + 88, + 89 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:759", + "pc": [ + 90, + 91, + 92, + 93 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:759", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 94 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:759", + "pc": [ + 95, + 96, + 97, + 98, + 99, + 100 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:759", + "pc": [ + 101, + 102, + 103 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:759", + "pc": [ + 104, + 105, + 106, + 107 + ] }, { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:759", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 108 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestNestedObject.arc56_draft.json b/tests/contracts/artifacts/ABITestNestedObject.arc56_draft.json index 0ba1c3176..c8b880e7f 100644 --- a/tests/contracts/artifacts/ABITestNestedObject.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestNestedObject.arc56_draft.json @@ -64,22 +64,366 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1084", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:1084", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1084", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1084", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1084", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1084", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1084", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1084", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:1084", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:1085", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:1085", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1085", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1085", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1085", + "pc": [ + 48 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1085", + "pc": [ + 49, + 50 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:1085", + "pc": [ + 51 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:1085", + "pc": [ + 52, + 53, + 54 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:1085", + "pc": [ + 55, + 56 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:1086", + "pc": [ + 57, + 58, + 59, + 60, + 61, + 62, + 63, + 64, + 65, + 66 + ] }, { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:1086", + "pc": [ + 67, + 68 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:1087", + "pc": [ + 69, + 70 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:1087", + "pc": [ + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79, + 80 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:1087", + "pc": [ + 81, + 82 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:1087", + "pc": [ + 83, + 84 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:1088", + "pc": [ + 85, + 86 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:1088", + "pc": [ + 87, + 88, + 89 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:1088", + "pc": [ + 90 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:1085", + "pc": [ + 91, + 92 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:1085", + "pc": [ + 93 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:1084", + "pc": [ + 94, + 95 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:1084", + "pc": [ + 96 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:1084", + "pc": [ + 97, + 98, + 99, + 100, + 101, + 102 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:1084", + "pc": [ + 103, + 104, + 105 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:1084", + "pc": [ + 106, + 107, + 108, + 109 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:1084", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 110 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:1084", + "pc": [ + 111, + 112, + 113, + 114, + 115, + 116 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:1084", + "pc": [ + 117, + 118, + 119 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:1084", + "pc": [ + 120, + 121, + 122, + 123 + ] }, { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:1084", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 124 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestNestedObjectType.arc56_draft.json b/tests/contracts/artifacts/ABITestNestedObjectType.arc56_draft.json index 15056e7cf..5514323e4 100644 --- a/tests/contracts/artifacts/ABITestNestedObjectType.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestNestedObjectType.arc56_draft.json @@ -64,22 +64,366 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1094", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:1094", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1094", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1094", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1094", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1094", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1094", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1094", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:1094", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:1095", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:1095", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1095", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1095", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1095", + "pc": [ + 48 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1095", + "pc": [ + 49, + 50 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:1095", + "pc": [ + 51 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:1095", + "pc": [ + 52, + 53, + 54 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:1095", + "pc": [ + 55, + 56 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:1096", + "pc": [ + 57, + 58, + 59, + 60, + 61, + 62, + 63, + 64, + 65, + 66 + ] }, { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:1096", + "pc": [ + 67, + 68 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:1097", + "pc": [ + 69, + 70 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:1097", + "pc": [ + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79, + 80 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:1097", + "pc": [ + 81, + 82 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:1097", + "pc": [ + 83, + 84 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:1098", + "pc": [ + 85, + 86 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:1098", + "pc": [ + 87, + 88, + 89 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:1098", + "pc": [ + 90 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:1095", + "pc": [ + 91, + 92 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:1095", + "pc": [ + 93 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:1094", + "pc": [ + 94, + 95 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:1094", + "pc": [ + 96 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:1094", + "pc": [ + 97, + 98, + 99, + 100, + 101, + 102 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:1094", + "pc": [ + 103, + 104, + 105 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:1094", + "pc": [ + 106, + 107, + 108, + 109 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:1094", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 110 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:1094", + "pc": [ + 111, + 112, + 113, + 114, + 115, + 116 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:1094", + "pc": [ + 117, + 118, + 119 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:1094", + "pc": [ + 120, + 121, + 122, + 123 + ] }, { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:1094", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 124 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestNestedStaticArray.arc56_draft.json b/tests/contracts/artifacts/ABITestNestedStaticArray.arc56_draft.json index 048c7ab9a..353f71db3 100644 --- a/tests/contracts/artifacts/ABITestNestedStaticArray.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestNestedStaticArray.arc56_draft.json @@ -64,22 +64,390 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:196", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:196", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:196", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:196", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:196", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:196", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:196", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:196", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:196", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:197", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:197", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:197", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:197", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:197", + "pc": [ + 48 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:197", + "pc": [ + 49, + 50 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:197", + "pc": [ + 51 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:197", + "pc": [ + 52, + 53, + 54 + ] }, { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:197", + "pc": [ + 55, + 56 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:198", + "pc": [ + 57, + 58, + 59, + 60, + 61, + 62, + 63, + 64, + 65, + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82, + 83, + 84, + 85, + 86, + 87, + 88, + 89, + 90, + 91, + 92, + 93, + 94, + 95, + 96, + 97, + 98, + 99, + 100, + 101, + 102, + 103, + 104, + 105, + 106, + 107, + 108, + 109, + 110, + 111, + 112, + 113, + 114, + 115, + 116, + 117, + 118, + 119, + 120, + 121, + 122, + 123, + 124, + 125, + 126, + 127, + 128, + 129, + 130 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:198", + "pc": [ + 131, + 132 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:204", + "pc": [ + 133, + 134 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:204", + "pc": [ + 135, + 136, + 137 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:204", + "pc": [ + 138 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:197", + "pc": [ + 139, + 140 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:197", + "pc": [ + 141 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:196", + "pc": [ + 142, + 143 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:196", + "pc": [ + 144 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:196", + "pc": [ + 145, + 146, + 147, + 148, + 149, + 150 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:196", + "pc": [ + 151, + 152, + 153 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:196", + "pc": [ + 154, + 155, + 156, + 157 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:196", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 158 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:196", + "pc": [ + 159, + 160, + 161, + 162, + 163, + 164 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:196", + "pc": [ + 165, + 166, + 167 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:196", + "pc": [ + 168, + 169, + 170, + 171 + ] }, { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:196", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 172 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestNestedStaticArrayLength.arc56_draft.json b/tests/contracts/artifacts/ABITestNestedStaticArrayLength.arc56_draft.json index a4e6ff232..ea8aaf30d 100644 --- a/tests/contracts/artifacts/ABITestNestedStaticArrayLength.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestNestedStaticArrayLength.arc56_draft.json @@ -64,22 +64,325 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1412", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:1412", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1412", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1412", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1412", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1412", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1412", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1412", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:1412", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] }, { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:1413", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:1413", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1413", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1413", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1413", + "pc": [ + 48 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1413", + "pc": [ + 49, + 50 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:1413", + "pc": [ + 51 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:1413", + "pc": [ + 52, + 53, + 54 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:1413", + "pc": [ + 55, + 56 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:1414", + "pc": [ + 57, + 58, + 59, + 60, + 61, + 62, + 63, + 64, + 65, + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:1414", + "pc": [ + 74, + 75 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:1420", + "pc": [ + 76, + 77 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:1420", + "pc": [ + 78, + 79 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:1413", + "pc": [ + 80, + 81 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:1413", + "pc": [ + 82 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:1412", + "pc": [ + 83, + 84 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:1412", + "pc": [ + 85 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:1412", + "pc": [ + 86, + 87, + 88, + 89, + 90, + 91 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:1412", + "pc": [ + 92, + 93, + 94 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:1412", + "pc": [ + 95, + 96, + 97, + 98 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:1412", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 99 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:1412", + "pc": [ + 100, + 101, + 102, + 103, + 104, + 105 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:1412", + "pc": [ + 106, + 107, + 108 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:1412", + "pc": [ + 109, + 110, + 111, + 112 + ] }, { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:1412", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 113 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestNestedStaticForEach.arc56_draft.json b/tests/contracts/artifacts/ABITestNestedStaticForEach.arc56_draft.json index 23c1dfd8e..58ec7fc36 100644 --- a/tests/contracts/artifacts/ABITestNestedStaticForEach.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestNestedStaticForEach.arc56_draft.json @@ -64,22 +64,635 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1318", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:1318", + "pc": [ + 1, + 2, + 3 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1318", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1318", + "pc": [ + 6 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1318", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1318", + "pc": [ + 9 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1318", + "pc": [ + 10, + 11 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1318", + "pc": [ + 12 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:1318", + "pc": [ + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:1318", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 39 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:1319", + "pc": [ + 40, + 41, + 42, + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1319", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1319", + "pc": [ + 49 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1319", + "pc": [ + 50 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1319", + "pc": [ + 51 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:1319", + "pc": [ + 52, + 53 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:1319", + "pc": [ + 54 + ] }, { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:1319", + "pc": [ + 55, + 56, + 57 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:1319", + "pc": [ + 58, + 59 + ] + }, + { + "teal": 45, + "source": "tests/contracts/abi.algo.ts:1319", + "pc": [ + 60, + 61 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:1320", + "pc": [ + 62, + 63, + 64, + 65, + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82, + 83, + 84, + 85, + 86, + 87, + 88, + 89, + 90, + 91, + 92, + 93, + 94, + 95, + 96, + 97, + 98, + 99, + 100, + 101, + 102, + 103, + 104, + 105, + 106, + 107, + 108, + 109, + 110, + 111, + 112, + 113, + 114, + 115, + 116, + 117, + 118, + 119, + 120, + 121, + 122, + 123, + 124, + 125, + 126, + 127, + 128, + 129, + 130, + 131, + 132, + 133, + 134, + 135 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:1320", + "pc": [ + 136, + 137 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:1325", + "pc": [ + 138, + 139 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:1325", + "pc": [ + 140, + 141 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:1327", + "pc": [ + 142, + 143 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:1327", + "pc": [ + 144, + 145, + 146 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:1327", + "pc": [ + 147 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:1327", + "pc": [ + 148, + 149 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:1327", + "pc": [ + 150, + 151, + 152 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:1327", + "pc": [ + 153 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:1327", + "pc": [ + 154, + 155 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:1327", + "pc": [ + 156, + 157 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:1327", + "pc": [ + 158, + 159 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:1328", + "pc": [ + 160, + 161 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:1328", + "pc": [ + 162, + 163 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:1328", + "pc": [ + 164 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:1328", + "pc": [ + 165, + 166 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:1327", + "pc": [ + 167, + 168 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:1327", + "pc": [ + 169, + 170 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:1327", + "pc": [ + 171 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:1327", + "pc": [ + 172 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:1327", + "pc": [ + 173, + 174 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:1327", + "pc": [ + 175 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:1327", + "pc": [ + 176, + 177, + 178 + ] + }, + { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:1327", + "pc": [ + 179, + 180 + ] + }, + { + "teal": 90, + "source": "tests/contracts/abi.algo.ts:1327", + "pc": [ + 181, + 182 + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:1327", + "pc": [ + 183, + 184 + ] + }, + { + "teal": 92, + "source": "tests/contracts/abi.algo.ts:1327", + "pc": [ + 185, + 186 + ] + }, + { + "teal": 93, + "source": "tests/contracts/abi.algo.ts:1327", + "pc": [ + 187 + ] + }, + { + "teal": 94, + "source": "tests/contracts/abi.algo.ts:1327", + "pc": [ + 188 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:1327", + "pc": [ + 189, + 190 + ] + }, + { + "teal": 96, + "source": "tests/contracts/abi.algo.ts:1327", + "pc": [ + 191, + 192, + 193 + ] + }, + { + "teal": 101, + "source": "tests/contracts/abi.algo.ts:1331", + "pc": [ + 194, + 195 + ] + }, + { + "teal": 104, + "source": "tests/contracts/abi.algo.ts:1319", + "pc": [ + 196, + 197 + ] + }, + { + "teal": 107, + "source": "tests/contracts/abi.algo.ts:1319", + "pc": [ + 198, + 199 + ] + }, + { + "teal": 108, + "source": "tests/contracts/abi.algo.ts:1319", + "pc": [ + 200 + ] + }, + { + "teal": 111, + "source": "tests/contracts/abi.algo.ts:1318", + "pc": [ + 201, + 202 + ] + }, + { + "teal": 112, + "source": "tests/contracts/abi.algo.ts:1318", + "pc": [ + 203 + ] + }, + { + "teal": 115, + "source": "tests/contracts/abi.algo.ts:1318", + "pc": [ + 204, + 205, + 206, + 207, + 208, + 209 + ] + }, + { + "teal": 116, + "source": "tests/contracts/abi.algo.ts:1318", + "pc": [ + 210, + 211, + 212 + ] + }, + { + "teal": 117, + "source": "tests/contracts/abi.algo.ts:1318", + "pc": [ + 213, + 214, + 215, + 216 + ] + }, + { + "teal": 120, + "source": "tests/contracts/abi.algo.ts:1318", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 217 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 123, + "source": "tests/contracts/abi.algo.ts:1318", + "pc": [ + 218, + 219, + 220, + 221, + 222, + 223 + ] + }, + { + "teal": 124, + "source": "tests/contracts/abi.algo.ts:1318", + "pc": [ + 224, + 225, + 226 + ] + }, + { + "teal": 125, + "source": "tests/contracts/abi.algo.ts:1318", + "pc": [ + 227, + 228, + 229, + 230 + ] }, { + "teal": 128, + "source": "tests/contracts/abi.algo.ts:1318", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 231 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestNestedStaticForEachInBox.arc56_draft.json b/tests/contracts/artifacts/ABITestNestedStaticForEachInBox.arc56_draft.json index e1781579c..3c188dd92 100644 --- a/tests/contracts/artifacts/ABITestNestedStaticForEachInBox.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestNestedStaticForEachInBox.arc56_draft.json @@ -70,22 +70,669 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1335", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:1335", + "pc": [ + 1, + 2, + 3, + 4, + 5, + 6, + 7, + 8 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1335", + "pc": [ + 9, + 10 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1335", + "pc": [ + 11 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1335", + "pc": [ + 12, + 13 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1335", + "pc": [ + 14 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1335", + "pc": [ + 15, + 16 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1335", + "pc": [ + 17 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:1335", + "pc": [ + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38, + 39, + 40, + 41, + 42, + 43 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:1335", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 44 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:1338", + "pc": [ + 45, + 46, + 47, + 48, + 49, + 50 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1338", + "pc": [ + 51, + 52, + 53 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1338", + "pc": [ + 54 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1338", + "pc": [ + 55 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1338", + "pc": [ + 56 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:1338", + "pc": [ + 57, + 58 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:1338", + "pc": [ + 59 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:1338", + "pc": [ + 60, + 61, + 62 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:1338", + "pc": [ + 63, + 64 + ] + }, + { + "teal": 45, + "source": "tests/contracts/abi.algo.ts:1338", + "pc": [ + 65, + 66 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:1339", + "pc": [ + 67, + 68, + 69, + 70, + 71, + 72 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:1339", + "pc": [ + 73, + 74, + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82, + 83, + 84, + 85, + 86, + 87, + 88, + 89, + 90, + 91, + 92, + 93, + 94, + 95, + 96, + 97, + 98, + 99, + 100, + 101, + 102, + 103, + 104, + 105, + 106, + 107, + 108, + 109, + 110, + 111, + 112, + 113, + 114, + 115, + 116, + 117, + 118, + 119, + 120, + 121, + 122, + 123, + 124, + 125, + 126, + 127, + 128, + 129, + 130, + 131, + 132, + 133, + 134, + 135, + 136, + 137, + 138, + 139, + 140, + 141, + 142, + 143, + 144, + 145, + 146 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:1339", + "pc": [ + 147 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:1344", + "pc": [ + 148, + 149 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:1344", + "pc": [ + 150, + 151 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:1346", + "pc": [ + 152, + 153, + 154, + 155, + 156, + 157 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:1346", + "pc": [ + 158, + 159 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:1346", + "pc": [ + 160, + 161 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:1346", + "pc": [ + 162 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:1346", + "pc": [ + 163 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:1346", + "pc": [ + 164, + 165 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:1346", + "pc": [ + 166, + 167, + 168 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:1346", + "pc": [ + 169 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:1346", + "pc": [ + 170, + 171 + ] }, { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:1346", + "pc": [ + 172, + 173 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:1346", + "pc": [ + 174, + 175 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:1347", + "pc": [ + 176, + 177 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:1347", + "pc": [ + 178, + 179 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:1347", + "pc": [ + 180 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:1347", + "pc": [ + 181, + 182 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:1346", + "pc": [ + 183, + 184 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:1346", + "pc": [ + 185, + 186 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:1346", + "pc": [ + 187 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:1346", + "pc": [ + 188 + ] + }, + { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:1346", + "pc": [ + 189, + 190 + ] + }, + { + "teal": 90, + "source": "tests/contracts/abi.algo.ts:1346", + "pc": [ + 191 + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:1346", + "pc": [ + 192, + 193, + 194 + ] + }, + { + "teal": 92, + "source": "tests/contracts/abi.algo.ts:1346", + "pc": [ + 195, + 196 + ] + }, + { + "teal": 93, + "source": "tests/contracts/abi.algo.ts:1346", + "pc": [ + 197, + 198 + ] + }, + { + "teal": 94, + "source": "tests/contracts/abi.algo.ts:1346", + "pc": [ + 199, + 200 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:1346", + "pc": [ + 201, + 202 + ] + }, + { + "teal": 96, + "source": "tests/contracts/abi.algo.ts:1346", + "pc": [ + 203 + ] + }, + { + "teal": 97, + "source": "tests/contracts/abi.algo.ts:1346", + "pc": [ + 204 + ] + }, + { + "teal": 98, + "source": "tests/contracts/abi.algo.ts:1346", + "pc": [ + 205, + 206 + ] + }, + { + "teal": 99, + "source": "tests/contracts/abi.algo.ts:1346", + "pc": [ + 207, + 208, + 209 + ] + }, + { + "teal": 104, + "source": "tests/contracts/abi.algo.ts:1350", + "pc": [ + 210, + 211 + ] + }, + { + "teal": 107, + "source": "tests/contracts/abi.algo.ts:1338", + "pc": [ + 212, + 213 + ] + }, + { + "teal": 110, + "source": "tests/contracts/abi.algo.ts:1338", + "pc": [ + 214, + 215 + ] + }, + { + "teal": 111, + "source": "tests/contracts/abi.algo.ts:1338", + "pc": [ + 216 + ] + }, + { + "teal": 114, + "source": "tests/contracts/abi.algo.ts:1335", + "pc": [ + 217, + 218 + ] + }, + { + "teal": 115, + "source": "tests/contracts/abi.algo.ts:1335", + "pc": [ + 219 + ] + }, + { + "teal": 118, + "source": "tests/contracts/abi.algo.ts:1335", + "pc": [ + 220, + 221, + 222, + 223, + 224, + 225 + ] + }, + { + "teal": 119, + "source": "tests/contracts/abi.algo.ts:1335", + "pc": [ + 226, + 227, + 228 + ] + }, + { + "teal": 120, + "source": "tests/contracts/abi.algo.ts:1335", + "pc": [ + 229, + 230, + 231, + 232 + ] + }, + { + "teal": 123, + "source": "tests/contracts/abi.algo.ts:1335", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 233 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 126, + "source": "tests/contracts/abi.algo.ts:1335", + "pc": [ + 234, + 235, + 236, + 237, + 238, + 239 + ] + }, + { + "teal": 127, + "source": "tests/contracts/abi.algo.ts:1335", + "pc": [ + 240, + 241, + 242 + ] + }, + { + "teal": 128, + "source": "tests/contracts/abi.algo.ts:1335", + "pc": [ + 243, + 244, + 245, + 246 + ] }, { + "teal": 131, + "source": "tests/contracts/abi.algo.ts:1335", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 247 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestNestedStructInBoxMap.arc56_draft.json b/tests/contracts/artifacts/ABITestNestedStructInBoxMap.arc56_draft.json index 9b92e1059..b38723d95 100644 --- a/tests/contracts/artifacts/ABITestNestedStructInBoxMap.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestNestedStructInBoxMap.arc56_draft.json @@ -82,28 +82,395 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1276", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:1276", + "pc": [ + 1, + 2, + 3, + 4, + 5, + 6, + 7 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1276", + "pc": [ + 8, + 9 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1276", + "pc": [ + 10 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1276", + "pc": [ + 11, + 12 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1276", + "pc": [ + 13 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1276", + "pc": [ + 14, + 15 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1276", + "pc": [ + 16 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:1276", + "pc": [ + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:1276", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 43 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:1279", + "pc": [ + 44, + 45, + 46, + 47, + 48, + 49 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1279", + "pc": [ + 50, + 51, + 52 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1279", + "pc": [ + 53 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1279", + "pc": [ + 54 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1279", + "pc": [ + 55, + 56 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:1279", + "pc": [ + 57 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:1279", + "pc": [ + 58, + 59, + 60 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:1280", + "pc": [ + 61, + 62, + 63, + 64, + 65, + 66 + ] + }, + { + "teal": 45, + "source": "tests/contracts/abi.algo.ts:1280", + "pc": [ + 67, + 68, + 69 + ] + }, + { + "teal": 46, + "source": "tests/contracts/abi.algo.ts:1280", + "pc": [ + 70 + ] }, { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:1281", + "pc": [ + 71, + 72, + 73, + 74, + 75, + 76 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:1281", + "pc": [ + 77, + 78 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:1281", + "pc": [ + 79, + 80, + 81 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:1281", + "pc": [ + 82 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:1282", + "pc": [ + 83, + 84, + 85, + 86, + 87, + 88 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:1282", + "pc": [ + 89, + 90 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:1282", + "pc": [ + 91, + 92, + 93 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:1282", + "pc": [ + 94 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:1283", + "pc": [ + 95, + 96, + 97, + 98, + 99, + 100 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:1283", + "pc": [ + 101 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:1283", + "errorMessage": "box value does not exist: this.bMap('bMap').value", "pc": [ 102 - ], - "errorMessage": "box value does not exist: this.bMap('bMap').value" + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:1279", + "pc": [ + 103 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:1276", + "pc": [ + 104, + 105 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:1276", + "pc": [ + 106 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:1276", + "pc": [ + 107, + 108, + 109, + 110, + 111, + 112 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:1276", + "pc": [ + 113, + 114, + 115 + ] }, { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:1276", + "pc": [ + 116, + 117, + 118, + 119 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:1276", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 120 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:1276", + "pc": [ + 121, + 122, + 123, + 124, + 125, + 126 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:1276", + "pc": [ + 127, + 128, + 129 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:1276", + "pc": [ + 130, + 131, + 132, + 133 + ] }, { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:1276", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 134 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestNestedTuple.arc56_draft.json b/tests/contracts/artifacts/ABITestNestedTuple.arc56_draft.json index 44fc6fdf3..a21b99313 100644 --- a/tests/contracts/artifacts/ABITestNestedTuple.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestNestedTuple.arc56_draft.json @@ -64,22 +64,758 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:690", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:690", + "pc": [ + 1, + 2, + 3 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:690", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:690", + "pc": [ + 6 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:690", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:690", + "pc": [ + 9 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:690", + "pc": [ + 10, + 11 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:690", + "pc": [ + 12 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:690", + "pc": [ + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:690", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 39 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:691", + "pc": [ + 40, + 41, + 42, + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:691", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:691", + "pc": [ + 49 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:691", + "pc": [ + 50 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:691", + "pc": [ + 51, + 52 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:691", + "pc": [ + 53 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:691", + "pc": [ + 54, + 55, + 56 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:691", + "pc": [ + 57, + 58 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:692", + "pc": [ + 59, + 60 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:692", + "pc": [ + 61, + 62 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:692", + "pc": [ + 63, + 64, + 65, + 66 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:692", + "pc": [ + 67, + 68, + 69, + 70 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:692", + "pc": [ + 71, + 72, + 73 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:692", + "pc": [ + 74, + 75 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:692", + "pc": [ + 76, + 77 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:692", + "pc": [ + 78, + 79, + 80, + 81 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:692", + "pc": [ + 82, + 83, + 84 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:692", + "pc": [ + 85, + 86, + 87 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:692", + "pc": [ + 88, + 89, + 90, + 91, + 92, + 93, + 94 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:692", + "pc": [ + 95, + 96, + 97 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:692", + "pc": [ + 98 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:692", + "pc": [ + 99 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:692", + "pc": [ + 100, + 101, + 102 + ] }, { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:692", + "pc": [ + 103, + 104 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:692", + "pc": [ + 105, + 106 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:692", + "pc": [ + 107, + 108, + 109, + 110 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:692", + "pc": [ + 111, + 112, + 113, + 114 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:692", + "pc": [ + 115, + 116, + 117 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:692", + "pc": [ + 118, + 119, + 120, + 121, + 122, + 123, + 124 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:692", + "pc": [ + 125, + 126, + 127 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:692", + "pc": [ + 128 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:692", + "pc": [ + 129 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:692", + "pc": [ + 130, + 131, + 132 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:692", + "pc": [ + 133 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:692", + "pc": [ + 134 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:692", + "pc": [ + 135, + 136 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:694", + "pc": [ + 137, + 138 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:691", + "pc": [ + 139, + 140 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:691", + "pc": [ + 141 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:690", + "pc": [ + 142, + 143 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:690", + "pc": [ + 144 + ] + }, + { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:690", + "pc": [ + 145, + 146, + 147, + 148, + 149, + 150 + ] + }, + { + "teal": 90, + "source": "tests/contracts/abi.algo.ts:690", + "pc": [ + 151, + 152, + 153 + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:690", + "pc": [ + 154, + 155, + 156, + 157 + ] + }, + { + "teal": 94, + "source": "tests/contracts/abi.algo.ts:690", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 158 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 97, + "source": "tests/contracts/abi.algo.ts:690", + "pc": [ + 159, + 160, + 161, + 162, + 163, + 164 + ] + }, + { + "teal": 98, + "source": "tests/contracts/abi.algo.ts:690", + "pc": [ + 165, + 166, + 167 + ] + }, + { + "teal": 99, + "source": "tests/contracts/abi.algo.ts:690", + "pc": [ + 168, + 169, + 170, + 171 + ] }, { + "teal": 102, + "source": "tests/contracts/abi.algo.ts:690", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 172 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] + }, + { + "teal": 105, + "source": "tests/contracts/abi.algo.ts:690", + "pc": [ + 173, + 174, + 175 + ] + }, + { + "teal": 106, + "source": "tests/contracts/abi.algo.ts:690", + "pc": [ + 176, + 177 + ] + }, + { + "teal": 107, + "source": "tests/contracts/abi.algo.ts:690", + "pc": [ + 178, + 179 + ] + }, + { + "teal": 108, + "source": "tests/contracts/abi.algo.ts:690", + "pc": [ + 180 + ] + }, + { + "teal": 109, + "source": "tests/contracts/abi.algo.ts:690", + "pc": [ + 181, + 182 + ] + }, + { + "teal": 110, + "source": "tests/contracts/abi.algo.ts:690", + "pc": [ + 183, + 184 + ] + }, + { + "teal": 111, + "source": "tests/contracts/abi.algo.ts:690", + "pc": [ + 185 + ] + }, + { + "teal": 114, + "source": "tests/contracts/abi.algo.ts:690", + "pc": [ + 186, + 187, + 188 + ] + }, + { + "teal": 115, + "source": "tests/contracts/abi.algo.ts:690", + "pc": [ + 189, + 190 + ] + }, + { + "teal": 116, + "source": "tests/contracts/abi.algo.ts:690", + "pc": [ + 191, + 192 + ] + }, + { + "teal": 117, + "source": "tests/contracts/abi.algo.ts:690", + "pc": [ + 193 + ] + }, + { + "teal": 118, + "source": "tests/contracts/abi.algo.ts:690", + "pc": [ + 194, + 195 + ] + }, + { + "teal": 119, + "source": "tests/contracts/abi.algo.ts:690", + "pc": [ + 196, + 197 + ] + }, + { + "teal": 120, + "source": "tests/contracts/abi.algo.ts:690", + "pc": [ + 198 + ] + }, + { + "teal": 121, + "source": "tests/contracts/abi.algo.ts:690", + "pc": [ + 199 + ] + }, + { + "teal": 122, + "source": "tests/contracts/abi.algo.ts:690", + "pc": [ + 200, + 201 + ] + }, + { + "teal": 123, + "source": "tests/contracts/abi.algo.ts:690", + "pc": [ + 202 + ] + }, + { + "teal": 124, + "source": "tests/contracts/abi.algo.ts:690", + "pc": [ + 203 + ] + }, + { + "teal": 125, + "source": "tests/contracts/abi.algo.ts:690", + "pc": [ + 204 + ] + }, + { + "teal": 126, + "source": "tests/contracts/abi.algo.ts:690", + "pc": [ + 205, + 206, + 207 + ] + }, + { + "teal": 127, + "source": "tests/contracts/abi.algo.ts:690", + "pc": [ + 208, + 209 + ] + }, + { + "teal": 128, + "source": "tests/contracts/abi.algo.ts:690", + "pc": [ + 210, + 211 + ] + }, + { + "teal": 129, + "source": "tests/contracts/abi.algo.ts:690", + "pc": [ + 212 + ] + }, + { + "teal": 130, + "source": "tests/contracts/abi.algo.ts:690", + "pc": [ + 213 + ] + }, + { + "teal": 131, + "source": "tests/contracts/abi.algo.ts:690", + "pc": [ + 214, + 215 + ] + }, + { + "teal": 132, + "source": "tests/contracts/abi.algo.ts:690", + "pc": [ + 216, + 217 + ] + }, + { + "teal": 133, + "source": "tests/contracts/abi.algo.ts:690", + "pc": [ + 218, + 219 + ] + }, + { + "teal": 134, + "source": "tests/contracts/abi.algo.ts:690", + "pc": [ + 220, + 221 + ] + }, + { + "teal": 135, + "source": "tests/contracts/abi.algo.ts:690", + "pc": [ + 222 + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestNestedTypesInSignature.arc56_draft.json b/tests/contracts/artifacts/ABITestNestedTypesInSignature.arc56_draft.json index d51f419dc..ea6415cca 100644 --- a/tests/contracts/artifacts/ABITestNestedTypesInSignature.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestNestedTypesInSignature.arc56_draft.json @@ -64,22 +64,287 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1134", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:1134", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1134", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1134", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1134", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1134", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1134", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1134", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:1134", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] }, { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:1135", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:1135", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1135", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1135", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1135", + "pc": [ + 48, + 49 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1135", + "pc": [ + 50 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:1135", + "pc": [ + 51, + 52, + 53 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:1136", + "pc": [ + 54, + 55, + 56, + 57, + 58, + 59, + 60, + 61, + 62, + 63, + 64, + 65, + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:1135", + "pc": [ + 80 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:1134", + "pc": [ + 81, + 82 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:1134", + "pc": [ + 83 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:1134", + "pc": [ + 84, + 85, + 86, + 87, + 88, + 89 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:1134", + "pc": [ + 90, + 91, + 92 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:1134", + "pc": [ + 93, + 94, + 95, + 96 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:1134", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 97 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:1134", + "pc": [ + 98, + 99, + 100, + 101, + 102, + 103 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:1134", + "pc": [ + 104, + 105, + 106 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:1134", + "pc": [ + 107, + 108, + 109, + 110 + ] }, { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:1134", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 111 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestNonE2E.arc56_draft.json b/tests/contracts/artifacts/ABITestNonE2E.arc56_draft.json index c1fbe9d9a..93771b96b 100644 --- a/tests/contracts/artifacts/ABITestNonE2E.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestNonE2E.arc56_draft.json @@ -80,22 +80,609 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1158", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:1158", + "pc": [ + 1, + 2, + 3 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1158", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1158", + "pc": [ + 6 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1158", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1158", + "pc": [ + 9 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1158", + "pc": [ + 10, + 11 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1158", + "pc": [ + 12 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:1158", + "pc": [ + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:1158", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 39 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:1159", + "pc": [ + 40, + 41, + 42, + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1159", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1159", + "pc": [ + 49 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1159", + "pc": [ + 50 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1159", + "pc": [ + 51, + 52 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:1159", + "pc": [ + 53 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:1159", + "pc": [ + 54, + 55, + 56 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:1160", + "pc": [ + 57, + 58 + ] }, { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:1160", + "pc": [ + 59, + 60 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:1160", + "pc": [ + 61, + 62, + 63, + 64 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:1161", + "pc": [ + 65, + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79, + 80 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:1161", + "pc": [ + 81, + 82, + 83 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:1162", + "pc": [ + 84, + 85, + 86, + 87, + 88, + 89, + 90, + 91, + 92, + 93 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:1162", + "pc": [ + 94, + 95, + 96 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:1163", + "pc": [ + 97, + 98, + 99, + 100, + 101, + 102, + 103, + 104, + 105, + 106 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:1163", + "pc": [ + 107, + 108, + 109 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:1160", + "pc": [ + 110 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:1160", + "pc": [ + 111 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:1159", + "pc": [ + 112 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:1158", + "pc": [ + 113, + 114 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:1158", + "pc": [ + 115 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:1158", + "pc": [ + 116, + 117, + 118, + 119, + 120, + 121 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:1158", + "pc": [ + 122, + 123, + 124 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:1158", + "pc": [ + 125, + 126, + 127, + 128 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:1158", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 129 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:1158", + "pc": [ + 130, + 131, + 132, + 133, + 134, + 135 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:1158", + "pc": [ + 136, + 137, + 138 + ] }, { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:1158", + "pc": [ + 139, + 140, + 141, + 142 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:1158", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 143 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:1158", + "pc": [ + 144, + 145, + 146 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:1158", + "pc": [ + 147, + 148 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:1158", + "pc": [ + 149, + 150 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:1158", + "pc": [ + 151 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:1158", + "pc": [ + 152, + 153 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:1158", + "pc": [ + 154, + 155 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:1158", + "pc": [ + 156 + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:1158", + "pc": [ + 157, + 158, + 159 + ] + }, + { + "teal": 92, + "source": "tests/contracts/abi.algo.ts:1158", + "pc": [ + 160, + 161 + ] + }, + { + "teal": 93, + "source": "tests/contracts/abi.algo.ts:1158", + "pc": [ + 162, + 163 + ] + }, + { + "teal": 94, + "source": "tests/contracts/abi.algo.ts:1158", + "pc": [ + 164 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:1158", + "pc": [ + 165, + 166 + ] + }, + { + "teal": 96, + "source": "tests/contracts/abi.algo.ts:1158", + "pc": [ + 167, + 168 + ] + }, + { + "teal": 97, + "source": "tests/contracts/abi.algo.ts:1158", + "pc": [ + 169 + ] + }, + { + "teal": 98, + "source": "tests/contracts/abi.algo.ts:1158", + "pc": [ + 170 + ] + }, + { + "teal": 99, + "source": "tests/contracts/abi.algo.ts:1158", + "pc": [ + 171, + 172 + ] + }, + { + "teal": 100, + "source": "tests/contracts/abi.algo.ts:1158", + "pc": [ + 173 + ] + }, + { + "teal": 101, + "source": "tests/contracts/abi.algo.ts:1158", + "pc": [ + 174 + ] + }, + { + "teal": 102, + "source": "tests/contracts/abi.algo.ts:1158", + "pc": [ + 175 + ] + }, + { + "teal": 103, + "source": "tests/contracts/abi.algo.ts:1158", + "pc": [ + 176, + 177, + 178 + ] + }, + { + "teal": 104, + "source": "tests/contracts/abi.algo.ts:1158", + "pc": [ + 179, + 180 + ] + }, + { + "teal": 105, + "source": "tests/contracts/abi.algo.ts:1158", + "pc": [ + 181, + 182 + ] + }, + { + "teal": 106, + "source": "tests/contracts/abi.algo.ts:1158", + "pc": [ + 183 + ] + }, + { + "teal": 107, + "source": "tests/contracts/abi.algo.ts:1158", + "pc": [ + 184 + ] + }, + { + "teal": 108, + "source": "tests/contracts/abi.algo.ts:1158", + "pc": [ + 185, + 186 + ] + }, + { + "teal": 109, + "source": "tests/contracts/abi.algo.ts:1158", + "pc": [ + 187, + 188 + ] + }, + { + "teal": 110, + "source": "tests/contracts/abi.algo.ts:1158", + "pc": [ + 189, + 190 + ] + }, + { + "teal": 111, + "source": "tests/contracts/abi.algo.ts:1158", + "pc": [ + 191, + 192 + ] + }, + { + "teal": 112, + "source": "tests/contracts/abi.algo.ts:1158", + "pc": [ + 193 + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestNonLiteralDynamicElementInTuple.arc56_draft.json b/tests/contracts/artifacts/ABITestNonLiteralDynamicElementInTuple.arc56_draft.json index 6ddf3650f..c8a402a11 100644 --- a/tests/contracts/artifacts/ABITestNonLiteralDynamicElementInTuple.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestNonLiteralDynamicElementInTuple.arc56_draft.json @@ -64,22 +64,750 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:418", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:418", + "pc": [ + 1, + 2, + 3 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:418", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:418", + "pc": [ + 6 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:418", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:418", + "pc": [ + 9 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:418", + "pc": [ + 10, + 11 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:418", + "pc": [ + 12 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:418", + "pc": [ + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:418", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 39 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:419", + "pc": [ + 40, + 41, + 42, + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:419", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:419", + "pc": [ + 49 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:419", + "pc": [ + 50 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:419", + "pc": [ + 51, + 52 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:419", + "pc": [ + 53 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:419", + "pc": [ + 54, + 55, + 56 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:419", + "pc": [ + 57, + 58 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:419", + "pc": [ + 59 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:420", + "pc": [ + 60, + 61, + 62, + 63, + 64, + 65 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:420", + "pc": [ + 66, + 67 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:421", + "pc": [ + 68, + 69 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:421", + "pc": [ + 70, + 71 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:421", + "pc": [ + 72, + 73, + 74, + 75 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:421", + "pc": [ + 76, + 77, + 78 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:421", + "pc": [ + 79, + 80, + 81 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:421", + "pc": [ + 82, + 83, + 84, + 85 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:421", + "pc": [ + 86, + 87, + 88 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:421", + "pc": [ + 89, + 90, + 91, + 92, + 93, + 94 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:421", + "pc": [ + 95, + 96, + 97 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:421", + "pc": [ + 98, + 99 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:421", + "pc": [ + 100 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:421", + "pc": [ + 101 + ] }, { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:421", + "pc": [ + 102, + 103 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:421", + "pc": [ + 104 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:421", + "pc": [ + 105 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:421", + "pc": [ + 106, + 107, + 108 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:421", + "pc": [ + 109 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:421", + "pc": [ + 110 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:421", + "pc": [ + 111, + 112, + 113 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:421", + "pc": [ + 114, + 115, + 116, + 117, + 118, + 119 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:421", + "pc": [ + 120, + 121, + 122 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:421", + "pc": [ + 123 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:421", + "pc": [ + 124 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:421", + "pc": [ + 125, + 126 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:423", + "pc": [ + 127, + 128 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:419", + "pc": [ + 129, + 130 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:419", + "pc": [ + 131, + 132 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:419", + "pc": [ + 133 + ] + }, + { + "teal": 90, + "source": "tests/contracts/abi.algo.ts:418", + "pc": [ + 134, + 135 + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:418", + "pc": [ + 136 + ] + }, + { + "teal": 94, + "source": "tests/contracts/abi.algo.ts:418", + "pc": [ + 137, + 138, + 139, + 140, + 141, + 142 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:418", + "pc": [ + 143, + 144, + 145 + ] + }, + { + "teal": 96, + "source": "tests/contracts/abi.algo.ts:418", + "pc": [ + 146, + 147, + 148, + 149 + ] + }, + { + "teal": 99, + "source": "tests/contracts/abi.algo.ts:418", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 150 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 102, + "source": "tests/contracts/abi.algo.ts:418", + "pc": [ + 151, + 152, + 153, + 154, + 155, + 156 + ] + }, + { + "teal": 103, + "source": "tests/contracts/abi.algo.ts:418", + "pc": [ + 157, + 158, + 159 + ] + }, + { + "teal": 104, + "source": "tests/contracts/abi.algo.ts:418", + "pc": [ + 160, + 161, + 162, + 163 + ] }, { + "teal": 107, + "source": "tests/contracts/abi.algo.ts:418", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 164 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] + }, + { + "teal": 110, + "source": "tests/contracts/abi.algo.ts:418", + "pc": [ + 165, + 166, + 167 + ] + }, + { + "teal": 111, + "source": "tests/contracts/abi.algo.ts:418", + "pc": [ + 168, + 169 + ] + }, + { + "teal": 112, + "source": "tests/contracts/abi.algo.ts:418", + "pc": [ + 170, + 171 + ] + }, + { + "teal": 113, + "source": "tests/contracts/abi.algo.ts:418", + "pc": [ + 172 + ] + }, + { + "teal": 114, + "source": "tests/contracts/abi.algo.ts:418", + "pc": [ + 173, + 174 + ] + }, + { + "teal": 115, + "source": "tests/contracts/abi.algo.ts:418", + "pc": [ + 175, + 176 + ] + }, + { + "teal": 116, + "source": "tests/contracts/abi.algo.ts:418", + "pc": [ + 177 + ] + }, + { + "teal": 119, + "source": "tests/contracts/abi.algo.ts:418", + "pc": [ + 178, + 179, + 180 + ] + }, + { + "teal": 120, + "source": "tests/contracts/abi.algo.ts:418", + "pc": [ + 181, + 182 + ] + }, + { + "teal": 121, + "source": "tests/contracts/abi.algo.ts:418", + "pc": [ + 183, + 184 + ] + }, + { + "teal": 122, + "source": "tests/contracts/abi.algo.ts:418", + "pc": [ + 185 + ] + }, + { + "teal": 123, + "source": "tests/contracts/abi.algo.ts:418", + "pc": [ + 186, + 187 + ] + }, + { + "teal": 124, + "source": "tests/contracts/abi.algo.ts:418", + "pc": [ + 188, + 189 + ] + }, + { + "teal": 125, + "source": "tests/contracts/abi.algo.ts:418", + "pc": [ + 190 + ] + }, + { + "teal": 126, + "source": "tests/contracts/abi.algo.ts:418", + "pc": [ + 191 + ] + }, + { + "teal": 127, + "source": "tests/contracts/abi.algo.ts:418", + "pc": [ + 192, + 193 + ] + }, + { + "teal": 128, + "source": "tests/contracts/abi.algo.ts:418", + "pc": [ + 194 + ] + }, + { + "teal": 129, + "source": "tests/contracts/abi.algo.ts:418", + "pc": [ + 195 + ] + }, + { + "teal": 130, + "source": "tests/contracts/abi.algo.ts:418", + "pc": [ + 196 + ] + }, + { + "teal": 131, + "source": "tests/contracts/abi.algo.ts:418", + "pc": [ + 197, + 198, + 199 + ] + }, + { + "teal": 132, + "source": "tests/contracts/abi.algo.ts:418", + "pc": [ + 200, + 201 + ] + }, + { + "teal": 133, + "source": "tests/contracts/abi.algo.ts:418", + "pc": [ + 202, + 203 + ] + }, + { + "teal": 134, + "source": "tests/contracts/abi.algo.ts:418", + "pc": [ + 204 + ] + }, + { + "teal": 135, + "source": "tests/contracts/abi.algo.ts:418", + "pc": [ + 205 + ] + }, + { + "teal": 136, + "source": "tests/contracts/abi.algo.ts:418", + "pc": [ + 206, + 207 + ] + }, + { + "teal": 137, + "source": "tests/contracts/abi.algo.ts:418", + "pc": [ + 208, + 209 + ] + }, + { + "teal": 138, + "source": "tests/contracts/abi.algo.ts:418", + "pc": [ + 210, + 211 + ] + }, + { + "teal": 139, + "source": "tests/contracts/abi.algo.ts:418", + "pc": [ + 212, + 213 + ] + }, + { + "teal": 140, + "source": "tests/contracts/abi.algo.ts:418", + "pc": [ + 214 + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestNonLiteralNestedArrayRef.arc56_draft.json b/tests/contracts/artifacts/ABITestNonLiteralNestedArrayRef.arc56_draft.json index 925b70919..9de781597 100644 --- a/tests/contracts/artifacts/ABITestNonLiteralNestedArrayRef.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestNonLiteralNestedArrayRef.arc56_draft.json @@ -64,22 +64,443 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:773", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:773", + "pc": [ + 1, + 2, + 3 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:773", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:773", + "pc": [ + 6 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:773", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:773", + "pc": [ + 9 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:773", + "pc": [ + 10, + 11 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:773", + "pc": [ + 12 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:773", + "pc": [ + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:773", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 39 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:774", + "pc": [ + 40, + 41, + 42, + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:774", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:774", + "pc": [ + 49 + ] }, { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:774", + "pc": [ + 50 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:774", + "pc": [ + 51, + 52 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:774", + "pc": [ + 53 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:774", + "pc": [ + 54, + 55, + 56 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:774", + "pc": [ + 57, + 58 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:774", + "pc": [ + 59, + 60 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:775", + "pc": [ + 61, + 62, + 63, + 64, + 65, + 66 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:775", + "pc": [ + 67, + 68 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:780", + "pc": [ + 69, + 70 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:780", + "pc": [ + 71, + 72 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:781", + "pc": [ + 73, + 74 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:781", + "pc": [ + 75, + 76 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:783", + "pc": [ + 77, + 78, + 79 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:783", + "pc": [ + 80, + 81 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:785", + "pc": [ + 82, + 83 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:785", + "pc": [ + 84, + 85 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:785", + "pc": [ + 86, + 87 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:785", + "pc": [ + 88 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:785", + "pc": [ + 89, + 90 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:785", + "pc": [ + 91 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:785", + "pc": [ + 92, + 93, + 94 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:785", + "pc": [ + 95 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:785", + "pc": [ + 96, + 97 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:787", + "pc": [ + 98, + 99 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:774", + "pc": [ + 100, + 101 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:774", + "pc": [ + 102, + 103 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:774", + "pc": [ + 104 + ] + }, + { + "teal": 90, + "source": "tests/contracts/abi.algo.ts:773", + "pc": [ + 105, + 106 + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:773", + "pc": [ + 107 + ] + }, + { + "teal": 94, + "source": "tests/contracts/abi.algo.ts:773", + "pc": [ + 108, + 109, + 110, + 111, + 112, + 113 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:773", + "pc": [ + 114, + 115, + 116 + ] + }, + { + "teal": 96, + "source": "tests/contracts/abi.algo.ts:773", + "pc": [ + 117, + 118, + 119, + 120 + ] + }, + { + "teal": 99, + "source": "tests/contracts/abi.algo.ts:773", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 121 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 102, + "source": "tests/contracts/abi.algo.ts:773", + "pc": [ + 122, + 123, + 124, + 125, + 126, + 127 + ] + }, + { + "teal": 103, + "source": "tests/contracts/abi.algo.ts:773", + "pc": [ + 128, + 129, + 130 + ] + }, + { + "teal": 104, + "source": "tests/contracts/abi.algo.ts:773", + "pc": [ + 131, + 132, + 133, + 134 + ] }, { + "teal": 107, + "source": "tests/contracts/abi.algo.ts:773", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 135 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestNonLiteralStaticArrayAccess.arc56_draft.json b/tests/contracts/artifacts/ABITestNonLiteralStaticArrayAccess.arc56_draft.json index a1032cdbd..575c27558 100644 --- a/tests/contracts/artifacts/ABITestNonLiteralStaticArrayAccess.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestNonLiteralStaticArrayAccess.arc56_draft.json @@ -64,22 +64,382 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:53", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:53", + "pc": [ + 1, + 2, + 3 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:53", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:53", + "pc": [ + 6 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:53", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:53", + "pc": [ + 9 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:53", + "pc": [ + 10, + 11 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:53", + "pc": [ + 12 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:53", + "pc": [ + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:53", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 39 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:54", + "pc": [ + 40, + 41, + 42, + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:54", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:54", + "pc": [ + 49 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:54", + "pc": [ + 50 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:54", + "pc": [ + 51 + ] }, { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:54", + "pc": [ + 52, + 53 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:54", + "pc": [ + 54 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:54", + "pc": [ + 55, + 56, + 57 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:54", + "pc": [ + 58, + 59 + ] + }, + { + "teal": 45, + "source": "tests/contracts/abi.algo.ts:54", + "pc": [ + 60 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:55", + "pc": [ + 61, + 62, + 63, + 64, + 65, + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82, + 83, + 84, + 85, + 86 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:55", + "pc": [ + 87, + 88 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:56", + "pc": [ + 89, + 90 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:56", + "pc": [ + 91, + 92 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:58", + "pc": [ + 93, + 94 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:58", + "pc": [ + 95, + 96, + 97 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:58", + "pc": [ + 98 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:54", + "pc": [ + 99, + 100 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:54", + "pc": [ + 101, + 102 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:54", + "pc": [ + 103 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:53", + "pc": [ + 104, + 105 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:53", + "pc": [ + 106 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:53", + "pc": [ + 107, + 108, + 109, + 110, + 111, + 112 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:53", + "pc": [ + 113, + 114, + 115 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:53", + "pc": [ + 116, + 117, + 118, + 119 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:53", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 120 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:53", + "pc": [ + 121, + 122, + 123, + 124, + 125, + 126 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:53", + "pc": [ + 127, + 128, + 129 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:53", + "pc": [ + 130, + 131, + 132, + 133 + ] }, { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:53", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 134 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestNonLiteralStaticArrayElements.arc56_draft.json b/tests/contracts/artifacts/ABITestNonLiteralStaticArrayElements.arc56_draft.json index bc22678ea..196c95a2c 100644 --- a/tests/contracts/artifacts/ABITestNonLiteralStaticArrayElements.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestNonLiteralStaticArrayElements.arc56_draft.json @@ -64,22 +64,444 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:31", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:31", + "pc": [ + 1, + 2, + 3 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:31", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:31", + "pc": [ + 6 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:31", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:31", + "pc": [ + 9 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:31", + "pc": [ + 10, + 11 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:31", + "pc": [ + 12 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:31", + "pc": [ + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:31", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 39 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:32", + "pc": [ + 40, + 41, + 42, + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:32", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:32", + "pc": [ + 49 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:32", + "pc": [ + 50 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:32", + "pc": [ + 51 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:32", + "pc": [ + 52, + 53 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:32", + "pc": [ + 54 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:32", + "pc": [ + 55, + 56, + 57 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:32", + "pc": [ + 58, + 59 + ] + }, + { + "teal": 45, + "source": "tests/contracts/abi.algo.ts:32", + "pc": [ + 60, + 61 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:33", + "pc": [ + 62, + 63 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:33", + "pc": [ + 64, + 65 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:34", + "pc": [ + 66, + 67 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:34", + "pc": [ + 68, + 69 + ] }, { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:35", + "pc": [ + 70, + 71 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:35", + "pc": [ + 72, + 73 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:36", + "pc": [ + 74, + 75 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:36", + "pc": [ + 76 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:36", + "pc": [ + 77, + 78, + 79, + 80, + 81, + 82, + 83, + 84, + 85, + 86 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:36", + "pc": [ + 87 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:36", + "pc": [ + 88, + 89, + 90, + 91, + 92, + 93, + 94, + 95, + 96, + 97 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:36", + "pc": [ + 98 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:36", + "pc": [ + 99, + 100 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:38", + "pc": [ + 101, + 102 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:38", + "pc": [ + 103, + 104, + 105 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:38", + "pc": [ + 106 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:32", + "pc": [ + 107, + 108 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:32", + "pc": [ + 109, + 110 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:32", + "pc": [ + 111 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:31", + "pc": [ + 112, + 113 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:31", + "pc": [ + 114 + ] + }, + { + "teal": 90, + "source": "tests/contracts/abi.algo.ts:31", + "pc": [ + 115, + 116, + 117, + 118, + 119, + 120 + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:31", + "pc": [ + 121, + 122, + 123 + ] + }, + { + "teal": 92, + "source": "tests/contracts/abi.algo.ts:31", + "pc": [ + 124, + 125, + 126, + 127 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:31", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 128 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 98, + "source": "tests/contracts/abi.algo.ts:31", + "pc": [ + 129, + 130, + 131, + 132, + 133, + 134 + ] + }, + { + "teal": 99, + "source": "tests/contracts/abi.algo.ts:31", + "pc": [ + 135, + 136, + 137 + ] + }, + { + "teal": 100, + "source": "tests/contracts/abi.algo.ts:31", + "pc": [ + 138, + 139, + 140, + 141 + ] }, { + "teal": 103, + "source": "tests/contracts/abi.algo.ts:31", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 142 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestObjectArrayRef.arc56_draft.json b/tests/contracts/artifacts/ABITestObjectArrayRef.arc56_draft.json index 4a9cff0ea..c2e1aeeda 100644 --- a/tests/contracts/artifacts/ABITestObjectArrayRef.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestObjectArrayRef.arc56_draft.json @@ -72,22 +72,332 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:815", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:815", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:815", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:815", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:815", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:815", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:815", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:815", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:815", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:816", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] }, { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:816", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:816", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:816", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:816", + "pc": [ + 48, + 49 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:816", + "pc": [ + 50 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:816", + "pc": [ + 51, + 52, + 53 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:816", + "pc": [ + 54, + 55 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:818", + "pc": [ + 56, + 57, + 58, + 59, + 60, + 61 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:817", + "pc": [ + 62, + 63 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:826", + "pc": [ + 64, + 65 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:826", + "pc": [ + 66, + 67, + 68 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:826", + "pc": [ + 69, + 70 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:826", + "pc": [ + 71, + 72 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:828", + "pc": [ + 73, + 74 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:816", + "pc": [ + 75, + 76 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:816", + "pc": [ + 77 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:815", + "pc": [ + 78, + 79 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:815", + "pc": [ + 80 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:815", + "pc": [ + 81, + 82, + 83, + 84, + 85, + 86 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:815", + "pc": [ + 87, + 88, + 89 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:815", + "pc": [ + 90, + 91, + 92, + 93 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:815", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 94 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:815", + "pc": [ + 95, + 96, + 97, + 98, + 99, + 100 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:815", + "pc": [ + 101, + 102, + 103 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:815", + "pc": [ + 104, + 105, + 106, + 107 + ] }, { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:815", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 108 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestObjectInArgs.arc56_draft.json b/tests/contracts/artifacts/ABITestObjectInArgs.arc56_draft.json index d7db1933a..05c7c8730 100644 --- a/tests/contracts/artifacts/ABITestObjectInArgs.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestObjectInArgs.arc56_draft.json @@ -64,22 +64,374 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1402", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:1402", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1402", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1402", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1402", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1402", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1402", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1402", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:1402", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 27, + "source": "tests/contracts/abi.algo.ts:1403", + "pc": [ + 37, + 38, + 39 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:1404", + "pc": [ + 40, + 41 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1404", + "pc": [ + 42, + 43, + 44 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1404", + "pc": [ + 45 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1404", + "pc": [ + 46, + 47 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1404", + "pc": [ + 48, + 49, + 50 + ] }, { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:1404", + "pc": [ + 51 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:1404", + "pc": [ + 52 + ] + }, + { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:1403", + "pc": [ + 53 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:1407", + "pc": [ + 54, + 55, + 56, + 57, + 58, + 59 + ] + }, + { + "teal": 46, + "source": "tests/contracts/abi.algo.ts:1407", + "pc": [ + 60, + 61, + 62 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:1407", + "pc": [ + 63 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:1407", + "pc": [ + 64 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:1407", + "pc": [ + 65 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:1407", + "pc": [ + 66, + 67 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:1407", + "pc": [ + 68 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:1407", + "pc": [ + 69, + 70, + 71 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:1408", + "pc": [ + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82, + 83, + 84, + 85, + 86, + 87, + 88, + 89 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:1408", + "pc": [ + 90, + 91 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:1408", + "pc": [ + 92, + 93, + 94 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:1407", + "pc": [ + 95 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:1402", + "pc": [ + 96, + 97 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:1402", + "pc": [ + 98 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:1402", + "pc": [ + 99, + 100, + 101, + 102, + 103, + 104 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:1402", + "pc": [ + 105, + 106, + 107 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:1402", + "pc": [ + 108, + 109, + 110, + 111 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:1402", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 112 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:1402", + "pc": [ + 113, + 114, + 115, + 116, + 117, + 118 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:1402", + "pc": [ + 119, + 120, + 121 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:1402", + "pc": [ + 122, + 123, + 124, + 125 + ] }, { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:1402", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 126 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestObjectRef.arc56_draft.json b/tests/contracts/artifacts/ABITestObjectRef.arc56_draft.json index 97d3df62a..d9b4a0254 100644 --- a/tests/contracts/artifacts/ABITestObjectRef.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestObjectRef.arc56_draft.json @@ -72,22 +72,343 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:984", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:984", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:984", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:984", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:984", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:984", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:984", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:984", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:984", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:985", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] }, { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:985", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:985", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:985", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:985", + "pc": [ + 48, + 49 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:985", + "pc": [ + 50 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:985", + "pc": [ + 51, + 52, + 53 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:985", + "pc": [ + 54, + 55 + ] + }, + { + "teal": 46, + "source": "tests/contracts/abi.algo.ts:986", + "pc": [ + 56, + 57, + 58, + 59, + 60, + 61, + 62, + 63, + 64, + 65 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:986", + "pc": [ + 66, + 67 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:990", + "pc": [ + 68, + 69 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:990", + "pc": [ + 70, + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:990", + "pc": [ + 80, + 81 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:990", + "pc": [ + 82, + 83 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:992", + "pc": [ + 84, + 85 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:985", + "pc": [ + 86, + 87 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:985", + "pc": [ + 88 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:984", + "pc": [ + 89, + 90 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:984", + "pc": [ + 91 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:984", + "pc": [ + 92, + 93, + 94, + 95, + 96, + 97 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:984", + "pc": [ + 98, + 99, + 100 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:984", + "pc": [ + 101, + 102, + 103, + 104 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:984", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 105 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:984", + "pc": [ + 106, + 107, + 108, + 109, + 110, + 111 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:984", + "pc": [ + 112, + 113, + 114 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:984", + "pc": [ + 115, + 116, + 117, + 118 + ] }, { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:984", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 119 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestOpcodeParamFromObject.arc56_draft.json b/tests/contracts/artifacts/ABITestOpcodeParamFromObject.arc56_draft.json index c5b6bb2c2..9fb7dc718 100644 --- a/tests/contracts/artifacts/ABITestOpcodeParamFromObject.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestOpcodeParamFromObject.arc56_draft.json @@ -64,22 +64,303 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1065", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:1065", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1065", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1065", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1065", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1065", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1065", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1065", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:1065", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:1066", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:1066", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1066", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1066", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1066", + "pc": [ + 48, + 49 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1066", + "pc": [ + 50 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:1066", + "pc": [ + 51, + 52, + 53 + ] }, { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:1066", + "pc": [ + 54, + 55 + ] + }, + { + "teal": 46, + "source": "tests/contracts/abi.algo.ts:1067", + "pc": [ + 56, + 57, + 58 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:1067", + "pc": [ + 59 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:1067", + "pc": [ + 60, + 61 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:1069", + "pc": [ + 62, + 63 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:1066", + "pc": [ + 64, + 65 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:1066", + "pc": [ + 66 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:1065", + "pc": [ + 67, + 68 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:1065", + "pc": [ + 69 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:1065", + "pc": [ + 70, + 71, + 72, + 73, + 74, + 75 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:1065", + "pc": [ + 76, + 77, + 78 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:1065", + "pc": [ + 79, + 80, + 81, + 82 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:1065", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 83 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:1065", + "pc": [ + 84, + 85, + 86, + 87, + 88, + 89 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:1065", + "pc": [ + 90, + 91, + 92 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:1065", + "pc": [ + 93, + 94, + 95, + 96 + ] }, { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:1065", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 97 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestPartialStaticArray.arc56_draft.json b/tests/contracts/artifacts/ABITestPartialStaticArray.arc56_draft.json index 2e6a2356a..d79520605 100644 --- a/tests/contracts/artifacts/ABITestPartialStaticArray.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestPartialStaticArray.arc56_draft.json @@ -64,22 +64,301 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:848", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:848", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:848", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:848", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:848", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:848", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:848", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:848", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:848", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:849", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:849", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:849", + "pc": [ + 46 + ] }, { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:849", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:849", + "pc": [ + 48, + 49 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:849", + "pc": [ + 50 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:849", + "pc": [ + 51, + 52, + 53 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:849", + "pc": [ + 54, + 55 + ] + }, + { + "teal": 46, + "source": "tests/contracts/abi.algo.ts:850", + "pc": [ + 56, + 57, + 58, + 59, + 60, + 61, + 62, + 63 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:850", + "pc": [ + 64, + 65 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:852", + "pc": [ + 66, + 67 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:849", + "pc": [ + 68, + 69 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:849", + "pc": [ + 70 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:848", + "pc": [ + 71, + 72 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:848", + "pc": [ + 73 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:848", + "pc": [ + 74, + 75, + 76, + 77, + 78, + 79 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:848", + "pc": [ + 80, + 81, + 82 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:848", + "pc": [ + 83, + 84, + 85, + 86 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:848", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 87 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:848", + "pc": [ + 88, + 89, + 90, + 91, + 92, + 93 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:848", + "pc": [ + 94, + 95, + 96 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:848", + "pc": [ + 97, + 98, + 99, + 100 + ] }, { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:848", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 101 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestPlusEqualsArrayValue.arc56_draft.json b/tests/contracts/artifacts/ABITestPlusEqualsArrayValue.arc56_draft.json index 24248bc33..75253da1a 100644 --- a/tests/contracts/artifacts/ABITestPlusEqualsArrayValue.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestPlusEqualsArrayValue.arc56_draft.json @@ -64,22 +64,388 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1231", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:1231", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1231", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1231", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1231", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1231", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1231", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1231", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:1231", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:1232", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:1232", + "pc": [ + 43, + 44, + 45 + ] }, { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1232", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1232", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1232", + "pc": [ + 48, + 49 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1232", + "pc": [ + 50 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:1232", + "pc": [ + 51, + 52, + 53 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:1232", + "pc": [ + 54, + 55 + ] + }, + { + "teal": 46, + "source": "tests/contracts/abi.algo.ts:1233", + "pc": [ + 56, + 57, + 58, + 59, + 60, + 61, + 62, + 63, + 64, + 65, + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:1233", + "pc": [ + 74, + 75 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:1234", + "pc": [ + 76, + 77 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:1234", + "pc": [ + 78, + 79 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:1234", + "pc": [ + 80, + 81 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:1234", + "pc": [ + 82, + 83, + 84 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:1234", + "pc": [ + 85 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:1234", + "pc": [ + 86, + 87 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:1234", + "pc": [ + 88 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:1234", + "pc": [ + 89 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:1234", + "pc": [ + 90 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:1234", + "pc": [ + 91, + 92 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:1235", + "pc": [ + 93, + 94 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:1232", + "pc": [ + 95, + 96 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:1232", + "pc": [ + 97 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:1231", + "pc": [ + 98, + 99 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:1231", + "pc": [ + 100 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:1231", + "pc": [ + 101, + 102, + 103, + 104, + 105, + 106 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:1231", + "pc": [ + 107, + 108, + 109 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:1231", + "pc": [ + 110, + 111, + 112, + 113 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:1231", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 114 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:1231", + "pc": [ + 115, + 116, + 117, + 118, + 119, + 120 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:1231", + "pc": [ + 121, + 122, + 123 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:1231", + "pc": [ + 124, + 125, + 126, + 127 + ] }, { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:1231", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 128 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestPlusEqualsObjValue.arc56_draft.json b/tests/contracts/artifacts/ABITestPlusEqualsObjValue.arc56_draft.json index 4704fc2ad..b2609a096 100644 --- a/tests/contracts/artifacts/ABITestPlusEqualsObjValue.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestPlusEqualsObjValue.arc56_draft.json @@ -76,22 +76,388 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1239", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:1239", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1239", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1239", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1239", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1239", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1239", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1239", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:1239", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:1240", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:1240", + "pc": [ + 43, + 44, + 45 + ] }, { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1240", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1240", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1240", + "pc": [ + 48, + 49 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1240", + "pc": [ + 50 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:1240", + "pc": [ + 51, + 52, + 53 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:1240", + "pc": [ + 54, + 55 + ] + }, + { + "teal": 46, + "source": "tests/contracts/abi.algo.ts:1241", + "pc": [ + 56, + 57, + 58, + 59, + 60, + 61, + 62, + 63, + 64, + 65, + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:1241", + "pc": [ + 74, + 75 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:1242", + "pc": [ + 76, + 77 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:1242", + "pc": [ + 78, + 79 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:1242", + "pc": [ + 80, + 81 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:1242", + "pc": [ + 82, + 83, + 84 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:1242", + "pc": [ + 85 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:1242", + "pc": [ + 86, + 87 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:1242", + "pc": [ + 88 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:1242", + "pc": [ + 89 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:1242", + "pc": [ + 90 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:1242", + "pc": [ + 91, + 92 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:1243", + "pc": [ + 93, + 94 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:1240", + "pc": [ + 95, + 96 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:1240", + "pc": [ + 97 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:1239", + "pc": [ + 98, + 99 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:1239", + "pc": [ + 100 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:1239", + "pc": [ + 101, + 102, + 103, + 104, + 105, + 106 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:1239", + "pc": [ + 107, + 108, + 109 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:1239", + "pc": [ + 110, + 111, + 112, + 113 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:1239", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 114 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:1239", + "pc": [ + 115, + 116, + 117, + 118, + 119, + 120 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:1239", + "pc": [ + 121, + 122, + 123 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:1239", + "pc": [ + 124, + 125, + 126, + 127 + ] }, { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:1239", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 128 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestPlusEqualsObjValueInBox.arc56_draft.json b/tests/contracts/artifacts/ABITestPlusEqualsObjValueInBox.arc56_draft.json index 2c8b07286..ee95203e3 100644 --- a/tests/contracts/artifacts/ABITestPlusEqualsObjValueInBox.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestPlusEqualsObjValueInBox.arc56_draft.json @@ -91,28 +91,437 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1247", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:1247", + "pc": [ + 1, + 2, + 3, + 4, + 5, + 6, + 7 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1247", + "pc": [ + 8, + 9 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1247", + "pc": [ + 10 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1247", + "pc": [ + 11, + 12 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1247", + "pc": [ + 13 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1247", + "pc": [ + 14, + 15 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1247", + "pc": [ + 16 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:1247", + "pc": [ + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:1247", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 43 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:1250", + "pc": [ + 44, + 45, + 46, + 47, + 48, + 49 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1250", + "pc": [ + 50, + 51, + 52 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1250", + "pc": [ + 53 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1250", + "pc": [ + 54 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1250", + "pc": [ + 55, + 56 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:1250", + "pc": [ + 57 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:1250", + "pc": [ + 58, + 59, + 60 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:1251", + "pc": [ + 61, + 62, + 63, + 64, + 65, + 66 + ] + }, + { + "teal": 45, + "source": "tests/contracts/abi.algo.ts:1251", + "pc": [ + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82, + 83, + 84 + ] + }, + { + "teal": 46, + "source": "tests/contracts/abi.algo.ts:1251", + "pc": [ + 85 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:1252", + "pc": [ + 86, + 87 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:1252", + "pc": [ + 88, + 89, + 90, + 91, + 92, + 93 + ] }, { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:1252", + "pc": [ + 94, + 95 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:1252", + "pc": [ + 96, + 97 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:1252", + "pc": [ + 98 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:1252", + "pc": [ + 99 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:1252", + "pc": [ + 100, + 101 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:1252", + "pc": [ + 102 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:1252", + "pc": [ + 103 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:1252", + "pc": [ + 104, + 105, + 106, + 107, + 108, + 109 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:1252", + "pc": [ + 110, + 111 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:1252", + "pc": [ + 112 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:1253", + "pc": [ + 113, + 114, + 115, + 116, + 117, + 118 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:1253", + "pc": [ + 119 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:1253", + "errorMessage": "box value does not exist: this.bMap('bMap').value", "pc": [ 120 - ], - "errorMessage": "box value does not exist: this.bMap('bMap').value" + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:1250", + "pc": [ + 121 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:1247", + "pc": [ + 122, + 123 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:1247", + "pc": [ + 124 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:1247", + "pc": [ + 125, + 126, + 127, + 128, + 129, + 130 + ] }, { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:1247", + "pc": [ + 131, + 132, + 133 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:1247", + "pc": [ + 134, + 135, + 136, + 137 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:1247", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 138 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:1247", + "pc": [ + 139, + 140, + 141, + 142, + 143, + 144 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:1247", + "pc": [ + 145, + 146, + 147 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:1247", + "pc": [ + 148, + 149, + 150, + 151 + ] }, { + "teal": 90, + "source": "tests/contracts/abi.algo.ts:1247", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 152 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestPostBoolTupleOffset.arc56_draft.json b/tests/contracts/artifacts/ABITestPostBoolTupleOffset.arc56_draft.json index c539f8dce..40d88ca14 100644 --- a/tests/contracts/artifacts/ABITestPostBoolTupleOffset.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestPostBoolTupleOffset.arc56_draft.json @@ -80,22 +80,549 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1617", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:1617", + "pc": [ + 1, + 2, + 3, + 4, + 5, + 6, + 7, + 8, + 9, + 10, + 11 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1617", + "pc": [ + 12, + 13 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1617", + "pc": [ + 14 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1617", + "pc": [ + 15, + 16 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1617", + "pc": [ + 17 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1617", + "pc": [ + 18, + 19 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1617", + "pc": [ + 20 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:1617", + "pc": [ + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38, + 39, + 40, + 41, + 42, + 43, + 44, + 45, + 46 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:1617", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 47 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:1618", + "pc": [ + 48, + 49, + 50, + 51, + 52, + 53 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1618", + "pc": [ + 54, + 55, + 56 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1618", + "pc": [ + 57 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1618", + "pc": [ + 58 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1618", + "pc": [ + 59, + 60 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:1618", + "pc": [ + 61 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:1618", + "pc": [ + 62, + 63, + 64 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:1618", + "pc": [ + 65, + 66 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:1619", + "pc": [ + 67, + 68, + 69 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:1619", + "pc": [ + 70, + 71 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:1619", + "pc": [ + 72, + 73 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:1619", + "pc": [ + 74 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:1619", + "pc": [ + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82, + 83, + 84 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:1619", + "pc": [ + 85 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:1619", + "pc": [ + 86, + 87, + 88, + 89, + 90, + 91, + 92, + 93, + 94, + 95 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:1619", + "pc": [ + 96 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:1619", + "pc": [ + 97, + 98 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:1621", + "pc": [ + 99, + 100 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:1621", + "pc": [ + 101, + 102 + ] }, { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:1621", + "pc": [ + 103, + 104 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:1621", + "pc": [ + 105, + 106 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:1621", + "pc": [ + 107, + 108 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:1621", + "pc": [ + 109 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:1621", + "pc": [ + 110, + 111 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:1622", + "pc": [ + 112, + 113 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:1622", + "pc": [ + 114, + 115 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:1622", + "pc": [ + 116, + 117 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:1622", + "pc": [ + 118, + 119, + 120, + 121, + 122, + 123, + 124, + 125, + 126, + 127 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:1622", + "pc": [ + 128, + 129 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:1622", + "pc": [ + 130, + 131 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:1623", + "pc": [ + 132, + 133 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:1623", + "pc": [ + 134, + 135 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:1623", + "pc": [ + 136, + 137 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:1623", + "pc": [ + 138, + 139, + 140, + 141, + 142, + 143, + 144, + 145, + 146, + 147 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:1623", + "pc": [ + 148, + 149 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:1623", + "pc": [ + 150, + 151 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:1625", + "pc": [ + 152, + 153 + ] + }, + { + "teal": 90, + "source": "tests/contracts/abi.algo.ts:1618", + "pc": [ + 154, + 155 + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:1618", + "pc": [ + 156 + ] + }, + { + "teal": 94, + "source": "tests/contracts/abi.algo.ts:1617", + "pc": [ + 157, + 158 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:1617", + "pc": [ + 159 + ] + }, + { + "teal": 98, + "source": "tests/contracts/abi.algo.ts:1617", + "pc": [ + 160, + 161, + 162, + 163, + 164, + 165 + ] + }, + { + "teal": 99, + "source": "tests/contracts/abi.algo.ts:1617", + "pc": [ + 166, + 167, + 168 + ] + }, + { + "teal": 100, + "source": "tests/contracts/abi.algo.ts:1617", + "pc": [ + 169, + 170, + 171, + 172 + ] + }, + { + "teal": 103, + "source": "tests/contracts/abi.algo.ts:1617", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 173 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 106, + "source": "tests/contracts/abi.algo.ts:1617", + "pc": [ + 174, + 175, + 176, + 177, + 178, + 179 + ] + }, + { + "teal": 107, + "source": "tests/contracts/abi.algo.ts:1617", + "pc": [ + 180, + 181, + 182 + ] + }, + { + "teal": 108, + "source": "tests/contracts/abi.algo.ts:1617", + "pc": [ + 183, + 184, + 185, + 186 + ] }, { + "teal": 111, + "source": "tests/contracts/abi.algo.ts:1617", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 187 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestPushToArrayInBox.arc56_draft.json b/tests/contracts/artifacts/ABITestPushToArrayInBox.arc56_draft.json index 15541b50e..9b31cc0dd 100644 --- a/tests/contracts/artifacts/ABITestPushToArrayInBox.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestPushToArrayInBox.arc56_draft.json @@ -69,40 +69,759 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1550", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:1550", + "pc": [ + 1, + 2, + 3, + 4, + 5, + 6, + 7 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1550", + "pc": [ + 8, + 9 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1550", + "pc": [ + 10 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1550", + "pc": [ + 11, + 12 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1550", + "pc": [ + 13 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1550", + "pc": [ + 14, + 15 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1550", + "pc": [ + 16 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:1550", + "pc": [ + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:1550", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 43 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:1553", + "pc": [ + 44, + 45, + 46, + 47, + 48, + 49 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1553", + "pc": [ + 50, + 51, + 52 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1553", + "pc": [ + 53 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1553", + "pc": [ + 54 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1553", + "pc": [ + 55, + 56 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:1553", + "pc": [ + 57 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:1553", + "pc": [ + 58 + ] + }, + { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:1553", + "pc": [ + 59, + 60, + 61 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:1553", + "pc": [ + 62 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:1553", + "pc": [ + 63 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:1553", + "pc": [ + 64 + ] }, { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:1553", + "pc": [ + 65 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:1553", + "pc": [ + 66, + 67 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:1553", + "pc": [ + 68 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:1553", + "pc": [ + 69, + 70, + 71 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:1554", + "pc": [ + 72, + 73, + 74, + 75, + 76, + 77 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:1554", + "pc": [ + 78 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:1554", + "pc": [ + 79 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:1554", + "pc": [ + 80 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:1554", + "pc": [ + 81, + 82, + 83, + 84, + 85, + 86, + 87, + 88, + 89, + 90, + 91, + 92, + 93, + 94, + 95, + 96, + 97, + 98, + 99, + 100 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:1554", + "pc": [ + 101 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:1556", + "pc": [ + 102, + 103, + 104, + 105, + 106, + 107 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:1556", + "pc": [ + 108 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:1556", + "errorMessage": "box value does not exist: this.bMap('bMap').value", "pc": [ 109 - ], - "errorMessage": "box value does not exist: this.bMap('bMap').value" + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:1556", + "pc": [ + 110, + 111, + 112 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:1556", + "pc": [ + 113, + 114, + 115, + 116, + 117, + 118, + 119, + 120, + 121, + 122 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:1556", + "pc": [ + 123 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:1556", + "pc": [ + 124, + 125, + 126, + 127, + 128, + 129 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:1556", + "pc": [ + 130 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:1556", + "pc": [ + 131 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:1556", + "pc": [ + 132 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:1556", + "pc": [ + 133 + ] }, { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:1556", + "pc": [ + 134 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:1556", + "pc": [ + 135 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:1556", + "pc": [ + 136, + 137 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:1556", + "pc": [ + 138 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:1556", + "pc": [ + 139 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:1556", + "pc": [ + 140, + 141, + 142 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:1556", + "pc": [ + 143 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:1556", + "pc": [ + 144 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:1556", + "pc": [ + 145 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:1557", + "pc": [ + 146, + 147, + 148, + 149, + 150, + 151 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:1557", + "pc": [ + 152 + ] + }, + { + "teal": 90, + "source": "tests/contracts/abi.algo.ts:1557", + "errorMessage": "box value does not exist: this.bMap('bMap').value", "pc": [ 153 - ], - "errorMessage": "box value does not exist: this.bMap('bMap').value" + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:1557", + "pc": [ + 154, + 155, + 156 + ] + }, + { + "teal": 92, + "source": "tests/contracts/abi.algo.ts:1557", + "pc": [ + 157, + 158, + 159, + 160, + 161, + 162, + 163, + 164, + 165, + 166 + ] + }, + { + "teal": 93, + "source": "tests/contracts/abi.algo.ts:1557", + "pc": [ + 167 + ] + }, + { + "teal": 94, + "source": "tests/contracts/abi.algo.ts:1557", + "pc": [ + 168, + 169, + 170, + 171, + 172, + 173 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:1557", + "pc": [ + 174 + ] + }, + { + "teal": 96, + "source": "tests/contracts/abi.algo.ts:1557", + "pc": [ + 175 + ] + }, + { + "teal": 97, + "source": "tests/contracts/abi.algo.ts:1557", + "pc": [ + 176 + ] + }, + { + "teal": 98, + "source": "tests/contracts/abi.algo.ts:1557", + "pc": [ + 177 + ] + }, + { + "teal": 99, + "source": "tests/contracts/abi.algo.ts:1557", + "pc": [ + 178 + ] }, { + "teal": 100, + "source": "tests/contracts/abi.algo.ts:1557", + "pc": [ + 179 + ] + }, + { + "teal": 101, + "source": "tests/contracts/abi.algo.ts:1557", + "pc": [ + 180, + 181 + ] + }, + { + "teal": 102, + "source": "tests/contracts/abi.algo.ts:1557", + "pc": [ + 182 + ] + }, + { + "teal": 103, + "source": "tests/contracts/abi.algo.ts:1557", + "pc": [ + 183 + ] + }, + { + "teal": 104, + "source": "tests/contracts/abi.algo.ts:1557", + "pc": [ + 184, + 185, + 186 + ] + }, + { + "teal": 105, + "source": "tests/contracts/abi.algo.ts:1557", + "pc": [ + 187 + ] + }, + { + "teal": 106, + "source": "tests/contracts/abi.algo.ts:1557", + "pc": [ + 188 + ] + }, + { + "teal": 107, + "source": "tests/contracts/abi.algo.ts:1557", + "pc": [ + 189 + ] + }, + { + "teal": 111, + "source": "tests/contracts/abi.algo.ts:1559", + "pc": [ + 190, + 191, + 192, + 193, + 194, + 195 + ] + }, + { + "teal": 112, + "source": "tests/contracts/abi.algo.ts:1559", + "pc": [ + 196 + ] + }, + { + "teal": 115, + "source": "tests/contracts/abi.algo.ts:1559", + "errorMessage": "box value does not exist: this.bMap('bMap').value", "pc": [ 197 - ], - "errorMessage": "box value does not exist: this.bMap('bMap').value" + ] }, { + "teal": 116, + "source": "tests/contracts/abi.algo.ts:1559", + "pc": [ + 198, + 199, + 200 + ] + }, + { + "teal": 117, + "source": "tests/contracts/abi.algo.ts:1553", + "pc": [ + 201 + ] + }, + { + "teal": 120, + "source": "tests/contracts/abi.algo.ts:1550", + "pc": [ + 202, + 203 + ] + }, + { + "teal": 121, + "source": "tests/contracts/abi.algo.ts:1550", + "pc": [ + 204 + ] + }, + { + "teal": 124, + "source": "tests/contracts/abi.algo.ts:1550", + "pc": [ + 205, + 206, + 207, + 208, + 209, + 210 + ] + }, + { + "teal": 125, + "source": "tests/contracts/abi.algo.ts:1550", + "pc": [ + 211, + 212, + 213 + ] + }, + { + "teal": 126, + "source": "tests/contracts/abi.algo.ts:1550", + "pc": [ + 214, + 215, + 216, + 217 + ] + }, + { + "teal": 129, + "source": "tests/contracts/abi.algo.ts:1550", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 218 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 132, + "source": "tests/contracts/abi.algo.ts:1550", + "pc": [ + 219, + 220, + 221, + 222, + 223, + 224 + ] + }, + { + "teal": 133, + "source": "tests/contracts/abi.algo.ts:1550", + "pc": [ + 225, + 226, + 227 + ] + }, + { + "teal": 134, + "source": "tests/contracts/abi.algo.ts:1550", + "pc": [ + 228, + 229, + 230, + 231 + ] }, { + "teal": 137, + "source": "tests/contracts/abi.algo.ts:1550", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 232 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestRawBytesFunction.arc56_draft.json b/tests/contracts/artifacts/ABITestRawBytesFunction.arc56_draft.json index 300a70e75..d8eec2eb1 100644 --- a/tests/contracts/artifacts/ABITestRawBytesFunction.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestRawBytesFunction.arc56_draft.json @@ -64,22 +64,342 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1051", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:1051", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1051", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1051", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1051", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1051", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1051", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1051", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:1051", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:1052", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] }, { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:1052", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1052", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1052", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1052", + "pc": [ + 48 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1052", + "pc": [ + 49, + 50, + 51 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:1052", + "pc": [ + 52 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:1052", + "pc": [ + 53 + ] + }, + { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:1052", + "pc": [ + 54 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:1052", + "pc": [ + 55 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:1052", + "pc": [ + 56, + 57 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:1052", + "pc": [ + 58 + ] + }, + { + "teal": 45, + "source": "tests/contracts/abi.algo.ts:1052", + "pc": [ + 59, + 60, + 61 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:1052", + "pc": [ + 62, + 63 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:1053", + "pc": [ + 64, + 65, + 66, + 67, + 68 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:1053", + "pc": [ + 69, + 70 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:1054", + "pc": [ + 71, + 72 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:1052", + "pc": [ + 73, + 74 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:1052", + "pc": [ + 75 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:1051", + "pc": [ + 76, + 77 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:1051", + "pc": [ + 78 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:1051", + "pc": [ + 79, + 80, + 81, + 82, + 83, + 84 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:1051", + "pc": [ + 85, + 86, + 87 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:1051", + "pc": [ + 88, + 89, + 90, + 91 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:1051", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 92 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:1051", + "pc": [ + 93, + 94, + 95, + 96, + 97, + 98 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:1051", + "pc": [ + 99, + 100, + 101 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:1051", + "pc": [ + 102, + 103, + 104, + 105 + ] }, { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:1051", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 106 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestRefTypes.arc56_draft.json b/tests/contracts/artifacts/ABITestRefTypes.arc56_draft.json index 8912e3385..387530ad7 100644 --- a/tests/contracts/artifacts/ABITestRefTypes.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestRefTypes.arc56_draft.json @@ -77,22 +77,420 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1524", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:1524", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1524", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1524", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1524", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1524", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1524", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1524", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:1524", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:1525", + "pc": [ + 37, + 38, + 39 + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:1525", + "pc": [ + 40 + ] + }, + { + "teal": 30, + "source": "tests/contracts/abi.algo.ts:1525", + "pc": [ + 41, + 42 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1525", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1525", + "pc": [ + 46 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1525", + "pc": [ + 47, + 48 + ] + }, + { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:1525", + "pc": [ + 49, + 50, + 51 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:1525", + "pc": [ + 52 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:1525", + "pc": [ + 53, + 54 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:1525", + "pc": [ + 55, + 56, + 57 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:1525", + "pc": [ + 58, + 59 + ] + }, + { + "teal": 45, + "source": "tests/contracts/abi.algo.ts:1525", + "pc": [ + 60 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:1525", + "pc": [ + 61, + 62, + 63 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:1526", + "pc": [ + 64, + 65 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:1526", + "pc": [ + 66, + 67 + ] }, { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:1526", + "pc": [ + 68, + 69 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:1526", + "pc": [ + 70 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:1526", + "pc": [ + 71 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:1526", + "pc": [ + 72 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:1526", + "pc": [ + 73 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:1527", + "pc": [ + 74, + 75 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:1527", + "pc": [ + 76, + 77 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:1527", + "pc": [ + 78 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:1527", + "pc": [ + 79, + 80 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:1527", + "pc": [ + 81, + 82 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:1527", + "pc": [ + 83 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:1527", + "pc": [ + 84 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:1527", + "pc": [ + 85 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:1527", + "pc": [ + 86 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:1525", + "pc": [ + 87 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:1524", + "pc": [ + 88, + 89 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:1524", + "pc": [ + 90 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:1524", + "pc": [ + 91, + 92, + 93, + 94, + 95, + 96 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:1524", + "pc": [ + 97, + 98, + 99 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:1524", + "pc": [ + 100, + 101, + 102, + 103 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:1524", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 104 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:1524", + "pc": [ + 105, + 106, + 107, + 108, + 109, + 110 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:1524", + "pc": [ + 111, + 112, + 113 + ] + }, + { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:1524", + "pc": [ + 114, + 115, + 116, + 117 + ] }, { + "teal": 92, + "source": "tests/contracts/abi.algo.ts:1524", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 118 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestReturnByte.arc56_draft.json b/tests/contracts/artifacts/ABITestReturnByte.arc56_draft.json index 800784777..caa02f7eb 100644 --- a/tests/contracts/artifacts/ABITestReturnByte.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestReturnByte.arc56_draft.json @@ -64,22 +64,339 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1563", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:1563", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1563", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1563", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1563", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1563", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1563", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1563", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:1563", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:1564", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] }, { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:1564", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1564", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1564", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1564", + "pc": [ + 48 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1564", + "pc": [ + 49, + 50, + 51 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:1564", + "pc": [ + 52 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:1564", + "pc": [ + 53 + ] + }, + { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:1564", + "pc": [ + 54 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:1564", + "pc": [ + 55 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:1564", + "pc": [ + 56, + 57 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:1564", + "pc": [ + 58 + ] + }, + { + "teal": 45, + "source": "tests/contracts/abi.algo.ts:1564", + "pc": [ + 59, + 60, + 61 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:1565", + "pc": [ + 62, + 63 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:1565", + "pc": [ + 64, + 65, + 66 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:1565", + "pc": [ + 67, + 68 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:1565", + "pc": [ + 69, + 70 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:1565", + "pc": [ + 71 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:1564", + "pc": [ + 72 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:1563", + "pc": [ + 73, + 74 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:1563", + "pc": [ + 75 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:1563", + "pc": [ + 76, + 77, + 78, + 79, + 80, + 81 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:1563", + "pc": [ + 82, + 83, + 84 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:1563", + "pc": [ + 85, + 86, + 87, + 88 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:1563", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 89 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:1563", + "pc": [ + 90, + 91, + 92, + 93, + 94, + 95 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:1563", + "pc": [ + 96, + 97, + 98 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:1563", + "pc": [ + 99, + 100, + 101, + 102 + ] }, { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:1563", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 103 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestReturnDynamicArray.arc56_draft.json b/tests/contracts/artifacts/ABITestReturnDynamicArray.arc56_draft.json index 811bf814c..b9d4763ef 100644 --- a/tests/contracts/artifacts/ABITestReturnDynamicArray.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestReturnDynamicArray.arc56_draft.json @@ -64,22 +64,378 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:354", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:354", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:354", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:354", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:354", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:354", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:354", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:354", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:354", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:355", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:355", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:355", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:355", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:355", + "pc": [ + 48, + 49 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:355", + "pc": [ + 50 + ] }, { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:355", + "pc": [ + 51 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:355", + "pc": [ + 52, + 53, + 54 + ] + }, + { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:355", + "pc": [ + 55 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:355", + "pc": [ + 56 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:355", + "pc": [ + 57 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:355", + "pc": [ + 58 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:355", + "pc": [ + 59, + 60 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:355", + "pc": [ + 61 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:355", + "pc": [ + 62, + 63, + 64 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:355", + "pc": [ + 65, + 66 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:356", + "pc": [ + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82, + 83, + 84, + 85, + 86, + 87, + 88, + 89, + 90, + 91, + 92 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:356", + "pc": [ + 93, + 94 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:357", + "pc": [ + 95, + 96 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:355", + "pc": [ + 97, + 98 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:355", + "pc": [ + 99 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:354", + "pc": [ + 100, + 101 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:354", + "pc": [ + 102 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:354", + "pc": [ + 103, + 104, + 105, + 106, + 107, + 108 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:354", + "pc": [ + 109, + 110, + 111 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:354", + "pc": [ + 112, + 113, + 114, + 115 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:354", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 116 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:354", + "pc": [ + 117, + 118, + 119, + 120, + 121, + 122 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:354", + "pc": [ + 123, + 124, + 125 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:354", + "pc": [ + 126, + 127, + 128, + 129 + ] }, { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:354", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 130 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestReturnDynamicArrayFromTuple.arc56_draft.json b/tests/contracts/artifacts/ABITestReturnDynamicArrayFromTuple.arc56_draft.json index 5a81ff2b0..a5c7122fb 100644 --- a/tests/contracts/artifacts/ABITestReturnDynamicArrayFromTuple.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestReturnDynamicArrayFromTuple.arc56_draft.json @@ -64,22 +64,828 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:396", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:396", + "pc": [ + 1, + 2, + 3 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:396", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:396", + "pc": [ + 6 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:396", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:396", + "pc": [ + 9 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:396", + "pc": [ + 10, + 11 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:396", + "pc": [ + 12 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:396", + "pc": [ + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:396", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 39 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:397", + "pc": [ + 40, + 41, + 42, + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:397", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:397", + "pc": [ + 49 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:397", + "pc": [ + 50 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:397", + "pc": [ + 51 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:397", + "pc": [ + 52, + 53, + 54 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:397", + "pc": [ + 55 + ] + }, + { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:397", + "pc": [ + 56 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:397", + "pc": [ + 57 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:397", + "pc": [ + 58 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:397", + "pc": [ + 59, + 60 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:397", + "pc": [ + 61 + ] + }, + { + "teal": 46, + "source": "tests/contracts/abi.algo.ts:397", + "pc": [ + 62, + 63, + 64 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:397", + "pc": [ + 65, + 66 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:398", + "pc": [ + 67, + 68 + ] }, { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:398", + "pc": [ + 69, + 70 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:398", + "pc": [ + 71, + 72, + 73, + 74 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:398", + "pc": [ + 75, + 76, + 77 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:398", + "pc": [ + 78, + 79, + 80 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:398", + "pc": [ + 81, + 82, + 83, + 84 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:398", + "pc": [ + 85, + 86, + 87 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:398", + "pc": [ + 88, + 89, + 90, + 91, + 92, + 93 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:398", + "pc": [ + 94, + 95, + 96 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:398", + "pc": [ + 97, + 98, + 99, + 100, + 101, + 102, + 103, + 104 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:398", + "pc": [ + 105, + 106, + 107 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:398", + "pc": [ + 108, + 109, + 110, + 111, + 112, + 113 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:398", + "pc": [ + 114, + 115, + 116 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:398", + "pc": [ + 117 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:398", + "pc": [ + 118 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:398", + "pc": [ + 119, + 120 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:400", + "pc": [ + 121, + 122 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:400", + "pc": [ + 123, + 124 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:400", + "pc": [ + 125, + 126 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:400", + "pc": [ + 127, + 128 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:400", + "pc": [ + 129, + 130 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:400", + "pc": [ + 131, + 132 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:400", + "pc": [ + 133 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:400", + "pc": [ + 134 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:400", + "pc": [ + 135, + 136 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:400", + "pc": [ + 137 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:400", + "pc": [ + 138 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:400", + "pc": [ + 139, + 140 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:400", + "pc": [ + 141 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:400", + "pc": [ + 142, + 143 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:400", + "pc": [ + 144 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:400", + "pc": [ + 145 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:400", + "pc": [ + 146, + 147, + 148 + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:397", + "pc": [ + 149, + 150 + ] + }, + { + "teal": 92, + "source": "tests/contracts/abi.algo.ts:397", + "pc": [ + 151 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:396", + "pc": [ + 152, + 153 + ] + }, + { + "teal": 96, + "source": "tests/contracts/abi.algo.ts:396", + "pc": [ + 154 + ] + }, + { + "teal": 99, + "source": "tests/contracts/abi.algo.ts:396", + "pc": [ + 155, + 156, + 157, + 158, + 159, + 160 + ] + }, + { + "teal": 100, + "source": "tests/contracts/abi.algo.ts:396", + "pc": [ + 161, + 162, + 163 + ] + }, + { + "teal": 101, + "source": "tests/contracts/abi.algo.ts:396", + "pc": [ + 164, + 165, + 166, + 167 + ] + }, + { + "teal": 104, + "source": "tests/contracts/abi.algo.ts:396", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 168 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] }, { + "teal": 107, + "source": "tests/contracts/abi.algo.ts:396", + "pc": [ + 169, + 170, + 171, + 172, + 173, + 174 + ] + }, + { + "teal": 108, + "source": "tests/contracts/abi.algo.ts:396", + "pc": [ + 175, + 176, + 177 + ] + }, + { + "teal": 109, + "source": "tests/contracts/abi.algo.ts:396", + "pc": [ + 178, + 179, + 180, + 181 + ] + }, + { + "teal": 112, + "source": "tests/contracts/abi.algo.ts:396", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 182 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] + }, + { + "teal": 115, + "source": "tests/contracts/abi.algo.ts:396", + "pc": [ + 183, + 184, + 185 + ] + }, + { + "teal": 116, + "source": "tests/contracts/abi.algo.ts:396", + "pc": [ + 186, + 187 + ] + }, + { + "teal": 117, + "source": "tests/contracts/abi.algo.ts:396", + "pc": [ + 188, + 189 + ] + }, + { + "teal": 118, + "source": "tests/contracts/abi.algo.ts:396", + "pc": [ + 190 + ] + }, + { + "teal": 119, + "source": "tests/contracts/abi.algo.ts:396", + "pc": [ + 191, + 192 + ] + }, + { + "teal": 120, + "source": "tests/contracts/abi.algo.ts:396", + "pc": [ + 193, + 194 + ] + }, + { + "teal": 121, + "source": "tests/contracts/abi.algo.ts:396", + "pc": [ + 195 + ] + }, + { + "teal": 124, + "source": "tests/contracts/abi.algo.ts:396", + "pc": [ + 196, + 197, + 198 + ] + }, + { + "teal": 125, + "source": "tests/contracts/abi.algo.ts:396", + "pc": [ + 199, + 200 + ] + }, + { + "teal": 126, + "source": "tests/contracts/abi.algo.ts:396", + "pc": [ + 201, + 202 + ] + }, + { + "teal": 127, + "source": "tests/contracts/abi.algo.ts:396", + "pc": [ + 203 + ] + }, + { + "teal": 128, + "source": "tests/contracts/abi.algo.ts:396", + "pc": [ + 204, + 205 + ] + }, + { + "teal": 129, + "source": "tests/contracts/abi.algo.ts:396", + "pc": [ + 206, + 207 + ] + }, + { + "teal": 130, + "source": "tests/contracts/abi.algo.ts:396", + "pc": [ + 208 + ] + }, + { + "teal": 131, + "source": "tests/contracts/abi.algo.ts:396", + "pc": [ + 209 + ] + }, + { + "teal": 132, + "source": "tests/contracts/abi.algo.ts:396", + "pc": [ + 210, + 211 + ] + }, + { + "teal": 133, + "source": "tests/contracts/abi.algo.ts:396", + "pc": [ + 212 + ] + }, + { + "teal": 134, + "source": "tests/contracts/abi.algo.ts:396", + "pc": [ + 213 + ] + }, + { + "teal": 135, + "source": "tests/contracts/abi.algo.ts:396", + "pc": [ + 214 + ] + }, + { + "teal": 136, + "source": "tests/contracts/abi.algo.ts:396", + "pc": [ + 215, + 216, + 217 + ] + }, + { + "teal": 137, + "source": "tests/contracts/abi.algo.ts:396", + "pc": [ + 218, + 219 + ] + }, + { + "teal": 138, + "source": "tests/contracts/abi.algo.ts:396", + "pc": [ + 220, + 221 + ] + }, + { + "teal": 139, + "source": "tests/contracts/abi.algo.ts:396", + "pc": [ + 222 + ] + }, + { + "teal": 140, + "source": "tests/contracts/abi.algo.ts:396", + "pc": [ + 223 + ] + }, + { + "teal": 141, + "source": "tests/contracts/abi.algo.ts:396", + "pc": [ + 224, + 225 + ] + }, + { + "teal": 142, + "source": "tests/contracts/abi.algo.ts:396", + "pc": [ + 226, + 227 + ] + }, + { + "teal": 143, + "source": "tests/contracts/abi.algo.ts:396", + "pc": [ + 228, + 229 + ] + }, + { + "teal": 144, + "source": "tests/contracts/abi.algo.ts:396", + "pc": [ + 230, + 231 + ] + }, + { + "teal": 145, + "source": "tests/contracts/abi.algo.ts:396", + "pc": [ + 232 + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestReturnStaticArray.arc56_draft.json b/tests/contracts/artifacts/ABITestReturnStaticArray.arc56_draft.json index 5baa49db6..5d5536474 100644 --- a/tests/contracts/artifacts/ABITestReturnStaticArray.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestReturnStaticArray.arc56_draft.json @@ -64,22 +64,319 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:17", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:17", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:17", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:17", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:17", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:17", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:17", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:17", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:17", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:18", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:18", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:18", + "pc": [ + 46 + ] }, { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:18", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:18", + "pc": [ + 48, + 49 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:18", + "pc": [ + 50 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:18", + "pc": [ + 51, + 52, + 53 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:18", + "pc": [ + 54, + 55 + ] + }, + { + "teal": 46, + "source": "tests/contracts/abi.algo.ts:19", + "pc": [ + 56, + 57, + 58, + 59, + 60, + 61, + 62, + 63, + 64, + 65, + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79, + 80, + 81 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:19", + "pc": [ + 82, + 83 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:21", + "pc": [ + 84, + 85 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:18", + "pc": [ + 86, + 87 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:18", + "pc": [ + 88 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:17", + "pc": [ + 89, + 90 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:17", + "pc": [ + 91 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:17", + "pc": [ + 92, + 93, + 94, + 95, + 96, + 97 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:17", + "pc": [ + 98, + 99, + 100 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:17", + "pc": [ + 101, + 102, + 103, + 104 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:17", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 105 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:17", + "pc": [ + 106, + 107, + 108, + 109, + 110, + 111 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:17", + "pc": [ + 112, + 113, + 114 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:17", + "pc": [ + 115, + 116, + 117, + 118 + ] }, { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:17", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 119 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestReturnTuple.arc56_draft.json b/tests/contracts/artifacts/ABITestReturnTuple.arc56_draft.json index a8f1d5f12..2eb453640 100644 --- a/tests/contracts/artifacts/ABITestReturnTuple.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestReturnTuple.arc56_draft.json @@ -64,22 +64,313 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:333", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:333", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:333", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:333", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:333", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:333", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:333", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:333", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:333", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:334", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:334", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:334", + "pc": [ + 46 + ] }, { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:334", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:334", + "pc": [ + 48, + 49 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:334", + "pc": [ + 50 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:334", + "pc": [ + 51, + 52, + 53 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:334", + "pc": [ + 54, + 55 + ] + }, + { + "teal": 46, + "source": "tests/contracts/abi.algo.ts:335", + "pc": [ + 56, + 57, + 58, + 59, + 60, + 61, + 62, + 63, + 64, + 65, + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:335", + "pc": [ + 76, + 77 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:336", + "pc": [ + 78, + 79 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:334", + "pc": [ + 80, + 81 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:334", + "pc": [ + 82 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:333", + "pc": [ + 83, + 84 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:333", + "pc": [ + 85 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:333", + "pc": [ + 86, + 87, + 88, + 89, + 90, + 91 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:333", + "pc": [ + 92, + 93, + 94 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:333", + "pc": [ + 95, + 96, + 97, + 98 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:333", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 99 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:333", + "pc": [ + 100, + 101, + 102, + 103, + 104, + 105 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:333", + "pc": [ + 106, + 107, + 108 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:333", + "pc": [ + 109, + 110, + 111, + 112 + ] }, { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:333", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 113 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestReturnTupleWithDyamicArray.arc56_draft.json b/tests/contracts/artifacts/ABITestReturnTupleWithDyamicArray.arc56_draft.json index 9414144ff..c34b94cd0 100644 --- a/tests/contracts/artifacts/ABITestReturnTupleWithDyamicArray.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestReturnTupleWithDyamicArray.arc56_draft.json @@ -64,22 +64,662 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:388", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:388", + "pc": [ + 1, + 2, + 3 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:388", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:388", + "pc": [ + 6 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:388", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:388", + "pc": [ + 9 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:388", + "pc": [ + 10, + 11 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:388", + "pc": [ + 12 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:388", + "pc": [ + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:388", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 39 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:389", + "pc": [ + 40, + 41, + 42, + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:389", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:389", + "pc": [ + 49 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:389", + "pc": [ + 50 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:389", + "pc": [ + 51, + 52 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:389", + "pc": [ + 53 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:389", + "pc": [ + 54, + 55, + 56 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:389", + "pc": [ + 57, + 58 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:390", + "pc": [ + 59, + 60 + ] }, { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:390", + "pc": [ + 61, + 62 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:390", + "pc": [ + 63, + 64, + 65, + 66 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:390", + "pc": [ + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75, + 76 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:390", + "pc": [ + 77, + 78, + 79 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:390", + "pc": [ + 80, + 81, + 82, + 83 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:390", + "pc": [ + 84, + 85, + 86 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:390", + "pc": [ + 87, + 88, + 89, + 90, + 91, + 92, + 93, + 94, + 95, + 96, + 97, + 98, + 99, + 100, + 101, + 102, + 103, + 104, + 105, + 106 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:390", + "pc": [ + 107, + 108, + 109 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:390", + "pc": [ + 110, + 111, + 112, + 113, + 114, + 115, + 116, + 117 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:390", + "pc": [ + 118, + 119, + 120 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:390", + "pc": [ + 121 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:390", + "pc": [ + 122 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:390", + "pc": [ + 123, + 124 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:392", + "pc": [ + 125, + 126 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:389", + "pc": [ + 127, + 128 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:389", + "pc": [ + 129 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:388", + "pc": [ + 130, + 131 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:388", + "pc": [ + 132 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:388", + "pc": [ + 133, + 134, + 135, + 136, + 137, + 138 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:388", + "pc": [ + 139, + 140, + 141 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:388", + "pc": [ + 142, + 143, + 144, + 145 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:388", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 146 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] }, { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:388", + "pc": [ + 147, + 148, + 149, + 150, + 151, + 152 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:388", + "pc": [ + 153, + 154, + 155 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:388", + "pc": [ + 156, + 157, + 158, + 159 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:388", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 160 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:388", + "pc": [ + 161, + 162, + 163 + ] + }, + { + "teal": 92, + "source": "tests/contracts/abi.algo.ts:388", + "pc": [ + 164, + 165 + ] + }, + { + "teal": 93, + "source": "tests/contracts/abi.algo.ts:388", + "pc": [ + 166, + 167 + ] + }, + { + "teal": 94, + "source": "tests/contracts/abi.algo.ts:388", + "pc": [ + 168 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:388", + "pc": [ + 169, + 170 + ] + }, + { + "teal": 96, + "source": "tests/contracts/abi.algo.ts:388", + "pc": [ + 171, + 172 + ] + }, + { + "teal": 97, + "source": "tests/contracts/abi.algo.ts:388", + "pc": [ + 173 + ] + }, + { + "teal": 100, + "source": "tests/contracts/abi.algo.ts:388", + "pc": [ + 174, + 175, + 176 + ] + }, + { + "teal": 101, + "source": "tests/contracts/abi.algo.ts:388", + "pc": [ + 177, + 178 + ] + }, + { + "teal": 102, + "source": "tests/contracts/abi.algo.ts:388", + "pc": [ + 179, + 180 + ] + }, + { + "teal": 103, + "source": "tests/contracts/abi.algo.ts:388", + "pc": [ + 181 + ] + }, + { + "teal": 104, + "source": "tests/contracts/abi.algo.ts:388", + "pc": [ + 182, + 183 + ] + }, + { + "teal": 105, + "source": "tests/contracts/abi.algo.ts:388", + "pc": [ + 184, + 185 + ] + }, + { + "teal": 106, + "source": "tests/contracts/abi.algo.ts:388", + "pc": [ + 186 + ] + }, + { + "teal": 107, + "source": "tests/contracts/abi.algo.ts:388", + "pc": [ + 187 + ] + }, + { + "teal": 108, + "source": "tests/contracts/abi.algo.ts:388", + "pc": [ + 188, + 189 + ] + }, + { + "teal": 109, + "source": "tests/contracts/abi.algo.ts:388", + "pc": [ + 190 + ] + }, + { + "teal": 110, + "source": "tests/contracts/abi.algo.ts:388", + "pc": [ + 191 + ] + }, + { + "teal": 111, + "source": "tests/contracts/abi.algo.ts:388", + "pc": [ + 192 + ] + }, + { + "teal": 112, + "source": "tests/contracts/abi.algo.ts:388", + "pc": [ + 193, + 194, + 195 + ] + }, + { + "teal": 113, + "source": "tests/contracts/abi.algo.ts:388", + "pc": [ + 196, + 197 + ] + }, + { + "teal": 114, + "source": "tests/contracts/abi.algo.ts:388", + "pc": [ + 198, + 199 + ] + }, + { + "teal": 115, + "source": "tests/contracts/abi.algo.ts:388", + "pc": [ + 200 + ] + }, + { + "teal": 116, + "source": "tests/contracts/abi.algo.ts:388", + "pc": [ + 201 + ] + }, + { + "teal": 117, + "source": "tests/contracts/abi.algo.ts:388", + "pc": [ + 202, + 203 + ] + }, + { + "teal": 118, + "source": "tests/contracts/abi.algo.ts:388", + "pc": [ + 204, + 205 + ] + }, + { + "teal": 119, + "source": "tests/contracts/abi.algo.ts:388", + "pc": [ + 206, + 207 + ] + }, + { + "teal": 120, + "source": "tests/contracts/abi.algo.ts:388", + "pc": [ + 208, + 209 + ] + }, + { + "teal": 121, + "source": "tests/contracts/abi.algo.ts:388", + "pc": [ + 210 + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestSetStaticArrayElement.arc56_draft.json b/tests/contracts/artifacts/ABITestSetStaticArrayElement.arc56_draft.json index 5d43080e4..f4c2e38c3 100644 --- a/tests/contracts/artifacts/ABITestSetStaticArrayElement.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestSetStaticArrayElement.arc56_draft.json @@ -64,22 +64,382 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:62", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:62", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:62", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:62", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:62", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:62", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:62", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:62", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:62", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:63", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:63", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:63", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:63", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:63", + "pc": [ + 48 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:63", + "pc": [ + 49, + 50 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:63", + "pc": [ + 51 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:63", + "pc": [ + 52, + 53, + 54 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:63", + "pc": [ + 55, + 56 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:64", + "pc": [ + 57, + 58, + 59, + 60, + 61, + 62, + 63, + 64, + 65, + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82 + ] }, { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:64", + "pc": [ + 83, + 84 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:66", + "pc": [ + 85, + 86 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:66", + "pc": [ + 87, + 88, + 89, + 90, + 91, + 92, + 93, + 94, + 95, + 96 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:66", + "pc": [ + 97, + 98 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:66", + "pc": [ + 99, + 100 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:68", + "pc": [ + 101, + 102 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:68", + "pc": [ + 103, + 104, + 105 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:68", + "pc": [ + 106 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:63", + "pc": [ + 107, + 108 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:63", + "pc": [ + 109 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:62", + "pc": [ + 110, + 111 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:62", + "pc": [ + 112 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:62", + "pc": [ + 113, + 114, + 115, + 116, + 117, + 118 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:62", + "pc": [ + 119, + 120, + 121 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:62", + "pc": [ + 122, + 123, + 124, + 125 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:62", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 126 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:62", + "pc": [ + 127, + 128, + 129, + 130, + 131, + 132 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:62", + "pc": [ + 133, + 134, + 135 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:62", + "pc": [ + 136, + 137, + 138, + 139 + ] }, { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:62", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 140 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestShortTypeNotation.arc56_draft.json b/tests/contracts/artifacts/ABITestShortTypeNotation.arc56_draft.json index 5551c280a..ae4651651 100644 --- a/tests/contracts/artifacts/ABITestShortTypeNotation.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestShortTypeNotation.arc56_draft.json @@ -64,28 +64,388 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:290", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:290", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:290", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:290", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:290", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:290", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:290", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:290", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:290", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:291", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:291", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:291", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:291", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:291", + "pc": [ + 48 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:291", + "pc": [ + 49, + 50 + ] }, { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:291", + "pc": [ + 51 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:291", + "errorMessage": "shortTypeNotation return value overflowed 16 bits", "pc": [ 52 - ], - "errorMessage": "shortTypeNotation return value overflowed 16 bits" + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:291", + "pc": [ + 53, + 54, + 55 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:291", + "pc": [ + 56 + ] }, { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:291", + "pc": [ + 57 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:291", + "pc": [ + 58, + 59 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:291", + "pc": [ + 60 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:291", + "pc": [ + 61, + 62, + 63 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:291", + "pc": [ + 64, + 65 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:295", + "pc": [ + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82, + 83, + 84, + 85, + 86, + 87, + 88, + 89, + 90, + 91 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:292", + "pc": [ + 92, + 93 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:298", + "pc": [ + 94, + 95 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:298", + "pc": [ + 96, + 97, + 98 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:298", + "pc": [ + 99 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:291", + "pc": [ + 100, + 101 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:291", + "pc": [ + 102 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:290", + "pc": [ + 103, + 104 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:290", + "pc": [ + 105 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:290", + "pc": [ + 106, + 107, + 108, + 109, + 110, + 111 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:290", + "pc": [ + 112, + 113, + 114 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:290", + "pc": [ + 115, + 116, + 117, + 118 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:290", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 119 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:290", + "pc": [ + 120, + 121, + 122, + 123, + 124, + 125 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:290", + "pc": [ + 126, + 127, + 128 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:290", + "pc": [ + 129, + 130, + 131, + 132 + ] }, { + "teal": 90, + "source": "tests/contracts/abi.algo.ts:290", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 133 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestShortenDynamicElementInTuple.arc56_draft.json b/tests/contracts/artifacts/ABITestShortenDynamicElementInTuple.arc56_draft.json index 0ce0220ea..a6e6acca6 100644 --- a/tests/contracts/artifacts/ABITestShortenDynamicElementInTuple.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestShortenDynamicElementInTuple.arc56_draft.json @@ -64,22 +64,1951 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 1, + 2, + 3 + ] + }, + { + "teal": 3, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 4, + 5, + 6, + 7, + 8, + 9, + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 22, + 23 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 24 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 25, + 26 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 27 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 28, + 29 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 30 + ] + }, + { + "teal": 21, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38, + 39, + 40, + 41, + 42, + 43, + 44, + 45, + 46, + 47, + 48, + 49, + 50, + 51, + 52, + 53, + 54, + 55, + 56 + ] + }, + { + "teal": 25, + "source": "tests/contracts/abi.algo.ts:584", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 57 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 30, + "source": "tests/contracts/abi.algo.ts:585", + "pc": [ + 58, + 59, + 60, + 61, + 62, + 63 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:585", + "pc": [ + 64, + 65, + 66 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:585", + "pc": [ + 67 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:585", + "pc": [ + 68 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:585", + "pc": [ + 69, + 70 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:585", + "pc": [ + 71 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:585", + "pc": [ + 72, + 73, + 74 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:585", + "pc": [ + 75, + 76 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:586", + "pc": [ + 77, + 78 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:586", + "pc": [ + 79, + 80 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:586", + "pc": [ + 81, + 82, + 83, + 84 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:587", + "pc": [ + 85, + 86, + 87, + 88, + 89, + 90, + 91, + 92 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:587", + "pc": [ + 93, + 94, + 95 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:588", + "pc": [ + 96, + 97, + 98, + 99, + 100, + 101, + 102, + 103 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:588", + "pc": [ + 104, + 105, + 106 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:589", + "pc": [ + 107, + 108, + 109, + 110, + 111, + 112, + 113, + 114 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:589", + "pc": [ + 115, + 116, + 117 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:586", + "pc": [ + 118 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:586", + "pc": [ + 119 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:586", + "pc": [ + 120, + 121 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:592", + "pc": [ + 122, + 123 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:592", + "pc": [ + 124, + 125 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:592", + "pc": [ + 126, + 127 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:592", + "pc": [ + 128 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:592", + "pc": [ + 129, + 130 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:592", + "pc": [ + 131, + 132 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:592", + "pc": [ + 133, + 134 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:592", + "pc": [ + 135, + 136 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:592", + "pc": [ + 137 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:592", + "pc": [ + 138 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:592", + "pc": [ + 139, + 140 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:592", + "pc": [ + 141 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:592", + "pc": [ + 142, + 143 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:592", + "pc": [ + 144 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:592", + "pc": [ + 145 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:592", + "pc": [ + 146, + 147 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:592", + "pc": [ + 148 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:592", + "pc": [ + 149, + 150 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:592", + "pc": [ + 151 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:592", + "pc": [ + 152, + 153 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:592", + "pc": [ + 154, + 155 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:592", + "pc": [ + 156, + 157 + ] + }, + { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:592", + "pc": [ + 158, + 159 + ] + }, + { + "teal": 90, + "source": "tests/contracts/abi.algo.ts:592", + "pc": [ + 160 + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:592", + "pc": [ + 161, + 162, + 163, + 164, + 165, + 166 + ] + }, + { + "teal": 92, + "source": "tests/contracts/abi.algo.ts:592", + "pc": [ + 167 + ] + }, + { + "teal": 93, + "source": "tests/contracts/abi.algo.ts:592", + "pc": [ + 168, + 169 + ] + }, + { + "teal": 94, + "source": "tests/contracts/abi.algo.ts:592", + "pc": [ + 170, + 171 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:592", + "pc": [ + 172, + 173 + ] + }, + { + "teal": 96, + "source": "tests/contracts/abi.algo.ts:592", + "pc": [ + 174, + 175 + ] + }, + { + "teal": 97, + "source": "tests/contracts/abi.algo.ts:592", + "pc": [ + 176 + ] + }, + { + "teal": 98, + "source": "tests/contracts/abi.algo.ts:592", + "pc": [ + 177, + 178 + ] + }, + { + "teal": 99, + "source": "tests/contracts/abi.algo.ts:592", + "pc": [ + 179 + ] + }, + { + "teal": 100, + "source": "tests/contracts/abi.algo.ts:592", + "pc": [ + 180 + ] + }, + { + "teal": 101, + "source": "tests/contracts/abi.algo.ts:592", + "pc": [ + 181 + ] + }, + { + "teal": 102, + "source": "tests/contracts/abi.algo.ts:592", + "pc": [ + 182 + ] + }, + { + "teal": 103, + "source": "tests/contracts/abi.algo.ts:592", + "pc": [ + 183, + 184 + ] + }, + { + "teal": 104, + "source": "tests/contracts/abi.algo.ts:592", + "pc": [ + 185, + 186, + 187 + ] + }, + { + "teal": 105, + "source": "tests/contracts/abi.algo.ts:592", + "pc": [ + 188, + 189 + ] + }, + { + "teal": 106, + "source": "tests/contracts/abi.algo.ts:592", + "pc": [ + 190, + 191 + ] + }, + { + "teal": 107, + "source": "tests/contracts/abi.algo.ts:592", + "pc": [ + 192, + 193 + ] + }, + { + "teal": 108, + "source": "tests/contracts/abi.algo.ts:592", + "pc": [ + 194 + ] + }, + { + "teal": 109, + "source": "tests/contracts/abi.algo.ts:592", + "pc": [ + 195, + 196, + 197 + ] + }, + { + "teal": 110, + "source": "tests/contracts/abi.algo.ts:592", + "pc": [ + 198, + 199 + ] + }, + { + "teal": 111, + "source": "tests/contracts/abi.algo.ts:592", + "pc": [ + 200, + 201 + ] + }, + { + "teal": 112, + "source": "tests/contracts/abi.algo.ts:592", + "pc": [ + 202, + 203 + ] + }, + { + "teal": 113, + "source": "tests/contracts/abi.algo.ts:592", + "pc": [ + 204 + ] + }, + { + "teal": 114, + "source": "tests/contracts/abi.algo.ts:592", + "pc": [ + 205, + 206, + 207 + ] + }, + { + "teal": 115, + "source": "tests/contracts/abi.algo.ts:592", + "pc": [ + 208, + 209 + ] + }, + { + "teal": 116, + "source": "tests/contracts/abi.algo.ts:592", + "pc": [ + 210, + 211 + ] + }, + { + "teal": 120, + "source": "tests/contracts/abi.algo.ts:593", + "pc": [ + 212, + 213 + ] + }, + { + "teal": 121, + "source": "tests/contracts/abi.algo.ts:593", + "pc": [ + 214, + 215 + ] + }, + { + "teal": 122, + "source": "tests/contracts/abi.algo.ts:593", + "pc": [ + 216, + 217 + ] + }, + { + "teal": 123, + "source": "tests/contracts/abi.algo.ts:593", + "pc": [ + 218 + ] + }, + { + "teal": 124, + "source": "tests/contracts/abi.algo.ts:593", + "pc": [ + 219, + 220 + ] + }, + { + "teal": 125, + "source": "tests/contracts/abi.algo.ts:593", + "pc": [ + 221, + 222 + ] + }, + { + "teal": 126, + "source": "tests/contracts/abi.algo.ts:593", + "pc": [ + 223, + 224 + ] + }, + { + "teal": 127, + "source": "tests/contracts/abi.algo.ts:593", + "pc": [ + 225, + 226 + ] + }, + { + "teal": 128, + "source": "tests/contracts/abi.algo.ts:593", + "pc": [ + 227 + ] + }, + { + "teal": 129, + "source": "tests/contracts/abi.algo.ts:593", + "pc": [ + 228 + ] + }, + { + "teal": 130, + "source": "tests/contracts/abi.algo.ts:593", + "pc": [ + 229, + 230 + ] + }, + { + "teal": 131, + "source": "tests/contracts/abi.algo.ts:593", + "pc": [ + 231 + ] + }, + { + "teal": 132, + "source": "tests/contracts/abi.algo.ts:593", + "pc": [ + 232, + 233 + ] + }, + { + "teal": 133, + "source": "tests/contracts/abi.algo.ts:593", + "pc": [ + 234 + ] + }, + { + "teal": 134, + "source": "tests/contracts/abi.algo.ts:593", + "pc": [ + 235 + ] + }, + { + "teal": 135, + "source": "tests/contracts/abi.algo.ts:593", + "pc": [ + 236, + 237 + ] + }, + { + "teal": 136, + "source": "tests/contracts/abi.algo.ts:593", + "pc": [ + 238 + ] + }, + { + "teal": 137, + "source": "tests/contracts/abi.algo.ts:593", + "pc": [ + 239, + 240 + ] + }, + { + "teal": 138, + "source": "tests/contracts/abi.algo.ts:593", + "pc": [ + 241 + ] + }, + { + "teal": 139, + "source": "tests/contracts/abi.algo.ts:593", + "pc": [ + 242, + 243 + ] + }, + { + "teal": 140, + "source": "tests/contracts/abi.algo.ts:593", + "pc": [ + 244, + 245 + ] + }, + { + "teal": 141, + "source": "tests/contracts/abi.algo.ts:593", + "pc": [ + 246, + 247 + ] + }, + { + "teal": 142, + "source": "tests/contracts/abi.algo.ts:593", + "pc": [ + 248, + 249 + ] + }, + { + "teal": 143, + "source": "tests/contracts/abi.algo.ts:593", + "pc": [ + 250 + ] + }, + { + "teal": 144, + "source": "tests/contracts/abi.algo.ts:593", + "pc": [ + 251, + 252, + 253, + 254, + 255, + 256 + ] + }, + { + "teal": 145, + "source": "tests/contracts/abi.algo.ts:593", + "pc": [ + 257 + ] + }, + { + "teal": 146, + "source": "tests/contracts/abi.algo.ts:593", + "pc": [ + 258, + 259 + ] + }, + { + "teal": 147, + "source": "tests/contracts/abi.algo.ts:593", + "pc": [ + 260, + 261 + ] + }, + { + "teal": 148, + "source": "tests/contracts/abi.algo.ts:593", + "pc": [ + 262, + 263 + ] + }, + { + "teal": 149, + "source": "tests/contracts/abi.algo.ts:593", + "pc": [ + 264, + 265 + ] + }, + { + "teal": 150, + "source": "tests/contracts/abi.algo.ts:593", + "pc": [ + 266 + ] + }, + { + "teal": 151, + "source": "tests/contracts/abi.algo.ts:593", + "pc": [ + 267, + 268 + ] + }, + { + "teal": 152, + "source": "tests/contracts/abi.algo.ts:593", + "pc": [ + 269 + ] + }, + { + "teal": 153, + "source": "tests/contracts/abi.algo.ts:593", + "pc": [ + 270 + ] + }, + { + "teal": 154, + "source": "tests/contracts/abi.algo.ts:593", + "pc": [ + 271 + ] + }, + { + "teal": 155, + "source": "tests/contracts/abi.algo.ts:593", + "pc": [ + 272 + ] + }, + { + "teal": 156, + "source": "tests/contracts/abi.algo.ts:593", + "pc": [ + 273, + 274 + ] + }, + { + "teal": 157, + "source": "tests/contracts/abi.algo.ts:593", + "pc": [ + 275, + 276, + 277 + ] + }, + { + "teal": 158, + "source": "tests/contracts/abi.algo.ts:593", + "pc": [ + 278, + 279 + ] + }, + { + "teal": 159, + "source": "tests/contracts/abi.algo.ts:593", + "pc": [ + 280, + 281 + ] + }, + { + "teal": 160, + "source": "tests/contracts/abi.algo.ts:593", + "pc": [ + 282, + 283 + ] + }, + { + "teal": 161, + "source": "tests/contracts/abi.algo.ts:593", + "pc": [ + 284 + ] + }, + { + "teal": 162, + "source": "tests/contracts/abi.algo.ts:593", + "pc": [ + 285, + 286, + 287 + ] + }, + { + "teal": 163, + "source": "tests/contracts/abi.algo.ts:593", + "pc": [ + 288, + 289 + ] + }, + { + "teal": 164, + "source": "tests/contracts/abi.algo.ts:593", + "pc": [ + 290, + 291 + ] + }, + { + "teal": 168, + "source": "tests/contracts/abi.algo.ts:594", + "pc": [ + 292, + 293 + ] + }, + { + "teal": 169, + "source": "tests/contracts/abi.algo.ts:594", + "pc": [ + 294, + 295 + ] + }, + { + "teal": 170, + "source": "tests/contracts/abi.algo.ts:594", + "pc": [ + 296, + 297 + ] + }, + { + "teal": 171, + "source": "tests/contracts/abi.algo.ts:594", + "pc": [ + 298 + ] + }, + { + "teal": 172, + "source": "tests/contracts/abi.algo.ts:594", + "pc": [ + 299, + 300 + ] + }, + { + "teal": 173, + "source": "tests/contracts/abi.algo.ts:594", + "pc": [ + 301, + 302 + ] + }, + { + "teal": 174, + "source": "tests/contracts/abi.algo.ts:594", + "pc": [ + 303, + 304 + ] + }, + { + "teal": 175, + "source": "tests/contracts/abi.algo.ts:594", + "pc": [ + 305, + 306 + ] + }, + { + "teal": 176, + "source": "tests/contracts/abi.algo.ts:594", + "pc": [ + 307 + ] + }, + { + "teal": 177, + "source": "tests/contracts/abi.algo.ts:594", + "pc": [ + 308 + ] + }, + { + "teal": 178, + "source": "tests/contracts/abi.algo.ts:594", + "pc": [ + 309, + 310 + ] + }, + { + "teal": 179, + "source": "tests/contracts/abi.algo.ts:594", + "pc": [ + 311 + ] + }, + { + "teal": 180, + "source": "tests/contracts/abi.algo.ts:594", + "pc": [ + 312, + 313 + ] + }, + { + "teal": 181, + "source": "tests/contracts/abi.algo.ts:594", + "pc": [ + 314 + ] + }, + { + "teal": 182, + "source": "tests/contracts/abi.algo.ts:594", + "pc": [ + 315 + ] + }, + { + "teal": 183, + "source": "tests/contracts/abi.algo.ts:594", + "pc": [ + 316, + 317 + ] + }, + { + "teal": 184, + "source": "tests/contracts/abi.algo.ts:594", + "pc": [ + 318 + ] + }, + { + "teal": 185, + "source": "tests/contracts/abi.algo.ts:594", + "pc": [ + 319, + 320 + ] + }, + { + "teal": 186, + "source": "tests/contracts/abi.algo.ts:594", + "pc": [ + 321 + ] + }, + { + "teal": 187, + "source": "tests/contracts/abi.algo.ts:594", + "pc": [ + 322, + 323 + ] + }, + { + "teal": 188, + "source": "tests/contracts/abi.algo.ts:594", + "pc": [ + 324, + 325 + ] + }, + { + "teal": 189, + "source": "tests/contracts/abi.algo.ts:594", + "pc": [ + 326, + 327 + ] + }, + { + "teal": 190, + "source": "tests/contracts/abi.algo.ts:594", + "pc": [ + 328, + 329 + ] + }, + { + "teal": 191, + "source": "tests/contracts/abi.algo.ts:594", + "pc": [ + 330 + ] + }, + { + "teal": 192, + "source": "tests/contracts/abi.algo.ts:594", + "pc": [ + 331, + 332, + 333, + 334, + 335, + 336 + ] + }, + { + "teal": 193, + "source": "tests/contracts/abi.algo.ts:594", + "pc": [ + 337 + ] + }, + { + "teal": 194, + "source": "tests/contracts/abi.algo.ts:594", + "pc": [ + 338, + 339 + ] + }, + { + "teal": 195, + "source": "tests/contracts/abi.algo.ts:594", + "pc": [ + 340, + 341 + ] + }, + { + "teal": 196, + "source": "tests/contracts/abi.algo.ts:594", + "pc": [ + 342, + 343 + ] + }, + { + "teal": 197, + "source": "tests/contracts/abi.algo.ts:594", + "pc": [ + 344, + 345 + ] + }, + { + "teal": 198, + "source": "tests/contracts/abi.algo.ts:594", + "pc": [ + 346 + ] + }, + { + "teal": 199, + "source": "tests/contracts/abi.algo.ts:594", + "pc": [ + 347, + 348 + ] + }, + { + "teal": 200, + "source": "tests/contracts/abi.algo.ts:594", + "pc": [ + 349 + ] + }, + { + "teal": 201, + "source": "tests/contracts/abi.algo.ts:594", + "pc": [ + 350 + ] + }, + { + "teal": 202, + "source": "tests/contracts/abi.algo.ts:594", + "pc": [ + 351 + ] + }, + { + "teal": 203, + "source": "tests/contracts/abi.algo.ts:594", + "pc": [ + 352 + ] + }, + { + "teal": 204, + "source": "tests/contracts/abi.algo.ts:594", + "pc": [ + 353, + 354 + ] + }, + { + "teal": 205, + "source": "tests/contracts/abi.algo.ts:594", + "pc": [ + 355, + 356, + 357 + ] + }, + { + "teal": 206, + "source": "tests/contracts/abi.algo.ts:594", + "pc": [ + 358, + 359 + ] + }, + { + "teal": 207, + "source": "tests/contracts/abi.algo.ts:594", + "pc": [ + 360, + 361 + ] + }, + { + "teal": 211, + "source": "tests/contracts/abi.algo.ts:596", + "pc": [ + 362, + 363 + ] + }, + { + "teal": 214, + "source": "tests/contracts/abi.algo.ts:585", + "pc": [ + 364, + 365 + ] + }, + { + "teal": 215, + "source": "tests/contracts/abi.algo.ts:585", + "pc": [ + 366 + ] + }, + { + "teal": 218, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 367, + 368 + ] + }, + { + "teal": 219, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 369 + ] + }, + { + "teal": 222, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 370, + 371, + 372, + 373, + 374, + 375 + ] + }, + { + "teal": 223, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 376, + 377, + 378 + ] + }, + { + "teal": 224, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 379, + 380, + 381, + 382 + ] }, { + "teal": 227, + "source": "tests/contracts/abi.algo.ts:584", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 383 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] }, { + "teal": 230, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 384, + 385, + 386, + 387, + 388, + 389 + ] + }, + { + "teal": 231, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 390, + 391, + 392 + ] + }, + { + "teal": 232, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 393, + 394, + 395, + 396 + ] + }, + { + "teal": 235, + "source": "tests/contracts/abi.algo.ts:584", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 397 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] + }, + { + "teal": 238, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 398, + 399, + 400 + ] + }, + { + "teal": 239, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 401, + 402 + ] + }, + { + "teal": 240, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 403, + 404 + ] + }, + { + "teal": 241, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 405 + ] + }, + { + "teal": 242, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 406, + 407 + ] + }, + { + "teal": 243, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 408, + 409 + ] + }, + { + "teal": 244, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 410 + ] + }, + { + "teal": 245, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 411 + ] + }, + { + "teal": 246, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 412, + 413 + ] + }, + { + "teal": 247, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 414 + ] + }, + { + "teal": 248, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 415 + ] + }, + { + "teal": 249, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 416 + ] + }, + { + "teal": 250, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 417, + 418, + 419 + ] + }, + { + "teal": 251, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 420, + 421 + ] + }, + { + "teal": 252, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 422, + 423 + ] + }, + { + "teal": 253, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 424 + ] + }, + { + "teal": 254, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 425 + ] + }, + { + "teal": 255, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 426, + 427 + ] + }, + { + "teal": 256, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 428, + 429 + ] + }, + { + "teal": 257, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 430, + 431 + ] + }, + { + "teal": 258, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 432, + 433 + ] + }, + { + "teal": 259, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 434 + ] + }, + { + "teal": 262, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 435, + 436, + 437 + ] + }, + { + "teal": 263, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 438, + 439 + ] + }, + { + "teal": 264, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 440, + 441 + ] + }, + { + "teal": 265, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 442, + 443 + ] + }, + { + "teal": 266, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 444 + ] + }, + { + "teal": 267, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 445, + 446 + ] + }, + { + "teal": 268, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 447, + 448, + 449 + ] + }, + { + "teal": 269, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 450 + ] + }, + { + "teal": 270, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 451, + 452, + 453 + ] + }, + { + "teal": 273, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 454 + ] + }, + { + "teal": 274, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 455 + ] + }, + { + "teal": 277, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 456 + ] + }, + { + "teal": 278, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 457, + 458, + 459 + ] + }, + { + "teal": 279, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 460, + 461 + ] + }, + { + "teal": 280, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 462 + ] + }, + { + "teal": 281, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 463, + 464 + ] + }, + { + "teal": 282, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 465 + ] + }, + { + "teal": 283, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 466 + ] + }, + { + "teal": 284, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 467, + 468 + ] + }, + { + "teal": 285, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 469 + ] + }, + { + "teal": 288, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 470, + 471 + ] + }, + { + "teal": 289, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 472 + ] + }, + { + "teal": 290, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 473, + 474 + ] + }, + { + "teal": 291, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 475 + ] + }, + { + "teal": 292, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 476, + 477, + 478 + ] + }, + { + "teal": 293, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 479, + 480 + ] + }, + { + "teal": 294, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 481 + ] + }, + { + "teal": 295, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 482, + 483 + ] + }, + { + "teal": 296, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 484, + 485 + ] + }, + { + "teal": 297, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 486, + 487 + ] + }, + { + "teal": 298, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 488, + 489, + 490 + ] + }, + { + "teal": 301, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 491, + 492 + ] + }, + { + "teal": 302, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 493, + 494 + ] + }, + { + "teal": 303, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 495 + ] + }, + { + "teal": 304, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 496, + 497 + ] + }, + { + "teal": 305, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 498, + 499 + ] + }, + { + "teal": 308, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 500 + ] + }, + { + "teal": 309, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 501, + 502 + ] + }, + { + "teal": 310, + "source": "tests/contracts/abi.algo.ts:584", + "pc": [ + 503 + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestSimpleTuple.arc56_draft.json b/tests/contracts/artifacts/ABITestSimpleTuple.arc56_draft.json index a5f05ab44..0ed398f25 100644 --- a/tests/contracts/artifacts/ABITestSimpleTuple.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestSimpleTuple.arc56_draft.json @@ -64,28 +64,384 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:255", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:255", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:255", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:255", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:255", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:255", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:255", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:255", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:255", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:256", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:256", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:256", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:256", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:256", + "pc": [ + 48 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:256", + "pc": [ + 49, + 50 + ] }, { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:256", + "pc": [ + 51 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:256", + "errorMessage": "simpleTuple return value overflowed 16 bits", "pc": [ 52 - ], - "errorMessage": "simpleTuple return value overflowed 16 bits" + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:256", + "pc": [ + 53, + 54, + 55 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:256", + "pc": [ + 56 + ] }, { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:256", + "pc": [ + 57 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:256", + "pc": [ + 58, + 59 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:256", + "pc": [ + 60 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:256", + "pc": [ + 61, + 62, + 63 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:256", + "pc": [ + 64, + 65 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:257", + "pc": [ + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82, + 83, + 84, + 85, + 86, + 87 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:257", + "pc": [ + 88, + 89 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:259", + "pc": [ + 90, + 91 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:259", + "pc": [ + 92, + 93, + 94 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:259", + "pc": [ + 95 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:256", + "pc": [ + 96, + 97 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:256", + "pc": [ + 98 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:255", + "pc": [ + 99, + 100 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:255", + "pc": [ + 101 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:255", + "pc": [ + 102, + 103, + 104, + 105, + 106, + 107 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:255", + "pc": [ + 108, + 109, + 110 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:255", + "pc": [ + 111, + 112, + 113, + 114 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:255", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 115 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:255", + "pc": [ + 116, + 117, + 118, + 119, + 120, + 121 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:255", + "pc": [ + 122, + 123, + 124 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:255", + "pc": [ + 125, + 126, + 127, + 128 + ] }, { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:255", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 129 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestSmallerByteCasting.arc56_draft.json b/tests/contracts/artifacts/ABITestSmallerByteCasting.arc56_draft.json index 2546d874a..9ed6d9731 100644 --- a/tests/contracts/artifacts/ABITestSmallerByteCasting.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestSmallerByteCasting.arc56_draft.json @@ -69,28 +69,318 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1211", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:1211", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1211", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1211", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1211", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1211", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1211", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1211", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:1211", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] }, { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:1212", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:1212", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1212", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1212", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1212", + "pc": [ + 48, + 49 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1212", + "pc": [ + 50 + ] + }, + { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:1212", + "errorMessage": "argument 0 (a) for smallerByteCasting must be a byte[4]", "pc": [ 51 - ], - "errorMessage": "argument 0 (a) for smallerByteCasting must be a byte[4]" + ] }, { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:1212", + "pc": [ + 52, + 53, + 54 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:1212", + "pc": [ + 55 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:1212", + "pc": [ + 56 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:1212", + "pc": [ + 57, + 58 + ] + }, + { + "teal": 45, + "source": "tests/contracts/abi.algo.ts:1212", + "pc": [ + 59 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:1212", + "pc": [ + 60, + 61, + 62 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:1213", + "pc": [ + 63, + 64 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:1213", + "pc": [ + 65, + 66, + 67 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:1212", + "pc": [ + 68 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:1211", + "pc": [ + 69, + 70 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:1211", + "pc": [ + 71 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:1211", + "pc": [ + 72, + 73, + 74, + 75, + 76, + 77 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:1211", + "pc": [ + 78, + 79, + 80 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:1211", + "pc": [ + 81, + 82, + 83, + 84 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:1211", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 85 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:1211", + "pc": [ + 86, + 87, + 88, + 89, + 90, + 91 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:1211", + "pc": [ + 92, + 93, + 94 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:1211", + "pc": [ + 95, + 96, + 97, + 98 + ] }, { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:1211", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 99 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestSpliceFirstElement.arc56_draft.json b/tests/contracts/artifacts/ABITestSpliceFirstElement.arc56_draft.json index e2d2e65d7..4311adb9c 100644 --- a/tests/contracts/artifacts/ABITestSpliceFirstElement.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestSpliceFirstElement.arc56_draft.json @@ -64,22 +64,528 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:508", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:508", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:508", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:508", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:508", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:508", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:508", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:508", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:508", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:509", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:509", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:509", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:509", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:509", + "pc": [ + 48, + 49 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:509", + "pc": [ + 50 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:509", + "pc": [ + 51 + ] }, { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:509", + "pc": [ + 52, + 53, + 54 + ] + }, + { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:509", + "pc": [ + 55 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:509", + "pc": [ + 56 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:509", + "pc": [ + 57 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:509", + "pc": [ + 58 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:509", + "pc": [ + 59, + 60 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:509", + "pc": [ + 61 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:509", + "pc": [ + 62, + 63, + 64 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:509", + "pc": [ + 65, + 66 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:510", + "pc": [ + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:510", + "pc": [ + 75, + 76 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:512", + "pc": [ + 77, + 78 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:512", + "pc": [ + 79, + 80 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:512", + "pc": [ + 81, + 82 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:512", + "pc": [ + 83, + 84 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:512", + "pc": [ + 85, + 86 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:512", + "pc": [ + 87, + 88 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:512", + "pc": [ + 89, + 90 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:512", + "pc": [ + 91, + 92 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:512", + "pc": [ + 93, + 94 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:512", + "pc": [ + 95 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:512", + "pc": [ + 96, + 97 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:512", + "pc": [ + 98 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:512", + "pc": [ + 99 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:512", + "pc": [ + 100, + 101 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:512", + "pc": [ + 102, + 103 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:512", + "pc": [ + 104 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:512", + "pc": [ + 105, + 106 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:512", + "pc": [ + 107 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:512", + "pc": [ + 108 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:512", + "pc": [ + 109 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:512", + "pc": [ + 110 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:512", + "pc": [ + 111, + 112 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:514", + "pc": [ + 113, + 114 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:509", + "pc": [ + 115, + 116 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:509", + "pc": [ + 117 + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:508", + "pc": [ + 118, + 119 + ] + }, + { + "teal": 92, + "source": "tests/contracts/abi.algo.ts:508", + "pc": [ + 120 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:508", + "pc": [ + 121, + 122, + 123, + 124, + 125, + 126 + ] + }, + { + "teal": 96, + "source": "tests/contracts/abi.algo.ts:508", + "pc": [ + 127, + 128, + 129 + ] + }, + { + "teal": 97, + "source": "tests/contracts/abi.algo.ts:508", + "pc": [ + 130, + 131, + 132, + 133 + ] + }, + { + "teal": 100, + "source": "tests/contracts/abi.algo.ts:508", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 134 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 103, + "source": "tests/contracts/abi.algo.ts:508", + "pc": [ + 135, + 136, + 137, + 138, + 139, + 140 + ] + }, + { + "teal": 104, + "source": "tests/contracts/abi.algo.ts:508", + "pc": [ + 141, + 142, + 143 + ] + }, + { + "teal": 105, + "source": "tests/contracts/abi.algo.ts:508", + "pc": [ + 144, + 145, + 146, + 147 + ] }, { + "teal": 108, + "source": "tests/contracts/abi.algo.ts:508", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 148 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestSpliceFirstElementValue.arc56_draft.json b/tests/contracts/artifacts/ABITestSpliceFirstElementValue.arc56_draft.json index 92e2cd015..622c4443c 100644 --- a/tests/contracts/artifacts/ABITestSpliceFirstElementValue.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestSpliceFirstElementValue.arc56_draft.json @@ -64,22 +64,613 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:518", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:518", + "pc": [ + 1, + 2, + 3 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:518", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:518", + "pc": [ + 6 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:518", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:518", + "pc": [ + 9 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:518", + "pc": [ + 10, + 11 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:518", + "pc": [ + 12 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:518", + "pc": [ + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:518", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 39 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:519", + "pc": [ + 40, + 41, + 42, + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:519", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:519", + "pc": [ + 49 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:519", + "pc": [ + 50 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:519", + "pc": [ + 51, + 52 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:519", + "pc": [ + 53 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:519", + "pc": [ + 54 + ] + }, + { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:519", + "pc": [ + 55, + 56, + 57 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:519", + "pc": [ + 58 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:519", + "pc": [ + 59 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:519", + "pc": [ + 60 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:519", + "pc": [ + 61 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:519", + "pc": [ + 62, + 63 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:519", + "pc": [ + 64 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:519", + "pc": [ + 65, + 66, + 67 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:519", + "pc": [ + 68, + 69 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:519", + "pc": [ + 70 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:520", + "pc": [ + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:520", + "pc": [ + 79, + 80 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:522", + "pc": [ + 81, + 82 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:522", + "pc": [ + 83, + 84 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:522", + "pc": [ + 85, + 86 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:522", + "pc": [ + 87, + 88 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:522", + "pc": [ + 89, + 90 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:522", + "pc": [ + 91, + 92 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:522", + "pc": [ + 93, + 94 + ] }, { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:522", + "pc": [ + 95, + 96 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:522", + "pc": [ + 97, + 98 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:522", + "pc": [ + 99 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:522", + "pc": [ + 100, + 101 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:522", + "pc": [ + 102 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:522", + "pc": [ + 103 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:522", + "pc": [ + 104, + 105 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:522", + "pc": [ + 106, + 107 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:522", + "pc": [ + 108 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:522", + "pc": [ + 109, + 110 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:522", + "pc": [ + 111 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:522", + "pc": [ + 112 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:522", + "pc": [ + 113 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:522", + "pc": [ + 114 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:522", + "pc": [ + 115, + 116 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:522", + "pc": [ + 117, + 118 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:522", + "pc": [ + 119, + 120 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:522", + "pc": [ + 121, + 122 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:522", + "pc": [ + 123 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:522", + "pc": [ + 124 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:522", + "pc": [ + 125 + ] + }, + { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:522", + "pc": [ + 126, + 127 + ] + }, + { + "teal": 90, + "source": "tests/contracts/abi.algo.ts:522", + "pc": [ + 128, + 129 + ] + }, + { + "teal": 94, + "source": "tests/contracts/abi.algo.ts:524", + "pc": [ + 130, + 131 + ] + }, + { + "teal": 97, + "source": "tests/contracts/abi.algo.ts:519", + "pc": [ + 132, + 133 + ] + }, + { + "teal": 100, + "source": "tests/contracts/abi.algo.ts:519", + "pc": [ + 134, + 135 + ] + }, + { + "teal": 101, + "source": "tests/contracts/abi.algo.ts:519", + "pc": [ + 136 + ] + }, + { + "teal": 104, + "source": "tests/contracts/abi.algo.ts:518", + "pc": [ + 137, + 138 + ] + }, + { + "teal": 105, + "source": "tests/contracts/abi.algo.ts:518", + "pc": [ + 139 + ] + }, + { + "teal": 108, + "source": "tests/contracts/abi.algo.ts:518", + "pc": [ + 140, + 141, + 142, + 143, + 144, + 145 + ] + }, + { + "teal": 109, + "source": "tests/contracts/abi.algo.ts:518", + "pc": [ + 146, + 147, + 148 + ] + }, + { + "teal": 110, + "source": "tests/contracts/abi.algo.ts:518", + "pc": [ + 149, + 150, + 151, + 152 + ] + }, + { + "teal": 113, + "source": "tests/contracts/abi.algo.ts:518", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 153 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 116, + "source": "tests/contracts/abi.algo.ts:518", + "pc": [ + 154, + 155, + 156, + 157, + 158, + 159 + ] + }, + { + "teal": 117, + "source": "tests/contracts/abi.algo.ts:518", + "pc": [ + 160, + 161, + 162 + ] + }, + { + "teal": 118, + "source": "tests/contracts/abi.algo.ts:518", + "pc": [ + 163, + 164, + 165, + 166 + ] }, { + "teal": 121, + "source": "tests/contracts/abi.algo.ts:518", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 167 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestSpliceLastElement.arc56_draft.json b/tests/contracts/artifacts/ABITestSpliceLastElement.arc56_draft.json index b18b79d5c..900fd4d33 100644 --- a/tests/contracts/artifacts/ABITestSpliceLastElement.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestSpliceLastElement.arc56_draft.json @@ -64,22 +64,528 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:488", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:488", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:488", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:488", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:488", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:488", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:488", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:488", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:488", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:489", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:489", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:489", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:489", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:489", + "pc": [ + 48, + 49 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:489", + "pc": [ + 50 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:489", + "pc": [ + 51 + ] }, { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:489", + "pc": [ + 52, + 53, + 54 + ] + }, + { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:489", + "pc": [ + 55 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:489", + "pc": [ + 56 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:489", + "pc": [ + 57 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:489", + "pc": [ + 58 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:489", + "pc": [ + 59, + 60 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:489", + "pc": [ + 61 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:489", + "pc": [ + 62, + 63, + 64 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:489", + "pc": [ + 65, + 66 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:490", + "pc": [ + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:490", + "pc": [ + 75, + 76 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:492", + "pc": [ + 77, + 78 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:492", + "pc": [ + 79, + 80 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:492", + "pc": [ + 81, + 82 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:492", + "pc": [ + 83, + 84 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:492", + "pc": [ + 85, + 86 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:492", + "pc": [ + 87, + 88 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:492", + "pc": [ + 89, + 90 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:492", + "pc": [ + 91, + 92 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:492", + "pc": [ + 93, + 94 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:492", + "pc": [ + 95 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:492", + "pc": [ + 96, + 97 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:492", + "pc": [ + 98 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:492", + "pc": [ + 99 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:492", + "pc": [ + 100, + 101 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:492", + "pc": [ + 102, + 103 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:492", + "pc": [ + 104 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:492", + "pc": [ + 105, + 106 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:492", + "pc": [ + 107 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:492", + "pc": [ + 108 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:492", + "pc": [ + 109 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:492", + "pc": [ + 110 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:492", + "pc": [ + 111, + 112 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:494", + "pc": [ + 113, + 114 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:489", + "pc": [ + 115, + 116 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:489", + "pc": [ + 117 + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:488", + "pc": [ + 118, + 119 + ] + }, + { + "teal": 92, + "source": "tests/contracts/abi.algo.ts:488", + "pc": [ + 120 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:488", + "pc": [ + 121, + 122, + 123, + 124, + 125, + 126 + ] + }, + { + "teal": 96, + "source": "tests/contracts/abi.algo.ts:488", + "pc": [ + 127, + 128, + 129 + ] + }, + { + "teal": 97, + "source": "tests/contracts/abi.algo.ts:488", + "pc": [ + 130, + 131, + 132, + 133 + ] + }, + { + "teal": 100, + "source": "tests/contracts/abi.algo.ts:488", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 134 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 103, + "source": "tests/contracts/abi.algo.ts:488", + "pc": [ + 135, + 136, + 137, + 138, + 139, + 140 + ] + }, + { + "teal": 104, + "source": "tests/contracts/abi.algo.ts:488", + "pc": [ + 141, + 142, + 143 + ] + }, + { + "teal": 105, + "source": "tests/contracts/abi.algo.ts:488", + "pc": [ + 144, + 145, + 146, + 147 + ] }, { + "teal": 108, + "source": "tests/contracts/abi.algo.ts:488", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 148 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestSpliceLastElementValue.arc56_draft.json b/tests/contracts/artifacts/ABITestSpliceLastElementValue.arc56_draft.json index 8f8eab50d..0e98cbfeb 100644 --- a/tests/contracts/artifacts/ABITestSpliceLastElementValue.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestSpliceLastElementValue.arc56_draft.json @@ -64,22 +64,613 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:498", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:498", + "pc": [ + 1, + 2, + 3 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:498", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:498", + "pc": [ + 6 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:498", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:498", + "pc": [ + 9 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:498", + "pc": [ + 10, + 11 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:498", + "pc": [ + 12 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:498", + "pc": [ + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:498", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 39 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:499", + "pc": [ + 40, + 41, + 42, + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:499", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:499", + "pc": [ + 49 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:499", + "pc": [ + 50 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:499", + "pc": [ + 51, + 52 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:499", + "pc": [ + 53 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:499", + "pc": [ + 54 + ] + }, + { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:499", + "pc": [ + 55, + 56, + 57 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:499", + "pc": [ + 58 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:499", + "pc": [ + 59 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:499", + "pc": [ + 60 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:499", + "pc": [ + 61 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:499", + "pc": [ + 62, + 63 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:499", + "pc": [ + 64 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:499", + "pc": [ + 65, + 66, + 67 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:499", + "pc": [ + 68, + 69 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:499", + "pc": [ + 70 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:500", + "pc": [ + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:500", + "pc": [ + 79, + 80 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:502", + "pc": [ + 81, + 82 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:502", + "pc": [ + 83, + 84 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:502", + "pc": [ + 85, + 86 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:502", + "pc": [ + 87, + 88 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:502", + "pc": [ + 89, + 90 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:502", + "pc": [ + 91, + 92 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:502", + "pc": [ + 93, + 94 + ] }, { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:502", + "pc": [ + 95, + 96 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:502", + "pc": [ + 97, + 98 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:502", + "pc": [ + 99 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:502", + "pc": [ + 100, + 101 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:502", + "pc": [ + 102 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:502", + "pc": [ + 103 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:502", + "pc": [ + 104, + 105 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:502", + "pc": [ + 106, + 107 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:502", + "pc": [ + 108 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:502", + "pc": [ + 109, + 110 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:502", + "pc": [ + 111 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:502", + "pc": [ + 112 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:502", + "pc": [ + 113 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:502", + "pc": [ + 114 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:502", + "pc": [ + 115, + 116 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:502", + "pc": [ + 117, + 118 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:502", + "pc": [ + 119, + 120 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:502", + "pc": [ + 121, + 122 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:502", + "pc": [ + 123 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:502", + "pc": [ + 124 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:502", + "pc": [ + 125 + ] + }, + { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:502", + "pc": [ + 126, + 127 + ] + }, + { + "teal": 90, + "source": "tests/contracts/abi.algo.ts:502", + "pc": [ + 128, + 129 + ] + }, + { + "teal": 94, + "source": "tests/contracts/abi.algo.ts:504", + "pc": [ + 130, + 131 + ] + }, + { + "teal": 97, + "source": "tests/contracts/abi.algo.ts:499", + "pc": [ + 132, + 133 + ] + }, + { + "teal": 100, + "source": "tests/contracts/abi.algo.ts:499", + "pc": [ + 134, + 135 + ] + }, + { + "teal": 101, + "source": "tests/contracts/abi.algo.ts:499", + "pc": [ + 136 + ] + }, + { + "teal": 104, + "source": "tests/contracts/abi.algo.ts:498", + "pc": [ + 137, + 138 + ] + }, + { + "teal": 105, + "source": "tests/contracts/abi.algo.ts:498", + "pc": [ + 139 + ] + }, + { + "teal": 108, + "source": "tests/contracts/abi.algo.ts:498", + "pc": [ + 140, + 141, + 142, + 143, + 144, + 145 + ] + }, + { + "teal": 109, + "source": "tests/contracts/abi.algo.ts:498", + "pc": [ + 146, + 147, + 148 + ] + }, + { + "teal": 110, + "source": "tests/contracts/abi.algo.ts:498", + "pc": [ + 149, + 150, + 151, + 152 + ] + }, + { + "teal": 113, + "source": "tests/contracts/abi.algo.ts:498", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 153 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 116, + "source": "tests/contracts/abi.algo.ts:498", + "pc": [ + 154, + 155, + 156, + 157, + 158, + 159 + ] + }, + { + "teal": 117, + "source": "tests/contracts/abi.algo.ts:498", + "pc": [ + 160, + 161, + 162 + ] + }, + { + "teal": 118, + "source": "tests/contracts/abi.algo.ts:498", + "pc": [ + 163, + 164, + 165, + 166 + ] }, { + "teal": 121, + "source": "tests/contracts/abi.algo.ts:498", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 167 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestStaticArray.arc56_draft.json b/tests/contracts/artifacts/ABITestStaticArray.arc56_draft.json index 833916f46..6d9485b53 100644 --- a/tests/contracts/artifacts/ABITestStaticArray.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestStaticArray.arc56_draft.json @@ -64,22 +64,342 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:9", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:9", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:9", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:9", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:9", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:9", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:9", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:9", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:9", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:10", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:10", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:10", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:10", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:10", + "pc": [ + 48 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:10", + "pc": [ + 49, + 50 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:10", + "pc": [ + 51 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:10", + "pc": [ + 52, + 53, + 54 + ] }, { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:10", + "pc": [ + 55, + 56 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:11", + "pc": [ + 57, + 58, + 59, + 60, + 61, + 62, + 63, + 64, + 65, + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:11", + "pc": [ + 83, + 84 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:13", + "pc": [ + 85, + 86 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:13", + "pc": [ + 87, + 88, + 89 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:13", + "pc": [ + 90 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:10", + "pc": [ + 91, + 92 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:10", + "pc": [ + 93 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:9", + "pc": [ + 94, + 95 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:9", + "pc": [ + 96 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:9", + "pc": [ + 97, + 98, + 99, + 100, + 101, + 102 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:9", + "pc": [ + 103, + 104, + 105 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:9", + "pc": [ + 106, + 107, + 108, + 109 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:9", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 110 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:9", + "pc": [ + 111, + 112, + 113, + 114, + 115, + 116 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:9", + "pc": [ + 117, + 118, + 119 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:9", + "pc": [ + 120, + 121, + 122, + 123 + ] }, { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:9", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 124 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestStaticArrayArg.arc56_draft.json b/tests/contracts/artifacts/ABITestStaticArrayArg.arc56_draft.json index f39f6ca91..9f0043397 100644 --- a/tests/contracts/artifacts/ABITestStaticArrayArg.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestStaticArrayArg.arc56_draft.json @@ -69,28 +69,332 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:25", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:25", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:25", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:25", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:25", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:25", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:25", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:25", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:25", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:26", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] }, { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:26", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:26", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:26", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:26", + "pc": [ + 48, + 49 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:26", + "pc": [ + 50 + ] + }, + { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:26", + "errorMessage": "argument 0 (a) for staticArrayArg must be a uint64[3]", "pc": [ 51 - ], - "errorMessage": "argument 0 (a) for staticArrayArg must be a uint64[3]" + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:26", + "pc": [ + 52, + 53, + 54 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:26", + "pc": [ + 55 + ] }, { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:26", + "pc": [ + 56 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:26", + "pc": [ + 57 + ] + }, + { + "teal": 45, + "source": "tests/contracts/abi.algo.ts:26", + "pc": [ + 58, + 59 + ] + }, + { + "teal": 46, + "source": "tests/contracts/abi.algo.ts:26", + "pc": [ + 60 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:26", + "pc": [ + 61, + 62, + 63 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:27", + "pc": [ + 64, + 65 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:27", + "pc": [ + 66, + 67, + 68 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:27", + "pc": [ + 69 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:26", + "pc": [ + 70 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:25", + "pc": [ + 71, + 72 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:25", + "pc": [ + 73 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:25", + "pc": [ + 74, + 75, + 76, + 77, + 78, + 79 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:25", + "pc": [ + 80, + 81, + 82 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:25", + "pc": [ + 83, + 84, + 85, + 86 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:25", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 87 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:25", + "pc": [ + 88, + 89, + 90, + 91, + 92, + 93 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:25", + "pc": [ + 94, + 95, + 96 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:25", + "pc": [ + 97, + 98, + 99, + 100 + ] }, { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:25", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 101 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestStaticArrayInStorageMap.arc56_draft.json b/tests/contracts/artifacts/ABITestStaticArrayInStorageMap.arc56_draft.json index 616c7eb86..984e1af92 100644 --- a/tests/contracts/artifacts/ABITestStaticArrayInStorageMap.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestStaticArrayInStorageMap.arc56_draft.json @@ -97,22 +97,610 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:130", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:130", + "pc": [ + 1, + 2, + 3, + 4, + 5, + 6, + 7, + 8, + 9, + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:130", + "pc": [ + 19, + 20 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:130", + "pc": [ + 21 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:130", + "pc": [ + 22, + 23 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:130", + "pc": [ + 24 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:130", + "pc": [ + 25, + 26 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:130", + "pc": [ + 27 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:130", + "pc": [ + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38, + 39, + 40, + 41, + 42, + 43, + 44, + 45, + 46, + 47, + 48, + 49, + 50, + 51, + 52, + 53 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:130", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 54 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:143", + "pc": [ + 55, + 56, + 57, + 58, + 59, + 60 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:143", + "pc": [ + 61, + 62, + 63 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:143", + "pc": [ + 64 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:143", + "pc": [ + 65 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:143", + "pc": [ + 66, + 67 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:143", + "pc": [ + 68 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:143", + "pc": [ + 69, + 70, + 71 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:143", + "pc": [ + 72, + 73 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:143", + "pc": [ + 74 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:145", + "pc": [ + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82, + 83, + 84, + 85, + 86, + 87, + 88, + 89, + 90, + 91, + 92, + 93, + 94, + 95, + 96, + 97, + 98, + 99, + 100 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:145", + "pc": [ + 101, + 102 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:147", + "pc": [ + 103, + 104, + 105, + 106, + 107, + 108 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:147", + "pc": [ + 109, + 110 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:147", + "pc": [ + 111 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:148", + "pc": [ + 112, + 113 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:148", + "pc": [ + 114, + 115, + 116, + 117, + 118, + 119 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:148", + "pc": [ + 120, + 121 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:148", + "pc": [ + 122 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:149", + "pc": [ + 123, + 124, + 125, + 126, + 127, + 128 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:149", + "pc": [ + 129, + 130 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:149", + "pc": [ + 131 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:152", + "pc": [ + 132, + 133, + 134, + 135, + 136, + 137 + ] }, { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:152", + "pc": [ + 138 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:152", + "pc": [ + 139, + 140, + 141 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:152", + "pc": [ + 142 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:152", + "pc": [ + 143 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:153", + "pc": [ + 144, + 145 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:153", + "pc": [ + 146, + 147, + 148, + 149, + 150, + 151 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:153", + "pc": [ + 152 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:153", + "pc": [ + 153, + 154, + 155 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:153", + "pc": [ + 156 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:153", + "pc": [ + 157 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:151", + "pc": [ + 158 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:154", + "pc": [ + 159, + 160, + 161, + 162, + 163, + 164 + ] + }, + { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:154", + "pc": [ + 165, + 166 + ] + }, + { + "teal": 90, + "source": "tests/contracts/abi.algo.ts:154", + "pc": [ + 167, + 168 + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:154", + "pc": [ + 169 + ] + }, + { + "teal": 92, + "source": "tests/contracts/abi.algo.ts:154", + "pc": [ + 170 + ] + }, + { + "teal": 93, + "source": "tests/contracts/abi.algo.ts:154", + "pc": [ + 171 + ] + }, + { + "teal": 94, + "source": "tests/contracts/abi.algo.ts:151", + "pc": [ + 172 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:151", + "pc": [ + 173, + 174 + ] + }, + { + "teal": 99, + "source": "tests/contracts/abi.algo.ts:157", + "pc": [ + 175, + 176 + ] + }, + { + "teal": 102, + "source": "tests/contracts/abi.algo.ts:143", + "pc": [ + 177, + 178 + ] + }, + { + "teal": 105, + "source": "tests/contracts/abi.algo.ts:143", + "pc": [ + 179, + 180 + ] + }, + { + "teal": 106, + "source": "tests/contracts/abi.algo.ts:143", + "pc": [ + 181 + ] + }, + { + "teal": 109, + "source": "tests/contracts/abi.algo.ts:130", + "pc": [ + 182, + 183 + ] + }, + { + "teal": 110, + "source": "tests/contracts/abi.algo.ts:130", + "pc": [ + 184 + ] + }, + { + "teal": 113, + "source": "tests/contracts/abi.algo.ts:130", + "pc": [ + 185, + 186, + 187, + 188, + 189, + 190 + ] + }, + { + "teal": 114, + "source": "tests/contracts/abi.algo.ts:130", + "pc": [ + 191, + 192, + 193 + ] + }, + { + "teal": 115, + "source": "tests/contracts/abi.algo.ts:130", + "pc": [ + 194, + 195, + 196, + 197 + ] + }, + { + "teal": 118, + "source": "tests/contracts/abi.algo.ts:130", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 198 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 121, + "source": "tests/contracts/abi.algo.ts:130", + "pc": [ + 199, + 200, + 201, + 202, + 203, + 204 + ] + }, + { + "teal": 122, + "source": "tests/contracts/abi.algo.ts:130", + "pc": [ + 205, + 206, + 207 + ] + }, + { + "teal": 123, + "source": "tests/contracts/abi.algo.ts:130", + "pc": [ + 208, + 209, + 210, + 211 + ] }, { + "teal": 126, + "source": "tests/contracts/abi.algo.ts:130", + "errorMessage": "this contract does not implement the given ABI method for call OptIn", "pc": [ 212 - ], - "errorMessage": "this contract does not implement the given ABI method for call OptIn" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestStaticArrayInStorageRef.arc56_draft.json b/tests/contracts/artifacts/ABITestStaticArrayInStorageRef.arc56_draft.json index a8c69c6ab..86412b6f7 100644 --- a/tests/contracts/artifacts/ABITestStaticArrayInStorageRef.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestStaticArrayInStorageRef.arc56_draft.json @@ -97,22 +97,610 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:72", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:72", + "pc": [ + 1, + 2, + 3, + 4, + 5, + 6, + 7, + 8, + 9, + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:72", + "pc": [ + 19, + 20 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:72", + "pc": [ + 21 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:72", + "pc": [ + 22, + 23 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:72", + "pc": [ + 24 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:72", + "pc": [ + 25, + 26 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:72", + "pc": [ + 27 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:72", + "pc": [ + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38, + 39, + 40, + 41, + 42, + 43, + 44, + 45, + 46, + 47, + 48, + 49, + 50, + 51, + 52, + 53 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:72", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 54 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:85", + "pc": [ + 55, + 56, + 57, + 58, + 59, + 60 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:85", + "pc": [ + 61, + 62, + 63 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:85", + "pc": [ + 64 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:85", + "pc": [ + 65 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:85", + "pc": [ + 66, + 67 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:85", + "pc": [ + 68 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:85", + "pc": [ + 69, + 70, + 71 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:85", + "pc": [ + 72, + 73 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:85", + "pc": [ + 74 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:87", + "pc": [ + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82, + 83, + 84, + 85, + 86, + 87, + 88, + 89, + 90, + 91, + 92, + 93, + 94, + 95, + 96, + 97, + 98, + 99, + 100 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:87", + "pc": [ + 101, + 102 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:89", + "pc": [ + 103, + 104, + 105, + 106, + 107, + 108 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:89", + "pc": [ + 109, + 110 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:89", + "pc": [ + 111 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:90", + "pc": [ + 112, + 113 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:90", + "pc": [ + 114, + 115, + 116, + 117, + 118, + 119 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:90", + "pc": [ + 120, + 121 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:90", + "pc": [ + 122 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:91", + "pc": [ + 123, + 124, + 125, + 126, + 127, + 128 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:91", + "pc": [ + 129, + 130 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:91", + "pc": [ + 131 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:93", + "pc": [ + 132, + 133, + 134, + 135, + 136, + 137 + ] }, { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:93", + "pc": [ + 138 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:93", + "pc": [ + 139, + 140, + 141 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:93", + "pc": [ + 142 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:93", + "pc": [ + 143 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:93", + "pc": [ + 144, + 145 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:93", + "pc": [ + 146, + 147, + 148, + 149, + 150, + 151 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:93", + "pc": [ + 152 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:93", + "pc": [ + 153, + 154, + 155 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:93", + "pc": [ + 156 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:93", + "pc": [ + 157 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:93", + "pc": [ + 158 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:93", + "pc": [ + 159, + 160, + 161, + 162, + 163, + 164 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:93", + "pc": [ + 165, + 166 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:93", + "pc": [ + 167, + 168 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:93", + "pc": [ + 169 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:93", + "pc": [ + 170 + ] + }, + { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:93", + "pc": [ + 171 + ] + }, + { + "teal": 90, + "source": "tests/contracts/abi.algo.ts:93", + "pc": [ + 172 + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:93", + "pc": [ + 173, + 174 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:95", + "pc": [ + 175, + 176 + ] + }, + { + "teal": 98, + "source": "tests/contracts/abi.algo.ts:85", + "pc": [ + 177, + 178 + ] + }, + { + "teal": 101, + "source": "tests/contracts/abi.algo.ts:85", + "pc": [ + 179, + 180 + ] + }, + { + "teal": 102, + "source": "tests/contracts/abi.algo.ts:85", + "pc": [ + 181 + ] + }, + { + "teal": 105, + "source": "tests/contracts/abi.algo.ts:72", + "pc": [ + 182, + 183 + ] + }, + { + "teal": 106, + "source": "tests/contracts/abi.algo.ts:72", + "pc": [ + 184 + ] + }, + { + "teal": 109, + "source": "tests/contracts/abi.algo.ts:72", + "pc": [ + 185, + 186, + 187, + 188, + 189, + 190 + ] + }, + { + "teal": 110, + "source": "tests/contracts/abi.algo.ts:72", + "pc": [ + 191, + 192, + 193 + ] + }, + { + "teal": 111, + "source": "tests/contracts/abi.algo.ts:72", + "pc": [ + 194, + 195, + 196, + 197 + ] + }, + { + "teal": 114, + "source": "tests/contracts/abi.algo.ts:72", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 198 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 117, + "source": "tests/contracts/abi.algo.ts:72", + "pc": [ + 199, + 200, + 201, + 202, + 203, + 204 + ] + }, + { + "teal": 118, + "source": "tests/contracts/abi.algo.ts:72", + "pc": [ + 205, + 206, + 207 + ] + }, + { + "teal": 119, + "source": "tests/contracts/abi.algo.ts:72", + "pc": [ + 208, + 209, + 210, + 211 + ] }, { + "teal": 122, + "source": "tests/contracts/abi.algo.ts:72", + "errorMessage": "this contract does not implement the given ABI method for call OptIn", "pc": [ 212 - ], - "errorMessage": "this contract does not implement the given ABI method for call OptIn" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestStaticArrayLength.arc56_draft.json b/tests/contracts/artifacts/ABITestStaticArrayLength.arc56_draft.json index f17d372ee..5e63dc15e 100644 --- a/tests/contracts/artifacts/ABITestStaticArrayLength.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestStaticArrayLength.arc56_draft.json @@ -64,22 +64,307 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1383", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:1383", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1383", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1383", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1383", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1383", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1383", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1383", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:1383", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:1384", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:1384", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1384", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1384", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1384", + "pc": [ + 48 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1384", + "pc": [ + 49, + 50 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:1384", + "pc": [ + 51 + ] }, { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:1384", + "pc": [ + 52, + 53, + 54 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:1384", + "pc": [ + 55, + 56 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:1385", + "pc": [ + 57, + 58, + 59, + 60, + 61, + 62, + 63 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:1385", + "pc": [ + 64, + 65 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:1387", + "pc": [ + 66, + 67 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:1384", + "pc": [ + 68, + 69 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:1384", + "pc": [ + 70 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:1383", + "pc": [ + 71, + 72 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:1383", + "pc": [ + 73 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:1383", + "pc": [ + 74, + 75, + 76, + 77, + 78, + 79 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:1383", + "pc": [ + 80, + 81, + 82 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:1383", + "pc": [ + 83, + 84, + 85, + 86 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:1383", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 87 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:1383", + "pc": [ + 88, + 89, + 90, + 91, + 92, + 93 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:1383", + "pc": [ + 94, + 95, + 96 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:1383", + "pc": [ + 97, + 98, + 99, + 100 + ] }, { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:1383", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 101 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestStaticBoolArray.arc56_draft.json b/tests/contracts/artifacts/ABITestStaticBoolArray.arc56_draft.json index 99f83e7bd..404240e46 100644 --- a/tests/contracts/artifacts/ABITestStaticBoolArray.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestStaticBoolArray.arc56_draft.json @@ -64,22 +64,504 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:895", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:895", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:895", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:895", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:895", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:895", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:895", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:895", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:895", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:896", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:896", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:896", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:896", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:896", + "pc": [ + 48, + 49 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:896", + "pc": [ + 50 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:896", + "pc": [ + 51, + 52, + 53 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:896", + "pc": [ + 54, + 55 + ] + }, + { + "teal": 46, + "source": "tests/contracts/abi.algo.ts:897", + "pc": [ + 56, + 57, + 58, + 59 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:897", + "pc": [ + 60, + 61 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:897", + "pc": [ + 62, + 63 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:897", + "pc": [ + 64 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:897", + "pc": [ + 65, + 66 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:897", + "pc": [ + 67, + 68 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:897", + "pc": [ + 69 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:897", + "pc": [ + 70, + 71 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:897", + "pc": [ + 72, + 73 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:897", + "pc": [ + 74 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:897", + "pc": [ + 75, + 76 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:897", + "pc": [ + 77, + 78 + ] }, { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:897", + "pc": [ + 79 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:897", + "pc": [ + 80, + 81 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:897", + "pc": [ + 82, + 83 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:897", + "pc": [ + 84 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:897", + "pc": [ + 85, + 86 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:897", + "pc": [ + 87, + 88 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:897", + "pc": [ + 89 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:897", + "pc": [ + 90, + 91 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:897", + "pc": [ + 92, + 93 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:897", + "pc": [ + 94 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:897", + "pc": [ + 95, + 96 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:897", + "pc": [ + 97, + 98 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:897", + "pc": [ + 99 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:897", + "pc": [ + 100, + 101 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:897", + "pc": [ + 102, + 103 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:897", + "pc": [ + 104 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:897", + "pc": [ + 105, + 106 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:899", + "pc": [ + 107, + 108 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:896", + "pc": [ + 109, + 110 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:896", + "pc": [ + 111 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:895", + "pc": [ + 112, + 113 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:895", + "pc": [ + 114 + ] + }, + { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:895", + "pc": [ + 115, + 116, + 117, + 118, + 119, + 120 + ] + }, + { + "teal": 90, + "source": "tests/contracts/abi.algo.ts:895", + "pc": [ + 121, + 122, + 123 + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:895", + "pc": [ + 124, + 125, + 126, + 127 + ] + }, + { + "teal": 94, + "source": "tests/contracts/abi.algo.ts:895", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 128 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 97, + "source": "tests/contracts/abi.algo.ts:895", + "pc": [ + 129, + 130, + 131, + 132, + 133, + 134 + ] + }, + { + "teal": 98, + "source": "tests/contracts/abi.algo.ts:895", + "pc": [ + 135, + 136, + 137 + ] + }, + { + "teal": 99, + "source": "tests/contracts/abi.algo.ts:895", + "pc": [ + 138, + 139, + 140, + 141 + ] }, { + "teal": 102, + "source": "tests/contracts/abi.algo.ts:895", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 142 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestStaticBoolArrayAccess.arc56_draft.json b/tests/contracts/artifacts/ABITestStaticBoolArrayAccess.arc56_draft.json index 17173f482..2d17d10b7 100644 --- a/tests/contracts/artifacts/ABITestStaticBoolArrayAccess.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestStaticBoolArrayAccess.arc56_draft.json @@ -64,22 +64,567 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:921", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:921", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:921", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:921", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:921", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:921", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:921", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:921", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:921", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:922", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:922", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:922", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:922", + "pc": [ + 49, + 50 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:922", + "pc": [ + 51, + 52 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:922", + "pc": [ + 53 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:922", + "pc": [ + 54 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:922", + "pc": [ + 55 + ] + }, + { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:922", + "pc": [ + 56, + 57 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:922", + "pc": [ + 58 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:922", + "pc": [ + 59, + 60, + 61 + ] + }, + { + "teal": 46, + "source": "tests/contracts/abi.algo.ts:922", + "pc": [ + 62, + 63 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:923", + "pc": [ + 64, + 65, + 66, + 67 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:923", + "pc": [ + 68, + 69 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:923", + "pc": [ + 70, + 71 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:923", + "pc": [ + 72 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:923", + "pc": [ + 73, + 74 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:923", + "pc": [ + 75, + 76 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:923", + "pc": [ + 77 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:923", + "pc": [ + 78, + 79 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:923", + "pc": [ + 80, + 81 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:923", + "pc": [ + 82 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:923", + "pc": [ + 83, + 84 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:923", + "pc": [ + 85, + 86 + ] }, { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:923", + "pc": [ + 87 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:923", + "pc": [ + 88, + 89 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:923", + "pc": [ + 90, + 91 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:923", + "pc": [ + 92 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:923", + "pc": [ + 93, + 94 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:923", + "pc": [ + 95, + 96 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:923", + "pc": [ + 97 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:923", + "pc": [ + 98, + 99 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:923", + "pc": [ + 100, + 101 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:923", + "pc": [ + 102 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:923", + "pc": [ + 103, + 104 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:923", + "pc": [ + 105, + 106 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:923", + "pc": [ + 107 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:923", + "pc": [ + 108, + 109 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:923", + "pc": [ + 110, + 111 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:923", + "pc": [ + 112 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:923", + "pc": [ + 113, + 114 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:925", + "pc": [ + 115, + 116 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:925", + "pc": [ + 117, + 118 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:925", + "pc": [ + 119, + 120 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:925", + "pc": [ + 121, + 122 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:925", + "pc": [ + 123 + ] + }, + { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:922", + "pc": [ + 124, + 125 + ] + }, + { + "teal": 90, + "source": "tests/contracts/abi.algo.ts:922", + "pc": [ + 126 + ] + }, + { + "teal": 93, + "source": "tests/contracts/abi.algo.ts:921", + "pc": [ + 127, + 128 + ] + }, + { + "teal": 94, + "source": "tests/contracts/abi.algo.ts:921", + "pc": [ + 129 + ] + }, + { + "teal": 97, + "source": "tests/contracts/abi.algo.ts:921", + "pc": [ + 130, + 131, + 132, + 133, + 134, + 135 + ] + }, + { + "teal": 98, + "source": "tests/contracts/abi.algo.ts:921", + "pc": [ + 136, + 137, + 138 + ] + }, + { + "teal": 99, + "source": "tests/contracts/abi.algo.ts:921", + "pc": [ + 139, + 140, + 141, + 142 + ] + }, + { + "teal": 102, + "source": "tests/contracts/abi.algo.ts:921", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 143 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 105, + "source": "tests/contracts/abi.algo.ts:921", + "pc": [ + 144, + 145, + 146, + 147, + 148, + 149 + ] + }, + { + "teal": 106, + "source": "tests/contracts/abi.algo.ts:921", + "pc": [ + 150, + 151, + 152 + ] + }, + { + "teal": 107, + "source": "tests/contracts/abi.algo.ts:921", + "pc": [ + 153, + 154, + 155, + 156 + ] }, { + "teal": 110, + "source": "tests/contracts/abi.algo.ts:921", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 157 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestStaticBoolArrayUpdate.arc56_draft.json b/tests/contracts/artifacts/ABITestStaticBoolArrayUpdate.arc56_draft.json index af354ddb0..06191823c 100644 --- a/tests/contracts/artifacts/ABITestStaticBoolArrayUpdate.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestStaticBoolArrayUpdate.arc56_draft.json @@ -64,22 +64,568 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:945", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:945", + "pc": [ + 1, + 2, + 3 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:945", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:945", + "pc": [ + 6 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:945", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:945", + "pc": [ + 9 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:945", + "pc": [ + 10, + 11 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:945", + "pc": [ + 12 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:945", + "pc": [ + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:945", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 39 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:946", + "pc": [ + 40, + 41, + 42, + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:946", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:946", + "pc": [ + 49 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:946", + "pc": [ + 50 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:946", + "pc": [ + 51, + 52 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:946", + "pc": [ + 53 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:946", + "pc": [ + 54, + 55, + 56 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:946", + "pc": [ + 57, + 58 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:947", + "pc": [ + 59, + 60, + 61, + 62 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:947", + "pc": [ + 63, + 64 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:947", + "pc": [ + 65, + 66 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:947", + "pc": [ + 67 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:947", + "pc": [ + 68, + 69 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:947", + "pc": [ + 70, + 71 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:947", + "pc": [ + 72 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:947", + "pc": [ + 73, + 74 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:947", + "pc": [ + 75, + 76 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:947", + "pc": [ + 77 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:947", + "pc": [ + 78, + 79 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:947", + "pc": [ + 80, + 81 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:947", + "pc": [ + 82 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:947", + "pc": [ + 83, + 84 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:947", + "pc": [ + 85, + 86 + ] }, { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:947", + "pc": [ + 87 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:947", + "pc": [ + 88, + 89 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:947", + "pc": [ + 90, + 91 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:947", + "pc": [ + 92 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:947", + "pc": [ + 93, + 94 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:947", + "pc": [ + 95, + 96 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:947", + "pc": [ + 97 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:947", + "pc": [ + 98, + 99 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:947", + "pc": [ + 100, + 101 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:947", + "pc": [ + 102 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:947", + "pc": [ + 103, + 104 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:947", + "pc": [ + 105, + 106 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:947", + "pc": [ + 107 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:947", + "pc": [ + 108, + 109 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:949", + "pc": [ + 110, + 111 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:949", + "pc": [ + 112, + 113 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:949", + "pc": [ + 114, + 115 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:949", + "pc": [ + 116, + 117 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:949", + "pc": [ + 118, + 119 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:949", + "pc": [ + 120 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:949", + "pc": [ + 121, + 122 + ] + }, + { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:951", + "pc": [ + 123, + 124 + ] + }, + { + "teal": 92, + "source": "tests/contracts/abi.algo.ts:946", + "pc": [ + 125, + 126 + ] + }, + { + "teal": 93, + "source": "tests/contracts/abi.algo.ts:946", + "pc": [ + 127 + ] + }, + { + "teal": 96, + "source": "tests/contracts/abi.algo.ts:945", + "pc": [ + 128, + 129 + ] + }, + { + "teal": 97, + "source": "tests/contracts/abi.algo.ts:945", + "pc": [ + 130 + ] + }, + { + "teal": 100, + "source": "tests/contracts/abi.algo.ts:945", + "pc": [ + 131, + 132, + 133, + 134, + 135, + 136 + ] + }, + { + "teal": 101, + "source": "tests/contracts/abi.algo.ts:945", + "pc": [ + 137, + 138, + 139 + ] + }, + { + "teal": 102, + "source": "tests/contracts/abi.algo.ts:945", + "pc": [ + 140, + 141, + 142, + 143 + ] + }, + { + "teal": 105, + "source": "tests/contracts/abi.algo.ts:945", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 144 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 108, + "source": "tests/contracts/abi.algo.ts:945", + "pc": [ + 145, + 146, + 147, + 148, + 149, + 150 + ] + }, + { + "teal": 109, + "source": "tests/contracts/abi.algo.ts:945", + "pc": [ + 151, + 152, + 153 + ] + }, + { + "teal": 110, + "source": "tests/contracts/abi.algo.ts:945", + "pc": [ + 154, + 155, + 156, + 157 + ] }, { + "teal": 113, + "source": "tests/contracts/abi.algo.ts:945", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 158 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestStaticByteCasting.arc56_draft.json b/tests/contracts/artifacts/ABITestStaticByteCasting.arc56_draft.json index abb690666..1180e580e 100644 --- a/tests/contracts/artifacts/ABITestStaticByteCasting.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestStaticByteCasting.arc56_draft.json @@ -64,22 +64,268 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1039", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:1039", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1039", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1039", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1039", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1039", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1039", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1039", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:1039", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] }, { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:1040", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:1040", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1040", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1040", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1040", + "pc": [ + 48, + 49 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1040", + "pc": [ + 50 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:1040", + "pc": [ + 51, + 52, + 53 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:1041", + "pc": [ + 54, + 55, + 56, + 57, + 58, + 59, + 60 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:1040", + "pc": [ + 61 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:1039", + "pc": [ + 62, + 63 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:1039", + "pc": [ + 64 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:1039", + "pc": [ + 65, + 66, + 67, + 68, + 69, + 70 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:1039", + "pc": [ + 71, + 72, + 73 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:1039", + "pc": [ + 74, + 75, + 76, + 77 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:1039", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 78 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:1039", + "pc": [ + 79, + 80, + 81, + 82, + 83, + 84 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:1039", + "pc": [ + 85, + 86, + 87 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:1039", + "pc": [ + 88, + 89, + 90, + 91 + ] }, { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:1039", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 92 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestStaticForEach.arc56_draft.json b/tests/contracts/artifacts/ABITestStaticForEach.arc56_draft.json index cb885fb6b..1f2647253 100644 --- a/tests/contracts/artifacts/ABITestStaticForEach.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestStaticForEach.arc56_draft.json @@ -64,22 +64,578 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1306", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:1306", + "pc": [ + 1, + 2, + 3 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1306", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1306", + "pc": [ + 6 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1306", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1306", + "pc": [ + 9 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1306", + "pc": [ + 10, + 11 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1306", + "pc": [ + 12 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:1306", + "pc": [ + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:1306", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 39 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:1307", + "pc": [ + 40, + 41, + 42, + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1307", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1307", + "pc": [ + 49 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1307", + "pc": [ + 50 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1307", + "pc": [ + 51 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:1307", + "pc": [ + 52, + 53 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:1307", + "pc": [ + 54 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:1307", + "pc": [ + 55, + 56, + 57 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:1307", + "pc": [ + 58, + 59 + ] + }, + { + "teal": 45, + "source": "tests/contracts/abi.algo.ts:1307", + "pc": [ + 60, + 61 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:1308", + "pc": [ + 62, + 63, + 64, + 65, + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82, + 83, + 84, + 85, + 86, + 87 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:1308", + "pc": [ + 88, + 89 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:1309", + "pc": [ + 90, + 91 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:1309", + "pc": [ + 92, + 93 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:1311", + "pc": [ + 94, + 95 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:1311", + "pc": [ + 96 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:1311", + "pc": [ + 97, + 98 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:1311", + "pc": [ + 99, + 100, + 101 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:1311", + "pc": [ + 102 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:1311", + "pc": [ + 103, + 104 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:1311", + "pc": [ + 105, + 106 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:1311", + "pc": [ + 107, + 108 + ] }, { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:1312", + "pc": [ + 109, + 110 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:1312", + "pc": [ + 111, + 112 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:1312", + "pc": [ + 113 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:1312", + "pc": [ + 114, + 115 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:1311", + "pc": [ + 116, + 117 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:1311", + "pc": [ + 118, + 119 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:1311", + "pc": [ + 120 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:1311", + "pc": [ + 121 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:1311", + "pc": [ + 122, + 123 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:1311", + "pc": [ + 124 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:1311", + "pc": [ + 125, + 126, + 127 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:1311", + "pc": [ + 128, + 129 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:1311", + "pc": [ + 130, + 131 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:1311", + "pc": [ + 132, + 133 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:1311", + "pc": [ + 134, + 135 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:1311", + "pc": [ + 136 + ] + }, + { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:1311", + "pc": [ + 137 + ] + }, + { + "teal": 90, + "source": "tests/contracts/abi.algo.ts:1311", + "pc": [ + 138, + 139 + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:1311", + "pc": [ + 140, + 141, + 142 + ] + }, + { + "teal": 96, + "source": "tests/contracts/abi.algo.ts:1314", + "pc": [ + 143, + 144 + ] + }, + { + "teal": 99, + "source": "tests/contracts/abi.algo.ts:1307", + "pc": [ + 145, + 146 + ] + }, + { + "teal": 102, + "source": "tests/contracts/abi.algo.ts:1307", + "pc": [ + 147, + 148 + ] + }, + { + "teal": 103, + "source": "tests/contracts/abi.algo.ts:1307", + "pc": [ + 149 + ] + }, + { + "teal": 106, + "source": "tests/contracts/abi.algo.ts:1306", + "pc": [ + 150, + 151 + ] + }, + { + "teal": 107, + "source": "tests/contracts/abi.algo.ts:1306", + "pc": [ + 152 + ] + }, + { + "teal": 110, + "source": "tests/contracts/abi.algo.ts:1306", + "pc": [ + 153, + 154, + 155, + 156, + 157, + 158 + ] + }, + { + "teal": 111, + "source": "tests/contracts/abi.algo.ts:1306", + "pc": [ + 159, + 160, + 161 + ] + }, + { + "teal": 112, + "source": "tests/contracts/abi.algo.ts:1306", + "pc": [ + 162, + 163, + 164, + 165 + ] + }, + { + "teal": 115, + "source": "tests/contracts/abi.algo.ts:1306", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 166 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 118, + "source": "tests/contracts/abi.algo.ts:1306", + "pc": [ + 167, + 168, + 169, + 170, + 171, + 172 + ] + }, + { + "teal": 119, + "source": "tests/contracts/abi.algo.ts:1306", + "pc": [ + 173, + 174, + 175 + ] + }, + { + "teal": 120, + "source": "tests/contracts/abi.algo.ts:1306", + "pc": [ + 176, + 177, + 178, + 179 + ] }, { + "teal": 123, + "source": "tests/contracts/abi.algo.ts:1306", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 180 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestStaticForOf.arc56_draft.json b/tests/contracts/artifacts/ABITestStaticForOf.arc56_draft.json index 5575b0bf1..693eab777 100644 --- a/tests/contracts/artifacts/ABITestStaticForOf.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestStaticForOf.arc56_draft.json @@ -64,22 +64,578 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1451", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:1451", + "pc": [ + 1, + 2, + 3 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1451", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1451", + "pc": [ + 6 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1451", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1451", + "pc": [ + 9 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1451", + "pc": [ + 10, + 11 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1451", + "pc": [ + 12 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:1451", + "pc": [ + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:1451", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 39 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:1452", + "pc": [ + 40, + 41, + 42, + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1452", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1452", + "pc": [ + 49 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1452", + "pc": [ + 50 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1452", + "pc": [ + 51 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:1452", + "pc": [ + 52, + 53 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:1452", + "pc": [ + 54 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:1452", + "pc": [ + 55, + 56, + 57 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:1452", + "pc": [ + 58, + 59 + ] + }, + { + "teal": 45, + "source": "tests/contracts/abi.algo.ts:1452", + "pc": [ + 60, + 61 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:1453", + "pc": [ + 62, + 63, + 64, + 65, + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82, + 83, + 84, + 85, + 86, + 87 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:1453", + "pc": [ + 88, + 89 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:1454", + "pc": [ + 90, + 91 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:1454", + "pc": [ + 92, + 93 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:1457", + "pc": [ + 94, + 95 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:1457", + "pc": [ + 96 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:1457", + "pc": [ + 97, + 98 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:1457", + "pc": [ + 99, + 100, + 101 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:1457", + "pc": [ + 102 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:1457", + "pc": [ + 103, + 104 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:1457", + "pc": [ + 105, + 106 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:1457", + "pc": [ + 107, + 108 + ] }, { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:1458", + "pc": [ + 109, + 110 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:1458", + "pc": [ + 111, + 112 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:1458", + "pc": [ + 113 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:1458", + "pc": [ + 114, + 115 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:1457", + "pc": [ + 116, + 117 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:1457", + "pc": [ + 118, + 119 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:1457", + "pc": [ + 120 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:1457", + "pc": [ + 121 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:1457", + "pc": [ + 122, + 123 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:1457", + "pc": [ + 124 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:1457", + "pc": [ + 125, + 126, + 127 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:1457", + "pc": [ + 128, + 129 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:1457", + "pc": [ + 130, + 131 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:1457", + "pc": [ + 132, + 133 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:1457", + "pc": [ + 134, + 135 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:1457", + "pc": [ + 136 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:1457", + "pc": [ + 137 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:1457", + "pc": [ + 138, + 139 + ] + }, + { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:1457", + "pc": [ + 140, + 141, + 142 + ] + }, + { + "teal": 94, + "source": "tests/contracts/abi.algo.ts:1460", + "pc": [ + 143, + 144 + ] + }, + { + "teal": 97, + "source": "tests/contracts/abi.algo.ts:1452", + "pc": [ + 145, + 146 + ] + }, + { + "teal": 100, + "source": "tests/contracts/abi.algo.ts:1452", + "pc": [ + 147, + 148 + ] + }, + { + "teal": 101, + "source": "tests/contracts/abi.algo.ts:1452", + "pc": [ + 149 + ] + }, + { + "teal": 104, + "source": "tests/contracts/abi.algo.ts:1451", + "pc": [ + 150, + 151 + ] + }, + { + "teal": 105, + "source": "tests/contracts/abi.algo.ts:1451", + "pc": [ + 152 + ] + }, + { + "teal": 108, + "source": "tests/contracts/abi.algo.ts:1451", + "pc": [ + 153, + 154, + 155, + 156, + 157, + 158 + ] + }, + { + "teal": 109, + "source": "tests/contracts/abi.algo.ts:1451", + "pc": [ + 159, + 160, + 161 + ] + }, + { + "teal": 110, + "source": "tests/contracts/abi.algo.ts:1451", + "pc": [ + 162, + 163, + 164, + 165 + ] + }, + { + "teal": 113, + "source": "tests/contracts/abi.algo.ts:1451", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 166 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 116, + "source": "tests/contracts/abi.algo.ts:1451", + "pc": [ + 167, + 168, + 169, + 170, + 171, + 172 + ] + }, + { + "teal": 117, + "source": "tests/contracts/abi.algo.ts:1451", + "pc": [ + 173, + 174, + 175 + ] + }, + { + "teal": 118, + "source": "tests/contracts/abi.algo.ts:1451", + "pc": [ + 176, + 177, + 178, + 179 + ] }, { + "teal": 121, + "source": "tests/contracts/abi.algo.ts:1451", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 180 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestStaticStringArrayArg.arc56_draft.json b/tests/contracts/artifacts/ABITestStaticStringArrayArg.arc56_draft.json index d09f7826d..9cba52d90 100644 --- a/tests/contracts/artifacts/ABITestStaticStringArrayArg.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestStaticStringArrayArg.arc56_draft.json @@ -69,22 +69,438 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:643", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:643", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:643", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:643", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:643", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:643", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:643", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:643", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:643", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:644", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:644", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:644", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:644", + "pc": [ + 49 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:644", + "pc": [ + 50 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:644", + "pc": [ + 51 + ] + }, + { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:644", + "pc": [ + 52, + 53, + 54 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:644", + "pc": [ + 55 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:644", + "pc": [ + 56 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:644", + "pc": [ + 57 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:644", + "pc": [ + 58 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:644", + "pc": [ + 59, + 60 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:644", + "pc": [ + 61 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:644", + "pc": [ + 62, + 63, + 64 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:645", + "pc": [ + 65, + 66 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:645", + "pc": [ + 67, + 68 + ] }, { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:645", + "pc": [ + 69, + 70 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:645", + "pc": [ + 71, + 72 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:645", + "pc": [ + 73, + 74 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:645", + "pc": [ + 75, + 76 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:645", + "pc": [ + 77 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:645", + "pc": [ + 78 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:645", + "pc": [ + 79, + 80 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:645", + "pc": [ + 81 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:645", + "pc": [ + 82 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:645", + "pc": [ + 83, + 84 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:645", + "pc": [ + 85 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:645", + "pc": [ + 86, + 87 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:645", + "pc": [ + 88 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:645", + "pc": [ + 89 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:645", + "pc": [ + 90, + 91, + 92 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:644", + "pc": [ + 93 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:643", + "pc": [ + 94, + 95 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:643", + "pc": [ + 96 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:643", + "pc": [ + 97, + 98, + 99, + 100, + 101, + 102 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:643", + "pc": [ + 103, + 104, + 105 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:643", + "pc": [ + 106, + 107, + 108, + 109 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:643", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 110 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:643", + "pc": [ + 111, + 112, + 113, + 114, + 115, + 116 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:643", + "pc": [ + 117, + 118, + 119 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:643", + "pc": [ + 120, + 121, + 122, + 123 + ] }, { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:643", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 124 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestStaticTypeInBox.arc56_draft.json b/tests/contracts/artifacts/ABITestStaticTypeInBox.arc56_draft.json index fb1eef60f..774c77bf9 100644 --- a/tests/contracts/artifacts/ABITestStaticTypeInBox.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestStaticTypeInBox.arc56_draft.json @@ -69,28 +69,304 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1531", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:1531", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1531", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1531", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1531", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1531", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1531", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1531", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:1531", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:1534", + "pc": [ + 37, + 38, + 39 + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:1534", + "pc": [ + 40, + 41 + ] + }, + { + "teal": 30, + "source": "tests/contracts/abi.algo.ts:1534", + "pc": [ + 42 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1534", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:1535", + "pc": [ + 46, + 47 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:1535", + "pc": [ + 48, + 49 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:1535", + "pc": [ + 50 + ] }, { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:1536", + "pc": [ + 51, + 52 + ] + }, + { + "teal": 45, + "source": "tests/contracts/abi.algo.ts:1536", + "pc": [ + 53 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:1536", + "errorMessage": "box value does not exist: this.bMap(this.txn.sender).value", "pc": [ 54 - ], - "errorMessage": "box value does not exist: this.bMap(this.txn.sender).value" + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:1536", + "pc": [ + 55, + 56 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:1536", + "pc": [ + 57 + ] }, { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:1536", + "pc": [ + 58 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:1536", + "pc": [ + 59 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:1534", + "pc": [ + 60 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:1531", + "pc": [ + 61, + 62 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:1531", + "pc": [ + 63 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:1531", + "pc": [ + 64, + 65, + 66, + 67, + 68, + 69 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:1531", + "pc": [ + 70, + 71, + 72 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:1531", + "pc": [ + 73, + 74, + 75, + 76 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:1531", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 77 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:1531", + "pc": [ + 78, + 79, + 80, + 81, + 82, + 83 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:1531", + "pc": [ + 84, + 85, + 86 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:1531", + "pc": [ + 87, + 88, + 89, + 90 + ] }, { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:1531", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 91 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestStoragePropertyReferenceInBox.arc56_draft.json b/tests/contracts/artifacts/ABITestStoragePropertyReferenceInBox.arc56_draft.json index c1bc9a431..87254d465 100644 --- a/tests/contracts/artifacts/ABITestStoragePropertyReferenceInBox.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestStoragePropertyReferenceInBox.arc56_draft.json @@ -85,22 +85,405 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1540", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:1540", + "pc": [ + 1, + 2, + 3, + 4, + 5, + 6, + 7, + 8, + 9 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1540", + "pc": [ + 10, + 11 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1540", + "pc": [ + 12 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1540", + "pc": [ + 13, + 14 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1540", + "pc": [ + 15 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1540", + "pc": [ + 16, + 17 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1540", + "pc": [ + 18 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:1540", + "pc": [ + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38, + 39, + 40, + 41, + 42, + 43, + 44 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:1540", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 45 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:1543", + "pc": [ + 46, + 47, + 48, + 49, + 50, + 51 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1543", + "pc": [ + 52, + 53, + 54 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1543", + "pc": [ + 55 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1543", + "pc": [ + 56 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1543", + "pc": [ + 57 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:1543", + "pc": [ + 58, + 59 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:1543", + "pc": [ + 60 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:1543", + "pc": [ + 61, + 62, + 63 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:1543", + "pc": [ + 64, + 65 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:1544", + "pc": [ + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:1544", + "pc": [ + 74, + 75 + ] }, { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:1544", + "pc": [ + 76, + 77, + 78, + 79, + 80, + 81, + 82, + 83, + 84, + 85 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:1544", + "pc": [ + 86 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:1544", + "pc": [ + 87 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:1545", + "pc": [ + 88, + 89, + 90, + 91, + 92, + 93, + 94, + 95 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:1545", + "pc": [ + 96, + 97 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:1545", + "pc": [ + 98, + 99 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:1545", + "pc": [ + 100 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:1545", + "pc": [ + 101 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:1545", + "pc": [ + 102, + 103 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:1546", + "pc": [ + 104, + 105 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:1543", + "pc": [ + 106, + 107 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:1543", + "pc": [ + 108 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:1540", + "pc": [ + 109, + 110 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:1540", + "pc": [ + 111 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:1540", + "pc": [ + 112, + 113, + 114, + 115, + 116, + 117 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:1540", + "pc": [ + 118, + 119, + 120 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:1540", + "pc": [ + 121, + 122, + 123, + 124 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:1540", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 125 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:1540", + "pc": [ + 126, + 127, + 128, + 129, + 130, + 131 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:1540", + "pc": [ + 132, + 133, + 134 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:1540", + "pc": [ + 135, + 136, + 137, + 138 + ] }, { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:1540", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 139 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestStorageRefAccount.arc56_draft.json b/tests/contracts/artifacts/ABITestStorageRefAccount.arc56_draft.json index 1b4206844..bcfcc896b 100644 --- a/tests/contracts/artifacts/ABITestStorageRefAccount.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestStorageRefAccount.arc56_draft.json @@ -69,22 +69,674 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1014", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:1014", + "pc": [ + 1, + 2, + 3, + 4, + 5, + 6, + 7, + 8, + 9, + 10, + 11, + 12 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1014", + "pc": [ + 13, + 14 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1014", + "pc": [ + 15 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1014", + "pc": [ + 16, + 17 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1014", + "pc": [ + 18 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1014", + "pc": [ + 19, + 20 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1014", + "pc": [ + 21 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:1014", + "pc": [ + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38, + 39, + 40, + 41, + 42, + 43, + 44, + 45, + 46, + 47 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:1014", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 48 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:1017", + "pc": [ + 49, + 50, + 51, + 52, + 53, + 54 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1017", + "pc": [ + 55, + 56, + 57 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1017", + "pc": [ + 58 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1017", + "pc": [ + 59 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1017", + "pc": [ + 60 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:1017", + "pc": [ + 61, + 62 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:1017", + "pc": [ + 63 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:1017", + "pc": [ + 64, + 65, + 66 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:1017", + "pc": [ + 67, + 68 + ] + }, + { + "teal": 45, + "source": "tests/contracts/abi.algo.ts:1017", + "pc": [ + 69 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:1019", + "pc": [ + 70, + 71 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:1019", + "pc": [ + 72, + 73 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:1020", + "pc": [ + 74, + 75 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:1020", + "pc": [ + 76, + 77, + 78, + 79, + 80, + 81, + 82, + 83, + 84, + 85 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:1020", + "pc": [ + 86, + 87, + 88, + 89, + 90, + 91, + 92, + 93, + 94, + 95, + 96, + 97, + 98, + 99, + 100, + 101, + 102, + 103, + 104, + 105, + 106, + 107, + 108, + 109, + 110, + 111, + 112, + 113 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:1020", + "pc": [ + 114 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:1021", + "pc": [ + 115, + 116 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:1021", + "pc": [ + 117, + 118 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:1023", + "pc": [ + 119, + 120 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:1023", + "pc": [ + 121, + 122 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:1021", + "pc": [ + 123, + 124 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:1021", + "pc": [ + 125, + 126, + 127, + 128, + 129, + 130, + 131, + 132, + 133, + 134 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:1021", + "pc": [ + 135 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:1021", + "pc": [ + 136, + 137, + 138 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:1025", + "pc": [ + 139, + 140 + ] }, { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:1025", + "pc": [ + 141, + 142 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:1025", + "pc": [ + 143, + 144, + 145, + 146, + 147, + 148, + 149, + 150, + 151, + 152 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:1025", + "pc": [ + 153, + 154 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:1021", + "pc": [ + 155, + 156 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:1021", + "pc": [ + 157, + 158, + 159, + 160, + 161, + 162, + 163, + 164, + 165, + 166 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:1021", + "pc": [ + 167, + 168 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:1021", + "pc": [ + 169 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:1021", + "pc": [ + 170 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:1021", + "pc": [ + 171, + 172 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:1021", + "pc": [ + 173 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:1021", + "pc": [ + 174 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:1021", + "pc": [ + 175, + 176, + 177 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:1021", + "pc": [ + 178 + ] + }, + { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:1021", + "pc": [ + 179 + ] + }, + { + "teal": 90, + "source": "tests/contracts/abi.algo.ts:1021", + "pc": [ + 180 + ] + }, + { + "teal": 94, + "source": "tests/contracts/abi.algo.ts:1027", + "pc": [ + 181, + 182 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:1027", + "pc": [ + 183, + 184, + 185, + 186, + 187, + 188, + 189, + 190, + 191, + 192 + ] + }, + { + "teal": 96, + "source": "tests/contracts/abi.algo.ts:1027", + "pc": [ + 193 + ] + }, + { + "teal": 97, + "source": "tests/contracts/abi.algo.ts:1027", + "pc": [ + 194, + 195, + 196 + ] + }, + { + "teal": 98, + "source": "tests/contracts/abi.algo.ts:1027", + "pc": [ + 197, + 198 + ] + }, + { + "teal": 99, + "source": "tests/contracts/abi.algo.ts:1027", + "pc": [ + 199, + 200 + ] + }, + { + "teal": 100, + "source": "tests/contracts/abi.algo.ts:1027", + "pc": [ + 201, + 202, + 203 + ] + }, + { + "teal": 101, + "source": "tests/contracts/abi.algo.ts:1027", + "pc": [ + 204 + ] + }, + { + "teal": 104, + "source": "tests/contracts/abi.algo.ts:1017", + "pc": [ + 205, + 206 + ] + }, + { + "teal": 107, + "source": "tests/contracts/abi.algo.ts:1017", + "pc": [ + 207, + 208 + ] + }, + { + "teal": 108, + "source": "tests/contracts/abi.algo.ts:1017", + "pc": [ + 209 + ] + }, + { + "teal": 111, + "source": "tests/contracts/abi.algo.ts:1014", + "pc": [ + 210, + 211 + ] + }, + { + "teal": 112, + "source": "tests/contracts/abi.algo.ts:1014", + "pc": [ + 212 + ] + }, + { + "teal": 115, + "source": "tests/contracts/abi.algo.ts:1014", + "pc": [ + 213, + 214, + 215, + 216, + 217, + 218 + ] + }, + { + "teal": 116, + "source": "tests/contracts/abi.algo.ts:1014", + "pc": [ + 219, + 220, + 221 + ] + }, + { + "teal": 117, + "source": "tests/contracts/abi.algo.ts:1014", + "pc": [ + 222, + 223, + 224, + 225 + ] + }, + { + "teal": 120, + "source": "tests/contracts/abi.algo.ts:1014", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 226 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 123, + "source": "tests/contracts/abi.algo.ts:1014", + "pc": [ + 227, + 228, + 229, + 230, + 231, + 232 + ] + }, + { + "teal": 124, + "source": "tests/contracts/abi.algo.ts:1014", + "pc": [ + 233, + 234, + 235 + ] + }, + { + "teal": 125, + "source": "tests/contracts/abi.algo.ts:1014", + "pc": [ + 236, + 237, + 238, + 239 + ] }, { + "teal": 128, + "source": "tests/contracts/abi.algo.ts:1014", + "errorMessage": "this contract does not implement the given ABI method for call OptIn", "pc": [ 240 - ], - "errorMessage": "this contract does not implement the given ABI method for call OptIn" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestStorageRefKey.arc56_draft.json b/tests/contracts/artifacts/ABITestStorageRefKey.arc56_draft.json index 120e52d0f..c847cba24 100644 --- a/tests/contracts/artifacts/ABITestStorageRefKey.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestStorageRefKey.arc56_draft.json @@ -69,22 +69,632 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:996", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:996", + "pc": [ + 1, + 2, + 3, + 4, + 5, + 6, + 7, + 8, + 9, + 10, + 11, + 12 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:996", + "pc": [ + 13, + 14 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:996", + "pc": [ + 15 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:996", + "pc": [ + 16, + 17 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:996", + "pc": [ + 18 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:996", + "pc": [ + 19, + 20 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:996", + "pc": [ + 21 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:996", + "pc": [ + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38, + 39, + 40, + 41, + 42, + 43, + 44, + 45, + 46, + 47 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:996", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 48 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:999", + "pc": [ + 49, + 50, + 51, + 52, + 53, + 54 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:999", + "pc": [ + 55, + 56, + 57 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:999", + "pc": [ + 58 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:999", + "pc": [ + 59 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:999", + "pc": [ + 60 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:999", + "pc": [ + 61, + 62 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:999", + "pc": [ + 63 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:999", + "pc": [ + 64, + 65, + 66 + ] }, { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:999", + "pc": [ + 67, + 68 + ] + }, + { + "teal": 45, + "source": "tests/contracts/abi.algo.ts:999", + "pc": [ + 69 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:1000", + "pc": [ + 70, + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:1000", + "pc": [ + 80, + 81, + 82, + 83, + 84, + 85, + 86, + 87, + 88, + 89, + 90, + 91, + 92, + 93, + 94, + 95, + 96, + 97, + 98, + 99, + 100, + 101, + 102, + 103, + 104, + 105, + 106, + 107 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:1000", + "pc": [ + 108 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:1002", + "pc": [ + 109, + 110 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:1002", + "pc": [ + 111, + 112 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:1004", + "pc": [ + 113, + 114 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:1004", + "pc": [ + 115 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:1004", + "pc": [ + 116, + 117 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:1006", + "pc": [ + 118, + 119 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:1006", + "pc": [ + 120, + 121 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:1004", + "pc": [ + 122, + 123 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:1004", + "pc": [ + 124 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:1004", + "pc": [ + 125, + 126, + 127 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:1008", + "pc": [ + 128, + 129 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:1008", + "pc": [ + 130, + 131 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:1008", + "pc": [ + 132, + 133, + 134, + 135, + 136, + 137, + 138, + 139, + 140, + 141 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:1008", + "pc": [ + 142, + 143 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:1004", + "pc": [ + 144, + 145 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:1004", + "pc": [ + 146 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:1004", + "pc": [ + 147 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:1004", + "pc": [ + 148 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:1004", + "pc": [ + 149, + 150 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:1004", + "pc": [ + 151 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:1004", + "pc": [ + 152 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:1004", + "pc": [ + 153, + 154, + 155 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:1004", + "pc": [ + 156 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:1004", + "pc": [ + 157 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:1004", + "pc": [ + 158 + ] + }, + { + "teal": 92, + "source": "tests/contracts/abi.algo.ts:1010", + "pc": [ + 159, + 160, + 161, + 162, + 163, + 164, + 165, + 166, + 167, + 168 + ] + }, + { + "teal": 93, + "source": "tests/contracts/abi.algo.ts:1010", + "pc": [ + 169 + ] + }, + { + "teal": 94, + "source": "tests/contracts/abi.algo.ts:1010", + "pc": [ + 170, + 171, + 172 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:1010", + "pc": [ + 173, + 174 + ] + }, + { + "teal": 96, + "source": "tests/contracts/abi.algo.ts:1010", + "pc": [ + 175, + 176 + ] + }, + { + "teal": 97, + "source": "tests/contracts/abi.algo.ts:1010", + "pc": [ + 177, + 178, + 179 + ] + }, + { + "teal": 98, + "source": "tests/contracts/abi.algo.ts:1010", + "pc": [ + 180 + ] + }, + { + "teal": 101, + "source": "tests/contracts/abi.algo.ts:999", + "pc": [ + 181, + 182 + ] + }, + { + "teal": 104, + "source": "tests/contracts/abi.algo.ts:999", + "pc": [ + 183, + 184 + ] + }, + { + "teal": 105, + "source": "tests/contracts/abi.algo.ts:999", + "pc": [ + 185 + ] + }, + { + "teal": 108, + "source": "tests/contracts/abi.algo.ts:996", + "pc": [ + 186, + 187 + ] + }, + { + "teal": 109, + "source": "tests/contracts/abi.algo.ts:996", + "pc": [ + 188 + ] + }, + { + "teal": 112, + "source": "tests/contracts/abi.algo.ts:996", + "pc": [ + 189, + 190, + 191, + 192, + 193, + 194 + ] + }, + { + "teal": 113, + "source": "tests/contracts/abi.algo.ts:996", + "pc": [ + 195, + 196, + 197 + ] + }, + { + "teal": 114, + "source": "tests/contracts/abi.algo.ts:996", + "pc": [ + 198, + 199, + 200, + 201 + ] + }, + { + "teal": 117, + "source": "tests/contracts/abi.algo.ts:996", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 202 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 120, + "source": "tests/contracts/abi.algo.ts:996", + "pc": [ + 203, + 204, + 205, + 206, + 207, + 208 + ] + }, + { + "teal": 121, + "source": "tests/contracts/abi.algo.ts:996", + "pc": [ + 209, + 210, + 211 + ] + }, + { + "teal": 122, + "source": "tests/contracts/abi.algo.ts:996", + "pc": [ + 212, + 213, + 214, + 215 + ] }, { + "teal": 125, + "source": "tests/contracts/abi.algo.ts:996", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 216 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestStorageTypeHint.arc56_draft.json b/tests/contracts/artifacts/ABITestStorageTypeHint.arc56_draft.json index 085f82c0b..e0642a796 100644 --- a/tests/contracts/artifacts/ABITestStorageTypeHint.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestStorageTypeHint.arc56_draft.json @@ -70,22 +70,320 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:856", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:856", + "pc": [ + 1, + 2, + 3, + 4, + 5, + 6, + 7 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:856", + "pc": [ + 8, + 9 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:856", + "pc": [ + 10 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:856", + "pc": [ + 11, + 12 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:856", + "pc": [ + 13 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:856", + "pc": [ + 14, + 15 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:856", + "pc": [ + 16 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:856", + "pc": [ + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:856", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 43 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:859", + "pc": [ + 44, + 45, + 46, + 47, + 48, + 49 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:859", + "pc": [ + 50, + 51, + 52 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:859", + "pc": [ + 53 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:859", + "pc": [ + 54 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:859", + "pc": [ + 55, + 56 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:859", + "pc": [ + 57 + ] }, { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:859", + "pc": [ + 58, + 59, + 60 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:860", + "pc": [ + 61, + 62, + 63, + 64, + 65, + 66 + ] + }, + { + "teal": 45, + "source": "tests/contracts/abi.algo.ts:860", + "pc": [ + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74 + ] + }, + { + "teal": 46, + "source": "tests/contracts/abi.algo.ts:860", + "pc": [ + 75 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:862", + "pc": [ + 76, + 77, + 78, + 79, + 80, + 81 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:862", + "pc": [ + 82 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:859", + "pc": [ + 83 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:856", + "pc": [ + 84, + 85 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:856", + "pc": [ + 86 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:856", + "pc": [ + 87, + 88, + 89, + 90, + 91, + 92 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:856", + "pc": [ + 93, + 94, + 95 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:856", + "pc": [ + 96, + 97, + 98, + 99 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:856", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 100 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:856", + "pc": [ + 101, + 102, + 103, + 104, + 105, + 106 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:856", + "pc": [ + 107, + 108, + 109 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:856", + "pc": [ + 110, + 111, + 112, + 113 + ] }, { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:856", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 114 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestStringAccessor.arc56_draft.json b/tests/contracts/artifacts/ABITestStringAccessor.arc56_draft.json index ce828c819..ea09b4942 100644 --- a/tests/contracts/artifacts/ABITestStringAccessor.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestStringAccessor.arc56_draft.json @@ -64,22 +64,359 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:832", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:832", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:832", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:832", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:832", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:832", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:832", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:832", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:832", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:833", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:833", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:833", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:833", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:833", + "pc": [ + 48 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:833", + "pc": [ + 49, + 50, + 51 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:833", + "pc": [ + 52 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:833", + "pc": [ + 53 + ] + }, + { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:833", + "pc": [ + 54 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:833", + "pc": [ + 55 + ] }, { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:833", + "pc": [ + 56, + 57 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:833", + "pc": [ + 58 + ] + }, + { + "teal": 45, + "source": "tests/contracts/abi.algo.ts:833", + "pc": [ + 59, + 60, + 61 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:833", + "pc": [ + 62, + 63 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:834", + "pc": [ + 64, + 65, + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75, + 76 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:834", + "pc": [ + 77, + 78 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:836", + "pc": [ + 79, + 80 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:836", + "pc": [ + 81, + 82, + 83 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:833", + "pc": [ + 84, + 85 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:833", + "pc": [ + 86 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:832", + "pc": [ + 87, + 88 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:832", + "pc": [ + 89 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:832", + "pc": [ + 90, + 91, + 92, + 93, + 94, + 95 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:832", + "pc": [ + 96, + 97, + 98 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:832", + "pc": [ + 99, + 100, + 101, + 102 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:832", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 103 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:832", + "pc": [ + 104, + 105, + 106, + 107, + 108, + 109 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:832", + "pc": [ + 110, + 111, + 112 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:832", + "pc": [ + 113, + 114, + 115, + 116 + ] }, { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:832", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 117 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestStringArg.arc56_draft.json b/tests/contracts/artifacts/ABITestStringArg.arc56_draft.json index 82f09e4d5..1867d10de 100644 --- a/tests/contracts/artifacts/ABITestStringArg.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestStringArg.arc56_draft.json @@ -69,22 +69,289 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:534", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:534", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:534", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:534", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:534", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:534", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:534", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:534", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:534", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:535", + "pc": [ + 37, + 38, + 39 + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:535", + "pc": [ + 40, + 41, + 42 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:535", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:535", + "pc": [ + 46, + 47 + ] }, { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:535", + "pc": [ + 48 + ] + }, + { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:535", + "pc": [ + 49, + 50, + 51 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:536", + "pc": [ + 52, + 53 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:536", + "pc": [ + 54, + 55, + 56, + 57, + 58, + 59, + 60, + 61, + 62, + 63, + 64, + 65, + 66, + 67 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:536", + "pc": [ + 68 + ] + }, + { + "teal": 45, + "source": "tests/contracts/abi.algo.ts:536", + "pc": [ + 69 + ] + }, + { + "teal": 46, + "source": "tests/contracts/abi.algo.ts:535", + "pc": [ + 70 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:534", + "pc": [ + 71, + 72 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:534", + "pc": [ + 73 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:534", + "pc": [ + 74, + 75, + 76, + 77, + 78, + 79 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:534", + "pc": [ + 80, + 81, + 82 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:534", + "pc": [ + 83, + 84, + 85, + 86 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:534", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 87 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:534", + "pc": [ + 88, + 89, + 90, + 91, + 92, + 93 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:534", + "pc": [ + 94, + 95, + 96 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:534", + "pc": [ + 97, + 98, + 99, + 100 + ] }, { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:534", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 101 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestStringArray.arc56_draft.json b/tests/contracts/artifacts/ABITestStringArray.arc56_draft.json index 546b0ce88..ca30bdde6 100644 --- a/tests/contracts/artifacts/ABITestStringArray.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestStringArray.arc56_draft.json @@ -75,22 +75,265 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1179", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:1179", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1179", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1179", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1179", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1179", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1179", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1179", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:1179", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] }, { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:1182", + "pc": [ + 37, + 38, + 39 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:1182", + "pc": [ + 40, + 41, + 42 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1182", + "pc": [ + 43, + 44 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1182", + "pc": [ + 45 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:1182", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:1183", + "pc": [ + 49, + 50, + 51, + 52, + 53, + 54 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:1183", + "pc": [ + 55, + 56 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:1183", + "pc": [ + 57 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:1182", + "pc": [ + 58 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:1179", + "pc": [ + 59, + 60 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:1179", + "pc": [ + 61 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:1179", + "pc": [ + 62, + 63, + 64, + 65, + 66, + 67 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:1179", + "pc": [ + 68, + 69, + 70 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:1179", + "pc": [ + 71, + 72, + 73, + 74 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:1179", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 75 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:1179", + "pc": [ + 76, + 77, + 78, + 79, + 80, + 81 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:1179", + "pc": [ + 82, + 83, + 84 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:1179", + "pc": [ + 85, + 86, + 87, + 88 + ] }, { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:1179", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 89 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestStringInTuple.arc56_draft.json b/tests/contracts/artifacts/ABITestStringInTuple.arc56_draft.json index 73a340a86..3aef4562e 100644 --- a/tests/contracts/artifacts/ABITestStringInTuple.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestStringInTuple.arc56_draft.json @@ -64,22 +64,650 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:540", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:540", + "pc": [ + 1, + 2, + 3 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:540", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:540", + "pc": [ + 6 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:540", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:540", + "pc": [ + 9 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:540", + "pc": [ + 10, + 11 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:540", + "pc": [ + 12 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:540", + "pc": [ + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:540", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 39 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:541", + "pc": [ + 40, + 41, + 42, + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:541", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:541", + "pc": [ + 49 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:541", + "pc": [ + 50 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:541", + "pc": [ + 51, + 52 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:541", + "pc": [ + 53 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:541", + "pc": [ + 54, + 55, + 56 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:541", + "pc": [ + 57, + 58 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:542", + "pc": [ + 59, + 60 + ] }, { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:542", + "pc": [ + 61, + 62 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:542", + "pc": [ + 63, + 64, + 65, + 66 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:542", + "pc": [ + 67, + 68, + 69, + 70 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:542", + "pc": [ + 71, + 72, + 73 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:542", + "pc": [ + 74, + 75, + 76, + 77, + 78 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:542", + "pc": [ + 79, + 80, + 81 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:542", + "pc": [ + 82, + 83, + 84, + 85, + 86, + 87, + 88, + 89, + 90, + 91, + 92, + 93, + 94, + 95, + 96, + 97 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:542", + "pc": [ + 98, + 99, + 100 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:542", + "pc": [ + 101, + 102, + 103, + 104, + 105 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:542", + "pc": [ + 106, + 107, + 108 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:542", + "pc": [ + 109 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:542", + "pc": [ + 110 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:542", + "pc": [ + 111, + 112 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:544", + "pc": [ + 113, + 114 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:541", + "pc": [ + 115, + 116 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:541", + "pc": [ + 117 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:540", + "pc": [ + 118, + 119 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:540", + "pc": [ + 120 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:540", + "pc": [ + 121, + 122, + 123, + 124, + 125, + 126 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:540", + "pc": [ + 127, + 128, + 129 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:540", + "pc": [ + 130, + 131, + 132, + 133 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:540", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 134 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] }, { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:540", + "pc": [ + 135, + 136, + 137, + 138, + 139, + 140 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:540", + "pc": [ + 141, + 142, + 143 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:540", + "pc": [ + 144, + 145, + 146, + 147 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:540", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 148 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:540", + "pc": [ + 149, + 150, + 151 + ] + }, + { + "teal": 92, + "source": "tests/contracts/abi.algo.ts:540", + "pc": [ + 152, + 153 + ] + }, + { + "teal": 93, + "source": "tests/contracts/abi.algo.ts:540", + "pc": [ + 154, + 155 + ] + }, + { + "teal": 94, + "source": "tests/contracts/abi.algo.ts:540", + "pc": [ + 156 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:540", + "pc": [ + 157, + 158 + ] + }, + { + "teal": 96, + "source": "tests/contracts/abi.algo.ts:540", + "pc": [ + 159, + 160 + ] + }, + { + "teal": 97, + "source": "tests/contracts/abi.algo.ts:540", + "pc": [ + 161 + ] + }, + { + "teal": 100, + "source": "tests/contracts/abi.algo.ts:540", + "pc": [ + 162, + 163, + 164 + ] + }, + { + "teal": 101, + "source": "tests/contracts/abi.algo.ts:540", + "pc": [ + 165, + 166 + ] + }, + { + "teal": 102, + "source": "tests/contracts/abi.algo.ts:540", + "pc": [ + 167, + 168 + ] + }, + { + "teal": 103, + "source": "tests/contracts/abi.algo.ts:540", + "pc": [ + 169 + ] + }, + { + "teal": 104, + "source": "tests/contracts/abi.algo.ts:540", + "pc": [ + 170, + 171 + ] + }, + { + "teal": 105, + "source": "tests/contracts/abi.algo.ts:540", + "pc": [ + 172, + 173 + ] + }, + { + "teal": 106, + "source": "tests/contracts/abi.algo.ts:540", + "pc": [ + 174 + ] + }, + { + "teal": 107, + "source": "tests/contracts/abi.algo.ts:540", + "pc": [ + 175 + ] + }, + { + "teal": 108, + "source": "tests/contracts/abi.algo.ts:540", + "pc": [ + 176, + 177 + ] + }, + { + "teal": 109, + "source": "tests/contracts/abi.algo.ts:540", + "pc": [ + 178 + ] + }, + { + "teal": 110, + "source": "tests/contracts/abi.algo.ts:540", + "pc": [ + 179 + ] + }, + { + "teal": 111, + "source": "tests/contracts/abi.algo.ts:540", + "pc": [ + 180 + ] + }, + { + "teal": 112, + "source": "tests/contracts/abi.algo.ts:540", + "pc": [ + 181, + 182, + 183 + ] + }, + { + "teal": 113, + "source": "tests/contracts/abi.algo.ts:540", + "pc": [ + 184, + 185 + ] + }, + { + "teal": 114, + "source": "tests/contracts/abi.algo.ts:540", + "pc": [ + 186, + 187 + ] + }, + { + "teal": 115, + "source": "tests/contracts/abi.algo.ts:540", + "pc": [ + 188 + ] + }, + { + "teal": 116, + "source": "tests/contracts/abi.algo.ts:540", + "pc": [ + 189 + ] + }, + { + "teal": 117, + "source": "tests/contracts/abi.algo.ts:540", + "pc": [ + 190, + 191 + ] + }, + { + "teal": 118, + "source": "tests/contracts/abi.algo.ts:540", + "pc": [ + 192, + 193 + ] + }, + { + "teal": 119, + "source": "tests/contracts/abi.algo.ts:540", + "pc": [ + 194, + 195 + ] + }, + { + "teal": 120, + "source": "tests/contracts/abi.algo.ts:540", + "pc": [ + 196, + 197 + ] + }, + { + "teal": 121, + "source": "tests/contracts/abi.algo.ts:540", + "pc": [ + 198 + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestStringLength.arc56_draft.json b/tests/contracts/artifacts/ABITestStringLength.arc56_draft.json index 7e5b8da46..bf418433f 100644 --- a/tests/contracts/artifacts/ABITestStringLength.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestStringLength.arc56_draft.json @@ -64,22 +64,316 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:741", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:741", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:741", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:741", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:741", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:741", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:741", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:741", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:741", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] }, { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:742", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:742", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:742", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:742", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:742", + "pc": [ + 48 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:742", + "pc": [ + 49, + 50 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:742", + "pc": [ + 51 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:742", + "pc": [ + 52, + 53, + 54 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:742", + "pc": [ + 55, + 56 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:743", + "pc": [ + 57, + 58, + 59, + 60, + 61, + 62, + 63, + 64, + 65 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:743", + "pc": [ + 66, + 67 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:745", + "pc": [ + 68, + 69 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:745", + "pc": [ + 70 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:742", + "pc": [ + 71, + 72 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:742", + "pc": [ + 73 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:741", + "pc": [ + 74, + 75 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:741", + "pc": [ + 76 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:741", + "pc": [ + 77, + 78, + 79, + 80, + 81, + 82 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:741", + "pc": [ + 83, + 84, + 85 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:741", + "pc": [ + 86, + 87, + 88, + 89 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:741", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 90 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:741", + "pc": [ + 91, + 92, + 93, + 94, + 95, + 96 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:741", + "pc": [ + 97, + 98, + 99 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:741", + "pc": [ + 100, + 101, + 102, + 103 + ] }, { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:741", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 104 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestStringReturn.arc56_draft.json b/tests/contracts/artifacts/ABITestStringReturn.arc56_draft.json index 895a4934c..3ceeeaee6 100644 --- a/tests/contracts/artifacts/ABITestStringReturn.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestStringReturn.arc56_draft.json @@ -64,22 +64,319 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:528", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:528", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:528", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:528", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:528", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:528", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:528", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:528", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:528", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] }, { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:529", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:529", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:529", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:529", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:529", + "pc": [ + 48 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:529", + "pc": [ + 49, + 50, + 51 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:529", + "pc": [ + 52 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:529", + "pc": [ + 53 + ] + }, + { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:529", + "pc": [ + 54 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:529", + "pc": [ + 55 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:529", + "pc": [ + 56, + 57 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:529", + "pc": [ + 58 + ] + }, + { + "teal": 45, + "source": "tests/contracts/abi.algo.ts:529", + "pc": [ + 59, + 60, + 61 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:530", + "pc": [ + 62, + 63, + 64, + 65, + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:529", + "pc": [ + 76 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:528", + "pc": [ + 77, + 78 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:528", + "pc": [ + 79 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:528", + "pc": [ + 80, + 81, + 82, + 83, + 84, + 85 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:528", + "pc": [ + 86, + 87, + 88 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:528", + "pc": [ + 89, + 90, + 91, + 92 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:528", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 93 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:528", + "pc": [ + 94, + 95, + 96, + 97, + 98, + 99 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:528", + "pc": [ + 100, + 101, + 102 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:528", + "pc": [ + 103, + 104, + 105, + 106 + ] }, { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:528", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 107 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestThreeDimensionalUint16Array.arc56_draft.json b/tests/contracts/artifacts/ABITestThreeDimensionalUint16Array.arc56_draft.json index 507431f57..73f0566f2 100644 --- a/tests/contracts/artifacts/ABITestThreeDimensionalUint16Array.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestThreeDimensionalUint16Array.arc56_draft.json @@ -64,28 +64,416 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:236", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:236", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:236", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:236", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:236", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:236", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:236", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:236", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:236", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:237", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:237", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:237", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:237", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:237", + "pc": [ + 48 + ] }, { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:237", + "pc": [ + 49, + 50 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:237", + "pc": [ + 51 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:237", + "errorMessage": "threeDimensionalUint16Array return value overflowed 16 bits", "pc": [ 52 - ], - "errorMessage": "threeDimensionalUint16Array return value overflowed 16 bits" + ] }, { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:237", + "pc": [ + 53, + 54, + 55 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:237", + "pc": [ + 56 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:237", + "pc": [ + 57 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:237", + "pc": [ + 58, + 59 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:237", + "pc": [ + 60 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:237", + "pc": [ + 61, + 62, + 63 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:237", + "pc": [ + 64, + 65 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:238", + "pc": [ + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82, + 83 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:238", + "pc": [ + 84, + 85 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:249", + "pc": [ + 86, + 87 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:249", + "pc": [ + 88, + 89, + 90, + 91, + 92, + 93 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:249", + "pc": [ + 94, + 95 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:249", + "pc": [ + 96, + 97 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:251", + "pc": [ + 98, + 99 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:251", + "pc": [ + 100, + 101, + 102 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:251", + "pc": [ + 103 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:237", + "pc": [ + 104, + 105 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:237", + "pc": [ + 106 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:236", + "pc": [ + 107, + 108 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:236", + "pc": [ + 109 + ] + }, + { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:236", + "pc": [ + 110, + 111, + 112, + 113, + 114, + 115 + ] + }, + { + "teal": 90, + "source": "tests/contracts/abi.algo.ts:236", + "pc": [ + 116, + 117, + 118 + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:236", + "pc": [ + 119, + 120, + 121, + 122 + ] + }, + { + "teal": 94, + "source": "tests/contracts/abi.algo.ts:236", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 123 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 97, + "source": "tests/contracts/abi.algo.ts:236", + "pc": [ + 124, + 125, + 126, + 127, + 128, + 129 + ] + }, + { + "teal": 98, + "source": "tests/contracts/abi.algo.ts:236", + "pc": [ + 130, + 131, + 132 + ] + }, + { + "teal": 99, + "source": "tests/contracts/abi.algo.ts:236", + "pc": [ + 133, + 134, + 135, + 136 + ] }, { + "teal": 102, + "source": "tests/contracts/abi.algo.ts:236", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 137 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestTupleArg.arc56_draft.json b/tests/contracts/artifacts/ABITestTupleArg.arc56_draft.json index 81bea1c2c..c770ccade 100644 --- a/tests/contracts/artifacts/ABITestTupleArg.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestTupleArg.arc56_draft.json @@ -69,34 +69,378 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:340", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:340", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:340", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:340", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:340", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:340", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:340", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:340", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:340", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] }, { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:341", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:341", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:341", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:341", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:341", + "pc": [ + 48, + 49 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:341", + "pc": [ + 50 + ] + }, + { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:341", + "errorMessage": "argument 0 (a) for tupleArg must be a (uint64,uint16,uint64)", "pc": [ 51 - ], - "errorMessage": "argument 0 (a) for tupleArg must be a (uint64,uint16,uint64)" + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:341", + "pc": [ + 52, + 53, + 54 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:341", + "pc": [ + 55 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:341", + "pc": [ + 56 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:341", + "pc": [ + 57 + ] + }, + { + "teal": 45, + "source": "tests/contracts/abi.algo.ts:341", + "pc": [ + 58, + 59 + ] }, { + "teal": 46, + "source": "tests/contracts/abi.algo.ts:341", + "pc": [ + 60 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:341", + "errorMessage": "tupleArg return value overflowed 16 bits", "pc": [ 61 - ], - "errorMessage": "tupleArg return value overflowed 16 bits" + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:341", + "pc": [ + 62, + 63, + 64 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:341", + "pc": [ + 65 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:341", + "pc": [ + 66 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:341", + "pc": [ + 67, + 68 + ] }, { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:341", + "pc": [ + 69 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:341", + "pc": [ + 70, + 71, + 72 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:342", + "pc": [ + 73, + 74 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:342", + "pc": [ + 75, + 76, + 77 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:342", + "pc": [ + 78 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:341", + "pc": [ + 79 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:340", + "pc": [ + 80, + 81 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:340", + "pc": [ + 82 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:340", + "pc": [ + 83, + 84, + 85, + 86, + 87, + 88 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:340", + "pc": [ + 89, + 90, + 91 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:340", + "pc": [ + 92, + 93, + 94, + 95 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:340", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 96 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:340", + "pc": [ + 97, + 98, + 99, + 100, + 101, + 102 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:340", + "pc": [ + 103, + 104, + 105 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:340", + "pc": [ + 106, + 107, + 108, + 109 + ] }, { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:340", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 110 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestTupleInArray.arc56_draft.json b/tests/contracts/artifacts/ABITestTupleInArray.arc56_draft.json index e23cb2619..96d93f466 100644 --- a/tests/contracts/artifacts/ABITestTupleInArray.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestTupleInArray.arc56_draft.json @@ -64,28 +64,384 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:271", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:271", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:271", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:271", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:271", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:271", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:271", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:271", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:271", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:272", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:272", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:272", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:272", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:272", + "pc": [ + 48 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:272", + "pc": [ + 49, + 50 + ] }, { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:272", + "pc": [ + 51 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:272", + "errorMessage": "tupleInArray return value overflowed 16 bits", "pc": [ 52 - ], - "errorMessage": "tupleInArray return value overflowed 16 bits" + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:272", + "pc": [ + 53, + 54, + 55 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:272", + "pc": [ + 56 + ] }, { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:272", + "pc": [ + 57 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:272", + "pc": [ + 58, + 59 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:272", + "pc": [ + 60 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:272", + "pc": [ + 61, + 62, + 63 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:272", + "pc": [ + 64, + 65 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:273", + "pc": [ + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82, + 83, + 84, + 85, + 86, + 87 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:273", + "pc": [ + 88, + 89 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:278", + "pc": [ + 90, + 91 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:278", + "pc": [ + 92, + 93, + 94 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:278", + "pc": [ + 95 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:272", + "pc": [ + 96, + 97 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:272", + "pc": [ + 98 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:271", + "pc": [ + 99, + 100 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:271", + "pc": [ + 101 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:271", + "pc": [ + 102, + 103, + 104, + 105, + 106, + 107 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:271", + "pc": [ + 108, + 109, + 110 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:271", + "pc": [ + 111, + 112, + 113, + 114 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:271", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 115 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:271", + "pc": [ + 116, + 117, + 118, + 119, + 120, + 121 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:271", + "pc": [ + 122, + 123, + 124 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:271", + "pc": [ + 125, + 126, + 127, + 128 + ] }, { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:271", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 129 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestTupleInTuple.arc56_draft.json b/tests/contracts/artifacts/ABITestTupleInTuple.arc56_draft.json index 5a16ad8e9..5d0d7ac75 100644 --- a/tests/contracts/artifacts/ABITestTupleInTuple.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestTupleInTuple.arc56_draft.json @@ -64,22 +64,342 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:282", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:282", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:282", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:282", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:282", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:282", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:282", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:282", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:282", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:283", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:283", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:283", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:283", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:283", + "pc": [ + 48 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:283", + "pc": [ + 49, + 50 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:283", + "pc": [ + 51 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:283", + "pc": [ + 52, + 53, + 54 + ] }, { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:283", + "pc": [ + 55, + 56 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:284", + "pc": [ + 57, + 58, + 59, + 60, + 61, + 62, + 63, + 64, + 65, + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:284", + "pc": [ + 83, + 84 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:286", + "pc": [ + 85, + 86 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:286", + "pc": [ + 87, + 88, + 89 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:286", + "pc": [ + 90 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:283", + "pc": [ + 91, + 92 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:283", + "pc": [ + 93 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:282", + "pc": [ + 94, + 95 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:282", + "pc": [ + 96 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:282", + "pc": [ + 97, + 98, + 99, + 100, + 101, + 102 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:282", + "pc": [ + 103, + 104, + 105 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:282", + "pc": [ + 106, + 107, + 108, + 109 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:282", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 110 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:282", + "pc": [ + 111, + 112, + 113, + 114, + 115, + 116 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:282", + "pc": [ + 117, + 118, + 119 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:282", + "pc": [ + 120, + 121, + 122, + 123 + ] }, { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:282", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 124 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestTxnTypes.arc56_draft.json b/tests/contracts/artifacts/ABITestTxnTypes.arc56_draft.json index 543094d75..0ab42602d 100644 --- a/tests/contracts/artifacts/ABITestTxnTypes.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestTxnTypes.arc56_draft.json @@ -93,58 +93,802 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:716", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:716", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:716", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:716", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:716", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:716", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:716", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:716", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:716", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:724", + "pc": [ + 37, + 38 + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:724", + "pc": [ + 39, + 40 + ] + }, + { + "teal": 30, + "source": "tests/contracts/abi.algo.ts:724", + "pc": [ + 41 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:724", + "pc": [ + 42 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:724", + "pc": [ + 43, + 44 + ] }, { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:724", + "pc": [ + 45, + 46 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:724", + "pc": [ + 47 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:724", + "errorMessage": "argument 0 (p) for txnTypes must be a pay transaction", "pc": [ 48 - ], - "errorMessage": "argument 0 (p) for txnTypes must be a pay transaction" + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:723", + "pc": [ + 49, + 50 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:723", + "pc": [ + 51, + 52 + ] }, { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:723", + "pc": [ + 53 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:723", + "pc": [ + 54 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:723", + "pc": [ + 55, + 56 + ] + }, + { + "teal": 45, + "source": "tests/contracts/abi.algo.ts:723", + "pc": [ + 57, + 58 + ] + }, + { + "teal": 46, + "source": "tests/contracts/abi.algo.ts:723", + "pc": [ + 59 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:723", + "errorMessage": "argument 1 (kr) for txnTypes must be a keyreg transaction", "pc": [ 60 - ], - "errorMessage": "argument 1 (kr) for txnTypes must be a keyreg transaction" + ] }, { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:722", + "pc": [ + 61, + 62 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:722", + "pc": [ + 63, + 64 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:722", + "pc": [ + 65 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:722", + "pc": [ + 66 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:722", + "pc": [ + 67, + 68 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:722", + "pc": [ + 69, + 70 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:722", + "pc": [ + 71 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:722", + "errorMessage": "argument 2 (at) for txnTypes must be a axfer transaction", "pc": [ 72 - ], - "errorMessage": "argument 2 (at) for txnTypes must be a axfer transaction" + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:721", + "pc": [ + 73, + 74 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:721", + "pc": [ + 75, + 76 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:721", + "pc": [ + 77 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:721", + "pc": [ + 78 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:721", + "pc": [ + 79, + 80 + ] }, { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:721", + "pc": [ + 81, + 82 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:721", + "pc": [ + 83 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:721", + "errorMessage": "argument 3 (af) for txnTypes must be a afrz transaction", "pc": [ 84 - ], - "errorMessage": "argument 3 (af) for txnTypes must be a afrz transaction" + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:720", + "pc": [ + 85, + 86 + ] }, { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:720", + "pc": [ + 87, + 88 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:720", + "pc": [ + 89 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:720", + "pc": [ + 90 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:720", + "pc": [ + 91, + 92 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:720", + "pc": [ + 93, + 94 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:720", + "pc": [ + 95 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:720", + "errorMessage": "argument 4 (ac) for txnTypes must be a acfg transaction", "pc": [ 96 - ], - "errorMessage": "argument 4 (ac) for txnTypes must be a acfg transaction" + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:719", + "pc": [ + 97, + 98 + ] + }, + { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:719", + "pc": [ + 99, + 100 + ] }, { + "teal": 90, + "source": "tests/contracts/abi.algo.ts:719", + "pc": [ + 101 + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:719", + "pc": [ + 102 + ] + }, + { + "teal": 92, + "source": "tests/contracts/abi.algo.ts:719", + "pc": [ + 103, + 104 + ] + }, + { + "teal": 93, + "source": "tests/contracts/abi.algo.ts:719", + "pc": [ + 105, + 106 + ] + }, + { + "teal": 94, + "source": "tests/contracts/abi.algo.ts:719", + "pc": [ + 107 + ] + }, + { + "teal": 97, + "source": "tests/contracts/abi.algo.ts:719", + "errorMessage": "argument 5 (a) for txnTypes must be a appl transaction", "pc": [ 108 - ], - "errorMessage": "argument 5 (a) for txnTypes must be a appl transaction" + ] + }, + { + "teal": 100, + "source": "tests/contracts/abi.algo.ts:718", + "pc": [ + 109, + 110 + ] + }, + { + "teal": 101, + "source": "tests/contracts/abi.algo.ts:718", + "pc": [ + 111, + 112 + ] + }, + { + "teal": 102, + "source": "tests/contracts/abi.algo.ts:718", + "pc": [ + 113 + ] + }, + { + "teal": 105, + "source": "tests/contracts/abi.algo.ts:717", + "pc": [ + 114, + 115, + 116 + ] + }, + { + "teal": 106, + "source": "tests/contracts/abi.algo.ts:717", + "pc": [ + 117, + 118 + ] + }, + { + "teal": 107, + "source": "tests/contracts/abi.algo.ts:717", + "pc": [ + 119 + ] + }, + { + "teal": 111, + "source": "tests/contracts/abi.algo.ts:717", + "pc": [ + 120, + 121, + 122 + ] + }, + { + "teal": 115, + "source": "tests/contracts/abi.algo.ts:726", + "pc": [ + 123, + 124 + ] + }, + { + "teal": 116, + "source": "tests/contracts/abi.algo.ts:726", + "pc": [ + 125, + 126 + ] + }, + { + "teal": 117, + "source": "tests/contracts/abi.algo.ts:726", + "pc": [ + 127, + 128 + ] + }, + { + "teal": 118, + "source": "tests/contracts/abi.algo.ts:726", + "pc": [ + 129, + 130 + ] + }, + { + "teal": 119, + "source": "tests/contracts/abi.algo.ts:726", + "pc": [ + 131 + ] }, { + "teal": 120, + "source": "tests/contracts/abi.algo.ts:726", + "pc": [ + 132 + ] + }, + { + "teal": 124, + "source": "tests/contracts/abi.algo.ts:727", + "pc": [ + 133, + 134 + ] + }, + { + "teal": 125, + "source": "tests/contracts/abi.algo.ts:727", + "pc": [ + 135, + 136 + ] + }, + { + "teal": 126, + "source": "tests/contracts/abi.algo.ts:727", + "pc": [ + 137, + 138 + ] + }, + { + "teal": 127, + "source": "tests/contracts/abi.algo.ts:727", + "pc": [ + 139, + 140 + ] + }, + { + "teal": 128, + "source": "tests/contracts/abi.algo.ts:727", + "pc": [ + 141 + ] + }, + { + "teal": 129, + "source": "tests/contracts/abi.algo.ts:727", + "pc": [ + 142 + ] + }, + { + "teal": 133, + "source": "tests/contracts/abi.algo.ts:728", + "pc": [ + 143, + 144 + ] + }, + { + "teal": 134, + "source": "tests/contracts/abi.algo.ts:728", + "pc": [ + 145, + 146 + ] + }, + { + "teal": 135, + "source": "tests/contracts/abi.algo.ts:728", + "pc": [ + 147, + 148 + ] + }, + { + "teal": 136, + "source": "tests/contracts/abi.algo.ts:728", + "pc": [ + 149, + 150 + ] + }, + { + "teal": 137, + "source": "tests/contracts/abi.algo.ts:728", + "pc": [ + 151 + ] + }, + { + "teal": 138, + "source": "tests/contracts/abi.algo.ts:728", + "pc": [ + 152 + ] + }, + { + "teal": 142, + "source": "tests/contracts/abi.algo.ts:729", + "pc": [ + 153, + 154 + ] + }, + { + "teal": 143, + "source": "tests/contracts/abi.algo.ts:729", + "pc": [ + 155, + 156 + ] + }, + { + "teal": 144, + "source": "tests/contracts/abi.algo.ts:729", + "pc": [ + 157, + 158 + ] + }, + { + "teal": 145, + "source": "tests/contracts/abi.algo.ts:729", + "pc": [ + 159, + 160 + ] + }, + { + "teal": 146, + "source": "tests/contracts/abi.algo.ts:729", + "pc": [ + 161 + ] + }, + { + "teal": 147, + "source": "tests/contracts/abi.algo.ts:729", + "pc": [ + 162 + ] + }, + { + "teal": 148, + "source": "tests/contracts/abi.algo.ts:717", + "pc": [ + 163 + ] + }, + { + "teal": 151, + "source": "tests/contracts/abi.algo.ts:716", + "pc": [ + 164, + 165 + ] + }, + { + "teal": 152, + "source": "tests/contracts/abi.algo.ts:716", + "pc": [ + 166 + ] + }, + { + "teal": 155, + "source": "tests/contracts/abi.algo.ts:716", + "pc": [ + 167, + 168, + 169, + 170, + 171, + 172 + ] + }, + { + "teal": 156, + "source": "tests/contracts/abi.algo.ts:716", + "pc": [ + 173, + 174, + 175 + ] + }, + { + "teal": 157, + "source": "tests/contracts/abi.algo.ts:716", + "pc": [ + 176, + 177, + 178, + 179 + ] + }, + { + "teal": 160, + "source": "tests/contracts/abi.algo.ts:716", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 180 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 163, + "source": "tests/contracts/abi.algo.ts:716", + "pc": [ + 181, + 182, + 183, + 184, + 185, + 186 + ] + }, + { + "teal": 164, + "source": "tests/contracts/abi.algo.ts:716", + "pc": [ + 187, + 188, + 189 + ] + }, + { + "teal": 165, + "source": "tests/contracts/abi.algo.ts:716", + "pc": [ + 190, + 191, + 192, + 193 + ] }, { + "teal": 168, + "source": "tests/contracts/abi.algo.ts:716", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 194 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestTypedConst.arc56_draft.json b/tests/contracts/artifacts/ABITestTypedConst.arc56_draft.json index 97f3f4492..a31d68b1d 100644 --- a/tests/contracts/artifacts/ABITestTypedConst.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestTypedConst.arc56_draft.json @@ -64,22 +64,286 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1289", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:1289", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1289", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1289", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1289", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1289", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1289", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1289", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:1289", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:1290", + "pc": [ + 37, + 38, + 39 + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:1290", + "pc": [ + 40, + 41 + ] + }, + { + "teal": 30, + "source": "tests/contracts/abi.algo.ts:1290", + "pc": [ + 42 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1290", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:1290", + "pc": [ + 46, + 47 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:1291", + "pc": [ + 48, + 49, + 50 + ] }, { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:1291", + "pc": [ + 51, + 52 + ] + }, + { + "teal": 46, + "source": "tests/contracts/abi.algo.ts:1292", + "pc": [ + 53, + 54, + 55 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:1292", + "pc": [ + 56, + 57, + 58 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:1292", + "pc": [ + 59 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:1292", + "pc": [ + 60 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:1290", + "pc": [ + 61 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:1289", + "pc": [ + 62, + 63 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:1289", + "pc": [ + 64 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:1289", + "pc": [ + 65, + 66, + 67, + 68, + 69, + 70 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:1289", + "pc": [ + 71, + 72, + 73 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:1289", + "pc": [ + 74, + 75, + 76, + 77 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:1289", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 78 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:1289", + "pc": [ + 79, + 80, + 81, + 82, + 83, + 84 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:1289", + "pc": [ + 85, + 86, + 87 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:1289", + "pc": [ + 88, + 89, + 90, + 91 + ] }, { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:1289", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 92 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestTypedVarFromStorage.arc56_draft.json b/tests/contracts/artifacts/ABITestTypedVarFromStorage.arc56_draft.json index 7ebc6234b..52e1a958c 100644 --- a/tests/contracts/artifacts/ABITestTypedVarFromStorage.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestTypedVarFromStorage.arc56_draft.json @@ -74,34 +74,379 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1296", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:1296", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1296", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1296", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1296", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1296", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1296", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1296", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:1296", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] }, { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:1299", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:1299", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1299", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1299", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1299", + "pc": [ + 48, + 49 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1299", + "pc": [ + 50 + ] + }, + { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:1299", + "errorMessage": "argument 0 (key) for typedVarFromStorage must be a uint32", "pc": [ 51 - ], - "errorMessage": "argument 0 (key) for typedVarFromStorage must be a uint32" + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:1299", + "pc": [ + 52 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:1299", + "pc": [ + 53, + 54, + 55 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:1299", + "pc": [ + 56 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:1299", + "pc": [ + 57 + ] + }, + { + "teal": 45, + "source": "tests/contracts/abi.algo.ts:1299", + "pc": [ + 58, + 59 + ] }, { + "teal": 46, + "source": "tests/contracts/abi.algo.ts:1299", + "pc": [ + 60 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:1299", + "pc": [ + 61, + 62, + 63 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:1299", + "pc": [ + 64, + 65 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:1300", + "pc": [ + 66, + 67 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:1300", + "pc": [ + 68 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:1300", + "pc": [ + 69, + 70, + 71 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:1300", + "pc": [ + 72, + 73 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:1300", + "pc": [ + 74, + 75 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:1300", + "pc": [ + 76 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:1300", + "errorMessage": "box value does not exist: this.boxMapTest(key).value", "pc": [ 77 - ], - "errorMessage": "box value does not exist: this.boxMapTest(key).value" + ] }, { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:1299", + "pc": [ + 78, + 79 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:1299", + "pc": [ + 80 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:1296", + "pc": [ + 81, + 82 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:1296", + "pc": [ + 83 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:1296", + "pc": [ + 84, + 85, + 86, + 87, + 88, + 89 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:1296", + "pc": [ + 90, + 91, + 92 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:1296", + "pc": [ + 93, + 94, + 95, + 96 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:1296", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 97 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:1296", + "pc": [ + 98, + 99, + 100, + 101, + 102, + 103 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:1296", + "pc": [ + 104, + 105, + 106 + ] + }, + { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:1296", + "pc": [ + 107, + 108, + 109, + 110 + ] }, { + "teal": 92, + "source": "tests/contracts/abi.algo.ts:1296", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 111 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestUint64Casting.arc56_draft.json b/tests/contracts/artifacts/ABITestUint64Casting.arc56_draft.json index 409d76d30..363526d91 100644 --- a/tests/contracts/artifacts/ABITestUint64Casting.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestUint64Casting.arc56_draft.json @@ -69,34 +69,369 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1193", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:1193", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1193", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1193", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1193", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1193", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1193", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1193", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:1193", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:1194", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:1194", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1194", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1194", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1194", + "pc": [ + 48, + 49 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1194", + "pc": [ + 50 + ] }, { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:1194", + "errorMessage": "argument 0 (a) for uint64Casting must be a uint256", "pc": [ 51 - ], - "errorMessage": "argument 0 (a) for uint64Casting must be a uint256" + ] }, { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:1194", + "pc": [ + 52, + 53, + 54 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:1194", + "pc": [ + 55 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:1194", + "pc": [ + 56 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:1194", + "pc": [ + 57 + ] + }, + { + "teal": 45, + "source": "tests/contracts/abi.algo.ts:1194", + "pc": [ + 58, + 59 + ] + }, + { + "teal": 46, + "source": "tests/contracts/abi.algo.ts:1194", + "pc": [ + 60 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:1194", + "pc": [ + 61, + 62, + 63 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:1195", + "pc": [ + 64, + 65 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:1195", + "pc": [ + 66 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:1195", + "pc": [ + 67 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:1195", + "pc": [ + 68, + 69 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:1195", + "pc": [ + 70 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:1195", + "errorMessage": "a as uint64 overflowed 64 bits", "pc": [ 71 - ], - "errorMessage": "a as uint64 overflowed 64 bits" + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:1195", + "pc": [ + 72, + 73, + 74 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:1195", + "pc": [ + 75 + ] }, { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:1194", + "pc": [ + 76 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:1193", + "pc": [ + 77, + 78 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:1193", + "pc": [ + 79 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:1193", + "pc": [ + 80, + 81, + 82, + 83, + 84, + 85 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:1193", + "pc": [ + 86, + 87, + 88 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:1193", + "pc": [ + 89, + 90, + 91, + 92 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:1193", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 93 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:1193", + "pc": [ + 94, + 95, + 96, + 97, + 98, + 99 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:1193", + "pc": [ + 100, + 101, + 102 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:1193", + "pc": [ + 103, + 104, + 105, + 106 + ] }, { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:1193", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 107 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestUintCasting.arc56_draft.json b/tests/contracts/artifacts/ABITestUintCasting.arc56_draft.json index e7d628f3b..fb1e51f4f 100644 --- a/tests/contracts/artifacts/ABITestUintCasting.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestUintCasting.arc56_draft.json @@ -69,34 +69,458 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1187", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:1187", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1187", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1187", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1187", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1187", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1187", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1187", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:1187", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:1188", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:1188", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1188", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1188", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1188", + "pc": [ + 48, + 49 + ] }, { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1188", + "pc": [ + 50 + ] + }, + { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:1188", + "errorMessage": "argument 0 (a) for uintCasting must be a uint8", "pc": [ 51 - ], - "errorMessage": "argument 0 (a) for uintCasting must be a uint8" + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:1188", + "pc": [ + 52 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:1188", + "pc": [ + 53, + 54, + 55 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:1188", + "pc": [ + 56 + ] }, { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:1188", + "pc": [ + 57 + ] + }, + { + "teal": 45, + "source": "tests/contracts/abi.algo.ts:1188", + "pc": [ + 58, + 59, + 60 + ] + }, + { + "teal": 46, + "source": "tests/contracts/abi.algo.ts:1188", + "pc": [ + 61 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:1188", + "errorMessage": "uintCasting return value overflowed 256 bits", "pc": [ 62 - ], - "errorMessage": "uintCasting return value overflowed 256 bits" + ] }, { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:1188", + "pc": [ + 63, + 64, + 65, + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82, + 83, + 84, + 85, + 86, + 87, + 88, + 89, + 90, + 91, + 92, + 93, + 94, + 95, + 96 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:1188", + "pc": [ + 97 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:1188", + "pc": [ + 98 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:1188", + "pc": [ + 99 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:1188", + "pc": [ + 100 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:1188", + "pc": [ + 101, + 102 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:1188", + "pc": [ + 103 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:1188", + "pc": [ + 104 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:1188", + "pc": [ + 105 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:1188", + "pc": [ + 106 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:1188", + "pc": [ + 107 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:1188", + "pc": [ + 108, + 109 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:1188", + "pc": [ + 110 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:1188", + "pc": [ + 111, + 112, + 113 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:1189", + "pc": [ + 114, + 115 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:1189", + "pc": [ + 116 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:1188", + "pc": [ + 117 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:1187", + "pc": [ + 118, + 119 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:1187", + "pc": [ + 120 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:1187", + "pc": [ + 121, + 122, + 123, + 124, + 125, + 126 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:1187", + "pc": [ + 127, + 128, + 129 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:1187", + "pc": [ + 130, + 131, + 132, + 133 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:1187", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 134 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:1187", + "pc": [ + 135, + 136, + 137, + 138, + 139, + 140 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:1187", + "pc": [ + 141, + 142, + 143 + ] + }, + { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:1187", + "pc": [ + 144, + 145, + 146, + 147 + ] }, { + "teal": 92, + "source": "tests/contracts/abi.algo.ts:1187", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 148 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestUintNComparison.arc56_draft.json b/tests/contracts/artifacts/ABITestUintNComparison.arc56_draft.json index 6eae7f950..00a73efe1 100644 --- a/tests/contracts/artifacts/ABITestUintNComparison.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestUintNComparison.arc56_draft.json @@ -73,34 +73,402 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1257", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:1257", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1257", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1257", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1257", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1257", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1257", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1257", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:1257", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:1258", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:1258", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1258", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1258", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1258", + "pc": [ + 48, + 49 + ] }, { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1258", + "pc": [ + 50 + ] + }, + { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:1258", + "errorMessage": "argument 0 (y) for uintNComparison must be a uint256", "pc": [ 51 - ], - "errorMessage": "argument 0 (y) for uintNComparison must be a uint256" + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:1258", + "pc": [ + 52, + 53, + 54 + ] }, { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:1258", + "pc": [ + 55 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:1258", + "pc": [ + 56 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:1258", + "pc": [ + 57, + 58 + ] + }, + { + "teal": 45, + "source": "tests/contracts/abi.algo.ts:1258", + "pc": [ + 59 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:1258", + "errorMessage": "argument 1 (x) for uintNComparison must be a uint256", "pc": [ 60 - ], - "errorMessage": "argument 1 (x) for uintNComparison must be a uint256" + ] }, { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:1258", + "pc": [ + 61, + 62, + 63 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:1258", + "pc": [ + 64, + 65, + 66 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:1258", + "pc": [ + 67, + 68 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:1258", + "pc": [ + 69, + 70 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:1258", + "pc": [ + 71 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:1258", + "pc": [ + 72 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:1258", + "pc": [ + 73 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:1258", + "pc": [ + 74, + 75 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:1258", + "pc": [ + 76 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:1258", + "pc": [ + 77, + 78, + 79 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:1259", + "pc": [ + 80, + 81 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:1259", + "pc": [ + 82, + 83 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:1259", + "pc": [ + 84 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:1258", + "pc": [ + 85 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:1257", + "pc": [ + 86, + 87 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:1257", + "pc": [ + 88 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:1257", + "pc": [ + 89, + 90, + 91, + 92, + 93, + 94 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:1257", + "pc": [ + 95, + 96, + 97 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:1257", + "pc": [ + 98, + 99, + 100, + 101 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:1257", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 102 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:1257", + "pc": [ + 103, + 104, + 105, + 106, + 107, + 108 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:1257", + "pc": [ + 109, + 110, + 111 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:1257", + "pc": [ + 112, + 113, + 114, + 115 + ] }, { + "teal": 90, + "source": "tests/contracts/abi.algo.ts:1257", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 116 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestUpdateArrayRefInBoxStorage.arc56_draft.json b/tests/contracts/artifacts/ABITestUpdateArrayRefInBoxStorage.arc56_draft.json index 90aad3a8f..3b3bd0890 100644 --- a/tests/contracts/artifacts/ABITestUpdateArrayRefInBoxStorage.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestUpdateArrayRefInBoxStorage.arc56_draft.json @@ -69,28 +69,374 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1102", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:1102", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1102", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1102", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1102", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1102", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1102", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1102", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:1102", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:1105", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:1105", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1105", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1105", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1105", + "pc": [ + 48, + 49 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1105", + "pc": [ + 50 + ] }, { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:1105", + "pc": [ + 51, + 52, + 53 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:1105", + "pc": [ + 54, + 55 + ] + }, + { + "teal": 46, + "source": "tests/contracts/abi.algo.ts:1107", + "pc": [ + 56, + 57 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:1107", + "pc": [ + 58, + 59, + 60, + 61, + 62, + 63, + 64, + 65, + 66, + 67, + 68 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:1107", + "pc": [ + 69 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:1109", + "pc": [ + 70, + 71 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:1109", + "pc": [ + 72, + 73 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:1109", + "pc": [ + 74, + 75 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:1109", + "pc": [ + 76, + 77 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:1109", + "pc": [ + 78, + 79, + 80 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:1109", + "pc": [ + 81 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:1109", + "pc": [ + 82, + 83 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:1109", + "pc": [ + 84 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:1109", + "errorMessage": "box value does not exist: this.bMap(this.txn.sender).value", "pc": [ 85 - ], - "errorMessage": "box value does not exist: this.bMap(this.txn.sender).value" + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:1105", + "pc": [ + 86, + 87 + ] }, { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:1105", + "pc": [ + 88 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:1102", + "pc": [ + 89, + 90 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:1102", + "pc": [ + 91 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:1102", + "pc": [ + 92, + 93, + 94, + 95, + 96, + 97 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:1102", + "pc": [ + 98, + 99, + 100 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:1102", + "pc": [ + 101, + 102, + 103, + 104 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:1102", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 105 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:1102", + "pc": [ + 106, + 107, + 108, + 109, + 110, + 111 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:1102", + "pc": [ + 112, + 113, + 114 + ] + }, + { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:1102", + "pc": [ + 115, + 116, + 117, + 118 + ] }, { + "teal": 92, + "source": "tests/contracts/abi.algo.ts:1102", + "errorMessage": "this contract does not implement the given ABI method for call OptIn", "pc": [ 119 - ], - "errorMessage": "this contract does not implement the given ABI method for call OptIn" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestUpdateDynamicArrayElement.arc56_draft.json b/tests/contracts/artifacts/ABITestUpdateDynamicArrayElement.arc56_draft.json index ffa18fec6..5379ae178 100644 --- a/tests/contracts/artifacts/ABITestUpdateDynamicArrayElement.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestUpdateDynamicArrayElement.arc56_draft.json @@ -64,22 +64,414 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:367", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:367", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:367", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:367", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:367", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:367", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:367", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:367", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:367", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:368", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:368", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:368", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:368", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:368", + "pc": [ + 48 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:368", + "pc": [ + 49, + 50 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:368", + "pc": [ + 51 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:368", + "pc": [ + 52, + 53, + 54 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:368", + "pc": [ + 55, + 56 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:369", + "pc": [ + 57, + 58, + 59, + 60, + 61, + 62, + 63, + 64, + 65, + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:369", + "pc": [ + 83, + 84 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:371", + "pc": [ + 85, + 86 + ] }, { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:371", + "pc": [ + 87, + 88 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:371", + "pc": [ + 89, + 90 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:371", + "pc": [ + 91, + 92, + 93, + 94, + 95, + 96, + 97, + 98, + 99, + 100 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:371", + "pc": [ + 101, + 102 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:371", + "pc": [ + 103, + 104 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:373", + "pc": [ + 105, + 106 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:373", + "pc": [ + 107, + 108 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:373", + "pc": [ + 109, + 110 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:373", + "pc": [ + 111, + 112, + 113 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:373", + "pc": [ + 114 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:368", + "pc": [ + 115, + 116 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:368", + "pc": [ + 117 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:367", + "pc": [ + 118, + 119 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:367", + "pc": [ + 120 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:367", + "pc": [ + 121, + 122, + 123, + 124, + 125, + 126 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:367", + "pc": [ + 127, + 128, + 129 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:367", + "pc": [ + 130, + 131, + 132, + 133 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:367", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 134 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:367", + "pc": [ + 135, + 136, + 137, + 138, + 139, + 140 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:367", + "pc": [ + 141, + 142, + 143 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:367", + "pc": [ + 144, + 145, + 146, + 147 + ] }, { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:367", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 148 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestUpdateDynamicArrayInMiddleOfTuple.arc56_draft.json b/tests/contracts/artifacts/ABITestUpdateDynamicArrayInMiddleOfTuple.arc56_draft.json index 670ac8a74..14319b000 100644 --- a/tests/contracts/artifacts/ABITestUpdateDynamicArrayInMiddleOfTuple.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestUpdateDynamicArrayInMiddleOfTuple.arc56_draft.json @@ -64,22 +64,1081 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 1, + 2, + 3, + 4, + 5, + 6, + 7, + 8 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 9, + 10 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 11 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 12, + 13 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 14 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 15, + 16 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 17 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38, + 39, + 40, + 41, + 42, + 43 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:680", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 44 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:681", + "pc": [ + 45, + 46, + 47, + 48, + 49, + 50 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:681", + "pc": [ + 51, + 52, + 53 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:681", + "pc": [ + 54 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:681", + "pc": [ + 55 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:681", + "pc": [ + 56, + 57 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:681", + "pc": [ + 58 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:681", + "pc": [ + 59, + 60, + 61 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:681", + "pc": [ + 62, + 63 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:682", + "pc": [ + 64, + 65 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:682", + "pc": [ + 66, + 67 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:682", + "pc": [ + 68, + 69, + 70, + 71 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:682", + "pc": [ + 72, + 73, + 74, + 75 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:682", + "pc": [ + 76, + 77, + 78 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:682", + "pc": [ + 79, + 80, + 81, + 82, + 83 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:682", + "pc": [ + 84, + 85, + 86 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:682", + "pc": [ + 87, + 88, + 89, + 90 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:682", + "pc": [ + 91, + 92, + 93 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:682", + "pc": [ + 94 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:682", + "pc": [ + 95 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:682", + "pc": [ + 96, + 97 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:684", + "pc": [ + 98, + 99 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:684", + "pc": [ + 100, + 101 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:684", + "pc": [ + 102, + 103 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:684", + "pc": [ + 104 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:684", + "pc": [ + 105, + 106 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:684", + "pc": [ + 107, + 108 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:684", + "pc": [ + 109, + 110 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:684", + "pc": [ + 111, + 112 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:684", + "pc": [ + 113 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:684", + "pc": [ + 114 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:684", + "pc": [ + 115, + 116 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:684", + "pc": [ + 117 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:684", + "pc": [ + 118, + 119 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:684", + "pc": [ + 120 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:684", + "pc": [ + 121 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:684", + "pc": [ + 122, + 123 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:684", + "pc": [ + 124 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:684", + "pc": [ + 125, + 126 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:684", + "pc": [ + 127 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:684", + "pc": [ + 128, + 129 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:684", + "pc": [ + 130, + 131 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:684", + "pc": [ + 132, + 133 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:684", + "pc": [ + 134, + 135 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:684", + "pc": [ + 136 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:684", + "pc": [ + 137, + 138, + 139, + 140, + 141, + 142 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:684", + "pc": [ + 143 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:684", + "pc": [ + 144, + 145 + ] + }, + { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:684", + "pc": [ + 146, + 147 + ] + }, + { + "teal": 90, + "source": "tests/contracts/abi.algo.ts:684", + "pc": [ + 148, + 149 + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:684", + "pc": [ + 150, + 151 + ] + }, + { + "teal": 92, + "source": "tests/contracts/abi.algo.ts:684", + "pc": [ + 152 + ] + }, + { + "teal": 93, + "source": "tests/contracts/abi.algo.ts:684", + "pc": [ + 153, + 154 + ] + }, + { + "teal": 94, + "source": "tests/contracts/abi.algo.ts:684", + "pc": [ + 155 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:684", + "pc": [ + 156 + ] + }, + { + "teal": 96, + "source": "tests/contracts/abi.algo.ts:684", + "pc": [ + 157 + ] }, { + "teal": 97, + "source": "tests/contracts/abi.algo.ts:684", + "pc": [ + 158 + ] + }, + { + "teal": 98, + "source": "tests/contracts/abi.algo.ts:684", + "pc": [ + 159, + 160 + ] + }, + { + "teal": 99, + "source": "tests/contracts/abi.algo.ts:684", + "pc": [ + 161, + 162, + 163 + ] + }, + { + "teal": 100, + "source": "tests/contracts/abi.algo.ts:684", + "pc": [ + 164, + 165 + ] + }, + { + "teal": 101, + "source": "tests/contracts/abi.algo.ts:684", + "pc": [ + 166, + 167 + ] + }, + { + "teal": 105, + "source": "tests/contracts/abi.algo.ts:686", + "pc": [ + 168, + 169 + ] + }, + { + "teal": 108, + "source": "tests/contracts/abi.algo.ts:681", + "pc": [ + 170, + 171 + ] + }, + { + "teal": 109, + "source": "tests/contracts/abi.algo.ts:681", + "pc": [ + 172 + ] + }, + { + "teal": 112, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 173, + 174 + ] + }, + { + "teal": 113, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 175 + ] + }, + { + "teal": 116, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 176, + 177, + 178, + 179, + 180, + 181 + ] + }, + { + "teal": 117, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 182, + 183, + 184 + ] + }, + { + "teal": 118, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 185, + 186, + 187, + 188 + ] + }, + { + "teal": 121, + "source": "tests/contracts/abi.algo.ts:680", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 189 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 124, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 190, + 191, + 192, + 193, + 194, + 195 + ] + }, + { + "teal": 125, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 196, + 197, + 198 + ] + }, + { + "teal": 126, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 199, + 200, + 201, + 202 + ] }, { + "teal": 129, + "source": "tests/contracts/abi.algo.ts:680", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 203 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] + }, + { + "teal": 132, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 204, + 205, + 206 + ] + }, + { + "teal": 133, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 207, + 208 + ] + }, + { + "teal": 134, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 209, + 210 + ] + }, + { + "teal": 135, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 211 + ] + }, + { + "teal": 136, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 212, + 213 + ] + }, + { + "teal": 137, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 214, + 215 + ] + }, + { + "teal": 138, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 216 + ] + }, + { + "teal": 141, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 217, + 218, + 219 + ] + }, + { + "teal": 142, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 220, + 221 + ] + }, + { + "teal": 143, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 222, + 223 + ] + }, + { + "teal": 144, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 224 + ] + }, + { + "teal": 145, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 225, + 226 + ] + }, + { + "teal": 146, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 227, + 228 + ] + }, + { + "teal": 147, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 229 + ] + }, + { + "teal": 148, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 230 + ] + }, + { + "teal": 149, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 231, + 232 + ] + }, + { + "teal": 150, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 233 + ] + }, + { + "teal": 151, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 234 + ] + }, + { + "teal": 152, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 235 + ] + }, + { + "teal": 153, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 236, + 237, + 238 + ] + }, + { + "teal": 154, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 239, + 240 + ] + }, + { + "teal": 155, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 241, + 242 + ] + }, + { + "teal": 156, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 243 + ] + }, + { + "teal": 157, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 244 + ] + }, + { + "teal": 158, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 245, + 246 + ] + }, + { + "teal": 159, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 247, + 248 + ] + }, + { + "teal": 160, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 249, + 250 + ] + }, + { + "teal": 161, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 251, + 252 + ] + }, + { + "teal": 162, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 253 + ] + }, + { + "teal": 165, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 254, + 255 + ] + }, + { + "teal": 166, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 256 + ] + }, + { + "teal": 167, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 257, + 258 + ] + }, + { + "teal": 168, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 259 + ] + }, + { + "teal": 169, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 260, + 261, + 262 + ] + }, + { + "teal": 170, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 263, + 264 + ] + }, + { + "teal": 171, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 265 + ] + }, + { + "teal": 172, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 266, + 267 + ] + }, + { + "teal": 173, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 268, + 269 + ] + }, + { + "teal": 174, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 270, + 271 + ] + }, + { + "teal": 175, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 272, + 273, + 274 + ] + }, + { + "teal": 178, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 275, + 276 + ] + }, + { + "teal": 179, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 277, + 278 + ] + }, + { + "teal": 180, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 279 + ] + }, + { + "teal": 181, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 280, + 281 + ] + }, + { + "teal": 182, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 282, + 283 + ] + }, + { + "teal": 185, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 284 + ] + }, + { + "teal": 186, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 285, + 286 + ] + }, + { + "teal": 187, + "source": "tests/contracts/abi.algo.ts:680", + "pc": [ + 287 + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestUpdateDynamicArrayInTuple.arc56_draft.json b/tests/contracts/artifacts/ABITestUpdateDynamicArrayInTuple.arc56_draft.json index 50c06e202..1cf924e1e 100644 --- a/tests/contracts/artifacts/ABITestUpdateDynamicArrayInTuple.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestUpdateDynamicArrayInTuple.arc56_draft.json @@ -64,22 +64,2529 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 1, + 2, + 3 + ] + }, + { + "teal": 3, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 4, + 5, + 6, + 7, + 8, + 9, + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 31, + 32 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 33 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 34, + 35 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 36 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 37, + 38 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 39 + ] + }, + { + "teal": 21, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 40, + 41, + 42, + 43, + 44, + 45, + 46, + 47, + 48, + 49, + 50, + 51, + 52, + 53, + 54, + 55, + 56, + 57, + 58, + 59, + 60, + 61, + 62, + 63, + 64, + 65 + ] + }, + { + "teal": 25, + "source": "tests/contracts/abi.algo.ts:404", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 66 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 30, + "source": "tests/contracts/abi.algo.ts:405", + "pc": [ + 67, + 68, + 69, + 70, + 71, + 72 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:405", + "pc": [ + 73, + 74, + 75 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:405", + "pc": [ + 76 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:405", + "pc": [ + 77 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:405", + "pc": [ + 78, + 79 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:405", + "pc": [ + 80 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:405", + "pc": [ + 81, + 82, + 83 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:405", + "pc": [ + 84, + 85 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:406", + "pc": [ + 86, + 87 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:406", + "pc": [ + 88, + 89 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:406", + "pc": [ + 90, + 91, + 92, + 93 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:406", + "pc": [ + 94, + 95, + 96 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:406", + "pc": [ + 97, + 98, + 99 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:406", + "pc": [ + 100, + 101, + 102, + 103, + 104, + 105 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:406", + "pc": [ + 106, + 107, + 108 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:406", + "pc": [ + 109, + 110, + 111, + 112, + 113 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:406", + "pc": [ + 114, + 115, + 116 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:406", + "pc": [ + 117, + 118, + 119, + 120, + 121, + 122 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:406", + "pc": [ + 123, + 124, + 125 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:406", + "pc": [ + 126, + 127, + 128, + 129, + 130 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:406", + "pc": [ + 131, + 132, + 133 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:406", + "pc": [ + 134 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:406", + "pc": [ + 135 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:406", + "pc": [ + 136, + 137 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:408", + "pc": [ + 138, + 139 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:408", + "pc": [ + 140, + 141 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:408", + "pc": [ + 142, + 143 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:408", + "pc": [ + 144, + 145, + 146 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:408", + "pc": [ + 147, + 148 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:408", + "pc": [ + 149, + 150 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 151, + 152 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 153, + 154 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 155, + 156 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 157 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 158, + 159 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 160, + 161 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 162, + 163 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 164, + 165 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 166 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 167 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 168, + 169 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 170 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 171, + 172 + ] + }, + { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 173 + ] + }, + { + "teal": 90, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 174 + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 175, + 176 + ] + }, + { + "teal": 92, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 177 + ] + }, + { + "teal": 93, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 178, + 179 + ] + }, + { + "teal": 94, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 180 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 181, + 182 + ] + }, + { + "teal": 96, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 183, + 184 + ] + }, + { + "teal": 97, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 185, + 186 + ] + }, + { + "teal": 98, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 187, + 188 + ] + }, + { + "teal": 99, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 189 + ] + }, + { + "teal": 100, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 190, + 191, + 192, + 193, + 194, + 195, + 196, + 197 + ] + }, + { + "teal": 101, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 198 + ] + }, + { + "teal": 102, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 199, + 200 + ] + }, + { + "teal": 103, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 201, + 202 + ] + }, + { + "teal": 104, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 203, + 204 + ] + }, + { + "teal": 105, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 205, + 206 + ] + }, + { + "teal": 106, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 207 + ] + }, + { + "teal": 107, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 208, + 209 + ] + }, + { + "teal": 108, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 210 + ] + }, + { + "teal": 109, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 211 + ] + }, + { + "teal": 110, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 212 + ] + }, + { + "teal": 111, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 213 + ] + }, + { + "teal": 112, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 214, + 215 + ] + }, + { + "teal": 113, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 216, + 217, + 218 + ] + }, + { + "teal": 114, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 219, + 220 + ] + }, + { + "teal": 115, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 221, + 222 + ] + }, + { + "teal": 116, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 223, + 224 + ] + }, + { + "teal": 117, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 225 + ] + }, + { + "teal": 118, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 226, + 227, + 228 + ] + }, + { + "teal": 119, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 229, + 230 + ] + }, + { + "teal": 120, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 231, + 232 + ] + }, + { + "teal": 121, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 233, + 234 + ] + }, + { + "teal": 122, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 235 + ] + }, + { + "teal": 123, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 236, + 237, + 238 + ] + }, + { + "teal": 124, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 239, + 240 + ] + }, + { + "teal": 125, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 241, + 242 + ] + }, + { + "teal": 126, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 243, + 244 + ] + }, + { + "teal": 127, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 245 + ] + }, + { + "teal": 128, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 246, + 247, + 248 + ] + }, + { + "teal": 129, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 249, + 250 + ] + }, + { + "teal": 130, + "source": "tests/contracts/abi.algo.ts:409", + "pc": [ + 251, + 252 + ] + }, + { + "teal": 134, + "source": "tests/contracts/abi.algo.ts:410", + "pc": [ + 253, + 254 + ] + }, + { + "teal": 135, + "source": "tests/contracts/abi.algo.ts:410", + "pc": [ + 255, + 256 + ] + }, + { + "teal": 136, + "source": "tests/contracts/abi.algo.ts:410", + "pc": [ + 257, + 258 + ] + }, + { + "teal": 137, + "source": "tests/contracts/abi.algo.ts:410", + "pc": [ + 259 + ] + }, + { + "teal": 138, + "source": "tests/contracts/abi.algo.ts:410", + "pc": [ + 260, + 261 + ] + }, + { + "teal": 139, + "source": "tests/contracts/abi.algo.ts:410", + "pc": [ + 262, + 263 + ] + }, + { + "teal": 140, + "source": "tests/contracts/abi.algo.ts:410", + "pc": [ + 264, + 265 + ] + }, + { + "teal": 141, + "source": "tests/contracts/abi.algo.ts:410", + "pc": [ + 266, + 267 + ] + }, + { + "teal": 142, + "source": "tests/contracts/abi.algo.ts:410", + "pc": [ + 268 + ] + }, + { + "teal": 143, + "source": "tests/contracts/abi.algo.ts:410", + "pc": [ + 269 + ] + }, + { + "teal": 144, + "source": "tests/contracts/abi.algo.ts:410", + "pc": [ + 270, + 271 + ] + }, + { + "teal": 145, + "source": "tests/contracts/abi.algo.ts:410", + "pc": [ + 272 + ] + }, + { + "teal": 146, + "source": "tests/contracts/abi.algo.ts:410", + "pc": [ + 273, + 274 + ] + }, + { + "teal": 147, + "source": "tests/contracts/abi.algo.ts:410", + "pc": [ + 275 + ] + }, + { + "teal": 148, + "source": "tests/contracts/abi.algo.ts:410", + "pc": [ + 276 + ] + }, + { + "teal": 149, + "source": "tests/contracts/abi.algo.ts:410", + "pc": [ + 277, + 278 + ] + }, + { + "teal": 150, + "source": "tests/contracts/abi.algo.ts:410", + "pc": [ + 279 + ] + }, + { + "teal": 151, + "source": "tests/contracts/abi.algo.ts:410", + "pc": [ + 280, + 281 + ] + }, + { + "teal": 152, + "source": "tests/contracts/abi.algo.ts:410", + "pc": [ + 282 + ] + }, + { + "teal": 153, + "source": "tests/contracts/abi.algo.ts:410", + "pc": [ + 283, + 284 + ] + }, + { + "teal": 154, + "source": "tests/contracts/abi.algo.ts:410", + "pc": [ + 285, + 286 + ] + }, + { + "teal": 155, + "source": "tests/contracts/abi.algo.ts:410", + "pc": [ + 287, + 288 + ] + }, + { + "teal": 156, + "source": "tests/contracts/abi.algo.ts:410", + "pc": [ + 289, + 290 + ] + }, + { + "teal": 157, + "source": "tests/contracts/abi.algo.ts:410", + "pc": [ + 291 + ] + }, + { + "teal": 158, + "source": "tests/contracts/abi.algo.ts:410", + "pc": [ + 292, + 293, + 294, + 295, + 296, + 297 + ] + }, + { + "teal": 159, + "source": "tests/contracts/abi.algo.ts:410", + "pc": [ + 298 + ] + }, + { + "teal": 160, + "source": "tests/contracts/abi.algo.ts:410", + "pc": [ + 299, + 300 + ] + }, + { + "teal": 161, + "source": "tests/contracts/abi.algo.ts:410", + "pc": [ + 301, + 302 + ] + }, + { + "teal": 162, + "source": "tests/contracts/abi.algo.ts:410", + "pc": [ + 303, + 304 + ] + }, + { + "teal": 163, + "source": "tests/contracts/abi.algo.ts:410", + "pc": [ + 305, + 306 + ] + }, + { + "teal": 164, + "source": "tests/contracts/abi.algo.ts:410", + "pc": [ + 307 + ] + }, + { + "teal": 165, + "source": "tests/contracts/abi.algo.ts:410", + "pc": [ + 308, + 309 + ] + }, + { + "teal": 166, + "source": "tests/contracts/abi.algo.ts:410", + "pc": [ + 310 + ] + }, + { + "teal": 167, + "source": "tests/contracts/abi.algo.ts:410", + "pc": [ + 311 + ] + }, + { + "teal": 168, + "source": "tests/contracts/abi.algo.ts:410", + "pc": [ + 312 + ] + }, + { + "teal": 169, + "source": "tests/contracts/abi.algo.ts:410", + "pc": [ + 313 + ] + }, + { + "teal": 170, + "source": "tests/contracts/abi.algo.ts:410", + "pc": [ + 314, + 315 + ] + }, + { + "teal": 171, + "source": "tests/contracts/abi.algo.ts:410", + "pc": [ + 316, + 317, + 318 + ] + }, + { + "teal": 172, + "source": "tests/contracts/abi.algo.ts:410", + "pc": [ + 319, + 320 + ] + }, + { + "teal": 173, + "source": "tests/contracts/abi.algo.ts:410", + "pc": [ + 321, + 322 + ] + }, + { + "teal": 174, + "source": "tests/contracts/abi.algo.ts:410", + "pc": [ + 323, + 324 + ] + }, + { + "teal": 175, + "source": "tests/contracts/abi.algo.ts:410", + "pc": [ + 325 + ] + }, + { + "teal": 176, + "source": "tests/contracts/abi.algo.ts:410", + "pc": [ + 326, + 327, + 328 + ] + }, + { + "teal": 177, + "source": "tests/contracts/abi.algo.ts:410", + "pc": [ + 329, + 330 + ] + }, + { + "teal": 178, + "source": "tests/contracts/abi.algo.ts:410", + "pc": [ + 331, + 332 + ] + }, + { + "teal": 179, + "source": "tests/contracts/abi.algo.ts:410", + "pc": [ + 333, + 334 + ] + }, + { + "teal": 180, + "source": "tests/contracts/abi.algo.ts:410", + "pc": [ + 335 + ] + }, + { + "teal": 181, + "source": "tests/contracts/abi.algo.ts:410", + "pc": [ + 336, + 337, + 338 + ] + }, + { + "teal": 182, + "source": "tests/contracts/abi.algo.ts:410", + "pc": [ + 339, + 340 + ] + }, + { + "teal": 183, + "source": "tests/contracts/abi.algo.ts:410", + "pc": [ + 341, + 342 + ] + }, + { + "teal": 187, + "source": "tests/contracts/abi.algo.ts:411", + "pc": [ + 343, + 344 + ] + }, + { + "teal": 188, + "source": "tests/contracts/abi.algo.ts:411", + "pc": [ + 345, + 346 + ] + }, + { + "teal": 189, + "source": "tests/contracts/abi.algo.ts:411", + "pc": [ + 347, + 348 + ] + }, + { + "teal": 190, + "source": "tests/contracts/abi.algo.ts:411", + "pc": [ + 349 + ] + }, + { + "teal": 191, + "source": "tests/contracts/abi.algo.ts:411", + "pc": [ + 350, + 351 + ] + }, + { + "teal": 192, + "source": "tests/contracts/abi.algo.ts:411", + "pc": [ + 352, + 353 + ] + }, + { + "teal": 193, + "source": "tests/contracts/abi.algo.ts:411", + "pc": [ + 354, + 355 + ] + }, + { + "teal": 194, + "source": "tests/contracts/abi.algo.ts:411", + "pc": [ + 356, + 357 + ] + }, + { + "teal": 195, + "source": "tests/contracts/abi.algo.ts:411", + "pc": [ + 358 + ] + }, + { + "teal": 196, + "source": "tests/contracts/abi.algo.ts:411", + "pc": [ + 359 + ] + }, + { + "teal": 197, + "source": "tests/contracts/abi.algo.ts:411", + "pc": [ + 360, + 361 + ] + }, + { + "teal": 198, + "source": "tests/contracts/abi.algo.ts:411", + "pc": [ + 362 + ] + }, + { + "teal": 199, + "source": "tests/contracts/abi.algo.ts:411", + "pc": [ + 363, + 364 + ] + }, + { + "teal": 200, + "source": "tests/contracts/abi.algo.ts:411", + "pc": [ + 365 + ] + }, + { + "teal": 201, + "source": "tests/contracts/abi.algo.ts:411", + "pc": [ + 366 + ] + }, + { + "teal": 202, + "source": "tests/contracts/abi.algo.ts:411", + "pc": [ + 367, + 368 + ] + }, + { + "teal": 203, + "source": "tests/contracts/abi.algo.ts:411", + "pc": [ + 369 + ] + }, + { + "teal": 204, + "source": "tests/contracts/abi.algo.ts:411", + "pc": [ + 370, + 371 + ] + }, + { + "teal": 205, + "source": "tests/contracts/abi.algo.ts:411", + "pc": [ + 372 + ] + }, + { + "teal": 206, + "source": "tests/contracts/abi.algo.ts:411", + "pc": [ + 373, + 374 + ] + }, + { + "teal": 207, + "source": "tests/contracts/abi.algo.ts:411", + "pc": [ + 375, + 376 + ] + }, + { + "teal": 208, + "source": "tests/contracts/abi.algo.ts:411", + "pc": [ + 377, + 378 + ] + }, + { + "teal": 209, + "source": "tests/contracts/abi.algo.ts:411", + "pc": [ + 379, + 380 + ] + }, + { + "teal": 210, + "source": "tests/contracts/abi.algo.ts:411", + "pc": [ + 381 + ] + }, + { + "teal": 211, + "source": "tests/contracts/abi.algo.ts:411", + "pc": [ + 382, + 383, + 384, + 385, + 386, + 387, + 388, + 389 + ] + }, + { + "teal": 212, + "source": "tests/contracts/abi.algo.ts:411", + "pc": [ + 390 + ] + }, + { + "teal": 213, + "source": "tests/contracts/abi.algo.ts:411", + "pc": [ + 391, + 392 + ] + }, + { + "teal": 214, + "source": "tests/contracts/abi.algo.ts:411", + "pc": [ + 393, + 394 + ] + }, + { + "teal": 215, + "source": "tests/contracts/abi.algo.ts:411", + "pc": [ + 395, + 396 + ] + }, + { + "teal": 216, + "source": "tests/contracts/abi.algo.ts:411", + "pc": [ + 397, + 398 + ] + }, + { + "teal": 217, + "source": "tests/contracts/abi.algo.ts:411", + "pc": [ + 399 + ] + }, + { + "teal": 218, + "source": "tests/contracts/abi.algo.ts:411", + "pc": [ + 400, + 401 + ] + }, + { + "teal": 219, + "source": "tests/contracts/abi.algo.ts:411", + "pc": [ + 402 + ] + }, + { + "teal": 220, + "source": "tests/contracts/abi.algo.ts:411", + "pc": [ + 403 + ] + }, + { + "teal": 221, + "source": "tests/contracts/abi.algo.ts:411", + "pc": [ + 404 + ] + }, + { + "teal": 222, + "source": "tests/contracts/abi.algo.ts:411", + "pc": [ + 405 + ] + }, + { + "teal": 223, + "source": "tests/contracts/abi.algo.ts:411", + "pc": [ + 406, + 407 + ] + }, + { + "teal": 224, + "source": "tests/contracts/abi.algo.ts:411", + "pc": [ + 408, + 409, + 410 + ] + }, + { + "teal": 225, + "source": "tests/contracts/abi.algo.ts:411", + "pc": [ + 411, + 412 + ] + }, + { + "teal": 226, + "source": "tests/contracts/abi.algo.ts:411", + "pc": [ + 413, + 414 + ] + }, + { + "teal": 227, + "source": "tests/contracts/abi.algo.ts:411", + "pc": [ + 415, + 416 + ] + }, + { + "teal": 228, + "source": "tests/contracts/abi.algo.ts:411", + "pc": [ + 417 + ] + }, + { + "teal": 229, + "source": "tests/contracts/abi.algo.ts:411", + "pc": [ + 418, + 419, + 420 + ] + }, + { + "teal": 230, + "source": "tests/contracts/abi.algo.ts:411", + "pc": [ + 421, + 422 + ] + }, + { + "teal": 231, + "source": "tests/contracts/abi.algo.ts:411", + "pc": [ + 423, + 424 + ] + }, + { + "teal": 235, + "source": "tests/contracts/abi.algo.ts:412", + "pc": [ + 425, + 426 + ] + }, + { + "teal": 236, + "source": "tests/contracts/abi.algo.ts:412", + "pc": [ + 427, + 428 + ] + }, + { + "teal": 237, + "source": "tests/contracts/abi.algo.ts:412", + "pc": [ + 429, + 430 + ] + }, + { + "teal": 238, + "source": "tests/contracts/abi.algo.ts:412", + "pc": [ + 431 + ] + }, + { + "teal": 239, + "source": "tests/contracts/abi.algo.ts:412", + "pc": [ + 432, + 433 + ] + }, + { + "teal": 240, + "source": "tests/contracts/abi.algo.ts:412", + "pc": [ + 434, + 435 + ] + }, + { + "teal": 241, + "source": "tests/contracts/abi.algo.ts:412", + "pc": [ + 436, + 437 + ] + }, + { + "teal": 242, + "source": "tests/contracts/abi.algo.ts:412", + "pc": [ + 438, + 439 + ] + }, + { + "teal": 243, + "source": "tests/contracts/abi.algo.ts:412", + "pc": [ + 440 + ] + }, + { + "teal": 244, + "source": "tests/contracts/abi.algo.ts:412", + "pc": [ + 441 + ] + }, + { + "teal": 245, + "source": "tests/contracts/abi.algo.ts:412", + "pc": [ + 442, + 443 + ] + }, + { + "teal": 246, + "source": "tests/contracts/abi.algo.ts:412", + "pc": [ + 444 + ] + }, + { + "teal": 247, + "source": "tests/contracts/abi.algo.ts:412", + "pc": [ + 445, + 446 + ] + }, + { + "teal": 248, + "source": "tests/contracts/abi.algo.ts:412", + "pc": [ + 447 + ] + }, + { + "teal": 249, + "source": "tests/contracts/abi.algo.ts:412", + "pc": [ + 448 + ] + }, + { + "teal": 250, + "source": "tests/contracts/abi.algo.ts:412", + "pc": [ + 449, + 450 + ] + }, + { + "teal": 251, + "source": "tests/contracts/abi.algo.ts:412", + "pc": [ + 451 + ] + }, + { + "teal": 252, + "source": "tests/contracts/abi.algo.ts:412", + "pc": [ + 452, + 453 + ] + }, + { + "teal": 253, + "source": "tests/contracts/abi.algo.ts:412", + "pc": [ + 454 + ] + }, + { + "teal": 254, + "source": "tests/contracts/abi.algo.ts:412", + "pc": [ + 455, + 456 + ] + }, + { + "teal": 255, + "source": "tests/contracts/abi.algo.ts:412", + "pc": [ + 457, + 458 + ] + }, + { + "teal": 256, + "source": "tests/contracts/abi.algo.ts:412", + "pc": [ + 459, + 460 + ] + }, + { + "teal": 257, + "source": "tests/contracts/abi.algo.ts:412", + "pc": [ + 461, + 462 + ] + }, + { + "teal": 258, + "source": "tests/contracts/abi.algo.ts:412", + "pc": [ + 463 + ] + }, + { + "teal": 259, + "source": "tests/contracts/abi.algo.ts:412", + "pc": [ + 464, + 465, + 466, + 467, + 468, + 469 + ] + }, + { + "teal": 260, + "source": "tests/contracts/abi.algo.ts:412", + "pc": [ + 470 + ] + }, + { + "teal": 261, + "source": "tests/contracts/abi.algo.ts:412", + "pc": [ + 471, + 472 + ] + }, + { + "teal": 262, + "source": "tests/contracts/abi.algo.ts:412", + "pc": [ + 473, + 474 + ] + }, + { + "teal": 263, + "source": "tests/contracts/abi.algo.ts:412", + "pc": [ + 475, + 476 + ] + }, + { + "teal": 264, + "source": "tests/contracts/abi.algo.ts:412", + "pc": [ + 477, + 478 + ] + }, + { + "teal": 265, + "source": "tests/contracts/abi.algo.ts:412", + "pc": [ + 479 + ] + }, + { + "teal": 266, + "source": "tests/contracts/abi.algo.ts:412", + "pc": [ + 480, + 481 + ] + }, + { + "teal": 267, + "source": "tests/contracts/abi.algo.ts:412", + "pc": [ + 482 + ] + }, + { + "teal": 268, + "source": "tests/contracts/abi.algo.ts:412", + "pc": [ + 483 + ] + }, + { + "teal": 269, + "source": "tests/contracts/abi.algo.ts:412", + "pc": [ + 484 + ] + }, + { + "teal": 270, + "source": "tests/contracts/abi.algo.ts:412", + "pc": [ + 485 + ] + }, + { + "teal": 271, + "source": "tests/contracts/abi.algo.ts:412", + "pc": [ + 486, + 487 + ] + }, + { + "teal": 272, + "source": "tests/contracts/abi.algo.ts:412", + "pc": [ + 488, + 489, + 490 + ] + }, + { + "teal": 273, + "source": "tests/contracts/abi.algo.ts:412", + "pc": [ + 491, + 492 + ] + }, + { + "teal": 274, + "source": "tests/contracts/abi.algo.ts:412", + "pc": [ + 493, + 494 + ] + }, + { + "teal": 278, + "source": "tests/contracts/abi.algo.ts:414", + "pc": [ + 495, + 496 + ] + }, + { + "teal": 281, + "source": "tests/contracts/abi.algo.ts:405", + "pc": [ + 497, + 498 + ] + }, + { + "teal": 282, + "source": "tests/contracts/abi.algo.ts:405", + "pc": [ + 499 + ] + }, + { + "teal": 285, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 500, + 501 + ] + }, + { + "teal": 286, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 502 + ] + }, + { + "teal": 289, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 503, + 504, + 505, + 506, + 507, + 508 + ] + }, + { + "teal": 290, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 509, + 510, + 511 + ] }, { + "teal": 291, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 512, + 513, + 514, + 515 + ] + }, + { + "teal": 294, + "source": "tests/contracts/abi.algo.ts:404", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 516 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 297, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 517, + 518, + 519, + 520, + 521, + 522 + ] + }, + { + "teal": 298, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 523, + 524, + 525 + ] + }, + { + "teal": 299, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 526, + 527, + 528, + 529 + ] }, { + "teal": 302, + "source": "tests/contracts/abi.algo.ts:404", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 530 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] + }, + { + "teal": 305, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 531, + 532, + 533 + ] + }, + { + "teal": 306, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 534, + 535 + ] + }, + { + "teal": 307, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 536, + 537 + ] + }, + { + "teal": 308, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 538 + ] + }, + { + "teal": 309, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 539, + 540 + ] + }, + { + "teal": 310, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 541, + 542 + ] + }, + { + "teal": 311, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 543 + ] + }, + { + "teal": 314, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 544, + 545, + 546 + ] + }, + { + "teal": 315, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 547, + 548 + ] + }, + { + "teal": 316, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 549, + 550 + ] + }, + { + "teal": 317, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 551 + ] + }, + { + "teal": 318, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 552, + 553 + ] + }, + { + "teal": 319, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 554, + 555 + ] + }, + { + "teal": 320, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 556 + ] + }, + { + "teal": 321, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 557 + ] + }, + { + "teal": 322, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 558, + 559 + ] + }, + { + "teal": 323, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 560 + ] + }, + { + "teal": 324, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 561 + ] + }, + { + "teal": 325, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 562 + ] + }, + { + "teal": 326, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 563, + 564, + 565 + ] + }, + { + "teal": 327, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 566, + 567 + ] + }, + { + "teal": 328, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 568, + 569 + ] + }, + { + "teal": 329, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 570 + ] + }, + { + "teal": 330, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 571 + ] + }, + { + "teal": 331, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 572, + 573 + ] + }, + { + "teal": 332, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 574, + 575 + ] + }, + { + "teal": 333, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 576, + 577 + ] + }, + { + "teal": 334, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 578, + 579 + ] + }, + { + "teal": 335, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 580 + ] + }, + { + "teal": 338, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 581, + 582, + 583 + ] + }, + { + "teal": 339, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 584, + 585 + ] + }, + { + "teal": 340, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 586, + 587 + ] + }, + { + "teal": 341, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 588, + 589 + ] + }, + { + "teal": 342, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 590 + ] + }, + { + "teal": 343, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 591, + 592 + ] + }, + { + "teal": 344, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 593, + 594, + 595 + ] + }, + { + "teal": 345, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 596 + ] + }, + { + "teal": 346, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 597, + 598, + 599 + ] + }, + { + "teal": 349, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 600 + ] + }, + { + "teal": 350, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 601 + ] + }, + { + "teal": 353, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 602 + ] + }, + { + "teal": 354, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 603, + 604, + 605 + ] + }, + { + "teal": 355, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 606, + 607 + ] + }, + { + "teal": 356, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 608 + ] + }, + { + "teal": 357, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 609, + 610 + ] + }, + { + "teal": 358, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 611 + ] + }, + { + "teal": 359, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 612 + ] + }, + { + "teal": 360, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 613, + 614 + ] + }, + { + "teal": 361, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 615 + ] + }, + { + "teal": 364, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 616, + 617 + ] + }, + { + "teal": 365, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 618 + ] + }, + { + "teal": 366, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 619, + 620 + ] + }, + { + "teal": 367, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 621 + ] + }, + { + "teal": 368, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 622, + 623, + 624 + ] + }, + { + "teal": 369, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 625, + 626 + ] + }, + { + "teal": 370, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 627 + ] + }, + { + "teal": 371, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 628, + 629 + ] + }, + { + "teal": 372, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 630, + 631 + ] + }, + { + "teal": 373, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 632, + 633 + ] + }, + { + "teal": 374, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 634, + 635, + 636 + ] + }, + { + "teal": 377, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 637, + 638 + ] + }, + { + "teal": 378, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 639, + 640 + ] + }, + { + "teal": 379, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 641 + ] + }, + { + "teal": 380, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 642, + 643 + ] + }, + { + "teal": 381, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 644, + 645 + ] + }, + { + "teal": 384, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 646 + ] + }, + { + "teal": 385, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 647, + 648 + ] + }, + { + "teal": 386, + "source": "tests/contracts/abi.algo.ts:404", + "pc": [ + 649 + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestUpdateDynamicElementInTupleWithSameLength.arc56_draft.json b/tests/contracts/artifacts/ABITestUpdateDynamicElementInTupleWithSameLength.arc56_draft.json index 06464ff7d..1f139f65e 100644 --- a/tests/contracts/artifacts/ABITestUpdateDynamicElementInTupleWithSameLength.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestUpdateDynamicElementInTupleWithSameLength.arc56_draft.json @@ -64,22 +64,1321 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 1, + 2, + 3, + 4, + 5, + 6, + 7, + 8, + 9 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 10, + 11 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 12 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 13, + 14 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 15 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 16, + 17 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 18 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38, + 39, + 40, + 41, + 42, + 43, + 44 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:698", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 45 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:699", + "pc": [ + 46, + 47, + 48, + 49, + 50, + 51 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:699", + "pc": [ + 52, + 53, + 54 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:699", + "pc": [ + 55 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:699", + "pc": [ + 56 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:699", + "pc": [ + 57, + 58 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:699", + "pc": [ + 59 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:699", + "pc": [ + 60, + 61, + 62 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:699", + "pc": [ + 63, + 64 + ] + }, + { + "teal": 47, + "source": "tests/contracts/abi.algo.ts:700", + "pc": [ + 65, + 66 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:700", + "pc": [ + 67, + 68 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:700", + "pc": [ + 69, + 70, + 71, + 72 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:700", + "pc": [ + 73, + 74, + 75, + 76 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:700", + "pc": [ + 77, + 78, + 79 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:700", + "pc": [ + 80, + 81, + 82, + 83, + 84, + 85, + 86 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:700", + "pc": [ + 87, + 88, + 89 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:700", + "pc": [ + 90, + 91, + 92, + 93 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:700", + "pc": [ + 94, + 95, + 96 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:700", + "pc": [ + 97, + 98, + 99, + 100, + 101, + 102, + 103 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:700", + "pc": [ + 104, + 105, + 106 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:700", + "pc": [ + 107, + 108, + 109, + 110 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:700", + "pc": [ + 111, + 112, + 113 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:700", + "pc": [ + 114 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:700", + "pc": [ + 115 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:700", + "pc": [ + 116, + 117 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:702", + "pc": [ + 118, + 119 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:702", + "pc": [ + 120, + 121 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:702", + "pc": [ + 122, + 123 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:702", + "pc": [ + 124 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:702", + "pc": [ + 125, + 126 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:702", + "pc": [ + 127, + 128 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:702", + "pc": [ + 129, + 130 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:702", + "pc": [ + 131, + 132 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:702", + "pc": [ + 133 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:702", + "pc": [ + 134 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:702", + "pc": [ + 135, + 136 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:702", + "pc": [ + 137 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:702", + "pc": [ + 138, + 139 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:702", + "pc": [ + 140 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:702", + "pc": [ + 141 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:702", + "pc": [ + 142, + 143 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:702", + "pc": [ + 144 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:702", + "pc": [ + 145, + 146 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:702", + "pc": [ + 147 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:702", + "pc": [ + 148, + 149 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:702", + "pc": [ + 150, + 151 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:702", + "pc": [ + 152, + 153 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:702", + "pc": [ + 154, + 155 + ] + }, + { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:702", + "pc": [ + 156 + ] + }, + { + "teal": 90, + "source": "tests/contracts/abi.algo.ts:702", + "pc": [ + 157, + 158, + 159, + 160, + 161, + 162, + 163 + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:702", + "pc": [ + 164 + ] }, { + "teal": 92, + "source": "tests/contracts/abi.algo.ts:702", + "pc": [ + 165, + 166 + ] + }, + { + "teal": 93, + "source": "tests/contracts/abi.algo.ts:702", + "pc": [ + 167, + 168 + ] + }, + { + "teal": 94, + "source": "tests/contracts/abi.algo.ts:702", + "pc": [ + 169, + 170 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:702", + "pc": [ + 171, + 172 + ] + }, + { + "teal": 96, + "source": "tests/contracts/abi.algo.ts:702", + "pc": [ + 173 + ] + }, + { + "teal": 97, + "source": "tests/contracts/abi.algo.ts:702", + "pc": [ + 174, + 175 + ] + }, + { + "teal": 98, + "source": "tests/contracts/abi.algo.ts:702", + "pc": [ + 176 + ] + }, + { + "teal": 99, + "source": "tests/contracts/abi.algo.ts:702", + "pc": [ + 177 + ] + }, + { + "teal": 100, + "source": "tests/contracts/abi.algo.ts:702", + "pc": [ + 178 + ] + }, + { + "teal": 101, + "source": "tests/contracts/abi.algo.ts:702", + "pc": [ + 179 + ] + }, + { + "teal": 102, + "source": "tests/contracts/abi.algo.ts:702", + "pc": [ + 180, + 181 + ] + }, + { + "teal": 103, + "source": "tests/contracts/abi.algo.ts:702", + "pc": [ + 182, + 183, + 184 + ] + }, + { + "teal": 104, + "source": "tests/contracts/abi.algo.ts:702", + "pc": [ + 185, + 186 + ] + }, + { + "teal": 105, + "source": "tests/contracts/abi.algo.ts:702", + "pc": [ + 187, + 188 + ] + }, + { + "teal": 106, + "source": "tests/contracts/abi.algo.ts:702", + "pc": [ + 189, + 190 + ] + }, + { + "teal": 107, + "source": "tests/contracts/abi.algo.ts:702", + "pc": [ + 191 + ] + }, + { + "teal": 108, + "source": "tests/contracts/abi.algo.ts:702", + "pc": [ + 192, + 193, + 194 + ] + }, + { + "teal": 109, + "source": "tests/contracts/abi.algo.ts:702", + "pc": [ + 195, + 196 + ] + }, + { + "teal": 110, + "source": "tests/contracts/abi.algo.ts:702", + "pc": [ + 197, + 198 + ] + }, + { + "teal": 114, + "source": "tests/contracts/abi.algo.ts:704", + "pc": [ + 199, + 200 + ] + }, + { + "teal": 117, + "source": "tests/contracts/abi.algo.ts:699", + "pc": [ + 201, + 202 + ] + }, + { + "teal": 118, + "source": "tests/contracts/abi.algo.ts:699", + "pc": [ + 203 + ] + }, + { + "teal": 121, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 204, + 205 + ] + }, + { + "teal": 122, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 206 + ] + }, + { + "teal": 125, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 207, + 208, + 209, + 210, + 211, + 212 + ] + }, + { + "teal": 126, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 213, + 214, + 215 + ] + }, + { + "teal": 127, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 216, + 217, + 218, + 219 + ] + }, + { + "teal": 130, + "source": "tests/contracts/abi.algo.ts:698", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 220 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] }, { + "teal": 133, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 221, + 222, + 223, + 224, + 225, + 226 + ] + }, + { + "teal": 134, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 227, + 228, + 229 + ] + }, + { + "teal": 135, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 230, + 231, + 232, + 233 + ] + }, + { + "teal": 138, + "source": "tests/contracts/abi.algo.ts:698", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 234 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] + }, + { + "teal": 141, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 235, + 236, + 237 + ] + }, + { + "teal": 142, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 238, + 239 + ] + }, + { + "teal": 143, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 240, + 241 + ] + }, + { + "teal": 144, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 242 + ] + }, + { + "teal": 145, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 243, + 244 + ] + }, + { + "teal": 146, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 245, + 246 + ] + }, + { + "teal": 147, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 247 + ] + }, + { + "teal": 150, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 248, + 249, + 250 + ] + }, + { + "teal": 151, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 251, + 252 + ] + }, + { + "teal": 152, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 253, + 254 + ] + }, + { + "teal": 153, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 255 + ] + }, + { + "teal": 154, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 256, + 257 + ] + }, + { + "teal": 155, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 258, + 259 + ] + }, + { + "teal": 156, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 260 + ] + }, + { + "teal": 157, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 261 + ] + }, + { + "teal": 158, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 262, + 263 + ] + }, + { + "teal": 159, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 264 + ] + }, + { + "teal": 160, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 265 + ] + }, + { + "teal": 161, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 266 + ] + }, + { + "teal": 162, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 267, + 268, + 269 + ] + }, + { + "teal": 163, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 270, + 271 + ] + }, + { + "teal": 164, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 272, + 273 + ] + }, + { + "teal": 165, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 274 + ] + }, + { + "teal": 166, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 275 + ] + }, + { + "teal": 167, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 276, + 277 + ] + }, + { + "teal": 168, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 278, + 279 + ] + }, + { + "teal": 169, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 280, + 281 + ] + }, + { + "teal": 170, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 282, + 283 + ] + }, + { + "teal": 171, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 284 + ] + }, + { + "teal": 174, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 285, + 286, + 287 + ] + }, + { + "teal": 175, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 288, + 289 + ] + }, + { + "teal": 176, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 290, + 291 + ] + }, + { + "teal": 177, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 292, + 293 + ] + }, + { + "teal": 178, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 294 + ] + }, + { + "teal": 179, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 295, + 296 + ] + }, + { + "teal": 180, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 297, + 298, + 299 + ] + }, + { + "teal": 181, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 300 + ] + }, + { + "teal": 182, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 301, + 302, + 303 + ] + }, + { + "teal": 185, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 304 + ] + }, + { + "teal": 186, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 305 + ] + }, + { + "teal": 189, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 306 + ] + }, + { + "teal": 190, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 307, + 308, + 309 + ] + }, + { + "teal": 191, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 310, + 311 + ] + }, + { + "teal": 192, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 312 + ] + }, + { + "teal": 193, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 313, + 314 + ] + }, + { + "teal": 194, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 315 + ] + }, + { + "teal": 195, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 316 + ] + }, + { + "teal": 196, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 317, + 318 + ] + }, + { + "teal": 197, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 319 + ] + }, + { + "teal": 200, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 320, + 321 + ] + }, + { + "teal": 201, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 322 + ] + }, + { + "teal": 202, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 323, + 324 + ] + }, + { + "teal": 203, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 325 + ] + }, + { + "teal": 204, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 326, + 327, + 328 + ] + }, + { + "teal": 205, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 329, + 330 + ] + }, + { + "teal": 206, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 331 + ] + }, + { + "teal": 207, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 332, + 333 + ] + }, + { + "teal": 208, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 334, + 335 + ] + }, + { + "teal": 209, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 336, + 337 + ] + }, + { + "teal": 210, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 338, + 339, + 340 + ] + }, + { + "teal": 213, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 341, + 342 + ] + }, + { + "teal": 214, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 343, + 344 + ] + }, + { + "teal": 215, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 345 + ] + }, + { + "teal": 216, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 346, + 347 + ] + }, + { + "teal": 217, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 348, + 349 + ] + }, + { + "teal": 220, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 350 + ] + }, + { + "teal": 221, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 351, + 352 + ] + }, + { + "teal": 222, + "source": "tests/contracts/abi.algo.ts:698", + "pc": [ + 353 + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestUpdateNamedTuple.arc56_draft.json b/tests/contracts/artifacts/ABITestUpdateNamedTuple.arc56_draft.json index 27dba4b32..45cc58972 100644 --- a/tests/contracts/artifacts/ABITestUpdateNamedTuple.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestUpdateNamedTuple.arc56_draft.json @@ -64,22 +64,1250 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 1, + 2, + 3, + 4, + 5, + 6, + 7, + 8, + 9, + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 19, + 20 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 21 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 22, + 23 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 24 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 25, + 26 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 27 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38, + 39, + 40, + 41, + 42, + 43, + 44, + 45, + 46, + 47, + 48, + 49, + 50, + 51, + 52, + 53 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:614", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 54 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:615", + "pc": [ + 55, + 56, + 57, + 58, + 59, + 60 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:615", + "pc": [ + 61, + 62, + 63 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:615", + "pc": [ + 64 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:615", + "pc": [ + 65 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:615", + "pc": [ + 66 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:615", + "pc": [ + 67, + 68, + 69 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:615", + "pc": [ + 70 + ] + }, + { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:615", + "pc": [ + 71 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:615", + "pc": [ + 72 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:615", + "pc": [ + 73 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:615", + "pc": [ + 74, + 75 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:615", + "pc": [ + 76 + ] + }, + { + "teal": 46, + "source": "tests/contracts/abi.algo.ts:615", + "pc": [ + 77, + 78, + 79 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:615", + "pc": [ + 80, + 81 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:619", + "pc": [ + 82, + 83 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:619", + "pc": [ + 84, + 85 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:619", + "pc": [ + 86, + 87, + 88, + 89 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:620", + "pc": [ + 90, + 91, + 92, + 93 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:620", + "pc": [ + 94, + 95, + 96 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:621", + "pc": [ + 97, + 98, + 99, + 100, + 101, + 102, + 103 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:621", + "pc": [ + 104, + 105, + 106 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:619", + "pc": [ + 107 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:619", + "pc": [ + 108 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:616", + "pc": [ + 109, + 110 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:624", + "pc": [ + 111, + 112 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:624", + "pc": [ + 113, + 114 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:624", + "pc": [ + 115, + 116 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:624", + "pc": [ + 117 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:624", + "pc": [ + 118, + 119 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:624", + "pc": [ + 120, + 121 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:624", + "pc": [ + 122, + 123 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:624", + "pc": [ + 124, + 125 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:624", + "pc": [ + 126 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:624", + "pc": [ + 127 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:624", + "pc": [ + 128, + 129 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:624", + "pc": [ + 130 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:624", + "pc": [ + 131, + 132 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:624", + "pc": [ + 133 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:624", + "pc": [ + 134 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:624", + "pc": [ + 135, + 136 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:624", + "pc": [ + 137 + ] + }, + { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:624", + "pc": [ + 138, + 139 + ] + }, + { + "teal": 90, + "source": "tests/contracts/abi.algo.ts:624", + "pc": [ + 140 + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:624", + "pc": [ + 141, + 142 + ] + }, + { + "teal": 92, + "source": "tests/contracts/abi.algo.ts:624", + "pc": [ + 143, + 144 + ] + }, + { + "teal": 93, + "source": "tests/contracts/abi.algo.ts:624", + "pc": [ + 145, + 146 + ] + }, + { + "teal": 94, + "source": "tests/contracts/abi.algo.ts:624", + "pc": [ + 147, + 148 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:624", + "pc": [ + 149 + ] + }, + { + "teal": 96, + "source": "tests/contracts/abi.algo.ts:624", + "pc": [ + 150, + 151, + 152, + 153, + 154, + 155, + 156, + 157, + 158, + 159, + 160, + 161, + 162, + 163, + 164, + 165 + ] + }, + { + "teal": 97, + "source": "tests/contracts/abi.algo.ts:624", + "pc": [ + 166 + ] + }, + { + "teal": 98, + "source": "tests/contracts/abi.algo.ts:624", + "pc": [ + 167, + 168 + ] + }, + { + "teal": 99, + "source": "tests/contracts/abi.algo.ts:624", + "pc": [ + 169, + 170 + ] + }, + { + "teal": 100, + "source": "tests/contracts/abi.algo.ts:624", + "pc": [ + 171, + 172 + ] + }, + { + "teal": 101, + "source": "tests/contracts/abi.algo.ts:624", + "pc": [ + 173, + 174 + ] + }, + { + "teal": 102, + "source": "tests/contracts/abi.algo.ts:624", + "pc": [ + 175 + ] + }, + { + "teal": 103, + "source": "tests/contracts/abi.algo.ts:624", + "pc": [ + 176, + 177 + ] + }, + { + "teal": 104, + "source": "tests/contracts/abi.algo.ts:624", + "pc": [ + 178 + ] + }, + { + "teal": 105, + "source": "tests/contracts/abi.algo.ts:624", + "pc": [ + 179 + ] + }, + { + "teal": 106, + "source": "tests/contracts/abi.algo.ts:624", + "pc": [ + 180 + ] + }, + { + "teal": 107, + "source": "tests/contracts/abi.algo.ts:624", + "pc": [ + 181 + ] + }, + { + "teal": 108, + "source": "tests/contracts/abi.algo.ts:624", + "pc": [ + 182, + 183 + ] + }, + { + "teal": 109, + "source": "tests/contracts/abi.algo.ts:624", + "pc": [ + 184, + 185, + 186 + ] + }, + { + "teal": 110, + "source": "tests/contracts/abi.algo.ts:624", + "pc": [ + 187, + 188 + ] + }, + { + "teal": 111, + "source": "tests/contracts/abi.algo.ts:624", + "pc": [ + 189, + 190 + ] + }, + { + "teal": 115, + "source": "tests/contracts/abi.algo.ts:626", + "pc": [ + 191, + 192 + ] }, { + "teal": 116, + "source": "tests/contracts/abi.algo.ts:626", + "pc": [ + 193, + 194 + ] + }, + { + "teal": 117, + "source": "tests/contracts/abi.algo.ts:626", + "pc": [ + 195, + 196 + ] + }, + { + "teal": 118, + "source": "tests/contracts/abi.algo.ts:626", + "pc": [ + 197, + 198 + ] + }, + { + "teal": 119, + "source": "tests/contracts/abi.algo.ts:626", + "pc": [ + 199, + 200 + ] + }, + { + "teal": 120, + "source": "tests/contracts/abi.algo.ts:626", + "pc": [ + 201, + 202 + ] + }, + { + "teal": 121, + "source": "tests/contracts/abi.algo.ts:626", + "pc": [ + 203 + ] + }, + { + "teal": 122, + "source": "tests/contracts/abi.algo.ts:626", + "pc": [ + 204 + ] + }, + { + "teal": 123, + "source": "tests/contracts/abi.algo.ts:626", + "pc": [ + 205, + 206 + ] + }, + { + "teal": 124, + "source": "tests/contracts/abi.algo.ts:626", + "pc": [ + 207 + ] + }, + { + "teal": 125, + "source": "tests/contracts/abi.algo.ts:626", + "pc": [ + 208 + ] + }, + { + "teal": 126, + "source": "tests/contracts/abi.algo.ts:626", + "pc": [ + 209, + 210 + ] + }, + { + "teal": 127, + "source": "tests/contracts/abi.algo.ts:626", + "pc": [ + 211 + ] + }, + { + "teal": 128, + "source": "tests/contracts/abi.algo.ts:626", + "pc": [ + 212, + 213 + ] + }, + { + "teal": 129, + "source": "tests/contracts/abi.algo.ts:626", + "pc": [ + 214 + ] + }, + { + "teal": 130, + "source": "tests/contracts/abi.algo.ts:626", + "pc": [ + 215 + ] + }, + { + "teal": 131, + "source": "tests/contracts/abi.algo.ts:626", + "pc": [ + 216, + 217, + 218 + ] + }, + { + "teal": 134, + "source": "tests/contracts/abi.algo.ts:615", + "pc": [ + 219, + 220 + ] + }, + { + "teal": 135, + "source": "tests/contracts/abi.algo.ts:615", + "pc": [ + 221 + ] + }, + { + "teal": 138, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 222, + 223 + ] + }, + { + "teal": 139, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 224 + ] + }, + { + "teal": 142, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 225, + 226, + 227, + 228, + 229, + 230 + ] + }, + { + "teal": 143, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 231, + 232, + 233 + ] + }, + { + "teal": 144, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 234, + 235, + 236, + 237 + ] + }, + { + "teal": 147, + "source": "tests/contracts/abi.algo.ts:614", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 238 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 150, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 239, + 240, + 241, + 242, + 243, + 244 + ] + }, + { + "teal": 151, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 245, + 246, + 247 + ] + }, + { + "teal": 152, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 248, + 249, + 250, + 251 + ] }, { + "teal": 155, + "source": "tests/contracts/abi.algo.ts:614", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 252 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] + }, + { + "teal": 158, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 253, + 254, + 255 + ] + }, + { + "teal": 159, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 256, + 257 + ] + }, + { + "teal": 160, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 258, + 259 + ] + }, + { + "teal": 161, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 260 + ] + }, + { + "teal": 162, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 261, + 262 + ] + }, + { + "teal": 163, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 263, + 264 + ] + }, + { + "teal": 164, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 265 + ] + }, + { + "teal": 167, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 266, + 267, + 268 + ] + }, + { + "teal": 168, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 269, + 270 + ] + }, + { + "teal": 169, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 271, + 272 + ] + }, + { + "teal": 170, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 273 + ] + }, + { + "teal": 171, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 274, + 275 + ] + }, + { + "teal": 172, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 276, + 277 + ] + }, + { + "teal": 173, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 278 + ] + }, + { + "teal": 174, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 279 + ] + }, + { + "teal": 175, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 280, + 281 + ] + }, + { + "teal": 176, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 282 + ] + }, + { + "teal": 177, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 283 + ] + }, + { + "teal": 178, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 284 + ] + }, + { + "teal": 179, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 285, + 286, + 287 + ] + }, + { + "teal": 180, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 288, + 289 + ] + }, + { + "teal": 181, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 290, + 291 + ] + }, + { + "teal": 182, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 292 + ] + }, + { + "teal": 183, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 293 + ] + }, + { + "teal": 184, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 294, + 295 + ] + }, + { + "teal": 185, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 296, + 297 + ] + }, + { + "teal": 186, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 298, + 299 + ] + }, + { + "teal": 187, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 300, + 301 + ] + }, + { + "teal": 188, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 302 + ] + }, + { + "teal": 191, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 303, + 304 + ] + }, + { + "teal": 192, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 305 + ] + }, + { + "teal": 193, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 306, + 307 + ] + }, + { + "teal": 194, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 308 + ] + }, + { + "teal": 195, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 309, + 310, + 311 + ] + }, + { + "teal": 196, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 312, + 313 + ] + }, + { + "teal": 197, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 314 + ] + }, + { + "teal": 198, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 315, + 316 + ] + }, + { + "teal": 199, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 317, + 318 + ] + }, + { + "teal": 200, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 319, + 320 + ] + }, + { + "teal": 201, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 321, + 322, + 323 + ] + }, + { + "teal": 204, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 324, + 325 + ] + }, + { + "teal": 205, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 326, + 327 + ] + }, + { + "teal": 206, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 328 + ] + }, + { + "teal": 207, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 329, + 330 + ] + }, + { + "teal": 208, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 331, + 332 + ] + }, + { + "teal": 211, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 333 + ] + }, + { + "teal": 212, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 334, + 335 + ] + }, + { + "teal": 213, + "source": "tests/contracts/abi.algo.ts:614", + "pc": [ + 336 + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestUpdateNestedStaticArray.arc56_draft.json b/tests/contracts/artifacts/ABITestUpdateNestedStaticArray.arc56_draft.json index b2e7a57ec..e44916a66 100644 --- a/tests/contracts/artifacts/ABITestUpdateNestedStaticArray.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestUpdateNestedStaticArray.arc56_draft.json @@ -64,22 +64,446 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:222", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:222", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:222", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:222", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:222", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:222", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:222", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:222", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:222", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:223", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:223", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:223", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:223", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:223", + "pc": [ + 48 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:223", + "pc": [ + 49, + 50 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:223", + "pc": [ + 51 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:223", + "pc": [ + 52, + 53, + 54 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:223", + "pc": [ + 55, + 56 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:224", + "pc": [ + 57, + 58, + 59, + 60, + 61, + 62, + 63, + 64, + 65, + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82, + 83, + 84, + 85, + 86, + 87, + 88, + 89, + 90, + 91, + 92, + 93, + 94, + 95, + 96, + 97, + 98, + 99, + 100, + 101, + 102, + 103, + 104, + 105, + 106, + 107, + 108, + 109, + 110, + 111, + 112, + 113, + 114, + 115, + 116, + 117, + 118, + 119, + 120, + 121, + 122, + 123, + 124, + 125, + 126, + 127, + 128, + 129, + 130 + ] }, { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:224", + "pc": [ + 131, + 132 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:230", + "pc": [ + 133, + 134 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:230", + "pc": [ + 135, + 136, + 137, + 138, + 139, + 140, + 141, + 142, + 143, + 144, + 145, + 146, + 147, + 148, + 149, + 150, + 151, + 152, + 153, + 154, + 155, + 156, + 157, + 158, + 159, + 160 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:230", + "pc": [ + 161, + 162 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:230", + "pc": [ + 163, + 164 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:232", + "pc": [ + 165, + 166 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:232", + "pc": [ + 167, + 168, + 169 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:232", + "pc": [ + 170 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:223", + "pc": [ + 171, + 172 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:223", + "pc": [ + 173 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:222", + "pc": [ + 174, + 175 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:222", + "pc": [ + 176 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:222", + "pc": [ + 177, + 178, + 179, + 180, + 181, + 182 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:222", + "pc": [ + 183, + 184, + 185 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:222", + "pc": [ + 186, + 187, + 188, + 189 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:222", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 190 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:222", + "pc": [ + 191, + 192, + 193, + 194, + 195, + 196 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:222", + "pc": [ + 197, + 198, + 199 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:222", + "pc": [ + 200, + 201, + 202, + 203 + ] }, { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:222", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 204 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestUpdateNestedStaticArrayElement.arc56_draft.json b/tests/contracts/artifacts/ABITestUpdateNestedStaticArrayElement.arc56_draft.json index cc355add6..f0f5b0985 100644 --- a/tests/contracts/artifacts/ABITestUpdateNestedStaticArrayElement.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestUpdateNestedStaticArrayElement.arc56_draft.json @@ -64,22 +64,430 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:208", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/abi.algo.ts:208", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:208", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:208", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:208", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:208", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:208", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:208", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/abi.algo.ts:208", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/abi.algo.ts:209", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/abi.algo.ts:209", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:209", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:209", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:209", + "pc": [ + 48 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:209", + "pc": [ + 49, + 50 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:209", + "pc": [ + 51 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:209", + "pc": [ + 52, + 53, + 54 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:209", + "pc": [ + 55, + 56 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:210", + "pc": [ + 57, + 58, + 59, + 60, + 61, + 62, + 63, + 64, + 65, + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82, + 83, + 84, + 85, + 86, + 87, + 88, + 89, + 90, + 91, + 92, + 93, + 94, + 95, + 96, + 97, + 98, + 99, + 100, + 101, + 102, + 103, + 104, + 105, + 106, + 107, + 108, + 109, + 110, + 111, + 112, + 113, + 114, + 115, + 116, + 117, + 118, + 119, + 120, + 121, + 122, + 123, + 124, + 125, + 126, + 127, + 128, + 129, + 130 + ] }, { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:210", + "pc": [ + 131, + 132 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:216", + "pc": [ + 133, + 134 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:216", + "pc": [ + 135, + 136, + 137, + 138, + 139, + 140, + 141, + 142, + 143, + 144 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:216", + "pc": [ + 145, + 146 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:216", + "pc": [ + 147, + 148 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:218", + "pc": [ + 149, + 150 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:218", + "pc": [ + 151, + 152, + 153 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:218", + "pc": [ + 154 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:209", + "pc": [ + 155, + 156 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:209", + "pc": [ + 157 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:208", + "pc": [ + 158, + 159 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:208", + "pc": [ + 160 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:208", + "pc": [ + 161, + 162, + 163, + 164, + 165, + 166 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:208", + "pc": [ + 167, + 168, + 169 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:208", + "pc": [ + 170, + 171, + 172, + 173 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:208", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 174 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:208", + "pc": [ + 175, + 176, + 177, + 178, + 179, + 180 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:208", + "pc": [ + 181, + 182, + 183 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:208", + "pc": [ + 184, + 185, + 186, + 187 + ] }, { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:208", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 188 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestUpdateStaticArrayInStorageMap.arc56_draft.json b/tests/contracts/artifacts/ABITestUpdateStaticArrayInStorageMap.arc56_draft.json index 68f8393ce..bf5ad7212 100644 --- a/tests/contracts/artifacts/ABITestUpdateStaticArrayInStorageMap.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestUpdateStaticArrayInStorageMap.arc56_draft.json @@ -97,22 +97,808 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:161", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:161", + "pc": [ + 1, + 2, + 3, + 4, + 5, + 6, + 7, + 8, + 9, + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:161", + "pc": [ + 19, + 20 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:161", + "pc": [ + 21 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:161", + "pc": [ + 22, + 23 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:161", + "pc": [ + 24 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:161", + "pc": [ + 25, + 26 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:161", + "pc": [ + 27 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:161", + "pc": [ + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38, + 39, + 40, + 41, + 42, + 43, + 44, + 45, + 46, + 47, + 48, + 49, + 50, + 51, + 52, + 53 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:161", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 54 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:174", + "pc": [ + 55, + 56, + 57, + 58, + 59, + 60 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:174", + "pc": [ + 61, + 62, + 63 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:174", + "pc": [ + 64 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:174", + "pc": [ + 65 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:174", + "pc": [ + 66, + 67 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:174", + "pc": [ + 68 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:174", + "pc": [ + 69, + 70, + 71 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:174", + "pc": [ + 72, + 73 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:174", + "pc": [ + 74 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:176", + "pc": [ + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82, + 83, + 84, + 85, + 86, + 87, + 88, + 89, + 90, + 91, + 92, + 93, + 94, + 95, + 96, + 97, + 98, + 99, + 100 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:176", + "pc": [ + 101, + 102 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:178", + "pc": [ + 103, + 104, + 105, + 106, + 107, + 108 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:178", + "pc": [ + 109, + 110 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:178", + "pc": [ + 111 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:179", + "pc": [ + 112, + 113 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:179", + "pc": [ + 114, + 115, + 116, + 117, + 118, + 119 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:179", + "pc": [ + 120, + 121 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:179", + "pc": [ + 122 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:180", + "pc": [ + 123, + 124, + 125, + 126, + 127, + 128 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:180", + "pc": [ + 129, + 130 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:180", + "pc": [ + 131 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:182", + "pc": [ + 132, + 133, + 134, + 135, + 136, + 137 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:182", + "pc": [ + 138 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:182", + "pc": [ + 139, + 140, + 141, + 142, + 143, + 144, + 145, + 146, + 147, + 148 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:182", + "pc": [ + 149, + 150 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:182", + "pc": [ + 151, + 152, + 153, + 154, + 155, + 156 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:182", + "pc": [ + 157 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:182", + "pc": [ + 158 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:183", + "pc": [ + 159, + 160 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:183", + "pc": [ + 161, + 162, + 163, + 164, + 165, + 166 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:183", + "pc": [ + 167 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:183", + "pc": [ + 168, + 169, + 170, + 171, + 172, + 173, + 174, + 175, + 176, + 177 + ] }, { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:183", + "pc": [ + 178, + 179 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:183", + "pc": [ + 180, + 181 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:183", + "pc": [ + 182, + 183, + 184, + 185, + 186, + 187 + ] + }, + { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:183", + "pc": [ + 188, + 189 + ] + }, + { + "teal": 90, + "source": "tests/contracts/abi.algo.ts:183", + "pc": [ + 190 + ] + }, + { + "teal": 94, + "source": "tests/contracts/abi.algo.ts:184", + "pc": [ + 191, + 192, + 193, + 194, + 195, + 196 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:184", + "pc": [ + 197, + 198 + ] + }, + { + "teal": 96, + "source": "tests/contracts/abi.algo.ts:184", + "pc": [ + 199, + 200, + 201, + 202, + 203, + 204, + 205, + 206, + 207, + 208 + ] + }, + { + "teal": 97, + "source": "tests/contracts/abi.algo.ts:184", + "pc": [ + 209 + ] + }, + { + "teal": 105, + "source": "tests/contracts/abi.algo.ts:187", + "pc": [ + 210, + 211, + 212, + 213, + 214, + 215 + ] + }, + { + "teal": 106, + "source": "tests/contracts/abi.algo.ts:187", + "pc": [ + 216 + ] + }, + { + "teal": 107, + "source": "tests/contracts/abi.algo.ts:187", + "pc": [ + 217, + 218, + 219 + ] + }, + { + "teal": 108, + "source": "tests/contracts/abi.algo.ts:187", + "pc": [ + 220 + ] + }, + { + "teal": 109, + "source": "tests/contracts/abi.algo.ts:187", + "pc": [ + 221 + ] + }, + { + "teal": 110, + "source": "tests/contracts/abi.algo.ts:188", + "pc": [ + 222, + 223 + ] + }, + { + "teal": 111, + "source": "tests/contracts/abi.algo.ts:188", + "pc": [ + 224, + 225, + 226, + 227, + 228, + 229 + ] + }, + { + "teal": 112, + "source": "tests/contracts/abi.algo.ts:188", + "pc": [ + 230 + ] + }, + { + "teal": 113, + "source": "tests/contracts/abi.algo.ts:188", + "pc": [ + 231, + 232, + 233 + ] + }, + { + "teal": 114, + "source": "tests/contracts/abi.algo.ts:188", + "pc": [ + 234 + ] + }, + { + "teal": 115, + "source": "tests/contracts/abi.algo.ts:188", + "pc": [ + 235 + ] + }, + { + "teal": 116, + "source": "tests/contracts/abi.algo.ts:186", + "pc": [ + 236 + ] + }, + { + "teal": 117, + "source": "tests/contracts/abi.algo.ts:189", + "pc": [ + 237, + 238, + 239, + 240, + 241, + 242 + ] + }, + { + "teal": 118, + "source": "tests/contracts/abi.algo.ts:189", + "pc": [ + 243, + 244 + ] + }, + { + "teal": 119, + "source": "tests/contracts/abi.algo.ts:189", + "pc": [ + 245, + 246 + ] + }, + { + "teal": 120, + "source": "tests/contracts/abi.algo.ts:189", + "pc": [ + 247 + ] + }, + { + "teal": 121, + "source": "tests/contracts/abi.algo.ts:189", + "pc": [ + 248 + ] + }, + { + "teal": 122, + "source": "tests/contracts/abi.algo.ts:189", + "pc": [ + 249 + ] + }, + { + "teal": 123, + "source": "tests/contracts/abi.algo.ts:186", + "pc": [ + 250 + ] + }, + { + "teal": 124, + "source": "tests/contracts/abi.algo.ts:186", + "pc": [ + 251, + 252 + ] + }, + { + "teal": 128, + "source": "tests/contracts/abi.algo.ts:192", + "pc": [ + 253, + 254 + ] + }, + { + "teal": 131, + "source": "tests/contracts/abi.algo.ts:174", + "pc": [ + 255, + 256 + ] + }, + { + "teal": 134, + "source": "tests/contracts/abi.algo.ts:174", + "pc": [ + 257, + 258 + ] + }, + { + "teal": 135, + "source": "tests/contracts/abi.algo.ts:174", + "pc": [ + 259 + ] + }, + { + "teal": 138, + "source": "tests/contracts/abi.algo.ts:161", + "pc": [ + 260, + 261 + ] + }, + { + "teal": 139, + "source": "tests/contracts/abi.algo.ts:161", + "pc": [ + 262 + ] + }, + { + "teal": 142, + "source": "tests/contracts/abi.algo.ts:161", + "pc": [ + 263, + 264, + 265, + 266, + 267, + 268 + ] + }, + { + "teal": 143, + "source": "tests/contracts/abi.algo.ts:161", + "pc": [ + 269, + 270, + 271 + ] + }, + { + "teal": 144, + "source": "tests/contracts/abi.algo.ts:161", + "pc": [ + 272, + 273, + 274, + 275 + ] + }, + { + "teal": 147, + "source": "tests/contracts/abi.algo.ts:161", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 276 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 150, + "source": "tests/contracts/abi.algo.ts:161", + "pc": [ + 277, + 278, + 279, + 280, + 281, + 282 + ] + }, + { + "teal": 151, + "source": "tests/contracts/abi.algo.ts:161", + "pc": [ + 283, + 284, + 285 + ] + }, + { + "teal": 152, + "source": "tests/contracts/abi.algo.ts:161", + "pc": [ + 286, + 287, + 288, + 289 + ] }, { + "teal": 155, + "source": "tests/contracts/abi.algo.ts:161", + "errorMessage": "this contract does not implement the given ABI method for call OptIn", "pc": [ 290 - ], - "errorMessage": "this contract does not implement the given ABI method for call OptIn" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestUpdateStaticArrayInStorageRef.arc56_draft.json b/tests/contracts/artifacts/ABITestUpdateStaticArrayInStorageRef.arc56_draft.json index 648ff32e7..b2dba321d 100644 --- a/tests/contracts/artifacts/ABITestUpdateStaticArrayInStorageRef.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestUpdateStaticArrayInStorageRef.arc56_draft.json @@ -97,22 +97,808 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:99", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:99", + "pc": [ + 1, + 2, + 3, + 4, + 5, + 6, + 7, + 8, + 9, + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:99", + "pc": [ + 19, + 20 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:99", + "pc": [ + 21 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:99", + "pc": [ + 22, + 23 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:99", + "pc": [ + 24 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:99", + "pc": [ + 25, + 26 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:99", + "pc": [ + 27 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:99", + "pc": [ + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38, + 39, + 40, + 41, + 42, + 43, + 44, + 45, + 46, + 47, + 48, + 49, + 50, + 51, + 52, + 53 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:99", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 54 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:112", + "pc": [ + 55, + 56, + 57, + 58, + 59, + 60 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:112", + "pc": [ + 61, + 62, + 63 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:112", + "pc": [ + 64 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:112", + "pc": [ + 65 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:112", + "pc": [ + 66, + 67 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:112", + "pc": [ + 68 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:112", + "pc": [ + 69, + 70, + 71 + ] + }, + { + "teal": 43, + "source": "tests/contracts/abi.algo.ts:112", + "pc": [ + 72, + 73 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:112", + "pc": [ + 74 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:114", + "pc": [ + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82, + 83, + 84, + 85, + 86, + 87, + 88, + 89, + 90, + 91, + 92, + 93, + 94, + 95, + 96, + 97, + 98, + 99, + 100 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:114", + "pc": [ + 101, + 102 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:116", + "pc": [ + 103, + 104, + 105, + 106, + 107, + 108 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:116", + "pc": [ + 109, + 110 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:116", + "pc": [ + 111 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:117", + "pc": [ + 112, + 113 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:117", + "pc": [ + 114, + 115, + 116, + 117, + 118, + 119 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:117", + "pc": [ + 120, + 121 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:117", + "pc": [ + 122 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:118", + "pc": [ + 123, + 124, + 125, + 126, + 127, + 128 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:118", + "pc": [ + 129, + 130 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:118", + "pc": [ + 131 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:120", + "pc": [ + 132, + 133, + 134, + 135, + 136, + 137 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:120", + "pc": [ + 138 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:120", + "pc": [ + 139, + 140, + 141, + 142, + 143, + 144, + 145, + 146, + 147, + 148 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:120", + "pc": [ + 149, + 150 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:120", + "pc": [ + 151, + 152, + 153, + 154, + 155, + 156 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:120", + "pc": [ + 157 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:120", + "pc": [ + 158 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:121", + "pc": [ + 159, + 160 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:121", + "pc": [ + 161, + 162, + 163, + 164, + 165, + 166 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:121", + "pc": [ + 167 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:121", + "pc": [ + 168, + 169, + 170, + 171, + 172, + 173, + 174, + 175, + 176, + 177 + ] }, { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:121", + "pc": [ + 178, + 179 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:121", + "pc": [ + 180, + 181 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:121", + "pc": [ + 182, + 183, + 184, + 185, + 186, + 187 + ] + }, + { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:121", + "pc": [ + 188, + 189 + ] + }, + { + "teal": 90, + "source": "tests/contracts/abi.algo.ts:121", + "pc": [ + 190 + ] + }, + { + "teal": 94, + "source": "tests/contracts/abi.algo.ts:122", + "pc": [ + 191, + 192, + 193, + 194, + 195, + 196 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:122", + "pc": [ + 197, + 198 + ] + }, + { + "teal": 96, + "source": "tests/contracts/abi.algo.ts:122", + "pc": [ + 199, + 200, + 201, + 202, + 203, + 204, + 205, + 206, + 207, + 208 + ] + }, + { + "teal": 97, + "source": "tests/contracts/abi.algo.ts:122", + "pc": [ + 209 + ] + }, + { + "teal": 101, + "source": "tests/contracts/abi.algo.ts:124", + "pc": [ + 210, + 211, + 212, + 213, + 214, + 215 + ] + }, + { + "teal": 102, + "source": "tests/contracts/abi.algo.ts:124", + "pc": [ + 216 + ] + }, + { + "teal": 103, + "source": "tests/contracts/abi.algo.ts:124", + "pc": [ + 217, + 218, + 219 + ] + }, + { + "teal": 104, + "source": "tests/contracts/abi.algo.ts:124", + "pc": [ + 220 + ] + }, + { + "teal": 105, + "source": "tests/contracts/abi.algo.ts:124", + "pc": [ + 221 + ] + }, + { + "teal": 106, + "source": "tests/contracts/abi.algo.ts:124", + "pc": [ + 222, + 223 + ] + }, + { + "teal": 107, + "source": "tests/contracts/abi.algo.ts:124", + "pc": [ + 224, + 225, + 226, + 227, + 228, + 229 + ] + }, + { + "teal": 108, + "source": "tests/contracts/abi.algo.ts:124", + "pc": [ + 230 + ] + }, + { + "teal": 109, + "source": "tests/contracts/abi.algo.ts:124", + "pc": [ + 231, + 232, + 233 + ] + }, + { + "teal": 110, + "source": "tests/contracts/abi.algo.ts:124", + "pc": [ + 234 + ] + }, + { + "teal": 111, + "source": "tests/contracts/abi.algo.ts:124", + "pc": [ + 235 + ] + }, + { + "teal": 112, + "source": "tests/contracts/abi.algo.ts:124", + "pc": [ + 236 + ] + }, + { + "teal": 113, + "source": "tests/contracts/abi.algo.ts:124", + "pc": [ + 237, + 238, + 239, + 240, + 241, + 242 + ] + }, + { + "teal": 114, + "source": "tests/contracts/abi.algo.ts:124", + "pc": [ + 243, + 244 + ] + }, + { + "teal": 115, + "source": "tests/contracts/abi.algo.ts:124", + "pc": [ + 245, + 246 + ] + }, + { + "teal": 116, + "source": "tests/contracts/abi.algo.ts:124", + "pc": [ + 247 + ] + }, + { + "teal": 117, + "source": "tests/contracts/abi.algo.ts:124", + "pc": [ + 248 + ] + }, + { + "teal": 118, + "source": "tests/contracts/abi.algo.ts:124", + "pc": [ + 249 + ] + }, + { + "teal": 119, + "source": "tests/contracts/abi.algo.ts:124", + "pc": [ + 250 + ] + }, + { + "teal": 120, + "source": "tests/contracts/abi.algo.ts:124", + "pc": [ + 251, + 252 + ] + }, + { + "teal": 124, + "source": "tests/contracts/abi.algo.ts:126", + "pc": [ + 253, + 254 + ] + }, + { + "teal": 127, + "source": "tests/contracts/abi.algo.ts:112", + "pc": [ + 255, + 256 + ] + }, + { + "teal": 130, + "source": "tests/contracts/abi.algo.ts:112", + "pc": [ + 257, + 258 + ] + }, + { + "teal": 131, + "source": "tests/contracts/abi.algo.ts:112", + "pc": [ + 259 + ] + }, + { + "teal": 134, + "source": "tests/contracts/abi.algo.ts:99", + "pc": [ + 260, + 261 + ] + }, + { + "teal": 135, + "source": "tests/contracts/abi.algo.ts:99", + "pc": [ + 262 + ] + }, + { + "teal": 138, + "source": "tests/contracts/abi.algo.ts:99", + "pc": [ + 263, + 264, + 265, + 266, + 267, + 268 + ] + }, + { + "teal": 139, + "source": "tests/contracts/abi.algo.ts:99", + "pc": [ + 269, + 270, + 271 + ] + }, + { + "teal": 140, + "source": "tests/contracts/abi.algo.ts:99", + "pc": [ + 272, + 273, + 274, + 275 + ] + }, + { + "teal": 143, + "source": "tests/contracts/abi.algo.ts:99", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 276 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 146, + "source": "tests/contracts/abi.algo.ts:99", + "pc": [ + 277, + 278, + 279, + 280, + 281, + 282 + ] + }, + { + "teal": 147, + "source": "tests/contracts/abi.algo.ts:99", + "pc": [ + 283, + 284, + 285 + ] + }, + { + "teal": 148, + "source": "tests/contracts/abi.algo.ts:99", + "pc": [ + 286, + 287, + 288, + 289 + ] }, { + "teal": 151, + "source": "tests/contracts/abi.algo.ts:99", + "errorMessage": "this contract does not implement the given ABI method for call OptIn", "pc": [ 290 - ], - "errorMessage": "this contract does not implement the given ABI method for call OptIn" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestUpdateStaticFieldInDynamicObjectInBox.arc56_draft.json b/tests/contracts/artifacts/ABITestUpdateStaticFieldInDynamicObjectInBox.arc56_draft.json index e246d9bd1..2d5731350 100644 --- a/tests/contracts/artifacts/ABITestUpdateStaticFieldInDynamicObjectInBox.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestUpdateStaticFieldInDynamicObjectInBox.arc56_draft.json @@ -80,34 +80,937 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:1569", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:1569", + "pc": [ + 1, + 2, + 3, + 4, + 5, + 6, + 7, + 8, + 9, + 10 + ] + }, + { + "teal": 14, + "source": "tests/contracts/abi.algo.ts:1569", + "pc": [ + 11, + 12 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:1569", + "pc": [ + 13 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:1569", + "pc": [ + 14, + 15 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:1569", + "pc": [ + 16 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:1569", + "pc": [ + 17, + 18 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:1569", + "pc": [ + 19 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:1569", + "pc": [ + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38, + 39, + 40, + 41, + 42, + 43, + 44, + 45 + ] + }, + { + "teal": 24, + "source": "tests/contracts/abi.algo.ts:1569", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 46 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/abi.algo.ts:1572", + "pc": [ + 47, + 48, + 49, + 50, + 51, + 52 + ] + }, + { + "teal": 32, + "source": "tests/contracts/abi.algo.ts:1572", + "pc": [ + 53, + 54, + 55 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:1572", + "pc": [ + 56 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:1572", + "pc": [ + 57 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:1572", + "pc": [ + 58 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:1572", + "pc": [ + 59, + 60, + 61 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:1572", + "pc": [ + 62 + ] + }, + { + "teal": 38, + "source": "tests/contracts/abi.algo.ts:1572", + "pc": [ + 63 + ] + }, + { + "teal": 39, + "source": "tests/contracts/abi.algo.ts:1572", + "pc": [ + 64 + ] + }, + { + "teal": 40, + "source": "tests/contracts/abi.algo.ts:1572", + "pc": [ + 65 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:1572", + "pc": [ + 66, + 67 + ] + }, + { + "teal": 42, + "source": "tests/contracts/abi.algo.ts:1572", + "pc": [ + 68 + ] + }, + { + "teal": 46, + "source": "tests/contracts/abi.algo.ts:1572", + "pc": [ + 69, + 70, + 71 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:1573", + "pc": [ + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:1573", + "pc": [ + 80 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:1573", + "pc": [ + 81 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:1573", + "pc": [ + 82 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:1573", + "pc": [ + 83, + 84 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:1573", + "pc": [ + 85, + 86 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:1573", + "pc": [ + 87, + 88, + 89, + 90 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:1573", + "pc": [ + 91, + 92 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:1573", + "pc": [ + 93, + 94, + 95 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:1573", + "pc": [ + 96, + 97, + 98, + 99, + 100, + 101, + 102, + 103, + 104, + 105, + 106, + 107, + 108, + 109, + 110, + 111 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:1573", + "pc": [ + 112, + 113, + 114 + ] }, { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:1573", + "pc": [ + 115 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:1573", + "pc": [ + 116 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:1573", + "pc": [ + 117 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:1575", + "pc": [ + 118, + 119, + 120, + 121, + 122, + 123, + 124, + 125 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:1575", + "pc": [ + 126 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:1575", + "errorMessage": "box value does not exist: this.bMap('bMap').value", "pc": [ 127 - ], - "errorMessage": "box value does not exist: this.bMap('bMap').value" + ] }, { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:1575", + "pc": [ + 128, + 129 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:1575", + "pc": [ + 130, + 131 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:1575", + "pc": [ + 132, + 133 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:1575", + "pc": [ + 134, + 135 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:1575", + "pc": [ + 136 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:1575", + "pc": [ + 137, + 138, + 139, + 140, + 141, + 142, + 143, + 144 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:1575", + "pc": [ + 145 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:1575", + "pc": [ + 146 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:1575", + "pc": [ + 147 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:1575", + "pc": [ + 148 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:1575", + "pc": [ + 149 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:1576", + "pc": [ + 150, + 151, + 152, + 153, + 154, + 155, + 156, + 157 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:1576", + "pc": [ + 158 + ] + }, + { + "teal": 90, + "source": "tests/contracts/abi.algo.ts:1576", + "errorMessage": "box value does not exist: this.bMap('bMap').value", "pc": [ 159 - ], - "errorMessage": "box value does not exist: this.bMap('bMap').value" + ] }, { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:1576", + "pc": [ + 160, + 161 + ] + }, + { + "teal": 92, + "source": "tests/contracts/abi.algo.ts:1576", + "pc": [ + 162, + 163 + ] + }, + { + "teal": 93, + "source": "tests/contracts/abi.algo.ts:1576", + "pc": [ + 164, + 165 + ] + }, + { + "teal": 94, + "source": "tests/contracts/abi.algo.ts:1576", + "pc": [ + 166, + 167 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:1576", + "pc": [ + 168, + 169 + ] + }, + { + "teal": 96, + "source": "tests/contracts/abi.algo.ts:1576", + "pc": [ + 170 + ] + }, + { + "teal": 97, + "source": "tests/contracts/abi.algo.ts:1576", + "pc": [ + 171 + ] + }, + { + "teal": 98, + "source": "tests/contracts/abi.algo.ts:1576", + "pc": [ + 172, + 173 + ] + }, + { + "teal": 99, + "source": "tests/contracts/abi.algo.ts:1576", + "pc": [ + 174 + ] + }, + { + "teal": 100, + "source": "tests/contracts/abi.algo.ts:1576", + "pc": [ + 175 + ] + }, + { + "teal": 101, + "source": "tests/contracts/abi.algo.ts:1576", + "pc": [ + 176, + 177 + ] + }, + { + "teal": 102, + "source": "tests/contracts/abi.algo.ts:1576", + "pc": [ + 178 + ] + }, + { + "teal": 103, + "source": "tests/contracts/abi.algo.ts:1576", + "pc": [ + 179, + 180 + ] + }, + { + "teal": 104, + "source": "tests/contracts/abi.algo.ts:1576", + "pc": [ + 181 + ] + }, + { + "teal": 105, + "source": "tests/contracts/abi.algo.ts:1576", + "pc": [ + 182 + ] + }, + { + "teal": 106, + "source": "tests/contracts/abi.algo.ts:1576", + "pc": [ + 183, + 184, + 185 + ] + }, + { + "teal": 107, + "source": "tests/contracts/abi.algo.ts:1572", + "pc": [ + 186 + ] + }, + { + "teal": 110, + "source": "tests/contracts/abi.algo.ts:1569", + "pc": [ + 187, + 188 + ] + }, + { + "teal": 111, + "source": "tests/contracts/abi.algo.ts:1569", + "pc": [ + 189 + ] + }, + { + "teal": 114, + "source": "tests/contracts/abi.algo.ts:1569", + "pc": [ + 190, + 191, + 192, + 193, + 194, + 195 + ] + }, + { + "teal": 115, + "source": "tests/contracts/abi.algo.ts:1569", + "pc": [ + 196, + 197, + 198 + ] + }, + { + "teal": 116, + "source": "tests/contracts/abi.algo.ts:1569", + "pc": [ + 199, + 200, + 201, + 202 + ] + }, + { + "teal": 119, + "source": "tests/contracts/abi.algo.ts:1569", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 203 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 122, + "source": "tests/contracts/abi.algo.ts:1569", + "pc": [ + 204, + 205, + 206, + 207, + 208, + 209 + ] + }, + { + "teal": 123, + "source": "tests/contracts/abi.algo.ts:1569", + "pc": [ + 210, + 211, + 212 + ] + }, + { + "teal": 124, + "source": "tests/contracts/abi.algo.ts:1569", + "pc": [ + 213, + 214, + 215, + 216 + ] }, { + "teal": 127, + "source": "tests/contracts/abi.algo.ts:1569", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 217 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] + }, + { + "teal": 130, + "source": "tests/contracts/abi.algo.ts:1569", + "pc": [ + 218, + 219, + 220 + ] + }, + { + "teal": 131, + "source": "tests/contracts/abi.algo.ts:1569", + "pc": [ + 221, + 222 + ] + }, + { + "teal": 132, + "source": "tests/contracts/abi.algo.ts:1569", + "pc": [ + 223, + 224 + ] + }, + { + "teal": 133, + "source": "tests/contracts/abi.algo.ts:1569", + "pc": [ + 225 + ] + }, + { + "teal": 134, + "source": "tests/contracts/abi.algo.ts:1569", + "pc": [ + 226, + 227 + ] + }, + { + "teal": 135, + "source": "tests/contracts/abi.algo.ts:1569", + "pc": [ + 228, + 229 + ] + }, + { + "teal": 136, + "source": "tests/contracts/abi.algo.ts:1569", + "pc": [ + 230 + ] + }, + { + "teal": 139, + "source": "tests/contracts/abi.algo.ts:1569", + "pc": [ + 231, + 232, + 233 + ] + }, + { + "teal": 140, + "source": "tests/contracts/abi.algo.ts:1569", + "pc": [ + 234, + 235 + ] + }, + { + "teal": 141, + "source": "tests/contracts/abi.algo.ts:1569", + "pc": [ + 236, + 237 + ] + }, + { + "teal": 142, + "source": "tests/contracts/abi.algo.ts:1569", + "pc": [ + 238 + ] + }, + { + "teal": 143, + "source": "tests/contracts/abi.algo.ts:1569", + "pc": [ + 239, + 240 + ] + }, + { + "teal": 144, + "source": "tests/contracts/abi.algo.ts:1569", + "pc": [ + 241, + 242 + ] + }, + { + "teal": 145, + "source": "tests/contracts/abi.algo.ts:1569", + "pc": [ + 243 + ] + }, + { + "teal": 146, + "source": "tests/contracts/abi.algo.ts:1569", + "pc": [ + 244 + ] + }, + { + "teal": 147, + "source": "tests/contracts/abi.algo.ts:1569", + "pc": [ + 245, + 246 + ] + }, + { + "teal": 148, + "source": "tests/contracts/abi.algo.ts:1569", + "pc": [ + 247 + ] + }, + { + "teal": 149, + "source": "tests/contracts/abi.algo.ts:1569", + "pc": [ + 248 + ] + }, + { + "teal": 150, + "source": "tests/contracts/abi.algo.ts:1569", + "pc": [ + 249 + ] + }, + { + "teal": 151, + "source": "tests/contracts/abi.algo.ts:1569", + "pc": [ + 250, + 251, + 252 + ] + }, + { + "teal": 152, + "source": "tests/contracts/abi.algo.ts:1569", + "pc": [ + 253, + 254 + ] + }, + { + "teal": 153, + "source": "tests/contracts/abi.algo.ts:1569", + "pc": [ + 255, + 256 + ] + }, + { + "teal": 154, + "source": "tests/contracts/abi.algo.ts:1569", + "pc": [ + 257 + ] + }, + { + "teal": 155, + "source": "tests/contracts/abi.algo.ts:1569", + "pc": [ + 258 + ] + }, + { + "teal": 156, + "source": "tests/contracts/abi.algo.ts:1569", + "pc": [ + 259, + 260 + ] + }, + { + "teal": 157, + "source": "tests/contracts/abi.algo.ts:1569", + "pc": [ + 261, + 262 + ] + }, + { + "teal": 158, + "source": "tests/contracts/abi.algo.ts:1569", + "pc": [ + 263, + 264 + ] + }, + { + "teal": 159, + "source": "tests/contracts/abi.algo.ts:1569", + "pc": [ + 265, + 266 + ] + }, + { + "teal": 160, + "source": "tests/contracts/abi.algo.ts:1569", + "pc": [ + 267 + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestUpdateStringInTuple.arc56_draft.json b/tests/contracts/artifacts/ABITestUpdateStringInTuple.arc56_draft.json index 09b4622c7..8081d2635 100644 --- a/tests/contracts/artifacts/ABITestUpdateStringInTuple.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestUpdateStringInTuple.arc56_draft.json @@ -64,22 +64,2551 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 1, + 2, + 3 + ] + }, + { + "teal": 3, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 4, + 5, + 6, + 7, + 8, + 9, + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38, + 39, + 40 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 41, + 42 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 43 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 44, + 45 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 46 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 47, + 48 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 49 + ] + }, + { + "teal": 21, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 50, + 51, + 52, + 53, + 54, + 55, + 56, + 57, + 58, + 59, + 60, + 61, + 62, + 63, + 64, + 65, + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75 + ] + }, + { + "teal": 25, + "source": "tests/contracts/abi.algo.ts:558", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 76 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 30, + "source": "tests/contracts/abi.algo.ts:559", + "pc": [ + 77, + 78, + 79, + 80, + 81, + 82 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:559", + "pc": [ + 83, + 84, + 85 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:559", + "pc": [ + 86 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:559", + "pc": [ + 87 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:559", + "pc": [ + 88, + 89 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:559", + "pc": [ + 90 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:559", + "pc": [ + 91, + 92, + 93 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:559", + "pc": [ + 94, + 95 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:560", + "pc": [ + 96, + 97 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:560", + "pc": [ + 98, + 99 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:560", + "pc": [ + 100, + 101, + 102, + 103 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:560", + "pc": [ + 104, + 105, + 106 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:560", + "pc": [ + 107, + 108, + 109 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:560", + "pc": [ + 110, + 111, + 112, + 113, + 114, + 115 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:560", + "pc": [ + 116, + 117, + 118 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:560", + "pc": [ + 119, + 120, + 121, + 122, + 123, + 124, + 125 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:560", + "pc": [ + 126, + 127, + 128 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:560", + "pc": [ + 129, + 130, + 131, + 132, + 133, + 134 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:560", + "pc": [ + 135, + 136, + 137 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:560", + "pc": [ + 138, + 139, + 140, + 141, + 142 + ] + }, + { + "teal": 60, + "source": "tests/contracts/abi.algo.ts:560", + "pc": [ + 143, + 144, + 145 + ] + }, + { + "teal": 61, + "source": "tests/contracts/abi.algo.ts:560", + "pc": [ + 146 + ] + }, + { + "teal": 62, + "source": "tests/contracts/abi.algo.ts:560", + "pc": [ + 147 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:560", + "pc": [ + 148, + 149 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:562", + "pc": [ + 150, + 151 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:562", + "pc": [ + 152, + 153 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:562", + "pc": [ + 154, + 155 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:562", + "pc": [ + 156, + 157, + 158 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:562", + "pc": [ + 159, + 160 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:562", + "pc": [ + 161, + 162 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 163, + 164 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 165, + 166 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 167, + 168 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 169 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 170, + 171 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 172, + 173 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 174, + 175 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 176, + 177 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 178 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 179 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 180, + 181 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 182 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 183, + 184 + ] + }, + { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 185 + ] + }, + { + "teal": 90, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 186 + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 187, + 188 + ] + }, + { + "teal": 92, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 189 + ] + }, + { + "teal": 93, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 190, + 191 + ] + }, + { + "teal": 94, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 192 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 193, + 194 + ] + }, + { + "teal": 96, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 195, + 196 + ] + }, + { + "teal": 97, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 197, + 198 + ] + }, + { + "teal": 98, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 199, + 200 + ] + }, + { + "teal": 99, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 201 + ] + }, + { + "teal": 100, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 202, + 203, + 204, + 205, + 206, + 207, + 208, + 209 + ] + }, + { + "teal": 101, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 210 + ] + }, + { + "teal": 102, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 211, + 212 + ] + }, + { + "teal": 103, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 213, + 214 + ] + }, + { + "teal": 104, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 215, + 216 + ] + }, + { + "teal": 105, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 217, + 218 + ] + }, + { + "teal": 106, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 219 + ] + }, + { + "teal": 107, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 220, + 221 + ] + }, + { + "teal": 108, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 222 + ] + }, + { + "teal": 109, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 223 + ] + }, + { + "teal": 110, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 224 + ] + }, + { + "teal": 111, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 225 + ] + }, + { + "teal": 112, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 226, + 227 + ] + }, + { + "teal": 113, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 228, + 229, + 230 + ] + }, + { + "teal": 114, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 231, + 232 + ] + }, + { + "teal": 115, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 233, + 234 + ] + }, + { + "teal": 116, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 235, + 236 + ] + }, + { + "teal": 117, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 237 + ] + }, + { + "teal": 118, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 238, + 239, + 240 + ] + }, + { + "teal": 119, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 241, + 242 + ] + }, + { + "teal": 120, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 243, + 244 + ] + }, + { + "teal": 121, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 245, + 246 + ] + }, + { + "teal": 122, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 247 + ] + }, + { + "teal": 123, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 248, + 249, + 250 + ] + }, + { + "teal": 124, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 251, + 252 + ] + }, + { + "teal": 125, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 253, + 254 + ] + }, + { + "teal": 126, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 255, + 256 + ] + }, + { + "teal": 127, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 257 + ] + }, + { + "teal": 128, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 258, + 259, + 260 + ] + }, + { + "teal": 129, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 261, + 262 + ] + }, + { + "teal": 130, + "source": "tests/contracts/abi.algo.ts:563", + "pc": [ + 263, + 264 + ] + }, + { + "teal": 134, + "source": "tests/contracts/abi.algo.ts:564", + "pc": [ + 265, + 266 + ] + }, + { + "teal": 135, + "source": "tests/contracts/abi.algo.ts:564", + "pc": [ + 267, + 268 + ] + }, + { + "teal": 136, + "source": "tests/contracts/abi.algo.ts:564", + "pc": [ + 269, + 270 + ] + }, + { + "teal": 137, + "source": "tests/contracts/abi.algo.ts:564", + "pc": [ + 271 + ] + }, + { + "teal": 138, + "source": "tests/contracts/abi.algo.ts:564", + "pc": [ + 272, + 273 + ] + }, + { + "teal": 139, + "source": "tests/contracts/abi.algo.ts:564", + "pc": [ + 274, + 275 + ] + }, + { + "teal": 140, + "source": "tests/contracts/abi.algo.ts:564", + "pc": [ + 276, + 277 + ] + }, + { + "teal": 141, + "source": "tests/contracts/abi.algo.ts:564", + "pc": [ + 278, + 279 + ] + }, + { + "teal": 142, + "source": "tests/contracts/abi.algo.ts:564", + "pc": [ + 280 + ] + }, + { + "teal": 143, + "source": "tests/contracts/abi.algo.ts:564", + "pc": [ + 281 + ] + }, + { + "teal": 144, + "source": "tests/contracts/abi.algo.ts:564", + "pc": [ + 282, + 283 + ] + }, + { + "teal": 145, + "source": "tests/contracts/abi.algo.ts:564", + "pc": [ + 284 + ] + }, + { + "teal": 146, + "source": "tests/contracts/abi.algo.ts:564", + "pc": [ + 285, + 286 + ] + }, + { + "teal": 147, + "source": "tests/contracts/abi.algo.ts:564", + "pc": [ + 287 + ] + }, + { + "teal": 148, + "source": "tests/contracts/abi.algo.ts:564", + "pc": [ + 288 + ] + }, + { + "teal": 149, + "source": "tests/contracts/abi.algo.ts:564", + "pc": [ + 289, + 290 + ] + }, + { + "teal": 150, + "source": "tests/contracts/abi.algo.ts:564", + "pc": [ + 291 + ] + }, + { + "teal": 151, + "source": "tests/contracts/abi.algo.ts:564", + "pc": [ + 292, + 293 + ] + }, + { + "teal": 152, + "source": "tests/contracts/abi.algo.ts:564", + "pc": [ + 294 + ] + }, + { + "teal": 153, + "source": "tests/contracts/abi.algo.ts:564", + "pc": [ + 295, + 296 + ] + }, + { + "teal": 154, + "source": "tests/contracts/abi.algo.ts:564", + "pc": [ + 297, + 298 + ] + }, + { + "teal": 155, + "source": "tests/contracts/abi.algo.ts:564", + "pc": [ + 299, + 300 + ] + }, + { + "teal": 156, + "source": "tests/contracts/abi.algo.ts:564", + "pc": [ + 301, + 302 + ] + }, + { + "teal": 157, + "source": "tests/contracts/abi.algo.ts:564", + "pc": [ + 303 + ] + }, + { + "teal": 158, + "source": "tests/contracts/abi.algo.ts:564", + "pc": [ + 304, + 305, + 306, + 307, + 308, + 309, + 310, + 311, + 312, + 313, + 314, + 315, + 316, + 317, + 318, + 319 + ] + }, + { + "teal": 159, + "source": "tests/contracts/abi.algo.ts:564", + "pc": [ + 320 + ] + }, + { + "teal": 160, + "source": "tests/contracts/abi.algo.ts:564", + "pc": [ + 321, + 322 + ] + }, + { + "teal": 161, + "source": "tests/contracts/abi.algo.ts:564", + "pc": [ + 323, + 324 + ] + }, + { + "teal": 162, + "source": "tests/contracts/abi.algo.ts:564", + "pc": [ + 325, + 326 + ] + }, + { + "teal": 163, + "source": "tests/contracts/abi.algo.ts:564", + "pc": [ + 327, + 328 + ] + }, + { + "teal": 164, + "source": "tests/contracts/abi.algo.ts:564", + "pc": [ + 329 + ] + }, + { + "teal": 165, + "source": "tests/contracts/abi.algo.ts:564", + "pc": [ + 330, + 331 + ] + }, + { + "teal": 166, + "source": "tests/contracts/abi.algo.ts:564", + "pc": [ + 332 + ] + }, + { + "teal": 167, + "source": "tests/contracts/abi.algo.ts:564", + "pc": [ + 333 + ] + }, + { + "teal": 168, + "source": "tests/contracts/abi.algo.ts:564", + "pc": [ + 334 + ] + }, + { + "teal": 169, + "source": "tests/contracts/abi.algo.ts:564", + "pc": [ + 335 + ] + }, + { + "teal": 170, + "source": "tests/contracts/abi.algo.ts:564", + "pc": [ + 336, + 337 + ] + }, + { + "teal": 171, + "source": "tests/contracts/abi.algo.ts:564", + "pc": [ + 338, + 339, + 340 + ] + }, + { + "teal": 172, + "source": "tests/contracts/abi.algo.ts:564", + "pc": [ + 341, + 342 + ] + }, + { + "teal": 173, + "source": "tests/contracts/abi.algo.ts:564", + "pc": [ + 343, + 344 + ] + }, + { + "teal": 174, + "source": "tests/contracts/abi.algo.ts:564", + "pc": [ + 345, + 346 + ] + }, + { + "teal": 175, + "source": "tests/contracts/abi.algo.ts:564", + "pc": [ + 347 + ] + }, + { + "teal": 176, + "source": "tests/contracts/abi.algo.ts:564", + "pc": [ + 348, + 349, + 350 + ] + }, + { + "teal": 177, + "source": "tests/contracts/abi.algo.ts:564", + "pc": [ + 351, + 352 + ] + }, + { + "teal": 178, + "source": "tests/contracts/abi.algo.ts:564", + "pc": [ + 353, + 354 + ] + }, + { + "teal": 179, + "source": "tests/contracts/abi.algo.ts:564", + "pc": [ + 355, + 356 + ] + }, + { + "teal": 180, + "source": "tests/contracts/abi.algo.ts:564", + "pc": [ + 357 + ] + }, + { + "teal": 181, + "source": "tests/contracts/abi.algo.ts:564", + "pc": [ + 358, + 359, + 360 + ] + }, + { + "teal": 182, + "source": "tests/contracts/abi.algo.ts:564", + "pc": [ + 361, + 362 + ] + }, + { + "teal": 183, + "source": "tests/contracts/abi.algo.ts:564", + "pc": [ + 363, + 364 + ] + }, + { + "teal": 187, + "source": "tests/contracts/abi.algo.ts:565", + "pc": [ + 365, + 366 + ] + }, + { + "teal": 188, + "source": "tests/contracts/abi.algo.ts:565", + "pc": [ + 367, + 368 + ] + }, + { + "teal": 189, + "source": "tests/contracts/abi.algo.ts:565", + "pc": [ + 369, + 370 + ] + }, + { + "teal": 190, + "source": "tests/contracts/abi.algo.ts:565", + "pc": [ + 371 + ] + }, + { + "teal": 191, + "source": "tests/contracts/abi.algo.ts:565", + "pc": [ + 372, + 373 + ] + }, + { + "teal": 192, + "source": "tests/contracts/abi.algo.ts:565", + "pc": [ + 374, + 375 + ] + }, + { + "teal": 193, + "source": "tests/contracts/abi.algo.ts:565", + "pc": [ + 376, + 377 + ] + }, + { + "teal": 194, + "source": "tests/contracts/abi.algo.ts:565", + "pc": [ + 378, + 379 + ] + }, + { + "teal": 195, + "source": "tests/contracts/abi.algo.ts:565", + "pc": [ + 380 + ] + }, + { + "teal": 196, + "source": "tests/contracts/abi.algo.ts:565", + "pc": [ + 381 + ] + }, + { + "teal": 197, + "source": "tests/contracts/abi.algo.ts:565", + "pc": [ + 382, + 383 + ] + }, + { + "teal": 198, + "source": "tests/contracts/abi.algo.ts:565", + "pc": [ + 384 + ] + }, + { + "teal": 199, + "source": "tests/contracts/abi.algo.ts:565", + "pc": [ + 385, + 386 + ] + }, + { + "teal": 200, + "source": "tests/contracts/abi.algo.ts:565", + "pc": [ + 387 + ] + }, + { + "teal": 201, + "source": "tests/contracts/abi.algo.ts:565", + "pc": [ + 388 + ] + }, + { + "teal": 202, + "source": "tests/contracts/abi.algo.ts:565", + "pc": [ + 389, + 390 + ] + }, + { + "teal": 203, + "source": "tests/contracts/abi.algo.ts:565", + "pc": [ + 391 + ] + }, + { + "teal": 204, + "source": "tests/contracts/abi.algo.ts:565", + "pc": [ + 392, + 393 + ] + }, + { + "teal": 205, + "source": "tests/contracts/abi.algo.ts:565", + "pc": [ + 394 + ] + }, + { + "teal": 206, + "source": "tests/contracts/abi.algo.ts:565", + "pc": [ + 395, + 396 + ] + }, + { + "teal": 207, + "source": "tests/contracts/abi.algo.ts:565", + "pc": [ + 397, + 398 + ] + }, + { + "teal": 208, + "source": "tests/contracts/abi.algo.ts:565", + "pc": [ + 399, + 400 + ] + }, + { + "teal": 209, + "source": "tests/contracts/abi.algo.ts:565", + "pc": [ + 401, + 402 + ] + }, + { + "teal": 210, + "source": "tests/contracts/abi.algo.ts:565", + "pc": [ + 403 + ] + }, + { + "teal": 211, + "source": "tests/contracts/abi.algo.ts:565", + "pc": [ + 404, + 405, + 406, + 407, + 408, + 409, + 410, + 411 + ] + }, + { + "teal": 212, + "source": "tests/contracts/abi.algo.ts:565", + "pc": [ + 412 + ] + }, + { + "teal": 213, + "source": "tests/contracts/abi.algo.ts:565", + "pc": [ + 413, + 414 + ] + }, + { + "teal": 214, + "source": "tests/contracts/abi.algo.ts:565", + "pc": [ + 415, + 416 + ] + }, + { + "teal": 215, + "source": "tests/contracts/abi.algo.ts:565", + "pc": [ + 417, + 418 + ] + }, + { + "teal": 216, + "source": "tests/contracts/abi.algo.ts:565", + "pc": [ + 419, + 420 + ] + }, + { + "teal": 217, + "source": "tests/contracts/abi.algo.ts:565", + "pc": [ + 421 + ] + }, + { + "teal": 218, + "source": "tests/contracts/abi.algo.ts:565", + "pc": [ + 422, + 423 + ] + }, + { + "teal": 219, + "source": "tests/contracts/abi.algo.ts:565", + "pc": [ + 424 + ] + }, + { + "teal": 220, + "source": "tests/contracts/abi.algo.ts:565", + "pc": [ + 425 + ] + }, + { + "teal": 221, + "source": "tests/contracts/abi.algo.ts:565", + "pc": [ + 426 + ] + }, + { + "teal": 222, + "source": "tests/contracts/abi.algo.ts:565", + "pc": [ + 427 + ] + }, + { + "teal": 223, + "source": "tests/contracts/abi.algo.ts:565", + "pc": [ + 428, + 429 + ] + }, + { + "teal": 224, + "source": "tests/contracts/abi.algo.ts:565", + "pc": [ + 430, + 431, + 432 + ] + }, + { + "teal": 225, + "source": "tests/contracts/abi.algo.ts:565", + "pc": [ + 433, + 434 + ] + }, + { + "teal": 226, + "source": "tests/contracts/abi.algo.ts:565", + "pc": [ + 435, + 436 + ] + }, + { + "teal": 227, + "source": "tests/contracts/abi.algo.ts:565", + "pc": [ + 437, + 438 + ] + }, + { + "teal": 228, + "source": "tests/contracts/abi.algo.ts:565", + "pc": [ + 439 + ] + }, + { + "teal": 229, + "source": "tests/contracts/abi.algo.ts:565", + "pc": [ + 440, + 441, + 442 + ] + }, + { + "teal": 230, + "source": "tests/contracts/abi.algo.ts:565", + "pc": [ + 443, + 444 + ] + }, + { + "teal": 231, + "source": "tests/contracts/abi.algo.ts:565", + "pc": [ + 445, + 446 + ] + }, + { + "teal": 235, + "source": "tests/contracts/abi.algo.ts:566", + "pc": [ + 447, + 448 + ] + }, + { + "teal": 236, + "source": "tests/contracts/abi.algo.ts:566", + "pc": [ + 449, + 450 + ] + }, + { + "teal": 237, + "source": "tests/contracts/abi.algo.ts:566", + "pc": [ + 451, + 452 + ] + }, + { + "teal": 238, + "source": "tests/contracts/abi.algo.ts:566", + "pc": [ + 453 + ] + }, + { + "teal": 239, + "source": "tests/contracts/abi.algo.ts:566", + "pc": [ + 454, + 455 + ] + }, + { + "teal": 240, + "source": "tests/contracts/abi.algo.ts:566", + "pc": [ + 456, + 457 + ] + }, + { + "teal": 241, + "source": "tests/contracts/abi.algo.ts:566", + "pc": [ + 458, + 459 + ] + }, + { + "teal": 242, + "source": "tests/contracts/abi.algo.ts:566", + "pc": [ + 460, + 461 + ] + }, + { + "teal": 243, + "source": "tests/contracts/abi.algo.ts:566", + "pc": [ + 462 + ] + }, + { + "teal": 244, + "source": "tests/contracts/abi.algo.ts:566", + "pc": [ + 463 + ] + }, + { + "teal": 245, + "source": "tests/contracts/abi.algo.ts:566", + "pc": [ + 464, + 465 + ] + }, + { + "teal": 246, + "source": "tests/contracts/abi.algo.ts:566", + "pc": [ + 466 + ] + }, + { + "teal": 247, + "source": "tests/contracts/abi.algo.ts:566", + "pc": [ + 467, + 468 + ] + }, + { + "teal": 248, + "source": "tests/contracts/abi.algo.ts:566", + "pc": [ + 469 + ] + }, + { + "teal": 249, + "source": "tests/contracts/abi.algo.ts:566", + "pc": [ + 470 + ] + }, + { + "teal": 250, + "source": "tests/contracts/abi.algo.ts:566", + "pc": [ + 471, + 472 + ] + }, + { + "teal": 251, + "source": "tests/contracts/abi.algo.ts:566", + "pc": [ + 473 + ] + }, + { + "teal": 252, + "source": "tests/contracts/abi.algo.ts:566", + "pc": [ + 474, + 475 + ] + }, + { + "teal": 253, + "source": "tests/contracts/abi.algo.ts:566", + "pc": [ + 476 + ] + }, + { + "teal": 254, + "source": "tests/contracts/abi.algo.ts:566", + "pc": [ + 477, + 478 + ] + }, + { + "teal": 255, + "source": "tests/contracts/abi.algo.ts:566", + "pc": [ + 479, + 480 + ] + }, + { + "teal": 256, + "source": "tests/contracts/abi.algo.ts:566", + "pc": [ + 481, + 482 + ] + }, + { + "teal": 257, + "source": "tests/contracts/abi.algo.ts:566", + "pc": [ + 483, + 484 + ] + }, + { + "teal": 258, + "source": "tests/contracts/abi.algo.ts:566", + "pc": [ + 485 + ] + }, + { + "teal": 259, + "source": "tests/contracts/abi.algo.ts:566", + "pc": [ + 486, + 487, + 488, + 489, + 490, + 491 + ] + }, + { + "teal": 260, + "source": "tests/contracts/abi.algo.ts:566", + "pc": [ + 492 + ] + }, + { + "teal": 261, + "source": "tests/contracts/abi.algo.ts:566", + "pc": [ + 493, + 494 + ] + }, + { + "teal": 262, + "source": "tests/contracts/abi.algo.ts:566", + "pc": [ + 495, + 496 + ] + }, + { + "teal": 263, + "source": "tests/contracts/abi.algo.ts:566", + "pc": [ + 497, + 498 + ] + }, + { + "teal": 264, + "source": "tests/contracts/abi.algo.ts:566", + "pc": [ + 499, + 500 + ] + }, + { + "teal": 265, + "source": "tests/contracts/abi.algo.ts:566", + "pc": [ + 501 + ] + }, + { + "teal": 266, + "source": "tests/contracts/abi.algo.ts:566", + "pc": [ + 502, + 503 + ] + }, + { + "teal": 267, + "source": "tests/contracts/abi.algo.ts:566", + "pc": [ + 504 + ] + }, + { + "teal": 268, + "source": "tests/contracts/abi.algo.ts:566", + "pc": [ + 505 + ] + }, + { + "teal": 269, + "source": "tests/contracts/abi.algo.ts:566", + "pc": [ + 506 + ] + }, + { + "teal": 270, + "source": "tests/contracts/abi.algo.ts:566", + "pc": [ + 507 + ] + }, + { + "teal": 271, + "source": "tests/contracts/abi.algo.ts:566", + "pc": [ + 508, + 509 + ] + }, + { + "teal": 272, + "source": "tests/contracts/abi.algo.ts:566", + "pc": [ + 510, + 511, + 512 + ] + }, + { + "teal": 273, + "source": "tests/contracts/abi.algo.ts:566", + "pc": [ + 513, + 514 + ] + }, + { + "teal": 274, + "source": "tests/contracts/abi.algo.ts:566", + "pc": [ + 515, + 516 + ] + }, + { + "teal": 278, + "source": "tests/contracts/abi.algo.ts:568", + "pc": [ + 517, + 518 + ] + }, + { + "teal": 281, + "source": "tests/contracts/abi.algo.ts:559", + "pc": [ + 519, + 520 + ] + }, + { + "teal": 282, + "source": "tests/contracts/abi.algo.ts:559", + "pc": [ + 521 + ] + }, + { + "teal": 285, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 522, + 523 + ] + }, + { + "teal": 286, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 524 + ] + }, + { + "teal": 289, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 525, + 526, + 527, + 528, + 529, + 530 + ] + }, + { + "teal": 290, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 531, + 532, + 533 + ] }, { + "teal": 291, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 534, + 535, + 536, + 537 + ] + }, + { + "teal": 294, + "source": "tests/contracts/abi.algo.ts:558", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 538 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 297, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 539, + 540, + 541, + 542, + 543, + 544 + ] + }, + { + "teal": 298, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 545, + 546, + 547 + ] + }, + { + "teal": 299, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 548, + 549, + 550, + 551 + ] }, { + "teal": 302, + "source": "tests/contracts/abi.algo.ts:558", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 552 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] + }, + { + "teal": 305, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 553, + 554, + 555 + ] + }, + { + "teal": 306, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 556, + 557 + ] + }, + { + "teal": 307, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 558, + 559 + ] + }, + { + "teal": 308, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 560 + ] + }, + { + "teal": 309, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 561, + 562 + ] + }, + { + "teal": 310, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 563, + 564 + ] + }, + { + "teal": 311, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 565 + ] + }, + { + "teal": 314, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 566, + 567, + 568 + ] + }, + { + "teal": 315, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 569, + 570 + ] + }, + { + "teal": 316, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 571, + 572 + ] + }, + { + "teal": 317, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 573 + ] + }, + { + "teal": 318, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 574, + 575 + ] + }, + { + "teal": 319, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 576, + 577 + ] + }, + { + "teal": 320, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 578 + ] + }, + { + "teal": 321, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 579 + ] + }, + { + "teal": 322, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 580, + 581 + ] + }, + { + "teal": 323, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 582 + ] + }, + { + "teal": 324, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 583 + ] + }, + { + "teal": 325, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 584 + ] + }, + { + "teal": 326, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 585, + 586, + 587 + ] + }, + { + "teal": 327, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 588, + 589 + ] + }, + { + "teal": 328, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 590, + 591 + ] + }, + { + "teal": 329, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 592 + ] + }, + { + "teal": 330, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 593 + ] + }, + { + "teal": 331, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 594, + 595 + ] + }, + { + "teal": 332, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 596, + 597 + ] + }, + { + "teal": 333, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 598, + 599 + ] + }, + { + "teal": 334, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 600, + 601 + ] + }, + { + "teal": 335, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 602 + ] + }, + { + "teal": 338, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 603, + 604, + 605 + ] + }, + { + "teal": 339, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 606, + 607 + ] + }, + { + "teal": 340, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 608, + 609 + ] + }, + { + "teal": 341, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 610, + 611 + ] + }, + { + "teal": 342, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 612 + ] + }, + { + "teal": 343, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 613, + 614 + ] + }, + { + "teal": 344, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 615, + 616, + 617 + ] + }, + { + "teal": 345, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 618 + ] + }, + { + "teal": 346, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 619, + 620, + 621 + ] + }, + { + "teal": 349, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 622 + ] + }, + { + "teal": 350, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 623 + ] + }, + { + "teal": 353, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 624 + ] + }, + { + "teal": 354, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 625, + 626, + 627 + ] + }, + { + "teal": 355, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 628, + 629 + ] + }, + { + "teal": 356, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 630 + ] + }, + { + "teal": 357, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 631, + 632 + ] + }, + { + "teal": 358, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 633 + ] + }, + { + "teal": 359, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 634 + ] + }, + { + "teal": 360, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 635, + 636 + ] + }, + { + "teal": 361, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 637 + ] + }, + { + "teal": 364, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 638, + 639 + ] + }, + { + "teal": 365, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 640 + ] + }, + { + "teal": 366, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 641, + 642 + ] + }, + { + "teal": 367, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 643 + ] + }, + { + "teal": 368, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 644, + 645, + 646 + ] + }, + { + "teal": 369, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 647, + 648 + ] + }, + { + "teal": 370, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 649 + ] + }, + { + "teal": 371, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 650, + 651 + ] + }, + { + "teal": 372, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 652, + 653 + ] + }, + { + "teal": 373, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 654, + 655 + ] + }, + { + "teal": 374, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 656, + 657, + 658 + ] + }, + { + "teal": 377, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 659, + 660 + ] + }, + { + "teal": 378, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 661, + 662 + ] + }, + { + "teal": 379, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 663 + ] + }, + { + "teal": 380, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 664, + 665 + ] + }, + { + "teal": 381, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 666, + 667 + ] + }, + { + "teal": 384, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 668 + ] + }, + { + "teal": 385, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 669, + 670 + ] + }, + { + "teal": 386, + "source": "tests/contracts/abi.algo.ts:558", + "pc": [ + 671 + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ABITestUpdateTupleWithOnlyDynamicTypes.arc56_draft.json b/tests/contracts/artifacts/ABITestUpdateTupleWithOnlyDynamicTypes.arc56_draft.json index db6ae2219..445cf020c 100644 --- a/tests/contracts/artifacts/ABITestUpdateTupleWithOnlyDynamicTypes.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestUpdateTupleWithOnlyDynamicTypes.arc56_draft.json @@ -64,22 +64,1957 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 1, + 2, + 3 + ] + }, + { + "teal": 3, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 4, + 5, + 6, + 7, + 8, + 9, + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27 + ] + }, + { + "teal": 15, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 28, + 29 + ] + }, + { + "teal": 16, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 30 + ] + }, + { + "teal": 17, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 31, + 32 + ] + }, + { + "teal": 18, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 33 + ] + }, + { + "teal": 19, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 34, + 35 + ] + }, + { + "teal": 20, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 36 + ] + }, + { + "teal": 21, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42, + 43, + 44, + 45, + 46, + 47, + 48, + 49, + 50, + 51, + 52, + 53, + 54, + 55, + 56, + 57, + 58, + 59, + 60, + 61, + 62 + ] + }, + { + "teal": 25, + "source": "tests/contracts/abi.algo.ts:572", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 63 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 30, + "source": "tests/contracts/abi.algo.ts:573", + "pc": [ + 64, + 65, + 66, + 67, + 68, + 69 + ] + }, + { + "teal": 33, + "source": "tests/contracts/abi.algo.ts:573", + "pc": [ + 70, + 71, + 72 + ] + }, + { + "teal": 34, + "source": "tests/contracts/abi.algo.ts:573", + "pc": [ + 73 + ] + }, + { + "teal": 35, + "source": "tests/contracts/abi.algo.ts:573", + "pc": [ + 74 + ] + }, + { + "teal": 36, + "source": "tests/contracts/abi.algo.ts:573", + "pc": [ + 75, + 76 + ] + }, + { + "teal": 37, + "source": "tests/contracts/abi.algo.ts:573", + "pc": [ + 77 + ] + }, + { + "teal": 41, + "source": "tests/contracts/abi.algo.ts:573", + "pc": [ + 78, + 79, + 80 + ] + }, + { + "teal": 44, + "source": "tests/contracts/abi.algo.ts:573", + "pc": [ + 81, + 82 + ] + }, + { + "teal": 48, + "source": "tests/contracts/abi.algo.ts:574", + "pc": [ + 83, + 84 + ] + }, + { + "teal": 49, + "source": "tests/contracts/abi.algo.ts:574", + "pc": [ + 85, + 86 + ] + }, + { + "teal": 50, + "source": "tests/contracts/abi.algo.ts:574", + "pc": [ + 87, + 88, + 89, + 90 + ] + }, + { + "teal": 51, + "source": "tests/contracts/abi.algo.ts:574", + "pc": [ + 91, + 92, + 93, + 94, + 95, + 96 + ] + }, + { + "teal": 52, + "source": "tests/contracts/abi.algo.ts:574", + "pc": [ + 97, + 98, + 99 + ] + }, + { + "teal": 53, + "source": "tests/contracts/abi.algo.ts:574", + "pc": [ + 100, + 101, + 102, + 103, + 104, + 105 + ] + }, + { + "teal": 54, + "source": "tests/contracts/abi.algo.ts:574", + "pc": [ + 106, + 107, + 108 + ] + }, + { + "teal": 55, + "source": "tests/contracts/abi.algo.ts:574", + "pc": [ + 109, + 110, + 111, + 112, + 113, + 114 + ] + }, + { + "teal": 56, + "source": "tests/contracts/abi.algo.ts:574", + "pc": [ + 115, + 116, + 117 + ] + }, + { + "teal": 57, + "source": "tests/contracts/abi.algo.ts:574", + "pc": [ + 118 + ] + }, + { + "teal": 58, + "source": "tests/contracts/abi.algo.ts:574", + "pc": [ + 119 + ] + }, + { + "teal": 59, + "source": "tests/contracts/abi.algo.ts:574", + "pc": [ + 120, + 121 + ] + }, + { + "teal": 63, + "source": "tests/contracts/abi.algo.ts:576", + "pc": [ + 122, + 123 + ] + }, + { + "teal": 64, + "source": "tests/contracts/abi.algo.ts:576", + "pc": [ + 124, + 125 + ] + }, + { + "teal": 65, + "source": "tests/contracts/abi.algo.ts:576", + "pc": [ + 126, + 127 + ] + }, + { + "teal": 66, + "source": "tests/contracts/abi.algo.ts:576", + "pc": [ + 128 + ] + }, + { + "teal": 67, + "source": "tests/contracts/abi.algo.ts:576", + "pc": [ + 129, + 130 + ] + }, + { + "teal": 68, + "source": "tests/contracts/abi.algo.ts:576", + "pc": [ + 131, + 132 + ] + }, + { + "teal": 69, + "source": "tests/contracts/abi.algo.ts:576", + "pc": [ + 133, + 134 + ] + }, + { + "teal": 70, + "source": "tests/contracts/abi.algo.ts:576", + "pc": [ + 135, + 136 + ] + }, + { + "teal": 71, + "source": "tests/contracts/abi.algo.ts:576", + "pc": [ + 137 + ] + }, + { + "teal": 72, + "source": "tests/contracts/abi.algo.ts:576", + "pc": [ + 138 + ] + }, + { + "teal": 73, + "source": "tests/contracts/abi.algo.ts:576", + "pc": [ + 139, + 140 + ] + }, + { + "teal": 74, + "source": "tests/contracts/abi.algo.ts:576", + "pc": [ + 141 + ] + }, + { + "teal": 75, + "source": "tests/contracts/abi.algo.ts:576", + "pc": [ + 142, + 143 + ] + }, + { + "teal": 76, + "source": "tests/contracts/abi.algo.ts:576", + "pc": [ + 144 + ] + }, + { + "teal": 77, + "source": "tests/contracts/abi.algo.ts:576", + "pc": [ + 145 + ] + }, + { + "teal": 78, + "source": "tests/contracts/abi.algo.ts:576", + "pc": [ + 146, + 147 + ] + }, + { + "teal": 79, + "source": "tests/contracts/abi.algo.ts:576", + "pc": [ + 148 + ] + }, + { + "teal": 80, + "source": "tests/contracts/abi.algo.ts:576", + "pc": [ + 149, + 150 + ] + }, + { + "teal": 81, + "source": "tests/contracts/abi.algo.ts:576", + "pc": [ + 151 + ] + }, + { + "teal": 82, + "source": "tests/contracts/abi.algo.ts:576", + "pc": [ + 152, + 153 + ] + }, + { + "teal": 83, + "source": "tests/contracts/abi.algo.ts:576", + "pc": [ + 154, + 155 + ] + }, + { + "teal": 84, + "source": "tests/contracts/abi.algo.ts:576", + "pc": [ + 156, + 157 + ] + }, + { + "teal": 85, + "source": "tests/contracts/abi.algo.ts:576", + "pc": [ + 158, + 159 + ] + }, + { + "teal": 86, + "source": "tests/contracts/abi.algo.ts:576", + "pc": [ + 160 + ] + }, + { + "teal": 87, + "source": "tests/contracts/abi.algo.ts:576", + "pc": [ + 161, + 162, + 163, + 164, + 165, + 166, + 167, + 168 + ] + }, + { + "teal": 88, + "source": "tests/contracts/abi.algo.ts:576", + "pc": [ + 169 + ] + }, + { + "teal": 89, + "source": "tests/contracts/abi.algo.ts:576", + "pc": [ + 170, + 171 + ] + }, + { + "teal": 90, + "source": "tests/contracts/abi.algo.ts:576", + "pc": [ + 172, + 173 + ] + }, + { + "teal": 91, + "source": "tests/contracts/abi.algo.ts:576", + "pc": [ + 174, + 175 + ] + }, + { + "teal": 92, + "source": "tests/contracts/abi.algo.ts:576", + "pc": [ + 176, + 177 + ] + }, + { + "teal": 93, + "source": "tests/contracts/abi.algo.ts:576", + "pc": [ + 178 + ] + }, + { + "teal": 94, + "source": "tests/contracts/abi.algo.ts:576", + "pc": [ + 179, + 180 + ] + }, + { + "teal": 95, + "source": "tests/contracts/abi.algo.ts:576", + "pc": [ + 181 + ] + }, + { + "teal": 96, + "source": "tests/contracts/abi.algo.ts:576", + "pc": [ + 182 + ] + }, + { + "teal": 97, + "source": "tests/contracts/abi.algo.ts:576", + "pc": [ + 183 + ] + }, + { + "teal": 98, + "source": "tests/contracts/abi.algo.ts:576", + "pc": [ + 184 + ] + }, + { + "teal": 99, + "source": "tests/contracts/abi.algo.ts:576", + "pc": [ + 185, + 186 + ] + }, + { + "teal": 100, + "source": "tests/contracts/abi.algo.ts:576", + "pc": [ + 187, + 188, + 189 + ] + }, + { + "teal": 101, + "source": "tests/contracts/abi.algo.ts:576", + "pc": [ + 190, + 191 + ] + }, + { + "teal": 102, + "source": "tests/contracts/abi.algo.ts:576", + "pc": [ + 192, + 193 + ] + }, + { + "teal": 103, + "source": "tests/contracts/abi.algo.ts:576", + "pc": [ + 194, + 195 + ] + }, + { + "teal": 104, + "source": "tests/contracts/abi.algo.ts:576", + "pc": [ + 196 + ] + }, + { + "teal": 105, + "source": "tests/contracts/abi.algo.ts:576", + "pc": [ + 197, + 198, + 199 + ] + }, + { + "teal": 106, + "source": "tests/contracts/abi.algo.ts:576", + "pc": [ + 200, + 201 + ] + }, + { + "teal": 107, + "source": "tests/contracts/abi.algo.ts:576", + "pc": [ + 202, + 203 + ] + }, + { + "teal": 108, + "source": "tests/contracts/abi.algo.ts:576", + "pc": [ + 204, + 205 + ] + }, + { + "teal": 109, + "source": "tests/contracts/abi.algo.ts:576", + "pc": [ + 206 + ] + }, + { + "teal": 110, + "source": "tests/contracts/abi.algo.ts:576", + "pc": [ + 207, + 208, + 209 + ] + }, + { + "teal": 111, + "source": "tests/contracts/abi.algo.ts:576", + "pc": [ + 210, + 211 + ] + }, + { + "teal": 112, + "source": "tests/contracts/abi.algo.ts:576", + "pc": [ + 212, + 213 + ] + }, + { + "teal": 116, + "source": "tests/contracts/abi.algo.ts:577", + "pc": [ + 214, + 215 + ] + }, + { + "teal": 117, + "source": "tests/contracts/abi.algo.ts:577", + "pc": [ + 216, + 217 + ] + }, + { + "teal": 118, + "source": "tests/contracts/abi.algo.ts:577", + "pc": [ + 218, + 219 + ] + }, + { + "teal": 119, + "source": "tests/contracts/abi.algo.ts:577", + "pc": [ + 220 + ] + }, + { + "teal": 120, + "source": "tests/contracts/abi.algo.ts:577", + "pc": [ + 221, + 222 + ] + }, + { + "teal": 121, + "source": "tests/contracts/abi.algo.ts:577", + "pc": [ + 223, + 224 + ] + }, + { + "teal": 122, + "source": "tests/contracts/abi.algo.ts:577", + "pc": [ + 225, + 226 + ] + }, + { + "teal": 123, + "source": "tests/contracts/abi.algo.ts:577", + "pc": [ + 227, + 228 + ] + }, + { + "teal": 124, + "source": "tests/contracts/abi.algo.ts:577", + "pc": [ + 229 + ] + }, + { + "teal": 125, + "source": "tests/contracts/abi.algo.ts:577", + "pc": [ + 230 + ] + }, + { + "teal": 126, + "source": "tests/contracts/abi.algo.ts:577", + "pc": [ + 231, + 232 + ] + }, + { + "teal": 127, + "source": "tests/contracts/abi.algo.ts:577", + "pc": [ + 233 + ] + }, + { + "teal": 128, + "source": "tests/contracts/abi.algo.ts:577", + "pc": [ + 234, + 235 + ] + }, + { + "teal": 129, + "source": "tests/contracts/abi.algo.ts:577", + "pc": [ + 236 + ] + }, + { + "teal": 130, + "source": "tests/contracts/abi.algo.ts:577", + "pc": [ + 237 + ] + }, + { + "teal": 131, + "source": "tests/contracts/abi.algo.ts:577", + "pc": [ + 238, + 239 + ] + }, + { + "teal": 132, + "source": "tests/contracts/abi.algo.ts:577", + "pc": [ + 240 + ] + }, + { + "teal": 133, + "source": "tests/contracts/abi.algo.ts:577", + "pc": [ + 241, + 242 + ] + }, + { + "teal": 134, + "source": "tests/contracts/abi.algo.ts:577", + "pc": [ + 243 + ] + }, + { + "teal": 135, + "source": "tests/contracts/abi.algo.ts:577", + "pc": [ + 244, + 245 + ] + }, + { + "teal": 136, + "source": "tests/contracts/abi.algo.ts:577", + "pc": [ + 246, + 247 + ] + }, + { + "teal": 137, + "source": "tests/contracts/abi.algo.ts:577", + "pc": [ + 248, + 249 + ] + }, + { + "teal": 138, + "source": "tests/contracts/abi.algo.ts:577", + "pc": [ + 250, + 251 + ] + }, + { + "teal": 139, + "source": "tests/contracts/abi.algo.ts:577", + "pc": [ + 252 + ] + }, + { + "teal": 140, + "source": "tests/contracts/abi.algo.ts:577", + "pc": [ + 253, + 254, + 255, + 256, + 257, + 258, + 259, + 260 + ] + }, + { + "teal": 141, + "source": "tests/contracts/abi.algo.ts:577", + "pc": [ + 261 + ] + }, + { + "teal": 142, + "source": "tests/contracts/abi.algo.ts:577", + "pc": [ + 262, + 263 + ] + }, + { + "teal": 143, + "source": "tests/contracts/abi.algo.ts:577", + "pc": [ + 264, + 265 + ] + }, + { + "teal": 144, + "source": "tests/contracts/abi.algo.ts:577", + "pc": [ + 266, + 267 + ] + }, + { + "teal": 145, + "source": "tests/contracts/abi.algo.ts:577", + "pc": [ + 268, + 269 + ] + }, + { + "teal": 146, + "source": "tests/contracts/abi.algo.ts:577", + "pc": [ + 270 + ] + }, + { + "teal": 147, + "source": "tests/contracts/abi.algo.ts:577", + "pc": [ + 271, + 272 + ] + }, + { + "teal": 148, + "source": "tests/contracts/abi.algo.ts:577", + "pc": [ + 273 + ] + }, + { + "teal": 149, + "source": "tests/contracts/abi.algo.ts:577", + "pc": [ + 274 + ] + }, + { + "teal": 150, + "source": "tests/contracts/abi.algo.ts:577", + "pc": [ + 275 + ] + }, + { + "teal": 151, + "source": "tests/contracts/abi.algo.ts:577", + "pc": [ + 276 + ] + }, + { + "teal": 152, + "source": "tests/contracts/abi.algo.ts:577", + "pc": [ + 277, + 278 + ] + }, + { + "teal": 153, + "source": "tests/contracts/abi.algo.ts:577", + "pc": [ + 279, + 280, + 281 + ] + }, + { + "teal": 154, + "source": "tests/contracts/abi.algo.ts:577", + "pc": [ + 282, + 283 + ] + }, + { + "teal": 155, + "source": "tests/contracts/abi.algo.ts:577", + "pc": [ + 284, + 285 + ] + }, + { + "teal": 156, + "source": "tests/contracts/abi.algo.ts:577", + "pc": [ + 286, + 287 + ] + }, + { + "teal": 157, + "source": "tests/contracts/abi.algo.ts:577", + "pc": [ + 288 + ] + }, + { + "teal": 158, + "source": "tests/contracts/abi.algo.ts:577", + "pc": [ + 289, + 290, + 291 + ] + }, + { + "teal": 159, + "source": "tests/contracts/abi.algo.ts:577", + "pc": [ + 292, + 293 + ] + }, + { + "teal": 160, + "source": "tests/contracts/abi.algo.ts:577", + "pc": [ + 294, + 295 + ] + }, + { + "teal": 164, + "source": "tests/contracts/abi.algo.ts:578", + "pc": [ + 296, + 297 + ] + }, + { + "teal": 165, + "source": "tests/contracts/abi.algo.ts:578", + "pc": [ + 298, + 299 + ] + }, + { + "teal": 166, + "source": "tests/contracts/abi.algo.ts:578", + "pc": [ + 300, + 301 + ] + }, + { + "teal": 167, + "source": "tests/contracts/abi.algo.ts:578", + "pc": [ + 302 + ] + }, + { + "teal": 168, + "source": "tests/contracts/abi.algo.ts:578", + "pc": [ + 303, + 304 + ] + }, + { + "teal": 169, + "source": "tests/contracts/abi.algo.ts:578", + "pc": [ + 305, + 306 + ] + }, + { + "teal": 170, + "source": "tests/contracts/abi.algo.ts:578", + "pc": [ + 307, + 308 + ] + }, + { + "teal": 171, + "source": "tests/contracts/abi.algo.ts:578", + "pc": [ + 309, + 310 + ] + }, + { + "teal": 172, + "source": "tests/contracts/abi.algo.ts:578", + "pc": [ + 311 + ] + }, + { + "teal": 173, + "source": "tests/contracts/abi.algo.ts:578", + "pc": [ + 312 + ] + }, + { + "teal": 174, + "source": "tests/contracts/abi.algo.ts:578", + "pc": [ + 313, + 314 + ] + }, + { + "teal": 175, + "source": "tests/contracts/abi.algo.ts:578", + "pc": [ + 315 + ] + }, + { + "teal": 176, + "source": "tests/contracts/abi.algo.ts:578", + "pc": [ + 316, + 317 + ] + }, + { + "teal": 177, + "source": "tests/contracts/abi.algo.ts:578", + "pc": [ + 318 + ] + }, + { + "teal": 178, + "source": "tests/contracts/abi.algo.ts:578", + "pc": [ + 319 + ] + }, + { + "teal": 179, + "source": "tests/contracts/abi.algo.ts:578", + "pc": [ + 320, + 321 + ] + }, + { + "teal": 180, + "source": "tests/contracts/abi.algo.ts:578", + "pc": [ + 322 + ] + }, + { + "teal": 181, + "source": "tests/contracts/abi.algo.ts:578", + "pc": [ + 323, + 324 + ] + }, + { + "teal": 182, + "source": "tests/contracts/abi.algo.ts:578", + "pc": [ + 325 + ] + }, + { + "teal": 183, + "source": "tests/contracts/abi.algo.ts:578", + "pc": [ + 326, + 327 + ] + }, + { + "teal": 184, + "source": "tests/contracts/abi.algo.ts:578", + "pc": [ + 328, + 329 + ] + }, + { + "teal": 185, + "source": "tests/contracts/abi.algo.ts:578", + "pc": [ + 330, + 331 + ] + }, + { + "teal": 186, + "source": "tests/contracts/abi.algo.ts:578", + "pc": [ + 332, + 333 + ] + }, + { + "teal": 187, + "source": "tests/contracts/abi.algo.ts:578", + "pc": [ + 334 + ] + }, + { + "teal": 188, + "source": "tests/contracts/abi.algo.ts:578", + "pc": [ + 335, + 336, + 337, + 338, + 339, + 340, + 341, + 342 + ] + }, + { + "teal": 189, + "source": "tests/contracts/abi.algo.ts:578", + "pc": [ + 343 + ] + }, + { + "teal": 190, + "source": "tests/contracts/abi.algo.ts:578", + "pc": [ + 344, + 345 + ] + }, + { + "teal": 191, + "source": "tests/contracts/abi.algo.ts:578", + "pc": [ + 346, + 347 + ] + }, + { + "teal": 192, + "source": "tests/contracts/abi.algo.ts:578", + "pc": [ + 348, + 349 + ] + }, + { + "teal": 193, + "source": "tests/contracts/abi.algo.ts:578", + "pc": [ + 350, + 351 + ] + }, + { + "teal": 194, + "source": "tests/contracts/abi.algo.ts:578", + "pc": [ + 352 + ] + }, + { + "teal": 195, + "source": "tests/contracts/abi.algo.ts:578", + "pc": [ + 353, + 354 + ] + }, + { + "teal": 196, + "source": "tests/contracts/abi.algo.ts:578", + "pc": [ + 355 + ] + }, + { + "teal": 197, + "source": "tests/contracts/abi.algo.ts:578", + "pc": [ + 356 + ] + }, + { + "teal": 198, + "source": "tests/contracts/abi.algo.ts:578", + "pc": [ + 357 + ] + }, + { + "teal": 199, + "source": "tests/contracts/abi.algo.ts:578", + "pc": [ + 358 + ] + }, + { + "teal": 200, + "source": "tests/contracts/abi.algo.ts:578", + "pc": [ + 359, + 360 + ] + }, + { + "teal": 201, + "source": "tests/contracts/abi.algo.ts:578", + "pc": [ + 361, + 362, + 363 + ] + }, + { + "teal": 202, + "source": "tests/contracts/abi.algo.ts:578", + "pc": [ + 364, + 365 + ] + }, + { + "teal": 203, + "source": "tests/contracts/abi.algo.ts:578", + "pc": [ + 366, + 367 + ] + }, + { + "teal": 207, + "source": "tests/contracts/abi.algo.ts:580", + "pc": [ + 368, + 369 + ] + }, + { + "teal": 210, + "source": "tests/contracts/abi.algo.ts:573", + "pc": [ + 370, + 371 + ] + }, + { + "teal": 211, + "source": "tests/contracts/abi.algo.ts:573", + "pc": [ + 372 + ] + }, + { + "teal": 214, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 373, + 374 + ] + }, + { + "teal": 215, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 375 + ] + }, + { + "teal": 218, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 376, + 377, + 378, + 379, + 380, + 381 + ] + }, + { + "teal": 219, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 382, + 383, + 384 + ] + }, + { + "teal": 220, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 385, + 386, + 387, + 388 + ] }, { + "teal": 223, + "source": "tests/contracts/abi.algo.ts:572", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 389 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] }, { + "teal": 226, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 390, + 391, + 392, + 393, + 394, + 395 + ] + }, + { + "teal": 227, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 396, + 397, + 398 + ] + }, + { + "teal": 228, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 399, + 400, + 401, + 402 + ] + }, + { + "teal": 231, + "source": "tests/contracts/abi.algo.ts:572", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 403 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] + }, + { + "teal": 234, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 404, + 405, + 406 + ] + }, + { + "teal": 235, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 407, + 408 + ] + }, + { + "teal": 236, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 409, + 410 + ] + }, + { + "teal": 237, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 411 + ] + }, + { + "teal": 238, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 412, + 413 + ] + }, + { + "teal": 239, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 414, + 415 + ] + }, + { + "teal": 240, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 416 + ] + }, + { + "teal": 241, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 417 + ] + }, + { + "teal": 242, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 418, + 419 + ] + }, + { + "teal": 243, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 420 + ] + }, + { + "teal": 244, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 421 + ] + }, + { + "teal": 245, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 422 + ] + }, + { + "teal": 246, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 423, + 424, + 425 + ] + }, + { + "teal": 247, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 426, + 427 + ] + }, + { + "teal": 248, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 428, + 429 + ] + }, + { + "teal": 249, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 430 + ] + }, + { + "teal": 250, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 431 + ] + }, + { + "teal": 251, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 432, + 433 + ] + }, + { + "teal": 252, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 434, + 435 + ] + }, + { + "teal": 253, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 436, + 437 + ] + }, + { + "teal": 254, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 438, + 439 + ] + }, + { + "teal": 255, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 440 + ] + }, + { + "teal": 258, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 441, + 442, + 443 + ] + }, + { + "teal": 259, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 444, + 445 + ] + }, + { + "teal": 260, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 446, + 447 + ] + }, + { + "teal": 261, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 448, + 449 + ] + }, + { + "teal": 262, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 450 + ] + }, + { + "teal": 263, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 451, + 452 + ] + }, + { + "teal": 264, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 453, + 454, + 455 + ] + }, + { + "teal": 265, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 456 + ] + }, + { + "teal": 266, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 457, + 458, + 459 + ] + }, + { + "teal": 269, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 460 + ] + }, + { + "teal": 270, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 461 + ] + }, + { + "teal": 273, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 462 + ] + }, + { + "teal": 274, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 463, + 464, + 465 + ] + }, + { + "teal": 275, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 466, + 467 + ] + }, + { + "teal": 276, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 468 + ] + }, + { + "teal": 277, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 469, + 470 + ] + }, + { + "teal": 278, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 471 + ] + }, + { + "teal": 279, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 472 + ] + }, + { + "teal": 280, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 473, + 474 + ] + }, + { + "teal": 281, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 475 + ] + }, + { + "teal": 284, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 476, + 477 + ] + }, + { + "teal": 285, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 478 + ] + }, + { + "teal": 286, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 479, + 480 + ] + }, + { + "teal": 287, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 481 + ] + }, + { + "teal": 288, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 482, + 483, + 484 + ] + }, + { + "teal": 289, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 485, + 486 + ] + }, + { + "teal": 290, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 487 + ] + }, + { + "teal": 291, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 488, + 489 + ] + }, + { + "teal": 292, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 490, + 491 + ] + }, + { + "teal": 293, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 492, + 493 + ] + }, + { + "teal": 294, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 494, + 495, + 496 + ] + }, + { + "teal": 297, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 497, + 498 + ] + }, + { + "teal": 298, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 499, + 500 + ] + }, + { + "teal": 299, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 501 + ] + }, + { + "teal": 300, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 502, + 503 + ] + }, + { + "teal": 301, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 504, + 505 + ] + }, + { + "teal": 304, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 506 + ] + }, + { + "teal": 305, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 507, + 508 + ] + }, + { + "teal": 306, + "source": "tests/contracts/abi.algo.ts:572", + "pc": [ + 509 + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/AD.arc56_draft.json b/tests/contracts/artifacts/AD.arc56_draft.json index 6c0b570eb..9d832f488 100644 --- a/tests/contracts/artifacts/AD.arc56_draft.json +++ b/tests/contracts/artifacts/AD.arc56_draft.json @@ -101,22 +101,475 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/inheritance.algo.ts:44", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/inheritance.algo.ts:44", + "pc": [ + 1, + 2, + 3, + 4, + 5, + 6 + ] + }, + { + "teal": 14, + "source": "tests/contracts/inheritance.algo.ts:44", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 15, + "source": "tests/contracts/inheritance.algo.ts:44", + "pc": [ + 9 + ] + }, + { + "teal": 16, + "source": "tests/contracts/inheritance.algo.ts:44", + "pc": [ + 10, + 11 + ] + }, + { + "teal": 17, + "source": "tests/contracts/inheritance.algo.ts:44", + "pc": [ + 12 + ] + }, + { + "teal": 18, + "source": "tests/contracts/inheritance.algo.ts:44", + "pc": [ + 13, + 14 + ] + }, + { + "teal": 19, + "source": "tests/contracts/inheritance.algo.ts:44", + "pc": [ + 15 + ] + }, + { + "teal": 20, + "source": "tests/contracts/inheritance.algo.ts:44", + "pc": [ + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38, + 39, + 40, + 41 + ] + }, + { + "teal": 24, + "source": "tests/contracts/inheritance.algo.ts:44", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 42 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/inheritance.algo.ts:15", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 30, + "source": "tests/contracts/inheritance.algo.ts:15", + "pc": [ + 46, + 47 + ] + }, + { + "teal": 31, + "source": "tests/contracts/inheritance.algo.ts:15", + "pc": [ + 48 + ] + }, + { + "teal": 35, + "source": "tests/contracts/inheritance.algo.ts:15", + "pc": [ + 49, + 50, + 51 + ] + }, + { + "teal": 39, + "source": "tests/contracts/inheritance.algo.ts:16", + "pc": [ + 52, + 53, + 54 + ] + }, + { + "teal": 40, + "source": "tests/contracts/inheritance.algo.ts:16", + "pc": [ + 55, + 56, + 57 + ] + }, + { + "teal": 41, + "source": "tests/contracts/inheritance.algo.ts:16", + "pc": [ + 58 + ] + }, + { + "teal": 42, + "source": "tests/contracts/inheritance.algo.ts:15", + "pc": [ + 59 + ] + }, + { + "teal": 47, + "source": "tests/contracts/inheritance.algo.ts:39", + "pc": [ + 60, + 61, + 62 + ] + }, + { + "teal": 48, + "source": "tests/contracts/inheritance.algo.ts:39", + "pc": [ + 63, + 64 + ] + }, + { + "teal": 49, + "source": "tests/contracts/inheritance.algo.ts:39", + "pc": [ + 65 + ] + }, + { + "teal": 53, + "source": "tests/contracts/inheritance.algo.ts:39", + "pc": [ + 66, + 67, + 68 + ] + }, + { + "teal": 57, + "source": "tests/contracts/inheritance.algo.ts:40", + "pc": [ + 69, + 70, + 71 + ] + }, + { + "teal": 58, + "source": "tests/contracts/inheritance.algo.ts:40", + "pc": [ + 72, + 73 + ] + }, + { + "teal": 59, + "source": "tests/contracts/inheritance.algo.ts:40", + "pc": [ + 74 + ] + }, + { + "teal": 60, + "source": "tests/contracts/inheritance.algo.ts:39", + "pc": [ + 75 + ] }, { + "teal": 65, + "source": "tests/contracts/inheritance.algo.ts:45", + "pc": [ + 76, + 77, + 78 + ] + }, + { + "teal": 66, + "source": "tests/contracts/inheritance.algo.ts:45", + "pc": [ + 79, + 80 + ] + }, + { + "teal": 67, + "source": "tests/contracts/inheritance.algo.ts:45", + "pc": [ + 81 + ] + }, + { + "teal": 71, + "source": "tests/contracts/inheritance.algo.ts:45", + "pc": [ + 82, + 83, + 84 + ] + }, + { + "teal": 75, + "source": "tests/contracts/inheritance.algo.ts:46", + "pc": [ + 85, + 86, + 87 + ] + }, + { + "teal": 76, + "source": "tests/contracts/inheritance.algo.ts:46", + "pc": [ + 88 + ] + }, + { + "teal": 77, + "source": "tests/contracts/inheritance.algo.ts:46", + "pc": [ + 89, + 90, + 91 + ] + }, + { + "teal": 78, + "source": "tests/contracts/inheritance.algo.ts:46", + "pc": [ + 92 + ] + }, + { + "teal": 79, + "source": "tests/contracts/inheritance.algo.ts:46", + "pc": [ + 93 + ] + }, + { + "teal": 83, + "source": "tests/contracts/inheritance.algo.ts:47", + "pc": [ + 94, + 95, + 96 + ] + }, + { + "teal": 84, + "source": "tests/contracts/inheritance.algo.ts:47", + "pc": [ + 97 + ] + }, + { + "teal": 85, + "source": "tests/contracts/inheritance.algo.ts:47", + "pc": [ + 98, + 99 + ] + }, + { + "teal": 86, + "source": "tests/contracts/inheritance.algo.ts:47", + "pc": [ + 100 + ] + }, + { + "teal": 87, + "source": "tests/contracts/inheritance.algo.ts:47", + "pc": [ + 101 + ] + }, + { + "teal": 88, + "source": "tests/contracts/inheritance.algo.ts:45", + "pc": [ + 102 + ] + }, + { + "teal": 91, + "source": "tests/contracts/inheritance.algo.ts:44", + "pc": [ + 103, + 104 + ] + }, + { + "teal": 92, + "source": "tests/contracts/inheritance.algo.ts:44", + "pc": [ + 105 + ] + }, + { + "teal": 95, + "source": "tests/contracts/inheritance.algo.ts:44", + "pc": [ + 106, + 107, + 108, + 109, + 110, + 111 + ] + }, + { + "teal": 96, + "source": "tests/contracts/inheritance.algo.ts:44", + "pc": [ + 112, + 113, + 114 + ] + }, + { + "teal": 97, + "source": "tests/contracts/inheritance.algo.ts:44", + "pc": [ + 115, + 116, + 117, + 118 + ] + }, + { + "teal": 100, + "source": "tests/contracts/inheritance.algo.ts:44", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 119 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 103, + "source": "tests/contracts/inheritance.algo.ts:44", + "pc": [ + 120, + 121, + 122, + 123, + 124, + 125 + ] + }, + { + "teal": 104, + "source": "tests/contracts/inheritance.algo.ts:44", + "pc": [ + 126, + 127, + 128, + 129, + 130, + 131 + ] + }, + { + "teal": 105, + "source": "tests/contracts/inheritance.algo.ts:44", + "pc": [ + 132, + 133, + 134, + 135, + 136, + 137 + ] + }, + { + "teal": 106, + "source": "tests/contracts/inheritance.algo.ts:44", + "pc": [ + 138, + 139, + 140 + ] + }, + { + "teal": 107, + "source": "tests/contracts/inheritance.algo.ts:44", + "pc": [ + 141, + 142, + 143, + 144, + 145, + 146, + 147, + 148 + ] }, { + "teal": 110, + "source": "tests/contracts/inheritance.algo.ts:44", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 149 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ARC56Test.arc56_draft.json b/tests/contracts/artifacts/ARC56Test.arc56_draft.json index 776ad3e62..6cd956c9a 100644 --- a/tests/contracts/artifacts/ARC56Test.arc56_draft.json +++ b/tests/contracts/artifacts/ARC56Test.arc56_draft.json @@ -221,52 +221,1120 @@ "approval": { "sourceInfo": [ { + "teal": 11, + "source": "tests/contracts/arc56.algo.ts:7", + "pc": [ + 1 + ] + }, + { + "teal": 18, + "source": "tests/contracts/arc56.algo.ts:7", + "pc": [ + 2, + 3 + ] + }, + { + "teal": 19, + "source": "tests/contracts/arc56.algo.ts:7", + "pc": [ + 4 + ] + }, + { + "teal": 20, + "source": "tests/contracts/arc56.algo.ts:7", + "pc": [ + 5, + 6 + ] + }, + { + "teal": 21, + "source": "tests/contracts/arc56.algo.ts:7", + "pc": [ + 7 + ] + }, + { + "teal": 22, + "source": "tests/contracts/arc56.algo.ts:7", + "pc": [ + 8, + 9 + ] + }, + { + "teal": 23, + "source": "tests/contracts/arc56.algo.ts:7", + "pc": [ + 10 + ] + }, + { + "teal": 24, + "source": "tests/contracts/arc56.algo.ts:7", + "pc": [ + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36 + ] + }, + { + "teal": 28, + "source": "tests/contracts/arc56.algo.ts:7", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 37 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 33, + "source": "tests/contracts/inheritance-external.algo.ts:12", + "pc": [ + 38, + 39, + 40, + 41, + 42, + 43 + ] + }, + { + "teal": 36, + "source": "tests/contracts/inheritance-external.algo.ts:14", + "pc": [ + 44, + 45, + 46 + ] + }, + { + "teal": 37, + "source": "tests/contracts/inheritance-external.algo.ts:14", + "pc": [ + 47 + ] }, { + "teal": 38, + "source": "tests/contracts/inheritance-external.algo.ts:14", + "pc": [ + 48 + ] + }, + { + "teal": 39, + "source": "tests/contracts/inheritance-external.algo.ts:14", + "pc": [ + 49, + 50 + ] + }, + { + "teal": 40, + "source": "tests/contracts/inheritance-external.algo.ts:14", + "pc": [ + 51 + ] + }, + { + "teal": 43, + "source": "tests/contracts/inheritance-external.algo.ts:14", + "errorMessage": "argument 0 (input) for customStructMethod must be a (uint64)", "pc": [ 52 - ], - "errorMessage": "argument 0 (input) for customStructMethod must be a (uint64)" + ] }, { + "teal": 46, + "source": "tests/contracts/inheritance-external.algo.ts:12", + "pc": [ + 53, + 54, + 55 + ] + }, + { + "teal": 47, + "source": "tests/contracts/inheritance-external.algo.ts:12", + "pc": [ + 56 + ] + }, + { + "teal": 48, + "source": "tests/contracts/inheritance-external.algo.ts:12", + "pc": [ + 57 + ] + }, + { + "teal": 49, + "source": "tests/contracts/inheritance-external.algo.ts:12", + "pc": [ + 58, + 59 + ] + }, + { + "teal": 50, + "source": "tests/contracts/inheritance-external.algo.ts:12", + "pc": [ + 60 + ] + }, + { + "teal": 54, + "source": "tests/contracts/inheritance-external.algo.ts:12", + "pc": [ + 61, + 62, + 63 + ] + }, + { + "teal": 58, + "source": "tests/contracts/inheritance-external.algo.ts:16", + "pc": [ + 64, + 65 + ] + }, + { + "teal": 59, + "source": "tests/contracts/inheritance-external.algo.ts:12", + "pc": [ + 66 + ] + }, + { + "teal": 64, + "source": "tests/contracts/arc56.algo.ts:24", + "pc": [ + 67, + 68, + 69, + 70, + 71, + 72 + ] + }, + { + "teal": 67, + "source": "tests/contracts/arc56.algo.ts:24", + "pc": [ + 73, + 74, + 75 + ] + }, + { + "teal": 68, + "source": "tests/contracts/arc56.algo.ts:24", + "pc": [ + 76 + ] + }, + { + "teal": 69, + "source": "tests/contracts/arc56.algo.ts:24", + "pc": [ + 77 + ] + }, + { + "teal": 70, + "source": "tests/contracts/arc56.algo.ts:24", + "pc": [ + 78, + 79 + ] + }, + { + "teal": 71, + "source": "tests/contracts/arc56.algo.ts:24", + "pc": [ + 80 + ] + }, + { + "teal": 74, + "source": "tests/contracts/arc56.algo.ts:24", + "errorMessage": "argument 0 (inputs) for foo must be a ((uint64,uint64),(uint64,uint64))", "pc": [ 81 - ], - "errorMessage": "argument 0 (inputs) for foo must be a ((uint64,uint64),(uint64,uint64))" + ] + }, + { + "teal": 77, + "source": "tests/contracts/arc56.algo.ts:24", + "pc": [ + 82, + 83, + 84 + ] }, { + "teal": 78, + "source": "tests/contracts/arc56.algo.ts:24", + "pc": [ + 85 + ] + }, + { + "teal": 79, + "source": "tests/contracts/arc56.algo.ts:24", + "pc": [ + 86 + ] + }, + { + "teal": 80, + "source": "tests/contracts/arc56.algo.ts:24", + "pc": [ + 87, + 88 + ] + }, + { + "teal": 81, + "source": "tests/contracts/arc56.algo.ts:24", + "pc": [ + 89 + ] + }, + { + "teal": 85, + "source": "tests/contracts/arc56.algo.ts:24", + "pc": [ + 90, + 91, + 92 + ] + }, + { + "teal": 90, + "source": "tests/contracts/arc56.algo.ts:25", + "pc": [ + 93, + 94 + ] + }, + { + "teal": 91, + "source": "tests/contracts/arc56.algo.ts:25", + "pc": [ + 95, + 96, + 97 + ] + }, + { + "teal": 92, + "source": "tests/contracts/arc56.algo.ts:25", + "pc": [ + 98 + ] + }, + { + "teal": 93, + "source": "tests/contracts/arc56.algo.ts:25", + "pc": [ + 99, + 100 + ] + }, + { + "teal": 94, + "source": "tests/contracts/arc56.algo.ts:25", + "pc": [ + 101, + 102, + 103 + ] + }, + { + "teal": 95, + "source": "tests/contracts/arc56.algo.ts:25", + "pc": [ + 104 + ] + }, + { + "teal": 96, + "source": "tests/contracts/arc56.algo.ts:25", + "pc": [ + 105 + ] + }, + { + "teal": 97, + "source": "tests/contracts/arc56.algo.ts:25", + "pc": [ + 106, + 107, + 108 + ] + }, + { + "teal": 101, + "source": "tests/contracts/arc56.algo.ts:25", + "errorMessage": "subtract.a must be greater than subtract.b", "pc": [ 109 - ], - "errorMessage": "subtract.a must be greater than subtract.b" + ] + }, + { + "teal": 106, + "source": "tests/contracts/arc56.algo.ts:27", + "pc": [ + 110, + 111, + 112, + 113, + 114, + 115, + 116, + 117, + 118, + 119, + 120 + ] + }, + { + "teal": 107, + "source": "tests/contracts/arc56.algo.ts:27", + "pc": [ + 121 + ] + }, + { + "teal": 108, + "source": "tests/contracts/arc56.algo.ts:27", + "pc": [ + 122 + ] + }, + { + "teal": 112, + "source": "tests/contracts/arc56.algo.ts:28", + "pc": [ + 123, + 124, + 125, + 126, + 127, + 128, + 129, + 130 + ] + }, + { + "teal": 113, + "source": "tests/contracts/arc56.algo.ts:28", + "pc": [ + 131, + 132, + 133, + 134, + 135, + 136 + ] }, { + "teal": 114, + "source": "tests/contracts/arc56.algo.ts:28", + "pc": [ + 137 + ] + }, + { + "teal": 121, + "source": "tests/contracts/arc56.algo.ts:31", + "pc": [ + 138, + 139 + ] + }, + { + "teal": 122, + "source": "tests/contracts/arc56.algo.ts:31", + "pc": [ + 140, + 141, + 142 + ] + }, + { + "teal": 123, + "source": "tests/contracts/arc56.algo.ts:31", + "pc": [ + 143 + ] + }, + { + "teal": 124, + "source": "tests/contracts/arc56.algo.ts:31", + "pc": [ + 144, + 145 + ] + }, + { + "teal": 125, + "source": "tests/contracts/arc56.algo.ts:31", + "pc": [ + 146, + 147, + 148 + ] + }, + { + "teal": 126, + "source": "tests/contracts/arc56.algo.ts:31", + "pc": [ + 149 + ] + }, + { + "teal": 127, + "source": "tests/contracts/arc56.algo.ts:31", + "pc": [ + 150 + ] + }, + { + "teal": 128, + "source": "tests/contracts/arc56.algo.ts:31", + "pc": [ + 151 + ] + }, + { + "teal": 129, + "source": "tests/contracts/arc56.algo.ts:32", + "pc": [ + 152, + 153 + ] + }, + { + "teal": 130, + "source": "tests/contracts/arc56.algo.ts:32", + "pc": [ + 154, + 155, + 156 + ] + }, + { + "teal": 131, + "source": "tests/contracts/arc56.algo.ts:32", + "pc": [ + 157 + ] + }, + { + "teal": 132, + "source": "tests/contracts/arc56.algo.ts:32", + "pc": [ + 158, + 159 + ] + }, + { + "teal": 133, + "source": "tests/contracts/arc56.algo.ts:32", + "pc": [ + 160, + 161, + 162 + ] + }, + { + "teal": 134, + "source": "tests/contracts/arc56.algo.ts:32", + "pc": [ + 163 + ] + }, + { + "teal": 135, + "source": "tests/contracts/arc56.algo.ts:32", + "pc": [ + 164 + ] + }, + { + "teal": 136, + "source": "tests/contracts/arc56.algo.ts:32", + "pc": [ + 165 + ] + }, + { + "teal": 137, + "source": "tests/contracts/arc56.algo.ts:32", + "pc": [ + 166 + ] + }, + { + "teal": 138, + "source": "tests/contracts/arc56.algo.ts:24", + "pc": [ + 167 + ] + }, + { + "teal": 143, + "source": "tests/contracts/arc56.algo.ts:36", + "pc": [ + 168, + 169, + 170 + ] + }, + { + "teal": 144, + "source": "tests/contracts/arc56.algo.ts:36", + "pc": [ + 171, + 172 + ] + }, + { + "teal": 145, + "source": "tests/contracts/arc56.algo.ts:36", + "pc": [ + 173 + ] + }, + { + "teal": 149, + "source": "tests/contracts/arc56.algo.ts:36", + "pc": [ + 174, + 175, + 176 + ] + }, + { + "teal": 153, + "source": "tests/contracts/arc56.algo.ts:37", + "pc": [ + 177, + 178 + ] + }, + { + "teal": 154, + "source": "tests/contracts/arc56.algo.ts:37", + "pc": [ + 179, + 180, + 181, + 182, + 183, + 184, + 185, + 186, + 187, + 188 + ] + }, + { + "teal": 155, + "source": "tests/contracts/arc56.algo.ts:37", + "pc": [ + 189 + ] + }, + { + "teal": 156, + "source": "tests/contracts/arc56.algo.ts:37", + "pc": [ + 190 + ] + }, + { + "teal": 160, + "source": "tests/contracts/arc56.algo.ts:38", + "pc": [ + 191, + 192 + ] + }, + { + "teal": 161, + "source": "tests/contracts/arc56.algo.ts:38", + "pc": [ + 193, + 194, + 195, + 196, + 197, + 198 + ] + }, + { + "teal": 162, + "source": "tests/contracts/arc56.algo.ts:38", + "pc": [ + 199, + 200, + 201, + 202, + 203, + 204, + 205 + ] + }, + { + "teal": 163, + "source": "tests/contracts/arc56.algo.ts:38", + "pc": [ + 206 + ] + }, + { + "teal": 167, + "source": "tests/contracts/arc56.algo.ts:39", + "pc": [ + 207, + 208, + 209, + 210, + 211, + 212, + 213, + 214 + ] + }, + { + "teal": 168, + "source": "tests/contracts/arc56.algo.ts:39", + "pc": [ + 215 + ] + }, + { + "teal": 169, + "source": "tests/contracts/arc56.algo.ts:39", + "pc": [ + 216 + ] + }, + { + "teal": 170, + "source": "tests/contracts/arc56.algo.ts:39", + "pc": [ + 217 + ] + }, + { + "teal": 171, + "source": "tests/contracts/arc56.algo.ts:39", + "pc": [ + 218, + 219, + 220, + 221, + 222, + 223, + 224 + ] + }, + { + "teal": 172, + "source": "tests/contracts/arc56.algo.ts:39", + "pc": [ + 225 + ] + }, + { + "teal": 176, + "source": "tests/contracts/arc56.algo.ts:40", + "pc": [ + 226, + 227, + 228, + 229, + 230, + 231, + 232, + 233, + 234, + 235, + 236, + 237, + 238, + 239, + 240, + 241, + 242, + 243, + 244, + 245, + 246, + 247, + 248, + 249, + 250, + 251, + 252, + 253, + 254, + 255, + 256, + 257, + 258, + 259, + 260 + ] + }, + { + "teal": 177, + "source": "tests/contracts/arc56.algo.ts:40", + "pc": [ + 261, + 262, + 263, + 264, + 265, + 266, + 267, + 268, + 269, + 270, + 271, + 272, + 273, + 274, + 275, + 276, + 277, + 278 + ] + }, + { + "teal": 178, + "source": "tests/contracts/arc56.algo.ts:40", + "pc": [ + 279 + ] + }, + { + "teal": 179, + "source": "tests/contracts/arc56.algo.ts:36", + "pc": [ + 280 + ] + }, + { + "teal": 184, + "source": "tests/contracts/arc56.algo.ts:43", + "pc": [ + 281, + 282, + 283, + 284, + 285, + 286 + ] + }, + { + "teal": 187, + "source": "tests/contracts/arc56.algo.ts:43", + "pc": [ + 287, + 288, + 289 + ] + }, + { + "teal": 188, + "source": "tests/contracts/arc56.algo.ts:43", + "pc": [ + 290 + ] + }, + { + "teal": 189, + "source": "tests/contracts/arc56.algo.ts:43", + "pc": [ + 291 + ] + }, + { + "teal": 190, + "source": "tests/contracts/arc56.algo.ts:43", + "pc": [ + 292, + 293 + ] + }, + { + "teal": 191, + "source": "tests/contracts/arc56.algo.ts:43", + "pc": [ + 294 + ] + }, + { + "teal": 194, + "source": "tests/contracts/arc56.algo.ts:43", + "errorMessage": "argument 0 (input) for customType must be a (uint64)", "pc": [ 295 - ], - "errorMessage": "argument 0 (input) for customType must be a (uint64)" + ] + }, + { + "teal": 197, + "source": "tests/contracts/arc56.algo.ts:43", + "pc": [ + 296, + 297, + 298 + ] + }, + { + "teal": 198, + "source": "tests/contracts/arc56.algo.ts:43", + "pc": [ + 299 + ] + }, + { + "teal": 199, + "source": "tests/contracts/arc56.algo.ts:43", + "pc": [ + 300 + ] + }, + { + "teal": 200, + "source": "tests/contracts/arc56.algo.ts:43", + "pc": [ + 301, + 302 + ] + }, + { + "teal": 201, + "source": "tests/contracts/arc56.algo.ts:43", + "pc": [ + 303 + ] + }, + { + "teal": 205, + "source": "tests/contracts/arc56.algo.ts:43", + "pc": [ + 304, + 305, + 306 + ] + }, + { + "teal": 209, + "source": "tests/contracts/arc56.algo.ts:44", + "pc": [ + 307, + 308 + ] + }, + { + "teal": 210, + "source": "tests/contracts/arc56.algo.ts:43", + "pc": [ + 309 + ] + }, + { + "teal": 213, + "source": "tests/contracts/arc56.algo.ts:7", + "pc": [ + 310, + 311 + ] + }, + { + "teal": 214, + "source": "tests/contracts/arc56.algo.ts:7", + "pc": [ + 312 + ] + }, + { + "teal": 217, + "source": "tests/contracts/arc56.algo.ts:7", + "pc": [ + 313, + 314, + 315, + 316, + 317, + 318 + ] + }, + { + "teal": 218, + "source": "tests/contracts/arc56.algo.ts:7", + "pc": [ + 319, + 320, + 321 + ] }, { + "teal": 219, + "source": "tests/contracts/arc56.algo.ts:7", + "pc": [ + 322, + 323, + 324, + 325 + ] + }, + { + "teal": 222, + "source": "tests/contracts/arc56.algo.ts:7", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 326 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 225, + "source": "tests/contracts/arc56.algo.ts:7", + "pc": [ + 327, + 328, + 329, + 330, + 331, + 332 + ] }, { + "teal": 226, + "source": "tests/contracts/arc56.algo.ts:7", + "pc": [ + 333, + 334, + 335, + 336, + 337, + 338 + ] + }, + { + "teal": 227, + "source": "tests/contracts/arc56.algo.ts:7", + "pc": [ + 339, + 340, + 341, + 342, + 343, + 344 + ] + }, + { + "teal": 228, + "source": "tests/contracts/arc56.algo.ts:7", + "pc": [ + 345, + 346, + 347 + ] + }, + { + "teal": 229, + "source": "tests/contracts/arc56.algo.ts:7", + "pc": [ + 348, + 349, + 350, + 351, + 352, + 353, + 354, + 355 + ] + }, + { + "teal": 232, + "source": "tests/contracts/arc56.algo.ts:7", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 356 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] + }, + { + "teal": 235, + "source": "tests/contracts/arc56.algo.ts:7", + "pc": [ + 357, + 358, + 359, + 360, + 361, + 362 + ] + }, + { + "teal": 236, + "source": "tests/contracts/arc56.algo.ts:7", + "pc": [ + 363, + 364, + 365 + ] + }, + { + "teal": 237, + "source": "tests/contracts/arc56.algo.ts:7", + "pc": [ + 366, + 367, + 368, + 369 + ] }, { + "teal": 240, + "source": "tests/contracts/arc56.algo.ts:7", + "errorMessage": "this contract does not implement the given ABI method for call OptIn", "pc": [ 370 - ], - "errorMessage": "this contract does not implement the given ABI method for call OptIn" + ] } ], "pcOffsetMethod": "cblocks" diff --git a/tests/contracts/artifacts/ARC56TestNoTemplateVars.arc56_draft.json b/tests/contracts/artifacts/ARC56TestNoTemplateVars.arc56_draft.json index cf8853571..b5a6eece7 100644 --- a/tests/contracts/artifacts/ARC56TestNoTemplateVars.arc56_draft.json +++ b/tests/contracts/artifacts/ARC56TestNoTemplateVars.arc56_draft.json @@ -51,16 +51,150 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/arc56.algo.ts:48", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/arc56.algo.ts:48", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/arc56.algo.ts:48", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/arc56.algo.ts:48", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/arc56.algo.ts:48", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/arc56.algo.ts:48", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/arc56.algo.ts:48", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/arc56.algo.ts:48", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/arc56.algo.ts:48", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 26, + "source": "tests/contracts/arc56.algo.ts:48", + "pc": [ + 37, + 38 + ] + }, + { + "teal": 27, + "source": "tests/contracts/arc56.algo.ts:48", + "pc": [ + 39 + ] + }, + { + "teal": 30, + "source": "tests/contracts/arc56.algo.ts:48", + "pc": [ + 40, + 41, + 42, + 43, + 44, + 45 + ] + }, + { + "teal": 31, + "source": "tests/contracts/arc56.algo.ts:48", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 32, + "source": "tests/contracts/arc56.algo.ts:48", + "pc": [ + 49, + 50, + 51, + 52 + ] }, { + "teal": 35, + "source": "tests/contracts/arc56.algo.ts:48", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 53 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/AVM11.arc56_draft.json b/tests/contracts/artifacts/AVM11.arc56_draft.json index 82482ec2d..40158515f 100644 --- a/tests/contracts/artifacts/AVM11.arc56_draft.json +++ b/tests/contracts/artifacts/AVM11.arc56_draft.json @@ -114,17 +114,7 @@ }, "sourceInfo": { "approval": { - "sourceInfo": [ - { - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" - }, - { - "errorMessage": "this contract does not implement the given ABI method for create NoOp" - }, - { - "errorMessage": "this contract does not implement the given ABI method for call NoOp" - } - ], + "sourceInfo": [], "pcOffsetMethod": "none" }, "clear": { diff --git a/tests/contracts/artifacts/AccountTest.arc56_draft.json b/tests/contracts/artifacts/AccountTest.arc56_draft.json index 3186d46a0..f345e6539 100644 --- a/tests/contracts/artifacts/AccountTest.arc56_draft.json +++ b/tests/contracts/artifacts/AccountTest.arc56_draft.json @@ -339,118 +339,2303 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/account.algo.ts:4", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/account.algo.ts:4", + "pc": [ + 1, + 2, + 3, + 4 + ] + }, + { + "teal": 14, + "source": "tests/contracts/account.algo.ts:4", + "pc": [ + 5, + 6 + ] + }, + { + "teal": 15, + "source": "tests/contracts/account.algo.ts:4", + "pc": [ + 7 + ] + }, + { + "teal": 16, + "source": "tests/contracts/account.algo.ts:4", + "pc": [ + 8, + 9 + ] + }, + { + "teal": 17, + "source": "tests/contracts/account.algo.ts:4", + "pc": [ + 10 + ] + }, + { + "teal": 18, + "source": "tests/contracts/account.algo.ts:4", + "pc": [ + 11, + 12 + ] + }, + { + "teal": 19, + "source": "tests/contracts/account.algo.ts:4", + "pc": [ + 13 + ] + }, + { + "teal": 20, + "source": "tests/contracts/account.algo.ts:4", + "pc": [ + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38, + 39 + ] + }, + { + "teal": 24, + "source": "tests/contracts/account.algo.ts:4", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 40 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/account.algo.ts:5", + "pc": [ + 41, + 42, + 43 + ] + }, + { + "teal": 30, + "source": "tests/contracts/account.algo.ts:5", + "pc": [ + 44 + ] + }, + { + "teal": 31, + "source": "tests/contracts/account.algo.ts:5", + "pc": [ + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/account.algo.ts:5", + "pc": [ + 46, + 47 + ] + }, + { + "teal": 33, + "source": "tests/contracts/account.algo.ts:5", + "pc": [ + 48 + ] }, { + "teal": 36, + "source": "tests/contracts/account.algo.ts:5", + "errorMessage": "argument 0 (a) for hasAsset must be a address", "pc": [ 49 - ], - "errorMessage": "argument 0 (a) for hasAsset must be a address" + ] + }, + { + "teal": 39, + "source": "tests/contracts/account.algo.ts:5", + "pc": [ + 50, + 51, + 52 + ] + }, + { + "teal": 40, + "source": "tests/contracts/account.algo.ts:5", + "pc": [ + 53, + 54 + ] + }, + { + "teal": 41, + "source": "tests/contracts/account.algo.ts:5", + "pc": [ + 55 + ] + }, + { + "teal": 45, + "source": "tests/contracts/account.algo.ts:5", + "pc": [ + 56, + 57, + 58 + ] + }, + { + "teal": 49, + "source": "tests/contracts/account.algo.ts:6", + "pc": [ + 59, + 60 + ] + }, + { + "teal": 50, + "source": "tests/contracts/account.algo.ts:6", + "pc": [ + 61, + 62 + ] + }, + { + "teal": 51, + "source": "tests/contracts/account.algo.ts:6", + "pc": [ + 63, + 64 + ] + }, + { + "teal": 52, + "source": "tests/contracts/account.algo.ts:6", + "pc": [ + 65 + ] + }, + { + "teal": 53, + "source": "tests/contracts/account.algo.ts:6", + "pc": [ + 66 + ] + }, + { + "teal": 54, + "source": "tests/contracts/account.algo.ts:6", + "pc": [ + 67 + ] + }, + { + "teal": 55, + "source": "tests/contracts/account.algo.ts:5", + "pc": [ + 68 + ] + }, + { + "teal": 60, + "source": "tests/contracts/account.algo.ts:9", + "pc": [ + 69, + 70, + 71 + ] + }, + { + "teal": 61, + "source": "tests/contracts/account.algo.ts:9", + "pc": [ + 72 + ] + }, + { + "teal": 62, + "source": "tests/contracts/account.algo.ts:9", + "pc": [ + 73 + ] + }, + { + "teal": 63, + "source": "tests/contracts/account.algo.ts:9", + "pc": [ + 74, + 75 + ] + }, + { + "teal": 64, + "source": "tests/contracts/account.algo.ts:9", + "pc": [ + 76 + ] }, { + "teal": 67, + "source": "tests/contracts/account.algo.ts:9", + "errorMessage": "argument 0 (a) for assetBalance must be a address", "pc": [ 77 - ], - "errorMessage": "argument 0 (a) for assetBalance must be a address" + ] + }, + { + "teal": 70, + "source": "tests/contracts/account.algo.ts:9", + "pc": [ + 78, + 79, + 80 + ] + }, + { + "teal": 71, + "source": "tests/contracts/account.algo.ts:9", + "pc": [ + 81, + 82 + ] + }, + { + "teal": 72, + "source": "tests/contracts/account.algo.ts:9", + "pc": [ + 83 + ] + }, + { + "teal": 76, + "source": "tests/contracts/account.algo.ts:9", + "pc": [ + 84, + 85, + 86 + ] + }, + { + "teal": 80, + "source": "tests/contracts/account.algo.ts:10", + "pc": [ + 87, + 88 + ] + }, + { + "teal": 81, + "source": "tests/contracts/account.algo.ts:10", + "pc": [ + 89, + 90 + ] + }, + { + "teal": 82, + "source": "tests/contracts/account.algo.ts:10", + "pc": [ + 91, + 92 + ] + }, + { + "teal": 83, + "source": "tests/contracts/account.algo.ts:10", + "pc": [ + 93 + ] + }, + { + "teal": 84, + "source": "tests/contracts/account.algo.ts:10", + "pc": [ + 94 + ] + }, + { + "teal": 85, + "source": "tests/contracts/account.algo.ts:9", + "pc": [ + 95 + ] + }, + { + "teal": 90, + "source": "tests/contracts/account.algo.ts:13", + "pc": [ + 96, + 97, + 98 + ] + }, + { + "teal": 91, + "source": "tests/contracts/account.algo.ts:13", + "pc": [ + 99 + ] + }, + { + "teal": 92, + "source": "tests/contracts/account.algo.ts:13", + "pc": [ + 100 + ] + }, + { + "teal": 93, + "source": "tests/contracts/account.algo.ts:13", + "pc": [ + 101, + 102 + ] }, { + "teal": 94, + "source": "tests/contracts/account.algo.ts:13", + "pc": [ + 103 + ] + }, + { + "teal": 97, + "source": "tests/contracts/account.algo.ts:13", + "errorMessage": "argument 0 (a) for assetFrozen must be a address", "pc": [ 104 - ], - "errorMessage": "argument 0 (a) for assetFrozen must be a address" + ] + }, + { + "teal": 100, + "source": "tests/contracts/account.algo.ts:13", + "pc": [ + 105, + 106, + 107 + ] + }, + { + "teal": 101, + "source": "tests/contracts/account.algo.ts:13", + "pc": [ + 108, + 109 + ] + }, + { + "teal": 102, + "source": "tests/contracts/account.algo.ts:13", + "pc": [ + 110 + ] + }, + { + "teal": 106, + "source": "tests/contracts/account.algo.ts:13", + "pc": [ + 111, + 112, + 113 + ] + }, + { + "teal": 110, + "source": "tests/contracts/account.algo.ts:14", + "pc": [ + 114, + 115 + ] + }, + { + "teal": 111, + "source": "tests/contracts/account.algo.ts:14", + "pc": [ + 116, + 117 + ] + }, + { + "teal": 112, + "source": "tests/contracts/account.algo.ts:14", + "pc": [ + 118, + 119 + ] + }, + { + "teal": 113, + "source": "tests/contracts/account.algo.ts:14", + "pc": [ + 120 + ] + }, + { + "teal": 114, + "source": "tests/contracts/account.algo.ts:14", + "pc": [ + 121 + ] + }, + { + "teal": 115, + "source": "tests/contracts/account.algo.ts:13", + "pc": [ + 122 + ] + }, + { + "teal": 120, + "source": "tests/contracts/account.algo.ts:17", + "pc": [ + 123, + 124, + 125 + ] + }, + { + "teal": 121, + "source": "tests/contracts/account.algo.ts:17", + "pc": [ + 126 + ] + }, + { + "teal": 122, + "source": "tests/contracts/account.algo.ts:17", + "pc": [ + 127 + ] + }, + { + "teal": 123, + "source": "tests/contracts/account.algo.ts:17", + "pc": [ + 128, + 129 + ] + }, + { + "teal": 124, + "source": "tests/contracts/account.algo.ts:17", + "pc": [ + 130 + ] }, { + "teal": 127, + "source": "tests/contracts/account.algo.ts:17", + "errorMessage": "argument 0 (a) for hasBalance must be a address", "pc": [ 131 - ], - "errorMessage": "argument 0 (a) for hasBalance must be a address" + ] + }, + { + "teal": 130, + "source": "tests/contracts/account.algo.ts:17", + "pc": [ + 132, + 133, + 134 + ] + }, + { + "teal": 131, + "source": "tests/contracts/account.algo.ts:17", + "pc": [ + 135, + 136 + ] + }, + { + "teal": 132, + "source": "tests/contracts/account.algo.ts:17", + "pc": [ + 137 + ] + }, + { + "teal": 136, + "source": "tests/contracts/account.algo.ts:17", + "pc": [ + 138, + 139, + 140 + ] }, { + "teal": 140, + "source": "tests/contracts/account.algo.ts:18", + "pc": [ + 141, + 142 + ] + }, + { + "teal": 141, + "source": "tests/contracts/account.algo.ts:18", + "pc": [ + 143, + 144 + ] + }, + { + "teal": 142, + "source": "tests/contracts/account.algo.ts:18", + "pc": [ + 145 + ] + }, + { + "teal": 143, + "source": "tests/contracts/account.algo.ts:18", + "pc": [ + 146 + ] + }, + { + "teal": 144, + "source": "tests/contracts/account.algo.ts:18", + "pc": [ + 147 + ] + }, + { + "teal": 145, + "source": "tests/contracts/account.algo.ts:17", + "pc": [ + 148 + ] + }, + { + "teal": 150, + "source": "tests/contracts/account.algo.ts:21", + "pc": [ + 149, + 150, + 151 + ] + }, + { + "teal": 151, + "source": "tests/contracts/account.algo.ts:21", + "pc": [ + 152 + ] + }, + { + "teal": 152, + "source": "tests/contracts/account.algo.ts:21", + "pc": [ + 153 + ] + }, + { + "teal": 153, + "source": "tests/contracts/account.algo.ts:21", + "pc": [ + 154, + 155 + ] + }, + { + "teal": 154, + "source": "tests/contracts/account.algo.ts:21", + "pc": [ + 156 + ] + }, + { + "teal": 157, + "source": "tests/contracts/account.algo.ts:21", + "errorMessage": "argument 0 (a) for balance must be a address", "pc": [ 157 - ], - "errorMessage": "argument 0 (a) for balance must be a address" + ] }, { + "teal": 160, + "source": "tests/contracts/account.algo.ts:21", "pc": [ - 182 - ], - "errorMessage": "argument 0 (a) for minBalance must be a address" + 158, + 159, + 160 + ] }, { + "teal": 161, + "source": "tests/contracts/account.algo.ts:21", "pc": [ - 207 - ], - "errorMessage": "argument 0 (a) for authAddr must be a address" + 161, + 162 + ] }, { + "teal": 162, + "source": "tests/contracts/account.algo.ts:21", "pc": [ - 232 - ], - "errorMessage": "argument 0 (a) for totalNumUint must be a address" + 163 + ] }, { + "teal": 166, + "source": "tests/contracts/account.algo.ts:21", "pc": [ - 257 - ], - "errorMessage": "argument 0 (a) for totalNumByteSlice must be a address" + 164, + 165, + 166 + ] }, { + "teal": 170, + "source": "tests/contracts/account.algo.ts:22", "pc": [ - 282 - ], - "errorMessage": "argument 0 (a) for totalExtraAppPages must be a address" + 167, + 168 + ] }, { + "teal": 171, + "source": "tests/contracts/account.algo.ts:22", "pc": [ - 307 - ], - "errorMessage": "argument 0 (a) for totalAppsCreated must be a address" + 169, + 170 + ] }, { + "teal": 172, + "source": "tests/contracts/account.algo.ts:22", "pc": [ - 332 - ], - "errorMessage": "argument 0 (a) for totalAppsOptedIn must be a address" + 171 + ] }, { + "teal": 173, + "source": "tests/contracts/account.algo.ts:22", "pc": [ - 357 - ], - "errorMessage": "argument 0 (a) for totalAssetsCreated must be a address" + 172 + ] }, { + "teal": 174, + "source": "tests/contracts/account.algo.ts:21", "pc": [ - 382 - ], - "errorMessage": "argument 0 (a) for totalAssets must be a address" + 173 + ] }, { + "teal": 179, + "source": "tests/contracts/account.algo.ts:25", "pc": [ - 407 - ], - "errorMessage": "argument 0 (a) for totalBoxes must be a address" + 174, + 175, + 176 + ] }, { + "teal": 180, + "source": "tests/contracts/account.algo.ts:25", "pc": [ - 432 - ], - "errorMessage": "argument 0 (a) for totalBoxBytes must be a address" + 177 + ] }, { + "teal": 181, + "source": "tests/contracts/account.algo.ts:25", "pc": [ - 465 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + 178 + ] + }, + { + "teal": 182, + "source": "tests/contracts/account.algo.ts:25", + "pc": [ + 179, + 180 + ] + }, + { + "teal": 183, + "source": "tests/contracts/account.algo.ts:25", + "pc": [ + 181 + ] + }, + { + "teal": 186, + "source": "tests/contracts/account.algo.ts:25", + "errorMessage": "argument 0 (a) for minBalance must be a address", + "pc": [ + 182 + ] + }, + { + "teal": 189, + "source": "tests/contracts/account.algo.ts:25", + "pc": [ + 183, + 184, + 185 + ] + }, + { + "teal": 190, + "source": "tests/contracts/account.algo.ts:25", + "pc": [ + 186, + 187 + ] + }, + { + "teal": 191, + "source": "tests/contracts/account.algo.ts:25", + "pc": [ + 188 + ] + }, + { + "teal": 195, + "source": "tests/contracts/account.algo.ts:25", + "pc": [ + 189, + 190, + 191 + ] + }, + { + "teal": 199, + "source": "tests/contracts/account.algo.ts:26", + "pc": [ + 192, + 193 + ] + }, + { + "teal": 200, + "source": "tests/contracts/account.algo.ts:26", + "pc": [ + 194, + 195 + ] + }, + { + "teal": 201, + "source": "tests/contracts/account.algo.ts:26", + "pc": [ + 196 + ] + }, + { + "teal": 202, + "source": "tests/contracts/account.algo.ts:26", + "pc": [ + 197 + ] + }, + { + "teal": 203, + "source": "tests/contracts/account.algo.ts:25", + "pc": [ + 198 + ] + }, + { + "teal": 208, + "source": "tests/contracts/account.algo.ts:29", + "pc": [ + 199, + 200, + 201 + ] + }, + { + "teal": 209, + "source": "tests/contracts/account.algo.ts:29", + "pc": [ + 202 + ] + }, + { + "teal": 210, + "source": "tests/contracts/account.algo.ts:29", + "pc": [ + 203 + ] + }, + { + "teal": 211, + "source": "tests/contracts/account.algo.ts:29", + "pc": [ + 204, + 205 + ] + }, + { + "teal": 212, + "source": "tests/contracts/account.algo.ts:29", + "pc": [ + 206 + ] + }, + { + "teal": 215, + "source": "tests/contracts/account.algo.ts:29", + "errorMessage": "argument 0 (a) for authAddr must be a address", + "pc": [ + 207 + ] + }, + { + "teal": 218, + "source": "tests/contracts/account.algo.ts:29", + "pc": [ + 208, + 209, + 210 + ] + }, + { + "teal": 219, + "source": "tests/contracts/account.algo.ts:29", + "pc": [ + 211, + 212 + ] + }, + { + "teal": 220, + "source": "tests/contracts/account.algo.ts:29", + "pc": [ + 213 + ] + }, + { + "teal": 224, + "source": "tests/contracts/account.algo.ts:29", + "pc": [ + 214, + 215, + 216 + ] + }, + { + "teal": 228, + "source": "tests/contracts/account.algo.ts:30", + "pc": [ + 217, + 218 + ] + }, + { + "teal": 229, + "source": "tests/contracts/account.algo.ts:30", + "pc": [ + 219, + 220 + ] + }, + { + "teal": 230, + "source": "tests/contracts/account.algo.ts:30", + "pc": [ + 221 + ] + }, + { + "teal": 231, + "source": "tests/contracts/account.algo.ts:30", + "pc": [ + 222 + ] + }, + { + "teal": 232, + "source": "tests/contracts/account.algo.ts:29", + "pc": [ + 223 + ] + }, + { + "teal": 237, + "source": "tests/contracts/account.algo.ts:33", + "pc": [ + 224, + 225, + 226 + ] + }, + { + "teal": 238, + "source": "tests/contracts/account.algo.ts:33", + "pc": [ + 227 + ] + }, + { + "teal": 239, + "source": "tests/contracts/account.algo.ts:33", + "pc": [ + 228 + ] + }, + { + "teal": 240, + "source": "tests/contracts/account.algo.ts:33", + "pc": [ + 229, + 230 + ] + }, + { + "teal": 241, + "source": "tests/contracts/account.algo.ts:33", + "pc": [ + 231 + ] + }, + { + "teal": 244, + "source": "tests/contracts/account.algo.ts:33", + "errorMessage": "argument 0 (a) for totalNumUint must be a address", + "pc": [ + 232 + ] + }, + { + "teal": 247, + "source": "tests/contracts/account.algo.ts:33", + "pc": [ + 233, + 234, + 235 + ] + }, + { + "teal": 248, + "source": "tests/contracts/account.algo.ts:33", + "pc": [ + 236, + 237 + ] + }, + { + "teal": 249, + "source": "tests/contracts/account.algo.ts:33", + "pc": [ + 238 + ] + }, + { + "teal": 253, + "source": "tests/contracts/account.algo.ts:33", + "pc": [ + 239, + 240, + 241 + ] + }, + { + "teal": 257, + "source": "tests/contracts/account.algo.ts:34", + "pc": [ + 242, + 243 + ] + }, + { + "teal": 258, + "source": "tests/contracts/account.algo.ts:34", + "pc": [ + 244, + 245 + ] + }, + { + "teal": 259, + "source": "tests/contracts/account.algo.ts:34", + "pc": [ + 246 + ] + }, + { + "teal": 260, + "source": "tests/contracts/account.algo.ts:34", + "pc": [ + 247 + ] + }, + { + "teal": 261, + "source": "tests/contracts/account.algo.ts:33", + "pc": [ + 248 + ] + }, + { + "teal": 266, + "source": "tests/contracts/account.algo.ts:37", + "pc": [ + 249, + 250, + 251 + ] + }, + { + "teal": 267, + "source": "tests/contracts/account.algo.ts:37", + "pc": [ + 252 + ] + }, + { + "teal": 268, + "source": "tests/contracts/account.algo.ts:37", + "pc": [ + 253 + ] + }, + { + "teal": 269, + "source": "tests/contracts/account.algo.ts:37", + "pc": [ + 254, + 255 + ] + }, + { + "teal": 270, + "source": "tests/contracts/account.algo.ts:37", + "pc": [ + 256 + ] + }, + { + "teal": 273, + "source": "tests/contracts/account.algo.ts:37", + "errorMessage": "argument 0 (a) for totalNumByteSlice must be a address", + "pc": [ + 257 + ] + }, + { + "teal": 276, + "source": "tests/contracts/account.algo.ts:37", + "pc": [ + 258, + 259, + 260 + ] + }, + { + "teal": 277, + "source": "tests/contracts/account.algo.ts:37", + "pc": [ + 261, + 262 + ] + }, + { + "teal": 278, + "source": "tests/contracts/account.algo.ts:37", + "pc": [ + 263 + ] + }, + { + "teal": 282, + "source": "tests/contracts/account.algo.ts:37", + "pc": [ + 264, + 265, + 266 + ] + }, + { + "teal": 286, + "source": "tests/contracts/account.algo.ts:38", + "pc": [ + 267, + 268 + ] + }, + { + "teal": 287, + "source": "tests/contracts/account.algo.ts:38", + "pc": [ + 269, + 270 + ] + }, + { + "teal": 288, + "source": "tests/contracts/account.algo.ts:38", + "pc": [ + 271 + ] + }, + { + "teal": 289, + "source": "tests/contracts/account.algo.ts:38", + "pc": [ + 272 + ] + }, + { + "teal": 290, + "source": "tests/contracts/account.algo.ts:37", + "pc": [ + 273 + ] + }, + { + "teal": 295, + "source": "tests/contracts/account.algo.ts:41", + "pc": [ + 274, + 275, + 276 + ] + }, + { + "teal": 296, + "source": "tests/contracts/account.algo.ts:41", + "pc": [ + 277 + ] + }, + { + "teal": 297, + "source": "tests/contracts/account.algo.ts:41", + "pc": [ + 278 + ] + }, + { + "teal": 298, + "source": "tests/contracts/account.algo.ts:41", + "pc": [ + 279, + 280 + ] + }, + { + "teal": 299, + "source": "tests/contracts/account.algo.ts:41", + "pc": [ + 281 + ] + }, + { + "teal": 302, + "source": "tests/contracts/account.algo.ts:41", + "errorMessage": "argument 0 (a) for totalExtraAppPages must be a address", + "pc": [ + 282 + ] + }, + { + "teal": 305, + "source": "tests/contracts/account.algo.ts:41", + "pc": [ + 283, + 284, + 285 + ] + }, + { + "teal": 306, + "source": "tests/contracts/account.algo.ts:41", + "pc": [ + 286, + 287 + ] + }, + { + "teal": 307, + "source": "tests/contracts/account.algo.ts:41", + "pc": [ + 288 + ] + }, + { + "teal": 311, + "source": "tests/contracts/account.algo.ts:41", + "pc": [ + 289, + 290, + 291 + ] + }, + { + "teal": 315, + "source": "tests/contracts/account.algo.ts:42", + "pc": [ + 292, + 293 + ] + }, + { + "teal": 316, + "source": "tests/contracts/account.algo.ts:42", + "pc": [ + 294, + 295 + ] + }, + { + "teal": 317, + "source": "tests/contracts/account.algo.ts:42", + "pc": [ + 296 + ] + }, + { + "teal": 318, + "source": "tests/contracts/account.algo.ts:42", + "pc": [ + 297 + ] + }, + { + "teal": 319, + "source": "tests/contracts/account.algo.ts:41", + "pc": [ + 298 + ] + }, + { + "teal": 324, + "source": "tests/contracts/account.algo.ts:45", + "pc": [ + 299, + 300, + 301 + ] + }, + { + "teal": 325, + "source": "tests/contracts/account.algo.ts:45", + "pc": [ + 302 + ] + }, + { + "teal": 326, + "source": "tests/contracts/account.algo.ts:45", + "pc": [ + 303 + ] + }, + { + "teal": 327, + "source": "tests/contracts/account.algo.ts:45", + "pc": [ + 304, + 305 + ] + }, + { + "teal": 328, + "source": "tests/contracts/account.algo.ts:45", + "pc": [ + 306 + ] + }, + { + "teal": 331, + "source": "tests/contracts/account.algo.ts:45", + "errorMessage": "argument 0 (a) for totalAppsCreated must be a address", + "pc": [ + 307 + ] + }, + { + "teal": 334, + "source": "tests/contracts/account.algo.ts:45", + "pc": [ + 308, + 309, + 310 + ] + }, + { + "teal": 335, + "source": "tests/contracts/account.algo.ts:45", + "pc": [ + 311, + 312 + ] + }, + { + "teal": 336, + "source": "tests/contracts/account.algo.ts:45", + "pc": [ + 313 + ] + }, + { + "teal": 340, + "source": "tests/contracts/account.algo.ts:45", + "pc": [ + 314, + 315, + 316 + ] + }, + { + "teal": 344, + "source": "tests/contracts/account.algo.ts:46", + "pc": [ + 317, + 318 + ] + }, + { + "teal": 345, + "source": "tests/contracts/account.algo.ts:46", + "pc": [ + 319, + 320 + ] + }, + { + "teal": 346, + "source": "tests/contracts/account.algo.ts:46", + "pc": [ + 321 + ] + }, + { + "teal": 347, + "source": "tests/contracts/account.algo.ts:46", + "pc": [ + 322 + ] + }, + { + "teal": 348, + "source": "tests/contracts/account.algo.ts:45", + "pc": [ + 323 + ] + }, + { + "teal": 353, + "source": "tests/contracts/account.algo.ts:49", + "pc": [ + 324, + 325, + 326 + ] + }, + { + "teal": 354, + "source": "tests/contracts/account.algo.ts:49", + "pc": [ + 327 + ] + }, + { + "teal": 355, + "source": "tests/contracts/account.algo.ts:49", + "pc": [ + 328 + ] + }, + { + "teal": 356, + "source": "tests/contracts/account.algo.ts:49", + "pc": [ + 329, + 330 + ] + }, + { + "teal": 357, + "source": "tests/contracts/account.algo.ts:49", + "pc": [ + 331 + ] + }, + { + "teal": 360, + "source": "tests/contracts/account.algo.ts:49", + "errorMessage": "argument 0 (a) for totalAppsOptedIn must be a address", + "pc": [ + 332 + ] + }, + { + "teal": 363, + "source": "tests/contracts/account.algo.ts:49", + "pc": [ + 333, + 334, + 335 + ] + }, + { + "teal": 364, + "source": "tests/contracts/account.algo.ts:49", + "pc": [ + 336, + 337 + ] + }, + { + "teal": 365, + "source": "tests/contracts/account.algo.ts:49", + "pc": [ + 338 + ] + }, + { + "teal": 369, + "source": "tests/contracts/account.algo.ts:49", + "pc": [ + 339, + 340, + 341 + ] + }, + { + "teal": 373, + "source": "tests/contracts/account.algo.ts:50", + "pc": [ + 342, + 343 + ] + }, + { + "teal": 374, + "source": "tests/contracts/account.algo.ts:50", + "pc": [ + 344, + 345 + ] + }, + { + "teal": 375, + "source": "tests/contracts/account.algo.ts:50", + "pc": [ + 346 + ] + }, + { + "teal": 376, + "source": "tests/contracts/account.algo.ts:50", + "pc": [ + 347 + ] + }, + { + "teal": 377, + "source": "tests/contracts/account.algo.ts:49", + "pc": [ + 348 + ] + }, + { + "teal": 382, + "source": "tests/contracts/account.algo.ts:53", + "pc": [ + 349, + 350, + 351 + ] + }, + { + "teal": 383, + "source": "tests/contracts/account.algo.ts:53", + "pc": [ + 352 + ] + }, + { + "teal": 384, + "source": "tests/contracts/account.algo.ts:53", + "pc": [ + 353 + ] + }, + { + "teal": 385, + "source": "tests/contracts/account.algo.ts:53", + "pc": [ + 354, + 355 + ] + }, + { + "teal": 386, + "source": "tests/contracts/account.algo.ts:53", + "pc": [ + 356 + ] + }, + { + "teal": 389, + "source": "tests/contracts/account.algo.ts:53", + "errorMessage": "argument 0 (a) for totalAssetsCreated must be a address", + "pc": [ + 357 + ] + }, + { + "teal": 392, + "source": "tests/contracts/account.algo.ts:53", + "pc": [ + 358, + 359, + 360 + ] + }, + { + "teal": 393, + "source": "tests/contracts/account.algo.ts:53", + "pc": [ + 361, + 362 + ] + }, + { + "teal": 394, + "source": "tests/contracts/account.algo.ts:53", + "pc": [ + 363 + ] + }, + { + "teal": 398, + "source": "tests/contracts/account.algo.ts:53", + "pc": [ + 364, + 365, + 366 + ] + }, + { + "teal": 402, + "source": "tests/contracts/account.algo.ts:54", + "pc": [ + 367, + 368 + ] + }, + { + "teal": 403, + "source": "tests/contracts/account.algo.ts:54", + "pc": [ + 369, + 370 + ] + }, + { + "teal": 404, + "source": "tests/contracts/account.algo.ts:54", + "pc": [ + 371 + ] + }, + { + "teal": 405, + "source": "tests/contracts/account.algo.ts:54", + "pc": [ + 372 + ] + }, + { + "teal": 406, + "source": "tests/contracts/account.algo.ts:53", + "pc": [ + 373 + ] + }, + { + "teal": 411, + "source": "tests/contracts/account.algo.ts:57", + "pc": [ + 374, + 375, + 376 + ] + }, + { + "teal": 412, + "source": "tests/contracts/account.algo.ts:57", + "pc": [ + 377 + ] + }, + { + "teal": 413, + "source": "tests/contracts/account.algo.ts:57", + "pc": [ + 378 + ] + }, + { + "teal": 414, + "source": "tests/contracts/account.algo.ts:57", + "pc": [ + 379, + 380 + ] + }, + { + "teal": 415, + "source": "tests/contracts/account.algo.ts:57", + "pc": [ + 381 + ] + }, + { + "teal": 418, + "source": "tests/contracts/account.algo.ts:57", + "errorMessage": "argument 0 (a) for totalAssets must be a address", + "pc": [ + 382 + ] + }, + { + "teal": 421, + "source": "tests/contracts/account.algo.ts:57", + "pc": [ + 383, + 384, + 385 + ] + }, + { + "teal": 422, + "source": "tests/contracts/account.algo.ts:57", + "pc": [ + 386, + 387 + ] + }, + { + "teal": 423, + "source": "tests/contracts/account.algo.ts:57", + "pc": [ + 388 + ] + }, + { + "teal": 427, + "source": "tests/contracts/account.algo.ts:57", + "pc": [ + 389, + 390, + 391 + ] + }, + { + "teal": 431, + "source": "tests/contracts/account.algo.ts:58", + "pc": [ + 392, + 393 + ] + }, + { + "teal": 432, + "source": "tests/contracts/account.algo.ts:58", + "pc": [ + 394, + 395 + ] + }, + { + "teal": 433, + "source": "tests/contracts/account.algo.ts:58", + "pc": [ + 396 + ] + }, + { + "teal": 434, + "source": "tests/contracts/account.algo.ts:58", + "pc": [ + 397 + ] + }, + { + "teal": 435, + "source": "tests/contracts/account.algo.ts:57", + "pc": [ + 398 + ] + }, + { + "teal": 440, + "source": "tests/contracts/account.algo.ts:61", + "pc": [ + 399, + 400, + 401 + ] + }, + { + "teal": 441, + "source": "tests/contracts/account.algo.ts:61", + "pc": [ + 402 + ] + }, + { + "teal": 442, + "source": "tests/contracts/account.algo.ts:61", + "pc": [ + 403 + ] + }, + { + "teal": 443, + "source": "tests/contracts/account.algo.ts:61", + "pc": [ + 404, + 405 + ] + }, + { + "teal": 444, + "source": "tests/contracts/account.algo.ts:61", + "pc": [ + 406 + ] + }, + { + "teal": 447, + "source": "tests/contracts/account.algo.ts:61", + "errorMessage": "argument 0 (a) for totalBoxes must be a address", + "pc": [ + 407 + ] + }, + { + "teal": 450, + "source": "tests/contracts/account.algo.ts:61", + "pc": [ + 408, + 409, + 410 + ] + }, + { + "teal": 451, + "source": "tests/contracts/account.algo.ts:61", + "pc": [ + 411, + 412 + ] + }, + { + "teal": 452, + "source": "tests/contracts/account.algo.ts:61", + "pc": [ + 413 + ] + }, + { + "teal": 456, + "source": "tests/contracts/account.algo.ts:61", + "pc": [ + 414, + 415, + 416 + ] + }, + { + "teal": 460, + "source": "tests/contracts/account.algo.ts:62", + "pc": [ + 417, + 418 + ] + }, + { + "teal": 461, + "source": "tests/contracts/account.algo.ts:62", + "pc": [ + 419, + 420 + ] + }, + { + "teal": 462, + "source": "tests/contracts/account.algo.ts:62", + "pc": [ + 421 + ] + }, + { + "teal": 463, + "source": "tests/contracts/account.algo.ts:62", + "pc": [ + 422 + ] + }, + { + "teal": 464, + "source": "tests/contracts/account.algo.ts:61", + "pc": [ + 423 + ] + }, + { + "teal": 469, + "source": "tests/contracts/account.algo.ts:65", + "pc": [ + 424, + 425, + 426 + ] + }, + { + "teal": 470, + "source": "tests/contracts/account.algo.ts:65", + "pc": [ + 427 + ] + }, + { + "teal": 471, + "source": "tests/contracts/account.algo.ts:65", + "pc": [ + 428 + ] + }, + { + "teal": 472, + "source": "tests/contracts/account.algo.ts:65", + "pc": [ + 429, + 430 + ] + }, + { + "teal": 473, + "source": "tests/contracts/account.algo.ts:65", + "pc": [ + 431 + ] + }, + { + "teal": 476, + "source": "tests/contracts/account.algo.ts:65", + "errorMessage": "argument 0 (a) for totalBoxBytes must be a address", + "pc": [ + 432 + ] + }, + { + "teal": 479, + "source": "tests/contracts/account.algo.ts:65", + "pc": [ + 433, + 434, + 435 + ] + }, + { + "teal": 480, + "source": "tests/contracts/account.algo.ts:65", + "pc": [ + 436, + 437 + ] + }, + { + "teal": 481, + "source": "tests/contracts/account.algo.ts:65", + "pc": [ + 438 + ] + }, + { + "teal": 485, + "source": "tests/contracts/account.algo.ts:65", + "pc": [ + 439, + 440, + 441 + ] + }, + { + "teal": 489, + "source": "tests/contracts/account.algo.ts:66", + "pc": [ + 442, + 443 + ] + }, + { + "teal": 490, + "source": "tests/contracts/account.algo.ts:66", + "pc": [ + 444, + 445 + ] + }, + { + "teal": 491, + "source": "tests/contracts/account.algo.ts:66", + "pc": [ + 446 + ] + }, + { + "teal": 492, + "source": "tests/contracts/account.algo.ts:66", + "pc": [ + 447 + ] + }, + { + "teal": 493, + "source": "tests/contracts/account.algo.ts:65", + "pc": [ + 448 + ] + }, + { + "teal": 496, + "source": "tests/contracts/account.algo.ts:4", + "pc": [ + 449, + 450 + ] + }, + { + "teal": 497, + "source": "tests/contracts/account.algo.ts:4", + "pc": [ + 451 + ] + }, + { + "teal": 500, + "source": "tests/contracts/account.algo.ts:4", + "pc": [ + 452, + 453, + 454, + 455, + 456, + 457 + ] + }, + { + "teal": 501, + "source": "tests/contracts/account.algo.ts:4", + "pc": [ + 458, + 459, + 460 + ] + }, + { + "teal": 502, + "source": "tests/contracts/account.algo.ts:4", + "pc": [ + 461, + 462, + 463, + 464 + ] + }, + { + "teal": 505, + "source": "tests/contracts/account.algo.ts:4", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", + "pc": [ + 465 + ] + }, + { + "teal": 508, + "source": "tests/contracts/account.algo.ts:4", + "pc": [ + 466, + 467, + 468, + 469, + 470, + 471 + ] + }, + { + "teal": 509, + "source": "tests/contracts/account.algo.ts:4", + "pc": [ + 472, + 473, + 474, + 475, + 476, + 477 + ] + }, + { + "teal": 510, + "source": "tests/contracts/account.algo.ts:4", + "pc": [ + 478, + 479, + 480, + 481, + 482, + 483 + ] + }, + { + "teal": 511, + "source": "tests/contracts/account.algo.ts:4", + "pc": [ + 484, + 485, + 486, + 487, + 488, + 489 + ] + }, + { + "teal": 512, + "source": "tests/contracts/account.algo.ts:4", + "pc": [ + 490, + 491, + 492, + 493, + 494, + 495 + ] + }, + { + "teal": 513, + "source": "tests/contracts/account.algo.ts:4", + "pc": [ + 496, + 497, + 498, + 499, + 500, + 501 + ] + }, + { + "teal": 514, + "source": "tests/contracts/account.algo.ts:4", + "pc": [ + 502, + 503, + 504, + 505, + 506, + 507 + ] + }, + { + "teal": 515, + "source": "tests/contracts/account.algo.ts:4", + "pc": [ + 508, + 509, + 510, + 511, + 512, + 513 + ] + }, + { + "teal": 516, + "source": "tests/contracts/account.algo.ts:4", + "pc": [ + 514, + 515, + 516, + 517, + 518, + 519 + ] + }, + { + "teal": 517, + "source": "tests/contracts/account.algo.ts:4", + "pc": [ + 520, + 521, + 522, + 523, + 524, + 525 + ] + }, + { + "teal": 518, + "source": "tests/contracts/account.algo.ts:4", + "pc": [ + 526, + 527, + 528, + 529, + 530, + 531 + ] + }, + { + "teal": 519, + "source": "tests/contracts/account.algo.ts:4", + "pc": [ + 532, + 533, + 534, + 535, + 536, + 537 + ] + }, + { + "teal": 520, + "source": "tests/contracts/account.algo.ts:4", + "pc": [ + 538, + 539, + 540, + 541, + 542, + 543 + ] + }, + { + "teal": 521, + "source": "tests/contracts/account.algo.ts:4", + "pc": [ + 544, + 545, + 546, + 547, + 548, + 549 + ] + }, + { + "teal": 522, + "source": "tests/contracts/account.algo.ts:4", + "pc": [ + 550, + 551, + 552, + 553, + 554, + 555 + ] + }, + { + "teal": 523, + "source": "tests/contracts/account.algo.ts:4", + "pc": [ + 556, + 557, + 558, + 559, + 560, + 561 + ] + }, + { + "teal": 524, + "source": "tests/contracts/account.algo.ts:4", + "pc": [ + 562, + 563, + 564 + ] + }, + { + "teal": 525, + "source": "tests/contracts/account.algo.ts:4", + "pc": [ + 565, + 566, + 567, + 568, + 569, + 570, + 571, + 572, + 573, + 574, + 575, + 576, + 577, + 578, + 579, + 580, + 581, + 582, + 583, + 584, + 585, + 586, + 587, + 588, + 589, + 590, + 591, + 592, + 593, + 594, + 595, + 596, + 597, + 598 + ] }, { + "teal": 528, + "source": "tests/contracts/account.algo.ts:4", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 599 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/B.arc56_draft.json b/tests/contracts/artifacts/B.arc56_draft.json index 14460a8bd..104a4cbca 100644 --- a/tests/contracts/artifacts/B.arc56_draft.json +++ b/tests/contracts/artifacts/B.arc56_draft.json @@ -88,22 +88,381 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/inheritance.algo.ts:20", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/inheritance.algo.ts:20", + "pc": [ + 1, + 2, + 3, + 4 + ] + }, + { + "teal": 14, + "source": "tests/contracts/inheritance.algo.ts:20", + "pc": [ + 5, + 6 + ] + }, + { + "teal": 15, + "source": "tests/contracts/inheritance.algo.ts:20", + "pc": [ + 7 + ] + }, + { + "teal": 16, + "source": "tests/contracts/inheritance.algo.ts:20", + "pc": [ + 8, + 9 + ] + }, + { + "teal": 17, + "source": "tests/contracts/inheritance.algo.ts:20", + "pc": [ + 10 + ] + }, + { + "teal": 18, + "source": "tests/contracts/inheritance.algo.ts:20", + "pc": [ + 11, + 12 + ] + }, + { + "teal": 19, + "source": "tests/contracts/inheritance.algo.ts:20", + "pc": [ + 13 + ] + }, + { + "teal": 20, + "source": "tests/contracts/inheritance.algo.ts:20", + "pc": [ + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38, + 39 + ] + }, + { + "teal": 24, + "source": "tests/contracts/inheritance.algo.ts:20", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 40 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/inheritance.algo.ts:15", + "pc": [ + 41, + 42, + 43 + ] }, { + "teal": 30, + "source": "tests/contracts/inheritance.algo.ts:15", + "pc": [ + 44, + 45 + ] + }, + { + "teal": 31, + "source": "tests/contracts/inheritance.algo.ts:15", + "pc": [ + 46 + ] + }, + { + "teal": 35, + "source": "tests/contracts/inheritance.algo.ts:15", + "pc": [ + 47, + 48, + 49 + ] + }, + { + "teal": 39, + "source": "tests/contracts/inheritance.algo.ts:16", + "pc": [ + 50, + 51, + 52 + ] + }, + { + "teal": 40, + "source": "tests/contracts/inheritance.algo.ts:16", + "pc": [ + 53, + 54, + 55 + ] + }, + { + "teal": 41, + "source": "tests/contracts/inheritance.algo.ts:16", + "pc": [ + 56 + ] + }, + { + "teal": 42, + "source": "tests/contracts/inheritance.algo.ts:15", + "pc": [ + 57 + ] + }, + { + "teal": 47, + "source": "tests/contracts/inheritance.algo.ts:23", + "pc": [ + 58, + 59, + 60 + ] + }, + { + "teal": 48, + "source": "tests/contracts/inheritance.algo.ts:23", + "pc": [ + 61, + 62 + ] + }, + { + "teal": 49, + "source": "tests/contracts/inheritance.algo.ts:23", + "pc": [ + 63 + ] + }, + { + "teal": 53, + "source": "tests/contracts/inheritance.algo.ts:23", + "pc": [ + 64, + 65, + 66 + ] + }, + { + "teal": 57, + "source": "tests/contracts/inheritance.algo.ts:24", + "pc": [ + 67, + 68, + 69 + ] + }, + { + "teal": 58, + "source": "tests/contracts/inheritance.algo.ts:24", + "pc": [ + 70 + ] + }, + { + "teal": 59, + "source": "tests/contracts/inheritance.algo.ts:24", + "pc": [ + 71, + 72, + 73 + ] + }, + { + "teal": 60, + "source": "tests/contracts/inheritance.algo.ts:24", + "pc": [ + 74 + ] + }, + { + "teal": 61, + "source": "tests/contracts/inheritance.algo.ts:24", + "pc": [ + 75 + ] + }, + { + "teal": 65, + "source": "tests/contracts/inheritance.algo.ts:25", + "pc": [ + 76, + 77, + 78 + ] + }, + { + "teal": 66, + "source": "tests/contracts/inheritance.algo.ts:25", + "pc": [ + 79, + 80 + ] + }, + { + "teal": 67, + "source": "tests/contracts/inheritance.algo.ts:25", + "pc": [ + 81 + ] + }, + { + "teal": 68, + "source": "tests/contracts/inheritance.algo.ts:23", + "pc": [ + 82 + ] + }, + { + "teal": 71, + "source": "tests/contracts/inheritance.algo.ts:20", + "pc": [ + 83, + 84 + ] + }, + { + "teal": 72, + "source": "tests/contracts/inheritance.algo.ts:20", + "pc": [ + 85 + ] + }, + { + "teal": 75, + "source": "tests/contracts/inheritance.algo.ts:20", + "pc": [ + 86, + 87, + 88, + 89, + 90, + 91 + ] + }, + { + "teal": 76, + "source": "tests/contracts/inheritance.algo.ts:20", + "pc": [ + 92, + 93, + 94 + ] + }, + { + "teal": 77, + "source": "tests/contracts/inheritance.algo.ts:20", + "pc": [ + 95, + 96, + 97, + 98 + ] + }, + { + "teal": 80, + "source": "tests/contracts/inheritance.algo.ts:20", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 99 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 83, + "source": "tests/contracts/inheritance.algo.ts:20", + "pc": [ + 100, + 101, + 102, + 103, + 104, + 105 + ] + }, + { + "teal": 84, + "source": "tests/contracts/inheritance.algo.ts:20", + "pc": [ + 106, + 107, + 108, + 109, + 110, + 111 + ] + }, + { + "teal": 85, + "source": "tests/contracts/inheritance.algo.ts:20", + "pc": [ + 112, + 113, + 114 + ] + }, + { + "teal": 86, + "source": "tests/contracts/inheritance.algo.ts:20", + "pc": [ + 115, + 116, + 117, + 118, + 119, + 120 + ] }, { + "teal": 89, + "source": "tests/contracts/inheritance.algo.ts:20", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 121 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/B2.arc56_draft.json b/tests/contracts/artifacts/B2.arc56_draft.json index 2e8c4f30f..d2397ca2f 100644 --- a/tests/contracts/artifacts/B2.arc56_draft.json +++ b/tests/contracts/artifacts/B2.arc56_draft.json @@ -83,22 +83,325 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/inheritance.algo.ts:86", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/inheritance.algo.ts:86", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/inheritance.algo.ts:86", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/inheritance.algo.ts:86", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/inheritance.algo.ts:86", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/inheritance.algo.ts:86", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/inheritance.algo.ts:86", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/inheritance.algo.ts:86", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/inheritance.algo.ts:86", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/inheritance.algo.ts:15", + "pc": [ + 37, + 38, + 39 + ] + }, + { + "teal": 29, + "source": "tests/contracts/inheritance.algo.ts:15", + "pc": [ + 40, + 41 + ] + }, + { + "teal": 30, + "source": "tests/contracts/inheritance.algo.ts:15", + "pc": [ + 42 + ] + }, + { + "teal": 34, + "source": "tests/contracts/inheritance.algo.ts:15", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 38, + "source": "tests/contracts/inheritance.algo.ts:16", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 39, + "source": "tests/contracts/inheritance.algo.ts:16", + "pc": [ + 49, + 50, + 51 + ] + }, + { + "teal": 40, + "source": "tests/contracts/inheritance.algo.ts:16", + "pc": [ + 52 + ] + }, + { + "teal": 41, + "source": "tests/contracts/inheritance.algo.ts:15", + "pc": [ + 53 + ] }, { + "teal": 46, + "source": "tests/contracts/inheritance.algo.ts:87", + "pc": [ + 54, + 55, + 56 + ] + }, + { + "teal": 47, + "source": "tests/contracts/inheritance.algo.ts:87", + "pc": [ + 57, + 58 + ] + }, + { + "teal": 48, + "source": "tests/contracts/inheritance.algo.ts:87", + "pc": [ + 59 + ] + }, + { + "teal": 52, + "source": "tests/contracts/inheritance.algo.ts:87", + "pc": [ + 60, + 61, + 62 + ] + }, + { + "teal": 56, + "source": "tests/contracts/inheritance.algo.ts:88", + "pc": [ + 63, + 64, + 65, + 66 + ] + }, + { + "teal": 57, + "source": "tests/contracts/inheritance.algo.ts:88", + "pc": [ + 67 + ] + }, + { + "teal": 58, + "source": "tests/contracts/inheritance.algo.ts:87", + "pc": [ + 68 + ] + }, + { + "teal": 61, + "source": "tests/contracts/inheritance.algo.ts:86", + "pc": [ + 69, + 70 + ] + }, + { + "teal": 62, + "source": "tests/contracts/inheritance.algo.ts:86", + "pc": [ + 71 + ] + }, + { + "teal": 65, + "source": "tests/contracts/inheritance.algo.ts:86", + "pc": [ + 72, + 73, + 74, + 75, + 76, + 77 + ] + }, + { + "teal": 66, + "source": "tests/contracts/inheritance.algo.ts:86", + "pc": [ + 78, + 79, + 80 + ] + }, + { + "teal": 67, + "source": "tests/contracts/inheritance.algo.ts:86", + "pc": [ + 81, + 82, + 83, + 84 + ] + }, + { + "teal": 70, + "source": "tests/contracts/inheritance.algo.ts:86", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 85 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 73, + "source": "tests/contracts/inheritance.algo.ts:86", + "pc": [ + 86, + 87, + 88, + 89, + 90, + 91 + ] + }, + { + "teal": 74, + "source": "tests/contracts/inheritance.algo.ts:86", + "pc": [ + 92, + 93, + 94, + 95, + 96, + 97 + ] + }, + { + "teal": 75, + "source": "tests/contracts/inheritance.algo.ts:86", + "pc": [ + 98, + 99, + 100 + ] + }, + { + "teal": 76, + "source": "tests/contracts/inheritance.algo.ts:86", + "pc": [ + 101, + 102, + 103, + 104, + 105, + 106 + ] }, { + "teal": 79, + "source": "tests/contracts/inheritance.algo.ts:86", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 107 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/BigComment.arc56_draft.json b/tests/contracts/artifacts/BigComment.arc56_draft.json index 08611cf7f..0df2b4544 100644 --- a/tests/contracts/artifacts/BigComment.arc56_draft.json +++ b/tests/contracts/artifacts/BigComment.arc56_draft.json @@ -64,18 +64,542 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/big_comment.algo.ts:3", + "pc": [ + 0 + ] + }, + { + "teal": 14, + "source": "tests/contracts/big_comment.algo.ts:3", + "pc": [ + 36 + ] + }, + { + "teal": 17, + "source": "tests/contracts/big_comment.algo.ts:3", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 19, + "source": "tests/contracts/big_comment.algo.ts:3", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 23, + "source": "tests/contracts/big_comment.algo.ts:3", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 49, 50, 51 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/big_comment.algo.ts:6", + "pc": [ + 56, + 57 + ] }, { - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + "teal": 32, + "source": "tests/contracts/big_comment.algo.ts:6", + "pc": [ + 59, + 60, + 61 + ] }, { - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + "teal": 34, + "source": "tests/contracts/big_comment.algo.ts:6", + "pc": [ + 62, + 63, + 64, + 65, + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82, + 83, + 84, + 85, + 86, + 87, + 88, + 89, + 90, + 91, + 92, + 93, + 94, + 95, + 96, + 97, + 98, + 99, + 100, + 101, + 102, + 103, + 104, + 105, + 106, + 107, + 108, + 109, + 110, + 111, + 112, + 113, + 114, + 115, + 116, + 117, + 118, + 119, + 120, + 121, + 122, + 123, + 124, + 125, + 126, + 127, + 128, + 129, + 130, + 131, + 132, + 133, + 134, + 135, + 136, + 137, + 138, + 139, + 140, + 141, + 142, + 143, + 144, + 145, + 146, + 147, + 148, + 149, + 150, + 151, + 152, + 153, + 154, + 155, + 156, + 157, + 158, + 159, + 160, + 161, + 162, + 163, + 164, + 165, + 166, + 167, + 168, + 169, + 170, + 171, + 172, + 173, + 174, + 175, + 176, + 177, + 178, + 179, + 180, + 181, + 182, + 183, + 184, + 185, + 186, + 187, + 188, + 189, + 190, + 191, + 192, + 193, + 194, + 195, + 196, + 197, + 198, + 199, + 200, + 201, + 202, + 203, + 204, + 205, + 206, + 207, + 208, + 209, + 210, + 211, + 212, + 213, + 214, + 215, + 216, + 217, + 218, + 219, + 220, + 221, + 222, + 223, + 224, + 225, + 226, + 227, + 228, + 229, + 230, + 231, + 232, + 233, + 234, + 235, + 236, + 237, + 238, + 239, + 240, + 241, + 242, + 243, + 244, + 245, + 246, + 247, + 248, + 249, + 250, + 251, + 252, + 253, + 254, + 255, + 256, + 257, + 258, + 259, + 260, + 261, + 262, + 263, + 264, + 265, + 266, + 267, + 268, + 269, + 270, + 271, + 272, + 273, + 274, + 275, + 276, + 277, + 278, + 279, + 280, + 281, + 282, + 283, + 284, + 285, + 286, + 287, + 288, + 289, + 290, + 291, + 292, + 293, + 294, + 295, + 296, + 297, + 298, + 299, + 300, + 301, + 302, + 303, + 304, + 305, + 306, + 307, + 308, + 309, + 310, + 311, + 312, + 313, + 314, + 315, + 316, + 317, + 318, + 319, + 320, + 321, + 322, + 323, + 324, + 325, + 326, + 327, + 328, + 329, + 330, + 331, + 332, + 333, + 334, + 335, + 336, + 337, + 338, + 339, + 340, + 341, + 342, + 343, + 344, + 345, + 346, + 347, + 348, + 349, + 350, + 351, + 352, + 353, + 354, + 355, + 356, + 357, + 358, + 359, + 360, + 361, + 362, + 363, + 364, + 365, + 366, + 367, + 368, + 369, + 370, + 371, + 372, + 373, + 374, + 375, + 376, + 377, + 378, + 379, + 380, + 381, + 382, + 383, + 384, + 385, + 386, + 387, + 388, + 389, + 390, + 391, + 392, + 393, + 394, + 395, + 396, + 397, + 398, + 399, + 400, + 401, + 402, + 403, + 404, + 405, + 406, + 407, + 408, + 409, + 410, + 411, + 412, + 413, + 414, + 415, + 416, + 417, + 418, + 419, + 420, + 421, + 422, + 423, + 424, + 425, + 426, + 427, + 428, + 429, + 430, + 431, + 432, + 433, + 434, + 435, + 436, + 437, + 438, + 439, + 440, + 441, + 442, + 443, + 444, + 445, + 446, + 447, + 448, + 449, + 450, + 451, + 452, + 453, + 454, + 455, + 456, + 457, + 458, + 459, + 460, + 461, + 462, + 463, + 464, + 465, + 466, + 467, + 468, + 469, + 470, + 471, + 472, + 473, + 474, + 475, + 476, + 477, + 478, + 479, + 480, + 481, + 482, + 483, + 484, + 485, + 486, + 487, + 488, + 489, + 490, + 491, + 492, + 493, + 494, + 495, + 496, + 497, + 498, + 499, + 500, + 501, + 502, + 503, + 504, + 505, + 506, + 507, + 508, + 509 + ] + }, + { + "teal": 35, + "source": "tests/contracts/big_comment.algo.ts:6", + "pc": [ + 510 + ] + }, + { + "teal": 38, + "source": "tests/contracts/big_comment.algo.ts:6", + "pc": [ + 511, + 512 + ] + }, + { + "teal": 39, + "source": "tests/contracts/big_comment.algo.ts:6", + "pc": [ + 513 + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/BinaryTest.arc56_draft.json b/tests/contracts/artifacts/BinaryTest.arc56_draft.json index 2466ecfe4..1d96fda34 100644 --- a/tests/contracts/artifacts/BinaryTest.arc56_draft.json +++ b/tests/contracts/artifacts/BinaryTest.arc56_draft.json @@ -231,22 +231,1207 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/binary.algo.ts:4", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/binary.algo.ts:4", + "pc": [ + 1, + 2, + 3 + ] + }, + { + "teal": 14, + "source": "tests/contracts/binary.algo.ts:4", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 15, + "source": "tests/contracts/binary.algo.ts:4", + "pc": [ + 6 + ] + }, + { + "teal": 16, + "source": "tests/contracts/binary.algo.ts:4", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 17, + "source": "tests/contracts/binary.algo.ts:4", + "pc": [ + 9 + ] + }, + { + "teal": 18, + "source": "tests/contracts/binary.algo.ts:4", + "pc": [ + 10, + 11 + ] + }, + { + "teal": 19, + "source": "tests/contracts/binary.algo.ts:4", + "pc": [ + 12 + ] + }, + { + "teal": 20, + "source": "tests/contracts/binary.algo.ts:4", + "pc": [ + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38 + ] + }, + { + "teal": 24, + "source": "tests/contracts/binary.algo.ts:4", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 39 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/binary.algo.ts:5", + "pc": [ + 40, + 41, + 42 + ] + }, + { + "teal": 30, + "source": "tests/contracts/binary.algo.ts:5", + "pc": [ + 43 + ] + }, + { + "teal": 33, + "source": "tests/contracts/binary.algo.ts:5", + "pc": [ + 44, + 45, + 46 + ] + }, + { + "teal": 34, + "source": "tests/contracts/binary.algo.ts:5", + "pc": [ + 47 + ] + }, + { + "teal": 37, + "source": "tests/contracts/binary.algo.ts:5", + "pc": [ + 48, + 49, + 50 + ] + }, + { + "teal": 38, + "source": "tests/contracts/binary.algo.ts:5", + "pc": [ + 51, + 52 + ] + }, + { + "teal": 39, + "source": "tests/contracts/binary.algo.ts:5", + "pc": [ + 53 + ] + }, + { + "teal": 43, + "source": "tests/contracts/binary.algo.ts:5", + "pc": [ + 54, + 55, + 56 + ] + }, + { + "teal": 47, + "source": "tests/contracts/binary.algo.ts:6", + "pc": [ + 57, + 58 + ] + }, + { + "teal": 48, + "source": "tests/contracts/binary.algo.ts:6", + "pc": [ + 59 + ] + }, + { + "teal": 49, + "source": "tests/contracts/binary.algo.ts:6", + "pc": [ + 60, + 61, + 62 + ] + }, + { + "teal": 50, + "source": "tests/contracts/binary.algo.ts:6", + "pc": [ + 63, + 64 + ] + }, + { + "teal": 51, + "source": "tests/contracts/binary.algo.ts:6", + "pc": [ + 65 + ] + }, + { + "teal": 54, + "source": "tests/contracts/binary.algo.ts:6", + "pc": [ + 66 + ] + }, + { + "teal": 55, + "source": "tests/contracts/binary.algo.ts:5", + "pc": [ + 67 + ] + }, + { + "teal": 60, + "source": "tests/contracts/binary.algo.ts:9", + "pc": [ + 68, + 69, + 70 + ] + }, + { + "teal": 61, + "source": "tests/contracts/binary.algo.ts:9", + "pc": [ + 71 + ] + }, + { + "teal": 64, + "source": "tests/contracts/binary.algo.ts:9", + "pc": [ + 72, + 73, + 74 + ] + }, + { + "teal": 65, + "source": "tests/contracts/binary.algo.ts:9", + "pc": [ + 75 + ] + }, + { + "teal": 68, + "source": "tests/contracts/binary.algo.ts:9", + "pc": [ + 76, + 77, + 78 + ] + }, + { + "teal": 69, + "source": "tests/contracts/binary.algo.ts:9", + "pc": [ + 79, + 80 + ] + }, + { + "teal": 70, + "source": "tests/contracts/binary.algo.ts:9", + "pc": [ + 81 + ] + }, + { + "teal": 74, + "source": "tests/contracts/binary.algo.ts:9", + "pc": [ + 82, + 83, + 84 + ] + }, + { + "teal": 78, + "source": "tests/contracts/binary.algo.ts:10", + "pc": [ + 85, + 86 + ] + }, + { + "teal": 79, + "source": "tests/contracts/binary.algo.ts:10", + "pc": [ + 87 + ] + }, + { + "teal": 80, + "source": "tests/contracts/binary.algo.ts:10", + "pc": [ + 88, + 89, + 90 + ] + }, + { + "teal": 81, + "source": "tests/contracts/binary.algo.ts:10", + "pc": [ + 91, + 92 + ] + }, + { + "teal": 82, + "source": "tests/contracts/binary.algo.ts:10", + "pc": [ + 93 + ] + }, + { + "teal": 85, + "source": "tests/contracts/binary.algo.ts:10", + "pc": [ + 94 + ] + }, + { + "teal": 86, + "source": "tests/contracts/binary.algo.ts:9", + "pc": [ + 95 + ] + }, + { + "teal": 91, + "source": "tests/contracts/binary.algo.ts:13", + "pc": [ + 96, + 97, + 98 + ] + }, + { + "teal": 92, + "source": "tests/contracts/binary.algo.ts:13", + "pc": [ + 99 + ] + }, + { + "teal": 95, + "source": "tests/contracts/binary.algo.ts:13", + "pc": [ + 100, + 101, + 102 + ] + }, + { + "teal": 96, + "source": "tests/contracts/binary.algo.ts:13", + "pc": [ + 103 + ] + }, + { + "teal": 99, + "source": "tests/contracts/binary.algo.ts:13", + "pc": [ + 104, + 105, + 106 + ] + }, + { + "teal": 100, + "source": "tests/contracts/binary.algo.ts:13", + "pc": [ + 107, + 108 + ] + }, + { + "teal": 101, + "source": "tests/contracts/binary.algo.ts:13", + "pc": [ + 109 + ] + }, + { + "teal": 105, + "source": "tests/contracts/binary.algo.ts:13", + "pc": [ + 110, + 111, + 112 + ] + }, + { + "teal": 109, + "source": "tests/contracts/binary.algo.ts:14", + "pc": [ + 113, + 114 + ] + }, + { + "teal": 110, + "source": "tests/contracts/binary.algo.ts:14", + "pc": [ + 115, + 116 + ] + }, + { + "teal": 111, + "source": "tests/contracts/binary.algo.ts:14", + "pc": [ + 117 + ] + }, + { + "teal": 112, + "source": "tests/contracts/binary.algo.ts:14", + "pc": [ + 118 + ] + }, + { + "teal": 113, + "source": "tests/contracts/binary.algo.ts:13", + "pc": [ + 119 + ] + }, + { + "teal": 118, + "source": "tests/contracts/binary.algo.ts:17", + "pc": [ + 120, + 121, + 122 + ] + }, + { + "teal": 119, + "source": "tests/contracts/binary.algo.ts:17", + "pc": [ + 123 + ] + }, + { + "teal": 122, + "source": "tests/contracts/binary.algo.ts:17", + "pc": [ + 124, + 125, + 126 + ] + }, + { + "teal": 123, + "source": "tests/contracts/binary.algo.ts:17", + "pc": [ + 127 + ] + }, + { + "teal": 126, + "source": "tests/contracts/binary.algo.ts:17", + "pc": [ + 128, + 129, + 130 + ] + }, + { + "teal": 127, + "source": "tests/contracts/binary.algo.ts:17", + "pc": [ + 131, + 132 + ] + }, + { + "teal": 128, + "source": "tests/contracts/binary.algo.ts:17", + "pc": [ + 133 + ] + }, + { + "teal": 132, + "source": "tests/contracts/binary.algo.ts:17", + "pc": [ + 134, + 135, + 136 + ] + }, + { + "teal": 136, + "source": "tests/contracts/binary.algo.ts:18", + "pc": [ + 137, + 138 + ] + }, + { + "teal": 137, + "source": "tests/contracts/binary.algo.ts:18", + "pc": [ + 139, + 140 + ] + }, + { + "teal": 138, + "source": "tests/contracts/binary.algo.ts:18", + "pc": [ + 141 + ] + }, + { + "teal": 139, + "source": "tests/contracts/binary.algo.ts:18", + "pc": [ + 142 + ] + }, + { + "teal": 140, + "source": "tests/contracts/binary.algo.ts:17", + "pc": [ + 143 + ] + }, + { + "teal": 145, + "source": "tests/contracts/binary.algo.ts:21", + "pc": [ + 144, + 145, + 146 + ] + }, + { + "teal": 146, + "source": "tests/contracts/binary.algo.ts:21", + "pc": [ + 147 + ] + }, + { + "teal": 149, + "source": "tests/contracts/binary.algo.ts:21", + "pc": [ + 148, + 149, + 150 + ] + }, + { + "teal": 150, + "source": "tests/contracts/binary.algo.ts:21", + "pc": [ + 151 + ] + }, + { + "teal": 153, + "source": "tests/contracts/binary.algo.ts:21", + "pc": [ + 152, + 153, + 154 + ] }, { + "teal": 154, + "source": "tests/contracts/binary.algo.ts:21", + "pc": [ + 155, + 156 + ] + }, + { + "teal": 155, + "source": "tests/contracts/binary.algo.ts:21", + "pc": [ + 157 + ] + }, + { + "teal": 159, + "source": "tests/contracts/binary.algo.ts:21", + "pc": [ + 158, + 159, + 160 + ] + }, + { + "teal": 163, + "source": "tests/contracts/binary.algo.ts:22", + "pc": [ + 161, + 162 + ] + }, + { + "teal": 164, + "source": "tests/contracts/binary.algo.ts:22", + "pc": [ + 163, + 164 + ] + }, + { + "teal": 165, + "source": "tests/contracts/binary.algo.ts:22", + "pc": [ + 165 + ] + }, + { + "teal": 166, + "source": "tests/contracts/binary.algo.ts:22", + "pc": [ + 166 + ] + }, + { + "teal": 167, + "source": "tests/contracts/binary.algo.ts:21", + "pc": [ + 167 + ] + }, + { + "teal": 172, + "source": "tests/contracts/binary.algo.ts:25", + "pc": [ + 168, + 169, + 170 + ] + }, + { + "teal": 173, + "source": "tests/contracts/binary.algo.ts:25", + "pc": [ + 171 + ] + }, + { + "teal": 176, + "source": "tests/contracts/binary.algo.ts:25", + "pc": [ + 172, + 173, + 174 + ] + }, + { + "teal": 177, + "source": "tests/contracts/binary.algo.ts:25", + "pc": [ + 175 + ] + }, + { + "teal": 180, + "source": "tests/contracts/binary.algo.ts:25", + "pc": [ + 176, + 177, + 178 + ] + }, + { + "teal": 181, + "source": "tests/contracts/binary.algo.ts:25", + "pc": [ + 179, + 180 + ] + }, + { + "teal": 182, + "source": "tests/contracts/binary.algo.ts:25", + "pc": [ + 181 + ] + }, + { + "teal": 186, + "source": "tests/contracts/binary.algo.ts:25", + "pc": [ + 182, + 183, + 184 + ] + }, + { + "teal": 190, + "source": "tests/contracts/binary.algo.ts:26", + "pc": [ + 185, + 186 + ] + }, + { + "teal": 191, + "source": "tests/contracts/binary.algo.ts:26", + "pc": [ + 187, + 188 + ] + }, + { + "teal": 192, + "source": "tests/contracts/binary.algo.ts:26", + "pc": [ + 189 + ] + }, + { + "teal": 193, + "source": "tests/contracts/binary.algo.ts:26", + "pc": [ + 190 + ] + }, + { + "teal": 194, + "source": "tests/contracts/binary.algo.ts:25", + "pc": [ + 191 + ] + }, + { + "teal": 199, + "source": "tests/contracts/binary.algo.ts:29", + "pc": [ + 192, + 193, + 194 + ] + }, + { + "teal": 200, + "source": "tests/contracts/binary.algo.ts:29", + "pc": [ + 195 + ] + }, + { + "teal": 203, + "source": "tests/contracts/binary.algo.ts:29", + "pc": [ + 196, + 197, + 198 + ] + }, + { + "teal": 204, + "source": "tests/contracts/binary.algo.ts:29", + "pc": [ + 199 + ] + }, + { + "teal": 207, + "source": "tests/contracts/binary.algo.ts:29", + "pc": [ + 200, + 201, + 202 + ] + }, + { + "teal": 208, + "source": "tests/contracts/binary.algo.ts:29", + "pc": [ + 203, + 204 + ] + }, + { + "teal": 209, + "source": "tests/contracts/binary.algo.ts:29", + "pc": [ + 205 + ] + }, + { + "teal": 213, + "source": "tests/contracts/binary.algo.ts:29", + "pc": [ + 206, + 207, + 208 + ] + }, + { + "teal": 217, + "source": "tests/contracts/binary.algo.ts:30", + "pc": [ + 209, + 210 + ] + }, + { + "teal": 218, + "source": "tests/contracts/binary.algo.ts:30", + "pc": [ + 211, + 212 + ] + }, + { + "teal": 219, + "source": "tests/contracts/binary.algo.ts:30", + "pc": [ + 213 + ] + }, + { + "teal": 220, + "source": "tests/contracts/binary.algo.ts:30", + "pc": [ + 214 + ] + }, + { + "teal": 221, + "source": "tests/contracts/binary.algo.ts:29", + "pc": [ + 215 + ] + }, + { + "teal": 226, + "source": "tests/contracts/binary.algo.ts:33", + "pc": [ + 216, + 217, + 218 + ] + }, + { + "teal": 227, + "source": "tests/contracts/binary.algo.ts:33", + "pc": [ + 219 + ] + }, + { + "teal": 230, + "source": "tests/contracts/binary.algo.ts:33", + "pc": [ + 220, + 221, + 222 + ] + }, + { + "teal": 231, + "source": "tests/contracts/binary.algo.ts:33", + "pc": [ + 223 + ] + }, + { + "teal": 234, + "source": "tests/contracts/binary.algo.ts:33", + "pc": [ + 224, + 225, + 226 + ] + }, + { + "teal": 235, + "source": "tests/contracts/binary.algo.ts:33", + "pc": [ + 227 + ] + }, + { + "teal": 238, + "source": "tests/contracts/binary.algo.ts:33", + "pc": [ + 228, + 229, + 230 + ] + }, + { + "teal": 239, + "source": "tests/contracts/binary.algo.ts:33", + "pc": [ + 231, + 232 + ] + }, + { + "teal": 240, + "source": "tests/contracts/binary.algo.ts:33", + "pc": [ + 233 + ] + }, + { + "teal": 244, + "source": "tests/contracts/binary.algo.ts:33", + "pc": [ + 234, + 235, + 236 + ] + }, + { + "teal": 248, + "source": "tests/contracts/binary.algo.ts:34", + "pc": [ + 237, + 238 + ] + }, + { + "teal": 249, + "source": "tests/contracts/binary.algo.ts:34", + "pc": [ + 239 + ] + }, + { + "teal": 250, + "source": "tests/contracts/binary.algo.ts:34", + "pc": [ + 240, + 241, + 242 + ] + }, + { + "teal": 251, + "source": "tests/contracts/binary.algo.ts:34", + "pc": [ + 243, + 244 + ] + }, + { + "teal": 252, + "source": "tests/contracts/binary.algo.ts:34", + "pc": [ + 245 + ] + }, + { + "teal": 253, + "source": "tests/contracts/binary.algo.ts:34", + "pc": [ + 246, + 247, + 248 + ] + }, + { + "teal": 254, + "source": "tests/contracts/binary.algo.ts:34", + "pc": [ + 249, + 250 + ] + }, + { + "teal": 255, + "source": "tests/contracts/binary.algo.ts:34", + "pc": [ + 251 + ] + }, + { + "teal": 258, + "source": "tests/contracts/binary.algo.ts:34", + "pc": [ + 252 + ] + }, + { + "teal": 261, + "source": "tests/contracts/binary.algo.ts:34", + "pc": [ + 253 + ] + }, + { + "teal": 262, + "source": "tests/contracts/binary.algo.ts:33", + "pc": [ + 254 + ] + }, + { + "teal": 265, + "source": "tests/contracts/binary.algo.ts:4", + "pc": [ + 255, + 256 + ] + }, + { + "teal": 266, + "source": "tests/contracts/binary.algo.ts:4", + "pc": [ + 257 + ] + }, + { + "teal": 269, + "source": "tests/contracts/binary.algo.ts:4", + "pc": [ + 258, + 259, + 260, + 261, + 262, + 263 + ] + }, + { + "teal": 270, + "source": "tests/contracts/binary.algo.ts:4", + "pc": [ + 264, + 265, + 266 + ] + }, + { + "teal": 271, + "source": "tests/contracts/binary.algo.ts:4", + "pc": [ + 267, + 268, + 269, + 270 + ] + }, + { + "teal": 274, + "source": "tests/contracts/binary.algo.ts:4", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 271 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 277, + "source": "tests/contracts/binary.algo.ts:4", + "pc": [ + 272, + 273, + 274, + 275, + 276, + 277 + ] + }, + { + "teal": 278, + "source": "tests/contracts/binary.algo.ts:4", + "pc": [ + 278, + 279, + 280, + 281, + 282, + 283 + ] + }, + { + "teal": 279, + "source": "tests/contracts/binary.algo.ts:4", + "pc": [ + 284, + 285, + 286, + 287, + 288, + 289 + ] + }, + { + "teal": 280, + "source": "tests/contracts/binary.algo.ts:4", + "pc": [ + 290, + 291, + 292, + 293, + 294, + 295 + ] + }, + { + "teal": 281, + "source": "tests/contracts/binary.algo.ts:4", + "pc": [ + 296, + 297, + 298, + 299, + 300, + 301 + ] + }, + { + "teal": 282, + "source": "tests/contracts/binary.algo.ts:4", + "pc": [ + 302, + 303, + 304, + 305, + 306, + 307 + ] + }, + { + "teal": 283, + "source": "tests/contracts/binary.algo.ts:4", + "pc": [ + 308, + 309, + 310, + 311, + 312, + 313 + ] + }, + { + "teal": 284, + "source": "tests/contracts/binary.algo.ts:4", + "pc": [ + 314, + 315, + 316, + 317, + 318, + 319 + ] + }, + { + "teal": 285, + "source": "tests/contracts/binary.algo.ts:4", + "pc": [ + 320, + 321, + 322 + ] + }, + { + "teal": 286, + "source": "tests/contracts/binary.algo.ts:4", + "pc": [ + 323, + 324, + 325, + 326, + 327, + 328, + 329, + 330, + 331, + 332, + 333, + 334, + 335, + 336, + 337, + 338, + 339, + 340 + ] }, { + "teal": 289, + "source": "tests/contracts/binary.algo.ts:4", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 341 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/BytecblockTest.arc56_draft.json b/tests/contracts/artifacts/BytecblockTest.arc56_draft.json index e08f45e04..8986bee68 100644 --- a/tests/contracts/artifacts/BytecblockTest.arc56_draft.json +++ b/tests/contracts/artifacts/BytecblockTest.arc56_draft.json @@ -70,22 +70,9388 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/cblocks.algo.ts:270", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/cblocks.algo.ts:270", + "pc": [ + 1, + 2, + 3, + 4, + 5, + 6, + 7, + 8, + 9, + 10, + 11, + 12, + 13, + 14, + 15, + 16 + ] + }, + { + "teal": 14, + "source": "tests/contracts/cblocks.algo.ts:270", + "pc": [ + 17, + 18 + ] + }, + { + "teal": 15, + "source": "tests/contracts/cblocks.algo.ts:270", + "pc": [ + 19 + ] + }, + { + "teal": 16, + "source": "tests/contracts/cblocks.algo.ts:270", + "pc": [ + 20, + 21 + ] + }, + { + "teal": 17, + "source": "tests/contracts/cblocks.algo.ts:270", + "pc": [ + 22 + ] + }, + { + "teal": 18, + "source": "tests/contracts/cblocks.algo.ts:270", + "pc": [ + 23, + 24 + ] + }, + { + "teal": 19, + "source": "tests/contracts/cblocks.algo.ts:270", + "pc": [ + 25 + ] + }, + { + "teal": 20, + "source": "tests/contracts/cblocks.algo.ts:270", + "pc": [ + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38, + 39, + 40, + 41, + 42, + 43, + 44, + 45, + 46, + 47, + 48, + 49, + 50, + 51 + ] + }, + { + "teal": 24, + "source": "tests/contracts/cblocks.algo.ts:270", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 52 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/cblocks.algo.ts:273", + "pc": [ + 53, + 54, + 55, + 56, + 57, + 58 + ] + }, + { + "teal": 32, + "source": "tests/contracts/cblocks.algo.ts:273", + "pc": [ + 59, + 60, + 61 + ] + }, + { + "teal": 33, + "source": "tests/contracts/cblocks.algo.ts:273", + "pc": [ + 62 + ] + }, + { + "teal": 34, + "source": "tests/contracts/cblocks.algo.ts:273", + "pc": [ + 63 + ] + }, + { + "teal": 35, + "source": "tests/contracts/cblocks.algo.ts:273", + "pc": [ + 64 + ] + }, + { + "teal": 36, + "source": "tests/contracts/cblocks.algo.ts:273", + "pc": [ + 65, + 66, + 67 + ] + }, + { + "teal": 37, + "source": "tests/contracts/cblocks.algo.ts:273", + "pc": [ + 68 + ] + }, + { + "teal": 38, + "source": "tests/contracts/cblocks.algo.ts:273", + "pc": [ + 69 + ] + }, + { + "teal": 39, + "source": "tests/contracts/cblocks.algo.ts:273", + "pc": [ + 70 + ] + }, + { + "teal": 40, + "source": "tests/contracts/cblocks.algo.ts:273", + "pc": [ + 71 + ] + }, + { + "teal": 41, + "source": "tests/contracts/cblocks.algo.ts:273", + "pc": [ + 72, + 73 + ] + }, + { + "teal": 42, + "source": "tests/contracts/cblocks.algo.ts:273", + "pc": [ + 74 + ] + }, + { + "teal": 46, + "source": "tests/contracts/cblocks.algo.ts:273", + "pc": [ + 75, + 76, + 77 + ] + }, + { + "teal": 50, + "source": "tests/contracts/cblocks.algo.ts:274", + "pc": [ + 78 + ] + }, + { + "teal": 51, + "source": "tests/contracts/cblocks.algo.ts:274", + "pc": [ + 79, + 80 + ] + }, + { + "teal": 52, + "source": "tests/contracts/cblocks.algo.ts:274", + "pc": [ + 81, + 82 + ] + }, + { + "teal": 53, + "source": "tests/contracts/cblocks.algo.ts:274", + "pc": [ + 83, + 84 + ] + }, + { + "teal": 54, + "source": "tests/contracts/cblocks.algo.ts:274", + "pc": [ + 85, + 86 + ] + }, + { + "teal": 55, + "source": "tests/contracts/cblocks.algo.ts:274", + "pc": [ + 87, + 88, + 89, + 90, + 91 + ] + }, + { + "teal": 56, + "source": "tests/contracts/cblocks.algo.ts:274", + "pc": [ + 92 + ] + }, + { + "teal": 57, + "source": "tests/contracts/cblocks.algo.ts:274", + "pc": [ + 93, + 94 + ] + }, + { + "teal": 58, + "source": "tests/contracts/cblocks.algo.ts:274", + "pc": [ + 95, + 96 + ] + }, + { + "teal": 59, + "source": "tests/contracts/cblocks.algo.ts:274", + "pc": [ + 97, + 98 + ] + }, + { + "teal": 60, + "source": "tests/contracts/cblocks.algo.ts:274", + "pc": [ + 99, + 100 + ] + }, + { + "teal": 61, + "source": "tests/contracts/cblocks.algo.ts:274", + "pc": [ + 101 + ] + }, + { + "teal": 65, + "source": "tests/contracts/cblocks.algo.ts:276", + "pc": [ + 102, + 103, + 104, + 105, + 106, + 107, + 108, + 109, + 110, + 111, + 112 + ] + }, + { + "teal": 66, + "source": "tests/contracts/cblocks.algo.ts:276", + "pc": [ + 113, + 114, + 115 + ] + }, + { + "teal": 67, + "source": "tests/contracts/cblocks.algo.ts:276", + "pc": [ + 116 + ] + }, + { + "teal": 71, + "source": "tests/contracts/cblocks.algo.ts:277", + "pc": [ + 117, + 118, + 119, + 120, + 121, + 122, + 123, + 124, + 125, + 126, + 127 + ] + }, + { + "teal": 72, + "source": "tests/contracts/cblocks.algo.ts:277", + "pc": [ + 128, + 129, + 130 + ] + }, + { + "teal": 73, + "source": "tests/contracts/cblocks.algo.ts:277", + "pc": [ + 131 + ] + }, + { + "teal": 77, + "source": "tests/contracts/cblocks.algo.ts:278", + "pc": [ + 132, + 133, + 134, + 135, + 136, + 137, + 138, + 139, + 140, + 141, + 142 + ] + }, + { + "teal": 78, + "source": "tests/contracts/cblocks.algo.ts:278", + "pc": [ + 143, + 144, + 145 + ] + }, + { + "teal": 79, + "source": "tests/contracts/cblocks.algo.ts:278", + "pc": [ + 146 + ] + }, + { + "teal": 83, + "source": "tests/contracts/cblocks.algo.ts:279", + "pc": [ + 147, + 148, + 149, + 150, + 151, + 152, + 153, + 154, + 155, + 156, + 157 + ] + }, + { + "teal": 84, + "source": "tests/contracts/cblocks.algo.ts:279", + "pc": [ + 158, + 159, + 160 + ] + }, + { + "teal": 85, + "source": "tests/contracts/cblocks.algo.ts:279", + "pc": [ + 161 + ] + }, + { + "teal": 89, + "source": "tests/contracts/cblocks.algo.ts:280", + "pc": [ + 162, + 163, + 164, + 165, + 166, + 167, + 168, + 169, + 170, + 171, + 172 + ] + }, + { + "teal": 90, + "source": "tests/contracts/cblocks.algo.ts:280", + "pc": [ + 173, + 174, + 175 + ] + }, + { + "teal": 91, + "source": "tests/contracts/cblocks.algo.ts:280", + "pc": [ + 176 + ] + }, + { + "teal": 95, + "source": "tests/contracts/cblocks.algo.ts:281", + "pc": [ + 177, + 178, + 179, + 180, + 181, + 182, + 183, + 184, + 185, + 186, + 187 + ] + }, + { + "teal": 96, + "source": "tests/contracts/cblocks.algo.ts:281", + "pc": [ + 188, + 189, + 190 + ] + }, + { + "teal": 97, + "source": "tests/contracts/cblocks.algo.ts:281", + "pc": [ + 191 + ] + }, + { + "teal": 101, + "source": "tests/contracts/cblocks.algo.ts:282", + "pc": [ + 192, + 193, + 194, + 195, + 196, + 197, + 198, + 199, + 200, + 201, + 202 + ] + }, + { + "teal": 102, + "source": "tests/contracts/cblocks.algo.ts:282", + "pc": [ + 203, + 204, + 205 + ] + }, + { + "teal": 103, + "source": "tests/contracts/cblocks.algo.ts:282", + "pc": [ + 206 + ] + }, + { + "teal": 107, + "source": "tests/contracts/cblocks.algo.ts:283", + "pc": [ + 207, + 208, + 209, + 210, + 211, + 212, + 213, + 214, + 215, + 216, + 217 + ] + }, + { + "teal": 108, + "source": "tests/contracts/cblocks.algo.ts:283", + "pc": [ + 218, + 219, + 220 + ] + }, + { + "teal": 109, + "source": "tests/contracts/cblocks.algo.ts:283", + "pc": [ + 221 + ] + }, + { + "teal": 113, + "source": "tests/contracts/cblocks.algo.ts:284", + "pc": [ + 222, + 223, + 224, + 225, + 226, + 227, + 228, + 229, + 230, + 231, + 232 + ] + }, + { + "teal": 114, + "source": "tests/contracts/cblocks.algo.ts:284", + "pc": [ + 233, + 234, + 235, + 236 + ] + }, + { + "teal": 115, + "source": "tests/contracts/cblocks.algo.ts:284", + "pc": [ + 237 + ] + }, + { + "teal": 119, + "source": "tests/contracts/cblocks.algo.ts:285", + "pc": [ + 238, + 239, + 240, + 241, + 242, + 243, + 244, + 245, + 246, + 247, + 248 + ] + }, + { + "teal": 120, + "source": "tests/contracts/cblocks.algo.ts:285", + "pc": [ + 249, + 250, + 251, + 252 + ] + }, + { + "teal": 121, + "source": "tests/contracts/cblocks.algo.ts:285", + "pc": [ + 253 + ] + }, + { + "teal": 125, + "source": "tests/contracts/cblocks.algo.ts:286", + "pc": [ + 254, + 255, + 256, + 257, + 258, + 259, + 260, + 261, + 262, + 263, + 264 + ] + }, + { + "teal": 126, + "source": "tests/contracts/cblocks.algo.ts:286", + "pc": [ + 265, + 266, + 267, + 268 + ] + }, + { + "teal": 127, + "source": "tests/contracts/cblocks.algo.ts:286", + "pc": [ + 269 + ] + }, + { + "teal": 131, + "source": "tests/contracts/cblocks.algo.ts:287", + "pc": [ + 270, + 271, + 272, + 273, + 274, + 275, + 276, + 277, + 278, + 279, + 280 + ] + }, + { + "teal": 132, + "source": "tests/contracts/cblocks.algo.ts:287", + "pc": [ + 281, + 282, + 283, + 284 + ] + }, + { + "teal": 133, + "source": "tests/contracts/cblocks.algo.ts:287", + "pc": [ + 285 + ] + }, + { + "teal": 137, + "source": "tests/contracts/cblocks.algo.ts:288", + "pc": [ + 286, + 287, + 288, + 289, + 290, + 291, + 292, + 293, + 294, + 295, + 296 + ] + }, + { + "teal": 138, + "source": "tests/contracts/cblocks.algo.ts:288", + "pc": [ + 297, + 298, + 299, + 300 + ] + }, + { + "teal": 139, + "source": "tests/contracts/cblocks.algo.ts:288", + "pc": [ + 301 + ] + }, + { + "teal": 143, + "source": "tests/contracts/cblocks.algo.ts:289", + "pc": [ + 302, + 303, + 304, + 305, + 306, + 307, + 308, + 309, + 310, + 311, + 312 + ] + }, + { + "teal": 144, + "source": "tests/contracts/cblocks.algo.ts:289", + "pc": [ + 313, + 314, + 315, + 316 + ] + }, + { + "teal": 145, + "source": "tests/contracts/cblocks.algo.ts:289", + "pc": [ + 317 + ] + }, + { + "teal": 149, + "source": "tests/contracts/cblocks.algo.ts:290", + "pc": [ + 318, + 319, + 320, + 321, + 322, + 323, + 324, + 325, + 326, + 327, + 328 + ] + }, + { + "teal": 150, + "source": "tests/contracts/cblocks.algo.ts:290", + "pc": [ + 329, + 330, + 331, + 332 + ] + }, + { + "teal": 151, + "source": "tests/contracts/cblocks.algo.ts:290", + "pc": [ + 333 + ] + }, + { + "teal": 155, + "source": "tests/contracts/cblocks.algo.ts:291", + "pc": [ + 334, + 335, + 336, + 337, + 338, + 339, + 340, + 341, + 342, + 343, + 344 + ] + }, + { + "teal": 156, + "source": "tests/contracts/cblocks.algo.ts:291", + "pc": [ + 345, + 346, + 347, + 348 + ] + }, + { + "teal": 157, + "source": "tests/contracts/cblocks.algo.ts:291", + "pc": [ + 349 + ] + }, + { + "teal": 161, + "source": "tests/contracts/cblocks.algo.ts:292", + "pc": [ + 350, + 351, + 352, + 353, + 354, + 355, + 356, + 357, + 358, + 359, + 360 + ] + }, + { + "teal": 162, + "source": "tests/contracts/cblocks.algo.ts:292", + "pc": [ + 361, + 362, + 363, + 364 + ] + }, + { + "teal": 163, + "source": "tests/contracts/cblocks.algo.ts:292", + "pc": [ + 365 + ] + }, + { + "teal": 167, + "source": "tests/contracts/cblocks.algo.ts:293", + "pc": [ + 366, + 367, + 368, + 369, + 370, + 371, + 372, + 373, + 374, + 375, + 376 + ] + }, + { + "teal": 168, + "source": "tests/contracts/cblocks.algo.ts:293", + "pc": [ + 377, + 378, + 379, + 380 + ] + }, + { + "teal": 169, + "source": "tests/contracts/cblocks.algo.ts:293", + "pc": [ + 381 + ] + }, + { + "teal": 173, + "source": "tests/contracts/cblocks.algo.ts:294", + "pc": [ + 382, + 383, + 384, + 385, + 386, + 387, + 388, + 389, + 390, + 391, + 392 + ] + }, + { + "teal": 174, + "source": "tests/contracts/cblocks.algo.ts:294", + "pc": [ + 393, + 394, + 395, + 396 + ] + }, + { + "teal": 175, + "source": "tests/contracts/cblocks.algo.ts:294", + "pc": [ + 397 + ] + }, + { + "teal": 179, + "source": "tests/contracts/cblocks.algo.ts:295", + "pc": [ + 398, + 399, + 400, + 401, + 402, + 403, + 404, + 405, + 406, + 407, + 408 + ] + }, + { + "teal": 180, + "source": "tests/contracts/cblocks.algo.ts:295", + "pc": [ + 409, + 410, + 411, + 412 + ] + }, + { + "teal": 181, + "source": "tests/contracts/cblocks.algo.ts:295", + "pc": [ + 413 + ] + }, + { + "teal": 185, + "source": "tests/contracts/cblocks.algo.ts:296", + "pc": [ + 414, + 415, + 416, + 417, + 418, + 419, + 420, + 421, + 422, + 423, + 424 + ] + }, + { + "teal": 186, + "source": "tests/contracts/cblocks.algo.ts:296", + "pc": [ + 425, + 426, + 427, + 428 + ] + }, + { + "teal": 187, + "source": "tests/contracts/cblocks.algo.ts:296", + "pc": [ + 429 + ] + }, + { + "teal": 191, + "source": "tests/contracts/cblocks.algo.ts:297", + "pc": [ + 430, + 431, + 432, + 433, + 434, + 435, + 436, + 437, + 438, + 439, + 440 + ] + }, + { + "teal": 192, + "source": "tests/contracts/cblocks.algo.ts:297", + "pc": [ + 441, + 442, + 443, + 444 + ] + }, + { + "teal": 193, + "source": "tests/contracts/cblocks.algo.ts:297", + "pc": [ + 445 + ] + }, + { + "teal": 197, + "source": "tests/contracts/cblocks.algo.ts:298", + "pc": [ + 446, + 447, + 448, + 449, + 450, + 451, + 452, + 453, + 454, + 455, + 456 + ] + }, + { + "teal": 198, + "source": "tests/contracts/cblocks.algo.ts:298", + "pc": [ + 457, + 458, + 459, + 460 + ] + }, + { + "teal": 199, + "source": "tests/contracts/cblocks.algo.ts:298", + "pc": [ + 461 + ] + }, + { + "teal": 203, + "source": "tests/contracts/cblocks.algo.ts:299", + "pc": [ + 462, + 463, + 464, + 465, + 466, + 467, + 468, + 469, + 470, + 471, + 472 + ] + }, + { + "teal": 204, + "source": "tests/contracts/cblocks.algo.ts:299", + "pc": [ + 473, + 474, + 475, + 476 + ] + }, + { + "teal": 205, + "source": "tests/contracts/cblocks.algo.ts:299", + "pc": [ + 477 + ] + }, + { + "teal": 209, + "source": "tests/contracts/cblocks.algo.ts:300", + "pc": [ + 478, + 479, + 480, + 481, + 482, + 483, + 484, + 485, + 486, + 487, + 488 + ] + }, + { + "teal": 210, + "source": "tests/contracts/cblocks.algo.ts:300", + "pc": [ + 489, + 490, + 491, + 492 + ] + }, + { + "teal": 211, + "source": "tests/contracts/cblocks.algo.ts:300", + "pc": [ + 493 + ] + }, + { + "teal": 215, + "source": "tests/contracts/cblocks.algo.ts:301", + "pc": [ + 494, + 495, + 496, + 497, + 498, + 499, + 500, + 501, + 502, + 503, + 504 + ] + }, + { + "teal": 216, + "source": "tests/contracts/cblocks.algo.ts:301", + "pc": [ + 505, + 506, + 507, + 508 + ] + }, + { + "teal": 217, + "source": "tests/contracts/cblocks.algo.ts:301", + "pc": [ + 509 + ] + }, + { + "teal": 221, + "source": "tests/contracts/cblocks.algo.ts:302", + "pc": [ + 510, + 511, + 512, + 513, + 514, + 515, + 516, + 517, + 518, + 519, + 520 + ] + }, + { + "teal": 222, + "source": "tests/contracts/cblocks.algo.ts:302", + "pc": [ + 521, + 522, + 523, + 524 + ] + }, + { + "teal": 223, + "source": "tests/contracts/cblocks.algo.ts:302", + "pc": [ + 525 + ] + }, + { + "teal": 227, + "source": "tests/contracts/cblocks.algo.ts:303", + "pc": [ + 526, + 527, + 528, + 529, + 530, + 531, + 532, + 533, + 534, + 535, + 536 + ] + }, + { + "teal": 228, + "source": "tests/contracts/cblocks.algo.ts:303", + "pc": [ + 537, + 538, + 539, + 540 + ] + }, + { + "teal": 229, + "source": "tests/contracts/cblocks.algo.ts:303", + "pc": [ + 541 + ] + }, + { + "teal": 233, + "source": "tests/contracts/cblocks.algo.ts:304", + "pc": [ + 542, + 543, + 544, + 545, + 546, + 547, + 548, + 549, + 550, + 551, + 552 + ] + }, + { + "teal": 234, + "source": "tests/contracts/cblocks.algo.ts:304", + "pc": [ + 553, + 554, + 555, + 556 + ] + }, + { + "teal": 235, + "source": "tests/contracts/cblocks.algo.ts:304", + "pc": [ + 557 + ] + }, + { + "teal": 239, + "source": "tests/contracts/cblocks.algo.ts:305", + "pc": [ + 558, + 559, + 560, + 561, + 562, + 563, + 564, + 565, + 566, + 567, + 568 + ] + }, + { + "teal": 240, + "source": "tests/contracts/cblocks.algo.ts:305", + "pc": [ + 569, + 570, + 571, + 572 + ] + }, + { + "teal": 241, + "source": "tests/contracts/cblocks.algo.ts:305", + "pc": [ + 573 + ] + }, + { + "teal": 245, + "source": "tests/contracts/cblocks.algo.ts:306", + "pc": [ + 574, + 575, + 576, + 577, + 578, + 579, + 580, + 581, + 582, + 583, + 584 + ] + }, + { + "teal": 246, + "source": "tests/contracts/cblocks.algo.ts:306", + "pc": [ + 585, + 586, + 587, + 588 + ] + }, + { + "teal": 247, + "source": "tests/contracts/cblocks.algo.ts:306", + "pc": [ + 589 + ] + }, + { + "teal": 251, + "source": "tests/contracts/cblocks.algo.ts:307", + "pc": [ + 590, + 591, + 592, + 593, + 594, + 595, + 596, + 597, + 598, + 599, + 600 + ] + }, + { + "teal": 252, + "source": "tests/contracts/cblocks.algo.ts:307", + "pc": [ + 601, + 602, + 603, + 604 + ] + }, + { + "teal": 253, + "source": "tests/contracts/cblocks.algo.ts:307", + "pc": [ + 605 + ] + }, + { + "teal": 257, + "source": "tests/contracts/cblocks.algo.ts:308", + "pc": [ + 606, + 607, + 608, + 609, + 610, + 611, + 612, + 613, + 614, + 615, + 616 + ] + }, + { + "teal": 258, + "source": "tests/contracts/cblocks.algo.ts:308", + "pc": [ + 617, + 618, + 619, + 620 + ] + }, + { + "teal": 259, + "source": "tests/contracts/cblocks.algo.ts:308", + "pc": [ + 621 + ] + }, + { + "teal": 263, + "source": "tests/contracts/cblocks.algo.ts:309", + "pc": [ + 622, + 623, + 624, + 625, + 626, + 627, + 628, + 629, + 630, + 631, + 632 + ] + }, + { + "teal": 264, + "source": "tests/contracts/cblocks.algo.ts:309", + "pc": [ + 633, + 634, + 635, + 636 + ] + }, + { + "teal": 265, + "source": "tests/contracts/cblocks.algo.ts:309", + "pc": [ + 637 + ] + }, + { + "teal": 269, + "source": "tests/contracts/cblocks.algo.ts:310", + "pc": [ + 638, + 639, + 640, + 641, + 642, + 643, + 644, + 645, + 646, + 647, + 648 + ] + }, + { + "teal": 270, + "source": "tests/contracts/cblocks.algo.ts:310", + "pc": [ + 649, + 650, + 651, + 652 + ] + }, + { + "teal": 271, + "source": "tests/contracts/cblocks.algo.ts:310", + "pc": [ + 653 + ] + }, + { + "teal": 275, + "source": "tests/contracts/cblocks.algo.ts:311", + "pc": [ + 654, + 655, + 656, + 657, + 658, + 659, + 660, + 661, + 662, + 663, + 664 + ] + }, + { + "teal": 276, + "source": "tests/contracts/cblocks.algo.ts:311", + "pc": [ + 665, + 666, + 667, + 668 + ] + }, + { + "teal": 277, + "source": "tests/contracts/cblocks.algo.ts:311", + "pc": [ + 669 + ] + }, + { + "teal": 281, + "source": "tests/contracts/cblocks.algo.ts:312", + "pc": [ + 670, + 671, + 672, + 673, + 674, + 675, + 676, + 677, + 678, + 679, + 680 + ] + }, + { + "teal": 282, + "source": "tests/contracts/cblocks.algo.ts:312", + "pc": [ + 681, + 682, + 683, + 684 + ] + }, + { + "teal": 283, + "source": "tests/contracts/cblocks.algo.ts:312", + "pc": [ + 685 + ] + }, + { + "teal": 287, + "source": "tests/contracts/cblocks.algo.ts:313", + "pc": [ + 686, + 687, + 688, + 689, + 690, + 691, + 692, + 693, + 694, + 695, + 696 + ] + }, + { + "teal": 288, + "source": "tests/contracts/cblocks.algo.ts:313", + "pc": [ + 697, + 698, + 699, + 700 + ] + }, + { + "teal": 289, + "source": "tests/contracts/cblocks.algo.ts:313", + "pc": [ + 701 + ] + }, + { + "teal": 293, + "source": "tests/contracts/cblocks.algo.ts:314", + "pc": [ + 702, + 703, + 704, + 705, + 706, + 707, + 708, + 709, + 710, + 711, + 712 + ] + }, + { + "teal": 294, + "source": "tests/contracts/cblocks.algo.ts:314", + "pc": [ + 713, + 714, + 715, + 716 + ] + }, + { + "teal": 295, + "source": "tests/contracts/cblocks.algo.ts:314", + "pc": [ + 717 + ] + }, + { + "teal": 299, + "source": "tests/contracts/cblocks.algo.ts:315", + "pc": [ + 718, + 719, + 720, + 721, + 722, + 723, + 724, + 725, + 726, + 727, + 728 + ] + }, + { + "teal": 300, + "source": "tests/contracts/cblocks.algo.ts:315", + "pc": [ + 729, + 730, + 731, + 732 + ] + }, + { + "teal": 301, + "source": "tests/contracts/cblocks.algo.ts:315", + "pc": [ + 733 + ] + }, + { + "teal": 305, + "source": "tests/contracts/cblocks.algo.ts:316", + "pc": [ + 734, + 735, + 736, + 737, + 738, + 739, + 740, + 741, + 742, + 743, + 744 + ] + }, + { + "teal": 306, + "source": "tests/contracts/cblocks.algo.ts:316", + "pc": [ + 745, + 746, + 747, + 748 + ] + }, + { + "teal": 307, + "source": "tests/contracts/cblocks.algo.ts:316", + "pc": [ + 749 + ] + }, + { + "teal": 311, + "source": "tests/contracts/cblocks.algo.ts:317", + "pc": [ + 750, + 751, + 752, + 753, + 754, + 755, + 756, + 757, + 758, + 759, + 760 + ] + }, + { + "teal": 312, + "source": "tests/contracts/cblocks.algo.ts:317", + "pc": [ + 761, + 762, + 763, + 764 + ] + }, + { + "teal": 313, + "source": "tests/contracts/cblocks.algo.ts:317", + "pc": [ + 765 + ] + }, + { + "teal": 317, + "source": "tests/contracts/cblocks.algo.ts:318", + "pc": [ + 766, + 767, + 768, + 769, + 770, + 771, + 772, + 773, + 774, + 775, + 776 + ] + }, + { + "teal": 318, + "source": "tests/contracts/cblocks.algo.ts:318", + "pc": [ + 777, + 778, + 779, + 780 + ] + }, + { + "teal": 319, + "source": "tests/contracts/cblocks.algo.ts:318", + "pc": [ + 781 + ] + }, + { + "teal": 323, + "source": "tests/contracts/cblocks.algo.ts:319", + "pc": [ + 782, + 783, + 784, + 785, + 786, + 787, + 788, + 789, + 790, + 791, + 792 + ] + }, + { + "teal": 324, + "source": "tests/contracts/cblocks.algo.ts:319", + "pc": [ + 793, + 794, + 795, + 796 + ] + }, + { + "teal": 325, + "source": "tests/contracts/cblocks.algo.ts:319", + "pc": [ + 797 + ] + }, + { + "teal": 329, + "source": "tests/contracts/cblocks.algo.ts:320", + "pc": [ + 798, + 799, + 800, + 801, + 802, + 803, + 804, + 805, + 806, + 807, + 808 + ] + }, + { + "teal": 330, + "source": "tests/contracts/cblocks.algo.ts:320", + "pc": [ + 809, + 810, + 811, + 812 + ] + }, + { + "teal": 331, + "source": "tests/contracts/cblocks.algo.ts:320", + "pc": [ + 813 + ] + }, + { + "teal": 335, + "source": "tests/contracts/cblocks.algo.ts:321", + "pc": [ + 814, + 815, + 816, + 817, + 818, + 819, + 820, + 821, + 822, + 823, + 824 + ] + }, + { + "teal": 336, + "source": "tests/contracts/cblocks.algo.ts:321", + "pc": [ + 825, + 826, + 827, + 828 + ] + }, + { + "teal": 337, + "source": "tests/contracts/cblocks.algo.ts:321", + "pc": [ + 829 + ] + }, + { + "teal": 341, + "source": "tests/contracts/cblocks.algo.ts:322", + "pc": [ + 830, + 831, + 832, + 833, + 834, + 835, + 836, + 837, + 838, + 839, + 840 + ] + }, + { + "teal": 342, + "source": "tests/contracts/cblocks.algo.ts:322", + "pc": [ + 841, + 842, + 843, + 844 + ] + }, + { + "teal": 343, + "source": "tests/contracts/cblocks.algo.ts:322", + "pc": [ + 845 + ] + }, + { + "teal": 347, + "source": "tests/contracts/cblocks.algo.ts:323", + "pc": [ + 846, + 847, + 848, + 849, + 850, + 851, + 852, + 853, + 854, + 855, + 856 + ] + }, + { + "teal": 348, + "source": "tests/contracts/cblocks.algo.ts:323", + "pc": [ + 857, + 858, + 859, + 860 + ] + }, + { + "teal": 349, + "source": "tests/contracts/cblocks.algo.ts:323", + "pc": [ + 861 + ] + }, + { + "teal": 353, + "source": "tests/contracts/cblocks.algo.ts:324", + "pc": [ + 862, + 863, + 864, + 865, + 866, + 867, + 868, + 869, + 870, + 871, + 872 + ] + }, + { + "teal": 354, + "source": "tests/contracts/cblocks.algo.ts:324", + "pc": [ + 873, + 874, + 875, + 876 + ] + }, + { + "teal": 355, + "source": "tests/contracts/cblocks.algo.ts:324", + "pc": [ + 877 + ] + }, + { + "teal": 359, + "source": "tests/contracts/cblocks.algo.ts:325", + "pc": [ + 878, + 879, + 880, + 881, + 882, + 883, + 884, + 885, + 886, + 887, + 888 + ] + }, + { + "teal": 360, + "source": "tests/contracts/cblocks.algo.ts:325", + "pc": [ + 889, + 890, + 891, + 892 + ] + }, + { + "teal": 361, + "source": "tests/contracts/cblocks.algo.ts:325", + "pc": [ + 893 + ] + }, + { + "teal": 365, + "source": "tests/contracts/cblocks.algo.ts:326", + "pc": [ + 894, + 895, + 896, + 897, + 898, + 899, + 900, + 901, + 902, + 903, + 904 + ] + }, + { + "teal": 366, + "source": "tests/contracts/cblocks.algo.ts:326", + "pc": [ + 905, + 906, + 907, + 908 + ] + }, + { + "teal": 367, + "source": "tests/contracts/cblocks.algo.ts:326", + "pc": [ + 909 + ] + }, + { + "teal": 371, + "source": "tests/contracts/cblocks.algo.ts:327", + "pc": [ + 910, + 911, + 912, + 913, + 914, + 915, + 916, + 917, + 918, + 919, + 920 + ] + }, + { + "teal": 372, + "source": "tests/contracts/cblocks.algo.ts:327", + "pc": [ + 921, + 922, + 923, + 924 + ] + }, + { + "teal": 373, + "source": "tests/contracts/cblocks.algo.ts:327", + "pc": [ + 925 + ] + }, + { + "teal": 377, + "source": "tests/contracts/cblocks.algo.ts:328", + "pc": [ + 926, + 927, + 928, + 929, + 930, + 931, + 932, + 933, + 934, + 935, + 936 + ] + }, + { + "teal": 378, + "source": "tests/contracts/cblocks.algo.ts:328", + "pc": [ + 937, + 938, + 939, + 940 + ] + }, + { + "teal": 379, + "source": "tests/contracts/cblocks.algo.ts:328", + "pc": [ + 941 + ] + }, + { + "teal": 383, + "source": "tests/contracts/cblocks.algo.ts:329", + "pc": [ + 942, + 943, + 944, + 945, + 946, + 947, + 948, + 949, + 950, + 951, + 952 + ] + }, + { + "teal": 384, + "source": "tests/contracts/cblocks.algo.ts:329", + "pc": [ + 953, + 954, + 955, + 956 + ] + }, + { + "teal": 385, + "source": "tests/contracts/cblocks.algo.ts:329", + "pc": [ + 957 + ] + }, + { + "teal": 389, + "source": "tests/contracts/cblocks.algo.ts:330", + "pc": [ + 958, + 959, + 960, + 961, + 962, + 963, + 964, + 965, + 966, + 967, + 968 + ] + }, + { + "teal": 390, + "source": "tests/contracts/cblocks.algo.ts:330", + "pc": [ + 969, + 970, + 971, + 972 + ] + }, + { + "teal": 391, + "source": "tests/contracts/cblocks.algo.ts:330", + "pc": [ + 973 + ] + }, + { + "teal": 395, + "source": "tests/contracts/cblocks.algo.ts:331", + "pc": [ + 974, + 975, + 976, + 977, + 978, + 979, + 980, + 981, + 982, + 983, + 984 + ] + }, + { + "teal": 396, + "source": "tests/contracts/cblocks.algo.ts:331", + "pc": [ + 985, + 986, + 987, + 988 + ] + }, + { + "teal": 397, + "source": "tests/contracts/cblocks.algo.ts:331", + "pc": [ + 989 + ] + }, + { + "teal": 401, + "source": "tests/contracts/cblocks.algo.ts:332", + "pc": [ + 990, + 991, + 992, + 993, + 994, + 995, + 996, + 997, + 998, + 999, + 1000 + ] + }, + { + "teal": 402, + "source": "tests/contracts/cblocks.algo.ts:332", + "pc": [ + 1001, + 1002, + 1003, + 1004 + ] + }, + { + "teal": 403, + "source": "tests/contracts/cblocks.algo.ts:332", + "pc": [ + 1005 + ] + }, + { + "teal": 407, + "source": "tests/contracts/cblocks.algo.ts:333", + "pc": [ + 1006, + 1007, + 1008, + 1009, + 1010, + 1011, + 1012, + 1013, + 1014, + 1015, + 1016 + ] + }, + { + "teal": 408, + "source": "tests/contracts/cblocks.algo.ts:333", + "pc": [ + 1017, + 1018, + 1019, + 1020 + ] + }, + { + "teal": 409, + "source": "tests/contracts/cblocks.algo.ts:333", + "pc": [ + 1021 + ] + }, + { + "teal": 413, + "source": "tests/contracts/cblocks.algo.ts:334", + "pc": [ + 1022, + 1023, + 1024, + 1025, + 1026, + 1027, + 1028, + 1029, + 1030, + 1031, + 1032 + ] + }, + { + "teal": 414, + "source": "tests/contracts/cblocks.algo.ts:334", + "pc": [ + 1033, + 1034, + 1035, + 1036 + ] + }, + { + "teal": 415, + "source": "tests/contracts/cblocks.algo.ts:334", + "pc": [ + 1037 + ] + }, + { + "teal": 419, + "source": "tests/contracts/cblocks.algo.ts:335", + "pc": [ + 1038, + 1039, + 1040, + 1041, + 1042, + 1043, + 1044, + 1045, + 1046, + 1047, + 1048 + ] + }, + { + "teal": 420, + "source": "tests/contracts/cblocks.algo.ts:335", + "pc": [ + 1049, + 1050, + 1051, + 1052 + ] + }, + { + "teal": 421, + "source": "tests/contracts/cblocks.algo.ts:335", + "pc": [ + 1053 + ] + }, + { + "teal": 425, + "source": "tests/contracts/cblocks.algo.ts:336", + "pc": [ + 1054, + 1055, + 1056, + 1057, + 1058, + 1059, + 1060, + 1061, + 1062, + 1063, + 1064 + ] + }, + { + "teal": 426, + "source": "tests/contracts/cblocks.algo.ts:336", + "pc": [ + 1065, + 1066, + 1067, + 1068 + ] + }, + { + "teal": 427, + "source": "tests/contracts/cblocks.algo.ts:336", + "pc": [ + 1069 + ] + }, + { + "teal": 431, + "source": "tests/contracts/cblocks.algo.ts:337", + "pc": [ + 1070, + 1071, + 1072, + 1073, + 1074, + 1075, + 1076, + 1077, + 1078, + 1079, + 1080 + ] + }, + { + "teal": 432, + "source": "tests/contracts/cblocks.algo.ts:337", + "pc": [ + 1081, + 1082, + 1083, + 1084 + ] + }, + { + "teal": 433, + "source": "tests/contracts/cblocks.algo.ts:337", + "pc": [ + 1085 + ] + }, + { + "teal": 437, + "source": "tests/contracts/cblocks.algo.ts:338", + "pc": [ + 1086, + 1087, + 1088, + 1089, + 1090, + 1091, + 1092, + 1093, + 1094, + 1095, + 1096 + ] + }, + { + "teal": 438, + "source": "tests/contracts/cblocks.algo.ts:338", + "pc": [ + 1097, + 1098, + 1099, + 1100 + ] + }, + { + "teal": 439, + "source": "tests/contracts/cblocks.algo.ts:338", + "pc": [ + 1101 + ] + }, + { + "teal": 443, + "source": "tests/contracts/cblocks.algo.ts:339", + "pc": [ + 1102, + 1103, + 1104, + 1105, + 1106, + 1107, + 1108, + 1109, + 1110, + 1111, + 1112 + ] + }, + { + "teal": 444, + "source": "tests/contracts/cblocks.algo.ts:339", + "pc": [ + 1113, + 1114, + 1115, + 1116 + ] + }, + { + "teal": 445, + "source": "tests/contracts/cblocks.algo.ts:339", + "pc": [ + 1117 + ] + }, + { + "teal": 449, + "source": "tests/contracts/cblocks.algo.ts:340", + "pc": [ + 1118, + 1119, + 1120, + 1121, + 1122, + 1123, + 1124, + 1125, + 1126, + 1127, + 1128 + ] + }, + { + "teal": 450, + "source": "tests/contracts/cblocks.algo.ts:340", + "pc": [ + 1129, + 1130, + 1131, + 1132 + ] + }, + { + "teal": 451, + "source": "tests/contracts/cblocks.algo.ts:340", + "pc": [ + 1133 + ] + }, + { + "teal": 455, + "source": "tests/contracts/cblocks.algo.ts:341", + "pc": [ + 1134, + 1135, + 1136, + 1137, + 1138, + 1139, + 1140, + 1141, + 1142, + 1143, + 1144 + ] + }, + { + "teal": 456, + "source": "tests/contracts/cblocks.algo.ts:341", + "pc": [ + 1145, + 1146, + 1147, + 1148 + ] + }, + { + "teal": 457, + "source": "tests/contracts/cblocks.algo.ts:341", + "pc": [ + 1149 + ] + }, + { + "teal": 461, + "source": "tests/contracts/cblocks.algo.ts:342", + "pc": [ + 1150, + 1151, + 1152, + 1153, + 1154, + 1155, + 1156, + 1157, + 1158, + 1159, + 1160 + ] + }, + { + "teal": 462, + "source": "tests/contracts/cblocks.algo.ts:342", + "pc": [ + 1161, + 1162, + 1163, + 1164 + ] + }, + { + "teal": 463, + "source": "tests/contracts/cblocks.algo.ts:342", + "pc": [ + 1165 + ] + }, + { + "teal": 467, + "source": "tests/contracts/cblocks.algo.ts:343", + "pc": [ + 1166, + 1167, + 1168, + 1169, + 1170, + 1171, + 1172, + 1173, + 1174, + 1175, + 1176 + ] + }, + { + "teal": 468, + "source": "tests/contracts/cblocks.algo.ts:343", + "pc": [ + 1177, + 1178, + 1179, + 1180 + ] + }, + { + "teal": 469, + "source": "tests/contracts/cblocks.algo.ts:343", + "pc": [ + 1181 + ] + }, + { + "teal": 473, + "source": "tests/contracts/cblocks.algo.ts:344", + "pc": [ + 1182, + 1183, + 1184, + 1185, + 1186, + 1187, + 1188, + 1189, + 1190, + 1191, + 1192 + ] + }, + { + "teal": 474, + "source": "tests/contracts/cblocks.algo.ts:344", + "pc": [ + 1193, + 1194, + 1195, + 1196 + ] + }, + { + "teal": 475, + "source": "tests/contracts/cblocks.algo.ts:344", + "pc": [ + 1197 + ] + }, + { + "teal": 479, + "source": "tests/contracts/cblocks.algo.ts:345", + "pc": [ + 1198, + 1199, + 1200, + 1201, + 1202, + 1203, + 1204, + 1205, + 1206, + 1207, + 1208 + ] + }, + { + "teal": 480, + "source": "tests/contracts/cblocks.algo.ts:345", + "pc": [ + 1209, + 1210, + 1211, + 1212 + ] + }, + { + "teal": 481, + "source": "tests/contracts/cblocks.algo.ts:345", + "pc": [ + 1213 + ] + }, + { + "teal": 485, + "source": "tests/contracts/cblocks.algo.ts:346", + "pc": [ + 1214, + 1215, + 1216, + 1217, + 1218, + 1219, + 1220, + 1221, + 1222, + 1223, + 1224 + ] + }, + { + "teal": 486, + "source": "tests/contracts/cblocks.algo.ts:346", + "pc": [ + 1225, + 1226, + 1227, + 1228 + ] + }, + { + "teal": 487, + "source": "tests/contracts/cblocks.algo.ts:346", + "pc": [ + 1229 + ] + }, + { + "teal": 491, + "source": "tests/contracts/cblocks.algo.ts:347", + "pc": [ + 1230, + 1231, + 1232, + 1233, + 1234, + 1235, + 1236, + 1237, + 1238, + 1239, + 1240 + ] + }, + { + "teal": 492, + "source": "tests/contracts/cblocks.algo.ts:347", + "pc": [ + 1241, + 1242, + 1243, + 1244 + ] + }, + { + "teal": 493, + "source": "tests/contracts/cblocks.algo.ts:347", + "pc": [ + 1245 + ] + }, + { + "teal": 497, + "source": "tests/contracts/cblocks.algo.ts:348", + "pc": [ + 1246, + 1247, + 1248, + 1249, + 1250, + 1251, + 1252, + 1253, + 1254, + 1255, + 1256 + ] + }, + { + "teal": 498, + "source": "tests/contracts/cblocks.algo.ts:348", + "pc": [ + 1257, + 1258, + 1259, + 1260 + ] + }, + { + "teal": 499, + "source": "tests/contracts/cblocks.algo.ts:348", + "pc": [ + 1261 + ] + }, + { + "teal": 503, + "source": "tests/contracts/cblocks.algo.ts:349", + "pc": [ + 1262, + 1263, + 1264, + 1265, + 1266, + 1267, + 1268, + 1269, + 1270, + 1271, + 1272 + ] + }, + { + "teal": 504, + "source": "tests/contracts/cblocks.algo.ts:349", + "pc": [ + 1273, + 1274, + 1275, + 1276 + ] + }, + { + "teal": 505, + "source": "tests/contracts/cblocks.algo.ts:349", + "pc": [ + 1277 + ] + }, + { + "teal": 509, + "source": "tests/contracts/cblocks.algo.ts:350", + "pc": [ + 1278, + 1279, + 1280, + 1281, + 1282, + 1283, + 1284, + 1285, + 1286, + 1287, + 1288 + ] + }, + { + "teal": 510, + "source": "tests/contracts/cblocks.algo.ts:350", + "pc": [ + 1289, + 1290, + 1291, + 1292 + ] + }, + { + "teal": 511, + "source": "tests/contracts/cblocks.algo.ts:350", + "pc": [ + 1293 + ] + }, + { + "teal": 515, + "source": "tests/contracts/cblocks.algo.ts:351", + "pc": [ + 1294, + 1295, + 1296, + 1297, + 1298, + 1299, + 1300, + 1301, + 1302, + 1303, + 1304 + ] + }, + { + "teal": 516, + "source": "tests/contracts/cblocks.algo.ts:351", + "pc": [ + 1305, + 1306, + 1307, + 1308 + ] + }, + { + "teal": 517, + "source": "tests/contracts/cblocks.algo.ts:351", + "pc": [ + 1309 + ] + }, + { + "teal": 521, + "source": "tests/contracts/cblocks.algo.ts:352", + "pc": [ + 1310, + 1311, + 1312, + 1313, + 1314, + 1315, + 1316, + 1317, + 1318, + 1319, + 1320 + ] + }, + { + "teal": 522, + "source": "tests/contracts/cblocks.algo.ts:352", + "pc": [ + 1321, + 1322, + 1323, + 1324 + ] + }, + { + "teal": 523, + "source": "tests/contracts/cblocks.algo.ts:352", + "pc": [ + 1325 + ] + }, + { + "teal": 527, + "source": "tests/contracts/cblocks.algo.ts:353", + "pc": [ + 1326, + 1327, + 1328, + 1329, + 1330, + 1331, + 1332, + 1333, + 1334, + 1335, + 1336 + ] + }, + { + "teal": 528, + "source": "tests/contracts/cblocks.algo.ts:353", + "pc": [ + 1337, + 1338, + 1339, + 1340 + ] + }, + { + "teal": 529, + "source": "tests/contracts/cblocks.algo.ts:353", + "pc": [ + 1341 + ] + }, + { + "teal": 533, + "source": "tests/contracts/cblocks.algo.ts:354", + "pc": [ + 1342, + 1343, + 1344, + 1345, + 1346, + 1347, + 1348, + 1349, + 1350, + 1351, + 1352 + ] + }, + { + "teal": 534, + "source": "tests/contracts/cblocks.algo.ts:354", + "pc": [ + 1353, + 1354, + 1355, + 1356 + ] + }, + { + "teal": 535, + "source": "tests/contracts/cblocks.algo.ts:354", + "pc": [ + 1357 + ] + }, + { + "teal": 539, + "source": "tests/contracts/cblocks.algo.ts:355", + "pc": [ + 1358, + 1359, + 1360, + 1361, + 1362, + 1363, + 1364, + 1365, + 1366, + 1367, + 1368 + ] + }, + { + "teal": 540, + "source": "tests/contracts/cblocks.algo.ts:355", + "pc": [ + 1369, + 1370, + 1371, + 1372 + ] + }, + { + "teal": 541, + "source": "tests/contracts/cblocks.algo.ts:355", + "pc": [ + 1373 + ] + }, + { + "teal": 545, + "source": "tests/contracts/cblocks.algo.ts:356", + "pc": [ + 1374, + 1375, + 1376, + 1377, + 1378, + 1379, + 1380, + 1381, + 1382, + 1383, + 1384 + ] + }, + { + "teal": 546, + "source": "tests/contracts/cblocks.algo.ts:356", + "pc": [ + 1385, + 1386, + 1387, + 1388 + ] + }, + { + "teal": 547, + "source": "tests/contracts/cblocks.algo.ts:356", + "pc": [ + 1389 + ] + }, + { + "teal": 551, + "source": "tests/contracts/cblocks.algo.ts:357", + "pc": [ + 1390, + 1391, + 1392, + 1393, + 1394, + 1395, + 1396, + 1397, + 1398, + 1399, + 1400 + ] + }, + { + "teal": 552, + "source": "tests/contracts/cblocks.algo.ts:357", + "pc": [ + 1401, + 1402, + 1403, + 1404 + ] + }, + { + "teal": 553, + "source": "tests/contracts/cblocks.algo.ts:357", + "pc": [ + 1405 + ] + }, + { + "teal": 557, + "source": "tests/contracts/cblocks.algo.ts:358", + "pc": [ + 1406, + 1407, + 1408, + 1409, + 1410, + 1411, + 1412, + 1413, + 1414, + 1415, + 1416 + ] + }, + { + "teal": 558, + "source": "tests/contracts/cblocks.algo.ts:358", + "pc": [ + 1417, + 1418, + 1419, + 1420 + ] + }, + { + "teal": 559, + "source": "tests/contracts/cblocks.algo.ts:358", + "pc": [ + 1421 + ] + }, + { + "teal": 563, + "source": "tests/contracts/cblocks.algo.ts:359", + "pc": [ + 1422, + 1423, + 1424, + 1425, + 1426, + 1427, + 1428, + 1429, + 1430, + 1431, + 1432 + ] + }, + { + "teal": 564, + "source": "tests/contracts/cblocks.algo.ts:359", + "pc": [ + 1433, + 1434, + 1435, + 1436 + ] + }, + { + "teal": 565, + "source": "tests/contracts/cblocks.algo.ts:359", + "pc": [ + 1437 + ] + }, + { + "teal": 569, + "source": "tests/contracts/cblocks.algo.ts:360", + "pc": [ + 1438, + 1439, + 1440, + 1441, + 1442, + 1443, + 1444, + 1445, + 1446, + 1447, + 1448 + ] + }, + { + "teal": 570, + "source": "tests/contracts/cblocks.algo.ts:360", + "pc": [ + 1449, + 1450, + 1451, + 1452 + ] + }, + { + "teal": 571, + "source": "tests/contracts/cblocks.algo.ts:360", + "pc": [ + 1453 + ] + }, + { + "teal": 575, + "source": "tests/contracts/cblocks.algo.ts:361", + "pc": [ + 1454, + 1455, + 1456, + 1457, + 1458, + 1459, + 1460, + 1461, + 1462, + 1463, + 1464 + ] + }, + { + "teal": 576, + "source": "tests/contracts/cblocks.algo.ts:361", + "pc": [ + 1465, + 1466, + 1467, + 1468 + ] + }, + { + "teal": 577, + "source": "tests/contracts/cblocks.algo.ts:361", + "pc": [ + 1469 + ] + }, + { + "teal": 581, + "source": "tests/contracts/cblocks.algo.ts:362", + "pc": [ + 1470, + 1471, + 1472, + 1473, + 1474, + 1475, + 1476, + 1477, + 1478, + 1479, + 1480 + ] + }, + { + "teal": 582, + "source": "tests/contracts/cblocks.algo.ts:362", + "pc": [ + 1481, + 1482, + 1483, + 1484 + ] + }, + { + "teal": 583, + "source": "tests/contracts/cblocks.algo.ts:362", + "pc": [ + 1485 + ] + }, + { + "teal": 587, + "source": "tests/contracts/cblocks.algo.ts:363", + "pc": [ + 1486, + 1487, + 1488, + 1489, + 1490, + 1491, + 1492, + 1493, + 1494, + 1495, + 1496 + ] + }, + { + "teal": 588, + "source": "tests/contracts/cblocks.algo.ts:363", + "pc": [ + 1497, + 1498, + 1499, + 1500 + ] + }, + { + "teal": 589, + "source": "tests/contracts/cblocks.algo.ts:363", + "pc": [ + 1501 + ] + }, + { + "teal": 593, + "source": "tests/contracts/cblocks.algo.ts:364", + "pc": [ + 1502, + 1503, + 1504, + 1505, + 1506, + 1507, + 1508, + 1509, + 1510, + 1511, + 1512 + ] + }, + { + "teal": 594, + "source": "tests/contracts/cblocks.algo.ts:364", + "pc": [ + 1513, + 1514, + 1515, + 1516 + ] + }, + { + "teal": 595, + "source": "tests/contracts/cblocks.algo.ts:364", + "pc": [ + 1517 + ] + }, + { + "teal": 599, + "source": "tests/contracts/cblocks.algo.ts:365", + "pc": [ + 1518, + 1519, + 1520, + 1521, + 1522, + 1523, + 1524, + 1525, + 1526, + 1527, + 1528 + ] + }, + { + "teal": 600, + "source": "tests/contracts/cblocks.algo.ts:365", + "pc": [ + 1529, + 1530, + 1531, + 1532 + ] + }, + { + "teal": 601, + "source": "tests/contracts/cblocks.algo.ts:365", + "pc": [ + 1533 + ] + }, + { + "teal": 605, + "source": "tests/contracts/cblocks.algo.ts:366", + "pc": [ + 1534, + 1535, + 1536, + 1537, + 1538, + 1539, + 1540, + 1541, + 1542, + 1543, + 1544 + ] + }, + { + "teal": 606, + "source": "tests/contracts/cblocks.algo.ts:366", + "pc": [ + 1545, + 1546, + 1547, + 1548 + ] + }, + { + "teal": 607, + "source": "tests/contracts/cblocks.algo.ts:366", + "pc": [ + 1549 + ] + }, + { + "teal": 611, + "source": "tests/contracts/cblocks.algo.ts:367", + "pc": [ + 1550, + 1551, + 1552, + 1553, + 1554, + 1555, + 1556, + 1557, + 1558, + 1559, + 1560 + ] + }, + { + "teal": 612, + "source": "tests/contracts/cblocks.algo.ts:367", + "pc": [ + 1561, + 1562, + 1563, + 1564 + ] + }, + { + "teal": 613, + "source": "tests/contracts/cblocks.algo.ts:367", + "pc": [ + 1565 + ] + }, + { + "teal": 617, + "source": "tests/contracts/cblocks.algo.ts:368", + "pc": [ + 1566, + 1567, + 1568, + 1569, + 1570, + 1571, + 1572, + 1573, + 1574, + 1575, + 1576 + ] + }, + { + "teal": 618, + "source": "tests/contracts/cblocks.algo.ts:368", + "pc": [ + 1577, + 1578, + 1579, + 1580 + ] + }, + { + "teal": 619, + "source": "tests/contracts/cblocks.algo.ts:368", + "pc": [ + 1581 + ] + }, + { + "teal": 623, + "source": "tests/contracts/cblocks.algo.ts:369", + "pc": [ + 1582, + 1583, + 1584, + 1585, + 1586, + 1587, + 1588, + 1589, + 1590, + 1591, + 1592 + ] + }, + { + "teal": 624, + "source": "tests/contracts/cblocks.algo.ts:369", + "pc": [ + 1593, + 1594, + 1595, + 1596 + ] + }, + { + "teal": 625, + "source": "tests/contracts/cblocks.algo.ts:369", + "pc": [ + 1597 + ] + }, + { + "teal": 629, + "source": "tests/contracts/cblocks.algo.ts:370", + "pc": [ + 1598, + 1599, + 1600, + 1601, + 1602, + 1603, + 1604, + 1605, + 1606, + 1607, + 1608 + ] + }, + { + "teal": 630, + "source": "tests/contracts/cblocks.algo.ts:370", + "pc": [ + 1609, + 1610, + 1611, + 1612 + ] + }, + { + "teal": 631, + "source": "tests/contracts/cblocks.algo.ts:370", + "pc": [ + 1613 + ] + }, + { + "teal": 635, + "source": "tests/contracts/cblocks.algo.ts:371", + "pc": [ + 1614, + 1615, + 1616, + 1617, + 1618, + 1619, + 1620, + 1621, + 1622, + 1623, + 1624 + ] + }, + { + "teal": 636, + "source": "tests/contracts/cblocks.algo.ts:371", + "pc": [ + 1625, + 1626, + 1627, + 1628 + ] + }, + { + "teal": 637, + "source": "tests/contracts/cblocks.algo.ts:371", + "pc": [ + 1629 + ] + }, + { + "teal": 641, + "source": "tests/contracts/cblocks.algo.ts:372", + "pc": [ + 1630, + 1631, + 1632, + 1633, + 1634, + 1635, + 1636, + 1637, + 1638, + 1639, + 1640 + ] + }, + { + "teal": 642, + "source": "tests/contracts/cblocks.algo.ts:372", + "pc": [ + 1641, + 1642, + 1643, + 1644 + ] + }, + { + "teal": 643, + "source": "tests/contracts/cblocks.algo.ts:372", + "pc": [ + 1645 + ] + }, + { + "teal": 647, + "source": "tests/contracts/cblocks.algo.ts:373", + "pc": [ + 1646, + 1647, + 1648, + 1649, + 1650, + 1651, + 1652, + 1653, + 1654, + 1655, + 1656 + ] + }, + { + "teal": 648, + "source": "tests/contracts/cblocks.algo.ts:373", + "pc": [ + 1657, + 1658, + 1659, + 1660 + ] + }, + { + "teal": 649, + "source": "tests/contracts/cblocks.algo.ts:373", + "pc": [ + 1661 + ] + }, + { + "teal": 653, + "source": "tests/contracts/cblocks.algo.ts:374", + "pc": [ + 1662, + 1663, + 1664, + 1665, + 1666, + 1667, + 1668, + 1669, + 1670, + 1671, + 1672 + ] + }, + { + "teal": 654, + "source": "tests/contracts/cblocks.algo.ts:374", + "pc": [ + 1673, + 1674, + 1675, + 1676, + 1677 + ] + }, + { + "teal": 655, + "source": "tests/contracts/cblocks.algo.ts:374", + "pc": [ + 1678 + ] + }, + { + "teal": 659, + "source": "tests/contracts/cblocks.algo.ts:375", + "pc": [ + 1679, + 1680, + 1681, + 1682, + 1683, + 1684, + 1685, + 1686, + 1687, + 1688, + 1689 + ] + }, + { + "teal": 660, + "source": "tests/contracts/cblocks.algo.ts:375", + "pc": [ + 1690, + 1691, + 1692, + 1693, + 1694 + ] + }, + { + "teal": 661, + "source": "tests/contracts/cblocks.algo.ts:375", + "pc": [ + 1695 + ] + }, + { + "teal": 665, + "source": "tests/contracts/cblocks.algo.ts:376", + "pc": [ + 1696, + 1697, + 1698, + 1699, + 1700, + 1701, + 1702, + 1703, + 1704, + 1705, + 1706 + ] + }, + { + "teal": 666, + "source": "tests/contracts/cblocks.algo.ts:376", + "pc": [ + 1707, + 1708, + 1709, + 1710, + 1711 + ] + }, + { + "teal": 667, + "source": "tests/contracts/cblocks.algo.ts:376", + "pc": [ + 1712 + ] + }, + { + "teal": 671, + "source": "tests/contracts/cblocks.algo.ts:377", + "pc": [ + 1713, + 1714, + 1715, + 1716, + 1717, + 1718, + 1719, + 1720, + 1721, + 1722, + 1723 + ] + }, + { + "teal": 672, + "source": "tests/contracts/cblocks.algo.ts:377", + "pc": [ + 1724, + 1725, + 1726, + 1727, + 1728 + ] + }, + { + "teal": 673, + "source": "tests/contracts/cblocks.algo.ts:377", + "pc": [ + 1729 + ] + }, + { + "teal": 677, + "source": "tests/contracts/cblocks.algo.ts:378", + "pc": [ + 1730, + 1731, + 1732, + 1733, + 1734, + 1735, + 1736, + 1737, + 1738, + 1739, + 1740 + ] + }, + { + "teal": 678, + "source": "tests/contracts/cblocks.algo.ts:378", + "pc": [ + 1741, + 1742, + 1743, + 1744, + 1745 + ] + }, + { + "teal": 679, + "source": "tests/contracts/cblocks.algo.ts:378", + "pc": [ + 1746 + ] + }, + { + "teal": 683, + "source": "tests/contracts/cblocks.algo.ts:379", + "pc": [ + 1747, + 1748, + 1749, + 1750, + 1751, + 1752, + 1753, + 1754, + 1755, + 1756, + 1757 + ] + }, + { + "teal": 684, + "source": "tests/contracts/cblocks.algo.ts:379", + "pc": [ + 1758, + 1759, + 1760, + 1761, + 1762 + ] + }, + { + "teal": 685, + "source": "tests/contracts/cblocks.algo.ts:379", + "pc": [ + 1763 + ] + }, + { + "teal": 689, + "source": "tests/contracts/cblocks.algo.ts:380", + "pc": [ + 1764, + 1765, + 1766, + 1767, + 1768, + 1769, + 1770, + 1771, + 1772, + 1773, + 1774 + ] + }, + { + "teal": 690, + "source": "tests/contracts/cblocks.algo.ts:380", + "pc": [ + 1775, + 1776, + 1777, + 1778, + 1779 + ] + }, + { + "teal": 691, + "source": "tests/contracts/cblocks.algo.ts:380", + "pc": [ + 1780 + ] + }, + { + "teal": 695, + "source": "tests/contracts/cblocks.algo.ts:381", + "pc": [ + 1781, + 1782, + 1783, + 1784, + 1785, + 1786, + 1787, + 1788, + 1789, + 1790, + 1791 + ] + }, + { + "teal": 696, + "source": "tests/contracts/cblocks.algo.ts:381", + "pc": [ + 1792, + 1793, + 1794, + 1795, + 1796 + ] + }, + { + "teal": 697, + "source": "tests/contracts/cblocks.algo.ts:381", + "pc": [ + 1797 + ] + }, + { + "teal": 701, + "source": "tests/contracts/cblocks.algo.ts:382", + "pc": [ + 1798, + 1799, + 1800, + 1801, + 1802, + 1803, + 1804, + 1805, + 1806, + 1807, + 1808 + ] + }, + { + "teal": 702, + "source": "tests/contracts/cblocks.algo.ts:382", + "pc": [ + 1809, + 1810, + 1811, + 1812, + 1813 + ] + }, + { + "teal": 703, + "source": "tests/contracts/cblocks.algo.ts:382", + "pc": [ + 1814 + ] + }, + { + "teal": 707, + "source": "tests/contracts/cblocks.algo.ts:383", + "pc": [ + 1815, + 1816, + 1817, + 1818, + 1819, + 1820, + 1821, + 1822, + 1823, + 1824, + 1825 + ] + }, + { + "teal": 708, + "source": "tests/contracts/cblocks.algo.ts:383", + "pc": [ + 1826, + 1827, + 1828, + 1829, + 1830 + ] + }, + { + "teal": 709, + "source": "tests/contracts/cblocks.algo.ts:383", + "pc": [ + 1831 + ] + }, + { + "teal": 713, + "source": "tests/contracts/cblocks.algo.ts:384", + "pc": [ + 1832, + 1833, + 1834, + 1835, + 1836, + 1837, + 1838, + 1839, + 1840, + 1841, + 1842 + ] + }, + { + "teal": 714, + "source": "tests/contracts/cblocks.algo.ts:384", + "pc": [ + 1843, + 1844, + 1845, + 1846, + 1847 + ] + }, + { + "teal": 715, + "source": "tests/contracts/cblocks.algo.ts:384", + "pc": [ + 1848 + ] + }, + { + "teal": 719, + "source": "tests/contracts/cblocks.algo.ts:385", + "pc": [ + 1849, + 1850, + 1851, + 1852, + 1853, + 1854, + 1855, + 1856, + 1857, + 1858, + 1859 + ] + }, + { + "teal": 720, + "source": "tests/contracts/cblocks.algo.ts:385", + "pc": [ + 1860, + 1861, + 1862, + 1863, + 1864 + ] + }, + { + "teal": 721, + "source": "tests/contracts/cblocks.algo.ts:385", + "pc": [ + 1865 + ] + }, + { + "teal": 725, + "source": "tests/contracts/cblocks.algo.ts:386", + "pc": [ + 1866, + 1867, + 1868, + 1869, + 1870, + 1871, + 1872, + 1873, + 1874, + 1875, + 1876 + ] + }, + { + "teal": 726, + "source": "tests/contracts/cblocks.algo.ts:386", + "pc": [ + 1877, + 1878, + 1879, + 1880, + 1881 + ] + }, + { + "teal": 727, + "source": "tests/contracts/cblocks.algo.ts:386", + "pc": [ + 1882 + ] + }, + { + "teal": 731, + "source": "tests/contracts/cblocks.algo.ts:387", + "pc": [ + 1883, + 1884, + 1885, + 1886, + 1887, + 1888, + 1889, + 1890, + 1891, + 1892, + 1893 + ] + }, + { + "teal": 732, + "source": "tests/contracts/cblocks.algo.ts:387", + "pc": [ + 1894, + 1895, + 1896, + 1897, + 1898 + ] + }, + { + "teal": 733, + "source": "tests/contracts/cblocks.algo.ts:387", + "pc": [ + 1899 + ] + }, + { + "teal": 737, + "source": "tests/contracts/cblocks.algo.ts:388", + "pc": [ + 1900, + 1901, + 1902, + 1903, + 1904, + 1905, + 1906, + 1907, + 1908, + 1909, + 1910 + ] + }, + { + "teal": 738, + "source": "tests/contracts/cblocks.algo.ts:388", + "pc": [ + 1911, + 1912, + 1913, + 1914, + 1915 + ] + }, + { + "teal": 739, + "source": "tests/contracts/cblocks.algo.ts:388", + "pc": [ + 1916 + ] + }, + { + "teal": 743, + "source": "tests/contracts/cblocks.algo.ts:389", + "pc": [ + 1917, + 1918, + 1919, + 1920, + 1921, + 1922, + 1923, + 1924, + 1925, + 1926, + 1927 + ] + }, + { + "teal": 744, + "source": "tests/contracts/cblocks.algo.ts:389", + "pc": [ + 1928, + 1929, + 1930, + 1931, + 1932 + ] + }, + { + "teal": 745, + "source": "tests/contracts/cblocks.algo.ts:389", + "pc": [ + 1933 + ] + }, + { + "teal": 749, + "source": "tests/contracts/cblocks.algo.ts:390", + "pc": [ + 1934, + 1935, + 1936, + 1937, + 1938, + 1939, + 1940, + 1941, + 1942, + 1943, + 1944 + ] + }, + { + "teal": 750, + "source": "tests/contracts/cblocks.algo.ts:390", + "pc": [ + 1945, + 1946, + 1947, + 1948, + 1949 + ] + }, + { + "teal": 751, + "source": "tests/contracts/cblocks.algo.ts:390", + "pc": [ + 1950 + ] + }, + { + "teal": 755, + "source": "tests/contracts/cblocks.algo.ts:391", + "pc": [ + 1951, + 1952, + 1953, + 1954, + 1955, + 1956, + 1957, + 1958, + 1959, + 1960, + 1961 + ] + }, + { + "teal": 756, + "source": "tests/contracts/cblocks.algo.ts:391", + "pc": [ + 1962, + 1963, + 1964, + 1965, + 1966 + ] + }, + { + "teal": 757, + "source": "tests/contracts/cblocks.algo.ts:391", + "pc": [ + 1967 + ] + }, + { + "teal": 761, + "source": "tests/contracts/cblocks.algo.ts:392", + "pc": [ + 1968, + 1969, + 1970, + 1971, + 1972, + 1973, + 1974, + 1975, + 1976, + 1977, + 1978 + ] + }, + { + "teal": 762, + "source": "tests/contracts/cblocks.algo.ts:392", + "pc": [ + 1979, + 1980, + 1981, + 1982, + 1983 + ] + }, + { + "teal": 763, + "source": "tests/contracts/cblocks.algo.ts:392", + "pc": [ + 1984 + ] + }, + { + "teal": 767, + "source": "tests/contracts/cblocks.algo.ts:393", + "pc": [ + 1985, + 1986, + 1987, + 1988, + 1989, + 1990, + 1991, + 1992, + 1993, + 1994, + 1995 + ] + }, + { + "teal": 768, + "source": "tests/contracts/cblocks.algo.ts:393", + "pc": [ + 1996, + 1997, + 1998, + 1999, + 2000 + ] + }, + { + "teal": 769, + "source": "tests/contracts/cblocks.algo.ts:393", + "pc": [ + 2001 + ] + }, + { + "teal": 773, + "source": "tests/contracts/cblocks.algo.ts:394", + "pc": [ + 2002, + 2003, + 2004, + 2005, + 2006, + 2007, + 2008, + 2009, + 2010, + 2011, + 2012 + ] + }, + { + "teal": 774, + "source": "tests/contracts/cblocks.algo.ts:394", + "pc": [ + 2013, + 2014, + 2015, + 2016, + 2017 + ] + }, + { + "teal": 775, + "source": "tests/contracts/cblocks.algo.ts:394", + "pc": [ + 2018 + ] + }, + { + "teal": 779, + "source": "tests/contracts/cblocks.algo.ts:395", + "pc": [ + 2019, + 2020, + 2021, + 2022, + 2023, + 2024, + 2025, + 2026, + 2027, + 2028, + 2029 + ] + }, + { + "teal": 780, + "source": "tests/contracts/cblocks.algo.ts:395", + "pc": [ + 2030, + 2031, + 2032, + 2033, + 2034 + ] + }, + { + "teal": 781, + "source": "tests/contracts/cblocks.algo.ts:395", + "pc": [ + 2035 + ] + }, + { + "teal": 785, + "source": "tests/contracts/cblocks.algo.ts:396", + "pc": [ + 2036, + 2037, + 2038, + 2039, + 2040, + 2041, + 2042, + 2043, + 2044, + 2045, + 2046 + ] + }, + { + "teal": 786, + "source": "tests/contracts/cblocks.algo.ts:396", + "pc": [ + 2047, + 2048, + 2049, + 2050, + 2051 + ] + }, + { + "teal": 787, + "source": "tests/contracts/cblocks.algo.ts:396", + "pc": [ + 2052 + ] + }, + { + "teal": 791, + "source": "tests/contracts/cblocks.algo.ts:397", + "pc": [ + 2053, + 2054, + 2055, + 2056, + 2057, + 2058, + 2059, + 2060, + 2061, + 2062, + 2063 + ] + }, + { + "teal": 792, + "source": "tests/contracts/cblocks.algo.ts:397", + "pc": [ + 2064, + 2065, + 2066, + 2067, + 2068 + ] + }, + { + "teal": 793, + "source": "tests/contracts/cblocks.algo.ts:397", + "pc": [ + 2069 + ] + }, + { + "teal": 797, + "source": "tests/contracts/cblocks.algo.ts:398", + "pc": [ + 2070, + 2071, + 2072, + 2073, + 2074, + 2075, + 2076, + 2077, + 2078, + 2079, + 2080 + ] + }, + { + "teal": 798, + "source": "tests/contracts/cblocks.algo.ts:398", + "pc": [ + 2081, + 2082, + 2083, + 2084, + 2085 + ] + }, + { + "teal": 799, + "source": "tests/contracts/cblocks.algo.ts:398", + "pc": [ + 2086 + ] + }, + { + "teal": 803, + "source": "tests/contracts/cblocks.algo.ts:399", + "pc": [ + 2087, + 2088, + 2089, + 2090, + 2091, + 2092, + 2093, + 2094, + 2095, + 2096, + 2097 + ] + }, + { + "teal": 804, + "source": "tests/contracts/cblocks.algo.ts:399", + "pc": [ + 2098, + 2099, + 2100, + 2101, + 2102 + ] + }, + { + "teal": 805, + "source": "tests/contracts/cblocks.algo.ts:399", + "pc": [ + 2103 + ] + }, + { + "teal": 809, + "source": "tests/contracts/cblocks.algo.ts:400", + "pc": [ + 2104, + 2105, + 2106, + 2107, + 2108, + 2109, + 2110, + 2111, + 2112, + 2113, + 2114 + ] + }, + { + "teal": 810, + "source": "tests/contracts/cblocks.algo.ts:400", + "pc": [ + 2115, + 2116, + 2117, + 2118, + 2119 + ] + }, + { + "teal": 811, + "source": "tests/contracts/cblocks.algo.ts:400", + "pc": [ + 2120 + ] + }, + { + "teal": 815, + "source": "tests/contracts/cblocks.algo.ts:401", + "pc": [ + 2121, + 2122, + 2123, + 2124, + 2125, + 2126, + 2127, + 2128, + 2129, + 2130, + 2131 + ] + }, + { + "teal": 816, + "source": "tests/contracts/cblocks.algo.ts:401", + "pc": [ + 2132, + 2133, + 2134, + 2135, + 2136 + ] + }, + { + "teal": 817, + "source": "tests/contracts/cblocks.algo.ts:401", + "pc": [ + 2137 + ] + }, + { + "teal": 821, + "source": "tests/contracts/cblocks.algo.ts:402", + "pc": [ + 2138, + 2139, + 2140, + 2141, + 2142, + 2143, + 2144, + 2145, + 2146, + 2147, + 2148 + ] + }, + { + "teal": 822, + "source": "tests/contracts/cblocks.algo.ts:402", + "pc": [ + 2149, + 2150, + 2151, + 2152, + 2153 + ] + }, + { + "teal": 823, + "source": "tests/contracts/cblocks.algo.ts:402", + "pc": [ + 2154 + ] + }, + { + "teal": 827, + "source": "tests/contracts/cblocks.algo.ts:403", + "pc": [ + 2155, + 2156, + 2157, + 2158, + 2159, + 2160, + 2161, + 2162, + 2163, + 2164, + 2165 + ] + }, + { + "teal": 828, + "source": "tests/contracts/cblocks.algo.ts:403", + "pc": [ + 2166, + 2167, + 2168, + 2169, + 2170 + ] + }, + { + "teal": 829, + "source": "tests/contracts/cblocks.algo.ts:403", + "pc": [ + 2171 + ] + }, + { + "teal": 833, + "source": "tests/contracts/cblocks.algo.ts:404", + "pc": [ + 2172, + 2173, + 2174, + 2175, + 2176, + 2177, + 2178, + 2179, + 2180, + 2181, + 2182 + ] + }, + { + "teal": 834, + "source": "tests/contracts/cblocks.algo.ts:404", + "pc": [ + 2183, + 2184, + 2185, + 2186, + 2187 + ] + }, + { + "teal": 835, + "source": "tests/contracts/cblocks.algo.ts:404", + "pc": [ + 2188 + ] + }, + { + "teal": 839, + "source": "tests/contracts/cblocks.algo.ts:405", + "pc": [ + 2189, + 2190, + 2191, + 2192, + 2193, + 2194, + 2195, + 2196, + 2197, + 2198, + 2199 + ] + }, + { + "teal": 840, + "source": "tests/contracts/cblocks.algo.ts:405", + "pc": [ + 2200, + 2201, + 2202, + 2203, + 2204 + ] + }, + { + "teal": 841, + "source": "tests/contracts/cblocks.algo.ts:405", + "pc": [ + 2205 + ] + }, + { + "teal": 845, + "source": "tests/contracts/cblocks.algo.ts:406", + "pc": [ + 2206, + 2207, + 2208, + 2209, + 2210, + 2211, + 2212, + 2213, + 2214, + 2215, + 2216 + ] + }, + { + "teal": 846, + "source": "tests/contracts/cblocks.algo.ts:406", + "pc": [ + 2217, + 2218, + 2219, + 2220, + 2221 + ] + }, + { + "teal": 847, + "source": "tests/contracts/cblocks.algo.ts:406", + "pc": [ + 2222 + ] + }, + { + "teal": 851, + "source": "tests/contracts/cblocks.algo.ts:407", + "pc": [ + 2223, + 2224, + 2225, + 2226, + 2227, + 2228, + 2229, + 2230, + 2231, + 2232, + 2233 + ] + }, + { + "teal": 852, + "source": "tests/contracts/cblocks.algo.ts:407", + "pc": [ + 2234, + 2235, + 2236, + 2237, + 2238 + ] + }, + { + "teal": 853, + "source": "tests/contracts/cblocks.algo.ts:407", + "pc": [ + 2239 + ] + }, + { + "teal": 857, + "source": "tests/contracts/cblocks.algo.ts:408", + "pc": [ + 2240, + 2241, + 2242, + 2243, + 2244, + 2245, + 2246, + 2247, + 2248, + 2249, + 2250 + ] + }, + { + "teal": 858, + "source": "tests/contracts/cblocks.algo.ts:408", + "pc": [ + 2251, + 2252, + 2253, + 2254, + 2255 + ] + }, + { + "teal": 859, + "source": "tests/contracts/cblocks.algo.ts:408", + "pc": [ + 2256 + ] + }, + { + "teal": 863, + "source": "tests/contracts/cblocks.algo.ts:409", + "pc": [ + 2257, + 2258, + 2259, + 2260, + 2261, + 2262, + 2263, + 2264, + 2265, + 2266, + 2267 + ] + }, + { + "teal": 864, + "source": "tests/contracts/cblocks.algo.ts:409", + "pc": [ + 2268, + 2269, + 2270, + 2271, + 2272 + ] + }, + { + "teal": 865, + "source": "tests/contracts/cblocks.algo.ts:409", + "pc": [ + 2273 + ] + }, + { + "teal": 869, + "source": "tests/contracts/cblocks.algo.ts:410", + "pc": [ + 2274, + 2275, + 2276, + 2277, + 2278, + 2279, + 2280, + 2281, + 2282, + 2283, + 2284 + ] + }, + { + "teal": 870, + "source": "tests/contracts/cblocks.algo.ts:410", + "pc": [ + 2285, + 2286, + 2287, + 2288, + 2289 + ] + }, + { + "teal": 871, + "source": "tests/contracts/cblocks.algo.ts:410", + "pc": [ + 2290 + ] + }, + { + "teal": 875, + "source": "tests/contracts/cblocks.algo.ts:411", + "pc": [ + 2291, + 2292, + 2293, + 2294, + 2295, + 2296, + 2297, + 2298, + 2299, + 2300, + 2301 + ] + }, + { + "teal": 876, + "source": "tests/contracts/cblocks.algo.ts:411", + "pc": [ + 2302, + 2303, + 2304, + 2305, + 2306 + ] + }, + { + "teal": 877, + "source": "tests/contracts/cblocks.algo.ts:411", + "pc": [ + 2307 + ] + }, + { + "teal": 881, + "source": "tests/contracts/cblocks.algo.ts:412", + "pc": [ + 2308, + 2309, + 2310, + 2311, + 2312, + 2313, + 2314, + 2315, + 2316, + 2317, + 2318 + ] + }, + { + "teal": 882, + "source": "tests/contracts/cblocks.algo.ts:412", + "pc": [ + 2319, + 2320, + 2321, + 2322, + 2323 + ] + }, + { + "teal": 883, + "source": "tests/contracts/cblocks.algo.ts:412", + "pc": [ + 2324 + ] + }, + { + "teal": 887, + "source": "tests/contracts/cblocks.algo.ts:413", + "pc": [ + 2325, + 2326, + 2327, + 2328, + 2329, + 2330, + 2331, + 2332, + 2333, + 2334, + 2335 + ] + }, + { + "teal": 888, + "source": "tests/contracts/cblocks.algo.ts:413", + "pc": [ + 2336, + 2337, + 2338, + 2339, + 2340 + ] + }, + { + "teal": 889, + "source": "tests/contracts/cblocks.algo.ts:413", + "pc": [ + 2341 + ] + }, + { + "teal": 893, + "source": "tests/contracts/cblocks.algo.ts:414", + "pc": [ + 2342, + 2343, + 2344, + 2345, + 2346, + 2347, + 2348, + 2349, + 2350, + 2351, + 2352 + ] + }, + { + "teal": 894, + "source": "tests/contracts/cblocks.algo.ts:414", + "pc": [ + 2353, + 2354, + 2355, + 2356, + 2357 + ] + }, + { + "teal": 895, + "source": "tests/contracts/cblocks.algo.ts:414", + "pc": [ + 2358 + ] + }, + { + "teal": 899, + "source": "tests/contracts/cblocks.algo.ts:415", + "pc": [ + 2359, + 2360, + 2361, + 2362, + 2363, + 2364, + 2365, + 2366, + 2367, + 2368, + 2369 + ] + }, + { + "teal": 900, + "source": "tests/contracts/cblocks.algo.ts:415", + "pc": [ + 2370, + 2371, + 2372, + 2373, + 2374 + ] + }, + { + "teal": 901, + "source": "tests/contracts/cblocks.algo.ts:415", + "pc": [ + 2375 + ] + }, + { + "teal": 905, + "source": "tests/contracts/cblocks.algo.ts:416", + "pc": [ + 2376, + 2377, + 2378, + 2379, + 2380, + 2381, + 2382, + 2383, + 2384, + 2385, + 2386 + ] + }, + { + "teal": 906, + "source": "tests/contracts/cblocks.algo.ts:416", + "pc": [ + 2387, + 2388, + 2389, + 2390, + 2391 + ] + }, + { + "teal": 907, + "source": "tests/contracts/cblocks.algo.ts:416", + "pc": [ + 2392 + ] + }, + { + "teal": 911, + "source": "tests/contracts/cblocks.algo.ts:417", + "pc": [ + 2393, + 2394, + 2395, + 2396, + 2397, + 2398, + 2399, + 2400, + 2401, + 2402, + 2403 + ] + }, + { + "teal": 912, + "source": "tests/contracts/cblocks.algo.ts:417", + "pc": [ + 2404, + 2405, + 2406, + 2407, + 2408 + ] + }, + { + "teal": 913, + "source": "tests/contracts/cblocks.algo.ts:417", + "pc": [ + 2409 + ] + }, + { + "teal": 917, + "source": "tests/contracts/cblocks.algo.ts:418", + "pc": [ + 2410, + 2411, + 2412, + 2413, + 2414, + 2415, + 2416, + 2417, + 2418, + 2419, + 2420 + ] + }, + { + "teal": 918, + "source": "tests/contracts/cblocks.algo.ts:418", + "pc": [ + 2421, + 2422, + 2423, + 2424, + 2425 + ] + }, + { + "teal": 919, + "source": "tests/contracts/cblocks.algo.ts:418", + "pc": [ + 2426 + ] + }, + { + "teal": 923, + "source": "tests/contracts/cblocks.algo.ts:419", + "pc": [ + 2427, + 2428, + 2429, + 2430, + 2431, + 2432, + 2433, + 2434, + 2435, + 2436, + 2437 + ] + }, + { + "teal": 924, + "source": "tests/contracts/cblocks.algo.ts:419", + "pc": [ + 2438, + 2439, + 2440, + 2441, + 2442 + ] + }, + { + "teal": 925, + "source": "tests/contracts/cblocks.algo.ts:419", + "pc": [ + 2443 + ] + }, + { + "teal": 929, + "source": "tests/contracts/cblocks.algo.ts:420", + "pc": [ + 2444, + 2445, + 2446, + 2447, + 2448, + 2449, + 2450, + 2451, + 2452, + 2453, + 2454 + ] + }, + { + "teal": 930, + "source": "tests/contracts/cblocks.algo.ts:420", + "pc": [ + 2455, + 2456, + 2457, + 2458, + 2459 + ] + }, + { + "teal": 931, + "source": "tests/contracts/cblocks.algo.ts:420", + "pc": [ + 2460 + ] + }, + { + "teal": 935, + "source": "tests/contracts/cblocks.algo.ts:421", + "pc": [ + 2461, + 2462, + 2463, + 2464, + 2465, + 2466, + 2467, + 2468, + 2469, + 2470, + 2471 + ] + }, + { + "teal": 936, + "source": "tests/contracts/cblocks.algo.ts:421", + "pc": [ + 2472, + 2473, + 2474, + 2475, + 2476 + ] + }, + { + "teal": 937, + "source": "tests/contracts/cblocks.algo.ts:421", + "pc": [ + 2477 + ] + }, + { + "teal": 941, + "source": "tests/contracts/cblocks.algo.ts:422", + "pc": [ + 2478, + 2479, + 2480, + 2481, + 2482, + 2483, + 2484, + 2485, + 2486, + 2487, + 2488 + ] + }, + { + "teal": 942, + "source": "tests/contracts/cblocks.algo.ts:422", + "pc": [ + 2489, + 2490, + 2491, + 2492, + 2493 + ] + }, + { + "teal": 943, + "source": "tests/contracts/cblocks.algo.ts:422", + "pc": [ + 2494 + ] + }, + { + "teal": 947, + "source": "tests/contracts/cblocks.algo.ts:423", + "pc": [ + 2495, + 2496, + 2497, + 2498, + 2499, + 2500, + 2501, + 2502, + 2503, + 2504, + 2505 + ] + }, + { + "teal": 948, + "source": "tests/contracts/cblocks.algo.ts:423", + "pc": [ + 2506, + 2507, + 2508, + 2509, + 2510 + ] + }, + { + "teal": 949, + "source": "tests/contracts/cblocks.algo.ts:423", + "pc": [ + 2511 + ] + }, + { + "teal": 953, + "source": "tests/contracts/cblocks.algo.ts:424", + "pc": [ + 2512, + 2513, + 2514, + 2515, + 2516, + 2517, + 2518, + 2519, + 2520, + 2521, + 2522 + ] + }, + { + "teal": 954, + "source": "tests/contracts/cblocks.algo.ts:424", + "pc": [ + 2523, + 2524, + 2525, + 2526, + 2527 + ] + }, + { + "teal": 955, + "source": "tests/contracts/cblocks.algo.ts:424", + "pc": [ + 2528 + ] + }, + { + "teal": 959, + "source": "tests/contracts/cblocks.algo.ts:425", + "pc": [ + 2529, + 2530, + 2531, + 2532, + 2533, + 2534, + 2535, + 2536, + 2537, + 2538, + 2539 + ] + }, + { + "teal": 960, + "source": "tests/contracts/cblocks.algo.ts:425", + "pc": [ + 2540, + 2541, + 2542, + 2543, + 2544 + ] + }, + { + "teal": 961, + "source": "tests/contracts/cblocks.algo.ts:425", + "pc": [ + 2545 + ] + }, + { + "teal": 965, + "source": "tests/contracts/cblocks.algo.ts:426", + "pc": [ + 2546, + 2547, + 2548, + 2549, + 2550, + 2551, + 2552, + 2553, + 2554, + 2555, + 2556 + ] + }, + { + "teal": 966, + "source": "tests/contracts/cblocks.algo.ts:426", + "pc": [ + 2557, + 2558, + 2559, + 2560, + 2561 + ] + }, + { + "teal": 967, + "source": "tests/contracts/cblocks.algo.ts:426", + "pc": [ + 2562 + ] + }, + { + "teal": 971, + "source": "tests/contracts/cblocks.algo.ts:427", + "pc": [ + 2563, + 2564, + 2565, + 2566, + 2567, + 2568, + 2569, + 2570, + 2571, + 2572, + 2573 + ] + }, + { + "teal": 972, + "source": "tests/contracts/cblocks.algo.ts:427", + "pc": [ + 2574, + 2575, + 2576, + 2577, + 2578 + ] + }, + { + "teal": 973, + "source": "tests/contracts/cblocks.algo.ts:427", + "pc": [ + 2579 + ] + }, + { + "teal": 977, + "source": "tests/contracts/cblocks.algo.ts:428", + "pc": [ + 2580, + 2581, + 2582, + 2583, + 2584, + 2585, + 2586, + 2587, + 2588, + 2589, + 2590 + ] + }, + { + "teal": 978, + "source": "tests/contracts/cblocks.algo.ts:428", + "pc": [ + 2591, + 2592, + 2593, + 2594, + 2595 + ] + }, + { + "teal": 979, + "source": "tests/contracts/cblocks.algo.ts:428", + "pc": [ + 2596 + ] + }, + { + "teal": 983, + "source": "tests/contracts/cblocks.algo.ts:429", + "pc": [ + 2597, + 2598, + 2599, + 2600, + 2601, + 2602, + 2603, + 2604, + 2605, + 2606, + 2607 + ] + }, + { + "teal": 984, + "source": "tests/contracts/cblocks.algo.ts:429", + "pc": [ + 2608, + 2609, + 2610, + 2611, + 2612 + ] + }, + { + "teal": 985, + "source": "tests/contracts/cblocks.algo.ts:429", + "pc": [ + 2613 + ] + }, + { + "teal": 989, + "source": "tests/contracts/cblocks.algo.ts:430", + "pc": [ + 2614, + 2615, + 2616, + 2617, + 2618, + 2619, + 2620, + 2621, + 2622, + 2623, + 2624 + ] + }, + { + "teal": 990, + "source": "tests/contracts/cblocks.algo.ts:430", + "pc": [ + 2625, + 2626, + 2627, + 2628, + 2629 + ] + }, + { + "teal": 991, + "source": "tests/contracts/cblocks.algo.ts:430", + "pc": [ + 2630 + ] + }, + { + "teal": 995, + "source": "tests/contracts/cblocks.algo.ts:431", + "pc": [ + 2631, + 2632, + 2633, + 2634, + 2635, + 2636, + 2637, + 2638, + 2639, + 2640, + 2641 + ] + }, + { + "teal": 996, + "source": "tests/contracts/cblocks.algo.ts:431", + "pc": [ + 2642, + 2643, + 2644, + 2645, + 2646 + ] + }, + { + "teal": 997, + "source": "tests/contracts/cblocks.algo.ts:431", + "pc": [ + 2647 + ] + }, + { + "teal": 1001, + "source": "tests/contracts/cblocks.algo.ts:432", + "pc": [ + 2648, + 2649, + 2650, + 2651, + 2652, + 2653, + 2654, + 2655, + 2656, + 2657, + 2658 + ] + }, + { + "teal": 1002, + "source": "tests/contracts/cblocks.algo.ts:432", + "pc": [ + 2659, + 2660, + 2661, + 2662, + 2663 + ] + }, + { + "teal": 1003, + "source": "tests/contracts/cblocks.algo.ts:432", + "pc": [ + 2664 + ] + }, + { + "teal": 1007, + "source": "tests/contracts/cblocks.algo.ts:433", + "pc": [ + 2665, + 2666, + 2667, + 2668, + 2669, + 2670, + 2671, + 2672, + 2673, + 2674, + 2675 + ] + }, + { + "teal": 1008, + "source": "tests/contracts/cblocks.algo.ts:433", + "pc": [ + 2676, + 2677, + 2678, + 2679, + 2680 + ] + }, + { + "teal": 1009, + "source": "tests/contracts/cblocks.algo.ts:433", + "pc": [ + 2681 + ] + }, + { + "teal": 1013, + "source": "tests/contracts/cblocks.algo.ts:434", + "pc": [ + 2682, + 2683, + 2684, + 2685, + 2686, + 2687, + 2688, + 2689, + 2690, + 2691, + 2692 + ] + }, + { + "teal": 1014, + "source": "tests/contracts/cblocks.algo.ts:434", + "pc": [ + 2693, + 2694, + 2695, + 2696, + 2697 + ] + }, + { + "teal": 1015, + "source": "tests/contracts/cblocks.algo.ts:434", + "pc": [ + 2698 + ] + }, + { + "teal": 1019, + "source": "tests/contracts/cblocks.algo.ts:435", + "pc": [ + 2699, + 2700, + 2701, + 2702, + 2703, + 2704, + 2705, + 2706, + 2707, + 2708, + 2709 + ] + }, + { + "teal": 1020, + "source": "tests/contracts/cblocks.algo.ts:435", + "pc": [ + 2710, + 2711, + 2712, + 2713, + 2714 + ] + }, + { + "teal": 1021, + "source": "tests/contracts/cblocks.algo.ts:435", + "pc": [ + 2715 + ] + }, + { + "teal": 1025, + "source": "tests/contracts/cblocks.algo.ts:436", + "pc": [ + 2716, + 2717, + 2718, + 2719, + 2720, + 2721, + 2722, + 2723, + 2724, + 2725, + 2726 + ] + }, + { + "teal": 1026, + "source": "tests/contracts/cblocks.algo.ts:436", + "pc": [ + 2727, + 2728, + 2729, + 2730, + 2731 + ] + }, + { + "teal": 1027, + "source": "tests/contracts/cblocks.algo.ts:436", + "pc": [ + 2732 + ] + }, + { + "teal": 1031, + "source": "tests/contracts/cblocks.algo.ts:437", + "pc": [ + 2733, + 2734, + 2735, + 2736, + 2737, + 2738, + 2739, + 2740, + 2741, + 2742, + 2743 + ] + }, + { + "teal": 1032, + "source": "tests/contracts/cblocks.algo.ts:437", + "pc": [ + 2744, + 2745, + 2746, + 2747, + 2748 + ] + }, + { + "teal": 1033, + "source": "tests/contracts/cblocks.algo.ts:437", + "pc": [ + 2749 + ] + }, + { + "teal": 1037, + "source": "tests/contracts/cblocks.algo.ts:438", + "pc": [ + 2750, + 2751, + 2752, + 2753, + 2754, + 2755, + 2756, + 2757, + 2758, + 2759, + 2760 + ] + }, + { + "teal": 1038, + "source": "tests/contracts/cblocks.algo.ts:438", + "pc": [ + 2761, + 2762, + 2763, + 2764, + 2765 + ] + }, + { + "teal": 1039, + "source": "tests/contracts/cblocks.algo.ts:438", + "pc": [ + 2766 + ] + }, + { + "teal": 1043, + "source": "tests/contracts/cblocks.algo.ts:439", + "pc": [ + 2767, + 2768, + 2769, + 2770, + 2771, + 2772, + 2773, + 2774, + 2775, + 2776, + 2777 + ] + }, + { + "teal": 1044, + "source": "tests/contracts/cblocks.algo.ts:439", + "pc": [ + 2778, + 2779, + 2780, + 2781, + 2782 + ] + }, + { + "teal": 1045, + "source": "tests/contracts/cblocks.algo.ts:439", + "pc": [ + 2783 + ] + }, + { + "teal": 1049, + "source": "tests/contracts/cblocks.algo.ts:440", + "pc": [ + 2784, + 2785, + 2786, + 2787, + 2788, + 2789, + 2790, + 2791, + 2792, + 2793, + 2794 + ] + }, + { + "teal": 1050, + "source": "tests/contracts/cblocks.algo.ts:440", + "pc": [ + 2795, + 2796, + 2797, + 2798, + 2799 + ] + }, + { + "teal": 1051, + "source": "tests/contracts/cblocks.algo.ts:440", + "pc": [ + 2800 + ] + }, + { + "teal": 1055, + "source": "tests/contracts/cblocks.algo.ts:441", + "pc": [ + 2801, + 2802, + 2803, + 2804, + 2805, + 2806, + 2807, + 2808, + 2809, + 2810, + 2811 + ] + }, + { + "teal": 1056, + "source": "tests/contracts/cblocks.algo.ts:441", + "pc": [ + 2812, + 2813, + 2814, + 2815, + 2816 + ] + }, + { + "teal": 1057, + "source": "tests/contracts/cblocks.algo.ts:441", + "pc": [ + 2817 + ] + }, + { + "teal": 1061, + "source": "tests/contracts/cblocks.algo.ts:442", + "pc": [ + 2818, + 2819, + 2820, + 2821, + 2822, + 2823, + 2824, + 2825, + 2826, + 2827, + 2828 + ] + }, + { + "teal": 1062, + "source": "tests/contracts/cblocks.algo.ts:442", + "pc": [ + 2829, + 2830, + 2831, + 2832, + 2833 + ] + }, + { + "teal": 1063, + "source": "tests/contracts/cblocks.algo.ts:442", + "pc": [ + 2834 + ] + }, + { + "teal": 1067, + "source": "tests/contracts/cblocks.algo.ts:443", + "pc": [ + 2835, + 2836, + 2837, + 2838, + 2839, + 2840, + 2841, + 2842, + 2843, + 2844, + 2845 + ] + }, + { + "teal": 1068, + "source": "tests/contracts/cblocks.algo.ts:443", + "pc": [ + 2846, + 2847, + 2848, + 2849, + 2850 + ] + }, + { + "teal": 1069, + "source": "tests/contracts/cblocks.algo.ts:443", + "pc": [ + 2851 + ] + }, + { + "teal": 1073, + "source": "tests/contracts/cblocks.algo.ts:444", + "pc": [ + 2852, + 2853, + 2854, + 2855, + 2856, + 2857, + 2858, + 2859, + 2860, + 2861, + 2862 + ] + }, + { + "teal": 1074, + "source": "tests/contracts/cblocks.algo.ts:444", + "pc": [ + 2863, + 2864, + 2865, + 2866, + 2867 + ] + }, + { + "teal": 1075, + "source": "tests/contracts/cblocks.algo.ts:444", + "pc": [ + 2868 + ] + }, + { + "teal": 1079, + "source": "tests/contracts/cblocks.algo.ts:445", + "pc": [ + 2869, + 2870, + 2871, + 2872, + 2873, + 2874, + 2875, + 2876, + 2877, + 2878, + 2879 + ] + }, + { + "teal": 1080, + "source": "tests/contracts/cblocks.algo.ts:445", + "pc": [ + 2880, + 2881, + 2882, + 2883, + 2884 + ] + }, + { + "teal": 1081, + "source": "tests/contracts/cblocks.algo.ts:445", + "pc": [ + 2885 + ] + }, + { + "teal": 1085, + "source": "tests/contracts/cblocks.algo.ts:446", + "pc": [ + 2886, + 2887, + 2888, + 2889, + 2890, + 2891, + 2892, + 2893, + 2894, + 2895, + 2896 + ] + }, + { + "teal": 1086, + "source": "tests/contracts/cblocks.algo.ts:446", + "pc": [ + 2897, + 2898, + 2899, + 2900, + 2901 + ] + }, + { + "teal": 1087, + "source": "tests/contracts/cblocks.algo.ts:446", + "pc": [ + 2902 + ] + }, + { + "teal": 1091, + "source": "tests/contracts/cblocks.algo.ts:447", + "pc": [ + 2903, + 2904, + 2905, + 2906, + 2907, + 2908, + 2909, + 2910, + 2911, + 2912, + 2913 + ] + }, + { + "teal": 1092, + "source": "tests/contracts/cblocks.algo.ts:447", + "pc": [ + 2914, + 2915, + 2916, + 2917, + 2918 + ] + }, + { + "teal": 1093, + "source": "tests/contracts/cblocks.algo.ts:447", + "pc": [ + 2919 + ] + }, + { + "teal": 1097, + "source": "tests/contracts/cblocks.algo.ts:448", + "pc": [ + 2920, + 2921, + 2922, + 2923, + 2924, + 2925, + 2926, + 2927, + 2928, + 2929, + 2930 + ] + }, + { + "teal": 1098, + "source": "tests/contracts/cblocks.algo.ts:448", + "pc": [ + 2931, + 2932, + 2933, + 2934, + 2935 + ] + }, + { + "teal": 1099, + "source": "tests/contracts/cblocks.algo.ts:448", + "pc": [ + 2936 + ] + }, + { + "teal": 1103, + "source": "tests/contracts/cblocks.algo.ts:449", + "pc": [ + 2937, + 2938, + 2939, + 2940, + 2941, + 2942, + 2943, + 2944, + 2945, + 2946, + 2947 + ] + }, + { + "teal": 1104, + "source": "tests/contracts/cblocks.algo.ts:449", + "pc": [ + 2948, + 2949, + 2950, + 2951, + 2952 + ] + }, + { + "teal": 1105, + "source": "tests/contracts/cblocks.algo.ts:449", + "pc": [ + 2953 + ] + }, + { + "teal": 1109, + "source": "tests/contracts/cblocks.algo.ts:450", + "pc": [ + 2954, + 2955, + 2956, + 2957, + 2958, + 2959, + 2960, + 2961, + 2962, + 2963, + 2964 + ] + }, + { + "teal": 1110, + "source": "tests/contracts/cblocks.algo.ts:450", + "pc": [ + 2965, + 2966, + 2967, + 2968, + 2969 + ] + }, + { + "teal": 1111, + "source": "tests/contracts/cblocks.algo.ts:450", + "pc": [ + 2970 + ] + }, + { + "teal": 1115, + "source": "tests/contracts/cblocks.algo.ts:451", + "pc": [ + 2971, + 2972, + 2973, + 2974, + 2975, + 2976, + 2977, + 2978, + 2979, + 2980, + 2981 + ] + }, + { + "teal": 1116, + "source": "tests/contracts/cblocks.algo.ts:451", + "pc": [ + 2982, + 2983, + 2984, + 2985, + 2986 + ] + }, + { + "teal": 1117, + "source": "tests/contracts/cblocks.algo.ts:451", + "pc": [ + 2987 + ] + }, + { + "teal": 1121, + "source": "tests/contracts/cblocks.algo.ts:452", + "pc": [ + 2988, + 2989, + 2990, + 2991, + 2992, + 2993, + 2994, + 2995, + 2996, + 2997, + 2998 + ] + }, + { + "teal": 1122, + "source": "tests/contracts/cblocks.algo.ts:452", + "pc": [ + 2999, + 3000, + 3001, + 3002, + 3003 + ] + }, + { + "teal": 1123, + "source": "tests/contracts/cblocks.algo.ts:452", + "pc": [ + 3004 + ] + }, + { + "teal": 1127, + "source": "tests/contracts/cblocks.algo.ts:453", + "pc": [ + 3005, + 3006, + 3007, + 3008, + 3009, + 3010, + 3011, + 3012, + 3013, + 3014, + 3015 + ] + }, + { + "teal": 1128, + "source": "tests/contracts/cblocks.algo.ts:453", + "pc": [ + 3016, + 3017, + 3018, + 3019, + 3020 + ] + }, + { + "teal": 1129, + "source": "tests/contracts/cblocks.algo.ts:453", + "pc": [ + 3021 + ] + }, + { + "teal": 1133, + "source": "tests/contracts/cblocks.algo.ts:454", + "pc": [ + 3022, + 3023, + 3024, + 3025, + 3026, + 3027, + 3028, + 3029, + 3030, + 3031, + 3032 + ] + }, + { + "teal": 1134, + "source": "tests/contracts/cblocks.algo.ts:454", + "pc": [ + 3033, + 3034, + 3035, + 3036, + 3037 + ] + }, + { + "teal": 1135, + "source": "tests/contracts/cblocks.algo.ts:454", + "pc": [ + 3038 + ] + }, + { + "teal": 1139, + "source": "tests/contracts/cblocks.algo.ts:455", + "pc": [ + 3039, + 3040, + 3041, + 3042, + 3043, + 3044, + 3045, + 3046, + 3047, + 3048, + 3049 + ] + }, + { + "teal": 1140, + "source": "tests/contracts/cblocks.algo.ts:455", + "pc": [ + 3050, + 3051, + 3052, + 3053, + 3054 + ] + }, + { + "teal": 1141, + "source": "tests/contracts/cblocks.algo.ts:455", + "pc": [ + 3055 + ] + }, + { + "teal": 1145, + "source": "tests/contracts/cblocks.algo.ts:456", + "pc": [ + 3056, + 3057, + 3058, + 3059, + 3060, + 3061, + 3062, + 3063, + 3064, + 3065, + 3066 + ] + }, + { + "teal": 1146, + "source": "tests/contracts/cblocks.algo.ts:456", + "pc": [ + 3067, + 3068, + 3069, + 3070, + 3071 + ] + }, + { + "teal": 1147, + "source": "tests/contracts/cblocks.algo.ts:456", + "pc": [ + 3072 + ] + }, + { + "teal": 1151, + "source": "tests/contracts/cblocks.algo.ts:457", + "pc": [ + 3073, + 3074, + 3075, + 3076, + 3077, + 3078, + 3079, + 3080, + 3081, + 3082, + 3083 + ] + }, + { + "teal": 1152, + "source": "tests/contracts/cblocks.algo.ts:457", + "pc": [ + 3084, + 3085, + 3086, + 3087, + 3088 + ] + }, + { + "teal": 1153, + "source": "tests/contracts/cblocks.algo.ts:457", + "pc": [ + 3089 + ] + }, + { + "teal": 1157, + "source": "tests/contracts/cblocks.algo.ts:458", + "pc": [ + 3090, + 3091, + 3092, + 3093, + 3094, + 3095, + 3096, + 3097, + 3098, + 3099, + 3100 + ] + }, + { + "teal": 1158, + "source": "tests/contracts/cblocks.algo.ts:458", + "pc": [ + 3101, + 3102, + 3103, + 3104, + 3105 + ] + }, + { + "teal": 1159, + "source": "tests/contracts/cblocks.algo.ts:458", + "pc": [ + 3106 + ] + }, + { + "teal": 1163, + "source": "tests/contracts/cblocks.algo.ts:459", + "pc": [ + 3107, + 3108, + 3109, + 3110, + 3111, + 3112, + 3113, + 3114, + 3115, + 3116, + 3117 + ] + }, + { + "teal": 1164, + "source": "tests/contracts/cblocks.algo.ts:459", + "pc": [ + 3118, + 3119, + 3120, + 3121, + 3122 + ] + }, + { + "teal": 1165, + "source": "tests/contracts/cblocks.algo.ts:459", + "pc": [ + 3123 + ] + }, + { + "teal": 1169, + "source": "tests/contracts/cblocks.algo.ts:460", + "pc": [ + 3124, + 3125, + 3126, + 3127, + 3128, + 3129, + 3130, + 3131, + 3132, + 3133, + 3134 + ] + }, + { + "teal": 1170, + "source": "tests/contracts/cblocks.algo.ts:460", + "pc": [ + 3135, + 3136, + 3137, + 3138, + 3139 + ] + }, + { + "teal": 1171, + "source": "tests/contracts/cblocks.algo.ts:460", + "pc": [ + 3140 + ] + }, + { + "teal": 1175, + "source": "tests/contracts/cblocks.algo.ts:461", + "pc": [ + 3141, + 3142, + 3143, + 3144, + 3145, + 3146, + 3147, + 3148, + 3149, + 3150, + 3151 + ] + }, + { + "teal": 1176, + "source": "tests/contracts/cblocks.algo.ts:461", + "pc": [ + 3152, + 3153, + 3154, + 3155, + 3156 + ] + }, + { + "teal": 1177, + "source": "tests/contracts/cblocks.algo.ts:461", + "pc": [ + 3157 + ] + }, + { + "teal": 1181, + "source": "tests/contracts/cblocks.algo.ts:462", + "pc": [ + 3158, + 3159, + 3160, + 3161, + 3162, + 3163, + 3164, + 3165, + 3166, + 3167, + 3168 + ] + }, + { + "teal": 1182, + "source": "tests/contracts/cblocks.algo.ts:462", + "pc": [ + 3169, + 3170, + 3171, + 3172, + 3173 + ] + }, + { + "teal": 1183, + "source": "tests/contracts/cblocks.algo.ts:462", + "pc": [ + 3174 + ] + }, + { + "teal": 1187, + "source": "tests/contracts/cblocks.algo.ts:463", + "pc": [ + 3175, + 3176, + 3177, + 3178, + 3179, + 3180, + 3181, + 3182, + 3183, + 3184, + 3185 + ] + }, + { + "teal": 1188, + "source": "tests/contracts/cblocks.algo.ts:463", + "pc": [ + 3186, + 3187, + 3188, + 3189, + 3190 + ] + }, + { + "teal": 1189, + "source": "tests/contracts/cblocks.algo.ts:463", + "pc": [ + 3191 + ] + }, + { + "teal": 1193, + "source": "tests/contracts/cblocks.algo.ts:464", + "pc": [ + 3192, + 3193, + 3194, + 3195, + 3196, + 3197, + 3198, + 3199, + 3200, + 3201, + 3202 + ] + }, + { + "teal": 1194, + "source": "tests/contracts/cblocks.algo.ts:464", + "pc": [ + 3203, + 3204, + 3205, + 3206, + 3207 + ] + }, + { + "teal": 1195, + "source": "tests/contracts/cblocks.algo.ts:464", + "pc": [ + 3208 + ] + }, + { + "teal": 1199, + "source": "tests/contracts/cblocks.algo.ts:465", + "pc": [ + 3209, + 3210, + 3211, + 3212, + 3213, + 3214, + 3215, + 3216, + 3217, + 3218, + 3219 + ] + }, + { + "teal": 1200, + "source": "tests/contracts/cblocks.algo.ts:465", + "pc": [ + 3220, + 3221, + 3222, + 3223, + 3224 + ] + }, + { + "teal": 1201, + "source": "tests/contracts/cblocks.algo.ts:465", + "pc": [ + 3225 + ] + }, + { + "teal": 1205, + "source": "tests/contracts/cblocks.algo.ts:466", + "pc": [ + 3226, + 3227, + 3228, + 3229, + 3230, + 3231, + 3232, + 3233, + 3234, + 3235, + 3236 + ] + }, + { + "teal": 1206, + "source": "tests/contracts/cblocks.algo.ts:466", + "pc": [ + 3237, + 3238, + 3239, + 3240, + 3241 + ] + }, + { + "teal": 1207, + "source": "tests/contracts/cblocks.algo.ts:466", + "pc": [ + 3242 + ] + }, + { + "teal": 1211, + "source": "tests/contracts/cblocks.algo.ts:467", + "pc": [ + 3243, + 3244, + 3245, + 3246, + 3247, + 3248, + 3249, + 3250, + 3251, + 3252, + 3253 + ] + }, + { + "teal": 1212, + "source": "tests/contracts/cblocks.algo.ts:467", + "pc": [ + 3254, + 3255, + 3256, + 3257, + 3258 + ] + }, + { + "teal": 1213, + "source": "tests/contracts/cblocks.algo.ts:467", + "pc": [ + 3259 + ] + }, + { + "teal": 1217, + "source": "tests/contracts/cblocks.algo.ts:468", + "pc": [ + 3260, + 3261, + 3262, + 3263, + 3264, + 3265, + 3266, + 3267, + 3268, + 3269, + 3270 + ] + }, + { + "teal": 1218, + "source": "tests/contracts/cblocks.algo.ts:468", + "pc": [ + 3271, + 3272, + 3273, + 3274, + 3275 + ] + }, + { + "teal": 1219, + "source": "tests/contracts/cblocks.algo.ts:468", + "pc": [ + 3276 + ] + }, + { + "teal": 1223, + "source": "tests/contracts/cblocks.algo.ts:469", + "pc": [ + 3277, + 3278, + 3279, + 3280, + 3281, + 3282, + 3283, + 3284, + 3285, + 3286, + 3287 + ] + }, + { + "teal": 1224, + "source": "tests/contracts/cblocks.algo.ts:469", + "pc": [ + 3288, + 3289, + 3290, + 3291, + 3292 + ] + }, + { + "teal": 1225, + "source": "tests/contracts/cblocks.algo.ts:469", + "pc": [ + 3293 + ] + }, + { + "teal": 1229, + "source": "tests/contracts/cblocks.algo.ts:470", + "pc": [ + 3294, + 3295, + 3296, + 3297, + 3298, + 3299, + 3300, + 3301, + 3302, + 3303, + 3304 + ] + }, + { + "teal": 1230, + "source": "tests/contracts/cblocks.algo.ts:470", + "pc": [ + 3305, + 3306, + 3307, + 3308, + 3309 + ] + }, + { + "teal": 1231, + "source": "tests/contracts/cblocks.algo.ts:470", + "pc": [ + 3310 + ] + }, + { + "teal": 1235, + "source": "tests/contracts/cblocks.algo.ts:471", + "pc": [ + 3311, + 3312, + 3313, + 3314, + 3315, + 3316, + 3317, + 3318, + 3319, + 3320, + 3321 + ] + }, + { + "teal": 1236, + "source": "tests/contracts/cblocks.algo.ts:471", + "pc": [ + 3322, + 3323, + 3324, + 3325, + 3326 + ] + }, + { + "teal": 1237, + "source": "tests/contracts/cblocks.algo.ts:471", + "pc": [ + 3327 + ] + }, + { + "teal": 1241, + "source": "tests/contracts/cblocks.algo.ts:472", + "pc": [ + 3328, + 3329, + 3330, + 3331, + 3332, + 3333, + 3334, + 3335, + 3336, + 3337, + 3338 + ] + }, + { + "teal": 1242, + "source": "tests/contracts/cblocks.algo.ts:472", + "pc": [ + 3339, + 3340, + 3341, + 3342, + 3343 + ] + }, + { + "teal": 1243, + "source": "tests/contracts/cblocks.algo.ts:472", + "pc": [ + 3344 + ] + }, + { + "teal": 1247, + "source": "tests/contracts/cblocks.algo.ts:473", + "pc": [ + 3345, + 3346, + 3347, + 3348, + 3349, + 3350, + 3351, + 3352, + 3353, + 3354, + 3355 + ] + }, + { + "teal": 1248, + "source": "tests/contracts/cblocks.algo.ts:473", + "pc": [ + 3356, + 3357, + 3358, + 3359, + 3360 + ] + }, + { + "teal": 1249, + "source": "tests/contracts/cblocks.algo.ts:473", + "pc": [ + 3361 + ] + }, + { + "teal": 1253, + "source": "tests/contracts/cblocks.algo.ts:474", + "pc": [ + 3362, + 3363, + 3364, + 3365, + 3366, + 3367, + 3368, + 3369, + 3370, + 3371, + 3372 + ] + }, + { + "teal": 1254, + "source": "tests/contracts/cblocks.algo.ts:474", + "pc": [ + 3373, + 3374, + 3375, + 3376, + 3377 + ] + }, + { + "teal": 1255, + "source": "tests/contracts/cblocks.algo.ts:474", + "pc": [ + 3378 + ] + }, + { + "teal": 1259, + "source": "tests/contracts/cblocks.algo.ts:475", + "pc": [ + 3379, + 3380, + 3381, + 3382, + 3383, + 3384, + 3385, + 3386, + 3387, + 3388, + 3389 + ] + }, + { + "teal": 1260, + "source": "tests/contracts/cblocks.algo.ts:475", + "pc": [ + 3390, + 3391, + 3392, + 3393, + 3394 + ] + }, + { + "teal": 1261, + "source": "tests/contracts/cblocks.algo.ts:475", + "pc": [ + 3395 + ] + }, + { + "teal": 1265, + "source": "tests/contracts/cblocks.algo.ts:476", + "pc": [ + 3396, + 3397, + 3398, + 3399, + 3400, + 3401, + 3402, + 3403, + 3404, + 3405, + 3406 + ] + }, + { + "teal": 1266, + "source": "tests/contracts/cblocks.algo.ts:476", + "pc": [ + 3407, + 3408, + 3409, + 3410, + 3411 + ] + }, + { + "teal": 1267, + "source": "tests/contracts/cblocks.algo.ts:476", + "pc": [ + 3412 + ] + }, + { + "teal": 1271, + "source": "tests/contracts/cblocks.algo.ts:477", + "pc": [ + 3413, + 3414, + 3415, + 3416, + 3417, + 3418, + 3419, + 3420, + 3421, + 3422, + 3423 + ] + }, + { + "teal": 1272, + "source": "tests/contracts/cblocks.algo.ts:477", + "pc": [ + 3424, + 3425, + 3426, + 3427, + 3428 + ] + }, + { + "teal": 1273, + "source": "tests/contracts/cblocks.algo.ts:477", + "pc": [ + 3429 + ] + }, + { + "teal": 1277, + "source": "tests/contracts/cblocks.algo.ts:478", + "pc": [ + 3430, + 3431, + 3432, + 3433, + 3434, + 3435, + 3436, + 3437, + 3438, + 3439, + 3440 + ] + }, + { + "teal": 1278, + "source": "tests/contracts/cblocks.algo.ts:478", + "pc": [ + 3441, + 3442, + 3443, + 3444, + 3445 + ] + }, + { + "teal": 1279, + "source": "tests/contracts/cblocks.algo.ts:478", + "pc": [ + 3446 + ] + }, + { + "teal": 1283, + "source": "tests/contracts/cblocks.algo.ts:479", + "pc": [ + 3447, + 3448, + 3449, + 3450, + 3451, + 3452, + 3453, + 3454, + 3455, + 3456, + 3457 + ] + }, + { + "teal": 1284, + "source": "tests/contracts/cblocks.algo.ts:479", + "pc": [ + 3458, + 3459, + 3460, + 3461, + 3462 + ] + }, + { + "teal": 1285, + "source": "tests/contracts/cblocks.algo.ts:479", + "pc": [ + 3463 + ] + }, + { + "teal": 1289, + "source": "tests/contracts/cblocks.algo.ts:480", + "pc": [ + 3464, + 3465, + 3466, + 3467, + 3468, + 3469, + 3470, + 3471, + 3472, + 3473, + 3474 + ] + }, + { + "teal": 1290, + "source": "tests/contracts/cblocks.algo.ts:480", + "pc": [ + 3475, + 3476, + 3477, + 3478, + 3479 + ] + }, + { + "teal": 1291, + "source": "tests/contracts/cblocks.algo.ts:480", + "pc": [ + 3480 + ] + }, + { + "teal": 1295, + "source": "tests/contracts/cblocks.algo.ts:481", + "pc": [ + 3481, + 3482, + 3483, + 3484, + 3485, + 3486, + 3487, + 3488, + 3489, + 3490, + 3491 + ] + }, + { + "teal": 1296, + "source": "tests/contracts/cblocks.algo.ts:481", + "pc": [ + 3492, + 3493, + 3494, + 3495, + 3496 + ] + }, + { + "teal": 1297, + "source": "tests/contracts/cblocks.algo.ts:481", + "pc": [ + 3497 + ] + }, + { + "teal": 1301, + "source": "tests/contracts/cblocks.algo.ts:482", + "pc": [ + 3498, + 3499, + 3500, + 3501, + 3502, + 3503, + 3504, + 3505, + 3506, + 3507, + 3508 + ] + }, + { + "teal": 1302, + "source": "tests/contracts/cblocks.algo.ts:482", + "pc": [ + 3509, + 3510, + 3511, + 3512, + 3513 + ] + }, + { + "teal": 1303, + "source": "tests/contracts/cblocks.algo.ts:482", + "pc": [ + 3514 + ] + }, + { + "teal": 1307, + "source": "tests/contracts/cblocks.algo.ts:483", + "pc": [ + 3515, + 3516, + 3517, + 3518, + 3519, + 3520, + 3521, + 3522, + 3523, + 3524, + 3525 + ] + }, + { + "teal": 1308, + "source": "tests/contracts/cblocks.algo.ts:483", + "pc": [ + 3526, + 3527, + 3528, + 3529, + 3530 + ] + }, + { + "teal": 1309, + "source": "tests/contracts/cblocks.algo.ts:483", + "pc": [ + 3531 + ] + }, + { + "teal": 1313, + "source": "tests/contracts/cblocks.algo.ts:484", + "pc": [ + 3532, + 3533, + 3534, + 3535, + 3536, + 3537, + 3538, + 3539, + 3540, + 3541, + 3542 + ] + }, + { + "teal": 1314, + "source": "tests/contracts/cblocks.algo.ts:484", + "pc": [ + 3543, + 3544, + 3545, + 3546, + 3547 + ] + }, + { + "teal": 1315, + "source": "tests/contracts/cblocks.algo.ts:484", + "pc": [ + 3548 + ] + }, + { + "teal": 1319, + "source": "tests/contracts/cblocks.algo.ts:485", + "pc": [ + 3549, + 3550, + 3551, + 3552, + 3553, + 3554, + 3555, + 3556, + 3557, + 3558, + 3559 + ] + }, + { + "teal": 1320, + "source": "tests/contracts/cblocks.algo.ts:485", + "pc": [ + 3560, + 3561, + 3562, + 3563, + 3564 + ] + }, + { + "teal": 1321, + "source": "tests/contracts/cblocks.algo.ts:485", + "pc": [ + 3565 + ] + }, + { + "teal": 1325, + "source": "tests/contracts/cblocks.algo.ts:486", + "pc": [ + 3566, + 3567, + 3568, + 3569, + 3570, + 3571, + 3572, + 3573, + 3574, + 3575, + 3576 + ] + }, + { + "teal": 1326, + "source": "tests/contracts/cblocks.algo.ts:486", + "pc": [ + 3577, + 3578, + 3579, + 3580, + 3581 + ] + }, + { + "teal": 1327, + "source": "tests/contracts/cblocks.algo.ts:486", + "pc": [ + 3582 + ] + }, + { + "teal": 1331, + "source": "tests/contracts/cblocks.algo.ts:487", + "pc": [ + 3583, + 3584, + 3585, + 3586, + 3587, + 3588, + 3589, + 3590, + 3591, + 3592, + 3593 + ] + }, + { + "teal": 1332, + "source": "tests/contracts/cblocks.algo.ts:487", + "pc": [ + 3594, + 3595, + 3596, + 3597, + 3598 + ] + }, + { + "teal": 1333, + "source": "tests/contracts/cblocks.algo.ts:487", + "pc": [ + 3599 + ] + }, + { + "teal": 1337, + "source": "tests/contracts/cblocks.algo.ts:488", + "pc": [ + 3600, + 3601, + 3602, + 3603, + 3604, + 3605, + 3606, + 3607, + 3608, + 3609, + 3610 + ] + }, + { + "teal": 1338, + "source": "tests/contracts/cblocks.algo.ts:488", + "pc": [ + 3611, + 3612, + 3613, + 3614, + 3615 + ] + }, + { + "teal": 1339, + "source": "tests/contracts/cblocks.algo.ts:488", + "pc": [ + 3616 + ] + }, + { + "teal": 1343, + "source": "tests/contracts/cblocks.algo.ts:489", + "pc": [ + 3617, + 3618, + 3619, + 3620, + 3621, + 3622, + 3623, + 3624, + 3625, + 3626, + 3627 + ] + }, + { + "teal": 1344, + "source": "tests/contracts/cblocks.algo.ts:489", + "pc": [ + 3628, + 3629, + 3630, + 3631, + 3632 + ] + }, + { + "teal": 1345, + "source": "tests/contracts/cblocks.algo.ts:489", + "pc": [ + 3633 + ] + }, + { + "teal": 1349, + "source": "tests/contracts/cblocks.algo.ts:490", + "pc": [ + 3634, + 3635, + 3636, + 3637, + 3638, + 3639, + 3640, + 3641, + 3642, + 3643, + 3644 + ] + }, + { + "teal": 1350, + "source": "tests/contracts/cblocks.algo.ts:490", + "pc": [ + 3645, + 3646, + 3647, + 3648, + 3649 + ] + }, + { + "teal": 1351, + "source": "tests/contracts/cblocks.algo.ts:490", + "pc": [ + 3650 + ] + }, + { + "teal": 1355, + "source": "tests/contracts/cblocks.algo.ts:491", + "pc": [ + 3651, + 3652, + 3653, + 3654, + 3655, + 3656, + 3657, + 3658, + 3659, + 3660, + 3661 + ] + }, + { + "teal": 1356, + "source": "tests/contracts/cblocks.algo.ts:491", + "pc": [ + 3662, + 3663, + 3664, + 3665, + 3666 + ] + }, + { + "teal": 1357, + "source": "tests/contracts/cblocks.algo.ts:491", + "pc": [ + 3667 + ] + }, + { + "teal": 1361, + "source": "tests/contracts/cblocks.algo.ts:492", + "pc": [ + 3668, + 3669, + 3670, + 3671, + 3672, + 3673, + 3674, + 3675, + 3676, + 3677, + 3678 + ] + }, + { + "teal": 1362, + "source": "tests/contracts/cblocks.algo.ts:492", + "pc": [ + 3679, + 3680, + 3681, + 3682, + 3683 + ] + }, + { + "teal": 1363, + "source": "tests/contracts/cblocks.algo.ts:492", + "pc": [ + 3684 + ] + }, + { + "teal": 1367, + "source": "tests/contracts/cblocks.algo.ts:493", + "pc": [ + 3685, + 3686, + 3687, + 3688, + 3689, + 3690, + 3691, + 3692, + 3693, + 3694, + 3695 + ] + }, + { + "teal": 1368, + "source": "tests/contracts/cblocks.algo.ts:493", + "pc": [ + 3696, + 3697, + 3698, + 3699, + 3700 + ] + }, + { + "teal": 1369, + "source": "tests/contracts/cblocks.algo.ts:493", + "pc": [ + 3701 + ] + }, + { + "teal": 1373, + "source": "tests/contracts/cblocks.algo.ts:494", + "pc": [ + 3702, + 3703, + 3704, + 3705, + 3706, + 3707, + 3708, + 3709, + 3710, + 3711, + 3712 + ] + }, + { + "teal": 1374, + "source": "tests/contracts/cblocks.algo.ts:494", + "pc": [ + 3713, + 3714, + 3715, + 3716, + 3717 + ] + }, + { + "teal": 1375, + "source": "tests/contracts/cblocks.algo.ts:494", + "pc": [ + 3718 + ] + }, + { + "teal": 1379, + "source": "tests/contracts/cblocks.algo.ts:495", + "pc": [ + 3719, + 3720, + 3721, + 3722, + 3723, + 3724, + 3725, + 3726, + 3727, + 3728, + 3729 + ] + }, + { + "teal": 1380, + "source": "tests/contracts/cblocks.algo.ts:495", + "pc": [ + 3730, + 3731, + 3732, + 3733, + 3734 + ] + }, + { + "teal": 1381, + "source": "tests/contracts/cblocks.algo.ts:495", + "pc": [ + 3735 + ] + }, + { + "teal": 1385, + "source": "tests/contracts/cblocks.algo.ts:496", + "pc": [ + 3736, + 3737, + 3738, + 3739, + 3740, + 3741, + 3742, + 3743, + 3744, + 3745, + 3746 + ] + }, + { + "teal": 1386, + "source": "tests/contracts/cblocks.algo.ts:496", + "pc": [ + 3747, + 3748, + 3749, + 3750, + 3751 + ] + }, + { + "teal": 1387, + "source": "tests/contracts/cblocks.algo.ts:496", + "pc": [ + 3752 + ] + }, + { + "teal": 1391, + "source": "tests/contracts/cblocks.algo.ts:497", + "pc": [ + 3753, + 3754, + 3755, + 3756, + 3757, + 3758, + 3759, + 3760, + 3761, + 3762, + 3763 + ] + }, + { + "teal": 1392, + "source": "tests/contracts/cblocks.algo.ts:497", + "pc": [ + 3764, + 3765, + 3766, + 3767, + 3768 + ] + }, + { + "teal": 1393, + "source": "tests/contracts/cblocks.algo.ts:497", + "pc": [ + 3769 + ] + }, + { + "teal": 1397, + "source": "tests/contracts/cblocks.algo.ts:498", + "pc": [ + 3770, + 3771, + 3772, + 3773, + 3774, + 3775, + 3776, + 3777, + 3778, + 3779, + 3780 + ] + }, + { + "teal": 1398, + "source": "tests/contracts/cblocks.algo.ts:498", + "pc": [ + 3781, + 3782, + 3783, + 3784, + 3785 + ] + }, + { + "teal": 1399, + "source": "tests/contracts/cblocks.algo.ts:498", + "pc": [ + 3786 + ] + }, + { + "teal": 1403, + "source": "tests/contracts/cblocks.algo.ts:499", + "pc": [ + 3787, + 3788, + 3789, + 3790, + 3791, + 3792, + 3793, + 3794, + 3795, + 3796, + 3797 + ] + }, + { + "teal": 1404, + "source": "tests/contracts/cblocks.algo.ts:499", + "pc": [ + 3798, + 3799, + 3800, + 3801, + 3802 + ] + }, + { + "teal": 1405, + "source": "tests/contracts/cblocks.algo.ts:499", + "pc": [ + 3803 + ] + }, + { + "teal": 1409, + "source": "tests/contracts/cblocks.algo.ts:500", + "pc": [ + 3804, + 3805, + 3806, + 3807, + 3808, + 3809, + 3810, + 3811, + 3812, + 3813, + 3814 + ] + }, + { + "teal": 1410, + "source": "tests/contracts/cblocks.algo.ts:500", + "pc": [ + 3815, + 3816, + 3817, + 3818, + 3819 + ] + }, + { + "teal": 1411, + "source": "tests/contracts/cblocks.algo.ts:500", + "pc": [ + 3820 + ] + }, + { + "teal": 1415, + "source": "tests/contracts/cblocks.algo.ts:501", + "pc": [ + 3821, + 3822, + 3823, + 3824, + 3825, + 3826, + 3827, + 3828, + 3829, + 3830, + 3831 + ] + }, + { + "teal": 1416, + "source": "tests/contracts/cblocks.algo.ts:501", + "pc": [ + 3832, + 3833, + 3834, + 3835, + 3836 + ] + }, + { + "teal": 1417, + "source": "tests/contracts/cblocks.algo.ts:501", + "pc": [ + 3837 + ] + }, + { + "teal": 1421, + "source": "tests/contracts/cblocks.algo.ts:502", + "pc": [ + 3838, + 3839, + 3840, + 3841, + 3842, + 3843, + 3844, + 3845, + 3846, + 3847, + 3848 + ] + }, + { + "teal": 1422, + "source": "tests/contracts/cblocks.algo.ts:502", + "pc": [ + 3849, + 3850, + 3851, + 3852, + 3853 + ] + }, + { + "teal": 1423, + "source": "tests/contracts/cblocks.algo.ts:502", + "pc": [ + 3854 + ] + }, + { + "teal": 1427, + "source": "tests/contracts/cblocks.algo.ts:503", + "pc": [ + 3855, + 3856, + 3857, + 3858, + 3859, + 3860, + 3861, + 3862, + 3863, + 3864, + 3865 + ] + }, + { + "teal": 1428, + "source": "tests/contracts/cblocks.algo.ts:503", + "pc": [ + 3866, + 3867, + 3868, + 3869, + 3870 + ] + }, + { + "teal": 1429, + "source": "tests/contracts/cblocks.algo.ts:503", + "pc": [ + 3871 + ] + }, + { + "teal": 1433, + "source": "tests/contracts/cblocks.algo.ts:504", + "pc": [ + 3872, + 3873, + 3874, + 3875, + 3876, + 3877, + 3878, + 3879, + 3880, + 3881, + 3882 + ] + }, + { + "teal": 1434, + "source": "tests/contracts/cblocks.algo.ts:504", + "pc": [ + 3883, + 3884, + 3885, + 3886, + 3887 + ] + }, + { + "teal": 1435, + "source": "tests/contracts/cblocks.algo.ts:504", + "pc": [ + 3888 + ] + }, + { + "teal": 1439, + "source": "tests/contracts/cblocks.algo.ts:505", + "pc": [ + 3889, + 3890, + 3891, + 3892, + 3893, + 3894, + 3895, + 3896, + 3897, + 3898, + 3899 + ] + }, + { + "teal": 1440, + "source": "tests/contracts/cblocks.algo.ts:505", + "pc": [ + 3900, + 3901, + 3902, + 3903, + 3904 + ] + }, + { + "teal": 1441, + "source": "tests/contracts/cblocks.algo.ts:505", + "pc": [ + 3905 + ] + }, + { + "teal": 1445, + "source": "tests/contracts/cblocks.algo.ts:506", + "pc": [ + 3906, + 3907, + 3908, + 3909, + 3910, + 3911, + 3912, + 3913, + 3914, + 3915, + 3916 + ] + }, + { + "teal": 1446, + "source": "tests/contracts/cblocks.algo.ts:506", + "pc": [ + 3917, + 3918, + 3919, + 3920, + 3921 + ] + }, + { + "teal": 1447, + "source": "tests/contracts/cblocks.algo.ts:506", + "pc": [ + 3922 + ] + }, + { + "teal": 1451, + "source": "tests/contracts/cblocks.algo.ts:507", + "pc": [ + 3923, + 3924, + 3925, + 3926, + 3927, + 3928, + 3929, + 3930, + 3931, + 3932, + 3933 + ] + }, + { + "teal": 1452, + "source": "tests/contracts/cblocks.algo.ts:507", + "pc": [ + 3934, + 3935, + 3936, + 3937, + 3938 + ] + }, + { + "teal": 1453, + "source": "tests/contracts/cblocks.algo.ts:507", + "pc": [ + 3939 + ] + }, + { + "teal": 1457, + "source": "tests/contracts/cblocks.algo.ts:508", + "pc": [ + 3940, + 3941, + 3942, + 3943, + 3944, + 3945, + 3946, + 3947, + 3948, + 3949, + 3950 + ] + }, + { + "teal": 1458, + "source": "tests/contracts/cblocks.algo.ts:508", + "pc": [ + 3951, + 3952, + 3953, + 3954, + 3955 + ] + }, + { + "teal": 1459, + "source": "tests/contracts/cblocks.algo.ts:508", + "pc": [ + 3956 + ] + }, + { + "teal": 1463, + "source": "tests/contracts/cblocks.algo.ts:509", + "pc": [ + 3957, + 3958, + 3959, + 3960, + 3961, + 3962, + 3963, + 3964, + 3965, + 3966, + 3967 + ] + }, + { + "teal": 1464, + "source": "tests/contracts/cblocks.algo.ts:509", + "pc": [ + 3968, + 3969, + 3970, + 3971, + 3972 + ] + }, + { + "teal": 1465, + "source": "tests/contracts/cblocks.algo.ts:509", + "pc": [ + 3973 + ] + }, + { + "teal": 1469, + "source": "tests/contracts/cblocks.algo.ts:510", + "pc": [ + 3974, + 3975, + 3976, + 3977, + 3978, + 3979, + 3980, + 3981, + 3982, + 3983, + 3984 + ] + }, + { + "teal": 1470, + "source": "tests/contracts/cblocks.algo.ts:510", + "pc": [ + 3985, + 3986, + 3987, + 3988, + 3989 + ] + }, + { + "teal": 1471, + "source": "tests/contracts/cblocks.algo.ts:510", + "pc": [ + 3990 + ] + }, + { + "teal": 1475, + "source": "tests/contracts/cblocks.algo.ts:511", + "pc": [ + 3991, + 3992, + 3993, + 3994, + 3995, + 3996, + 3997, + 3998, + 3999, + 4000, + 4001 + ] + }, + { + "teal": 1476, + "source": "tests/contracts/cblocks.algo.ts:511", + "pc": [ + 4002, + 4003, + 4004, + 4005, + 4006 + ] + }, + { + "teal": 1477, + "source": "tests/contracts/cblocks.algo.ts:511", + "pc": [ + 4007 + ] + }, + { + "teal": 1481, + "source": "tests/contracts/cblocks.algo.ts:512", + "pc": [ + 4008, + 4009, + 4010, + 4011, + 4012, + 4013, + 4014, + 4015, + 4016, + 4017, + 4018 + ] + }, + { + "teal": 1482, + "source": "tests/contracts/cblocks.algo.ts:512", + "pc": [ + 4019, + 4020, + 4021, + 4022, + 4023 + ] + }, + { + "teal": 1483, + "source": "tests/contracts/cblocks.algo.ts:512", + "pc": [ + 4024 + ] + }, + { + "teal": 1487, + "source": "tests/contracts/cblocks.algo.ts:513", + "pc": [ + 4025, + 4026, + 4027, + 4028, + 4029, + 4030, + 4031, + 4032, + 4033, + 4034, + 4035 + ] + }, + { + "teal": 1488, + "source": "tests/contracts/cblocks.algo.ts:513", + "pc": [ + 4036, + 4037, + 4038, + 4039, + 4040 + ] + }, + { + "teal": 1489, + "source": "tests/contracts/cblocks.algo.ts:513", + "pc": [ + 4041 + ] + }, + { + "teal": 1493, + "source": "tests/contracts/cblocks.algo.ts:514", + "pc": [ + 4042, + 4043, + 4044, + 4045, + 4046, + 4047, + 4048, + 4049, + 4050, + 4051, + 4052 + ] + }, + { + "teal": 1494, + "source": "tests/contracts/cblocks.algo.ts:514", + "pc": [ + 4053, + 4054, + 4055, + 4056, + 4057 + ] + }, + { + "teal": 1495, + "source": "tests/contracts/cblocks.algo.ts:514", + "pc": [ + 4058 + ] + }, + { + "teal": 1499, + "source": "tests/contracts/cblocks.algo.ts:515", + "pc": [ + 4059, + 4060, + 4061, + 4062, + 4063, + 4064, + 4065, + 4066, + 4067, + 4068, + 4069 + ] + }, + { + "teal": 1500, + "source": "tests/contracts/cblocks.algo.ts:515", + "pc": [ + 4070, + 4071, + 4072, + 4073, + 4074 + ] + }, + { + "teal": 1501, + "source": "tests/contracts/cblocks.algo.ts:515", + "pc": [ + 4075 + ] + }, + { + "teal": 1505, + "source": "tests/contracts/cblocks.algo.ts:516", + "pc": [ + 4076, + 4077, + 4078, + 4079, + 4080, + 4081, + 4082, + 4083, + 4084, + 4085, + 4086 + ] + }, + { + "teal": 1506, + "source": "tests/contracts/cblocks.algo.ts:516", + "pc": [ + 4087, + 4088, + 4089, + 4090, + 4091 + ] + }, + { + "teal": 1507, + "source": "tests/contracts/cblocks.algo.ts:516", + "pc": [ + 4092 + ] + }, + { + "teal": 1511, + "source": "tests/contracts/cblocks.algo.ts:517", + "pc": [ + 4093, + 4094, + 4095, + 4096, + 4097, + 4098, + 4099, + 4100, + 4101, + 4102, + 4103 + ] + }, + { + "teal": 1512, + "source": "tests/contracts/cblocks.algo.ts:517", + "pc": [ + 4104, + 4105, + 4106, + 4107, + 4108 + ] + }, + { + "teal": 1513, + "source": "tests/contracts/cblocks.algo.ts:517", + "pc": [ + 4109 + ] + }, + { + "teal": 1517, + "source": "tests/contracts/cblocks.algo.ts:518", + "pc": [ + 4110, + 4111, + 4112, + 4113, + 4114, + 4115, + 4116, + 4117, + 4118, + 4119, + 4120 + ] + }, + { + "teal": 1518, + "source": "tests/contracts/cblocks.algo.ts:518", + "pc": [ + 4121, + 4122, + 4123, + 4124, + 4125 + ] + }, + { + "teal": 1519, + "source": "tests/contracts/cblocks.algo.ts:518", + "pc": [ + 4126 + ] + }, + { + "teal": 1523, + "source": "tests/contracts/cblocks.algo.ts:519", + "pc": [ + 4127, + 4128, + 4129, + 4130, + 4131, + 4132, + 4133, + 4134, + 4135, + 4136, + 4137 + ] + }, + { + "teal": 1524, + "source": "tests/contracts/cblocks.algo.ts:519", + "pc": [ + 4138, + 4139, + 4140, + 4141, + 4142 + ] + }, + { + "teal": 1525, + "source": "tests/contracts/cblocks.algo.ts:519", + "pc": [ + 4143 + ] + }, + { + "teal": 1529, + "source": "tests/contracts/cblocks.algo.ts:520", + "pc": [ + 4144, + 4145, + 4146, + 4147, + 4148, + 4149, + 4150, + 4151, + 4152, + 4153, + 4154 + ] + }, + { + "teal": 1530, + "source": "tests/contracts/cblocks.algo.ts:520", + "pc": [ + 4155, + 4156, + 4157, + 4158, + 4159 + ] + }, + { + "teal": 1531, + "source": "tests/contracts/cblocks.algo.ts:520", + "pc": [ + 4160 + ] + }, + { + "teal": 1535, + "source": "tests/contracts/cblocks.algo.ts:521", + "pc": [ + 4161, + 4162, + 4163, + 4164, + 4165, + 4166, + 4167, + 4168, + 4169, + 4170, + 4171 + ] + }, + { + "teal": 1536, + "source": "tests/contracts/cblocks.algo.ts:521", + "pc": [ + 4172, + 4173, + 4174, + 4175, + 4176 + ] + }, + { + "teal": 1537, + "source": "tests/contracts/cblocks.algo.ts:521", + "pc": [ + 4177 + ] + }, + { + "teal": 1541, + "source": "tests/contracts/cblocks.algo.ts:522", + "pc": [ + 4178, + 4179, + 4180, + 4181, + 4182, + 4183, + 4184, + 4185, + 4186, + 4187, + 4188 + ] + }, + { + "teal": 1542, + "source": "tests/contracts/cblocks.algo.ts:522", + "pc": [ + 4189, + 4190, + 4191, + 4192, + 4193 + ] + }, + { + "teal": 1543, + "source": "tests/contracts/cblocks.algo.ts:522", + "pc": [ + 4194 + ] + }, + { + "teal": 1547, + "source": "tests/contracts/cblocks.algo.ts:523", + "pc": [ + 4195, + 4196, + 4197, + 4198, + 4199, + 4200, + 4201, + 4202, + 4203, + 4204, + 4205 + ] + }, + { + "teal": 1548, + "source": "tests/contracts/cblocks.algo.ts:523", + "pc": [ + 4206, + 4207, + 4208, + 4209, + 4210 + ] + }, + { + "teal": 1549, + "source": "tests/contracts/cblocks.algo.ts:523", + "pc": [ + 4211 + ] + }, + { + "teal": 1553, + "source": "tests/contracts/cblocks.algo.ts:524", + "pc": [ + 4212, + 4213, + 4214, + 4215, + 4216, + 4217, + 4218, + 4219, + 4220, + 4221, + 4222 + ] + }, + { + "teal": 1554, + "source": "tests/contracts/cblocks.algo.ts:524", + "pc": [ + 4223, + 4224, + 4225, + 4226, + 4227 + ] + }, + { + "teal": 1555, + "source": "tests/contracts/cblocks.algo.ts:524", + "pc": [ + 4228 + ] + }, + { + "teal": 1559, + "source": "tests/contracts/cblocks.algo.ts:525", + "pc": [ + 4229, + 4230, + 4231, + 4232, + 4233, + 4234, + 4235, + 4236, + 4237, + 4238, + 4239 + ] + }, + { + "teal": 1560, + "source": "tests/contracts/cblocks.algo.ts:525", + "pc": [ + 4240, + 4241, + 4242, + 4243, + 4244 + ] + }, + { + "teal": 1561, + "source": "tests/contracts/cblocks.algo.ts:525", + "pc": [ + 4245 + ] + }, + { + "teal": 1565, + "source": "tests/contracts/cblocks.algo.ts:526", + "pc": [ + 4246, + 4247, + 4248, + 4249, + 4250, + 4251, + 4252, + 4253, + 4254, + 4255, + 4256 + ] + }, + { + "teal": 1566, + "source": "tests/contracts/cblocks.algo.ts:526", + "pc": [ + 4257, + 4258, + 4259, + 4260, + 4261 + ] + }, + { + "teal": 1567, + "source": "tests/contracts/cblocks.algo.ts:526", + "pc": [ + 4262 + ] + }, + { + "teal": 1571, + "source": "tests/contracts/cblocks.algo.ts:527", + "pc": [ + 4263, + 4264, + 4265, + 4266, + 4267, + 4268, + 4269, + 4270, + 4271, + 4272, + 4273 + ] + }, + { + "teal": 1572, + "source": "tests/contracts/cblocks.algo.ts:527", + "pc": [ + 4274, + 4275, + 4276, + 4277, + 4278 + ] + }, + { + "teal": 1573, + "source": "tests/contracts/cblocks.algo.ts:527", + "pc": [ + 4279 + ] + }, + { + "teal": 1577, + "source": "tests/contracts/cblocks.algo.ts:528", + "pc": [ + 4280, + 4281, + 4282, + 4283, + 4284, + 4285, + 4286, + 4287, + 4288, + 4289, + 4290 + ] + }, + { + "teal": 1578, + "source": "tests/contracts/cblocks.algo.ts:528", + "pc": [ + 4291, + 4292, + 4293, + 4294, + 4295 + ] + }, + { + "teal": 1579, + "source": "tests/contracts/cblocks.algo.ts:528", + "pc": [ + 4296 + ] + }, + { + "teal": 1583, + "source": "tests/contracts/cblocks.algo.ts:529", + "pc": [ + 4297, + 4298, + 4299, + 4300, + 4301, + 4302, + 4303, + 4304, + 4305, + 4306, + 4307 + ] + }, + { + "teal": 1584, + "source": "tests/contracts/cblocks.algo.ts:529", + "pc": [ + 4308, + 4309, + 4310, + 4311, + 4312 + ] + }, + { + "teal": 1585, + "source": "tests/contracts/cblocks.algo.ts:529", + "pc": [ + 4313 + ] + }, + { + "teal": 1589, + "source": "tests/contracts/cblocks.algo.ts:530", + "pc": [ + 4314, + 4315, + 4316, + 4317, + 4318, + 4319, + 4320, + 4321, + 4322, + 4323, + 4324 + ] + }, + { + "teal": 1590, + "source": "tests/contracts/cblocks.algo.ts:530", + "pc": [ + 4325, + 4326, + 4327, + 4328, + 4329 + ] + }, + { + "teal": 1591, + "source": "tests/contracts/cblocks.algo.ts:530", + "pc": [ + 4330 + ] + }, + { + "teal": 1596, + "source": "tests/contracts/cblocks.algo.ts:532", + "pc": [ + 4331, + 4332, + 4333, + 4334, + 4335, + 4336, + 4337, + 4338, + 4339, + 4340, + 4341 + ] + }, + { + "teal": 1597, + "source": "tests/contracts/cblocks.algo.ts:533", + "pc": [ + 4342, + 4343, + 4344, + 4345, + 4346, + 4347, + 4348, + 4349, + 4350, + 4351, + 4352, + 4353, + 4354, + 4355, + 4356, + 4357, + 4358, + 4359, + 4360, + 4361, + 4362, + 4363, + 4364, + 4365, + 4366, + 4367, + 4368, + 4369, + 4370, + 4371, + 4372, + 4373, + 4374, + 4375, + 4376, + 4377, + 4378, + 4379, + 4380, + 4381, + 4382, + 4383, + 4384, + 4385, + 4386, + 4387, + 4388, + 4389, + 4390, + 4391, + 4392, + 4393, + 4394, + 4395, + 4396, + 4397, + 4398, + 4399, + 4400, + 4401, + 4402, + 4403, + 4404, + 4405, + 4406, + 4407, + 4408, + 4409, + 4410, + 4411, + 4412, + 4413, + 4414, + 4415, + 4416, + 4417, + 4418, + 4419, + 4420, + 4421, + 4422, + 4423, + 4424, + 4425, + 4426, + 4427, + 4428, + 4429, + 4430, + 4431, + 4432, + 4433, + 4434, + 4435, + 4436 + ] + }, + { + "teal": 1598, + "source": "tests/contracts/cblocks.algo.ts:532", + "pc": [ + 4437 + ] + }, + { + "teal": 1602, + "source": "tests/contracts/cblocks.algo.ts:535", + "pc": [ + 4438, + 4439, + 4440 + ] + }, + { + "teal": 1603, + "source": "tests/contracts/cblocks.algo.ts:535", + "pc": [ + 4441, + 4442, + 4443, + 4444, + 4445 + ] + }, + { + "teal": 1604, + "source": "tests/contracts/cblocks.algo.ts:535", + "pc": [ + 4446 + ] + }, + { + "teal": 1605, + "source": "tests/contracts/cblocks.algo.ts:273", + "pc": [ + 4447 + ] + }, + { + "teal": 1608, + "source": "tests/contracts/cblocks.algo.ts:270", + "pc": [ + 4448, + 4449 + ] + }, + { + "teal": 1609, + "source": "tests/contracts/cblocks.algo.ts:270", + "pc": [ + 4450 + ] + }, + { + "teal": 1612, + "source": "tests/contracts/cblocks.algo.ts:270", + "pc": [ + 4451, + 4452, + 4453, + 4454, + 4455, + 4456 + ] + }, + { + "teal": 1613, + "source": "tests/contracts/cblocks.algo.ts:270", + "pc": [ + 4457, + 4458, + 4459 + ] }, { + "teal": 1614, + "source": "tests/contracts/cblocks.algo.ts:270", + "pc": [ + 4460, + 4461, + 4462, + 4463 + ] + }, + { + "teal": 1617, + "source": "tests/contracts/cblocks.algo.ts:270", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 4464 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 1620, + "source": "tests/contracts/cblocks.algo.ts:270", + "pc": [ + 4465, + 4466, + 4467, + 4468, + 4469, + 4470 + ] + }, + { + "teal": 1621, + "source": "tests/contracts/cblocks.algo.ts:270", + "pc": [ + 4471, + 4472, + 4473 + ] + }, + { + "teal": 1622, + "source": "tests/contracts/cblocks.algo.ts:270", + "pc": [ + 4474, + 4475, + 4476, + 4477 + ] }, { + "teal": 1625, + "source": "tests/contracts/cblocks.algo.ts:270", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 4478 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/C.arc56_draft.json b/tests/contracts/artifacts/C.arc56_draft.json index bd2a91453..453cb66f2 100644 --- a/tests/contracts/artifacts/C.arc56_draft.json +++ b/tests/contracts/artifacts/C.arc56_draft.json @@ -101,22 +101,514 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/inheritance.algo.ts:29", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/inheritance.algo.ts:29", + "pc": [ + 1, + 2, + 3, + 4, + 5, + 6 + ] + }, + { + "teal": 14, + "source": "tests/contracts/inheritance.algo.ts:29", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 15, + "source": "tests/contracts/inheritance.algo.ts:29", + "pc": [ + 9 + ] + }, + { + "teal": 16, + "source": "tests/contracts/inheritance.algo.ts:29", + "pc": [ + 10, + 11 + ] + }, + { + "teal": 17, + "source": "tests/contracts/inheritance.algo.ts:29", + "pc": [ + 12 + ] + }, + { + "teal": 18, + "source": "tests/contracts/inheritance.algo.ts:29", + "pc": [ + 13, + 14 + ] + }, + { + "teal": 19, + "source": "tests/contracts/inheritance.algo.ts:29", + "pc": [ + 15 + ] + }, + { + "teal": 20, + "source": "tests/contracts/inheritance.algo.ts:29", + "pc": [ + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38, + 39, + 40, + 41 + ] + }, + { + "teal": 24, + "source": "tests/contracts/inheritance.algo.ts:29", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 42 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/inheritance.algo.ts:15", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 30, + "source": "tests/contracts/inheritance.algo.ts:15", + "pc": [ + 46, + 47 + ] + }, + { + "teal": 31, + "source": "tests/contracts/inheritance.algo.ts:15", + "pc": [ + 48 + ] + }, + { + "teal": 35, + "source": "tests/contracts/inheritance.algo.ts:15", + "pc": [ + 49, + 50, + 51 + ] + }, + { + "teal": 39, + "source": "tests/contracts/inheritance.algo.ts:16", + "pc": [ + 52, + 53, + 54 + ] }, { + "teal": 40, + "source": "tests/contracts/inheritance.algo.ts:16", + "pc": [ + 55, + 56, + 57 + ] + }, + { + "teal": 41, + "source": "tests/contracts/inheritance.algo.ts:16", + "pc": [ + 58 + ] + }, + { + "teal": 42, + "source": "tests/contracts/inheritance.algo.ts:15", + "pc": [ + 59 + ] + }, + { + "teal": 47, + "source": "tests/contracts/inheritance.algo.ts:23", + "pc": [ + 60, + 61, + 62 + ] + }, + { + "teal": 48, + "source": "tests/contracts/inheritance.algo.ts:23", + "pc": [ + 63, + 64 + ] + }, + { + "teal": 49, + "source": "tests/contracts/inheritance.algo.ts:23", + "pc": [ + 65 + ] + }, + { + "teal": 53, + "source": "tests/contracts/inheritance.algo.ts:23", + "pc": [ + 66, + 67, + 68 + ] + }, + { + "teal": 57, + "source": "tests/contracts/inheritance.algo.ts:24", + "pc": [ + 69, + 70, + 71 + ] + }, + { + "teal": 58, + "source": "tests/contracts/inheritance.algo.ts:24", + "pc": [ + 72 + ] + }, + { + "teal": 59, + "source": "tests/contracts/inheritance.algo.ts:24", + "pc": [ + 73, + 74, + 75 + ] + }, + { + "teal": 60, + "source": "tests/contracts/inheritance.algo.ts:24", + "pc": [ + 76 + ] + }, + { + "teal": 61, + "source": "tests/contracts/inheritance.algo.ts:24", + "pc": [ + 77 + ] + }, + { + "teal": 65, + "source": "tests/contracts/inheritance.algo.ts:25", + "pc": [ + 78, + 79, + 80 + ] + }, + { + "teal": 66, + "source": "tests/contracts/inheritance.algo.ts:25", + "pc": [ + 81, + 82 + ] + }, + { + "teal": 67, + "source": "tests/contracts/inheritance.algo.ts:25", + "pc": [ + 83 + ] + }, + { + "teal": 68, + "source": "tests/contracts/inheritance.algo.ts:23", + "pc": [ + 84 + ] + }, + { + "teal": 73, + "source": "tests/contracts/inheritance.algo.ts:30", + "pc": [ + 85, + 86, + 87 + ] + }, + { + "teal": 74, + "source": "tests/contracts/inheritance.algo.ts:30", + "pc": [ + 88, + 89 + ] + }, + { + "teal": 75, + "source": "tests/contracts/inheritance.algo.ts:30", + "pc": [ + 90 + ] + }, + { + "teal": 79, + "source": "tests/contracts/inheritance.algo.ts:30", + "pc": [ + 91, + 92, + 93 + ] + }, + { + "teal": 83, + "source": "tests/contracts/inheritance.algo.ts:31", + "pc": [ + 94, + 95, + 96 + ] + }, + { + "teal": 84, + "source": "tests/contracts/inheritance.algo.ts:31", + "pc": [ + 97 + ] + }, + { + "teal": 85, + "source": "tests/contracts/inheritance.algo.ts:31", + "pc": [ + 98, + 99 + ] + }, + { + "teal": 86, + "source": "tests/contracts/inheritance.algo.ts:31", + "pc": [ + 100 + ] + }, + { + "teal": 87, + "source": "tests/contracts/inheritance.algo.ts:31", + "pc": [ + 101 + ] + }, + { + "teal": 91, + "source": "tests/contracts/inheritance.algo.ts:32", + "pc": [ + 102, + 103, + 104 + ] + }, + { + "teal": 92, + "source": "tests/contracts/inheritance.algo.ts:32", + "pc": [ + 105 + ] + }, + { + "teal": 93, + "source": "tests/contracts/inheritance.algo.ts:32", + "pc": [ + 106, + 107, + 108 + ] + }, + { + "teal": 94, + "source": "tests/contracts/inheritance.algo.ts:32", + "pc": [ + 109 + ] + }, + { + "teal": 95, + "source": "tests/contracts/inheritance.algo.ts:32", + "pc": [ + 110 + ] + }, + { + "teal": 96, + "source": "tests/contracts/inheritance.algo.ts:30", + "pc": [ + 111 + ] + }, + { + "teal": 99, + "source": "tests/contracts/inheritance.algo.ts:29", + "pc": [ + 112, + 113 + ] + }, + { + "teal": 100, + "source": "tests/contracts/inheritance.algo.ts:29", + "pc": [ + 114 + ] + }, + { + "teal": 103, + "source": "tests/contracts/inheritance.algo.ts:29", + "pc": [ + 115, + 116, + 117, + 118, + 119, + 120 + ] + }, + { + "teal": 104, + "source": "tests/contracts/inheritance.algo.ts:29", + "pc": [ + 121, + 122, + 123 + ] + }, + { + "teal": 105, + "source": "tests/contracts/inheritance.algo.ts:29", + "pc": [ + 124, + 125, + 126, + 127 + ] + }, + { + "teal": 108, + "source": "tests/contracts/inheritance.algo.ts:29", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 128 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 111, + "source": "tests/contracts/inheritance.algo.ts:29", + "pc": [ + 129, + 130, + 131, + 132, + 133, + 134 + ] + }, + { + "teal": 112, + "source": "tests/contracts/inheritance.algo.ts:29", + "pc": [ + 135, + 136, + 137, + 138, + 139, + 140 + ] + }, + { + "teal": 113, + "source": "tests/contracts/inheritance.algo.ts:29", + "pc": [ + 141, + 142, + 143, + 144, + 145, + 146 + ] + }, + { + "teal": 114, + "source": "tests/contracts/inheritance.algo.ts:29", + "pc": [ + 147, + 148, + 149 + ] + }, + { + "teal": 115, + "source": "tests/contracts/inheritance.algo.ts:29", + "pc": [ + 150, + 151, + 152, + 153, + 154, + 155, + 156, + 157 + ] }, { + "teal": 118, + "source": "tests/contracts/inheritance.algo.ts:29", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 158 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ContractWithCustomStruct.arc56_draft.json b/tests/contracts/artifacts/ContractWithCustomStruct.arc56_draft.json index 0d32e1dfd..7cbb18654 100644 --- a/tests/contracts/artifacts/ContractWithCustomStruct.arc56_draft.json +++ b/tests/contracts/artifacts/ContractWithCustomStruct.arc56_draft.json @@ -78,28 +78,309 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/inheritance-external.algo.ts:19", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/inheritance-external.algo.ts:19", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/inheritance-external.algo.ts:19", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/inheritance-external.algo.ts:19", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/inheritance-external.algo.ts:19", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/inheritance-external.algo.ts:19", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/inheritance-external.algo.ts:19", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/inheritance-external.algo.ts:19", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/inheritance-external.algo.ts:19", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/inheritance-external.algo.ts:20", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/inheritance-external.algo.ts:20", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/inheritance-external.algo.ts:20", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/inheritance-external.algo.ts:20", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/inheritance-external.algo.ts:20", + "pc": [ + 48, + 49 + ] }, { + "teal": 35, + "source": "tests/contracts/inheritance-external.algo.ts:20", + "pc": [ + 50 + ] + }, + { + "teal": 38, + "source": "tests/contracts/inheritance-external.algo.ts:20", + "errorMessage": "argument 0 (input) for customStructMethod must be a (uint64)", "pc": [ 51 - ], - "errorMessage": "argument 0 (input) for customStructMethod must be a (uint64)" + ] + }, + { + "teal": 41, + "source": "tests/contracts/inheritance-external.algo.ts:20", + "pc": [ + 52, + 53, + 54 + ] }, { + "teal": 42, + "source": "tests/contracts/inheritance-external.algo.ts:20", + "pc": [ + 55 + ] + }, + { + "teal": 43, + "source": "tests/contracts/inheritance-external.algo.ts:20", + "pc": [ + 56 + ] + }, + { + "teal": 44, + "source": "tests/contracts/inheritance-external.algo.ts:20", + "pc": [ + 57, + 58 + ] + }, + { + "teal": 45, + "source": "tests/contracts/inheritance-external.algo.ts:20", + "pc": [ + 59 + ] + }, + { + "teal": 49, + "source": "tests/contracts/inheritance-external.algo.ts:20", + "pc": [ + 60, + 61, + 62 + ] + }, + { + "teal": 53, + "source": "tests/contracts/inheritance-external.algo.ts:21", + "pc": [ + 63, + 64 + ] + }, + { + "teal": 54, + "source": "tests/contracts/inheritance-external.algo.ts:20", + "pc": [ + 65 + ] + }, + { + "teal": 57, + "source": "tests/contracts/inheritance-external.algo.ts:19", + "pc": [ + 66, + 67 + ] + }, + { + "teal": 58, + "source": "tests/contracts/inheritance-external.algo.ts:19", + "pc": [ + 68 + ] + }, + { + "teal": 61, + "source": "tests/contracts/inheritance-external.algo.ts:19", + "pc": [ + 69, + 70, + 71, + 72, + 73, + 74 + ] + }, + { + "teal": 62, + "source": "tests/contracts/inheritance-external.algo.ts:19", + "pc": [ + 75, + 76, + 77 + ] + }, + { + "teal": 63, + "source": "tests/contracts/inheritance-external.algo.ts:19", + "pc": [ + 78, + 79, + 80, + 81 + ] + }, + { + "teal": 66, + "source": "tests/contracts/inheritance-external.algo.ts:19", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 82 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 69, + "source": "tests/contracts/inheritance-external.algo.ts:19", + "pc": [ + 83, + 84, + 85, + 86, + 87, + 88 + ] + }, + { + "teal": 70, + "source": "tests/contracts/inheritance-external.algo.ts:19", + "pc": [ + 89, + 90, + 91 + ] + }, + { + "teal": 71, + "source": "tests/contracts/inheritance-external.algo.ts:19", + "pc": [ + 92, + 93, + 94, + 95 + ] }, { + "teal": 74, + "source": "tests/contracts/inheritance-external.algo.ts:19", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 96 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ContractWithLsigProgram.arc56_draft.json b/tests/contracts/artifacts/ContractWithLsigProgram.arc56_draft.json index 917ebbb06..79299a7b2 100644 --- a/tests/contracts/artifacts/ContractWithLsigProgram.arc56_draft.json +++ b/tests/contracts/artifacts/ContractWithLsigProgram.arc56_draft.json @@ -51,16 +51,207 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/lsig.algo.ts:30", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/lsig.algo.ts:30", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/lsig.algo.ts:30", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/lsig.algo.ts:30", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/lsig.algo.ts:30", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/lsig.algo.ts:30", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/lsig.algo.ts:30", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/lsig.algo.ts:30", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/lsig.algo.ts:30", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/lsig.algo.ts:31", + "pc": [ + 37, + 38, + 39 + ] + }, + { + "teal": 29, + "source": "tests/contracts/lsig.algo.ts:31", + "pc": [ + 40, + 41 + ] + }, + { + "teal": 30, + "source": "tests/contracts/lsig.algo.ts:31", + "pc": [ + 42 + ] + }, + { + "teal": 34, + "source": "tests/contracts/lsig.algo.ts:31", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 38, + "source": "tests/contracts/lsig.algo.ts:32", + "pc": [ + 46, + 47, + 48, + 49, + 50, + 51, + 52, + 53, + 54, + 55, + 56, + 57, + 58, + 59, + 60, + 61, + 62, + 63, + 64 + ] + }, + { + "teal": 39, + "source": "tests/contracts/lsig.algo.ts:32", + "pc": [ + 65 + ] + }, + { + "teal": 40, + "source": "tests/contracts/lsig.algo.ts:31", + "pc": [ + 66 + ] + }, + { + "teal": 43, + "source": "tests/contracts/lsig.algo.ts:30", + "pc": [ + 67, + 68, + 69, + 70, + 71, + 72 + ] + }, + { + "teal": 44, + "source": "tests/contracts/lsig.algo.ts:30", + "pc": [ + 73, + 74, + 75 + ] + }, + { + "teal": 45, + "source": "tests/contracts/lsig.algo.ts:30", + "pc": [ + 76, + 77, + 78, + 79 + ] }, { + "teal": 48, + "source": "tests/contracts/lsig.algo.ts:30", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 80 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ContratWithLsigAddress.arc56_draft.json b/tests/contracts/artifacts/ContratWithLsigAddress.arc56_draft.json index 9437ecea9..ac7047306 100644 --- a/tests/contracts/artifacts/ContratWithLsigAddress.arc56_draft.json +++ b/tests/contracts/artifacts/ContratWithLsigAddress.arc56_draft.json @@ -51,16 +51,222 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/lsig.algo.ts:37", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/lsig.algo.ts:37", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/lsig.algo.ts:37", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/lsig.algo.ts:37", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/lsig.algo.ts:37", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/lsig.algo.ts:37", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/lsig.algo.ts:37", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/lsig.algo.ts:37", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/lsig.algo.ts:37", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/lsig.algo.ts:38", + "pc": [ + 37, + 38, + 39 + ] + }, + { + "teal": 29, + "source": "tests/contracts/lsig.algo.ts:38", + "pc": [ + 40, + 41 + ] + }, + { + "teal": 30, + "source": "tests/contracts/lsig.algo.ts:38", + "pc": [ + 42 + ] + }, + { + "teal": 34, + "source": "tests/contracts/lsig.algo.ts:38", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 38, + "source": "tests/contracts/lsig.algo.ts:39", + "pc": [ + 46, + 47, + 48, + 49, + 50, + 51, + 52, + 53, + 54, + 55, + 56, + 57, + 58, + 59, + 60, + 61, + 62, + 63, + 64, + 65, + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79 + ] + }, + { + "teal": 39, + "source": "tests/contracts/lsig.algo.ts:39", + "pc": [ + 80 + ] + }, + { + "teal": 40, + "source": "tests/contracts/lsig.algo.ts:38", + "pc": [ + 81 + ] + }, + { + "teal": 43, + "source": "tests/contracts/lsig.algo.ts:37", + "pc": [ + 82, + 83, + 84, + 85, + 86, + 87 + ] + }, + { + "teal": 44, + "source": "tests/contracts/lsig.algo.ts:37", + "pc": [ + 88, + 89, + 90 + ] + }, + { + "teal": 45, + "source": "tests/contracts/lsig.algo.ts:37", + "pc": [ + 91, + 92, + 93, + 94 + ] }, { + "teal": 48, + "source": "tests/contracts/lsig.algo.ts:37", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 95 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/D.arc56_draft.json b/tests/contracts/artifacts/D.arc56_draft.json index daf396513..4f2b0f7fe 100644 --- a/tests/contracts/artifacts/D.arc56_draft.json +++ b/tests/contracts/artifacts/D.arc56_draft.json @@ -70,22 +70,253 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/inheritance.algo.ts:36", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/inheritance.algo.ts:36", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/inheritance.algo.ts:36", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/inheritance.algo.ts:36", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/inheritance.algo.ts:36", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/inheritance.algo.ts:36", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/inheritance.algo.ts:36", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/inheritance.algo.ts:36", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/inheritance.algo.ts:36", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/inheritance.algo.ts:39", + "pc": [ + 37, + 38, + 39 + ] + }, + { + "teal": 29, + "source": "tests/contracts/inheritance.algo.ts:39", + "pc": [ + 40, + 41 + ] + }, + { + "teal": 30, + "source": "tests/contracts/inheritance.algo.ts:39", + "pc": [ + 42 + ] + }, + { + "teal": 34, + "source": "tests/contracts/inheritance.algo.ts:39", + "pc": [ + 43, + 44, + 45 + ] }, { + "teal": 38, + "source": "tests/contracts/inheritance.algo.ts:40", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 39, + "source": "tests/contracts/inheritance.algo.ts:40", + "pc": [ + 49, + 50 + ] + }, + { + "teal": 40, + "source": "tests/contracts/inheritance.algo.ts:40", + "pc": [ + 51 + ] + }, + { + "teal": 41, + "source": "tests/contracts/inheritance.algo.ts:39", + "pc": [ + 52 + ] + }, + { + "teal": 44, + "source": "tests/contracts/inheritance.algo.ts:36", + "pc": [ + 53, + 54 + ] + }, + { + "teal": 45, + "source": "tests/contracts/inheritance.algo.ts:36", + "pc": [ + 55 + ] + }, + { + "teal": 48, + "source": "tests/contracts/inheritance.algo.ts:36", + "pc": [ + 56, + 57, + 58, + 59, + 60, + 61 + ] + }, + { + "teal": 49, + "source": "tests/contracts/inheritance.algo.ts:36", + "pc": [ + 62, + 63, + 64 + ] + }, + { + "teal": 50, + "source": "tests/contracts/inheritance.algo.ts:36", + "pc": [ + 65, + 66, + 67, + 68 + ] + }, + { + "teal": 53, + "source": "tests/contracts/inheritance.algo.ts:36", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 69 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 56, + "source": "tests/contracts/inheritance.algo.ts:36", + "pc": [ + 70, + 71, + 72, + 73, + 74, + 75 + ] + }, + { + "teal": 57, + "source": "tests/contracts/inheritance.algo.ts:36", + "pc": [ + 76, + 77, + 78 + ] + }, + { + "teal": 58, + "source": "tests/contracts/inheritance.algo.ts:36", + "pc": [ + 79, + 80, + 81, + 82 + ] }, { + "teal": 61, + "source": "tests/contracts/inheritance.algo.ts:36", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 83 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/DummyContract.arc56_draft.json b/tests/contracts/artifacts/DummyContract.arc56_draft.json index 35fe682b3..bc78c88e3 100644 --- a/tests/contracts/artifacts/DummyContract.arc56_draft.json +++ b/tests/contracts/artifacts/DummyContract.arc56_draft.json @@ -51,16 +51,150 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/general.algo.ts:5", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/general.algo.ts:5", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/general.algo.ts:5", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/general.algo.ts:5", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/general.algo.ts:5", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/general.algo.ts:5", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/general.algo.ts:5", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/general.algo.ts:5", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/general.algo.ts:5", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 26, + "source": "tests/contracts/general.algo.ts:5", + "pc": [ + 37, + 38 + ] + }, + { + "teal": 27, + "source": "tests/contracts/general.algo.ts:5", + "pc": [ + 39 + ] + }, + { + "teal": 30, + "source": "tests/contracts/general.algo.ts:5", + "pc": [ + 40, + 41, + 42, + 43, + 44, + 45 + ] + }, + { + "teal": 31, + "source": "tests/contracts/general.algo.ts:5", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 32, + "source": "tests/contracts/general.algo.ts:5", + "pc": [ + 49, + 50, + 51, + 52 + ] }, { + "teal": 35, + "source": "tests/contracts/general.algo.ts:5", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 53 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/E.arc56_draft.json b/tests/contracts/artifacts/E.arc56_draft.json index 108274f0f..9bb27b69e 100644 --- a/tests/contracts/artifacts/E.arc56_draft.json +++ b/tests/contracts/artifacts/E.arc56_draft.json @@ -83,28 +83,825 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/inheritance.algo.ts:51", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/inheritance.algo.ts:51", + "pc": [ + 1, + 2, + 3, + 4, + 5, + 6, + 7, + 8, + 9, + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38, + 39, + 40, + 41, + 42, + 43, + 44, + 45, + 46, + 47, + 48 + ] + }, + { + "teal": 14, + "source": "tests/contracts/inheritance.algo.ts:51", + "pc": [ + 49, + 50 + ] + }, + { + "teal": 15, + "source": "tests/contracts/inheritance.algo.ts:51", + "pc": [ + 51 + ] + }, + { + "teal": 16, + "source": "tests/contracts/inheritance.algo.ts:51", + "pc": [ + 52, + 53 + ] + }, + { + "teal": 17, + "source": "tests/contracts/inheritance.algo.ts:51", + "pc": [ + 54 + ] + }, + { + "teal": 18, + "source": "tests/contracts/inheritance.algo.ts:51", + "pc": [ + 55, + 56 + ] + }, + { + "teal": 19, + "source": "tests/contracts/inheritance.algo.ts:51", + "pc": [ + 57 + ] + }, + { + "teal": 20, + "source": "tests/contracts/inheritance.algo.ts:51", + "pc": [ + 58, + 59, + 60, + 61, + 62, + 63, + 64, + 65, + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82, + 83 + ] + }, + { + "teal": 24, + "source": "tests/contracts/inheritance.algo.ts:51", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 84 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/inheritance-external.algo.ts:10", + "pc": [ + 85, + 86, + 87, + 88, + 89, + 90 + ] + }, + { + "teal": 32, + "source": "tests/contracts/inheritance-external.algo.ts:10", + "pc": [ + 91, + 92, + 93 + ] + }, + { + "teal": 33, + "source": "tests/contracts/inheritance-external.algo.ts:10", + "pc": [ + 94 + ] + }, + { + "teal": 34, + "source": "tests/contracts/inheritance-external.algo.ts:10", + "pc": [ + 95 + ] }, { + "teal": 35, + "source": "tests/contracts/inheritance-external.algo.ts:10", + "pc": [ + 96 + ] + }, + { + "teal": 36, + "source": "tests/contracts/inheritance-external.algo.ts:10", + "pc": [ + 97, + 98 + ] + }, + { + "teal": 37, + "source": "tests/contracts/inheritance-external.algo.ts:10", + "pc": [ + 99 + ] + }, + { + "teal": 40, + "source": "tests/contracts/inheritance-external.algo.ts:10", + "errorMessage": "externalMethod return value overflowed 8 bits", "pc": [ 100 - ], - "errorMessage": "externalMethod return value overflowed 8 bits" + ] + }, + { + "teal": 41, + "source": "tests/contracts/inheritance-external.algo.ts:10", + "pc": [ + 101, + 102, + 103 + ] + }, + { + "teal": 42, + "source": "tests/contracts/inheritance-external.algo.ts:10", + "pc": [ + 104 + ] + }, + { + "teal": 43, + "source": "tests/contracts/inheritance-external.algo.ts:10", + "pc": [ + 105 + ] + }, + { + "teal": 44, + "source": "tests/contracts/inheritance-external.algo.ts:10", + "pc": [ + 106, + 107 + ] + }, + { + "teal": 45, + "source": "tests/contracts/inheritance-external.algo.ts:10", + "pc": [ + 108 + ] + }, + { + "teal": 49, + "source": "tests/contracts/inheritance-external.algo.ts:10", + "pc": [ + 109, + 110, + 111 + ] + }, + { + "teal": 53, + "source": "tests/contracts/inheritance-external.algo.ts:12", + "pc": [ + 112, + 113, + 114, + 115, + 116, + 117, + 118, + 119, + 120, + 121, + 122, + 123, + 124 + ] + }, + { + "teal": 54, + "source": "tests/contracts/inheritance-external.algo.ts:13", + "pc": [ + 125, + 126, + 127 + ] + }, + { + "teal": 55, + "source": "tests/contracts/inheritance-external.algo.ts:12", + "pc": [ + 128 + ] + }, + { + "teal": 59, + "source": "tests/contracts/inheritance-external.algo.ts:13", + "pc": [ + 129, + 130, + 131, + 132, + 133, + 134, + 135, + 136, + 137, + 138, + 139, + 140, + 141 + ] }, { + "teal": 60, + "source": "tests/contracts/inheritance-external.algo.ts:13", + "pc": [ + 142 + ] + }, + { + "teal": 61, + "source": "tests/contracts/inheritance-external.algo.ts:13", + "pc": [ + 143 + ] + }, + { + "teal": 62, + "source": "tests/contracts/inheritance-external.algo.ts:10", + "pc": [ + 144 + ] + }, + { + "teal": 67, + "source": "tests/contracts/inheritance.algo.ts:52", + "pc": [ + 145, + 146, + 147 + ] + }, + { + "teal": 68, + "source": "tests/contracts/inheritance.algo.ts:52", + "pc": [ + 148, + 149 + ] + }, + { + "teal": 69, + "source": "tests/contracts/inheritance.algo.ts:52", + "pc": [ + 150 + ] + }, + { + "teal": 73, + "source": "tests/contracts/inheritance.algo.ts:52", + "pc": [ + 151, + 152, + 153 + ] + }, + { + "teal": 76, + "source": "tests/contracts/inheritance.algo.ts:52", + "pc": [ + 154, + 155 + ] + }, + { + "teal": 77, + "source": "tests/contracts/inheritance.algo.ts:52", + "pc": [ + 156, + 157 + ] + }, + { + "teal": 81, + "source": "tests/contracts/inheritance.algo.ts:53", + "pc": [ + 158, + 159 + ] + }, + { + "teal": 82, + "source": "tests/contracts/inheritance.algo.ts:53", + "pc": [ + 160, + 161 + ] + }, + { + "teal": 86, + "source": "tests/contracts/inheritance.algo.ts:54", + "pc": [ + 162, + 163, + 164, + 165, + 166, + 167, + 168, + 169, + 170, + 171, + 172, + 173, + 174 + ] + }, + { + "teal": 87, + "source": "tests/contracts/inheritance.algo.ts:54", + "pc": [ + 175 + ] + }, + { + "teal": 88, + "source": "tests/contracts/inheritance.algo.ts:54", + "pc": [ + 176 + ] + }, + { + "teal": 89, + "source": "tests/contracts/inheritance.algo.ts:54", + "pc": [ + 177, + 178 + ] + }, + { + "teal": 90, + "source": "tests/contracts/inheritance.algo.ts:54", + "pc": [ + 179 + ] + }, + { + "teal": 91, + "source": "tests/contracts/inheritance.algo.ts:54", + "pc": [ + 180 + ] + }, + { + "teal": 95, + "source": "tests/contracts/inheritance.algo.ts:55", + "pc": [ + 181, + 182, + 183, + 184, + 185, + 186, + 187, + 188, + 189, + 190, + 191, + 192, + 193, + 194, + 195, + 196, + 197, + 198, + 199, + 200, + 201, + 202, + 203, + 204, + 205, + 206, + 207, + 208, + 209, + 210, + 211, + 212, + 213, + 214 + ] + }, + { + "teal": 96, + "source": "tests/contracts/inheritance.algo.ts:55", + "pc": [ + 215, + 216 + ] + }, + { + "teal": 100, + "source": "tests/contracts/inheritance.algo.ts:56", + "pc": [ + 217, + 218, + 219, + 220, + 221, + 222, + 223, + 224, + 225, + 226, + 227, + 228, + 229, + 230, + 231, + 232, + 233, + 234, + 235, + 236, + 237, + 238, + 239, + 240, + 241, + 242, + 243, + 244, + 245, + 246, + 247, + 248, + 249, + 250 + ] + }, + { + "teal": 101, + "source": "tests/contracts/inheritance.algo.ts:56", + "pc": [ + 251, + 252 + ] + }, + { + "teal": 105, + "source": "tests/contracts/inheritance.algo.ts:58", + "pc": [ + 253, + 254, + 255, + 256, + 257, + 258, + 259, + 260, + 261, + 262, + 263, + 264, + 265, + 266, + 267, + 268, + 269, + 270, + 271, + 272, + 273, + 274, + 275, + 276, + 277, + 278, + 279, + 280, + 281, + 282, + 283, + 284, + 285, + 286 + ] + }, + { + "teal": 106, + "source": "tests/contracts/inheritance.algo.ts:58", + "pc": [ + 287, + 288, + 289, + 290, + 291, + 292, + 293, + 294, + 295, + 296, + 297, + 298, + 299, + 300, + 301, + 302, + 303, + 304, + 305, + 306, + 307, + 308, + 309, + 310, + 311, + 312, + 313, + 314, + 315, + 316, + 317, + 318, + 319, + 320 + ] + }, + { + "teal": 107, + "source": "tests/contracts/inheritance.algo.ts:58", + "pc": [ + 321 + ] + }, + { + "teal": 108, + "source": "tests/contracts/inheritance.algo.ts:58", + "pc": [ + 322 + ] + }, + { + "teal": 112, + "source": "tests/contracts/inheritance.algo.ts:60", + "pc": [ + 323, + 324, + 325 + ] + }, + { + "teal": 113, + "source": "tests/contracts/inheritance.algo.ts:60", + "pc": [ + 326, + 327, + 328 + ] + }, + { + "teal": 114, + "source": "tests/contracts/inheritance.algo.ts:60", + "pc": [ + 329 + ] + }, + { + "teal": 115, + "source": "tests/contracts/inheritance.algo.ts:60", + "pc": [ + 330 + ] + }, + { + "teal": 119, + "source": "tests/contracts/inheritance.algo.ts:61", + "pc": [ + 331, + 332, + 333 + ] + }, + { + "teal": 120, + "source": "tests/contracts/inheritance.algo.ts:61", + "pc": [ + 334, + 335, + 336 + ] + }, + { + "teal": 121, + "source": "tests/contracts/inheritance.algo.ts:61", + "pc": [ + 337 + ] + }, + { + "teal": 122, + "source": "tests/contracts/inheritance.algo.ts:61", + "pc": [ + 338 + ] + }, + { + "teal": 123, + "source": "tests/contracts/inheritance.algo.ts:52", + "pc": [ + 339 + ] + }, + { + "teal": 126, + "source": "tests/contracts/inheritance.algo.ts:51", + "pc": [ + 340, + 341 + ] + }, + { + "teal": 127, + "source": "tests/contracts/inheritance.algo.ts:51", + "pc": [ + 342 + ] + }, + { + "teal": 130, + "source": "tests/contracts/inheritance.algo.ts:51", + "pc": [ + 343, + 344, + 345, + 346, + 347, + 348 + ] + }, + { + "teal": 131, + "source": "tests/contracts/inheritance.algo.ts:51", + "pc": [ + 349, + 350, + 351 + ] + }, + { + "teal": 132, + "source": "tests/contracts/inheritance.algo.ts:51", + "pc": [ + 352, + 353, + 354, + 355 + ] + }, + { + "teal": 135, + "source": "tests/contracts/inheritance.algo.ts:51", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 356 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 138, + "source": "tests/contracts/inheritance.algo.ts:51", + "pc": [ + 357, + 358, + 359, + 360, + 361, + 362 + ] + }, + { + "teal": 139, + "source": "tests/contracts/inheritance.algo.ts:51", + "pc": [ + 363, + 364, + 365, + 366, + 367, + 368 + ] + }, + { + "teal": 140, + "source": "tests/contracts/inheritance.algo.ts:51", + "pc": [ + 369, + 370, + 371 + ] + }, + { + "teal": 141, + "source": "tests/contracts/inheritance.algo.ts:51", + "pc": [ + 372, + 373, + 374, + 375, + 376, + 377 + ] }, { + "teal": 144, + "source": "tests/contracts/inheritance.algo.ts:51", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 378 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ExternalContract.arc56_draft.json b/tests/contracts/artifacts/ExternalContract.arc56_draft.json index 2b175c2c0..2e448903b 100644 --- a/tests/contracts/artifacts/ExternalContract.arc56_draft.json +++ b/tests/contracts/artifacts/ExternalContract.arc56_draft.json @@ -70,28 +70,396 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/inheritance-external.algo.ts:7", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/inheritance-external.algo.ts:7", + "pc": [ + 1, + 2, + 3, + 4, + 5, + 6, + 7, + 8, + 9, + 10, + 11, + 12, + 13, + 14 + ] + }, + { + "teal": 14, + "source": "tests/contracts/inheritance-external.algo.ts:7", + "pc": [ + 15, + 16 + ] + }, + { + "teal": 15, + "source": "tests/contracts/inheritance-external.algo.ts:7", + "pc": [ + 17 + ] + }, + { + "teal": 16, + "source": "tests/contracts/inheritance-external.algo.ts:7", + "pc": [ + 18, + 19 + ] + }, + { + "teal": 17, + "source": "tests/contracts/inheritance-external.algo.ts:7", + "pc": [ + 20 + ] + }, + { + "teal": 18, + "source": "tests/contracts/inheritance-external.algo.ts:7", + "pc": [ + 21, + 22 + ] + }, + { + "teal": 19, + "source": "tests/contracts/inheritance-external.algo.ts:7", + "pc": [ + 23 + ] + }, + { + "teal": 20, + "source": "tests/contracts/inheritance-external.algo.ts:7", + "pc": [ + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38, + 39, + 40, + 41, + 42, + 43, + 44, + 45, + 46, + 47, + 48, + 49 + ] + }, + { + "teal": 24, + "source": "tests/contracts/inheritance-external.algo.ts:7", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 50 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/inheritance-external.algo.ts:10", + "pc": [ + 51, + 52, + 53, + 54, + 55, + 56 + ] + }, + { + "teal": 32, + "source": "tests/contracts/inheritance-external.algo.ts:10", + "pc": [ + 57, + 58, + 59 + ] + }, + { + "teal": 33, + "source": "tests/contracts/inheritance-external.algo.ts:10", + "pc": [ + 60 + ] + }, + { + "teal": 34, + "source": "tests/contracts/inheritance-external.algo.ts:10", + "pc": [ + 61 + ] + }, + { + "teal": 35, + "source": "tests/contracts/inheritance-external.algo.ts:10", + "pc": [ + 62 + ] }, { + "teal": 36, + "source": "tests/contracts/inheritance-external.algo.ts:10", + "pc": [ + 63, + 64 + ] + }, + { + "teal": 37, + "source": "tests/contracts/inheritance-external.algo.ts:10", + "pc": [ + 65 + ] + }, + { + "teal": 40, + "source": "tests/contracts/inheritance-external.algo.ts:10", + "errorMessage": "externalMethod return value overflowed 8 bits", "pc": [ 66 - ], - "errorMessage": "externalMethod return value overflowed 8 bits" + ] + }, + { + "teal": 41, + "source": "tests/contracts/inheritance-external.algo.ts:10", + "pc": [ + 67, + 68, + 69 + ] }, { + "teal": 42, + "source": "tests/contracts/inheritance-external.algo.ts:10", + "pc": [ + 70 + ] + }, + { + "teal": 43, + "source": "tests/contracts/inheritance-external.algo.ts:10", + "pc": [ + 71 + ] + }, + { + "teal": 44, + "source": "tests/contracts/inheritance-external.algo.ts:10", + "pc": [ + 72, + 73 + ] + }, + { + "teal": 45, + "source": "tests/contracts/inheritance-external.algo.ts:10", + "pc": [ + 74 + ] + }, + { + "teal": 49, + "source": "tests/contracts/inheritance-external.algo.ts:10", + "pc": [ + 75, + 76, + 77 + ] + }, + { + "teal": 53, + "source": "tests/contracts/inheritance-external.algo.ts:11", + "pc": [ + 78, + 79, + 80, + 81, + 82, + 83, + 84, + 85, + 86, + 87, + 88, + 89, + 90 + ] + }, + { + "teal": 54, + "source": "tests/contracts/inheritance-external.algo.ts:11", + "pc": [ + 91, + 92, + 93 + ] + }, + { + "teal": 55, + "source": "tests/contracts/inheritance-external.algo.ts:11", + "pc": [ + 94 + ] + }, + { + "teal": 59, + "source": "tests/contracts/inheritance-external.algo.ts:12", + "pc": [ + 95, + 96, + 97, + 98, + 99, + 100, + 101, + 102, + 103, + 104, + 105, + 106, + 107 + ] + }, + { + "teal": 60, + "source": "tests/contracts/inheritance-external.algo.ts:12", + "pc": [ + 108 + ] + }, + { + "teal": 61, + "source": "tests/contracts/inheritance-external.algo.ts:12", + "pc": [ + 109 + ] + }, + { + "teal": 62, + "source": "tests/contracts/inheritance-external.algo.ts:10", + "pc": [ + 110 + ] + }, + { + "teal": 65, + "source": "tests/contracts/inheritance-external.algo.ts:7", + "pc": [ + 111, + 112 + ] + }, + { + "teal": 66, + "source": "tests/contracts/inheritance-external.algo.ts:7", + "pc": [ + 113 + ] + }, + { + "teal": 69, + "source": "tests/contracts/inheritance-external.algo.ts:7", + "pc": [ + 114, + 115, + 116, + 117, + 118, + 119 + ] + }, + { + "teal": 70, + "source": "tests/contracts/inheritance-external.algo.ts:7", + "pc": [ + 120, + 121, + 122 + ] + }, + { + "teal": 71, + "source": "tests/contracts/inheritance-external.algo.ts:7", + "pc": [ + 123, + 124, + 125, + 126 + ] + }, + { + "teal": 74, + "source": "tests/contracts/inheritance-external.algo.ts:7", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 127 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 77, + "source": "tests/contracts/inheritance-external.algo.ts:7", + "pc": [ + 128, + 129, + 130, + 131, + 132, + 133 + ] + }, + { + "teal": 78, + "source": "tests/contracts/inheritance-external.algo.ts:7", + "pc": [ + 134, + 135, + 136 + ] + }, + { + "teal": 79, + "source": "tests/contracts/inheritance-external.algo.ts:7", + "pc": [ + 137, + 138, + 139, + 140 + ] }, { + "teal": 82, + "source": "tests/contracts/inheritance-external.algo.ts:7", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 141 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/F.arc56_draft.json b/tests/contracts/artifacts/F.arc56_draft.json index 6c118dc58..284c8a1f6 100644 --- a/tests/contracts/artifacts/F.arc56_draft.json +++ b/tests/contracts/artifacts/F.arc56_draft.json @@ -64,22 +64,377 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/inheritance.algo.ts:65", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/inheritance.algo.ts:65", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/inheritance.algo.ts:65", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/inheritance.algo.ts:65", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/inheritance.algo.ts:65", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/inheritance.algo.ts:65", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/inheritance.algo.ts:65", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/inheritance.algo.ts:65", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/inheritance.algo.ts:65", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/inheritance.algo.ts:66", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/inheritance.algo.ts:66", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/inheritance.algo.ts:66", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/inheritance.algo.ts:66", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/inheritance.algo.ts:66", + "pc": [ + 48 + ] + }, + { + "teal": 35, + "source": "tests/contracts/inheritance.algo.ts:66", + "pc": [ + 49, + 50, + 51 + ] }, { + "teal": 36, + "source": "tests/contracts/inheritance.algo.ts:66", + "pc": [ + 52 + ] + }, + { + "teal": 37, + "source": "tests/contracts/inheritance.algo.ts:66", + "pc": [ + 53 + ] + }, + { + "teal": 38, + "source": "tests/contracts/inheritance.algo.ts:66", + "pc": [ + 54 + ] + }, + { + "teal": 39, + "source": "tests/contracts/inheritance.algo.ts:66", + "pc": [ + 55 + ] + }, + { + "teal": 40, + "source": "tests/contracts/inheritance.algo.ts:66", + "pc": [ + 56, + 57 + ] + }, + { + "teal": 41, + "source": "tests/contracts/inheritance.algo.ts:66", + "pc": [ + 58 + ] + }, + { + "teal": 45, + "source": "tests/contracts/inheritance.algo.ts:66", + "pc": [ + 59, + 60, + 61 + ] + }, + { + "teal": 49, + "source": "tests/contracts/inheritance.algo.ts:67", + "pc": [ + 62, + 63, + 64, + 65, + 66, + 67, + 68, + 69 + ] + }, + { + "teal": 50, + "source": "tests/contracts/inheritance.algo.ts:66", + "pc": [ + 70 + ] + }, + { + "teal": 54, + "source": "tests/contracts/inheritance.algo.ts:70", + "pc": [ + 71, + 72, + 73 + ] + }, + { + "teal": 58, + "source": "tests/contracts/inheritance.algo.ts:71", + "pc": [ + 74, + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82 + ] + }, + { + "teal": 59, + "source": "tests/contracts/inheritance.algo.ts:70", + "pc": [ + 83 + ] + }, + { + "teal": 63, + "source": "tests/contracts/inheritance.algo.ts:74", + "pc": [ + 84, + 85, + 86 + ] + }, + { + "teal": 67, + "source": "tests/contracts/inheritance.algo.ts:75", + "pc": [ + 87, + 88, + 89, + 90, + 91, + 92, + 93, + 94, + 95, + 96, + 97 + ] + }, + { + "teal": 68, + "source": "tests/contracts/inheritance.algo.ts:74", + "pc": [ + 98 + ] + }, + { + "teal": 71, + "source": "tests/contracts/inheritance.algo.ts:65", + "pc": [ + 99, + 100 + ] + }, + { + "teal": 72, + "source": "tests/contracts/inheritance.algo.ts:65", + "pc": [ + 101 + ] + }, + { + "teal": 75, + "source": "tests/contracts/inheritance.algo.ts:65", + "pc": [ + 102, + 103, + 104, + 105, + 106, + 107 + ] + }, + { + "teal": 76, + "source": "tests/contracts/inheritance.algo.ts:65", + "pc": [ + 108, + 109, + 110 + ] + }, + { + "teal": 77, + "source": "tests/contracts/inheritance.algo.ts:65", + "pc": [ + 111, + 112, + 113, + 114 + ] + }, + { + "teal": 80, + "source": "tests/contracts/inheritance.algo.ts:65", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 115 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 83, + "source": "tests/contracts/inheritance.algo.ts:65", + "pc": [ + 116, + 117, + 118, + 119, + 120, + 121 + ] + }, + { + "teal": 84, + "source": "tests/contracts/inheritance.algo.ts:65", + "pc": [ + 122, + 123, + 124 + ] + }, + { + "teal": 85, + "source": "tests/contracts/inheritance.algo.ts:65", + "pc": [ + 125, + 126, + 127, + 128 + ] }, { + "teal": 88, + "source": "tests/contracts/inheritance.algo.ts:65", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 129 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/FunctionsTest.arc56_draft.json b/tests/contracts/artifacts/FunctionsTest.arc56_draft.json index 26facadc0..865951e5b 100644 --- a/tests/contracts/artifacts/FunctionsTest.arc56_draft.json +++ b/tests/contracts/artifacts/FunctionsTest.arc56_draft.json @@ -117,22 +117,737 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/functions.algo.ts:10", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/functions.algo.ts:10", + "pc": [ + 1, + 2, + 3, + 4, + 5, + 6, + 7 + ] + }, + { + "teal": 14, + "source": "tests/contracts/functions.algo.ts:10", + "pc": [ + 8, + 9 + ] + }, + { + "teal": 15, + "source": "tests/contracts/functions.algo.ts:10", + "pc": [ + 10 + ] + }, + { + "teal": 16, + "source": "tests/contracts/functions.algo.ts:10", + "pc": [ + 11, + 12 + ] + }, + { + "teal": 17, + "source": "tests/contracts/functions.algo.ts:10", + "pc": [ + 13 + ] + }, + { + "teal": 18, + "source": "tests/contracts/functions.algo.ts:10", + "pc": [ + 14, + 15 + ] + }, + { + "teal": 19, + "source": "tests/contracts/functions.algo.ts:10", + "pc": [ + 16 + ] + }, + { + "teal": 20, + "source": "tests/contracts/functions.algo.ts:10", + "pc": [ + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 24, + "source": "tests/contracts/functions.algo.ts:10", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 43 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/functions.algo.ts:11", + "pc": [ + 44, + 45, + 46, + 47, + 48, + 49 + ] + }, + { + "teal": 32, + "source": "tests/contracts/functions.algo.ts:11", + "pc": [ + 50, + 51, + 52 + ] + }, + { + "teal": 33, + "source": "tests/contracts/functions.algo.ts:11", + "pc": [ + 53 + ] + }, + { + "teal": 36, + "source": "tests/contracts/functions.algo.ts:11", + "pc": [ + 54, + 55, + 56 + ] + }, + { + "teal": 37, + "source": "tests/contracts/functions.algo.ts:11", + "pc": [ + 57 + ] + }, + { + "teal": 40, + "source": "tests/contracts/functions.algo.ts:11", + "pc": [ + 58, + 59, + 60 + ] + }, + { + "teal": 41, + "source": "tests/contracts/functions.algo.ts:11", + "pc": [ + 61 + ] + }, + { + "teal": 42, + "source": "tests/contracts/functions.algo.ts:11", + "pc": [ + 62 + ] + }, + { + "teal": 43, + "source": "tests/contracts/functions.algo.ts:11", + "pc": [ + 63 + ] + }, + { + "teal": 44, + "source": "tests/contracts/functions.algo.ts:11", + "pc": [ + 64, + 65 + ] + }, + { + "teal": 45, + "source": "tests/contracts/functions.algo.ts:11", + "pc": [ + 66 + ] + }, + { + "teal": 49, + "source": "tests/contracts/functions.algo.ts:11", + "pc": [ + 67, + 68, + 69 + ] + }, + { + "teal": 53, + "source": "tests/contracts/functions.algo.ts:12", + "pc": [ + 70, + 71 + ] + }, + { + "teal": 54, + "source": "tests/contracts/functions.algo.ts:12", + "pc": [ + 72, + 73 + ] + }, + { + "teal": 55, + "source": "tests/contracts/functions.algo.ts:12", + "pc": [ + 74, + 75, + 76 + ] + }, + { + "teal": 56, + "source": "tests/contracts/functions.algo.ts:11", + "pc": [ + 77 + ] + }, + { + "teal": 61, + "source": "tests/contracts/functions.algo.ts:15", + "pc": [ + 78, + 79, + 80, + 81, + 82, + 83 + ] + }, + { + "teal": 64, + "source": "tests/contracts/functions.algo.ts:15", + "pc": [ + 84, + 85, + 86 + ] + }, + { + "teal": 65, + "source": "tests/contracts/functions.algo.ts:15", + "pc": [ + 87 + ] + }, + { + "teal": 68, + "source": "tests/contracts/functions.algo.ts:15", + "pc": [ + 88, + 89, + 90 + ] + }, + { + "teal": 69, + "source": "tests/contracts/functions.algo.ts:15", + "pc": [ + 91 + ] + }, + { + "teal": 72, + "source": "tests/contracts/functions.algo.ts:15", + "pc": [ + 92, + 93, + 94 + ] + }, + { + "teal": 73, + "source": "tests/contracts/functions.algo.ts:15", + "pc": [ + 95 + ] + }, + { + "teal": 74, + "source": "tests/contracts/functions.algo.ts:15", + "pc": [ + 96 + ] + }, + { + "teal": 75, + "source": "tests/contracts/functions.algo.ts:15", + "pc": [ + 97 + ] + }, + { + "teal": 76, + "source": "tests/contracts/functions.algo.ts:15", + "pc": [ + 98, + 99 + ] + }, + { + "teal": 77, + "source": "tests/contracts/functions.algo.ts:15", + "pc": [ + 100 + ] + }, + { + "teal": 81, + "source": "tests/contracts/functions.algo.ts:15", + "pc": [ + 101, + 102, + 103 + ] + }, + { + "teal": 85, + "source": "tests/contracts/functions.algo.ts:16", + "pc": [ + 104, + 105 + ] + }, + { + "teal": 86, + "source": "tests/contracts/functions.algo.ts:16", + "pc": [ + 106, + 107 + ] + }, + { + "teal": 87, + "source": "tests/contracts/functions.algo.ts:16", + "pc": [ + 108, + 109, + 110 + ] + }, + { + "teal": 88, + "source": "tests/contracts/functions.algo.ts:15", + "pc": [ + 111 + ] }, { + "teal": 93, + "source": "tests/contracts/functions.algo.ts:19", + "pc": [ + 112, + 113, + 114, + 115, + 116, + 117 + ] + }, + { + "teal": 96, + "source": "tests/contracts/functions.algo.ts:19", + "pc": [ + 118, + 119, + 120 + ] + }, + { + "teal": 97, + "source": "tests/contracts/functions.algo.ts:19", + "pc": [ + 121 + ] + }, + { + "teal": 100, + "source": "tests/contracts/functions.algo.ts:19", + "pc": [ + 122, + 123, + 124 + ] + }, + { + "teal": 101, + "source": "tests/contracts/functions.algo.ts:19", + "pc": [ + 125 + ] + }, + { + "teal": 104, + "source": "tests/contracts/functions.algo.ts:19", + "pc": [ + 126, + 127, + 128 + ] + }, + { + "teal": 105, + "source": "tests/contracts/functions.algo.ts:19", + "pc": [ + 129 + ] + }, + { + "teal": 106, + "source": "tests/contracts/functions.algo.ts:19", + "pc": [ + 130 + ] + }, + { + "teal": 107, + "source": "tests/contracts/functions.algo.ts:19", + "pc": [ + 131 + ] + }, + { + "teal": 108, + "source": "tests/contracts/functions.algo.ts:19", + "pc": [ + 132, + 133 + ] + }, + { + "teal": 109, + "source": "tests/contracts/functions.algo.ts:19", + "pc": [ + 134 + ] + }, + { + "teal": 113, + "source": "tests/contracts/functions.algo.ts:19", + "pc": [ + 135, + 136, + 137 + ] + }, + { + "teal": 117, + "source": "tests/contracts/functions.algo.ts:20", + "pc": [ + 138, + 139 + ] + }, + { + "teal": 118, + "source": "tests/contracts/functions.algo.ts:20", + "pc": [ + 140, + 141 + ] + }, + { + "teal": 119, + "source": "tests/contracts/functions.algo.ts:20", + "pc": [ + 142, + 143, + 144 + ] + }, + { + "teal": 120, + "source": "tests/contracts/functions.algo.ts:19", + "pc": [ + 145 + ] + }, + { + "teal": 123, + "source": "tests/contracts/functions.algo.ts:10", + "pc": [ + 146, + 147 + ] + }, + { + "teal": 124, + "source": "tests/contracts/functions.algo.ts:10", + "pc": [ + 148 + ] + }, + { + "teal": 127, + "source": "tests/contracts/functions.algo.ts:10", + "pc": [ + 149, + 150, + 151, + 152, + 153, + 154 + ] + }, + { + "teal": 128, + "source": "tests/contracts/functions.algo.ts:10", + "pc": [ + 155, + 156, + 157 + ] + }, + { + "teal": 129, + "source": "tests/contracts/functions.algo.ts:10", + "pc": [ + 158, + 159, + 160, + 161 + ] + }, + { + "teal": 132, + "source": "tests/contracts/functions.algo.ts:10", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 162 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 135, + "source": "tests/contracts/functions.algo.ts:10", + "pc": [ + 163, + 164, + 165, + 166, + 167, + 168 + ] + }, + { + "teal": 136, + "source": "tests/contracts/functions.algo.ts:10", + "pc": [ + 169, + 170, + 171, + 172, + 173, + 174 + ] + }, + { + "teal": 137, + "source": "tests/contracts/functions.algo.ts:10", + "pc": [ + 175, + 176, + 177, + 178, + 179, + 180 + ] + }, + { + "teal": 138, + "source": "tests/contracts/functions.algo.ts:10", + "pc": [ + 181, + 182, + 183 + ] + }, + { + "teal": 139, + "source": "tests/contracts/functions.algo.ts:10", + "pc": [ + 184, + 185, + 186, + 187, + 188, + 189, + 190, + 191 + ] }, { + "teal": 142, + "source": "tests/contracts/functions.algo.ts:10", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 192 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] + }, + { + "teal": 146, + "source": "node_modules/tealscript_test_package/index.ts:2", + "pc": [ + 193, + 194, + 195 + ] + }, + { + "teal": 150, + "source": "node_modules/tealscript_test_package/index.ts:4", + "pc": [ + 196, + 197 + ] + }, + { + "teal": 151, + "source": "node_modules/tealscript_test_package/index.ts:4", + "pc": [ + 198, + 199 + ] + }, + { + "teal": 152, + "source": "node_modules/tealscript_test_package/index.ts:4", + "pc": [ + 200 + ] + }, + { + "teal": 153, + "source": "node_modules/tealscript_test_package/index.ts:2", + "pc": [ + 201 + ] + }, + { + "teal": 157, + "source": "tests/contracts/functions-external.algo.ts:1", + "pc": [ + 202, + 203, + 204 + ] + }, + { + "teal": 161, + "source": "tests/contracts/functions-external.algo.ts:2", + "pc": [ + 205, + 206 + ] + }, + { + "teal": 162, + "source": "tests/contracts/functions-external.algo.ts:2", + "pc": [ + 207, + 208 + ] + }, + { + "teal": 163, + "source": "tests/contracts/functions-external.algo.ts:2", + "pc": [ + 209 + ] + }, + { + "teal": 164, + "source": "tests/contracts/functions-external.algo.ts:1", + "pc": [ + 210 + ] + }, + { + "teal": 168, + "source": "tests/contracts/functions.algo.ts:6", + "pc": [ + 211, + 212, + 213 + ] + }, + { + "teal": 172, + "source": "tests/contracts/functions.algo.ts:7", + "pc": [ + 214, + 215 + ] + }, + { + "teal": 173, + "source": "tests/contracts/functions.algo.ts:7", + "pc": [ + 216, + 217 + ] + }, + { + "teal": 174, + "source": "tests/contracts/functions.algo.ts:7", + "pc": [ + 218 + ] + }, + { + "teal": 175, + "source": "tests/contracts/functions.algo.ts:6", + "pc": [ + 219 + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/G.arc56_draft.json b/tests/contracts/artifacts/G.arc56_draft.json index 8579e5849..019af0649 100644 --- a/tests/contracts/artifacts/G.arc56_draft.json +++ b/tests/contracts/artifacts/G.arc56_draft.json @@ -77,22 +77,533 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/inheritance.algo.ts:79", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/inheritance.algo.ts:79", + "pc": [ + 1, + 2, + 3, + 4, + 5, + 6, + 7, + 8, + 9, + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19 + ] + }, + { + "teal": 14, + "source": "tests/contracts/inheritance.algo.ts:79", + "pc": [ + 20, + 21 + ] + }, + { + "teal": 15, + "source": "tests/contracts/inheritance.algo.ts:79", + "pc": [ + 22 + ] + }, + { + "teal": 16, + "source": "tests/contracts/inheritance.algo.ts:79", + "pc": [ + 23, + 24 + ] + }, + { + "teal": 17, + "source": "tests/contracts/inheritance.algo.ts:79", + "pc": [ + 25 + ] + }, + { + "teal": 18, + "source": "tests/contracts/inheritance.algo.ts:79", + "pc": [ + 26, + 27 + ] + }, + { + "teal": 19, + "source": "tests/contracts/inheritance.algo.ts:79", + "pc": [ + 28 + ] + }, + { + "teal": 20, + "source": "tests/contracts/inheritance.algo.ts:79", + "pc": [ + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38, + 39, + 40, + 41, + 42, + 43, + 44, + 45, + 46, + 47, + 48, + 49, + 50, + 51, + 52, + 53, + 54 + ] + }, + { + "teal": 24, + "source": "tests/contracts/inheritance.algo.ts:79", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 55 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/inheritance.algo.ts:66", + "pc": [ + 56, + 57, + 58, + 59, + 60, + 61 + ] + }, + { + "teal": 32, + "source": "tests/contracts/inheritance.algo.ts:66", + "pc": [ + 62, + 63, + 64 + ] + }, + { + "teal": 33, + "source": "tests/contracts/inheritance.algo.ts:66", + "pc": [ + 65 + ] + }, + { + "teal": 34, + "source": "tests/contracts/inheritance.algo.ts:66", + "pc": [ + 66 + ] + }, + { + "teal": 35, + "source": "tests/contracts/inheritance.algo.ts:66", + "pc": [ + 67 + ] + }, + { + "teal": 36, + "source": "tests/contracts/inheritance.algo.ts:66", + "pc": [ + 68, + 69, + 70 + ] + }, + { + "teal": 37, + "source": "tests/contracts/inheritance.algo.ts:66", + "pc": [ + 71 + ] + }, + { + "teal": 38, + "source": "tests/contracts/inheritance.algo.ts:66", + "pc": [ + 72 + ] + }, + { + "teal": 39, + "source": "tests/contracts/inheritance.algo.ts:66", + "pc": [ + 73 + ] + }, + { + "teal": 40, + "source": "tests/contracts/inheritance.algo.ts:66", + "pc": [ + 74 + ] + }, + { + "teal": 41, + "source": "tests/contracts/inheritance.algo.ts:66", + "pc": [ + 75, + 76 + ] + }, + { + "teal": 42, + "source": "tests/contracts/inheritance.algo.ts:66", + "pc": [ + 77 + ] + }, + { + "teal": 46, + "source": "tests/contracts/inheritance.algo.ts:66", + "pc": [ + 78, + 79, + 80 + ] + }, + { + "teal": 50, + "source": "tests/contracts/inheritance.algo.ts:67", + "pc": [ + 81, + 82, + 83, + 84, + 85, + 86, + 87, + 88 + ] + }, + { + "teal": 51, + "source": "tests/contracts/inheritance.algo.ts:66", + "pc": [ + 89 + ] + }, + { + "teal": 55, + "source": "tests/contracts/inheritance.algo.ts:70", + "pc": [ + 90, + 91, + 92 + ] + }, + { + "teal": 59, + "source": "tests/contracts/inheritance.algo.ts:71", + "pc": [ + 93, + 94, + 95, + 96, + 97, + 98, + 99, + 100, + 101 + ] }, { + "teal": 60, + "source": "tests/contracts/inheritance.algo.ts:70", + "pc": [ + 102 + ] + }, + { + "teal": 64, + "source": "tests/contracts/inheritance.algo.ts:74", + "pc": [ + 103, + 104, + 105 + ] + }, + { + "teal": 68, + "source": "tests/contracts/inheritance.algo.ts:75", + "pc": [ + 106, + 107, + 108, + 109, + 110, + 111, + 112, + 113, + 114, + 115, + 116 + ] + }, + { + "teal": 69, + "source": "tests/contracts/inheritance.algo.ts:74", + "pc": [ + 117 + ] + }, + { + "teal": 74, + "source": "tests/contracts/inheritance.algo.ts:80", + "pc": [ + 118, + 119, + 120 + ] + }, + { + "teal": 75, + "source": "tests/contracts/inheritance.algo.ts:80", + "pc": [ + 121, + 122 + ] + }, + { + "teal": 76, + "source": "tests/contracts/inheritance.algo.ts:80", + "pc": [ + 123 + ] + }, + { + "teal": 80, + "source": "tests/contracts/inheritance.algo.ts:80", + "pc": [ + 124, + 125, + 126 + ] + }, + { + "teal": 84, + "source": "tests/contracts/inheritance.algo.ts:81", + "pc": [ + 127, + 128, + 129 + ] + }, + { + "teal": 85, + "source": "tests/contracts/inheritance.algo.ts:81", + "pc": [ + 130, + 131, + 132, + 133, + 134, + 135, + 136, + 137, + 138, + 139, + 140 + ] + }, + { + "teal": 86, + "source": "tests/contracts/inheritance.algo.ts:81", + "pc": [ + 141 + ] + }, + { + "teal": 87, + "source": "tests/contracts/inheritance.algo.ts:81", + "pc": [ + 142 + ] + }, + { + "teal": 91, + "source": "tests/contracts/inheritance.algo.ts:82", + "pc": [ + 143, + 144, + 145 + ] + }, + { + "teal": 92, + "source": "tests/contracts/inheritance.algo.ts:82", + "pc": [ + 146, + 147, + 148, + 149, + 150, + 151, + 152, + 153 + ] + }, + { + "teal": 93, + "source": "tests/contracts/inheritance.algo.ts:82", + "pc": [ + 154 + ] + }, + { + "teal": 94, + "source": "tests/contracts/inheritance.algo.ts:82", + "pc": [ + 155 + ] + }, + { + "teal": 95, + "source": "tests/contracts/inheritance.algo.ts:80", + "pc": [ + 156 + ] + }, + { + "teal": 98, + "source": "tests/contracts/inheritance.algo.ts:79", + "pc": [ + 157, + 158 + ] + }, + { + "teal": 99, + "source": "tests/contracts/inheritance.algo.ts:79", + "pc": [ + 159 + ] + }, + { + "teal": 102, + "source": "tests/contracts/inheritance.algo.ts:79", + "pc": [ + 160, + 161, + 162, + 163, + 164, + 165 + ] + }, + { + "teal": 103, + "source": "tests/contracts/inheritance.algo.ts:79", + "pc": [ + 166, + 167, + 168 + ] + }, + { + "teal": 104, + "source": "tests/contracts/inheritance.algo.ts:79", + "pc": [ + 169, + 170, + 171, + 172 + ] + }, + { + "teal": 107, + "source": "tests/contracts/inheritance.algo.ts:79", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 173 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 110, + "source": "tests/contracts/inheritance.algo.ts:79", + "pc": [ + 174, + 175, + 176, + 177, + 178, + 179 + ] + }, + { + "teal": 111, + "source": "tests/contracts/inheritance.algo.ts:79", + "pc": [ + 180, + 181, + 182, + 183, + 184, + 185 + ] + }, + { + "teal": 112, + "source": "tests/contracts/inheritance.algo.ts:79", + "pc": [ + 186, + 187, + 188 + ] + }, + { + "teal": 113, + "source": "tests/contracts/inheritance.algo.ts:79", + "pc": [ + 189, + 190, + 191, + 192, + 193, + 194 + ] }, { + "teal": 116, + "source": "tests/contracts/inheritance.algo.ts:79", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 195 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/GeneralTest.arc56_draft.json b/tests/contracts/artifacts/GeneralTest.arc56_draft.json index 2dccf4851..6e4d6ea34 100644 --- a/tests/contracts/artifacts/GeneralTest.arc56_draft.json +++ b/tests/contracts/artifacts/GeneralTest.arc56_draft.json @@ -1123,226 +1123,15281 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 1, + 2, + 3, + 4, + 5, + 6, + 7, + 8, + 9, + 10, + 11 + ] + }, + { + "teal": 3, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38, + 39, + 40, + 41, + 42, + 43, + 44, + 45, + 46, + 47, + 48, + 49, + 50, + 51, + 52, + 53, + 54, + 55, + 56, + 57, + 58, + 59, + 60, + 61, + 62, + 63, + 64, + 65, + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82, + 83, + 84, + 85, + 86, + 87, + 88, + 89, + 90, + 91, + 92, + 93, + 94, + 95, + 96, + 97, + 98, + 99, + 100, + 101, + 102, + 103, + 104, + 105, + 106, + 107, + 108, + 109, + 110, + 111, + 112, + 113, + 114, + 115, + 116, + 117, + 118, + 119, + 120, + 121, + 122, + 123, + 124, + 125, + 126, + 127, + 128, + 129, + 130, + 131, + 132, + 133, + 134, + 135, + 136, + 137, + 138, + 139, + 140, + 141, + 142, + 143, + 144, + 145, + 146, + 147, + 148, + 149, + 150, + 151, + 152, + 153, + 154, + 155, + 156, + 157, + 158, + 159, + 160, + 161, + 162, + 163, + 164, + 165, + 166, + 167, + 168, + 169, + 170, + 171, + 172, + 173, + 174, + 175, + 176, + 177, + 178, + 179, + 180, + 181, + 182, + 183, + 184, + 185, + 186, + 187, + 188, + 189, + 190, + 191, + 192, + 193, + 194, + 195, + 196, + 197, + 198, + 199, + 200, + 201, + 202, + 203, + 204, + 205, + 206, + 207, + 208, + 209, + 210, + 211, + 212, + 213, + 214, + 215, + 216, + 217, + 218, + 219, + 220, + 221 + ] + }, + { + "teal": 15, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 222, + 223 + ] + }, + { + "teal": 16, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 224 + ] + }, + { + "teal": 17, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 225, + 226 + ] + }, + { + "teal": 18, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 227 + ] + }, + { + "teal": 19, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 228, + 229 + ] + }, + { + "teal": 20, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 230 + ] + }, + { + "teal": 21, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 231, + 232, + 233, + 234, + 235, + 236, + 237, + 238, + 239, + 240, + 241, + 242, + 243, + 244, + 245, + 246, + 247, + 248, + 249, + 250, + 251, + 252, + 253, + 254, + 255, + 256 + ] + }, + { + "teal": 25, + "source": "tests/contracts/general.algo.ts:57", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 257 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 30, + "source": "tests/contracts/general.algo.ts:68", + "pc": [ + 258, + 259, + 260 + ] + }, + { + "teal": 31, + "source": "tests/contracts/general.algo.ts:68", + "pc": [ + 261, + 262 + ] + }, + { + "teal": 32, + "source": "tests/contracts/general.algo.ts:68", + "pc": [ + 263 + ] + }, + { + "teal": 36, + "source": "tests/contracts/general.algo.ts:68", + "pc": [ + 264, + 265, + 266 + ] + }, + { + "teal": 40, + "source": "tests/contracts/general.algo.ts:69", + "pc": [ + 267, + 268 + ] + }, + { + "teal": 41, + "source": "tests/contracts/general.algo.ts:69", + "pc": [ + 269, + 270 + ] + }, + { + "teal": 42, + "source": "tests/contracts/general.algo.ts:69", + "pc": [ + 271, + 272 + ] + }, + { + "teal": 43, + "source": "tests/contracts/general.algo.ts:69", + "pc": [ + 273 + ] + }, + { + "teal": 44, + "source": "tests/contracts/general.algo.ts:69", + "pc": [ + 274 + ] + }, + { + "teal": 45, + "source": "tests/contracts/general.algo.ts:68", + "pc": [ + 275 + ] + }, + { + "teal": 50, + "source": "tests/contracts/general.algo.ts:72", + "pc": [ + 276, + 277, + 278 + ] }, { + "teal": 51, + "source": "tests/contracts/general.algo.ts:72", + "pc": [ + 279, + 280 + ] + }, + { + "teal": 52, + "source": "tests/contracts/general.algo.ts:72", + "pc": [ + 281 + ] + }, + { + "teal": 56, + "source": "tests/contracts/general.algo.ts:72", + "pc": [ + 282, + 283, + 284 + ] + }, + { + "teal": 60, + "source": "tests/contracts/general.algo.ts:73", + "pc": [ + 285, + 286 + ] + }, + { + "teal": 61, + "source": "tests/contracts/general.algo.ts:73", + "pc": [ + 287, + 288 + ] + }, + { + "teal": 62, + "source": "tests/contracts/general.algo.ts:73", + "pc": [ + 289 + ] + }, + { + "teal": 63, + "source": "tests/contracts/general.algo.ts:73", + "pc": [ + 290 + ] + }, + { + "teal": 64, + "source": "tests/contracts/general.algo.ts:72", + "pc": [ + 291 + ] + }, + { + "teal": 69, + "source": "tests/contracts/general.algo.ts:76", + "pc": [ + 292, + 293, + 294 + ] + }, + { + "teal": 70, + "source": "tests/contracts/general.algo.ts:76", + "pc": [ + 295 + ] + }, + { + "teal": 71, + "source": "tests/contracts/general.algo.ts:76", + "pc": [ + 296 + ] + }, + { + "teal": 72, + "source": "tests/contracts/general.algo.ts:76", + "pc": [ + 297, + 298 + ] + }, + { + "teal": 73, + "source": "tests/contracts/general.algo.ts:76", + "pc": [ + 299 + ] + }, + { + "teal": 76, + "source": "tests/contracts/general.algo.ts:76", + "errorMessage": "argument 0 (arg2) for asserts must be a bool", "pc": [ 300 - ], - "errorMessage": "argument 0 (arg2) for asserts must be a bool" + ] + }, + { + "teal": 77, + "source": "tests/contracts/general.algo.ts:76", + "pc": [ + 301, + 302 + ] + }, + { + "teal": 78, + "source": "tests/contracts/general.algo.ts:76", + "pc": [ + 303 + ] + }, + { + "teal": 81, + "source": "tests/contracts/general.algo.ts:76", + "pc": [ + 304, + 305, + 306 + ] + }, + { + "teal": 82, + "source": "tests/contracts/general.algo.ts:76", + "pc": [ + 307 + ] + }, + { + "teal": 83, + "source": "tests/contracts/general.algo.ts:76", + "pc": [ + 308 + ] + }, + { + "teal": 84, + "source": "tests/contracts/general.algo.ts:76", + "pc": [ + 309, + 310 + ] + }, + { + "teal": 85, + "source": "tests/contracts/general.algo.ts:76", + "pc": [ + 311 + ] }, { + "teal": 88, + "source": "tests/contracts/general.algo.ts:76", + "errorMessage": "argument 1 (arg1) for asserts must be a bool", "pc": [ 312 - ], - "errorMessage": "argument 1 (arg1) for asserts must be a bool" + ] + }, + { + "teal": 89, + "source": "tests/contracts/general.algo.ts:76", + "pc": [ + 313, + 314 + ] + }, + { + "teal": 90, + "source": "tests/contracts/general.algo.ts:76", + "pc": [ + 315 + ] + }, + { + "teal": 93, + "source": "tests/contracts/general.algo.ts:76", + "pc": [ + 316, + 317, + 318 + ] + }, + { + "teal": 94, + "source": "tests/contracts/general.algo.ts:76", + "pc": [ + 319, + 320 + ] + }, + { + "teal": 95, + "source": "tests/contracts/general.algo.ts:76", + "pc": [ + 321 + ] + }, + { + "teal": 99, + "source": "tests/contracts/general.algo.ts:76", + "pc": [ + 322, + 323, + 324 + ] }, { + "teal": 103, + "source": "tests/contracts/general.algo.ts:77", + "pc": [ + 325, + 326 + ] + }, + { + "teal": 106, + "source": "tests/contracts/general.algo.ts:77", + "errorMessage": "asserts failed: asserts(arg1, arg2, arg1 === arg2)", "pc": [ 327 - ], - "errorMessage": "asserts failed: asserts(arg1, arg2, arg1 === arg2)" + ] }, { + "teal": 107, + "source": "tests/contracts/general.algo.ts:77", + "pc": [ + 328, + 329 + ] + }, + { + "teal": 110, + "source": "tests/contracts/general.algo.ts:77", + "errorMessage": "asserts failed: asserts(arg1, arg2, arg1 === arg2)", "pc": [ 330 - ], - "errorMessage": "asserts failed: asserts(arg1, arg2, arg1 === arg2)" + ] + }, + { + "teal": 111, + "source": "tests/contracts/general.algo.ts:77", + "pc": [ + 331, + 332 + ] + }, + { + "teal": 112, + "source": "tests/contracts/general.algo.ts:77", + "pc": [ + 333, + 334 + ] + }, + { + "teal": 113, + "source": "tests/contracts/general.algo.ts:77", + "pc": [ + 335 + ] }, { + "teal": 116, + "source": "tests/contracts/general.algo.ts:77", + "errorMessage": "asserts failed: asserts(arg1, arg2, arg1 === arg2)", "pc": [ 336 - ], - "errorMessage": "asserts failed: asserts(arg1, arg2, arg1 === arg2)" + ] + }, + { + "teal": 117, + "source": "tests/contracts/general.algo.ts:76", + "pc": [ + 337 + ] + }, + { + "teal": 122, + "source": "tests/contracts/general.algo.ts:80", + "pc": [ + 338, + 339 + ] + }, + { + "teal": 123, + "source": "tests/contracts/general.algo.ts:80", + "pc": [ + 340, + 341 + ] + }, + { + "teal": 124, + "source": "tests/contracts/general.algo.ts:80", + "pc": [ + 342 + ] + }, + { + "teal": 125, + "source": "tests/contracts/general.algo.ts:80", + "pc": [ + 343 + ] + }, + { + "teal": 126, + "source": "tests/contracts/general.algo.ts:80", + "pc": [ + 344, + 345 + ] + }, + { + "teal": 127, + "source": "tests/contracts/general.algo.ts:80", + "pc": [ + 346, + 347 + ] + }, + { + "teal": 128, + "source": "tests/contracts/general.algo.ts:80", + "pc": [ + 348 + ] }, { + "teal": 131, + "source": "tests/contracts/general.algo.ts:80", + "errorMessage": "argument 0 (somePay) for verifyTxnFromArg must be a pay transaction", "pc": [ 349 - ], - "errorMessage": "argument 0 (somePay) for verifyTxnFromArg must be a pay transaction" + ] }, { + "teal": 134, + "source": "tests/contracts/general.algo.ts:80", "pc": [ - 366 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"somePay\",\"field\":\"receiver\",\"expected\":\"this.app.address\"}" + 350, + 351, + 352 + ] }, { + "teal": 135, + "source": "tests/contracts/general.algo.ts:80", "pc": [ - 376 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"somePay\",\"field\":\"amount\",\"expected\":\"100_000\"}" + 353, + 354 + ] }, { + "teal": 136, + "source": "tests/contracts/general.algo.ts:80", "pc": [ - 394 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"this.txnGroup[0]\",\"field\":\"sender\",\"expected\":\"this.txn.sender\"}" + 355 + ] }, { + "teal": 140, + "source": "tests/contracts/general.algo.ts:80", "pc": [ - 410 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"this.txn\",\"field\":\"applicationID\",\"condition\":\"greaterThan\",\"expected\":\">1\"}" + 356, + 357, + 358 + ] }, { + "teal": 145, + "source": "tests/contracts/general.algo.ts:81", "pc": [ - 426 - ], - "errorMessage": "transaction verification failed: {\"txn\":{\"txnText\":\"this.txn\"},\"field\":\"sender\",\"condition\":\"includedIn\",\"expected\":\"[this.txn.sender]\"}" + 359, + 360 + ] }, { + "teal": 146, + "source": "tests/contracts/general.algo.ts:81", "pc": [ - 442 - ], - "errorMessage": "transaction verification failed: {\"txn\":{\"txnText\":\"this.txn\"},\"field\":\"sender\",\"condition\":\"notIncludedIn\",\"expected\":\"[globals.zeroAddress]\"}" + 361, + 362 + ] }, { + "teal": 147, + "source": "tests/contracts/general.algo.ts:81", "pc": [ - 1238 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"this.txnGroup[0]\",\"field\":\"typeEnum\",\"expected\":\"pay\"}" + 363, + 364 + ] }, { + "teal": 148, + "source": "tests/contracts/general.algo.ts:81", "pc": [ - 1246 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"this.txnGroup[0]\",\"field\":\"amount\",\"condition\":\"greaterThan\",\"expected\":\">0\"}" + 365 + ] }, { + "teal": 151, + "source": "tests/contracts/general.algo.ts:81", + "errorMessage": "transaction verification failed: {\"txn\":\"somePay\",\"field\":\"receiver\",\"expected\":\"this.app.address\"}", "pc": [ - 1254 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"this.txnGroup[0]\",\"field\":\"typeEnum\",\"expected\":\"appl\"}" + 366 + ] }, { + "teal": 154, + "source": "tests/contracts/general.algo.ts:81", "pc": [ - 1262 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"this.txnGroup[0]\",\"field\":\"applicationID\",\"expected\":\"AppID.fromUint64(0)\"}" + 367, + 368 + ] }, { + "teal": 155, + "source": "tests/contracts/general.algo.ts:81", "pc": [ - 1274 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"this.txnGroup[0]\",\"field\":\"applicationArgs\",\"index\":\"0\",\"expected\":\"'foo'\"}" + 369, + 370 + ] }, { + "teal": 156, + "source": "tests/contracts/general.algo.ts:81", "pc": [ - 1298 - ], - "errorMessage": "transaction verification failed: {\"txn\":{\"txnText\":\"this.txnGroup[0]\"},\"field\":\"applicationArgs 1\",\"condition\":\"includedIn\",\"expected\":\"['bar', 'baz']\"}" + 371, + 372, + 373, + 374 + ] }, { + "teal": 157, + "source": "tests/contracts/general.algo.ts:81", "pc": [ - 1306 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"this.txnGroup[0]\",\"field\":\"typeEnum\",\"expected\":\"axfer\"}" + 375 + ] }, { + "teal": 160, + "source": "tests/contracts/general.algo.ts:81", + "errorMessage": "transaction verification failed: {\"txn\":\"somePay\",\"field\":\"amount\",\"expected\":\"100_000\"}", "pc": [ - 1314 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"this.txnGroup[0]\",\"field\":\"assetReceiver\",\"expected\":\"this.app.address\"}" + 376 + ] }, { + "teal": 161, + "source": "tests/contracts/general.algo.ts:80", "pc": [ - 1322 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"this.txnGroup[0]\",\"field\":\"typeEnum\",\"expected\":\"acfg\"}" + 377 + ] }, { + "teal": 166, + "source": "tests/contracts/general.algo.ts:84", "pc": [ - 1330 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"this.txnGroup[0]\",\"field\":\"configAsset\",\"expected\":\"AssetID.fromUint64(0)\"}" + 378, + 379, + 380 + ] }, { + "teal": 167, + "source": "tests/contracts/general.algo.ts:84", "pc": [ - 1338 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"this.txnGroup[0]\",\"field\":\"typeEnum\",\"expected\":\"keyreg\"}" + 381, + 382 + ] }, { + "teal": 168, + "source": "tests/contracts/general.algo.ts:84", "pc": [ - 1347 - ], - "errorMessage": "transaction verification failed: {\"txn\":\"this.txnGroup[0]\",\"field\":\"voteFirst\",\"expected\":\"1337\"}" + 383 + ] }, { + "teal": 172, + "source": "tests/contracts/general.algo.ts:84", "pc": [ - 2795 - ], - "errorMessage": "uintNWithUnderscore return value overflowed 256 bits" + 384, + 385, + 386 + ] }, { + "teal": 177, + "source": "tests/contracts/general.algo.ts:85", "pc": [ - 3392 - ], - "errorMessage": "this is false" + 387, + 388 + ] }, { + "teal": 178, + "source": "tests/contracts/general.algo.ts:85", "pc": [ - 4674 - ], - "errorMessage": "argument 0 (_pay1) for txnArgsMethod must be a pay transaction" + 389, + 390 + ] }, { + "teal": 179, + "source": "tests/contracts/general.algo.ts:85", "pc": [ - 4738 - ], - "errorMessage": "argument 0 (x) for staticValueLen must be a uint256" + 391, + 392 + ] }, { + "teal": 180, + "source": "tests/contracts/general.algo.ts:85", "pc": [ - 5023 - ], - "errorMessage": "box value does not exist: this.pageOne.value" + 393 + ] }, { + "teal": 183, + "source": "tests/contracts/general.algo.ts:85", + "errorMessage": "transaction verification failed: {\"txn\":\"this.txnGroup[0]\",\"field\":\"sender\",\"expected\":\"this.txn.sender\"}", "pc": [ - 5036 - ], - "errorMessage": "box value does not exist: this.pageTwo.value" + 394 + ] }, { + "teal": 184, + "source": "tests/contracts/general.algo.ts:84", "pc": [ - 5049 - ], - "errorMessage": "box value does not exist: this.pageOne.value" + 395 + ] }, { + "teal": 189, + "source": "tests/contracts/general.algo.ts:88", "pc": [ - 5062 - ], - "errorMessage": "box value does not exist: this.pageTwo.value" + 396, + 397, + 398 + ] }, { + "teal": 190, + "source": "tests/contracts/general.algo.ts:88", "pc": [ - 5082 - ], - "errorMessage": "this is false" + 399, + 400 + ] }, { + "teal": 191, + "source": "tests/contracts/general.algo.ts:88", "pc": [ - 5093 - ], - "errorMessage": "this is an error" + 401 + ] }, { + "teal": 195, + "source": "tests/contracts/general.algo.ts:88", "pc": [ - 5238 - ], - "errorMessage": "local state value does not exist: app.localState( addr, 'key' )" + 402, + 403, + 404 + ] }, { + "teal": 202, + "source": "tests/contracts/general.algo.ts:90", "pc": [ - 5386 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + 405, + 406 + ] + }, + { + "teal": 203, + "source": "tests/contracts/general.algo.ts:90", + "pc": [ + 407, + 408 + ] + }, + { + "teal": 204, + "source": "tests/contracts/general.algo.ts:90", + "pc": [ + 409 + ] + }, + { + "teal": 207, + "source": "tests/contracts/general.algo.ts:90", + "errorMessage": "transaction verification failed: {\"txn\":\"this.txn\",\"field\":\"applicationID\",\"condition\":\"greaterThan\",\"expected\":\">1\"}", + "pc": [ + 410 + ] + }, + { + "teal": 208, + "source": "tests/contracts/general.algo.ts:88", + "pc": [ + 411 + ] + }, + { + "teal": 213, + "source": "tests/contracts/general.algo.ts:94", + "pc": [ + 412, + 413, + 414 + ] + }, + { + "teal": 214, + "source": "tests/contracts/general.algo.ts:94", + "pc": [ + 415, + 416 + ] + }, + { + "teal": 215, + "source": "tests/contracts/general.algo.ts:94", + "pc": [ + 417 + ] + }, + { + "teal": 219, + "source": "tests/contracts/general.algo.ts:94", + "pc": [ + 418, + 419, + 420 + ] + }, + { + "teal": 226, + "source": "tests/contracts/general.algo.ts:96", + "pc": [ + 421, + 422 + ] + }, + { + "teal": 227, + "source": "tests/contracts/general.algo.ts:96", + "pc": [ + 423, + 424 + ] + }, + { + "teal": 228, + "source": "tests/contracts/general.algo.ts:96", + "pc": [ + 425 + ] + }, + { + "teal": 231, + "source": "tests/contracts/general.algo.ts:96", + "errorMessage": "transaction verification failed: {\"txn\":{\"txnText\":\"this.txn\"},\"field\":\"sender\",\"condition\":\"includedIn\",\"expected\":\"[this.txn.sender]\"}", + "pc": [ + 426 + ] + }, + { + "teal": 232, + "source": "tests/contracts/general.algo.ts:94", + "pc": [ + 427 + ] + }, + { + "teal": 237, + "source": "tests/contracts/general.algo.ts:100", + "pc": [ + 428, + 429, + 430 + ] + }, + { + "teal": 238, + "source": "tests/contracts/general.algo.ts:100", + "pc": [ + 431, + 432 + ] + }, + { + "teal": 239, + "source": "tests/contracts/general.algo.ts:100", + "pc": [ + 433 + ] + }, + { + "teal": 243, + "source": "tests/contracts/general.algo.ts:100", + "pc": [ + 434, + 435, + 436 + ] + }, + { + "teal": 250, + "source": "tests/contracts/general.algo.ts:102", + "pc": [ + 437, + 438 + ] + }, + { + "teal": 251, + "source": "tests/contracts/general.algo.ts:102", + "pc": [ + 439, + 440 + ] + }, + { + "teal": 252, + "source": "tests/contracts/general.algo.ts:102", + "pc": [ + 441 + ] + }, + { + "teal": 255, + "source": "tests/contracts/general.algo.ts:102", + "errorMessage": "transaction verification failed: {\"txn\":{\"txnText\":\"this.txn\"},\"field\":\"sender\",\"condition\":\"notIncludedIn\",\"expected\":\"[globals.zeroAddress]\"}", + "pc": [ + 442 + ] + }, + { + "teal": 256, + "source": "tests/contracts/general.algo.ts:100", + "pc": [ + 443 + ] + }, + { + "teal": 261, + "source": "tests/contracts/general.algo.ts:106", + "pc": [ + 444, + 445, + 446 + ] + }, + { + "teal": 262, + "source": "tests/contracts/general.algo.ts:106", + "pc": [ + 447, + 448 + ] + }, + { + "teal": 263, + "source": "tests/contracts/general.algo.ts:106", + "pc": [ + 449 + ] + }, + { + "teal": 267, + "source": "tests/contracts/general.algo.ts:106", + "pc": [ + 450, + 451, + 452 + ] + }, + { + "teal": 271, + "source": "tests/contracts/general.algo.ts:107", + "pc": [ + 453 + ] + }, + { + "teal": 272, + "source": "tests/contracts/general.algo.ts:107", + "pc": [ + 454, + 455 + ] + }, + { + "teal": 273, + "source": "tests/contracts/general.algo.ts:107", + "pc": [ + 456, + 457 + ] + }, + { + "teal": 277, + "source": "tests/contracts/general.algo.ts:107", + "pc": [ + 458, + 459 + ] + }, + { + "teal": 278, + "source": "tests/contracts/general.algo.ts:107", + "pc": [ + 460, + 461 + ] + }, + { + "teal": 282, + "source": "tests/contracts/general.algo.ts:107", + "pc": [ + 462, + 463 + ] + }, + { + "teal": 283, + "source": "tests/contracts/general.algo.ts:107", + "pc": [ + 464, + 465 + ] + }, + { + "teal": 286, + "source": "tests/contracts/general.algo.ts:107", + "pc": [ + 466, + 467 + ] + }, + { + "teal": 287, + "source": "tests/contracts/general.algo.ts:107", + "pc": [ + 468, + 469 + ] + }, + { + "teal": 291, + "source": "tests/contracts/general.algo.ts:108", + "pc": [ + 470 + ] + }, + { + "teal": 292, + "source": "tests/contracts/general.algo.ts:108", + "pc": [ + 471, + 472 + ] + }, + { + "teal": 293, + "source": "tests/contracts/general.algo.ts:108", + "pc": [ + 473, + 474 + ] + }, + { + "teal": 297, + "source": "tests/contracts/general.algo.ts:108", + "pc": [ + 475, + 476 + ] + }, + { + "teal": 298, + "source": "tests/contracts/general.algo.ts:108", + "pc": [ + 477, + 478 + ] + }, + { + "teal": 302, + "source": "tests/contracts/general.algo.ts:108", + "pc": [ + 479, + 480 + ] + }, + { + "teal": 303, + "source": "tests/contracts/general.algo.ts:108", + "pc": [ + 481, + 482 + ] + }, + { + "teal": 307, + "source": "tests/contracts/general.algo.ts:108", + "pc": [ + 483, + 484, + 485, + 486, + 487 + ] + }, + { + "teal": 308, + "source": "tests/contracts/general.algo.ts:108", + "pc": [ + 488, + 489 + ] + }, + { + "teal": 311, + "source": "tests/contracts/general.algo.ts:108", + "pc": [ + 490, + 491 + ] + }, + { + "teal": 312, + "source": "tests/contracts/general.algo.ts:108", + "pc": [ + 492, + 493 + ] + }, + { + "teal": 316, + "source": "tests/contracts/general.algo.ts:109", + "pc": [ + 494 + ] + }, + { + "teal": 317, + "source": "tests/contracts/general.algo.ts:106", + "pc": [ + 495 + ] + }, + { + "teal": 322, + "source": "tests/contracts/general.algo.ts:112", + "pc": [ + 496, + 497, + 498 + ] + }, + { + "teal": 323, + "source": "tests/contracts/general.algo.ts:112", + "pc": [ + 499, + 500 + ] + }, + { + "teal": 324, + "source": "tests/contracts/general.algo.ts:112", + "pc": [ + 501 + ] + }, + { + "teal": 328, + "source": "tests/contracts/general.algo.ts:112", + "pc": [ + 502, + 503, + 504 + ] + }, + { + "teal": 342, + "source": "tests/contracts/general.algo.ts:116", + "pc": [ + 505 + ] + }, + { + "teal": 343, + "source": "tests/contracts/general.algo.ts:116", + "pc": [ + 506, + 507 + ] + }, + { + "teal": 344, + "source": "tests/contracts/general.algo.ts:116", + "pc": [ + 508, + 509 + ] + }, + { + "teal": 348, + "source": "tests/contracts/general.algo.ts:116", + "pc": [ + 510, + 511, + 512, + 513 + ] + }, + { + "teal": 349, + "source": "tests/contracts/general.algo.ts:116", + "pc": [ + 514, + 515 + ] + }, + { + "teal": 353, + "source": "tests/contracts/general.algo.ts:116", + "pc": [ + 516, + 517 + ] + }, + { + "teal": 354, + "source": "tests/contracts/general.algo.ts:116", + "pc": [ + 518, + 519 + ] + }, + { + "teal": 357, + "source": "tests/contracts/general.algo.ts:116", + "pc": [ + 520, + 521 + ] + }, + { + "teal": 358, + "source": "tests/contracts/general.algo.ts:116", + "pc": [ + 522, + 523 + ] + }, + { + "teal": 359, + "source": "tests/contracts/general.algo.ts:117", + "pc": [ + 524 + ] + }, + { + "teal": 360, + "source": "tests/contracts/general.algo.ts:117", + "pc": [ + 525, + 526 + ] + }, + { + "teal": 361, + "source": "tests/contracts/general.algo.ts:117", + "pc": [ + 527, + 528 + ] + }, + { + "teal": 362, + "source": "tests/contracts/general.algo.ts:118", + "pc": [ + 529, + 530, + 531, + 532, + 533, + 534 + ] + }, + { + "teal": 363, + "source": "tests/contracts/general.algo.ts:118", + "pc": [ + 535, + 536 + ] + }, + { + "teal": 367, + "source": "tests/contracts/general.algo.ts:119", + "pc": [ + 537, + 538, + 539 + ] + }, + { + "teal": 368, + "source": "tests/contracts/general.algo.ts:119", + "pc": [ + 540, + 541 + ] + }, + { + "teal": 372, + "source": "tests/contracts/general.algo.ts:120", + "pc": [ + 542, + 543, + 544, + 545, + 546, + 547, + 548, + 549, + 550, + 551 + ] + }, + { + "teal": 373, + "source": "tests/contracts/general.algo.ts:120", + "pc": [ + 552, + 553 + ] + }, + { + "teal": 376, + "source": "tests/contracts/general.algo.ts:117", + "pc": [ + 554, + 555 + ] + }, + { + "teal": 377, + "source": "tests/contracts/general.algo.ts:117", + "pc": [ + 556, + 557 + ] + }, + { + "teal": 378, + "source": "tests/contracts/general.algo.ts:113", + "pc": [ + 558 + ] + }, + { + "teal": 379, + "source": "tests/contracts/general.algo.ts:113", + "pc": [ + 559, + 560 + ] + }, + { + "teal": 380, + "source": "tests/contracts/general.algo.ts:113", + "pc": [ + 561, + 562 + ] + }, + { + "teal": 381, + "source": "tests/contracts/general.algo.ts:114", + "pc": [ + 563, + 564, + 565, + 566, + 567, + 568 + ] + }, + { + "teal": 382, + "source": "tests/contracts/general.algo.ts:114", + "pc": [ + 569, + 570 + ] + }, + { + "teal": 394, + "source": "tests/contracts/general.algo.ts:113", + "pc": [ + 571, + 572 + ] + }, + { + "teal": 395, + "source": "tests/contracts/general.algo.ts:113", + "pc": [ + 573, + 574 + ] + }, + { + "teal": 398, + "source": "tests/contracts/general.algo.ts:113", + "pc": [ + 575 + ] + }, + { + "teal": 399, + "source": "tests/contracts/general.algo.ts:112", + "pc": [ + 576 + ] + }, + { + "teal": 404, + "source": "tests/contracts/general.algo.ts:126", + "pc": [ + 577, + 578, + 579 + ] + }, + { + "teal": 405, + "source": "tests/contracts/general.algo.ts:126", + "pc": [ + 580, + 581 + ] + }, + { + "teal": 406, + "source": "tests/contracts/general.algo.ts:126", + "pc": [ + 582 + ] + }, + { + "teal": 410, + "source": "tests/contracts/general.algo.ts:126", + "pc": [ + 583, + 584, + 585 + ] + }, + { + "teal": 414, + "source": "tests/contracts/general.algo.ts:127", + "pc": [ + 586, + 587 + ] + }, + { + "teal": 415, + "source": "tests/contracts/general.algo.ts:127", + "pc": [ + 588, + 589 + ] + }, + { + "teal": 416, + "source": "tests/contracts/general.algo.ts:127", + "pc": [ + 590 + ] + }, + { + "teal": 417, + "source": "tests/contracts/general.algo.ts:127", + "pc": [ + 591, + 592 + ] + }, + { + "teal": 418, + "source": "tests/contracts/general.algo.ts:127", + "pc": [ + 593 + ] + }, + { + "teal": 419, + "source": "tests/contracts/general.algo.ts:127", + "pc": [ + 594 + ] + }, + { + "teal": 423, + "source": "tests/contracts/general.algo.ts:128", + "pc": [ + 595, + 596 + ] + }, + { + "teal": 424, + "source": "tests/contracts/general.algo.ts:128", + "pc": [ + 597, + 598 + ] + }, + { + "teal": 425, + "source": "tests/contracts/general.algo.ts:128", + "pc": [ + 599 + ] + }, + { + "teal": 426, + "source": "tests/contracts/general.algo.ts:128", + "pc": [ + 600, + 601 + ] + }, + { + "teal": 427, + "source": "tests/contracts/general.algo.ts:128", + "pc": [ + 602 + ] + }, + { + "teal": 428, + "source": "tests/contracts/general.algo.ts:128", + "pc": [ + 603 + ] + }, + { + "teal": 429, + "source": "tests/contracts/general.algo.ts:126", + "pc": [ + 604 + ] + }, + { + "teal": 434, + "source": "tests/contracts/general.algo.ts:131", + "pc": [ + 605, + 606, + 607 + ] + }, + { + "teal": 435, + "source": "tests/contracts/general.algo.ts:131", + "pc": [ + 608, + 609 + ] + }, + { + "teal": 436, + "source": "tests/contracts/general.algo.ts:131", + "pc": [ + 610 + ] + }, + { + "teal": 440, + "source": "tests/contracts/general.algo.ts:131", + "pc": [ + 611, + 612, + 613 + ] + }, + { + "teal": 444, + "source": "tests/contracts/general.algo.ts:132", + "pc": [ + 614, + 615, + 616, + 617, + 618 + ] + }, + { + "teal": 445, + "source": "tests/contracts/general.algo.ts:132", + "pc": [ + 619, + 620 + ] + }, + { + "teal": 446, + "source": "tests/contracts/general.algo.ts:132", + "pc": [ + 621 + ] + }, + { + "teal": 447, + "source": "tests/contracts/general.algo.ts:132", + "pc": [ + 622 + ] + }, + { + "teal": 448, + "source": "tests/contracts/general.algo.ts:131", + "pc": [ + 623 + ] + }, + { + "teal": 453, + "source": "tests/contracts/general.algo.ts:135", + "pc": [ + 624, + 625, + 626 + ] + }, + { + "teal": 454, + "source": "tests/contracts/general.algo.ts:135", + "pc": [ + 627, + 628 + ] + }, + { + "teal": 455, + "source": "tests/contracts/general.algo.ts:135", + "pc": [ + 629 + ] + }, + { + "teal": 459, + "source": "tests/contracts/general.algo.ts:135", + "pc": [ + 630, + 631, + 632 + ] + }, + { + "teal": 463, + "source": "tests/contracts/general.algo.ts:136", + "pc": [ + 633, + 634 + ] + }, + { + "teal": 464, + "source": "tests/contracts/general.algo.ts:136", + "pc": [ + 635, + 636 + ] + }, + { + "teal": 465, + "source": "tests/contracts/general.algo.ts:136", + "pc": [ + 637 + ] + }, + { + "teal": 466, + "source": "tests/contracts/general.algo.ts:136", + "pc": [ + 638 + ] + }, + { + "teal": 470, + "source": "tests/contracts/general.algo.ts:137", + "pc": [ + 639, + 640 + ] + }, + { + "teal": 471, + "source": "tests/contracts/general.algo.ts:137", + "pc": [ + 641, + 642 + ] + }, + { + "teal": 472, + "source": "tests/contracts/general.algo.ts:137", + "pc": [ + 643 + ] + }, + { + "teal": 473, + "source": "tests/contracts/general.algo.ts:137", + "pc": [ + 644 + ] + }, + { + "teal": 474, + "source": "tests/contracts/general.algo.ts:135", + "pc": [ + 645 + ] + }, + { + "teal": 479, + "source": "tests/contracts/general.algo.ts:140", + "pc": [ + 646, + 647, + 648 + ] + }, + { + "teal": 480, + "source": "tests/contracts/general.algo.ts:140", + "pc": [ + 649, + 650 + ] + }, + { + "teal": 481, + "source": "tests/contracts/general.algo.ts:140", + "pc": [ + 651 + ] + }, + { + "teal": 485, + "source": "tests/contracts/general.algo.ts:140", + "pc": [ + 652, + 653, + 654 + ] + }, + { + "teal": 488, + "source": "tests/contracts/general.algo.ts:140", + "pc": [ + 655, + 656 + ] + }, + { + "teal": 489, + "source": "tests/contracts/general.algo.ts:140", + "pc": [ + 657, + 658 + ] + }, + { + "teal": 493, + "source": "tests/contracts/general.algo.ts:142", + "pc": [ + 659, + 660, + 661, + 662 + ] + }, + { + "teal": 494, + "source": "tests/contracts/general.algo.ts:142", + "pc": [ + 663, + 664 + ] + }, + { + "teal": 498, + "source": "tests/contracts/general.algo.ts:143", + "pc": [ + 665, + 666 + ] + }, + { + "teal": 499, + "source": "tests/contracts/general.algo.ts:143", + "pc": [ + 667 + ] + }, + { + "teal": 500, + "source": "tests/contracts/general.algo.ts:143", + "pc": [ + 668, + 669 + ] + }, + { + "teal": 504, + "source": "tests/contracts/general.algo.ts:144", + "pc": [ + 670, + 671, + 672, + 673, + 674, + 675, + 676, + 677, + 678, + 679, + 680 + ] + }, + { + "teal": 505, + "source": "tests/contracts/general.algo.ts:144", + "pc": [ + 681, + 682 + ] + }, + { + "teal": 509, + "source": "tests/contracts/general.algo.ts:145", + "pc": [ + 683, + 684, + 685, + 686 + ] + }, + { + "teal": 510, + "source": "tests/contracts/general.algo.ts:145", + "pc": [ + 687, + 688 + ] + }, + { + "teal": 511, + "source": "tests/contracts/general.algo.ts:145", + "pc": [ + 689 + ] + }, + { + "teal": 512, + "source": "tests/contracts/general.algo.ts:145", + "pc": [ + 690, + 691, + 692, + 693, + 694, + 695, + 696, + 697, + 698, + 699, + 700 + ] + }, + { + "teal": 513, + "source": "tests/contracts/general.algo.ts:145", + "pc": [ + 701 + ] + }, + { + "teal": 514, + "source": "tests/contracts/general.algo.ts:145", + "pc": [ + 702 + ] + }, + { + "teal": 515, + "source": "tests/contracts/general.algo.ts:145", + "pc": [ + 703, + 704 + ] + }, + { + "teal": 516, + "source": "tests/contracts/general.algo.ts:145", + "pc": [ + 705 + ] + }, + { + "teal": 517, + "source": "tests/contracts/general.algo.ts:145", + "pc": [ + 706 + ] + }, + { + "teal": 518, + "source": "tests/contracts/general.algo.ts:140", + "pc": [ + 707 + ] + }, + { + "teal": 523, + "source": "tests/contracts/general.algo.ts:159", + "pc": [ + 708, + 709, + 710 + ] + }, + { + "teal": 524, + "source": "tests/contracts/general.algo.ts:159", + "pc": [ + 711, + 712 + ] + }, + { + "teal": 525, + "source": "tests/contracts/general.algo.ts:159", + "pc": [ + 713 + ] + }, + { + "teal": 529, + "source": "tests/contracts/general.algo.ts:159", + "pc": [ + 714, + 715, + 716 + ] + }, + { + "teal": 533, + "source": "tests/contracts/general.algo.ts:160", + "pc": [ + 717, + 718, + 719, + 720, + 721, + 722 + ] + }, + { + "teal": 534, + "source": "tests/contracts/general.algo.ts:160", + "pc": [ + 723, + 724, + 725 + ] + }, + { + "teal": 535, + "source": "tests/contracts/general.algo.ts:160", + "pc": [ + 726 + ] + }, + { + "teal": 536, + "source": "tests/contracts/general.algo.ts:160", + "pc": [ + 727, + 728, + 729, + 730, + 731, + 732, + 733, + 734, + 735, + 736 + ] + }, + { + "teal": 537, + "source": "tests/contracts/general.algo.ts:160", + "pc": [ + 737 + ] + }, + { + "teal": 538, + "source": "tests/contracts/general.algo.ts:160", + "pc": [ + 738 + ] + }, + { + "teal": 539, + "source": "tests/contracts/general.algo.ts:160", + "pc": [ + 739 + ] + }, + { + "teal": 540, + "source": "tests/contracts/general.algo.ts:159", + "pc": [ + 740 + ] + }, + { + "teal": 545, + "source": "tests/contracts/general.algo.ts:163", + "pc": [ + 741, + 742, + 743, + 744, + 745, + 746 + ] + }, + { + "teal": 548, + "source": "tests/contracts/general.algo.ts:163", + "pc": [ + 747, + 748, + 749 + ] + }, + { + "teal": 549, + "source": "tests/contracts/general.algo.ts:163", + "pc": [ + 750, + 751, + 752 + ] + }, + { + "teal": 552, + "source": "tests/contracts/general.algo.ts:163", + "pc": [ + 753, + 754, + 755 + ] + }, + { + "teal": 553, + "source": "tests/contracts/general.algo.ts:163", + "pc": [ + 756 + ] + }, + { + "teal": 554, + "source": "tests/contracts/general.algo.ts:163", + "pc": [ + 757 + ] + }, + { + "teal": 555, + "source": "tests/contracts/general.algo.ts:163", + "pc": [ + 758, + 759 + ] + }, + { + "teal": 556, + "source": "tests/contracts/general.algo.ts:163", + "pc": [ + 760 + ] + }, + { + "teal": 557, + "source": "tests/contracts/general.algo.ts:163", + "pc": [ + 761 + ] + }, + { + "teal": 558, + "source": "tests/contracts/general.algo.ts:163", + "pc": [ + 762, + 763, + 764 + ] + }, + { + "teal": 559, + "source": "tests/contracts/general.algo.ts:163", + "pc": [ + 765 + ] + }, + { + "teal": 560, + "source": "tests/contracts/general.algo.ts:163", + "pc": [ + 766 + ] + }, + { + "teal": 561, + "source": "tests/contracts/general.algo.ts:163", + "pc": [ + 767 + ] + }, + { + "teal": 562, + "source": "tests/contracts/general.algo.ts:163", + "pc": [ + 768 + ] + }, + { + "teal": 563, + "source": "tests/contracts/general.algo.ts:163", + "pc": [ + 769, + 770 + ] + }, + { + "teal": 564, + "source": "tests/contracts/general.algo.ts:163", + "pc": [ + 771 + ] + }, + { + "teal": 568, + "source": "tests/contracts/general.algo.ts:163", + "pc": [ + 772, + 773, + 774 + ] + }, + { + "teal": 572, + "source": "tests/contracts/general.algo.ts:164", + "pc": [ + 775, + 776 + ] + }, + { + "teal": 573, + "source": "tests/contracts/general.algo.ts:164", + "pc": [ + 777, + 778 + ] + }, + { + "teal": 574, + "source": "tests/contracts/general.algo.ts:164", + "pc": [ + 779, + 780 + ] + }, + { + "teal": 575, + "source": "tests/contracts/general.algo.ts:164", + "pc": [ + 781, + 782, + 783 + ] + }, + { + "teal": 576, + "source": "tests/contracts/general.algo.ts:164", + "pc": [ + 784 + ] + }, + { + "teal": 577, + "source": "tests/contracts/general.algo.ts:164", + "pc": [ + 785 + ] + }, + { + "teal": 581, + "source": "tests/contracts/general.algo.ts:166", + "pc": [ + 786, + 787, + 788, + 789, + 790, + 791, + 792, + 793, + 794, + 795, + 796, + 797, + 798, + 799, + 800, + 801, + 802, + 803, + 804, + 805, + 806, + 807, + 808, + 809, + 810, + 811 + ] + }, + { + "teal": 582, + "source": "tests/contracts/general.algo.ts:166", + "pc": [ + 812, + 813 + ] + }, + { + "teal": 586, + "source": "tests/contracts/general.algo.ts:168", + "pc": [ + 814, + 815 + ] + }, + { + "teal": 587, + "source": "tests/contracts/general.algo.ts:163", + "pc": [ + 816 + ] + }, + { + "teal": 592, + "source": "tests/contracts/general.algo.ts:171", + "pc": [ + 817, + 818, + 819 + ] + }, + { + "teal": 593, + "source": "tests/contracts/general.algo.ts:171", + "pc": [ + 820, + 821 + ] + }, + { + "teal": 594, + "source": "tests/contracts/general.algo.ts:171", + "pc": [ + 822 + ] + }, + { + "teal": 598, + "source": "tests/contracts/general.algo.ts:171", + "pc": [ + 823, + 824, + 825 + ] + }, + { + "teal": 610, + "source": "tests/contracts/general.algo.ts:172", + "pc": [ + 826 + ] + }, + { + "teal": 611, + "source": "tests/contracts/general.algo.ts:172", + "pc": [ + 827, + 828 + ] + }, + { + "teal": 612, + "source": "tests/contracts/general.algo.ts:172", + "pc": [ + 829, + 830 + ] + }, + { + "teal": 616, + "source": "tests/contracts/general.algo.ts:173", + "pc": [ + 831, + 832 + ] + }, + { + "teal": 617, + "source": "tests/contracts/general.algo.ts:173", + "pc": [ + 833, + 834 + ] + }, + { + "teal": 621, + "source": "tests/contracts/general.algo.ts:174", + "pc": [ + 835, + 836, + 837, + 838, + 839, + 840, + 841, + 842, + 843, + 844, + 845, + 846, + 847, + 848, + 849, + 850, + 851, + 852, + 853, + 854, + 855, + 856, + 857, + 858, + 859, + 860, + 861, + 862, + 863, + 864, + 865, + 866, + 867, + 868, + 869, + 870, + 871, + 872, + 873, + 874, + 875, + 876, + 877, + 878, + 879, + 880, + 881, + 882, + 883, + 884, + 885, + 886, + 887, + 888, + 889, + 890 + ] + }, + { + "teal": 622, + "source": "tests/contracts/general.algo.ts:174", + "pc": [ + 891, + 892 + ] + }, + { + "teal": 626, + "source": "tests/contracts/general.algo.ts:175", + "pc": [ + 893, + 894, + 895 + ] + }, + { + "teal": 627, + "source": "tests/contracts/general.algo.ts:175", + "pc": [ + 896, + 897 + ] + }, + { + "teal": 631, + "source": "tests/contracts/general.algo.ts:176", + "pc": [ + 898, + 899 + ] + }, + { + "teal": 632, + "source": "tests/contracts/general.algo.ts:176", + "pc": [ + 900, + 901 + ] + }, + { + "teal": 636, + "source": "tests/contracts/general.algo.ts:177", + "pc": [ + 902, + 903 + ] + }, + { + "teal": 637, + "source": "tests/contracts/general.algo.ts:177", + "pc": [ + 904, + 905 + ] + }, + { + "teal": 641, + "source": "tests/contracts/general.algo.ts:178", + "pc": [ + 906, + 907 + ] + }, + { + "teal": 642, + "source": "tests/contracts/general.algo.ts:178", + "pc": [ + 908, + 909 + ] + }, + { + "teal": 646, + "source": "tests/contracts/general.algo.ts:179", + "pc": [ + 910, + 911 + ] + }, + { + "teal": 647, + "source": "tests/contracts/general.algo.ts:179", + "pc": [ + 912, + 913 + ] + }, + { + "teal": 650, + "source": "tests/contracts/general.algo.ts:172", + "pc": [ + 914, + 915 + ] + }, + { + "teal": 651, + "source": "tests/contracts/general.algo.ts:172", + "pc": [ + 916, + 917 + ] + }, + { + "teal": 654, + "source": "tests/contracts/general.algo.ts:172", + "pc": [ + 918 + ] + }, + { + "teal": 655, + "source": "tests/contracts/general.algo.ts:171", + "pc": [ + 919 + ] + }, + { + "teal": 660, + "source": "tests/contracts/general.algo.ts:183", + "pc": [ + 920, + 921, + 922 + ] + }, + { + "teal": 661, + "source": "tests/contracts/general.algo.ts:183", + "pc": [ + 923, + 924 + ] + }, + { + "teal": 662, + "source": "tests/contracts/general.algo.ts:183", + "pc": [ + 925 + ] + }, + { + "teal": 666, + "source": "tests/contracts/general.algo.ts:183", + "pc": [ + 926, + 927, + 928 + ] + }, + { + "teal": 670, + "source": "tests/contracts/general.algo.ts:186", + "pc": [ + 929, + 930 + ] + }, + { + "teal": 671, + "source": "tests/contracts/general.algo.ts:186", + "pc": [ + 931, + 932, + 933 + ] + }, + { + "teal": 672, + "source": "tests/contracts/general.algo.ts:186", + "pc": [ + 934, + 935, + 936 + ] + }, + { + "teal": 673, + "source": "tests/contracts/general.algo.ts:186", + "pc": [ + 937 + ] + }, + { + "teal": 674, + "source": "tests/contracts/general.algo.ts:186", + "pc": [ + 938 + ] + }, + { + "teal": 675, + "source": "tests/contracts/general.algo.ts:183", + "pc": [ + 939 + ] + }, + { + "teal": 680, + "source": "tests/contracts/general.algo.ts:189", + "pc": [ + 940, + 941, + 942 + ] + }, + { + "teal": 681, + "source": "tests/contracts/general.algo.ts:189", + "pc": [ + 943, + 944 + ] + }, + { + "teal": 682, + "source": "tests/contracts/general.algo.ts:189", + "pc": [ + 945 + ] + }, + { + "teal": 686, + "source": "tests/contracts/general.algo.ts:189", + "pc": [ + 946, + 947, + 948 + ] + }, + { + "teal": 690, + "source": "tests/contracts/general.algo.ts:190", + "pc": [ + 949, + 950 + ] + }, + { + "teal": 691, + "source": "tests/contracts/general.algo.ts:190", + "pc": [ + 951, + 952, + 953 + ] + }, + { + "teal": 692, + "source": "tests/contracts/general.algo.ts:190", + "pc": [ + 954, + 955, + 956 + ] + }, + { + "teal": 693, + "source": "tests/contracts/general.algo.ts:190", + "pc": [ + 957 + ] + }, + { + "teal": 694, + "source": "tests/contracts/general.algo.ts:190", + "pc": [ + 958 + ] + }, + { + "teal": 695, + "source": "tests/contracts/general.algo.ts:189", + "pc": [ + 959 + ] + }, + { + "teal": 700, + "source": "tests/contracts/general.algo.ts:193", + "pc": [ + 960, + 961, + 962 + ] + }, + { + "teal": 701, + "source": "tests/contracts/general.algo.ts:193", + "pc": [ + 963, + 964 + ] + }, + { + "teal": 702, + "source": "tests/contracts/general.algo.ts:193", + "pc": [ + 965 + ] + }, + { + "teal": 706, + "source": "tests/contracts/general.algo.ts:193", + "pc": [ + 966, + 967, + 968 + ] + }, + { + "teal": 710, + "source": "tests/contracts/general.algo.ts:195", + "pc": [ + 969, + 970, + 971, + 972, + 973, + 974, + 975, + 976 + ] + }, + { + "teal": 711, + "source": "tests/contracts/general.algo.ts:195", + "pc": [ + 977, + 978, + 979 + ] + }, + { + "teal": 712, + "source": "tests/contracts/general.algo.ts:195", + "pc": [ + 980, + 981, + 982, + 983 + ] + }, + { + "teal": 713, + "source": "tests/contracts/general.algo.ts:195", + "pc": [ + 984 + ] + }, + { + "teal": 714, + "source": "tests/contracts/general.algo.ts:195", + "pc": [ + 985 + ] + }, + { + "teal": 715, + "source": "tests/contracts/general.algo.ts:193", + "pc": [ + 986 + ] + }, + { + "teal": 720, + "source": "tests/contracts/general.algo.ts:198", + "pc": [ + 987, + 988, + 989 + ] + }, + { + "teal": 721, + "source": "tests/contracts/general.algo.ts:198", + "pc": [ + 990, + 991 + ] + }, + { + "teal": 722, + "source": "tests/contracts/general.algo.ts:198", + "pc": [ + 992 + ] + }, + { + "teal": 726, + "source": "tests/contracts/general.algo.ts:198", + "pc": [ + 993, + 994, + 995 + ] + }, + { + "teal": 729, + "source": "tests/contracts/general.algo.ts:198", + "pc": [ + 996, + 997 + ] + }, + { + "teal": 730, + "source": "tests/contracts/general.algo.ts:198", + "pc": [ + 998 + ] + }, + { + "teal": 734, + "source": "tests/contracts/general.algo.ts:199", + "pc": [ + 999, + 1000 + ] + }, + { + "teal": 735, + "source": "tests/contracts/general.algo.ts:199", + "pc": [ + 1001, + 1002 + ] + }, + { + "teal": 739, + "source": "tests/contracts/general.algo.ts:200", + "pc": [ + 1003, + 1004 + ] + }, + { + "teal": 740, + "source": "tests/contracts/general.algo.ts:200", + "pc": [ + 1005 + ] + }, + { + "teal": 741, + "source": "tests/contracts/general.algo.ts:200", + "pc": [ + 1006 + ] + }, + { + "teal": 742, + "source": "tests/contracts/general.algo.ts:200", + "pc": [ + 1007 + ] + }, + { + "teal": 746, + "source": "tests/contracts/general.algo.ts:202", + "pc": [ + 1008, + 1009 + ] + }, + { + "teal": 747, + "source": "tests/contracts/general.algo.ts:202", + "pc": [ + 1010, + 1011 + ] + }, + { + "teal": 751, + "source": "tests/contracts/general.algo.ts:203", + "pc": [ + 1012, + 1013 + ] + }, + { + "teal": 752, + "source": "tests/contracts/general.algo.ts:203", + "pc": [ + 1014 + ] + }, + { + "teal": 753, + "source": "tests/contracts/general.algo.ts:203", + "pc": [ + 1015 + ] + }, + { + "teal": 754, + "source": "tests/contracts/general.algo.ts:203", + "pc": [ + 1016 + ] + }, + { + "teal": 755, + "source": "tests/contracts/general.algo.ts:198", + "pc": [ + 1017 + ] + }, + { + "teal": 760, + "source": "tests/contracts/general.algo.ts:206", + "pc": [ + 1018, + 1019, + 1020 + ] + }, + { + "teal": 761, + "source": "tests/contracts/general.algo.ts:206", + "pc": [ + 1021, + 1022 + ] + }, + { + "teal": 762, + "source": "tests/contracts/general.algo.ts:206", + "pc": [ + 1023 + ] + }, + { + "teal": 766, + "source": "tests/contracts/general.algo.ts:206", + "pc": [ + 1024, + 1025, + 1026 + ] + }, + { + "teal": 770, + "source": "tests/contracts/general.algo.ts:207", + "pc": [ + 1027, + 1028, + 1029 + ] + }, + { + "teal": 771, + "source": "tests/contracts/general.algo.ts:207", + "pc": [ + 1030, + 1031 + ] + }, + { + "teal": 775, + "source": "tests/contracts/general.algo.ts:208", + "pc": [ + 1032, + 1033 + ] + }, + { + "teal": 776, + "source": "tests/contracts/general.algo.ts:208", + "pc": [ + 1034, + 1035, + 1036 + ] + }, + { + "teal": 777, + "source": "tests/contracts/general.algo.ts:208", + "pc": [ + 1037 + ] + }, + { + "teal": 778, + "source": "tests/contracts/general.algo.ts:208", + "pc": [ + 1038 + ] + }, + { + "teal": 779, + "source": "tests/contracts/general.algo.ts:206", + "pc": [ + 1039 + ] + }, + { + "teal": 784, + "source": "tests/contracts/general.algo.ts:211", + "pc": [ + 1040, + 1041, + 1042 + ] + }, + { + "teal": 785, + "source": "tests/contracts/general.algo.ts:211", + "pc": [ + 1043, + 1044 + ] + }, + { + "teal": 786, + "source": "tests/contracts/general.algo.ts:211", + "pc": [ + 1045 + ] + }, + { + "teal": 790, + "source": "tests/contracts/general.algo.ts:211", + "pc": [ + 1046, + 1047, + 1048 + ] + }, + { + "teal": 793, + "source": "tests/contracts/general.algo.ts:211", + "pc": [ + 1049, + 1050 + ] + }, + { + "teal": 794, + "source": "tests/contracts/general.algo.ts:211", + "pc": [ + 1051, + 1052 + ] + }, + { + "teal": 798, + "source": "tests/contracts/general.algo.ts:212", + "pc": [ + 1053, + 1054, + 1055, + 1056, + 1057, + 1058, + 1059, + 1060, + 1061, + 1062, + 1063, + 1064, + 1065, + 1066, + 1067, + 1068, + 1069, + 1070, + 1071, + 1072, + 1073, + 1074, + 1075, + 1076, + 1077, + 1078, + 1079, + 1080, + 1081, + 1082, + 1083, + 1084, + 1085, + 1086 + ] + }, + { + "teal": 799, + "source": "tests/contracts/general.algo.ts:212", + "pc": [ + 1087, + 1088 + ] + }, + { + "teal": 800, + "source": "tests/contracts/general.algo.ts:212", + "pc": [ + 1089, + 1090 + ] + }, + { + "teal": 804, + "source": "tests/contracts/general.algo.ts:213", + "pc": [ + 1091, + 1092, + 1093, + 1094, + 1095, + 1096, + 1097, + 1098, + 1099, + 1100, + 1101, + 1102, + 1103, + 1104, + 1105, + 1106, + 1107, + 1108, + 1109, + 1110, + 1111, + 1112, + 1113, + 1114, + 1115, + 1116, + 1117, + 1118, + 1119, + 1120, + 1121, + 1122, + 1123, + 1124, + 1125 + ] + }, + { + "teal": 805, + "source": "tests/contracts/general.algo.ts:213", + "pc": [ + 1126, + 1127 + ] + }, + { + "teal": 806, + "source": "tests/contracts/general.algo.ts:213", + "pc": [ + 1128, + 1129 + ] + }, + { + "teal": 807, + "source": "tests/contracts/general.algo.ts:213", + "pc": [ + 1130, + 1131 + ] + }, + { + "teal": 811, + "source": "tests/contracts/general.algo.ts:214", + "pc": [ + 1132, + 1133 + ] + }, + { + "teal": 812, + "source": "tests/contracts/general.algo.ts:214", + "pc": [ + 1134 + ] + }, + { + "teal": 816, + "source": "tests/contracts/general.algo.ts:215", + "pc": [ + 1135, + 1136 + ] + }, + { + "teal": 817, + "source": "tests/contracts/general.algo.ts:215", + "pc": [ + 1137 + ] + }, + { + "teal": 821, + "source": "tests/contracts/general.algo.ts:217", + "pc": [ + 1138, + 1139, + 1140, + 1141, + 1142, + 1143, + 1144, + 1145, + 1146, + 1147, + 1148, + 1149, + 1150, + 1151, + 1152, + 1153, + 1154, + 1155, + 1156, + 1157, + 1158, + 1159, + 1160, + 1161, + 1162, + 1163, + 1164, + 1165, + 1166, + 1167, + 1168, + 1169, + 1170, + 1171 + ] + }, + { + "teal": 822, + "source": "tests/contracts/general.algo.ts:217", + "pc": [ + 1172, + 1173 + ] + }, + { + "teal": 823, + "source": "tests/contracts/general.algo.ts:217", + "pc": [ + 1174, + 1175, + 1176, + 1177, + 1178, + 1179, + 1180, + 1181, + 1182, + 1183, + 1184, + 1185, + 1186, + 1187, + 1188, + 1189, + 1190, + 1191, + 1192, + 1193, + 1194, + 1195, + 1196, + 1197, + 1198, + 1199, + 1200, + 1201, + 1202, + 1203, + 1204, + 1205, + 1206, + 1207 + ] + }, + { + "teal": 824, + "source": "tests/contracts/general.algo.ts:217", + "pc": [ + 1208 + ] + }, + { + "teal": 825, + "source": "tests/contracts/general.algo.ts:217", + "pc": [ + 1209, + 1210 + ] + }, + { + "teal": 826, + "source": "tests/contracts/general.algo.ts:217", + "pc": [ + 1211, + 1212 + ] + }, + { + "teal": 827, + "source": "tests/contracts/general.algo.ts:217", + "pc": [ + 1213, + 1214 + ] + }, + { + "teal": 831, + "source": "tests/contracts/general.algo.ts:218", + "pc": [ + 1215, + 1216 + ] + }, + { + "teal": 832, + "source": "tests/contracts/general.algo.ts:218", + "pc": [ + 1217 + ] + }, + { + "teal": 836, + "source": "tests/contracts/general.algo.ts:219", + "pc": [ + 1218, + 1219 + ] + }, + { + "teal": 837, + "source": "tests/contracts/general.algo.ts:219", + "pc": [ + 1220 + ] + }, + { + "teal": 838, + "source": "tests/contracts/general.algo.ts:211", + "pc": [ + 1221 + ] + }, + { + "teal": 843, + "source": "tests/contracts/general.algo.ts:222", + "pc": [ + 1222, + 1223, + 1224 + ] + }, + { + "teal": 844, + "source": "tests/contracts/general.algo.ts:222", + "pc": [ + 1225, + 1226 + ] + }, + { + "teal": 845, + "source": "tests/contracts/general.algo.ts:222", + "pc": [ + 1227 + ] + }, + { + "teal": 849, + "source": "tests/contracts/general.algo.ts:222", + "pc": [ + 1228, + 1229, + 1230 + ] + }, + { + "teal": 856, + "source": "tests/contracts/general.algo.ts:223", + "pc": [ + 1231, + 1232 + ] + }, + { + "teal": 857, + "source": "tests/contracts/general.algo.ts:223", + "pc": [ + 1233, + 1234 + ] + }, + { + "teal": 858, + "source": "tests/contracts/general.algo.ts:223", + "pc": [ + 1235, + 1236 + ] + }, + { + "teal": 859, + "source": "tests/contracts/general.algo.ts:223", + "pc": [ + 1237 + ] + }, + { + "teal": 862, + "source": "tests/contracts/general.algo.ts:223", + "errorMessage": "transaction verification failed: {\"txn\":\"this.txnGroup[0]\",\"field\":\"typeEnum\",\"expected\":\"pay\"}", + "pc": [ + 1238 + ] + }, + { + "teal": 865, + "source": "tests/contracts/general.algo.ts:223", + "pc": [ + 1239, + 1240 + ] + }, + { + "teal": 866, + "source": "tests/contracts/general.algo.ts:224", + "pc": [ + 1241, + 1242 + ] + }, + { + "teal": 867, + "source": "tests/contracts/general.algo.ts:224", + "pc": [ + 1243, + 1244 + ] + }, + { + "teal": 868, + "source": "tests/contracts/general.algo.ts:224", + "pc": [ + 1245 + ] + }, + { + "teal": 871, + "source": "tests/contracts/general.algo.ts:224", + "errorMessage": "transaction verification failed: {\"txn\":\"this.txnGroup[0]\",\"field\":\"amount\",\"condition\":\"greaterThan\",\"expected\":\">0\"}", + "pc": [ + 1246 + ] + }, + { + "teal": 884, + "source": "tests/contracts/general.algo.ts:227", + "pc": [ + 1247, + 1248 + ] + }, + { + "teal": 885, + "source": "tests/contracts/general.algo.ts:227", + "pc": [ + 1249, + 1250 + ] + }, + { + "teal": 886, + "source": "tests/contracts/general.algo.ts:227", + "pc": [ + 1251, + 1252 + ] + }, + { + "teal": 887, + "source": "tests/contracts/general.algo.ts:227", + "pc": [ + 1253 + ] + }, + { + "teal": 890, + "source": "tests/contracts/general.algo.ts:227", + "errorMessage": "transaction verification failed: {\"txn\":\"this.txnGroup[0]\",\"field\":\"typeEnum\",\"expected\":\"appl\"}", + "pc": [ + 1254 + ] + }, + { + "teal": 893, + "source": "tests/contracts/general.algo.ts:227", + "pc": [ + 1255, + 1256 + ] + }, + { + "teal": 894, + "source": "tests/contracts/general.algo.ts:228", + "pc": [ + 1257, + 1258 + ] + }, + { + "teal": 895, + "source": "tests/contracts/general.algo.ts:228", + "pc": [ + 1259, + 1260 + ] + }, + { + "teal": 896, + "source": "tests/contracts/general.algo.ts:228", + "pc": [ + 1261 + ] + }, + { + "teal": 899, + "source": "tests/contracts/general.algo.ts:228", + "errorMessage": "transaction verification failed: {\"txn\":\"this.txnGroup[0]\",\"field\":\"applicationID\",\"expected\":\"AppID.fromUint64(0)\"}", + "pc": [ + 1262 + ] + }, + { + "teal": 903, + "source": "tests/contracts/general.algo.ts:227", + "pc": [ + 1263, + 1264 + ] + }, + { + "teal": 904, + "source": "tests/contracts/general.algo.ts:230", + "pc": [ + 1265, + 1266, + 1267 + ] + }, + { + "teal": 905, + "source": "tests/contracts/general.algo.ts:230", + "pc": [ + 1268, + 1269, + 1270, + 1271, + 1272 + ] + }, + { + "teal": 906, + "source": "tests/contracts/general.algo.ts:230", + "pc": [ + 1273 + ] + }, + { + "teal": 909, + "source": "tests/contracts/general.algo.ts:230", + "errorMessage": "transaction verification failed: {\"txn\":\"this.txnGroup[0]\",\"field\":\"applicationArgs\",\"index\":\"0\",\"expected\":\"'foo'\"}", + "pc": [ + 1274 + ] + }, + { + "teal": 912, + "source": "tests/contracts/general.algo.ts:227", + "pc": [ + 1275, + 1276 + ] + }, + { + "teal": 913, + "source": "tests/contracts/general.algo.ts:229", + "pc": [ + 1277, + 1278, + 1279 + ] + }, + { + "teal": 914, + "source": "tests/contracts/general.algo.ts:232", + "pc": [ + 1280, + 1281, + 1282, + 1283, + 1284 + ] + }, + { + "teal": 915, + "source": "tests/contracts/general.algo.ts:232", + "pc": [ + 1285 + ] + }, + { + "teal": 916, + "source": "tests/contracts/general.algo.ts:227", + "pc": [ + 1286, + 1287 + ] + }, + { + "teal": 917, + "source": "tests/contracts/general.algo.ts:229", + "pc": [ + 1288, + 1289, + 1290 + ] + }, + { + "teal": 918, + "source": "tests/contracts/general.algo.ts:232", + "pc": [ + 1291, + 1292, + 1293, + 1294, + 1295 + ] + }, + { + "teal": 919, + "source": "tests/contracts/general.algo.ts:232", + "pc": [ + 1296 + ] + }, + { + "teal": 920, + "source": "tests/contracts/general.algo.ts:232", + "pc": [ + 1297 + ] + }, + { + "teal": 923, + "source": "tests/contracts/general.algo.ts:232", + "errorMessage": "transaction verification failed: {\"txn\":{\"txnText\":\"this.txnGroup[0]\"},\"field\":\"applicationArgs 1\",\"condition\":\"includedIn\",\"expected\":\"['bar', 'baz']\"}", + "pc": [ + 1298 + ] + }, + { + "teal": 930, + "source": "tests/contracts/general.algo.ts:237", + "pc": [ + 1299, + 1300 + ] + }, + { + "teal": 931, + "source": "tests/contracts/general.algo.ts:237", + "pc": [ + 1301, + 1302 + ] + }, + { + "teal": 932, + "source": "tests/contracts/general.algo.ts:237", + "pc": [ + 1303, + 1304 + ] + }, + { + "teal": 933, + "source": "tests/contracts/general.algo.ts:237", + "pc": [ + 1305 + ] + }, + { + "teal": 936, + "source": "tests/contracts/general.algo.ts:237", + "errorMessage": "transaction verification failed: {\"txn\":\"this.txnGroup[0]\",\"field\":\"typeEnum\",\"expected\":\"axfer\"}", + "pc": [ + 1306 + ] + }, + { + "teal": 939, + "source": "tests/contracts/general.algo.ts:237", + "pc": [ + 1307, + 1308 + ] + }, + { + "teal": 940, + "source": "tests/contracts/general.algo.ts:238", + "pc": [ + 1309, + 1310 + ] + }, + { + "teal": 941, + "source": "tests/contracts/general.algo.ts:238", + "pc": [ + 1311, + 1312 + ] + }, + { + "teal": 942, + "source": "tests/contracts/general.algo.ts:238", + "pc": [ + 1313 + ] + }, + { + "teal": 945, + "source": "tests/contracts/general.algo.ts:238", + "errorMessage": "transaction verification failed: {\"txn\":\"this.txnGroup[0]\",\"field\":\"assetReceiver\",\"expected\":\"this.app.address\"}", + "pc": [ + 1314 + ] + }, + { + "teal": 952, + "source": "tests/contracts/general.algo.ts:241", + "pc": [ + 1315, + 1316 + ] + }, + { + "teal": 953, + "source": "tests/contracts/general.algo.ts:241", + "pc": [ + 1317, + 1318 + ] + }, + { + "teal": 954, + "source": "tests/contracts/general.algo.ts:241", + "pc": [ + 1319, + 1320 + ] + }, + { + "teal": 955, + "source": "tests/contracts/general.algo.ts:241", + "pc": [ + 1321 + ] + }, + { + "teal": 958, + "source": "tests/contracts/general.algo.ts:241", + "errorMessage": "transaction verification failed: {\"txn\":\"this.txnGroup[0]\",\"field\":\"typeEnum\",\"expected\":\"acfg\"}", + "pc": [ + 1322 + ] + }, + { + "teal": 961, + "source": "tests/contracts/general.algo.ts:241", + "pc": [ + 1323, + 1324 + ] + }, + { + "teal": 962, + "source": "tests/contracts/general.algo.ts:242", + "pc": [ + 1325, + 1326 + ] + }, + { + "teal": 963, + "source": "tests/contracts/general.algo.ts:242", + "pc": [ + 1327, + 1328 + ] + }, + { + "teal": 964, + "source": "tests/contracts/general.algo.ts:242", + "pc": [ + 1329 + ] + }, + { + "teal": 967, + "source": "tests/contracts/general.algo.ts:242", + "errorMessage": "transaction verification failed: {\"txn\":\"this.txnGroup[0]\",\"field\":\"configAsset\",\"expected\":\"AssetID.fromUint64(0)\"}", + "pc": [ + 1330 + ] + }, + { + "teal": 974, + "source": "tests/contracts/general.algo.ts:245", + "pc": [ + 1331, + 1332 + ] + }, + { + "teal": 975, + "source": "tests/contracts/general.algo.ts:245", + "pc": [ + 1333, + 1334 + ] + }, + { + "teal": 976, + "source": "tests/contracts/general.algo.ts:245", + "pc": [ + 1335, + 1336 + ] + }, + { + "teal": 977, + "source": "tests/contracts/general.algo.ts:245", + "pc": [ + 1337 + ] + }, + { + "teal": 980, + "source": "tests/contracts/general.algo.ts:245", + "errorMessage": "transaction verification failed: {\"txn\":\"this.txnGroup[0]\",\"field\":\"typeEnum\",\"expected\":\"keyreg\"}", + "pc": [ + 1338 + ] + }, + { + "teal": 983, + "source": "tests/contracts/general.algo.ts:245", + "pc": [ + 1339, + 1340 + ] + }, + { + "teal": 984, + "source": "tests/contracts/general.algo.ts:246", + "pc": [ + 1341, + 1342 + ] + }, + { + "teal": 985, + "source": "tests/contracts/general.algo.ts:246", + "pc": [ + 1343, + 1344, + 1345 + ] + }, + { + "teal": 986, + "source": "tests/contracts/general.algo.ts:246", + "pc": [ + 1346 + ] + }, + { + "teal": 989, + "source": "tests/contracts/general.algo.ts:246", + "errorMessage": "transaction verification failed: {\"txn\":\"this.txnGroup[0]\",\"field\":\"voteFirst\",\"expected\":\"1337\"}", + "pc": [ + 1347 + ] + }, + { + "teal": 990, + "source": "tests/contracts/general.algo.ts:222", + "pc": [ + 1348 + ] + }, + { + "teal": 995, + "source": "tests/contracts/general.algo.ts:250", + "pc": [ + 1349, + 1350, + 1351 + ] + }, + { + "teal": 996, + "source": "tests/contracts/general.algo.ts:250", + "pc": [ + 1352, + 1353 + ] + }, + { + "teal": 997, + "source": "tests/contracts/general.algo.ts:250", + "pc": [ + 1354 + ] + }, + { + "teal": 1001, + "source": "tests/contracts/general.algo.ts:250", + "pc": [ + 1355, + 1356, + 1357 + ] + }, + { + "teal": 1004, + "source": "tests/contracts/general.algo.ts:250", + "pc": [ + 1358, + 1359 + ] + }, + { + "teal": 1008, + "source": "tests/contracts/general.algo.ts:251", + "pc": [ + 1360, + 1361, + 1362, + 1363, + 1364 + ] + }, + { + "teal": 1009, + "source": "tests/contracts/general.algo.ts:251", + "pc": [ + 1365, + 1366 + ] + }, + { + "teal": 1013, + "source": "tests/contracts/general.algo.ts:252", + "pc": [ + 1367, + 1368 + ] + }, + { + "teal": 1014, + "source": "tests/contracts/general.algo.ts:252", + "pc": [ + 1369, + 1370, + 1371, + 1372, + 1373 + ] + }, + { + "teal": 1015, + "source": "tests/contracts/general.algo.ts:252", + "pc": [ + 1374 + ] + }, + { + "teal": 1016, + "source": "tests/contracts/general.algo.ts:252", + "pc": [ + 1375, + 1376 + ] + }, + { + "teal": 1020, + "source": "tests/contracts/general.algo.ts:253", + "pc": [ + 1377, + 1378 + ] + }, + { + "teal": 1021, + "source": "tests/contracts/general.algo.ts:253", + "pc": [ + 1379, + 1380, + 1381, + 1382, + 1383, + 1384, + 1385, + 1386 + ] + }, + { + "teal": 1022, + "source": "tests/contracts/general.algo.ts:253", + "pc": [ + 1387 + ] + }, + { + "teal": 1023, + "source": "tests/contracts/general.algo.ts:253", + "pc": [ + 1388 + ] + }, + { + "teal": 1024, + "source": "tests/contracts/general.algo.ts:250", + "pc": [ + 1389 + ] + }, + { + "teal": 1029, + "source": "tests/contracts/general.algo.ts:256", + "pc": [ + 1390, + 1391, + 1392, + 1393, + 1394, + 1395 + ] + }, + { + "teal": 1032, + "source": "tests/contracts/general.algo.ts:256", + "pc": [ + 1396, + 1397, + 1398 + ] + }, + { + "teal": 1033, + "source": "tests/contracts/general.algo.ts:256", + "pc": [ + 1399 + ] + }, + { + "teal": 1034, + "source": "tests/contracts/general.algo.ts:256", + "pc": [ + 1400 + ] + }, + { + "teal": 1035, + "source": "tests/contracts/general.algo.ts:256", + "pc": [ + 1401 + ] + }, + { + "teal": 1036, + "source": "tests/contracts/general.algo.ts:256", + "pc": [ + 1402, + 1403, + 1404 + ] + }, + { + "teal": 1037, + "source": "tests/contracts/general.algo.ts:256", + "pc": [ + 1405 + ] + }, + { + "teal": 1038, + "source": "tests/contracts/general.algo.ts:256", + "pc": [ + 1406 + ] + }, + { + "teal": 1039, + "source": "tests/contracts/general.algo.ts:256", + "pc": [ + 1407 + ] + }, + { + "teal": 1040, + "source": "tests/contracts/general.algo.ts:256", + "pc": [ + 1408 + ] + }, + { + "teal": 1041, + "source": "tests/contracts/general.algo.ts:256", + "pc": [ + 1409, + 1410 + ] + }, + { + "teal": 1042, + "source": "tests/contracts/general.algo.ts:256", + "pc": [ + 1411 + ] + }, + { + "teal": 1046, + "source": "tests/contracts/general.algo.ts:256", + "pc": [ + 1412, + 1413, + 1414 + ] + }, + { + "teal": 1050, + "source": "tests/contracts/general.algo.ts:257", + "pc": [ + 1415, + 1416, + 1417, + 1418, + 1419, + 1420, + 1421, + 1422, + 1423, + 1424, + 1425, + 1426, + 1427, + 1428, + 1429, + 1430, + 1431, + 1432, + 1433, + 1434, + 1435, + 1436, + 1437, + 1438, + 1439, + 1440, + 1441, + 1442, + 1443, + 1444, + 1445, + 1446, + 1447, + 1448, + 1449, + 1450, + 1451, + 1452, + 1453, + 1454, + 1455, + 1456, + 1457, + 1458, + 1459, + 1460, + 1461, + 1462, + 1463, + 1464, + 1465, + 1466, + 1467, + 1468, + 1469, + 1470, + 1471, + 1472, + 1473, + 1474, + 1475, + 1476, + 1477, + 1478, + 1479, + 1480, + 1481, + 1482, + 1483, + 1484, + 1485, + 1486, + 1487, + 1488, + 1489, + 1490, + 1491, + 1492, + 1493, + 1494, + 1495, + 1496, + 1497, + 1498, + 1499, + 1500, + 1501, + 1502, + 1503, + 1504, + 1505, + 1506, + 1507, + 1508, + 1509, + 1510, + 1511, + 1512, + 1513, + 1514, + 1515, + 1516, + 1517, + 1518, + 1519, + 1520, + 1521, + 1522, + 1523, + 1524, + 1525, + 1526, + 1527, + 1528, + 1529, + 1530, + 1531, + 1532, + 1533, + 1534, + 1535, + 1536, + 1537, + 1538, + 1539, + 1540, + 1541, + 1542, + 1543, + 1544, + 1545, + 1546, + 1547, + 1548, + 1549, + 1550, + 1551, + 1552, + 1553, + 1554, + 1555, + 1556, + 1557, + 1558, + 1559, + 1560, + 1561, + 1562, + 1563, + 1564, + 1565, + 1566, + 1567, + 1568, + 1569, + 1570, + 1571, + 1572, + 1573, + 1574, + 1575, + 1576, + 1577, + 1578, + 1579, + 1580, + 1581, + 1582, + 1583, + 1584, + 1585, + 1586, + 1587, + 1588, + 1589, + 1590, + 1591, + 1592, + 1593, + 1594, + 1595, + 1596, + 1597, + 1598, + 1599, + 1600, + 1601, + 1602, + 1603, + 1604, + 1605, + 1606, + 1607, + 1608, + 1609, + 1610, + 1611, + 1612, + 1613, + 1614, + 1615, + 1616, + 1617, + 1618, + 1619, + 1620, + 1621, + 1622, + 1623, + 1624, + 1625, + 1626, + 1627, + 1628, + 1629, + 1630, + 1631, + 1632, + 1633, + 1634, + 1635, + 1636, + 1637, + 1638, + 1639, + 1640, + 1641, + 1642, + 1643, + 1644, + 1645, + 1646, + 1647, + 1648, + 1649, + 1650, + 1651, + 1652, + 1653, + 1654, + 1655, + 1656, + 1657, + 1658, + 1659, + 1660, + 1661, + 1662, + 1663, + 1664, + 1665, + 1666, + 1667, + 1668, + 1669, + 1670, + 1671, + 1672, + 1673, + 1674, + 1675, + 1676, + 1677, + 1678, + 1679, + 1680, + 1681, + 1682, + 1683, + 1684, + 1685, + 1686, + 1687, + 1688, + 1689, + 1690, + 1691, + 1692, + 1693, + 1694, + 1695, + 1696, + 1697, + 1698, + 1699, + 1700, + 1701, + 1702, + 1703, + 1704, + 1705, + 1706, + 1707, + 1708, + 1709, + 1710, + 1711, + 1712, + 1713, + 1714, + 1715, + 1716, + 1717, + 1718, + 1719, + 1720, + 1721, + 1722, + 1723, + 1724, + 1725, + 1726, + 1727, + 1728, + 1729, + 1730, + 1731, + 1732, + 1733, + 1734, + 1735, + 1736, + 1737, + 1738, + 1739, + 1740, + 1741, + 1742, + 1743, + 1744, + 1745, + 1746, + 1747, + 1748, + 1749, + 1750, + 1751, + 1752, + 1753, + 1754, + 1755, + 1756, + 1757, + 1758, + 1759, + 1760, + 1761, + 1762, + 1763, + 1764, + 1765, + 1766, + 1767, + 1768, + 1769, + 1770, + 1771, + 1772, + 1773, + 1774, + 1775, + 1776, + 1777, + 1778, + 1779, + 1780, + 1781, + 1782, + 1783, + 1784, + 1785, + 1786, + 1787, + 1788, + 1789, + 1790, + 1791, + 1792, + 1793, + 1794, + 1795, + 1796, + 1797, + 1798, + 1799, + 1800, + 1801, + 1802, + 1803, + 1804, + 1805, + 1806, + 1807, + 1808, + 1809, + 1810, + 1811, + 1812, + 1813, + 1814, + 1815, + 1816, + 1817, + 1818, + 1819, + 1820, + 1821, + 1822, + 1823, + 1824, + 1825, + 1826, + 1827, + 1828, + 1829, + 1830, + 1831, + 1832, + 1833, + 1834, + 1835, + 1836, + 1837, + 1838, + 1839, + 1840, + 1841, + 1842, + 1843, + 1844, + 1845, + 1846, + 1847, + 1848, + 1849, + 1850, + 1851, + 1852, + 1853, + 1854, + 1855, + 1856, + 1857, + 1858, + 1859, + 1860, + 1861, + 1862, + 1863, + 1864, + 1865, + 1866, + 1867, + 1868, + 1869, + 1870, + 1871, + 1872, + 1873, + 1874, + 1875, + 1876, + 1877, + 1878, + 1879, + 1880, + 1881, + 1882, + 1883, + 1884, + 1885, + 1886, + 1887, + 1888, + 1889, + 1890, + 1891, + 1892, + 1893, + 1894, + 1895, + 1896, + 1897, + 1898, + 1899, + 1900, + 1901, + 1902, + 1903, + 1904, + 1905, + 1906, + 1907, + 1908, + 1909, + 1910, + 1911, + 1912, + 1913, + 1914, + 1915, + 1916, + 1917, + 1918, + 1919, + 1920, + 1921, + 1922, + 1923, + 1924, + 1925, + 1926, + 1927, + 1928, + 1929, + 1930, + 1931, + 1932, + 1933, + 1934, + 1935, + 1936, + 1937, + 1938, + 1939, + 1940, + 1941, + 1942, + 1943, + 1944, + 1945, + 1946, + 1947, + 1948, + 1949, + 1950, + 1951, + 1952, + 1953, + 1954, + 1955, + 1956, + 1957, + 1958, + 1959, + 1960, + 1961, + 1962, + 1963, + 1964, + 1965, + 1966, + 1967, + 1968, + 1969, + 1970, + 1971, + 1972, + 1973, + 1974, + 1975, + 1976, + 1977, + 1978, + 1979, + 1980, + 1981, + 1982, + 1983, + 1984, + 1985, + 1986, + 1987, + 1988, + 1989, + 1990, + 1991, + 1992, + 1993, + 1994, + 1995, + 1996, + 1997, + 1998, + 1999, + 2000, + 2001, + 2002, + 2003, + 2004, + 2005, + 2006, + 2007, + 2008, + 2009, + 2010, + 2011, + 2012, + 2013, + 2014, + 2015, + 2016, + 2017, + 2018, + 2019, + 2020, + 2021, + 2022, + 2023, + 2024, + 2025, + 2026, + 2027, + 2028, + 2029, + 2030, + 2031, + 2032, + 2033, + 2034, + 2035, + 2036, + 2037, + 2038, + 2039, + 2040, + 2041, + 2042, + 2043, + 2044, + 2045, + 2046, + 2047, + 2048, + 2049, + 2050, + 2051, + 2052, + 2053, + 2054, + 2055, + 2056, + 2057, + 2058, + 2059, + 2060, + 2061, + 2062, + 2063, + 2064, + 2065, + 2066, + 2067, + 2068, + 2069, + 2070, + 2071, + 2072, + 2073, + 2074, + 2075, + 2076, + 2077, + 2078, + 2079, + 2080, + 2081, + 2082, + 2083, + 2084, + 2085, + 2086, + 2087, + 2088, + 2089, + 2090, + 2091, + 2092, + 2093, + 2094, + 2095, + 2096, + 2097, + 2098, + 2099, + 2100, + 2101, + 2102, + 2103, + 2104, + 2105, + 2106, + 2107, + 2108, + 2109, + 2110, + 2111, + 2112, + 2113, + 2114, + 2115, + 2116, + 2117, + 2118, + 2119, + 2120, + 2121, + 2122, + 2123, + 2124, + 2125, + 2126, + 2127, + 2128, + 2129, + 2130, + 2131, + 2132, + 2133, + 2134, + 2135, + 2136, + 2137, + 2138, + 2139, + 2140, + 2141, + 2142, + 2143, + 2144, + 2145, + 2146, + 2147, + 2148, + 2149, + 2150, + 2151, + 2152, + 2153, + 2154, + 2155, + 2156, + 2157, + 2158, + 2159, + 2160, + 2161, + 2162, + 2163, + 2164, + 2165, + 2166, + 2167, + 2168, + 2169, + 2170, + 2171, + 2172, + 2173, + 2174, + 2175, + 2176, + 2177, + 2178, + 2179, + 2180, + 2181, + 2182, + 2183, + 2184, + 2185, + 2186, + 2187, + 2188, + 2189, + 2190, + 2191, + 2192, + 2193, + 2194, + 2195, + 2196, + 2197, + 2198, + 2199, + 2200, + 2201, + 2202, + 2203, + 2204, + 2205, + 2206, + 2207, + 2208, + 2209, + 2210, + 2211, + 2212, + 2213, + 2214, + 2215, + 2216, + 2217, + 2218, + 2219, + 2220, + 2221, + 2222, + 2223, + 2224, + 2225, + 2226, + 2227, + 2228, + 2229, + 2230, + 2231, + 2232, + 2233, + 2234, + 2235, + 2236, + 2237, + 2238, + 2239, + 2240, + 2241, + 2242, + 2243, + 2244, + 2245, + 2246, + 2247, + 2248, + 2249, + 2250, + 2251, + 2252, + 2253, + 2254, + 2255, + 2256, + 2257, + 2258, + 2259, + 2260, + 2261, + 2262, + 2263, + 2264, + 2265, + 2266, + 2267, + 2268, + 2269, + 2270, + 2271, + 2272, + 2273, + 2274, + 2275, + 2276, + 2277, + 2278, + 2279, + 2280, + 2281, + 2282, + 2283, + 2284, + 2285, + 2286, + 2287, + 2288, + 2289, + 2290, + 2291, + 2292, + 2293, + 2294, + 2295, + 2296, + 2297, + 2298, + 2299, + 2300, + 2301, + 2302, + 2303, + 2304, + 2305, + 2306, + 2307, + 2308, + 2309, + 2310, + 2311, + 2312, + 2313, + 2314, + 2315, + 2316, + 2317, + 2318, + 2319, + 2320, + 2321, + 2322, + 2323, + 2324, + 2325, + 2326, + 2327, + 2328, + 2329, + 2330, + 2331, + 2332, + 2333, + 2334, + 2335, + 2336, + 2337, + 2338, + 2339, + 2340, + 2341, + 2342, + 2343, + 2344, + 2345, + 2346, + 2347, + 2348, + 2349, + 2350, + 2351, + 2352, + 2353, + 2354, + 2355, + 2356, + 2357, + 2358, + 2359, + 2360, + 2361, + 2362, + 2363, + 2364, + 2365, + 2366, + 2367, + 2368, + 2369, + 2370, + 2371, + 2372, + 2373, + 2374, + 2375, + 2376, + 2377, + 2378, + 2379, + 2380, + 2381, + 2382, + 2383, + 2384, + 2385, + 2386, + 2387, + 2388, + 2389, + 2390, + 2391, + 2392, + 2393, + 2394, + 2395, + 2396, + 2397, + 2398, + 2399, + 2400, + 2401, + 2402, + 2403, + 2404, + 2405, + 2406, + 2407, + 2408, + 2409, + 2410, + 2411, + 2412, + 2413, + 2414, + 2415, + 2416, + 2417, + 2418, + 2419, + 2420, + 2421, + 2422, + 2423, + 2424, + 2425, + 2426, + 2427, + 2428, + 2429, + 2430, + 2431, + 2432, + 2433, + 2434, + 2435, + 2436, + 2437, + 2438, + 2439, + 2440, + 2441, + 2442, + 2443, + 2444, + 2445, + 2446, + 2447, + 2448, + 2449, + 2450, + 2451, + 2452, + 2453, + 2454, + 2455, + 2456, + 2457, + 2458, + 2459, + 2460, + 2461, + 2462, + 2463, + 2464, + 2465, + 2466, + 2467, + 2468, + 2469, + 2470, + 2471, + 2472, + 2473, + 2474, + 2475, + 2476, + 2477, + 2478, + 2479, + 2480, + 2481, + 2482, + 2483, + 2484, + 2485, + 2486, + 2487, + 2488, + 2489, + 2490, + 2491, + 2492, + 2493, + 2494, + 2495, + 2496, + 2497, + 2498, + 2499, + 2500, + 2501, + 2502, + 2503, + 2504, + 2505, + 2506, + 2507, + 2508, + 2509, + 2510, + 2511, + 2512, + 2513, + 2514, + 2515, + 2516, + 2517, + 2518, + 2519, + 2520, + 2521, + 2522, + 2523, + 2524, + 2525, + 2526, + 2527, + 2528, + 2529, + 2530, + 2531, + 2532, + 2533, + 2534, + 2535, + 2536, + 2537, + 2538, + 2539, + 2540, + 2541, + 2542, + 2543, + 2544, + 2545, + 2546, + 2547, + 2548, + 2549, + 2550, + 2551, + 2552, + 2553, + 2554, + 2555, + 2556, + 2557, + 2558, + 2559, + 2560, + 2561, + 2562, + 2563, + 2564, + 2565, + 2566, + 2567, + 2568, + 2569, + 2570, + 2571, + 2572, + 2573, + 2574, + 2575, + 2576, + 2577, + 2578, + 2579, + 2580, + 2581, + 2582, + 2583, + 2584, + 2585, + 2586, + 2587, + 2588, + 2589, + 2590, + 2591, + 2592, + 2593, + 2594, + 2595, + 2596, + 2597, + 2598, + 2599, + 2600, + 2601, + 2602, + 2603, + 2604, + 2605, + 2606, + 2607, + 2608, + 2609, + 2610, + 2611, + 2612, + 2613, + 2614, + 2615, + 2616, + 2617, + 2618, + 2619, + 2620, + 2621, + 2622, + 2623, + 2624, + 2625, + 2626, + 2627, + 2628, + 2629, + 2630, + 2631, + 2632, + 2633, + 2634, + 2635, + 2636, + 2637, + 2638, + 2639, + 2640, + 2641, + 2642, + 2643, + 2644, + 2645, + 2646, + 2647, + 2648, + 2649, + 2650, + 2651, + 2652, + 2653, + 2654, + 2655, + 2656, + 2657, + 2658, + 2659, + 2660, + 2661, + 2662, + 2663, + 2664, + 2665, + 2666, + 2667, + 2668, + 2669, + 2670, + 2671, + 2672, + 2673, + 2674, + 2675, + 2676, + 2677, + 2678, + 2679, + 2680, + 2681, + 2682, + 2683, + 2684 + ] + }, + { + "teal": 1051, + "source": "tests/contracts/general.algo.ts:256", + "pc": [ + 2685 + ] + }, + { + "teal": 1056, + "source": "tests/contracts/general.algo.ts:260", + "pc": [ + 2686, + 2687, + 2688 + ] + }, + { + "teal": 1057, + "source": "tests/contracts/general.algo.ts:260", + "pc": [ + 2689, + 2690 + ] + }, + { + "teal": 1058, + "source": "tests/contracts/general.algo.ts:260", + "pc": [ + 2691 + ] + }, + { + "teal": 1062, + "source": "tests/contracts/general.algo.ts:260", + "pc": [ + 2692, + 2693, + 2694 + ] + }, + { + "teal": 1066, + "source": "tests/contracts/general.algo.ts:261", + "pc": [ + 2695, + 2696, + 2697, + 2698, + 2699, + 2700, + 2701 + ] + }, + { + "teal": 1067, + "source": "tests/contracts/general.algo.ts:261", + "pc": [ + 2702, + 2703, + 2704 + ] + }, + { + "teal": 1068, + "source": "tests/contracts/general.algo.ts:261", + "pc": [ + 2705 + ] + }, + { + "teal": 1069, + "source": "tests/contracts/general.algo.ts:260", + "pc": [ + 2706 + ] + }, + { + "teal": 1073, + "source": "tests/contracts/general.algo.ts:264", + "pc": [ + 2707, + 2708, + 2709 + ] + }, + { + "teal": 1077, + "source": "tests/contracts/general.algo.ts:265", + "pc": [ + 2710, + 2711 + ] + }, + { + "teal": 1078, + "source": "tests/contracts/general.algo.ts:264", + "pc": [ + 2712 + ] + }, + { + "teal": 1083, + "source": "tests/contracts/general.algo.ts:268", + "pc": [ + 2713, + 2714, + 2715, + 2716, + 2717, + 2718 + ] + }, + { + "teal": 1086, + "source": "tests/contracts/general.algo.ts:268", + "pc": [ + 2719, + 2720, + 2721 + ] + }, + { + "teal": 1087, + "source": "tests/contracts/general.algo.ts:268", + "pc": [ + 2722 + ] + }, + { + "teal": 1090, + "source": "tests/contracts/general.algo.ts:268", + "pc": [ + 2723, + 2724, + 2725 + ] + }, + { + "teal": 1091, + "source": "tests/contracts/general.algo.ts:268", + "pc": [ + 2726 + ] + }, + { + "teal": 1094, + "source": "tests/contracts/general.algo.ts:268", + "pc": [ + 2727, + 2728, + 2729 + ] + }, + { + "teal": 1095, + "source": "tests/contracts/general.algo.ts:268", + "pc": [ + 2730 + ] + }, + { + "teal": 1096, + "source": "tests/contracts/general.algo.ts:268", + "pc": [ + 2731 + ] + }, + { + "teal": 1097, + "source": "tests/contracts/general.algo.ts:268", + "pc": [ + 2732 + ] + }, + { + "teal": 1098, + "source": "tests/contracts/general.algo.ts:268", + "pc": [ + 2733, + 2734 + ] + }, + { + "teal": 1099, + "source": "tests/contracts/general.algo.ts:268", + "pc": [ + 2735 + ] + }, + { + "teal": 1103, + "source": "tests/contracts/general.algo.ts:268", + "pc": [ + 2736, + 2737, + 2738 + ] + }, + { + "teal": 1107, + "source": "tests/contracts/general.algo.ts:269", + "pc": [ + 2739, + 2740 + ] + }, + { + "teal": 1108, + "source": "tests/contracts/general.algo.ts:269", + "pc": [ + 2741, + 2742 + ] + }, + { + "teal": 1109, + "source": "tests/contracts/general.algo.ts:269", + "pc": [ + 2743 + ] + }, + { + "teal": 1110, + "source": "tests/contracts/general.algo.ts:268", + "pc": [ + 2744 + ] + }, + { + "teal": 1115, + "source": "tests/contracts/general.algo.ts:272", + "pc": [ + 2745, + 2746, + 2747 + ] + }, + { + "teal": 1116, + "source": "tests/contracts/general.algo.ts:272", + "pc": [ + 2748, + 2749 + ] + }, + { + "teal": 1117, + "source": "tests/contracts/general.algo.ts:272", + "pc": [ + 2750 + ] + }, + { + "teal": 1121, + "source": "tests/contracts/general.algo.ts:272", + "pc": [ + 2751, + 2752, + 2753 + ] + }, + { + "teal": 1125, + "source": "tests/contracts/general.algo.ts:273", + "pc": [ + 2754, + 2755 + ] + }, + { + "teal": 1126, + "source": "tests/contracts/general.algo.ts:273", + "pc": [ + 2756, + 2757 + ] + }, + { + "teal": 1127, + "source": "tests/contracts/general.algo.ts:273", + "pc": [ + 2758, + 2759, + 2760 + ] + }, + { + "teal": 1128, + "source": "tests/contracts/general.algo.ts:273", + "pc": [ + 2761, + 2762 + ] + }, + { + "teal": 1129, + "source": "tests/contracts/general.algo.ts:273", + "pc": [ + 2763 + ] + }, + { + "teal": 1130, + "source": "tests/contracts/general.algo.ts:273", + "pc": [ + 2764 + ] + }, + { + "teal": 1131, + "source": "tests/contracts/general.algo.ts:272", + "pc": [ + 2765 + ] + }, + { + "teal": 1136, + "source": "tests/contracts/general.algo.ts:276", + "pc": [ + 2766, + 2767, + 2768 + ] + }, + { + "teal": 1137, + "source": "tests/contracts/general.algo.ts:276", + "pc": [ + 2769, + 2770 + ] + }, + { + "teal": 1138, + "source": "tests/contracts/general.algo.ts:276", + "pc": [ + 2771 + ] + }, + { + "teal": 1142, + "source": "tests/contracts/general.algo.ts:276", + "pc": [ + 2772, + 2773, + 2774 + ] + }, + { + "teal": 1146, + "source": "tests/contracts/general.algo.ts:277", + "pc": [ + 2775, + 2776, + 2777 + ] + }, + { + "teal": 1147, + "source": "tests/contracts/general.algo.ts:277", + "pc": [ + 2778 + ] + }, + { + "teal": 1148, + "source": "tests/contracts/general.algo.ts:276", + "pc": [ + 2779 + ] + }, + { + "teal": 1153, + "source": "tests/contracts/general.algo.ts:280", + "pc": [ + 2780, + 2781, + 2782, + 2783, + 2784, + 2785 + ] + }, + { + "teal": 1156, + "source": "tests/contracts/general.algo.ts:280", + "pc": [ + 2786, + 2787, + 2788 + ] + }, + { + "teal": 1157, + "source": "tests/contracts/general.algo.ts:280", + "pc": [ + 2789 + ] + }, + { + "teal": 1158, + "source": "tests/contracts/general.algo.ts:280", + "pc": [ + 2790 + ] + }, + { + "teal": 1159, + "source": "tests/contracts/general.algo.ts:280", + "pc": [ + 2791, + 2792, + 2793 + ] + }, + { + "teal": 1160, + "source": "tests/contracts/general.algo.ts:280", + "pc": [ + 2794 + ] + }, + { + "teal": 1163, + "source": "tests/contracts/general.algo.ts:280", + "errorMessage": "uintNWithUnderscore return value overflowed 256 bits", + "pc": [ + 2795 + ] + }, + { + "teal": 1164, + "source": "tests/contracts/general.algo.ts:280", + "pc": [ + 2796, + 2797, + 2798, + 2799, + 2800, + 2801, + 2802, + 2803, + 2804, + 2805, + 2806, + 2807, + 2808, + 2809, + 2810, + 2811, + 2812, + 2813, + 2814, + 2815, + 2816, + 2817, + 2818, + 2819, + 2820, + 2821, + 2822, + 2823, + 2824, + 2825, + 2826, + 2827, + 2828, + 2829 + ] + }, + { + "teal": 1165, + "source": "tests/contracts/general.algo.ts:280", + "pc": [ + 2830 + ] + }, + { + "teal": 1166, + "source": "tests/contracts/general.algo.ts:280", + "pc": [ + 2831 + ] + }, + { + "teal": 1167, + "source": "tests/contracts/general.algo.ts:280", + "pc": [ + 2832 + ] + }, + { + "teal": 1168, + "source": "tests/contracts/general.algo.ts:280", + "pc": [ + 2833 + ] + }, + { + "teal": 1169, + "source": "tests/contracts/general.algo.ts:280", + "pc": [ + 2834, + 2835 + ] + }, + { + "teal": 1170, + "source": "tests/contracts/general.algo.ts:280", + "pc": [ + 2836 + ] + }, + { + "teal": 1171, + "source": "tests/contracts/general.algo.ts:280", + "pc": [ + 2837 + ] + }, + { + "teal": 1172, + "source": "tests/contracts/general.algo.ts:280", + "pc": [ + 2838 + ] + }, + { + "teal": 1173, + "source": "tests/contracts/general.algo.ts:280", + "pc": [ + 2839 + ] + }, + { + "teal": 1174, + "source": "tests/contracts/general.algo.ts:280", + "pc": [ + 2840 + ] + }, + { + "teal": 1175, + "source": "tests/contracts/general.algo.ts:280", + "pc": [ + 2841, + 2842 + ] + }, + { + "teal": 1176, + "source": "tests/contracts/general.algo.ts:280", + "pc": [ + 2843 + ] + }, + { + "teal": 1180, + "source": "tests/contracts/general.algo.ts:280", + "pc": [ + 2844, + 2845, + 2846 + ] + }, + { + "teal": 1184, + "source": "tests/contracts/general.algo.ts:281", + "pc": [ + 2847, + 2848, + 2849, + 2850, + 2851, + 2852, + 2853, + 2854, + 2855, + 2856, + 2857, + 2858, + 2859, + 2860, + 2861, + 2862, + 2863, + 2864, + 2865, + 2866, + 2867, + 2868, + 2869, + 2870, + 2871, + 2872, + 2873, + 2874, + 2875, + 2876, + 2877, + 2878, + 2879, + 2880 + ] + }, + { + "teal": 1185, + "source": "tests/contracts/general.algo.ts:280", + "pc": [ + 2881 + ] + }, + { + "teal": 1190, + "source": "tests/contracts/general.algo.ts:284", + "pc": [ + 2882, + 2883, + 2884 + ] + }, + { + "teal": 1191, + "source": "tests/contracts/general.algo.ts:284", + "pc": [ + 2885, + 2886 + ] + }, + { + "teal": 1192, + "source": "tests/contracts/general.algo.ts:284", + "pc": [ + 2887 + ] + }, + { + "teal": 1196, + "source": "tests/contracts/general.algo.ts:284", + "pc": [ + 2888, + 2889, + 2890 + ] + }, + { + "teal": 1199, + "source": "tests/contracts/general.algo.ts:284", + "pc": [ + 2891, + 2892 + ] + }, + { + "teal": 1203, + "source": "tests/contracts/general.algo.ts:285", + "pc": [ + 2893 + ] + }, + { + "teal": 1204, + "source": "tests/contracts/general.algo.ts:285", + "pc": [ + 2894, + 2895 + ] + }, + { + "teal": 1205, + "source": "tests/contracts/general.algo.ts:285", + "pc": [ + 2896, + 2897 + ] + }, + { + "teal": 1206, + "source": "tests/contracts/general.algo.ts:285", + "pc": [ + 2898, + 2899 + ] + }, + { + "teal": 1207, + "source": "tests/contracts/general.algo.ts:285", + "pc": [ + 2900, + 2901 + ] + }, + { + "teal": 1208, + "source": "tests/contracts/general.algo.ts:285", + "pc": [ + 2902, + 2903, + 2904, + 2905, + 2906 + ] + }, + { + "teal": 1209, + "source": "tests/contracts/general.algo.ts:285", + "pc": [ + 2907 + ] + }, + { + "teal": 1210, + "source": "tests/contracts/general.algo.ts:285", + "pc": [ + 2908, + 2909 + ] + }, + { + "teal": 1211, + "source": "tests/contracts/general.algo.ts:285", + "pc": [ + 2910, + 2911 + ] + }, + { + "teal": 1212, + "source": "tests/contracts/general.algo.ts:285", + "pc": [ + 2912, + 2913 + ] + }, + { + "teal": 1213, + "source": "tests/contracts/general.algo.ts:285", + "pc": [ + 2914, + 2915 + ] + }, + { + "teal": 1214, + "source": "tests/contracts/general.algo.ts:285", + "pc": [ + 2916 + ] + }, + { + "teal": 1218, + "source": "tests/contracts/general.algo.ts:286", + "pc": [ + 2917, + 2918 + ] + }, + { + "teal": 1219, + "source": "tests/contracts/general.algo.ts:286", + "pc": [ + 2919, + 2920 + ] + }, + { + "teal": 1224, + "source": "tests/contracts/general.algo.ts:286", + "pc": [ + 2921, + 2922 + ] + }, + { + "teal": 1225, + "source": "tests/contracts/general.algo.ts:286", + "pc": [ + 2923, + 2924 + ] + }, + { + "teal": 1226, + "source": "tests/contracts/general.algo.ts:286", + "pc": [ + 2925 + ] + }, + { + "teal": 1227, + "source": "tests/contracts/general.algo.ts:286", + "pc": [ + 2926, + 2927, + 2928 + ] + }, + { + "teal": 1231, + "source": "tests/contracts/general.algo.ts:287", + "pc": [ + 2929, + 2930 + ] + }, + { + "teal": 1232, + "source": "tests/contracts/general.algo.ts:287", + "pc": [ + 2931 + ] + }, + { + "teal": 1237, + "source": "tests/contracts/general.algo.ts:286", + "pc": [ + 2932, + 2933 + ] + }, + { + "teal": 1238, + "source": "tests/contracts/general.algo.ts:286", + "pc": [ + 2934, + 2935 + ] + }, + { + "teal": 1239, + "source": "tests/contracts/general.algo.ts:286", + "pc": [ + 2936 + ] + }, + { + "teal": 1240, + "source": "tests/contracts/general.algo.ts:286", + "pc": [ + 2937, + 2938 + ] + }, + { + "teal": 1241, + "source": "tests/contracts/general.algo.ts:286", + "pc": [ + 2939, + 2940, + 2941 + ] + }, + { + "teal": 1244, + "source": "tests/contracts/general.algo.ts:284", + "pc": [ + 2942 + ] + }, + { + "teal": 1249, + "source": "tests/contracts/general.algo.ts:291", + "pc": [ + 2943, + 2944, + 2945, + 2946, + 2947, + 2948 + ] + }, + { + "teal": 1252, + "source": "tests/contracts/general.algo.ts:291", + "pc": [ + 2949, + 2950, + 2951 + ] + }, + { + "teal": 1253, + "source": "tests/contracts/general.algo.ts:291", + "pc": [ + 2952 + ] + }, + { + "teal": 1254, + "source": "tests/contracts/general.algo.ts:291", + "pc": [ + 2953 + ] + }, + { + "teal": 1255, + "source": "tests/contracts/general.algo.ts:291", + "pc": [ + 2954 + ] + }, + { + "teal": 1256, + "source": "tests/contracts/general.algo.ts:291", + "pc": [ + 2955, + 2956, + 2957 + ] + }, + { + "teal": 1257, + "source": "tests/contracts/general.algo.ts:291", + "pc": [ + 2958 + ] + }, + { + "teal": 1258, + "source": "tests/contracts/general.algo.ts:291", + "pc": [ + 2959 + ] + }, + { + "teal": 1259, + "source": "tests/contracts/general.algo.ts:291", + "pc": [ + 2960 + ] + }, + { + "teal": 1260, + "source": "tests/contracts/general.algo.ts:291", + "pc": [ + 2961 + ] + }, + { + "teal": 1261, + "source": "tests/contracts/general.algo.ts:291", + "pc": [ + 2962, + 2963 + ] + }, + { + "teal": 1262, + "source": "tests/contracts/general.algo.ts:291", + "pc": [ + 2964 + ] + }, + { + "teal": 1266, + "source": "tests/contracts/general.algo.ts:291", + "pc": [ + 2965, + 2966, + 2967 + ] + }, + { + "teal": 1269, + "source": "tests/contracts/general.algo.ts:291", + "pc": [ + 2968, + 2969 + ] + }, + { + "teal": 1273, + "source": "tests/contracts/general.algo.ts:292", + "pc": [ + 2970, + 2971, + 2972, + 2973 + ] + }, + { + "teal": 1274, + "source": "tests/contracts/general.algo.ts:292", + "pc": [ + 2974, + 2975 + ] + }, + { + "teal": 1279, + "source": "tests/contracts/general.algo.ts:294", + "pc": [ + 2976, + 2977 + ] + }, + { + "teal": 1280, + "source": "tests/contracts/general.algo.ts:294", + "pc": [ + 2978, + 2979 + ] + }, + { + "teal": 1281, + "source": "tests/contracts/general.algo.ts:294", + "pc": [ + 2980 + ] + }, + { + "teal": 1282, + "source": "tests/contracts/general.algo.ts:294", + "pc": [ + 2981, + 2982, + 2983 + ] + }, + { + "teal": 1287, + "source": "tests/contracts/general.algo.ts:295", + "pc": [ + 2984, + 2985, + 2986, + 2987, + 2988, + 2989, + 2990, + 2991, + 2992, + 2993 + ] + }, + { + "teal": 1288, + "source": "tests/contracts/general.algo.ts:295", + "pc": [ + 2994, + 2995 + ] + }, + { + "teal": 1293, + "source": "tests/contracts/general.algo.ts:298", + "pc": [ + 2996, + 2997, + 2998, + 2999, + 3000 + ] + }, + { + "teal": 1294, + "source": "tests/contracts/general.algo.ts:298", + "pc": [ + 3001 + ] + }, + { + "teal": 1295, + "source": "tests/contracts/general.algo.ts:298", + "pc": [ + 3002, + 3003 + ] + }, + { + "teal": 1298, + "source": "tests/contracts/general.algo.ts:291", + "pc": [ + 3004, + 3005 + ] + }, + { + "teal": 1299, + "source": "tests/contracts/general.algo.ts:291", + "pc": [ + 3006 + ] + }, + { + "teal": 1304, + "source": "tests/contracts/general.algo.ts:301", + "pc": [ + 3007, + 3008, + 3009, + 3010, + 3011, + 3012 + ] + }, + { + "teal": 1307, + "source": "tests/contracts/general.algo.ts:301", + "pc": [ + 3013, + 3014, + 3015 + ] + }, + { + "teal": 1308, + "source": "tests/contracts/general.algo.ts:301", + "pc": [ + 3016 + ] + }, + { + "teal": 1309, + "source": "tests/contracts/general.algo.ts:301", + "pc": [ + 3017 + ] + }, + { + "teal": 1310, + "source": "tests/contracts/general.algo.ts:301", + "pc": [ + 3018 + ] + }, + { + "teal": 1311, + "source": "tests/contracts/general.algo.ts:301", + "pc": [ + 3019, + 3020 + ] + }, + { + "teal": 1312, + "source": "tests/contracts/general.algo.ts:301", + "pc": [ + 3021 + ] + }, + { + "teal": 1316, + "source": "tests/contracts/general.algo.ts:301", + "pc": [ + 3022, + 3023, + 3024 + ] + }, + { + "teal": 1319, + "source": "tests/contracts/general.algo.ts:301", + "pc": [ + 3025, + 3026 + ] + }, + { + "teal": 1323, + "source": "tests/contracts/general.algo.ts:302", + "pc": [ + 3027, + 3028, + 3029, + 3030, + 3031, + 3032, + 3033, + 3034, + 3035, + 3036, + 3037, + 3038, + 3039, + 3040, + 3041, + 3042, + 3043, + 3044, + 3045, + 3046, + 3047, + 3048, + 3049, + 3050, + 3051, + 3052 + ] + }, + { + "teal": 1324, + "source": "tests/contracts/general.algo.ts:302", + "pc": [ + 3053, + 3054 + ] + }, + { + "teal": 1328, + "source": "tests/contracts/general.algo.ts:304", + "pc": [ + 3055, + 3056 + ] + }, + { + "teal": 1329, + "source": "tests/contracts/general.algo.ts:304", + "pc": [ + 3057, + 3058 + ] + }, + { + "teal": 1330, + "source": "tests/contracts/general.algo.ts:304", + "pc": [ + 3059, + 3060 + ] + }, + { + "teal": 1331, + "source": "tests/contracts/general.algo.ts:304", + "pc": [ + 3061 + ] + }, + { + "teal": 1332, + "source": "tests/contracts/general.algo.ts:304", + "pc": [ + 3062, + 3063 + ] + }, + { + "teal": 1333, + "source": "tests/contracts/general.algo.ts:304", + "pc": [ + 3064 + ] + }, + { + "teal": 1334, + "source": "tests/contracts/general.algo.ts:304", + "pc": [ + 3065 + ] + }, + { + "teal": 1335, + "source": "tests/contracts/general.algo.ts:304", + "pc": [ + 3066, + 3067 + ] + }, + { + "teal": 1336, + "source": "tests/contracts/general.algo.ts:304", + "pc": [ + 3068, + 3069 + ] + }, + { + "teal": 1339, + "source": "tests/contracts/general.algo.ts:301", + "pc": [ + 3070, + 3071 + ] + }, + { + "teal": 1340, + "source": "tests/contracts/general.algo.ts:301", + "pc": [ + 3072 + ] + }, + { + "teal": 1345, + "source": "tests/contracts/general.algo.ts:307", + "pc": [ + 3073, + 3074, + 3075, + 3076, + 3077, + 3078 + ] + }, + { + "teal": 1348, + "source": "tests/contracts/general.algo.ts:307", + "pc": [ + 3079, + 3080, + 3081 + ] + }, + { + "teal": 1349, + "source": "tests/contracts/general.algo.ts:307", + "pc": [ + 3082 + ] + }, + { + "teal": 1350, + "source": "tests/contracts/general.algo.ts:307", + "pc": [ + 3083 + ] + }, + { + "teal": 1351, + "source": "tests/contracts/general.algo.ts:307", + "pc": [ + 3084 + ] + }, + { + "teal": 1352, + "source": "tests/contracts/general.algo.ts:307", + "pc": [ + 3085, + 3086 + ] + }, + { + "teal": 1353, + "source": "tests/contracts/general.algo.ts:307", + "pc": [ + 3087 + ] + }, + { + "teal": 1357, + "source": "tests/contracts/general.algo.ts:307", + "pc": [ + 3088, + 3089, + 3090 + ] + }, + { + "teal": 1361, + "source": "tests/contracts/general.algo.ts:308", + "pc": [ + 3091, + 3092, + 3093, + 3094, + 3095, + 3096 + ] + }, + { + "teal": 1362, + "source": "tests/contracts/general.algo.ts:308", + "pc": [ + 3097, + 3098 + ] + }, + { + "teal": 1363, + "source": "tests/contracts/general.algo.ts:308", + "pc": [ + 3099 + ] + }, + { + "teal": 1367, + "source": "tests/contracts/general.algo.ts:310", + "pc": [ + 3100, + 3101, + 3102, + 3103, + 3104, + 3105 + ] + }, + { + "teal": 1368, + "source": "tests/contracts/general.algo.ts:310", + "pc": [ + 3106, + 3107 + ] + }, + { + "teal": 1369, + "source": "tests/contracts/general.algo.ts:310", + "pc": [ + 3108 + ] + }, + { + "teal": 1370, + "source": "tests/contracts/general.algo.ts:310", + "pc": [ + 3109, + 3110 + ] + }, + { + "teal": 1371, + "source": "tests/contracts/general.algo.ts:310", + "pc": [ + 3111 + ] + }, + { + "teal": 1372, + "source": "tests/contracts/general.algo.ts:310", + "pc": [ + 3112, + 3113 + ] + }, + { + "teal": 1373, + "source": "tests/contracts/general.algo.ts:307", + "pc": [ + 3114 + ] + }, + { + "teal": 1378, + "source": "tests/contracts/general.algo.ts:313", + "pc": [ + 3115, + 3116, + 3117, + 3118, + 3119, + 3120 + ] + }, + { + "teal": 1381, + "source": "tests/contracts/general.algo.ts:313", + "pc": [ + 3121, + 3122, + 3123 + ] + }, + { + "teal": 1382, + "source": "tests/contracts/general.algo.ts:313", + "pc": [ + 3124 + ] + }, + { + "teal": 1383, + "source": "tests/contracts/general.algo.ts:313", + "pc": [ + 3125 + ] + }, + { + "teal": 1384, + "source": "tests/contracts/general.algo.ts:313", + "pc": [ + 3126 + ] + }, + { + "teal": 1385, + "source": "tests/contracts/general.algo.ts:313", + "pc": [ + 3127, + 3128 + ] + }, + { + "teal": 1386, + "source": "tests/contracts/general.algo.ts:313", + "pc": [ + 3129 + ] + }, + { + "teal": 1390, + "source": "tests/contracts/general.algo.ts:313", + "pc": [ + 3130, + 3131, + 3132 + ] + }, + { + "teal": 1393, + "source": "tests/contracts/general.algo.ts:313", + "pc": [ + 3133, + 3134 + ] + }, + { + "teal": 1397, + "source": "tests/contracts/general.algo.ts:314", + "pc": [ + 3135, + 3136 + ] + }, + { + "teal": 1398, + "source": "tests/contracts/general.algo.ts:314", + "pc": [ + 3137, + 3138 + ] + }, + { + "teal": 1402, + "source": "tests/contracts/general.algo.ts:316", + "pc": [ + 3139, + 3140 + ] + }, + { + "teal": 1403, + "source": "tests/contracts/general.algo.ts:316", + "pc": [ + 3141, + 3142 + ] + }, + { + "teal": 1404, + "source": "tests/contracts/general.algo.ts:316", + "pc": [ + 3143 + ] + }, + { + "teal": 1405, + "source": "tests/contracts/general.algo.ts:316", + "pc": [ + 3144 + ] + }, + { + "teal": 1406, + "source": "tests/contracts/general.algo.ts:316", + "pc": [ + 3145, + 3146 + ] + }, + { + "teal": 1407, + "source": "tests/contracts/general.algo.ts:316", + "pc": [ + 3147, + 3148 + ] + }, + { + "teal": 1408, + "source": "tests/contracts/general.algo.ts:316", + "pc": [ + 3149, + 3150 + ] + }, + { + "teal": 1411, + "source": "tests/contracts/general.algo.ts:313", + "pc": [ + 3151, + 3152 + ] + }, + { + "teal": 1412, + "source": "tests/contracts/general.algo.ts:313", + "pc": [ + 3153 + ] + }, + { + "teal": 1417, + "source": "tests/contracts/general.algo.ts:319", + "pc": [ + 3154, + 3155, + 3156, + 3157, + 3158, + 3159 + ] + }, + { + "teal": 1420, + "source": "tests/contracts/general.algo.ts:319", + "pc": [ + 3160, + 3161, + 3162 + ] + }, + { + "teal": 1421, + "source": "tests/contracts/general.algo.ts:319", + "pc": [ + 3163 + ] + }, + { + "teal": 1422, + "source": "tests/contracts/general.algo.ts:319", + "pc": [ + 3164 + ] + }, + { + "teal": 1423, + "source": "tests/contracts/general.algo.ts:319", + "pc": [ + 3165 + ] + }, + { + "teal": 1424, + "source": "tests/contracts/general.algo.ts:319", + "pc": [ + 3166, + 3167 + ] + }, + { + "teal": 1425, + "source": "tests/contracts/general.algo.ts:319", + "pc": [ + 3168 + ] + }, + { + "teal": 1429, + "source": "tests/contracts/general.algo.ts:319", + "pc": [ + 3169, + 3170, + 3171 + ] + }, + { + "teal": 1432, + "source": "tests/contracts/general.algo.ts:319", + "pc": [ + 3172, + 3173 + ] + }, + { + "teal": 1436, + "source": "tests/contracts/general.algo.ts:320", + "pc": [ + 3174, + 3175, + 3176, + 3177, + 3178, + 3179, + 3180, + 3181, + 3182, + 3183, + 3184, + 3185, + 3186, + 3187, + 3188, + 3189, + 3190, + 3191, + 3192, + 3193, + 3194, + 3195, + 3196, + 3197, + 3198, + 3199 + ] + }, + { + "teal": 1437, + "source": "tests/contracts/general.algo.ts:320", + "pc": [ + 3200, + 3201 + ] + }, + { + "teal": 1441, + "source": "tests/contracts/general.algo.ts:322", + "pc": [ + 3202, + 3203 + ] + }, + { + "teal": 1442, + "source": "tests/contracts/general.algo.ts:322", + "pc": [ + 3204, + 3205 + ] + }, + { + "teal": 1443, + "source": "tests/contracts/general.algo.ts:322", + "pc": [ + 3206, + 3207 + ] + }, + { + "teal": 1444, + "source": "tests/contracts/general.algo.ts:322", + "pc": [ + 3208, + 3209, + 3210 + ] + }, + { + "teal": 1445, + "source": "tests/contracts/general.algo.ts:322", + "pc": [ + 3211 + ] + }, + { + "teal": 1446, + "source": "tests/contracts/general.algo.ts:322", + "pc": [ + 3212, + 3213 + ] + }, + { + "teal": 1447, + "source": "tests/contracts/general.algo.ts:322", + "pc": [ + 3214 + ] + }, + { + "teal": 1448, + "source": "tests/contracts/general.algo.ts:322", + "pc": [ + 3215 + ] + }, + { + "teal": 1449, + "source": "tests/contracts/general.algo.ts:322", + "pc": [ + 3216, + 3217 + ] + }, + { + "teal": 1450, + "source": "tests/contracts/general.algo.ts:322", + "pc": [ + 3218 + ] + }, + { + "teal": 1451, + "source": "tests/contracts/general.algo.ts:322", + "pc": [ + 3219 + ] + }, + { + "teal": 1452, + "source": "tests/contracts/general.algo.ts:322", + "pc": [ + 3220, + 3221 + ] + }, + { + "teal": 1453, + "source": "tests/contracts/general.algo.ts:322", + "pc": [ + 3222, + 3223 + ] + }, + { + "teal": 1456, + "source": "tests/contracts/general.algo.ts:319", + "pc": [ + 3224, + 3225 + ] + }, + { + "teal": 1457, + "source": "tests/contracts/general.algo.ts:319", + "pc": [ + 3226 + ] + }, + { + "teal": 1462, + "source": "tests/contracts/general.algo.ts:325", + "pc": [ + 3227, + 3228, + 3229, + 3230, + 3231, + 3232 + ] + }, + { + "teal": 1465, + "source": "tests/contracts/general.algo.ts:325", + "pc": [ + 3233, + 3234, + 3235 + ] + }, + { + "teal": 1466, + "source": "tests/contracts/general.algo.ts:325", + "pc": [ + 3236 + ] + }, + { + "teal": 1467, + "source": "tests/contracts/general.algo.ts:325", + "pc": [ + 3237 + ] + }, + { + "teal": 1468, + "source": "tests/contracts/general.algo.ts:325", + "pc": [ + 3238 + ] + }, + { + "teal": 1469, + "source": "tests/contracts/general.algo.ts:325", + "pc": [ + 3239, + 3240 + ] + }, + { + "teal": 1470, + "source": "tests/contracts/general.algo.ts:325", + "pc": [ + 3241 + ] + }, + { + "teal": 1474, + "source": "tests/contracts/general.algo.ts:325", + "pc": [ + 3242, + 3243, + 3244 + ] + }, + { + "teal": 1478, + "source": "tests/contracts/general.algo.ts:326", + "pc": [ + 3245, + 3246, + 3247, + 3248, + 3249, + 3250, + 3251, + 3252, + 3253, + 3254, + 3255, + 3256, + 3257, + 3258 + ] + }, + { + "teal": 1479, + "source": "tests/contracts/general.algo.ts:326", + "pc": [ + 3259, + 3260, + 3261, + 3262, + 3263, + 3264, + 3265, + 3266, + 3267, + 3268, + 3269, + 3270, + 3271, + 3272, + 3273, + 3274, + 3275, + 3276, + 3277, + 3278, + 3279, + 3280, + 3281, + 3282, + 3283, + 3284 + ] + }, + { + "teal": 1480, + "source": "tests/contracts/general.algo.ts:326", + "pc": [ + 3285 + ] + }, + { + "teal": 1484, + "source": "tests/contracts/general.algo.ts:328", + "pc": [ + 3286, + 3287, + 3288, + 3289, + 3290, + 3291, + 3292, + 3293, + 3294, + 3295, + 3296, + 3297, + 3298, + 3299 + ] + }, + { + "teal": 1485, + "source": "tests/contracts/general.algo.ts:328", + "pc": [ + 3300 + ] + }, + { + "teal": 1486, + "source": "tests/contracts/general.algo.ts:328", + "pc": [ + 3301, + 3302 + ] + }, + { + "teal": 1487, + "source": "tests/contracts/general.algo.ts:328", + "pc": [ + 3303, + 3304, + 3305, + 3306, + 3307, + 3308, + 3309, + 3310, + 3311, + 3312, + 3313, + 3314, + 3315, + 3316 + ] + }, + { + "teal": 1488, + "source": "tests/contracts/general.algo.ts:328", + "pc": [ + 3317 + ] + }, + { + "teal": 1489, + "source": "tests/contracts/general.algo.ts:328", + "pc": [ + 3318, + 3319, + 3320 + ] + }, + { + "teal": 1490, + "source": "tests/contracts/general.algo.ts:328", + "pc": [ + 3321 + ] + }, + { + "teal": 1491, + "source": "tests/contracts/general.algo.ts:328", + "pc": [ + 3322, + 3323 + ] + }, + { + "teal": 1492, + "source": "tests/contracts/general.algo.ts:328", + "pc": [ + 3324 + ] + }, + { + "teal": 1493, + "source": "tests/contracts/general.algo.ts:328", + "pc": [ + 3325 + ] + }, + { + "teal": 1494, + "source": "tests/contracts/general.algo.ts:328", + "pc": [ + 3326, + 3327 + ] + }, + { + "teal": 1495, + "source": "tests/contracts/general.algo.ts:328", + "pc": [ + 3328 + ] + }, + { + "teal": 1496, + "source": "tests/contracts/general.algo.ts:328", + "pc": [ + 3329 + ] + }, + { + "teal": 1497, + "source": "tests/contracts/general.algo.ts:328", + "pc": [ + 3330, + 3331, + 3332, + 3333, + 3334, + 3335, + 3336, + 3337, + 3338, + 3339, + 3340, + 3341, + 3342, + 3343 + ] + }, + { + "teal": 1498, + "source": "tests/contracts/general.algo.ts:328", + "pc": [ + 3344 + ] + }, + { + "teal": 1499, + "source": "tests/contracts/general.algo.ts:328", + "pc": [ + 3345 + ] + }, + { + "teal": 1500, + "source": "tests/contracts/general.algo.ts:328", + "pc": [ + 3346, + 3347 + ] + }, + { + "teal": 1501, + "source": "tests/contracts/general.algo.ts:325", + "pc": [ + 3348 + ] + }, + { + "teal": 1506, + "source": "tests/contracts/general.algo.ts:331", + "pc": [ + 3349, + 3350, + 3351 + ] + }, + { + "teal": 1507, + "source": "tests/contracts/general.algo.ts:331", + "pc": [ + 3352, + 3353 + ] + }, + { + "teal": 1508, + "source": "tests/contracts/general.algo.ts:331", + "pc": [ + 3354 + ] + }, + { + "teal": 1512, + "source": "tests/contracts/general.algo.ts:331", + "pc": [ + 3355, + 3356, + 3357 + ] + }, + { + "teal": 1516, + "source": "tests/contracts/general.algo.ts:332", + "pc": [ + 3358, + 3359, + 3360, + 3361, + 3362 + ] + }, + { + "teal": 1517, + "source": "tests/contracts/general.algo.ts:332", + "pc": [ + 3363, + 3364, + 3365, + 3366, + 3367 + ] + }, + { + "teal": 1518, + "source": "tests/contracts/general.algo.ts:332", + "pc": [ + 3368 + ] + }, + { + "teal": 1519, + "source": "tests/contracts/general.algo.ts:332", + "pc": [ + 3369 + ] + }, + { + "teal": 1523, + "source": "tests/contracts/general.algo.ts:333", + "pc": [ + 3370, + 3371 + ] + }, + { + "teal": 1524, + "source": "tests/contracts/general.algo.ts:333", + "pc": [ + 3372 + ] + }, + { + "teal": 1525, + "source": "tests/contracts/general.algo.ts:333", + "pc": [ + 3373 + ] + }, + { + "teal": 1526, + "source": "tests/contracts/general.algo.ts:333", + "pc": [ + 3374 + ] + }, + { + "teal": 1530, + "source": "tests/contracts/general.algo.ts:334", + "pc": [ + 3375, + 3376 + ] + }, + { + "teal": 1531, + "source": "tests/contracts/general.algo.ts:334", + "pc": [ + 3377 + ] + }, + { + "teal": 1532, + "source": "tests/contracts/general.algo.ts:334", + "pc": [ + 3378 + ] + }, + { + "teal": 1533, + "source": "tests/contracts/general.algo.ts:334", + "pc": [ + 3379 + ] + }, + { + "teal": 1534, + "source": "tests/contracts/general.algo.ts:331", + "pc": [ + 3380 + ] + }, + { + "teal": 1539, + "source": "tests/contracts/general.algo.ts:337", + "pc": [ + 3381, + 3382, + 3383 + ] + }, + { + "teal": 1540, + "source": "tests/contracts/general.algo.ts:337", + "pc": [ + 3384, + 3385 + ] + }, + { + "teal": 1541, + "source": "tests/contracts/general.algo.ts:337", + "pc": [ + 3386 + ] + }, + { + "teal": 1545, + "source": "tests/contracts/general.algo.ts:337", + "pc": [ + 3387, + 3388, + 3389 + ] + }, + { + "teal": 1549, + "source": "tests/contracts/general.algo.ts:338", + "pc": [ + 3390, + 3391 + ] + }, + { + "teal": 1552, + "source": "tests/contracts/general.algo.ts:338", + "errorMessage": "this is false", + "pc": [ + 3392 + ] + }, + { + "teal": 1553, + "source": "tests/contracts/general.algo.ts:337", + "pc": [ + 3393 + ] + }, + { + "teal": 1558, + "source": "tests/contracts/general.algo.ts:341", + "pc": [ + 3394, + 3395, + 3396 + ] + }, + { + "teal": 1559, + "source": "tests/contracts/general.algo.ts:341", + "pc": [ + 3397, + 3398 + ] + }, + { + "teal": 1560, + "source": "tests/contracts/general.algo.ts:341", + "pc": [ + 3399 + ] + }, + { + "teal": 1564, + "source": "tests/contracts/general.algo.ts:341", + "pc": [ + 3400, + 3401, + 3402 + ] + }, + { + "teal": 1568, + "source": "tests/contracts/general.algo.ts:342", + "pc": [ + 3403, + 3404, + 3405, + 3406, + 3407, + 3408, + 3409, + 3410, + 3411, + 3412, + 3413, + 3414, + 3415, + 3416, + 3417, + 3418, + 3419, + 3420, + 3421, + 3422, + 3423, + 3424, + 3425, + 3426, + 3427, + 3428, + 3429, + 3430, + 3431, + 3432, + 3433, + 3434, + 3435, + 3436, + 3437, + 3438, + 3439, + 3440, + 3441, + 3442, + 3443, + 3444, + 3445, + 3446, + 3447, + 3448, + 3449, + 3450, + 3451, + 3452, + 3453, + 3454, + 3455, + 3456, + 3457, + 3458, + 3459, + 3460, + 3461, + 3462, + 3463, + 3464, + 3465, + 3466, + 3467, + 3468 + ] + }, + { + "teal": 1569, + "source": "tests/contracts/general.algo.ts:342", + "pc": [ + 3469, + 3470 + ] + }, + { + "teal": 1570, + "source": "tests/contracts/general.algo.ts:342", + "pc": [ + 3471 + ] + }, + { + "teal": 1574, + "source": "tests/contracts/general.algo.ts:343", + "pc": [ + 3472, + 3473, + 3474, + 3475, + 3476, + 3477, + 3478, + 3479, + 3480, + 3481, + 3482, + 3483, + 3484, + 3485, + 3486, + 3487, + 3488, + 3489, + 3490, + 3491, + 3492, + 3493, + 3494, + 3495, + 3496, + 3497, + 3498, + 3499, + 3500, + 3501, + 3502, + 3503, + 3504, + 3505, + 3506, + 3507, + 3508, + 3509, + 3510, + 3511, + 3512, + 3513, + 3514, + 3515, + 3516, + 3517, + 3518, + 3519, + 3520, + 3521, + 3522, + 3523, + 3524, + 3525, + 3526, + 3527, + 3528, + 3529, + 3530, + 3531, + 3532, + 3533, + 3534, + 3535, + 3536, + 3537 + ] + }, + { + "teal": 1575, + "source": "tests/contracts/general.algo.ts:343", + "pc": [ + 3538, + 3539 + ] + }, + { + "teal": 1576, + "source": "tests/contracts/general.algo.ts:343", + "pc": [ + 3540 + ] + }, + { + "teal": 1580, + "source": "tests/contracts/general.algo.ts:344", + "pc": [ + 3541, + 3542, + 3543, + 3544, + 3545, + 3546, + 3547, + 3548, + 3549, + 3550, + 3551, + 3552, + 3553, + 3554, + 3555, + 3556, + 3557, + 3558, + 3559, + 3560, + 3561, + 3562, + 3563, + 3564, + 3565, + 3566, + 3567, + 3568, + 3569, + 3570, + 3571, + 3572, + 3573, + 3574, + 3575, + 3576, + 3577, + 3578, + 3579, + 3580, + 3581, + 3582, + 3583, + 3584, + 3585, + 3586, + 3587, + 3588, + 3589, + 3590, + 3591, + 3592, + 3593, + 3594, + 3595, + 3596, + 3597, + 3598, + 3599, + 3600, + 3601, + 3602, + 3603, + 3604, + 3605, + 3606 + ] + }, + { + "teal": 1581, + "source": "tests/contracts/general.algo.ts:344", + "pc": [ + 3607, + 3608 + ] + }, + { + "teal": 1582, + "source": "tests/contracts/general.algo.ts:344", + "pc": [ + 3609 + ] + }, + { + "teal": 1586, + "source": "tests/contracts/general.algo.ts:345", + "pc": [ + 3610, + 3611, + 3612, + 3613, + 3614, + 3615, + 3616, + 3617, + 3618, + 3619, + 3620, + 3621, + 3622, + 3623, + 3624, + 3625, + 3626, + 3627, + 3628, + 3629, + 3630, + 3631, + 3632, + 3633, + 3634, + 3635, + 3636, + 3637, + 3638, + 3639, + 3640, + 3641, + 3642, + 3643, + 3644, + 3645, + 3646, + 3647, + 3648, + 3649, + 3650, + 3651, + 3652, + 3653, + 3654, + 3655, + 3656, + 3657, + 3658, + 3659, + 3660, + 3661, + 3662, + 3663, + 3664, + 3665, + 3666, + 3667, + 3668, + 3669, + 3670, + 3671, + 3672, + 3673, + 3674, + 3675 + ] + }, + { + "teal": 1587, + "source": "tests/contracts/general.algo.ts:345", + "pc": [ + 3676 + ] + }, + { + "teal": 1588, + "source": "tests/contracts/general.algo.ts:345", + "pc": [ + 3677, + 3678, + 3679, + 3680, + 3681, + 3682, + 3683, + 3684, + 3685, + 3686, + 3687, + 3688, + 3689, + 3690, + 3691, + 3692, + 3693, + 3694, + 3695, + 3696, + 3697, + 3698, + 3699, + 3700, + 3701, + 3702, + 3703, + 3704, + 3705, + 3706, + 3707, + 3708, + 3709, + 3710 + ] + }, + { + "teal": 1589, + "source": "tests/contracts/general.algo.ts:345", + "pc": [ + 3711 + ] + }, + { + "teal": 1593, + "source": "tests/contracts/general.algo.ts:346", + "pc": [ + 3712, + 3713, + 3714, + 3715, + 3716, + 3717, + 3718, + 3719, + 3720, + 3721, + 3722, + 3723, + 3724, + 3725, + 3726, + 3727, + 3728, + 3729, + 3730, + 3731, + 3732, + 3733, + 3734, + 3735, + 3736, + 3737, + 3738, + 3739, + 3740, + 3741, + 3742, + 3743, + 3744, + 3745, + 3746, + 3747, + 3748, + 3749, + 3750, + 3751, + 3752, + 3753, + 3754, + 3755, + 3756, + 3757, + 3758, + 3759, + 3760, + 3761, + 3762, + 3763, + 3764, + 3765, + 3766, + 3767, + 3768, + 3769, + 3770, + 3771, + 3772, + 3773, + 3774, + 3775, + 3776, + 3777 + ] + }, + { + "teal": 1594, + "source": "tests/contracts/general.algo.ts:346", + "pc": [ + 3778 + ] + }, + { + "teal": 1595, + "source": "tests/contracts/general.algo.ts:346", + "pc": [ + 3779, + 3780, + 3781, + 3782, + 3783, + 3784, + 3785, + 3786, + 3787, + 3788, + 3789, + 3790, + 3791, + 3792, + 3793, + 3794, + 3795, + 3796, + 3797, + 3798, + 3799, + 3800, + 3801, + 3802, + 3803, + 3804, + 3805, + 3806, + 3807, + 3808, + 3809, + 3810, + 3811, + 3812 + ] + }, + { + "teal": 1596, + "source": "tests/contracts/general.algo.ts:346", + "pc": [ + 3813 + ] + }, + { + "teal": 1597, + "source": "tests/contracts/general.algo.ts:341", + "pc": [ + 3814 + ] + }, + { + "teal": 1602, + "source": "tests/contracts/general.algo.ts:349", + "pc": [ + 3815, + 3816, + 3817 + ] + }, + { + "teal": 1603, + "source": "tests/contracts/general.algo.ts:349", + "pc": [ + 3818, + 3819 + ] + }, + { + "teal": 1604, + "source": "tests/contracts/general.algo.ts:349", + "pc": [ + 3820 + ] + }, + { + "teal": 1608, + "source": "tests/contracts/general.algo.ts:349", + "pc": [ + 3821, + 3822, + 3823 + ] + }, + { + "teal": 1611, + "source": "tests/contracts/general.algo.ts:349", + "pc": [ + 3824, + 3825 + ] + }, + { + "teal": 1612, + "source": "tests/contracts/general.algo.ts:349", + "pc": [ + 3826 + ] + }, + { + "teal": 1616, + "source": "tests/contracts/general.algo.ts:350", + "pc": [ + 3827 + ] + }, + { + "teal": 1617, + "source": "tests/contracts/general.algo.ts:350", + "pc": [ + 3828, + 3829 + ] + }, + { + "teal": 1618, + "source": "tests/contracts/general.algo.ts:350", + "pc": [ + 3830, + 3831 + ] + }, + { + "teal": 1619, + "source": "tests/contracts/general.algo.ts:350", + "pc": [ + 3832, + 3833 + ] + }, + { + "teal": 1620, + "source": "tests/contracts/general.algo.ts:350", + "pc": [ + 3834, + 3835 + ] + }, + { + "teal": 1621, + "source": "tests/contracts/general.algo.ts:350", + "pc": [ + 3836, + 3837, + 3838, + 3839, + 3840 + ] + }, + { + "teal": 1622, + "source": "tests/contracts/general.algo.ts:350", + "pc": [ + 3841 + ] + }, + { + "teal": 1623, + "source": "tests/contracts/general.algo.ts:350", + "pc": [ + 3842, + 3843 + ] + }, + { + "teal": 1624, + "source": "tests/contracts/general.algo.ts:350", + "pc": [ + 3844, + 3845 + ] + }, + { + "teal": 1625, + "source": "tests/contracts/general.algo.ts:350", + "pc": [ + 3846, + 3847 + ] + }, + { + "teal": 1626, + "source": "tests/contracts/general.algo.ts:350", + "pc": [ + 3848, + 3849 + ] + }, + { + "teal": 1627, + "source": "tests/contracts/general.algo.ts:350", + "pc": [ + 3850 + ] + }, + { + "teal": 1631, + "source": "tests/contracts/general.algo.ts:351", + "pc": [ + 3851 + ] + }, + { + "teal": 1632, + "source": "tests/contracts/general.algo.ts:351", + "pc": [ + 3852, + 3853 + ] + }, + { + "teal": 1633, + "source": "tests/contracts/general.algo.ts:351", + "pc": [ + 3854, + 3855 + ] + }, + { + "teal": 1634, + "source": "tests/contracts/general.algo.ts:351", + "pc": [ + 3856, + 3857 + ] + }, + { + "teal": 1635, + "source": "tests/contracts/general.algo.ts:351", + "pc": [ + 3858, + 3859 + ] + }, + { + "teal": 1636, + "source": "tests/contracts/general.algo.ts:351", + "pc": [ + 3860, + 3861, + 3862, + 3863, + 3864 + ] + }, + { + "teal": 1637, + "source": "tests/contracts/general.algo.ts:351", + "pc": [ + 3865 + ] + }, + { + "teal": 1638, + "source": "tests/contracts/general.algo.ts:351", + "pc": [ + 3866, + 3867 + ] + }, + { + "teal": 1639, + "source": "tests/contracts/general.algo.ts:351", + "pc": [ + 3868, + 3869 + ] + }, + { + "teal": 1640, + "source": "tests/contracts/general.algo.ts:351", + "pc": [ + 3870, + 3871 + ] + }, + { + "teal": 1641, + "source": "tests/contracts/general.algo.ts:351", + "pc": [ + 3872, + 3873 + ] + }, + { + "teal": 1642, + "source": "tests/contracts/general.algo.ts:351", + "pc": [ + 3874 + ] + }, + { + "teal": 1646, + "source": "tests/contracts/general.algo.ts:352", + "pc": [ + 3875 + ] + }, + { + "teal": 1647, + "source": "tests/contracts/general.algo.ts:352", + "pc": [ + 3876, + 3877 + ] + }, + { + "teal": 1648, + "source": "tests/contracts/general.algo.ts:352", + "pc": [ + 3878, + 3879 + ] + }, + { + "teal": 1649, + "source": "tests/contracts/general.algo.ts:352", + "pc": [ + 3880, + 3881 + ] + }, + { + "teal": 1650, + "source": "tests/contracts/general.algo.ts:352", + "pc": [ + 3882, + 3883 + ] + }, + { + "teal": 1651, + "source": "tests/contracts/general.algo.ts:352", + "pc": [ + 3884, + 3885, + 3886, + 3887, + 3888 + ] + }, + { + "teal": 1652, + "source": "tests/contracts/general.algo.ts:352", + "pc": [ + 3889 + ] + }, + { + "teal": 1653, + "source": "tests/contracts/general.algo.ts:352", + "pc": [ + 3890, + 3891 + ] + }, + { + "teal": 1654, + "source": "tests/contracts/general.algo.ts:352", + "pc": [ + 3892, + 3893 + ] + }, + { + "teal": 1655, + "source": "tests/contracts/general.algo.ts:352", + "pc": [ + 3894, + 3895 + ] + }, + { + "teal": 1656, + "source": "tests/contracts/general.algo.ts:352", + "pc": [ + 3896, + 3897 + ] + }, + { + "teal": 1657, + "source": "tests/contracts/general.algo.ts:352", + "pc": [ + 3898 + ] + }, + { + "teal": 1661, + "source": "tests/contracts/general.algo.ts:353", + "pc": [ + 3899 + ] + }, + { + "teal": 1662, + "source": "tests/contracts/general.algo.ts:353", + "pc": [ + 3900, + 3901 + ] + }, + { + "teal": 1663, + "source": "tests/contracts/general.algo.ts:353", + "pc": [ + 3902, + 3903 + ] + }, + { + "teal": 1664, + "source": "tests/contracts/general.algo.ts:353", + "pc": [ + 3904, + 3905 + ] + }, + { + "teal": 1665, + "source": "tests/contracts/general.algo.ts:353", + "pc": [ + 3906, + 3907 + ] + }, + { + "teal": 1666, + "source": "tests/contracts/general.algo.ts:353", + "pc": [ + 3908, + 3909, + 3910, + 3911, + 3912 + ] + }, + { + "teal": 1667, + "source": "tests/contracts/general.algo.ts:353", + "pc": [ + 3913 + ] + }, + { + "teal": 1668, + "source": "tests/contracts/general.algo.ts:353", + "pc": [ + 3914, + 3915 + ] + }, + { + "teal": 1669, + "source": "tests/contracts/general.algo.ts:353", + "pc": [ + 3916, + 3917 + ] + }, + { + "teal": 1670, + "source": "tests/contracts/general.algo.ts:353", + "pc": [ + 3918, + 3919 + ] + }, + { + "teal": 1671, + "source": "tests/contracts/general.algo.ts:353", + "pc": [ + 3920, + 3921 + ] + }, + { + "teal": 1672, + "source": "tests/contracts/general.algo.ts:353", + "pc": [ + 3922 + ] + }, + { + "teal": 1676, + "source": "tests/contracts/general.algo.ts:354", + "pc": [ + 3923 + ] + }, + { + "teal": 1677, + "source": "tests/contracts/general.algo.ts:354", + "pc": [ + 3924, + 3925 + ] + }, + { + "teal": 1678, + "source": "tests/contracts/general.algo.ts:354", + "pc": [ + 3926, + 3927 + ] + }, + { + "teal": 1679, + "source": "tests/contracts/general.algo.ts:354", + "pc": [ + 3928, + 3929 + ] + }, + { + "teal": 1680, + "source": "tests/contracts/general.algo.ts:354", + "pc": [ + 3930, + 3931 + ] + }, + { + "teal": 1681, + "source": "tests/contracts/general.algo.ts:354", + "pc": [ + 3932, + 3933, + 3934, + 3935, + 3936 + ] + }, + { + "teal": 1682, + "source": "tests/contracts/general.algo.ts:354", + "pc": [ + 3937 + ] + }, + { + "teal": 1683, + "source": "tests/contracts/general.algo.ts:354", + "pc": [ + 3938, + 3939 + ] + }, + { + "teal": 1684, + "source": "tests/contracts/general.algo.ts:354", + "pc": [ + 3940, + 3941 + ] + }, + { + "teal": 1685, + "source": "tests/contracts/general.algo.ts:354", + "pc": [ + 3942, + 3943 + ] + }, + { + "teal": 1686, + "source": "tests/contracts/general.algo.ts:354", + "pc": [ + 3944, + 3945 + ] + }, + { + "teal": 1687, + "source": "tests/contracts/general.algo.ts:354", + "pc": [ + 3946 + ] + }, + { + "teal": 1691, + "source": "tests/contracts/general.algo.ts:355", + "pc": [ + 3947 + ] + }, + { + "teal": 1692, + "source": "tests/contracts/general.algo.ts:355", + "pc": [ + 3948, + 3949 + ] + }, + { + "teal": 1693, + "source": "tests/contracts/general.algo.ts:355", + "pc": [ + 3950, + 3951 + ] + }, + { + "teal": 1694, + "source": "tests/contracts/general.algo.ts:355", + "pc": [ + 3952, + 3953 + ] + }, + { + "teal": 1695, + "source": "tests/contracts/general.algo.ts:355", + "pc": [ + 3954, + 3955 + ] + }, + { + "teal": 1696, + "source": "tests/contracts/general.algo.ts:355", + "pc": [ + 3956, + 3957, + 3958, + 3959, + 3960 + ] + }, + { + "teal": 1697, + "source": "tests/contracts/general.algo.ts:355", + "pc": [ + 3961 + ] + }, + { + "teal": 1698, + "source": "tests/contracts/general.algo.ts:355", + "pc": [ + 3962, + 3963 + ] + }, + { + "teal": 1699, + "source": "tests/contracts/general.algo.ts:355", + "pc": [ + 3964, + 3965 + ] + }, + { + "teal": 1700, + "source": "tests/contracts/general.algo.ts:355", + "pc": [ + 3966, + 3967 + ] + }, + { + "teal": 1701, + "source": "tests/contracts/general.algo.ts:355", + "pc": [ + 3968, + 3969 + ] + }, + { + "teal": 1702, + "source": "tests/contracts/general.algo.ts:355", + "pc": [ + 3970 + ] + }, + { + "teal": 1706, + "source": "tests/contracts/general.algo.ts:356", + "pc": [ + 3971 + ] + }, + { + "teal": 1707, + "source": "tests/contracts/general.algo.ts:356", + "pc": [ + 3972, + 3973 + ] + }, + { + "teal": 1708, + "source": "tests/contracts/general.algo.ts:356", + "pc": [ + 3974, + 3975 + ] + }, + { + "teal": 1709, + "source": "tests/contracts/general.algo.ts:356", + "pc": [ + 3976, + 3977 + ] + }, + { + "teal": 1710, + "source": "tests/contracts/general.algo.ts:356", + "pc": [ + 3978, + 3979 + ] + }, + { + "teal": 1711, + "source": "tests/contracts/general.algo.ts:356", + "pc": [ + 3980, + 3981, + 3982, + 3983, + 3984 + ] + }, + { + "teal": 1712, + "source": "tests/contracts/general.algo.ts:356", + "pc": [ + 3985 + ] + }, + { + "teal": 1713, + "source": "tests/contracts/general.algo.ts:356", + "pc": [ + 3986, + 3987 + ] + }, + { + "teal": 1714, + "source": "tests/contracts/general.algo.ts:356", + "pc": [ + 3988, + 3989 + ] + }, + { + "teal": 1715, + "source": "tests/contracts/general.algo.ts:356", + "pc": [ + 3990, + 3991 + ] + }, + { + "teal": 1716, + "source": "tests/contracts/general.algo.ts:356", + "pc": [ + 3992, + 3993 + ] + }, + { + "teal": 1717, + "source": "tests/contracts/general.algo.ts:356", + "pc": [ + 3994 + ] + }, + { + "teal": 1721, + "source": "tests/contracts/general.algo.ts:357", + "pc": [ + 3995 + ] + }, + { + "teal": 1722, + "source": "tests/contracts/general.algo.ts:357", + "pc": [ + 3996, + 3997 + ] + }, + { + "teal": 1723, + "source": "tests/contracts/general.algo.ts:357", + "pc": [ + 3998, + 3999 + ] + }, + { + "teal": 1724, + "source": "tests/contracts/general.algo.ts:357", + "pc": [ + 4000, + 4001 + ] + }, + { + "teal": 1725, + "source": "tests/contracts/general.algo.ts:357", + "pc": [ + 4002, + 4003 + ] + }, + { + "teal": 1726, + "source": "tests/contracts/general.algo.ts:357", + "pc": [ + 4004, + 4005, + 4006, + 4007, + 4008 + ] + }, + { + "teal": 1727, + "source": "tests/contracts/general.algo.ts:357", + "pc": [ + 4009 + ] + }, + { + "teal": 1728, + "source": "tests/contracts/general.algo.ts:357", + "pc": [ + 4010, + 4011 + ] + }, + { + "teal": 1729, + "source": "tests/contracts/general.algo.ts:357", + "pc": [ + 4012, + 4013 + ] + }, + { + "teal": 1730, + "source": "tests/contracts/general.algo.ts:357", + "pc": [ + 4014, + 4015 + ] + }, + { + "teal": 1731, + "source": "tests/contracts/general.algo.ts:357", + "pc": [ + 4016, + 4017 + ] + }, + { + "teal": 1732, + "source": "tests/contracts/general.algo.ts:357", + "pc": [ + 4018 + ] + }, + { + "teal": 1736, + "source": "tests/contracts/general.algo.ts:358", + "pc": [ + 4019 + ] + }, + { + "teal": 1737, + "source": "tests/contracts/general.algo.ts:358", + "pc": [ + 4020, + 4021 + ] + }, + { + "teal": 1738, + "source": "tests/contracts/general.algo.ts:358", + "pc": [ + 4022, + 4023 + ] + }, + { + "teal": 1739, + "source": "tests/contracts/general.algo.ts:358", + "pc": [ + 4024, + 4025 + ] + }, + { + "teal": 1740, + "source": "tests/contracts/general.algo.ts:358", + "pc": [ + 4026, + 4027 + ] + }, + { + "teal": 1741, + "source": "tests/contracts/general.algo.ts:358", + "pc": [ + 4028, + 4029, + 4030, + 4031, + 4032 + ] + }, + { + "teal": 1742, + "source": "tests/contracts/general.algo.ts:358", + "pc": [ + 4033 + ] + }, + { + "teal": 1743, + "source": "tests/contracts/general.algo.ts:358", + "pc": [ + 4034, + 4035 + ] + }, + { + "teal": 1744, + "source": "tests/contracts/general.algo.ts:358", + "pc": [ + 4036, + 4037 + ] + }, + { + "teal": 1745, + "source": "tests/contracts/general.algo.ts:358", + "pc": [ + 4038, + 4039 + ] + }, + { + "teal": 1746, + "source": "tests/contracts/general.algo.ts:358", + "pc": [ + 4040, + 4041 + ] + }, + { + "teal": 1747, + "source": "tests/contracts/general.algo.ts:358", + "pc": [ + 4042 + ] + }, + { + "teal": 1751, + "source": "tests/contracts/general.algo.ts:360", + "pc": [ + 4043, + 4044, + 4045, + 4046, + 4047, + 4048, + 4049, + 4050, + 4051, + 4052, + 4053, + 4054, + 4055, + 4056, + 4057, + 4058, + 4059, + 4060, + 4061, + 4062, + 4063, + 4064, + 4065, + 4066, + 4067, + 4068, + 4069, + 4070, + 4071, + 4072, + 4073, + 4074, + 4075, + 4076 + ] + }, + { + "teal": 1752, + "source": "tests/contracts/general.algo.ts:360", + "pc": [ + 4077, + 4078, + 4079, + 4080, + 4081, + 4082, + 4083, + 4084, + 4085, + 4086, + 4087, + 4088, + 4089, + 4090, + 4091, + 4092, + 4093, + 4094, + 4095, + 4096, + 4097, + 4098, + 4099, + 4100, + 4101, + 4102, + 4103, + 4104, + 4105, + 4106, + 4107, + 4108, + 4109, + 4110, + 4111, + 4112, + 4113, + 4114, + 4115, + 4116, + 4117, + 4118, + 4119, + 4120, + 4121, + 4122, + 4123, + 4124, + 4125, + 4126, + 4127, + 4128, + 4129, + 4130, + 4131, + 4132, + 4133, + 4134, + 4135, + 4136, + 4137, + 4138, + 4139, + 4140, + 4141, + 4142, + 4143, + 4144, + 4145, + 4146, + 4147, + 4148, + 4149, + 4150, + 4151, + 4152, + 4153, + 4154, + 4155, + 4156, + 4157, + 4158 + ] + }, + { + "teal": 1753, + "source": "tests/contracts/general.algo.ts:360", + "pc": [ + 4159, + 4160, + 4161, + 4162, + 4163, + 4164, + 4165, + 4166, + 4167, + 4168, + 4169, + 4170, + 4171, + 4172, + 4173, + 4174, + 4175, + 4176, + 4177, + 4178, + 4179, + 4180, + 4181, + 4182, + 4183, + 4184, + 4185, + 4186, + 4187, + 4188, + 4189, + 4190, + 4191, + 4192 + ] + }, + { + "teal": 1754, + "source": "tests/contracts/general.algo.ts:360", + "pc": [ + 4193, + 4194 + ] + }, + { + "teal": 1755, + "source": "tests/contracts/general.algo.ts:360", + "pc": [ + 4195, + 4196 + ] + }, + { + "teal": 1756, + "source": "tests/contracts/general.algo.ts:360", + "pc": [ + 4197, + 4198 + ] + }, + { + "teal": 1760, + "source": "tests/contracts/general.algo.ts:361", + "pc": [ + 4199, + 4200 + ] + }, + { + "teal": 1761, + "source": "tests/contracts/general.algo.ts:361", + "pc": [ + 4201 + ] + }, + { + "teal": 1762, + "source": "tests/contracts/general.algo.ts:361", + "pc": [ + 4202 + ] + }, + { + "teal": 1766, + "source": "tests/contracts/general.algo.ts:362", + "pc": [ + 4203, + 4204 + ] + }, + { + "teal": 1767, + "source": "tests/contracts/general.algo.ts:362", + "pc": [ + 4205 + ] + }, + { + "teal": 1768, + "source": "tests/contracts/general.algo.ts:349", + "pc": [ + 4206 + ] + }, + { + "teal": 1773, + "source": "tests/contracts/general.algo.ts:365", + "pc": [ + 4207, + 4208, + 4209 + ] + }, + { + "teal": 1774, + "source": "tests/contracts/general.algo.ts:365", + "pc": [ + 4210, + 4211 + ] + }, + { + "teal": 1775, + "source": "tests/contracts/general.algo.ts:365", + "pc": [ + 4212 + ] + }, + { + "teal": 1779, + "source": "tests/contracts/general.algo.ts:365", + "pc": [ + 4213, + 4214, + 4215 + ] + }, + { + "teal": 1782, + "source": "tests/contracts/general.algo.ts:365", + "pc": [ + 4216, + 4217 + ] + }, + { + "teal": 1786, + "source": "tests/contracts/general.algo.ts:366", + "pc": [ + 4218, + 4219 + ] + }, + { + "teal": 1787, + "source": "tests/contracts/general.algo.ts:366", + "pc": [ + 4220 + ] + }, + { + "teal": 1788, + "source": "tests/contracts/general.algo.ts:366", + "pc": [ + 4221, + 4222 + ] + }, + { + "teal": 1792, + "source": "tests/contracts/general.algo.ts:367", + "pc": [ + 4223, + 4224 + ] + }, + { + "teal": 1793, + "source": "tests/contracts/general.algo.ts:367", + "pc": [ + 4225 + ] + }, + { + "teal": 1794, + "source": "tests/contracts/general.algo.ts:367", + "pc": [ + 4226, + 4227 + ] + }, + { + "teal": 1798, + "source": "tests/contracts/general.algo.ts:368", + "pc": [ + 4228, + 4229, + 4230, + 4231, + 4232, + 4233, + 4234, + 4235, + 4236, + 4237, + 4238, + 4239, + 4240, + 4241, + 4242, + 4243, + 4244, + 4245, + 4246, + 4247, + 4248, + 4249, + 4250, + 4251, + 4252, + 4253, + 4254, + 4255, + 4256, + 4257, + 4258, + 4259, + 4260, + 4261, + 4262, + 4263, + 4264, + 4265, + 4266, + 4267, + 4268, + 4269, + 4270, + 4271, + 4272, + 4273, + 4274, + 4275, + 4276, + 4277, + 4278, + 4279, + 4280, + 4281, + 4282, + 4283, + 4284, + 4285, + 4286, + 4287, + 4288, + 4289, + 4290, + 4291, + 4292, + 4293 + ] + }, + { + "teal": 1799, + "source": "tests/contracts/general.algo.ts:368", + "pc": [ + 4294, + 4295 + ] + }, + { + "teal": 1803, + "source": "tests/contracts/general.algo.ts:369", + "pc": [ + 4296, + 4297 + ] + }, + { + "teal": 1804, + "source": "tests/contracts/general.algo.ts:369", + "pc": [ + 4298, + 4299, + 4300, + 4301, + 4302, + 4303, + 4304, + 4305, + 4306, + 4307, + 4308, + 4309, + 4310, + 4311, + 4312, + 4313, + 4314, + 4315, + 4316, + 4317, + 4318, + 4319, + 4320, + 4321, + 4322, + 4323, + 4324, + 4325, + 4326, + 4327, + 4328, + 4329, + 4330, + 4331, + 4332, + 4333, + 4334, + 4335, + 4336, + 4337, + 4338, + 4339, + 4340, + 4341, + 4342, + 4343, + 4344, + 4345, + 4346, + 4347, + 4348, + 4349, + 4350, + 4351, + 4352, + 4353, + 4354, + 4355, + 4356, + 4357, + 4358, + 4359, + 4360, + 4361, + 4362, + 4363 + ] + }, + { + "teal": 1805, + "source": "tests/contracts/general.algo.ts:369", + "pc": [ + 4364, + 4365 + ] + }, + { + "teal": 1809, + "source": "tests/contracts/general.algo.ts:370", + "pc": [ + 4366, + 4367 + ] + }, + { + "teal": 1810, + "source": "tests/contracts/general.algo.ts:370", + "pc": [ + 4368, + 4369 + ] + }, + { + "teal": 1814, + "source": "tests/contracts/general.algo.ts:371", + "pc": [ + 4370, + 4371 + ] + }, + { + "teal": 1815, + "source": "tests/contracts/general.algo.ts:371", + "pc": [ + 4372, + 4373 + ] + }, + { + "teal": 1819, + "source": "tests/contracts/general.algo.ts:372", + "pc": [ + 4374, + 4375 + ] + }, + { + "teal": 1820, + "source": "tests/contracts/general.algo.ts:372", + "pc": [ + 4376 + ] + }, + { + "teal": 1821, + "source": "tests/contracts/general.algo.ts:372", + "pc": [ + 4377, + 4378 + ] + }, + { + "teal": 1822, + "source": "tests/contracts/general.algo.ts:365", + "pc": [ + 4379 + ] + }, + { + "teal": 1827, + "source": "tests/contracts/general.algo.ts:375", + "pc": [ + 4380, + 4381, + 4382 + ] + }, + { + "teal": 1828, + "source": "tests/contracts/general.algo.ts:375", + "pc": [ + 4383, + 4384 + ] + }, + { + "teal": 1829, + "source": "tests/contracts/general.algo.ts:375", + "pc": [ + 4385 + ] + }, + { + "teal": 1833, + "source": "tests/contracts/general.algo.ts:375", + "pc": [ + 4386, + 4387, + 4388 + ] + }, + { + "teal": 1836, + "source": "tests/contracts/general.algo.ts:375", + "pc": [ + 4389, + 4390 + ] + }, + { + "teal": 1840, + "source": "tests/contracts/general.algo.ts:376", + "pc": [ + 4391, + 4392, + 4393 + ] + }, + { + "teal": 1841, + "source": "tests/contracts/general.algo.ts:376", + "pc": [ + 4394 + ] + }, + { + "teal": 1845, + "source": "tests/contracts/general.algo.ts:378", + "pc": [ + 4395, + 4396 + ] + }, + { + "teal": 1846, + "source": "tests/contracts/general.algo.ts:378", + "pc": [ + 4397, + 4398 + ] + }, + { + "teal": 1850, + "source": "tests/contracts/general.algo.ts:380", + "pc": [ + 4399, + 4400, + 4401 + ] + }, + { + "teal": 1851, + "source": "tests/contracts/general.algo.ts:380", + "pc": [ + 4402 + ] + }, + { + "teal": 1852, + "source": "tests/contracts/general.algo.ts:375", + "pc": [ + 4403 + ] + }, + { + "teal": 1857, + "source": "tests/contracts/general.algo.ts:383", + "pc": [ + 4404, + 4405, + 4406 + ] + }, + { + "teal": 1858, + "source": "tests/contracts/general.algo.ts:383", + "pc": [ + 4407, + 4408 + ] + }, + { + "teal": 1859, + "source": "tests/contracts/general.algo.ts:383", + "pc": [ + 4409 + ] + }, + { + "teal": 1863, + "source": "tests/contracts/general.algo.ts:383", + "pc": [ + 4410, + 4411, + 4412 + ] + }, + { + "teal": 1867, + "source": "tests/contracts/general.algo.ts:384", + "pc": [ + 4413, + 4414, + 4415, + 4416, + 4417 + ] + }, + { + "teal": 1868, + "source": "tests/contracts/general.algo.ts:384", + "pc": [ + 4418, + 4419 + ] + }, + { + "teal": 1869, + "source": "tests/contracts/general.algo.ts:384", + "pc": [ + 4420, + 4421 + ] + }, + { + "teal": 1870, + "source": "tests/contracts/general.algo.ts:384", + "pc": [ + 4422 + ] + }, + { + "teal": 1871, + "source": "tests/contracts/general.algo.ts:384", + "pc": [ + 4423 + ] + }, + { + "teal": 1875, + "source": "tests/contracts/general.algo.ts:385", + "pc": [ + 4424, + 4425, + 4426, + 4427, + 4428 + ] + }, + { + "teal": 1876, + "source": "tests/contracts/general.algo.ts:385", + "pc": [ + 4429, + 4430 + ] + }, + { + "teal": 1877, + "source": "tests/contracts/general.algo.ts:385", + "pc": [ + 4431 + ] + }, + { + "teal": 1881, + "source": "tests/contracts/general.algo.ts:386", + "pc": [ + 4432, + 4433, + 4434, + 4435, + 4436 + ] + }, + { + "teal": 1882, + "source": "tests/contracts/general.algo.ts:386", + "pc": [ + 4437, + 4438 + ] + }, + { + "teal": 1883, + "source": "tests/contracts/general.algo.ts:386", + "pc": [ + 4439 + ] + }, + { + "teal": 1887, + "source": "tests/contracts/general.algo.ts:387", + "pc": [ + 4440, + 4441, + 4442, + 4443, + 4444 + ] + }, + { + "teal": 1888, + "source": "tests/contracts/general.algo.ts:387", + "pc": [ + 4445, + 4446 + ] + }, + { + "teal": 1889, + "source": "tests/contracts/general.algo.ts:387", + "pc": [ + 4447, + 4448 + ] + }, + { + "teal": 1890, + "source": "tests/contracts/general.algo.ts:387", + "pc": [ + 4449 + ] + }, + { + "teal": 1891, + "source": "tests/contracts/general.algo.ts:383", + "pc": [ + 4450 + ] + }, + { + "teal": 1896, + "source": "tests/contracts/general.algo.ts:390", + "pc": [ + 4451, + 4452, + 4453 + ] + }, + { + "teal": 1897, + "source": "tests/contracts/general.algo.ts:390", + "pc": [ + 4454, + 4455 + ] + }, + { + "teal": 1898, + "source": "tests/contracts/general.algo.ts:390", + "pc": [ + 4456 + ] + }, + { + "teal": 1902, + "source": "tests/contracts/general.algo.ts:390", + "pc": [ + 4457, + 4458, + 4459 + ] + }, + { + "teal": 1906, + "source": "tests/contracts/general.algo.ts:391", + "pc": [ + 4460, + 4461 + ] + }, + { + "teal": 1907, + "source": "tests/contracts/general.algo.ts:391", + "pc": [ + 4462, + 4463 + ] + }, + { + "teal": 1908, + "source": "tests/contracts/general.algo.ts:391", + "pc": [ + 4464, + 4465 + ] + }, + { + "teal": 1909, + "source": "tests/contracts/general.algo.ts:391", + "pc": [ + 4466 + ] + }, + { + "teal": 1910, + "source": "tests/contracts/general.algo.ts:391", + "pc": [ + 4467 + ] + }, + { + "teal": 1914, + "source": "tests/contracts/general.algo.ts:392", + "pc": [ + 4468, + 4469 + ] + }, + { + "teal": 1915, + "source": "tests/contracts/general.algo.ts:392", + "pc": [ + 4470, + 4471 + ] + }, + { + "teal": 1916, + "source": "tests/contracts/general.algo.ts:392", + "pc": [ + 4472 + ] + }, + { + "teal": 1917, + "source": "tests/contracts/general.algo.ts:390", + "pc": [ + 4473 + ] + }, + { + "teal": 1922, + "source": "tests/contracts/general.algo.ts:395", + "pc": [ + 4474, + 4475, + 4476 + ] + }, + { + "teal": 1923, + "source": "tests/contracts/general.algo.ts:395", + "pc": [ + 4477, + 4478 + ] + }, + { + "teal": 1924, + "source": "tests/contracts/general.algo.ts:395", + "pc": [ + 4479 + ] + }, + { + "teal": 1928, + "source": "tests/contracts/general.algo.ts:395", + "pc": [ + 4480, + 4481, + 4482 + ] + }, + { + "teal": 1932, + "source": "tests/contracts/general.algo.ts:396", + "pc": [ + 4483, + 4484 + ] + }, + { + "teal": 1933, + "source": "tests/contracts/general.algo.ts:396", + "pc": [ + 4485, + 4486 + ] + }, + { + "teal": 1934, + "source": "tests/contracts/general.algo.ts:396", + "pc": [ + 4487 + ] + }, + { + "teal": 1935, + "source": "tests/contracts/general.algo.ts:396", + "pc": [ + 4488, + 4489 + ] + }, + { + "teal": 1936, + "source": "tests/contracts/general.algo.ts:396", + "pc": [ + 4490 + ] + }, + { + "teal": 1940, + "source": "tests/contracts/general.algo.ts:397", + "pc": [ + 4491, + 4492 + ] + }, + { + "teal": 1941, + "source": "tests/contracts/general.algo.ts:397", + "pc": [ + 4493, + 4494 + ] + }, + { + "teal": 1942, + "source": "tests/contracts/general.algo.ts:397", + "pc": [ + 4495 + ] + }, + { + "teal": 1943, + "source": "tests/contracts/general.algo.ts:397", + "pc": [ + 4496, + 4497 + ] + }, + { + "teal": 1944, + "source": "tests/contracts/general.algo.ts:397", + "pc": [ + 4498 + ] + }, + { + "teal": 1945, + "source": "tests/contracts/general.algo.ts:395", + "pc": [ + 4499 + ] + }, + { + "teal": 1950, + "source": "tests/contracts/general.algo.ts:400", + "pc": [ + 4500, + 4501, + 4502 + ] + }, + { + "teal": 1951, + "source": "tests/contracts/general.algo.ts:400", + "pc": [ + 4503, + 4504 + ] + }, + { + "teal": 1952, + "source": "tests/contracts/general.algo.ts:400", + "pc": [ + 4505 + ] + }, + { + "teal": 1956, + "source": "tests/contracts/general.algo.ts:400", + "pc": [ + 4506, + 4507, + 4508 + ] + }, + { + "teal": 1960, + "source": "tests/contracts/general.algo.ts:401", + "pc": [ + 4509, + 4510 + ] + }, + { + "teal": 1961, + "source": "tests/contracts/general.algo.ts:401", + "pc": [ + 4511, + 4512 + ] + }, + { + "teal": 1962, + "source": "tests/contracts/general.algo.ts:401", + "pc": [ + 4513 + ] + }, + { + "teal": 1963, + "source": "tests/contracts/general.algo.ts:400", + "pc": [ + 4514 + ] + }, + { + "teal": 1968, + "source": "tests/contracts/general.algo.ts:404", + "pc": [ + 4515, + 4516, + 4517 + ] + }, + { + "teal": 1969, + "source": "tests/contracts/general.algo.ts:404", + "pc": [ + 4518, + 4519 + ] + }, + { + "teal": 1970, + "source": "tests/contracts/general.algo.ts:404", + "pc": [ + 4520 + ] + }, + { + "teal": 1974, + "source": "tests/contracts/general.algo.ts:404", + "pc": [ + 4521, + 4522, + 4523 + ] + }, + { + "teal": 1978, + "source": "tests/contracts/general.algo.ts:405", + "pc": [ + 4524, + 4525 + ] + }, + { + "teal": 1979, + "source": "tests/contracts/general.algo.ts:405", + "pc": [ + 4526 + ] + }, + { + "teal": 1980, + "source": "tests/contracts/general.algo.ts:405", + "pc": [ + 4527, + 4528 + ] + }, + { + "teal": 1981, + "source": "tests/contracts/general.algo.ts:405", + "pc": [ + 4529 + ] + }, + { + "teal": 1985, + "source": "tests/contracts/general.algo.ts:406", + "pc": [ + 4530, + 4531 + ] + }, + { + "teal": 1986, + "source": "tests/contracts/general.algo.ts:406", + "pc": [ + 4532 + ] + }, + { + "teal": 1987, + "source": "tests/contracts/general.algo.ts:406", + "pc": [ + 4533, + 4534 + ] + }, + { + "teal": 1988, + "source": "tests/contracts/general.algo.ts:406", + "pc": [ + 4535 + ] + }, + { + "teal": 1992, + "source": "tests/contracts/general.algo.ts:407", + "pc": [ + 4536, + 4537 + ] + }, + { + "teal": 1993, + "source": "tests/contracts/general.algo.ts:407", + "pc": [ + 4538 + ] + }, + { + "teal": 1994, + "source": "tests/contracts/general.algo.ts:407", + "pc": [ + 4539, + 4540 + ] + }, + { + "teal": 1995, + "source": "tests/contracts/general.algo.ts:407", + "pc": [ + 4541 + ] + }, + { + "teal": 1996, + "source": "tests/contracts/general.algo.ts:404", + "pc": [ + 4542 + ] + }, + { + "teal": 2001, + "source": "tests/contracts/general.algo.ts:410", + "pc": [ + 4543, + 4544, + 4545 + ] + }, + { + "teal": 2002, + "source": "tests/contracts/general.algo.ts:410", + "pc": [ + 4546, + 4547 + ] + }, + { + "teal": 2003, + "source": "tests/contracts/general.algo.ts:410", + "pc": [ + 4548 + ] + }, + { + "teal": 2007, + "source": "tests/contracts/general.algo.ts:410", + "pc": [ + 4549, + 4550, + 4551 + ] + }, + { + "teal": 2011, + "source": "tests/contracts/general.algo.ts:411", + "pc": [ + 4552, + 4553 + ] + }, + { + "teal": 2012, + "source": "tests/contracts/general.algo.ts:411", + "pc": [ + 4554 + ] + }, + { + "teal": 2016, + "source": "tests/contracts/general.algo.ts:412", + "pc": [ + 4555, + 4556, + 4557, + 4558, + 4559 + ] + }, + { + "teal": 2017, + "source": "tests/contracts/general.algo.ts:412", + "pc": [ + 4560 + ] + }, + { + "teal": 2018, + "source": "tests/contracts/general.algo.ts:410", + "pc": [ + 4561 + ] + }, + { + "teal": 2023, + "source": "tests/contracts/general.algo.ts:415", + "pc": [ + 4562, + 4563, + 4564 + ] + }, + { + "teal": 2024, + "source": "tests/contracts/general.algo.ts:415", + "pc": [ + 4565, + 4566 + ] + }, + { + "teal": 2025, + "source": "tests/contracts/general.algo.ts:415", + "pc": [ + 4567 + ] + }, + { + "teal": 2029, + "source": "tests/contracts/general.algo.ts:415", + "pc": [ + 4568, + 4569, + 4570 + ] + }, + { + "teal": 2033, + "source": "tests/contracts/general.algo.ts:10", + "pc": [ + 4571, + 4572, + 4573 + ] + }, + { + "teal": 2034, + "source": "tests/contracts/general.algo.ts:416", + "pc": [ + 4574 + ] + }, + { + "teal": 2035, + "source": "tests/contracts/general.algo.ts:415", + "pc": [ + 4575 + ] + }, + { + "teal": 2040, + "source": "tests/contracts/general.algo.ts:419", + "pc": [ + 4576, + 4577, + 4578 + ] + }, + { + "teal": 2041, + "source": "tests/contracts/general.algo.ts:419", + "pc": [ + 4579, + 4580 + ] + }, + { + "teal": 2042, + "source": "tests/contracts/general.algo.ts:419", + "pc": [ + 4581 + ] + }, + { + "teal": 2046, + "source": "tests/contracts/general.algo.ts:419", + "pc": [ + 4582, + 4583, + 4584 + ] + }, + { + "teal": 2050, + "source": "tests/contracts/general.algo.ts:11", + "pc": [ + 4585, + 4586, + 4587, + 4588 + ] + }, + { + "teal": 2051, + "source": "tests/contracts/general.algo.ts:420", + "pc": [ + 4589 + ] + }, + { + "teal": 2052, + "source": "tests/contracts/general.algo.ts:419", + "pc": [ + 4590 + ] + }, + { + "teal": 2057, + "source": "tests/contracts/general.algo.ts:423", + "pc": [ + 4591, + 4592, + 4593 + ] + }, + { + "teal": 2058, + "source": "tests/contracts/general.algo.ts:423", + "pc": [ + 4594, + 4595 + ] + }, + { + "teal": 2059, + "source": "tests/contracts/general.algo.ts:423", + "pc": [ + 4596 + ] + }, + { + "teal": 2063, + "source": "tests/contracts/general.algo.ts:423", + "pc": [ + 4597, + 4598, + 4599 + ] + }, + { + "teal": 2067, + "source": "tests/contracts/general.algo.ts:424", + "pc": [ + 4600, + 4601 + ] + }, + { + "teal": 2068, + "source": "tests/contracts/general.algo.ts:424", + "pc": [ + 4602 + ] + }, + { + "teal": 2069, + "source": "tests/contracts/general.algo.ts:424", + "pc": [ + 4603 + ] + }, + { + "teal": 2070, + "source": "tests/contracts/general.algo.ts:424", + "pc": [ + 4604 + ] + }, + { + "teal": 2074, + "source": "tests/contracts/general.algo.ts:425", + "pc": [ + 4605, + 4606 + ] + }, + { + "teal": 2075, + "source": "tests/contracts/general.algo.ts:425", + "pc": [ + 4607 + ] + }, + { + "teal": 2076, + "source": "tests/contracts/general.algo.ts:425", + "pc": [ + 4608 + ] + }, + { + "teal": 2077, + "source": "tests/contracts/general.algo.ts:425", + "pc": [ + 4609 + ] + }, + { + "teal": 2081, + "source": "tests/contracts/general.algo.ts:426", + "pc": [ + 4610, + 4611 + ] + }, + { + "teal": 2082, + "source": "tests/contracts/general.algo.ts:426", + "pc": [ + 4612, + 4613 + ] + }, + { + "teal": 2083, + "source": "tests/contracts/general.algo.ts:426", + "pc": [ + 4614 + ] + }, + { + "teal": 2084, + "source": "tests/contracts/general.algo.ts:426", + "pc": [ + 4615 + ] + }, + { + "teal": 2088, + "source": "tests/contracts/general.algo.ts:427", + "pc": [ + 4616, + 4617 + ] + }, + { + "teal": 2089, + "source": "tests/contracts/general.algo.ts:427", + "pc": [ + 4618 + ] + }, + { + "teal": 2090, + "source": "tests/contracts/general.algo.ts:427", + "pc": [ + 4619 + ] + }, + { + "teal": 2091, + "source": "tests/contracts/general.algo.ts:427", + "pc": [ + 4620 + ] + }, + { + "teal": 2092, + "source": "tests/contracts/general.algo.ts:423", + "pc": [ + 4621 + ] + }, + { + "teal": 2097, + "source": "tests/contracts/general.algo.ts:430", + "pc": [ + 4622, + 4623, + 4624, + 4625, + 4626, + 4627 + ] + }, + { + "teal": 2100, + "source": "tests/contracts/general.algo.ts:430", + "pc": [ + 4628, + 4629, + 4630 + ] + }, + { + "teal": 2101, + "source": "tests/contracts/general.algo.ts:430", + "pc": [ + 4631, + 4632, + 4633 + ] + }, + { + "teal": 2102, + "source": "tests/contracts/general.algo.ts:430", + "pc": [ + 4634, + 4635 + ] + }, + { + "teal": 2103, + "source": "tests/contracts/general.algo.ts:430", + "pc": [ + 4636, + 4637 + ] + }, + { + "teal": 2104, + "source": "tests/contracts/general.algo.ts:430", + "pc": [ + 4638 + ] + }, + { + "teal": 2105, + "source": "tests/contracts/general.algo.ts:430", + "pc": [ + 4639 + ] + }, + { + "teal": 2106, + "source": "tests/contracts/general.algo.ts:430", + "pc": [ + 4640 + ] + }, + { + "teal": 2107, + "source": "tests/contracts/general.algo.ts:430", + "pc": [ + 4641, + 4642 + ] + }, + { + "teal": 2108, + "source": "tests/contracts/general.algo.ts:430", + "pc": [ + 4643 + ] + }, + { + "teal": 2112, + "source": "tests/contracts/general.algo.ts:430", + "pc": [ + 4644, + 4645, + 4646 + ] + }, + { + "teal": 2116, + "source": "tests/contracts/general.algo.ts:431", + "pc": [ + 4647, + 4648 + ] + }, + { + "teal": 2117, + "source": "tests/contracts/general.algo.ts:431", + "pc": [ + 4649, + 4650 + ] + }, + { + "teal": 2118, + "source": "tests/contracts/general.algo.ts:431", + "pc": [ + 4651 + ] + }, + { + "teal": 2119, + "source": "tests/contracts/general.algo.ts:431", + "pc": [ + 4652 + ] + }, + { + "teal": 2120, + "source": "tests/contracts/general.algo.ts:431", + "pc": [ + 4653, + 4654, + 4655 + ] + }, + { + "teal": 2121, + "source": "tests/contracts/general.algo.ts:431", + "pc": [ + 4656, + 4657 + ] + }, + { + "teal": 2122, + "source": "tests/contracts/general.algo.ts:431", + "pc": [ + 4658, + 4659 + ] + }, + { + "teal": 2123, + "source": "tests/contracts/general.algo.ts:431", + "pc": [ + 4660 + ] + }, + { + "teal": 2124, + "source": "tests/contracts/general.algo.ts:431", + "pc": [ + 4661 + ] + }, + { + "teal": 2127, + "source": "tests/contracts/general.algo.ts:430", + "pc": [ + 4662 + ] + }, + { + "teal": 2132, + "source": "tests/contracts/general.algo.ts:435", + "pc": [ + 4663, + 4664 + ] + }, + { + "teal": 2133, + "source": "tests/contracts/general.algo.ts:435", + "pc": [ + 4665, + 4666 + ] + }, + { + "teal": 2134, + "source": "tests/contracts/general.algo.ts:435", + "pc": [ + 4667 + ] + }, + { + "teal": 2135, + "source": "tests/contracts/general.algo.ts:435", + "pc": [ + 4668 + ] + }, + { + "teal": 2136, + "source": "tests/contracts/general.algo.ts:435", + "pc": [ + 4669, + 4670 + ] + }, + { + "teal": 2137, + "source": "tests/contracts/general.algo.ts:435", + "pc": [ + 4671, + 4672 + ] + }, + { + "teal": 2138, + "source": "tests/contracts/general.algo.ts:435", + "pc": [ + 4673 + ] + }, + { + "teal": 2141, + "source": "tests/contracts/general.algo.ts:435", + "errorMessage": "argument 0 (_pay1) for txnArgsMethod must be a pay transaction", + "pc": [ + 4674 + ] + }, + { + "teal": 2144, + "source": "tests/contracts/general.algo.ts:435", + "pc": [ + 4675, + 4676, + 4677 + ] + }, + { + "teal": 2145, + "source": "tests/contracts/general.algo.ts:435", + "pc": [ + 4678, + 4679 + ] + }, + { + "teal": 2146, + "source": "tests/contracts/general.algo.ts:435", + "pc": [ + 4680 + ] + }, + { + "teal": 2150, + "source": "tests/contracts/general.algo.ts:435", + "pc": [ + 4681, + 4682, + 4683 + ] + }, + { + "teal": 2151, + "source": "tests/contracts/general.algo.ts:435", + "pc": [ + 4684 + ] + }, + { + "teal": 2156, + "source": "tests/contracts/general.algo.ts:437", + "pc": [ + 4685, + 4686, + 4687 + ] + }, + { + "teal": 2157, + "source": "tests/contracts/general.algo.ts:437", + "pc": [ + 4688, + 4689 + ] + }, + { + "teal": 2158, + "source": "tests/contracts/general.algo.ts:437", + "pc": [ + 4690 + ] + }, + { + "teal": 2162, + "source": "tests/contracts/general.algo.ts:437", + "pc": [ + 4691, + 4692, + 4693 + ] + }, + { + "teal": 2168, + "source": "tests/contracts/general.algo.ts:439", + "pc": [ + 4694 + ] + }, + { + "teal": 2169, + "source": "tests/contracts/general.algo.ts:439", + "pc": [ + 4695, + 4696 + ] + }, + { + "teal": 2170, + "source": "tests/contracts/general.algo.ts:439", + "pc": [ + 4697, + 4698 + ] + }, + { + "teal": 2174, + "source": "tests/contracts/general.algo.ts:439", + "pc": [ + 4699, + 4700 + ] + }, + { + "teal": 2175, + "source": "tests/contracts/general.algo.ts:439", + "pc": [ + 4701, + 4702 + ] + }, + { + "teal": 2179, + "source": "tests/contracts/general.algo.ts:439", + "pc": [ + 4703, + 4704 + ] + }, + { + "teal": 2180, + "source": "tests/contracts/general.algo.ts:439", + "pc": [ + 4705, + 4706 + ] + }, + { + "teal": 2183, + "source": "tests/contracts/general.algo.ts:439", + "pc": [ + 4707, + 4708 + ] + }, + { + "teal": 2184, + "source": "tests/contracts/general.algo.ts:439", + "pc": [ + 4709, + 4710 + ] + }, + { + "teal": 2185, + "source": "tests/contracts/general.algo.ts:438", + "pc": [ + 4711 + ] + }, + { + "teal": 2186, + "source": "tests/contracts/general.algo.ts:438", + "pc": [ + 4712, + 4713 + ] + }, + { + "teal": 2187, + "source": "tests/contracts/general.algo.ts:438", + "pc": [ + 4714, + 4715 + ] + }, + { + "teal": 2188, + "source": "tests/contracts/general.algo.ts:438", + "pc": [ + 4716, + 4717, + 4718, + 4719, + 4720, + 4721 + ] + }, + { + "teal": 2189, + "source": "tests/contracts/general.algo.ts:438", + "pc": [ + 4722, + 4723 + ] + }, + { + "teal": 2194, + "source": "tests/contracts/general.algo.ts:438", + "pc": [ + 4724, + 4725 + ] + }, + { + "teal": 2195, + "source": "tests/contracts/general.algo.ts:438", + "pc": [ + 4726, + 4727 + ] + }, + { + "teal": 2198, + "source": "tests/contracts/general.algo.ts:438", + "pc": [ + 4728 + ] + }, + { + "teal": 2199, + "source": "tests/contracts/general.algo.ts:437", + "pc": [ + 4729 + ] + }, + { + "teal": 2204, + "source": "tests/contracts/general.algo.ts:443", + "pc": [ + 4730, + 4731, + 4732 + ] + }, + { + "teal": 2205, + "source": "tests/contracts/general.algo.ts:443", + "pc": [ + 4733 + ] + }, + { + "teal": 2206, + "source": "tests/contracts/general.algo.ts:443", + "pc": [ + 4734 + ] + }, + { + "teal": 2207, + "source": "tests/contracts/general.algo.ts:443", + "pc": [ + 4735, + 4736 + ] + }, + { + "teal": 2208, + "source": "tests/contracts/general.algo.ts:443", + "pc": [ + 4737 + ] + }, + { + "teal": 2211, + "source": "tests/contracts/general.algo.ts:443", + "errorMessage": "argument 0 (x) for staticValueLen must be a uint256", + "pc": [ + 4738 + ] + }, + { + "teal": 2214, + "source": "tests/contracts/general.algo.ts:443", + "pc": [ + 4739, + 4740, + 4741 + ] + }, + { + "teal": 2215, + "source": "tests/contracts/general.algo.ts:443", + "pc": [ + 4742, + 4743 + ] + }, + { + "teal": 2216, + "source": "tests/contracts/general.algo.ts:443", + "pc": [ + 4744 + ] + }, + { + "teal": 2220, + "source": "tests/contracts/general.algo.ts:443", + "pc": [ + 4745, + 4746, + 4747 + ] + }, + { + "teal": 2224, + "source": "tests/contracts/general.algo.ts:444", + "pc": [ + 4748, + 4749 + ] + }, + { + "teal": 2225, + "source": "tests/contracts/general.algo.ts:444", + "pc": [ + 4750 + ] + }, + { + "teal": 2226, + "source": "tests/contracts/general.algo.ts:443", + "pc": [ + 4751 + ] + }, + { + "teal": 2231, + "source": "tests/contracts/general.algo.ts:447", + "pc": [ + 4752, + 4753, + 4754 + ] + }, + { + "teal": 2232, + "source": "tests/contracts/general.algo.ts:447", + "pc": [ + 4755, + 4756 + ] + }, + { + "teal": 2233, + "source": "tests/contracts/general.algo.ts:447", + "pc": [ + 4757 + ] + }, + { + "teal": 2237, + "source": "tests/contracts/general.algo.ts:447", + "pc": [ + 4758, + 4759, + 4760 + ] + }, + { + "teal": 2241, + "source": "tests/contracts/general.algo.ts:448", + "pc": [ + 4761, + 4762 + ] + }, + { + "teal": 2242, + "source": "tests/contracts/general.algo.ts:448", + "pc": [ + 4763 + ] + }, + { + "teal": 2243, + "source": "tests/contracts/general.algo.ts:447", + "pc": [ + 4764 + ] + }, + { + "teal": 2248, + "source": "tests/contracts/general.algo.ts:451", + "pc": [ + 4765, + 4766, + 4767 + ] + }, + { + "teal": 2249, + "source": "tests/contracts/general.algo.ts:451", + "pc": [ + 4768, + 4769 + ] + }, + { + "teal": 2250, + "source": "tests/contracts/general.algo.ts:451", + "pc": [ + 4770 + ] + }, + { + "teal": 2254, + "source": "tests/contracts/general.algo.ts:451", + "pc": [ + 4771, + 4772, + 4773 + ] + }, + { + "teal": 2258, + "source": "tests/contracts/general.algo.ts:452", + "pc": [ + 4774, + 4775 + ] + }, + { + "teal": 2259, + "source": "tests/contracts/general.algo.ts:452", + "pc": [ + 4776, + 4777, + 4778 + ] + }, + { + "teal": 2260, + "source": "tests/contracts/general.algo.ts:452", + "pc": [ + 4779 + ] + }, + { + "teal": 2264, + "source": "tests/contracts/general.algo.ts:453", + "pc": [ + 4780, + 4781 + ] + }, + { + "teal": 2265, + "source": "tests/contracts/general.algo.ts:453", + "pc": [ + 4782 + ] + }, + { + "teal": 2266, + "source": "tests/contracts/general.algo.ts:453", + "pc": [ + 4783, + 4784, + 4785 + ] + }, + { + "teal": 2267, + "source": "tests/contracts/general.algo.ts:453", + "pc": [ + 4786 + ] + }, + { + "teal": 2268, + "source": "tests/contracts/general.algo.ts:453", + "pc": [ + 4787 + ] + }, + { + "teal": 2269, + "source": "tests/contracts/general.algo.ts:451", + "pc": [ + 4788 + ] + }, + { + "teal": 2274, + "source": "tests/contracts/general.algo.ts:456", + "pc": [ + 4789, + 4790, + 4791 + ] + }, + { + "teal": 2275, + "source": "tests/contracts/general.algo.ts:456", + "pc": [ + 4792, + 4793 + ] + }, + { + "teal": 2276, + "source": "tests/contracts/general.algo.ts:456", + "pc": [ + 4794 + ] + }, + { + "teal": 2280, + "source": "tests/contracts/general.algo.ts:456", + "pc": [ + 4795, + 4796, + 4797 + ] + }, + { + "teal": 2284, + "source": "tests/contracts/general.algo.ts:457", + "pc": [ + 4798, + 4799, + 4800 + ] + }, + { + "teal": 2285, + "source": "tests/contracts/general.algo.ts:457", + "pc": [ + 4801, + 4802 + ] + }, + { + "teal": 2289, + "source": "tests/contracts/general.algo.ts:458", + "pc": [ + 4803, + 4804 + ] + }, + { + "teal": 2290, + "source": "tests/contracts/general.algo.ts:458", + "pc": [ + 4805, + 4806 + ] + }, + { + "teal": 2291, + "source": "tests/contracts/general.algo.ts:458", + "pc": [ + 4807 + ] + }, + { + "teal": 2292, + "source": "tests/contracts/general.algo.ts:458", + "pc": [ + 4808, + 4809 + ] + }, + { + "teal": 2296, + "source": "tests/contracts/general.algo.ts:459", + "pc": [ + 4810, + 4811 + ] + }, + { + "teal": 2297, + "source": "tests/contracts/general.algo.ts:459", + "pc": [ + 4812, + 4813, + 4814 + ] + }, + { + "teal": 2298, + "source": "tests/contracts/general.algo.ts:459", + "pc": [ + 4815 + ] + }, + { + "teal": 2299, + "source": "tests/contracts/general.algo.ts:459", + "pc": [ + 4816 + ] + }, + { + "teal": 2300, + "source": "tests/contracts/general.algo.ts:456", + "pc": [ + 4817 + ] + }, + { + "teal": 2305, + "source": "tests/contracts/general.algo.ts:462", + "pc": [ + 4818, + 4819, + 4820 + ] + }, + { + "teal": 2306, + "source": "tests/contracts/general.algo.ts:462", + "pc": [ + 4821, + 4822 + ] + }, + { + "teal": 2307, + "source": "tests/contracts/general.algo.ts:462", + "pc": [ + 4823 + ] + }, + { + "teal": 2311, + "source": "tests/contracts/general.algo.ts:462", + "pc": [ + 4824, + 4825, + 4826 + ] + }, + { + "teal": 2315, + "source": "tests/contracts/general.algo.ts:463", + "pc": [ + 4827, + 4828 + ] + }, + { + "teal": 2316, + "source": "tests/contracts/general.algo.ts:463", + "pc": [ + 4829, + 4830, + 4831 + ] + }, + { + "teal": 2317, + "source": "tests/contracts/general.algo.ts:463", + "pc": [ + 4832 + ] + }, + { + "teal": 2321, + "source": "tests/contracts/general.algo.ts:464", + "pc": [ + 4833, + 4834 + ] + }, + { + "teal": 2322, + "source": "tests/contracts/general.algo.ts:464", + "pc": [ + 4835 + ] + }, + { + "teal": 2323, + "source": "tests/contracts/general.algo.ts:464", + "pc": [ + 4836, + 4837 + ] + }, + { + "teal": 2324, + "source": "tests/contracts/general.algo.ts:464", + "pc": [ + 4838 + ] + }, + { + "teal": 2325, + "source": "tests/contracts/general.algo.ts:464", + "pc": [ + 4839, + 4840 + ] + }, + { + "teal": 2326, + "source": "tests/contracts/general.algo.ts:464", + "pc": [ + 4841 + ] + }, + { + "teal": 2327, + "source": "tests/contracts/general.algo.ts:464", + "pc": [ + 4842 + ] + }, + { + "teal": 2331, + "source": "tests/contracts/general.algo.ts:465", + "pc": [ + 4843, + 4844 + ] + }, + { + "teal": 2332, + "source": "tests/contracts/general.algo.ts:465", + "pc": [ + 4845 + ] + }, + { + "teal": 2333, + "source": "tests/contracts/general.algo.ts:465", + "pc": [ + 4846, + 4847, + 4848 + ] + }, + { + "teal": 2334, + "source": "tests/contracts/general.algo.ts:465", + "pc": [ + 4849 + ] + }, + { + "teal": 2335, + "source": "tests/contracts/general.algo.ts:465", + "pc": [ + 4850 + ] + }, + { + "teal": 2336, + "source": "tests/contracts/general.algo.ts:462", + "pc": [ + 4851 + ] + }, + { + "teal": 2341, + "source": "tests/contracts/general.algo.ts:468", + "pc": [ + 4852, + 4853, + 4854 + ] + }, + { + "teal": 2342, + "source": "tests/contracts/general.algo.ts:468", + "pc": [ + 4855, + 4856 + ] + }, + { + "teal": 2343, + "source": "tests/contracts/general.algo.ts:468", + "pc": [ + 4857 + ] + }, + { + "teal": 2347, + "source": "tests/contracts/general.algo.ts:468", + "pc": [ + 4858, + 4859, + 4860 + ] + }, + { + "teal": 2350, + "source": "tests/contracts/general.algo.ts:468", + "pc": [ + 4861, + 4862 + ] + }, + { + "teal": 2354, + "source": "tests/contracts/general.algo.ts:469", + "pc": [ + 4863, + 4864, + 4865, + 4866, + 4867, + 4868, + 4869, + 4870, + 4871, + 4872, + 4873, + 4874, + 4875, + 4876, + 4877, + 4878, + 4879, + 4880, + 4881, + 4882, + 4883, + 4884, + 4885, + 4886, + 4887, + 4888, + 4889, + 4890, + 4891, + 4892, + 4893, + 4894, + 4895, + 4896 + ] + }, + { + "teal": 2355, + "source": "tests/contracts/general.algo.ts:469", + "pc": [ + 4897, + 4898 + ] + }, + { + "teal": 2359, + "source": "tests/contracts/general.algo.ts:470", + "pc": [ + 4899, + 4900 + ] + }, + { + "teal": 2360, + "source": "tests/contracts/general.algo.ts:470", + "pc": [ + 4901, + 4902 + ] + }, + { + "teal": 2361, + "source": "tests/contracts/general.algo.ts:470", + "pc": [ + 4903 + ] + }, + { + "teal": 2362, + "source": "tests/contracts/general.algo.ts:470", + "pc": [ + 4904 + ] + }, + { + "teal": 2363, + "source": "tests/contracts/general.algo.ts:468", + "pc": [ + 4905 + ] + }, + { + "teal": 2368, + "source": "tests/contracts/general.algo.ts:473", + "pc": [ + 4906, + 4907, + 4908, + 4909, + 4910, + 4911 + ] + }, + { + "teal": 2371, + "source": "tests/contracts/general.algo.ts:473", + "pc": [ + 4912, + 4913, + 4914 + ] + }, + { + "teal": 2372, + "source": "tests/contracts/general.algo.ts:473", + "pc": [ + 4915 + ] + }, + { + "teal": 2375, + "source": "tests/contracts/general.algo.ts:473", + "pc": [ + 4916, + 4917, + 4918 + ] + }, + { + "teal": 2376, + "source": "tests/contracts/general.algo.ts:473", + "pc": [ + 4919 + ] + }, + { + "teal": 2377, + "source": "tests/contracts/general.algo.ts:473", + "pc": [ + 4920 + ] + }, + { + "teal": 2378, + "source": "tests/contracts/general.algo.ts:473", + "pc": [ + 4921 + ] + }, + { + "teal": 2379, + "source": "tests/contracts/general.algo.ts:473", + "pc": [ + 4922, + 4923 + ] + }, + { + "teal": 2380, + "source": "tests/contracts/general.algo.ts:473", + "pc": [ + 4924 + ] + }, + { + "teal": 2384, + "source": "tests/contracts/general.algo.ts:473", + "pc": [ + 4925, + 4926, + 4927 + ] + }, + { + "teal": 2387, + "source": "tests/contracts/general.algo.ts:473", + "pc": [ + 4928, + 4929 + ] + }, + { + "teal": 2392, + "source": "tests/contracts/general.algo.ts:474", + "pc": [ + 4930, + 4931 + ] + }, + { + "teal": 2393, + "source": "tests/contracts/general.algo.ts:474", + "pc": [ + 4932, + 4933 + ] + }, + { + "teal": 2394, + "source": "tests/contracts/general.algo.ts:474", + "pc": [ + 4934 + ] + }, + { + "teal": 2395, + "source": "tests/contracts/general.algo.ts:474", + "pc": [ + 4935, + 4936, + 4937 + ] + }, + { + "teal": 2400, + "source": "tests/contracts/general.algo.ts:475", + "pc": [ + 4938, + 4939 + ] + }, + { + "teal": 2401, + "source": "tests/contracts/general.algo.ts:475", + "pc": [ + 4940, + 4941, + 4942 + ] + }, + { + "teal": 2406, + "source": "tests/contracts/general.algo.ts:477", + "pc": [ + 4943, + 4944 + ] + }, + { + "teal": 2407, + "source": "tests/contracts/general.algo.ts:477", + "pc": [ + 4945, + 4946 + ] + }, + { + "teal": 2408, + "source": "tests/contracts/general.algo.ts:477", + "pc": [ + 4947 + ] + }, + { + "teal": 2409, + "source": "tests/contracts/general.algo.ts:477", + "pc": [ + 4948, + 4949 + ] + }, + { + "teal": 2413, + "source": "tests/contracts/general.algo.ts:478", + "pc": [ + 4950, + 4951 + ] + }, + { + "teal": 2417, + "source": "tests/contracts/general.algo.ts:473", + "pc": [ + 4952, + 4953 + ] + }, + { + "teal": 2418, + "source": "tests/contracts/general.algo.ts:473", + "pc": [ + 4954 + ] + }, + { + "teal": 2423, + "source": "tests/contracts/general.algo.ts:481", + "pc": [ + 4955, + 4956, + 4957 + ] + }, + { + "teal": 2424, + "source": "tests/contracts/general.algo.ts:481", + "pc": [ + 4958, + 4959 + ] + }, + { + "teal": 2425, + "source": "tests/contracts/general.algo.ts:481", + "pc": [ + 4960 + ] + }, + { + "teal": 2429, + "source": "tests/contracts/general.algo.ts:481", + "pc": [ + 4961, + 4962, + 4963 + ] + }, + { + "teal": 2436, + "source": "tests/contracts/general.algo.ts:482", + "pc": [ + 4964 + ] + }, + { + "teal": 2437, + "source": "tests/contracts/general.algo.ts:482", + "pc": [ + 4965, + 4966 + ] + }, + { + "teal": 2438, + "source": "tests/contracts/general.algo.ts:482", + "pc": [ + 4967, + 4968 + ] + }, + { + "teal": 2439, + "source": "tests/contracts/general.algo.ts:483", + "pc": [ + 4969, + 4970, + 4971, + 4972, + 4973, + 4974 + ] + }, + { + "teal": 2440, + "source": "tests/contracts/general.algo.ts:483", + "pc": [ + 4975, + 4976 + ] + }, + { + "teal": 2444, + "source": "tests/contracts/general.algo.ts:484", + "pc": [ + 4977, + 4978 + ] + }, + { + "teal": 2445, + "source": "tests/contracts/general.algo.ts:484", + "pc": [ + 4979, + 4980 + ] + }, + { + "teal": 2446, + "source": "tests/contracts/general.algo.ts:484", + "pc": [ + 4981, + 4982, + 4983, + 4984, + 4985, + 4986, + 4987, + 4988, + 4989, + 4990 + ] + }, + { + "teal": 2447, + "source": "tests/contracts/general.algo.ts:484", + "pc": [ + 4991, + 4992 + ] + }, + { + "teal": 2450, + "source": "tests/contracts/general.algo.ts:482", + "pc": [ + 4993, + 4994 + ] + }, + { + "teal": 2451, + "source": "tests/contracts/general.algo.ts:482", + "pc": [ + 4995, + 4996 + ] + }, + { + "teal": 2454, + "source": "tests/contracts/general.algo.ts:482", + "pc": [ + 4997 + ] + }, + { + "teal": 2455, + "source": "tests/contracts/general.algo.ts:481", + "pc": [ + 4998 + ] + }, + { + "teal": 2460, + "source": "tests/contracts/general.algo.ts:492", + "pc": [ + 4999, + 5000, + 5001 + ] + }, + { + "teal": 2461, + "source": "tests/contracts/general.algo.ts:492", + "pc": [ + 5002, + 5003 + ] + }, + { + "teal": 2462, + "source": "tests/contracts/general.algo.ts:492", + "pc": [ + 5004 + ] + }, + { + "teal": 2466, + "source": "tests/contracts/general.algo.ts:492", + "pc": [ + 5005, + 5006, + 5007 + ] + }, + { + "teal": 2473, + "source": "tests/contracts/general.algo.ts:493", + "pc": [ + 5008 + ] + }, + { + "teal": 2474, + "source": "tests/contracts/general.algo.ts:493", + "pc": [ + 5009, + 5010 + ] + }, + { + "teal": 2475, + "source": "tests/contracts/general.algo.ts:493", + "pc": [ + 5011, + 5012 + ] + }, + { + "teal": 2479, + "source": "tests/contracts/general.algo.ts:494", + "pc": [ + 5013, + 5014, + 5015, + 5016, + 5017, + 5018, + 5019, + 5020, + 5021 + ] + }, + { + "teal": 2480, + "source": "tests/contracts/general.algo.ts:494", + "pc": [ + 5022 + ] + }, + { + "teal": 2483, + "source": "tests/contracts/general.algo.ts:494", + "errorMessage": "box value does not exist: this.pageOne.value", + "pc": [ + 5023 + ] + }, + { + "teal": 2484, + "source": "tests/contracts/general.algo.ts:494", + "pc": [ + 5024, + 5025 + ] + }, + { + "teal": 2485, + "source": "tests/contracts/general.algo.ts:494", + "pc": [ + 5026, + 5027, + 5028, + 5029, + 5030, + 5031, + 5032, + 5033, + 5034 + ] + }, + { + "teal": 2486, + "source": "tests/contracts/general.algo.ts:494", + "pc": [ + 5035 + ] + }, + { + "teal": 2489, + "source": "tests/contracts/general.algo.ts:494", + "errorMessage": "box value does not exist: this.pageTwo.value", + "pc": [ + 5036 + ] + }, + { + "teal": 2490, + "source": "tests/contracts/general.algo.ts:494", + "pc": [ + 5037, + 5038 + ] + }, + { + "teal": 2494, + "source": "tests/contracts/general.algo.ts:495", + "pc": [ + 5039, + 5040, + 5041, + 5042, + 5043, + 5044, + 5045, + 5046, + 5047 + ] + }, + { + "teal": 2495, + "source": "tests/contracts/general.algo.ts:495", + "pc": [ + 5048 + ] + }, + { + "teal": 2498, + "source": "tests/contracts/general.algo.ts:495", + "errorMessage": "box value does not exist: this.pageOne.value", + "pc": [ + 5049 + ] + }, + { + "teal": 2499, + "source": "tests/contracts/general.algo.ts:495", + "pc": [ + 5050, + 5051 + ] + }, + { + "teal": 2500, + "source": "tests/contracts/general.algo.ts:495", + "pc": [ + 5052, + 5053, + 5054, + 5055, + 5056, + 5057, + 5058, + 5059, + 5060 + ] + }, + { + "teal": 2501, + "source": "tests/contracts/general.algo.ts:495", + "pc": [ + 5061 + ] + }, + { + "teal": 2504, + "source": "tests/contracts/general.algo.ts:495", + "errorMessage": "box value does not exist: this.pageTwo.value", + "pc": [ + 5062 + ] + }, + { + "teal": 2505, + "source": "tests/contracts/general.algo.ts:495", + "pc": [ + 5063, + 5064 + ] + }, + { + "teal": 2508, + "source": "tests/contracts/general.algo.ts:493", + "pc": [ + 5065, + 5066 + ] + }, + { + "teal": 2509, + "source": "tests/contracts/general.algo.ts:493", + "pc": [ + 5067, + 5068 + ] + }, + { + "teal": 2512, + "source": "tests/contracts/general.algo.ts:493", + "pc": [ + 5069 + ] + }, + { + "teal": 2513, + "source": "tests/contracts/general.algo.ts:492", + "pc": [ + 5070 + ] + }, + { + "teal": 2518, + "source": "tests/contracts/general.algo.ts:499", + "pc": [ + 5071, + 5072, + 5073 + ] + }, + { + "teal": 2519, + "source": "tests/contracts/general.algo.ts:499", + "pc": [ + 5074, + 5075 + ] + }, + { + "teal": 2520, + "source": "tests/contracts/general.algo.ts:499", + "pc": [ + 5076 + ] + }, + { + "teal": 2524, + "source": "tests/contracts/general.algo.ts:499", + "pc": [ + 5077, + 5078, + 5079 + ] + }, + { + "teal": 2528, + "source": "tests/contracts/general.algo.ts:500", + "pc": [ + 5080, + 5081 + ] + }, + { + "teal": 2531, + "source": "tests/contracts/general.algo.ts:500", + "errorMessage": "this is false", + "pc": [ + 5082 + ] + }, + { + "teal": 2532, + "source": "tests/contracts/general.algo.ts:499", + "pc": [ + 5083 + ] + }, + { + "teal": 2537, + "source": "tests/contracts/general.algo.ts:503", + "pc": [ + 5084, + 5085, + 5086 + ] + }, + { + "teal": 2538, + "source": "tests/contracts/general.algo.ts:503", + "pc": [ + 5087, + 5088 + ] + }, + { + "teal": 2539, + "source": "tests/contracts/general.algo.ts:503", + "pc": [ + 5089 + ] + }, + { + "teal": 2543, + "source": "tests/contracts/general.algo.ts:503", + "pc": [ + 5090, + 5091, + 5092 + ] + }, + { + "teal": 2546, + "source": "tests/contracts/general.algo.ts:504", + "errorMessage": "this is an error", + "pc": [ + 5093 + ] + }, + { + "teal": 2547, + "source": "tests/contracts/general.algo.ts:503", + "pc": [ + 5094 + ] + }, + { + "teal": 2552, + "source": "tests/contracts/general.algo.ts:507", + "pc": [ + 5095, + 5096, + 5097 + ] + }, + { + "teal": 2553, + "source": "tests/contracts/general.algo.ts:507", + "pc": [ + 5098 + ] + }, + { + "teal": 2556, + "source": "tests/contracts/general.algo.ts:507", + "pc": [ + 5099, + 5100, + 5101 + ] + }, + { + "teal": 2557, + "source": "tests/contracts/general.algo.ts:507", + "pc": [ + 5102 + ] + }, + { + "teal": 2560, + "source": "tests/contracts/general.algo.ts:507", + "pc": [ + 5103, + 5104, + 5105 + ] + }, + { + "teal": 2561, + "source": "tests/contracts/general.algo.ts:507", + "pc": [ + 5106, + 5107 + ] + }, + { + "teal": 2562, + "source": "tests/contracts/general.algo.ts:507", + "pc": [ + 5108 + ] + }, + { + "teal": 2566, + "source": "tests/contracts/general.algo.ts:507", + "pc": [ + 5109, + 5110, + 5111 + ] + }, + { + "teal": 2569, + "source": "tests/contracts/general.algo.ts:507", + "pc": [ + 5112, + 5113 + ] + }, + { + "teal": 2570, + "source": "tests/contracts/general.algo.ts:507", + "pc": [ + 5114 + ] + }, + { + "teal": 2574, + "source": "tests/contracts/general.algo.ts:508", + "pc": [ + 5115, + 5116 + ] + }, + { + "teal": 2575, + "source": "tests/contracts/general.algo.ts:508", + "pc": [ + 5117 + ] + }, + { + "teal": 2576, + "source": "tests/contracts/general.algo.ts:508", + "pc": [ + 5118, + 5119, + 5120 + ] + }, + { + "teal": 2577, + "source": "tests/contracts/general.algo.ts:508", + "pc": [ + 5121, + 5122 + ] + }, + { + "teal": 2578, + "source": "tests/contracts/general.algo.ts:508", + "pc": [ + 5123, + 5124 + ] + }, + { + "teal": 2579, + "source": "tests/contracts/general.algo.ts:508", + "pc": [ + 5125 + ] + }, + { + "teal": 2580, + "source": "tests/contracts/general.algo.ts:508", + "pc": [ + 5126 + ] + }, + { + "teal": 2583, + "source": "tests/contracts/general.algo.ts:508", + "pc": [ + 5127, + 5128, + 5129 + ] + }, + { + "teal": 2584, + "source": "tests/contracts/general.algo.ts:508", + "pc": [ + 5130, + 5131 + ] + }, + { + "teal": 2585, + "source": "tests/contracts/general.algo.ts:508", + "pc": [ + 5132, + 5133, + 5134 + ] + }, + { + "teal": 2588, + "source": "tests/contracts/general.algo.ts:508", + "pc": [ + 5135, + 5136 + ] + }, + { + "teal": 2591, + "source": "tests/contracts/general.algo.ts:508", + "pc": [ + 5137, + 5138 + ] + }, + { + "teal": 2595, + "source": "tests/contracts/general.algo.ts:509", + "pc": [ + 5139, + 5140 + ] + }, + { + "teal": 2596, + "source": "tests/contracts/general.algo.ts:509", + "pc": [ + 5141 + ] + }, + { + "teal": 2600, + "source": "tests/contracts/general.algo.ts:511", + "pc": [ + 5142, + 5143 + ] + }, + { + "teal": 2601, + "source": "tests/contracts/general.algo.ts:511", + "pc": [ + 5144 + ] + }, + { + "teal": 2602, + "source": "tests/contracts/general.algo.ts:511", + "pc": [ + 5145, + 5146, + 5147 + ] + }, + { + "teal": 2603, + "source": "tests/contracts/general.algo.ts:511", + "pc": [ + 5148, + 5149 + ] + }, + { + "teal": 2604, + "source": "tests/contracts/general.algo.ts:511", + "pc": [ + 5150, + 5151 + ] + }, + { + "teal": 2605, + "source": "tests/contracts/general.algo.ts:511", + "pc": [ + 5152 + ] + }, + { + "teal": 2606, + "source": "tests/contracts/general.algo.ts:511", + "pc": [ + 5153 + ] + }, + { + "teal": 2609, + "source": "tests/contracts/general.algo.ts:511", + "pc": [ + 5154, + 5155, + 5156 + ] + }, + { + "teal": 2610, + "source": "tests/contracts/general.algo.ts:511", + "pc": [ + 5157, + 5158, + 5159 + ] + }, + { + "teal": 2611, + "source": "tests/contracts/general.algo.ts:511", + "pc": [ + 5160, + 5161, + 5162 + ] + }, + { + "teal": 2614, + "source": "tests/contracts/general.algo.ts:511", + "pc": [ + 5163, + 5164, + 5165 + ] + }, + { + "teal": 2617, + "source": "tests/contracts/general.algo.ts:511", + "pc": [ + 5166, + 5167 + ] + }, + { + "teal": 2621, + "source": "tests/contracts/general.algo.ts:512", + "pc": [ + 5168, + 5169 + ] + }, + { + "teal": 2622, + "source": "tests/contracts/general.algo.ts:512", + "pc": [ + 5170 + ] + }, + { + "teal": 2623, + "source": "tests/contracts/general.algo.ts:507", + "pc": [ + 5171 + ] + }, + { + "teal": 2627, + "source": "tests/contracts/general.algo.ts:515", + "pc": [ + 5172, + 5173, + 5174 + ] + }, + { + "teal": 2630, + "source": "tests/contracts/general.algo.ts:515", + "pc": [ + 5175, + 5176 + ] + }, + { + "teal": 2634, + "source": "tests/contracts/general.algo.ts:517", + "pc": [ + 5177, + 5178 + ] + }, + { + "teal": 2635, + "source": "tests/contracts/general.algo.ts:517", + "pc": [ + 5179 + ] + }, + { + "teal": 2639, + "source": "tests/contracts/general.algo.ts:519", + "pc": [ + 5180, + 5181 + ] + }, + { + "teal": 2640, + "source": "tests/contracts/general.algo.ts:519", + "pc": [ + 5182, + 5183 + ] + }, + { + "teal": 2645, + "source": "tests/contracts/general.algo.ts:519", + "pc": [ + 5184, + 5185 + ] + }, + { + "teal": 2646, + "source": "tests/contracts/general.algo.ts:519", + "pc": [ + 5186, + 5187 + ] + }, + { + "teal": 2647, + "source": "tests/contracts/general.algo.ts:519", + "pc": [ + 5188 + ] + }, + { + "teal": 2648, + "source": "tests/contracts/general.algo.ts:519", + "pc": [ + 5189, + 5190, + 5191 + ] + }, + { + "teal": 2652, + "source": "tests/contracts/general.algo.ts:520", + "pc": [ + 5192, + 5193 + ] + }, + { + "teal": 2653, + "source": "tests/contracts/general.algo.ts:520", + "pc": [ + 5194, + 5195 + ] + }, + { + "teal": 2654, + "source": "tests/contracts/general.algo.ts:520", + "pc": [ + 5196 + ] + }, + { + "teal": 2659, + "source": "tests/contracts/general.algo.ts:519", + "pc": [ + 5197, + 5198 + ] + }, + { + "teal": 2660, + "source": "tests/contracts/general.algo.ts:519", + "pc": [ + 5199, + 5200 + ] + }, + { + "teal": 2661, + "source": "tests/contracts/general.algo.ts:519", + "pc": [ + 5201 + ] + }, + { + "teal": 2662, + "source": "tests/contracts/general.algo.ts:519", + "pc": [ + 5202, + 5203 + ] + }, + { + "teal": 2663, + "source": "tests/contracts/general.algo.ts:519", + "pc": [ + 5204, + 5205, + 5206 + ] + }, + { + "teal": 2666, + "source": "tests/contracts/general.algo.ts:515", + "pc": [ + 5207 + ] + }, + { + "teal": 2671, + "source": "tests/contracts/general.algo.ts:524", + "pc": [ + 5208, + 5209, + 5210 + ] + }, + { + "teal": 2672, + "source": "tests/contracts/general.algo.ts:524", + "pc": [ + 5211, + 5212 + ] + }, + { + "teal": 2673, + "source": "tests/contracts/general.algo.ts:524", + "pc": [ + 5213 + ] + }, + { + "teal": 2677, + "source": "tests/contracts/general.algo.ts:524", + "pc": [ + 5214, + 5215, + 5216 + ] + }, + { + "teal": 2680, + "source": "tests/contracts/general.algo.ts:524", + "pc": [ + 5217, + 5218 + ] + }, + { + "teal": 2681, + "source": "tests/contracts/general.algo.ts:524", + "pc": [ + 5219 + ] + }, + { + "teal": 2685, + "source": "tests/contracts/general.algo.ts:525", + "pc": [ + 5220, + 5221 + ] + }, + { + "teal": 2686, + "source": "tests/contracts/general.algo.ts:525", + "pc": [ + 5222, + 5223 + ] + }, + { + "teal": 2690, + "source": "tests/contracts/general.algo.ts:526", + "pc": [ + 5224, + 5225 + ] + }, + { + "teal": 2691, + "source": "tests/contracts/general.algo.ts:526", + "pc": [ + 5226, + 5227 + ] + }, + { + "teal": 2698, + "source": "tests/contracts/general.algo.ts:528", + "pc": [ + 5228, + 5229 + ] + }, + { + "teal": 2699, + "source": "tests/contracts/general.algo.ts:528", + "pc": [ + 5230, + 5231 + ] + }, + { + "teal": 2700, + "source": "tests/contracts/general.algo.ts:528", + "pc": [ + 5232, + 5233, + 5234, + 5235, + 5236 + ] + }, + { + "teal": 2701, + "source": "tests/contracts/general.algo.ts:528", + "pc": [ + 5237 + ] + }, + { + "teal": 2704, + "source": "tests/contracts/general.algo.ts:528", + "errorMessage": "local state value does not exist: app.localState( addr, 'key' )", + "pc": [ + 5238 + ] + }, + { + "teal": 2705, + "source": "tests/contracts/general.algo.ts:524", + "pc": [ + 5239 + ] + }, + { + "teal": 2710, + "source": "tests/contracts/general.algo.ts:534", + "pc": [ + 5240, + 5241, + 5242, + 5243, + 5244, + 5245 + ] + }, + { + "teal": 2713, + "source": "tests/contracts/general.algo.ts:534", + "pc": [ + 5246, + 5247, + 5248 + ] + }, + { + "teal": 2714, + "source": "tests/contracts/general.algo.ts:534", + "pc": [ + 5249 + ] + }, + { + "teal": 2715, + "source": "tests/contracts/general.algo.ts:534", + "pc": [ + 5250 + ] + }, + { + "teal": 2716, + "source": "tests/contracts/general.algo.ts:534", + "pc": [ + 5251 + ] + }, + { + "teal": 2717, + "source": "tests/contracts/general.algo.ts:534", + "pc": [ + 5252, + 5253 + ] + }, + { + "teal": 2718, + "source": "tests/contracts/general.algo.ts:534", + "pc": [ + 5254 + ] + }, + { + "teal": 2722, + "source": "tests/contracts/general.algo.ts:534", + "pc": [ + 5255, + 5256, + 5257 + ] + }, + { + "teal": 2726, + "source": "tests/contracts/general.algo.ts:535", + "pc": [ + 5258, + 5259 + ] + }, + { + "teal": 2727, + "source": "tests/contracts/general.algo.ts:534", + "pc": [ + 5260 + ] + }, + { + "teal": 2732, + "source": "tests/contracts/general.algo.ts:538", + "pc": [ + 5261, + 5262, + 5263, + 5264, + 5265, + 5266 + ] + }, + { + "teal": 2735, + "source": "tests/contracts/general.algo.ts:538", + "pc": [ + 5267, + 5268, + 5269 + ] + }, + { + "teal": 2736, + "source": "tests/contracts/general.algo.ts:538", + "pc": [ + 5270 + ] + }, + { + "teal": 2737, + "source": "tests/contracts/general.algo.ts:538", + "pc": [ + 5271 + ] + }, + { + "teal": 2738, + "source": "tests/contracts/general.algo.ts:538", + "pc": [ + 5272 + ] + }, + { + "teal": 2739, + "source": "tests/contracts/general.algo.ts:538", + "pc": [ + 5273, + 5274 + ] + }, + { + "teal": 2740, + "source": "tests/contracts/general.algo.ts:538", + "pc": [ + 5275 + ] + }, + { + "teal": 2744, + "source": "tests/contracts/general.algo.ts:538", + "pc": [ + 5276, + 5277, + 5278 + ] + }, + { + "teal": 2748, + "source": "tests/contracts/general.algo.ts:539", + "pc": [ + 5279, + 5280 + ] + }, + { + "teal": 2749, + "source": "tests/contracts/general.algo.ts:538", + "pc": [ + 5281 + ] + }, + { + "teal": 2754, + "source": "tests/contracts/general.algo.ts:542", + "pc": [ + 5282, + 5283, + 5284, + 5285, + 5286, + 5287 + ] + }, + { + "teal": 2757, + "source": "tests/contracts/general.algo.ts:542", + "pc": [ + 5288, + 5289, + 5290 + ] + }, + { + "teal": 2758, + "source": "tests/contracts/general.algo.ts:542", + "pc": [ + 5291 + ] + }, + { + "teal": 2759, + "source": "tests/contracts/general.algo.ts:542", + "pc": [ + 5292 + ] + }, + { + "teal": 2760, + "source": "tests/contracts/general.algo.ts:542", + "pc": [ + 5293 + ] + }, + { + "teal": 2761, + "source": "tests/contracts/general.algo.ts:542", + "pc": [ + 5294, + 5295 + ] + }, + { + "teal": 2762, + "source": "tests/contracts/general.algo.ts:542", + "pc": [ + 5296 + ] + }, + { + "teal": 2766, + "source": "tests/contracts/general.algo.ts:542", + "pc": [ + 5297, + 5298, + 5299 + ] + }, + { + "teal": 2770, + "source": "tests/contracts/general.algo.ts:543", + "pc": [ + 5300, + 5301, + 5302 + ] + }, + { + "teal": 2771, + "source": "tests/contracts/general.algo.ts:543", + "pc": [ + 5303 + ] + }, + { + "teal": 2775, + "source": "tests/contracts/general.algo.ts:544", + "pc": [ + 5304, + 5305, + 5306 + ] + }, + { + "teal": 2776, + "source": "tests/contracts/general.algo.ts:542", + "pc": [ + 5307 + ] + }, + { + "teal": 2781, + "source": "tests/contracts/general.algo.ts:554", + "pc": [ + 5308, + 5309, + 5310, + 5311, + 5312, + 5313 + ] + }, + { + "teal": 2784, + "source": "tests/contracts/general.algo.ts:554", + "pc": [ + 5314, + 5315, + 5316 + ] + }, + { + "teal": 2785, + "source": "tests/contracts/general.algo.ts:554", + "pc": [ + 5317 + ] + }, + { + "teal": 2786, + "source": "tests/contracts/general.algo.ts:554", + "pc": [ + 5318 + ] + }, + { + "teal": 2787, + "source": "tests/contracts/general.algo.ts:554", + "pc": [ + 5319 + ] + }, + { + "teal": 2788, + "source": "tests/contracts/general.algo.ts:554", + "pc": [ + 5320, + 5321 + ] + }, + { + "teal": 2789, + "source": "tests/contracts/general.algo.ts:554", + "pc": [ + 5322 + ] + }, + { + "teal": 2793, + "source": "tests/contracts/general.algo.ts:554", + "pc": [ + 5323, + 5324, + 5325 + ] + }, + { + "teal": 2796, + "source": "tests/contracts/general.algo.ts:554", + "pc": [ + 5326, + 5327 + ] + }, + { + "teal": 2797, + "source": "tests/contracts/general.algo.ts:554", + "pc": [ + 5328 + ] + }, + { + "teal": 2801, + "source": "tests/contracts/general.algo.ts:555", + "pc": [ + 5329, + 5330 + ] + }, + { + "teal": 2802, + "source": "tests/contracts/general.algo.ts:555", + "pc": [ + 5331, + 5332 + ] + }, + { + "teal": 2806, + "source": "tests/contracts/general.algo.ts:556", + "pc": [ + 5333, + 5334, + 5335 + ] + }, + { + "teal": 2807, + "source": "tests/contracts/general.algo.ts:556", + "pc": [ + 5336, + 5337 + ] + }, + { + "teal": 2812, + "source": "tests/contracts/general.algo.ts:557", + "pc": [ + 5338, + 5339 + ] + }, + { + "teal": 2813, + "source": "tests/contracts/general.algo.ts:557", + "pc": [ + 5340, + 5341, + 5342 + ] + }, + { + "teal": 2818, + "source": "tests/contracts/general.algo.ts:558", + "pc": [ + 5343, + 5344 + ] + }, + { + "teal": 2819, + "source": "tests/contracts/general.algo.ts:558", + "pc": [ + 5345, + 5346 + ] + }, + { + "teal": 2824, + "source": "tests/contracts/general.algo.ts:561", + "pc": [ + 5347, + 5348 + ] + }, + { + "teal": 2827, + "source": "tests/contracts/general.algo.ts:554", + "pc": [ + 5349, + 5350 + ] + }, + { + "teal": 2830, + "source": "tests/contracts/general.algo.ts:554", + "pc": [ + 5351, + 5352 + ] + }, + { + "teal": 2831, + "source": "tests/contracts/general.algo.ts:554", + "pc": [ + 5353 + ] + }, + { + "teal": 2836, + "source": "tests/contracts/general.algo.ts:564", + "pc": [ + 5354, + 5355, + 5356 + ] + }, + { + "teal": 2837, + "source": "tests/contracts/general.algo.ts:564", + "pc": [ + 5357, + 5358 + ] + }, + { + "teal": 2838, + "source": "tests/contracts/general.algo.ts:564", + "pc": [ + 5359 + ] + }, + { + "teal": 2842, + "source": "tests/contracts/general.algo.ts:564", + "pc": [ + 5360, + 5361, + 5362 + ] + }, + { + "teal": 2846, + "source": "tests/contracts/general.algo.ts:565", + "pc": [ + 5363, + 5364 + ] + }, + { + "teal": 2847, + "source": "tests/contracts/general.algo.ts:565", + "pc": [ + 5365 + ] + }, + { + "teal": 2851, + "source": "tests/contracts/general.algo.ts:566", + "pc": [ + 5366, + 5367 + ] + }, + { + "teal": 2852, + "source": "tests/contracts/general.algo.ts:566", + "pc": [ + 5368 + ] + }, + { + "teal": 2853, + "source": "tests/contracts/general.algo.ts:564", + "pc": [ + 5369 + ] + }, + { + "teal": 2856, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5370, + 5371 + ] + }, + { + "teal": 2857, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5372 + ] + }, + { + "teal": 2860, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5373, + 5374, + 5375, + 5376, + 5377, + 5378 + ] + }, + { + "teal": 2861, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5379, + 5380, + 5381 + ] + }, + { + "teal": 2862, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5382, + 5383, + 5384, + 5385 + ] + }, + { + "teal": 2865, + "source": "tests/contracts/general.algo.ts:57", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", + "pc": [ + 5386 + ] + }, + { + "teal": 2868, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5387, + 5388, + 5389, + 5390, + 5391, + 5392 + ] + }, + { + "teal": 2869, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5393, + 5394, + 5395, + 5396, + 5397, + 5398 + ] + }, + { + "teal": 2870, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5399, + 5400, + 5401, + 5402, + 5403, + 5404 + ] + }, + { + "teal": 2871, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5405, + 5406, + 5407, + 5408, + 5409, + 5410 + ] + }, + { + "teal": 2872, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5411, + 5412, + 5413, + 5414, + 5415, + 5416 + ] + }, + { + "teal": 2873, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5417, + 5418, + 5419, + 5420, + 5421, + 5422 + ] + }, + { + "teal": 2874, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5423, + 5424, + 5425, + 5426, + 5427, + 5428 + ] + }, + { + "teal": 2875, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5429, + 5430, + 5431, + 5432, + 5433, + 5434 + ] + }, + { + "teal": 2876, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5435, + 5436, + 5437, + 5438, + 5439, + 5440 + ] + }, + { + "teal": 2877, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5441, + 5442, + 5443, + 5444, + 5445, + 5446 + ] + }, + { + "teal": 2878, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5447, + 5448, + 5449, + 5450, + 5451, + 5452 + ] + }, + { + "teal": 2879, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5453, + 5454, + 5455, + 5456, + 5457, + 5458 + ] + }, + { + "teal": 2880, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5459, + 5460, + 5461, + 5462, + 5463, + 5464 + ] + }, + { + "teal": 2881, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5465, + 5466, + 5467, + 5468, + 5469, + 5470 + ] + }, + { + "teal": 2882, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5471, + 5472, + 5473, + 5474, + 5475, + 5476 + ] + }, + { + "teal": 2883, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5477, + 5478, + 5479, + 5480, + 5481, + 5482 + ] + }, + { + "teal": 2884, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5483, + 5484, + 5485, + 5486, + 5487, + 5488 + ] + }, + { + "teal": 2885, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5489, + 5490, + 5491, + 5492, + 5493, + 5494 + ] + }, + { + "teal": 2886, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5495, + 5496, + 5497, + 5498, + 5499, + 5500 + ] + }, + { + "teal": 2887, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5501, + 5502, + 5503, + 5504, + 5505, + 5506 + ] + }, + { + "teal": 2888, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5507, + 5508, + 5509, + 5510, + 5511, + 5512 + ] + }, + { + "teal": 2889, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5513, + 5514, + 5515, + 5516, + 5517, + 5518 + ] + }, + { + "teal": 2890, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5519, + 5520, + 5521, + 5522, + 5523, + 5524 + ] + }, + { + "teal": 2891, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5525, + 5526, + 5527, + 5528, + 5529, + 5530 + ] + }, + { + "teal": 2892, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5531, + 5532, + 5533, + 5534, + 5535, + 5536 + ] + }, + { + "teal": 2893, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5537, + 5538, + 5539, + 5540, + 5541, + 5542 + ] + }, + { + "teal": 2894, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5543, + 5544, + 5545, + 5546, + 5547, + 5548 + ] + }, + { + "teal": 2895, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5549, + 5550, + 5551, + 5552, + 5553, + 5554 + ] + }, + { + "teal": 2896, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5555, + 5556, + 5557, + 5558, + 5559, + 5560 + ] + }, + { + "teal": 2897, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5561, + 5562, + 5563, + 5564, + 5565, + 5566 + ] + }, + { + "teal": 2898, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5567, + 5568, + 5569, + 5570, + 5571, + 5572 + ] + }, + { + "teal": 2899, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5573, + 5574, + 5575, + 5576, + 5577, + 5578 + ] + }, + { + "teal": 2900, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5579, + 5580, + 5581, + 5582, + 5583, + 5584 + ] + }, + { + "teal": 2901, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5585, + 5586, + 5587, + 5588, + 5589, + 5590 + ] + }, + { + "teal": 2902, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5591, + 5592, + 5593, + 5594, + 5595, + 5596 + ] + }, + { + "teal": 2903, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5597, + 5598, + 5599, + 5600, + 5601, + 5602 + ] + }, + { + "teal": 2904, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5603, + 5604, + 5605, + 5606, + 5607, + 5608 + ] + }, + { + "teal": 2905, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5609, + 5610, + 5611, + 5612, + 5613, + 5614 + ] + }, + { + "teal": 2906, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5615, + 5616, + 5617, + 5618, + 5619, + 5620 + ] + }, + { + "teal": 2907, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5621, + 5622, + 5623, + 5624, + 5625, + 5626 + ] + }, + { + "teal": 2908, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5627, + 5628, + 5629, + 5630, + 5631, + 5632 + ] + }, + { + "teal": 2909, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5633, + 5634, + 5635, + 5636, + 5637, + 5638 + ] + }, + { + "teal": 2910, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5639, + 5640, + 5641, + 5642, + 5643, + 5644 + ] + }, + { + "teal": 2911, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5645, + 5646, + 5647, + 5648, + 5649, + 5650 + ] + }, + { + "teal": 2912, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5651, + 5652, + 5653, + 5654, + 5655, + 5656 + ] + }, + { + "teal": 2913, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5657, + 5658, + 5659, + 5660, + 5661, + 5662 + ] + }, + { + "teal": 2914, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5663, + 5664, + 5665, + 5666, + 5667, + 5668 + ] + }, + { + "teal": 2915, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5669, + 5670, + 5671, + 5672, + 5673, + 5674 + ] + }, + { + "teal": 2916, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5675, + 5676, + 5677, + 5678, + 5679, + 5680 + ] + }, + { + "teal": 2917, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5681, + 5682, + 5683, + 5684, + 5685, + 5686 + ] + }, + { + "teal": 2918, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5687, + 5688, + 5689, + 5690, + 5691, + 5692 + ] + }, + { + "teal": 2919, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5693, + 5694, + 5695, + 5696, + 5697, + 5698 + ] + }, + { + "teal": 2920, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5699, + 5700, + 5701, + 5702, + 5703, + 5704 + ] + }, + { + "teal": 2921, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5705, + 5706, + 5707, + 5708, + 5709, + 5710 + ] + }, + { + "teal": 2922, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5711, + 5712, + 5713, + 5714, + 5715, + 5716 + ] + }, + { + "teal": 2923, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5717, + 5718, + 5719, + 5720, + 5721, + 5722 + ] + }, + { + "teal": 2924, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5723, + 5724, + 5725, + 5726, + 5727, + 5728 + ] + }, + { + "teal": 2925, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5729, + 5730, + 5731, + 5732, + 5733, + 5734 + ] + }, + { + "teal": 2926, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5735, + 5736, + 5737, + 5738, + 5739, + 5740 + ] + }, + { + "teal": 2927, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5741, + 5742, + 5743, + 5744, + 5745, + 5746 + ] + }, + { + "teal": 2928, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5747, + 5748, + 5749, + 5750, + 5751, + 5752 + ] + }, + { + "teal": 2929, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5753, + 5754, + 5755, + 5756, + 5757, + 5758 + ] + }, + { + "teal": 2930, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5759, + 5760, + 5761, + 5762, + 5763, + 5764 + ] + }, + { + "teal": 2931, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5765, + 5766, + 5767, + 5768, + 5769, + 5770 + ] + }, + { + "teal": 2932, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5771, + 5772, + 5773, + 5774, + 5775, + 5776 + ] + }, + { + "teal": 2933, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5777, + 5778, + 5779, + 5780, + 5781, + 5782 + ] + }, + { + "teal": 2934, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5783, + 5784, + 5785, + 5786, + 5787, + 5788 + ] + }, + { + "teal": 2935, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5789, + 5790, + 5791, + 5792, + 5793, + 5794 + ] + }, + { + "teal": 2936, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5795, + 5796, + 5797, + 5798, + 5799, + 5800 + ] + }, + { + "teal": 2937, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5801, + 5802, + 5803, + 5804, + 5805, + 5806 + ] + }, + { + "teal": 2938, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5807, + 5808, + 5809, + 5810, + 5811, + 5812 + ] + }, + { + "teal": 2939, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5813, + 5814, + 5815, + 5816, + 5817, + 5818 + ] + }, + { + "teal": 2940, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5819, + 5820, + 5821, + 5822, + 5823, + 5824 + ] + }, + { + "teal": 2941, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5825, + 5826, + 5827, + 5828, + 5829, + 5830 + ] + }, + { + "teal": 2942, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5831, + 5832, + 5833 + ] + }, + { + "teal": 2943, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5834, + 5835, + 5836, + 5837, + 5838, + 5839, + 5840, + 5841, + 5842, + 5843, + 5844, + 5845, + 5846, + 5847, + 5848, + 5849, + 5850, + 5851, + 5852, + 5853, + 5854, + 5855, + 5856, + 5857, + 5858, + 5859, + 5860, + 5861, + 5862, + 5863, + 5864, + 5865, + 5866, + 5867, + 5868, + 5869, + 5870, + 5871, + 5872, + 5873, + 5874, + 5875, + 5876, + 5877, + 5878, + 5879, + 5880, + 5881, + 5882, + 5883, + 5884, + 5885, + 5886, + 5887, + 5888, + 5889, + 5890, + 5891, + 5892, + 5893, + 5894, + 5895, + 5896, + 5897, + 5898, + 5899, + 5900, + 5901, + 5902, + 5903, + 5904, + 5905, + 5906, + 5907, + 5908, + 5909, + 5910, + 5911, + 5912, + 5913, + 5914, + 5915, + 5916, + 5917, + 5918, + 5919, + 5920, + 5921, + 5922, + 5923, + 5924, + 5925, + 5926, + 5927, + 5928, + 5929, + 5930, + 5931, + 5932, + 5933, + 5934, + 5935, + 5936, + 5937, + 5938, + 5939, + 5940, + 5941, + 5942, + 5943, + 5944, + 5945, + 5946, + 5947, + 5948, + 5949, + 5950, + 5951, + 5952, + 5953, + 5954, + 5955, + 5956, + 5957, + 5958, + 5959, + 5960, + 5961, + 5962, + 5963, + 5964, + 5965, + 5966, + 5967, + 5968, + 5969, + 5970, + 5971, + 5972, + 5973, + 5974, + 5975, + 5976, + 5977, + 5978, + 5979, + 5980, + 5981, + 5982, + 5983 + ] + }, + { + "teal": 2946, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5984, + 5985, + 5986 + ] + }, + { + "teal": 2947, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5987, + 5988 + ] + }, + { + "teal": 2948, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5989 + ] + }, + { + "teal": 2951, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5990, + 5991, + 5992 + ] + }, + { + "teal": 2952, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 5993, + 5994, + 5995, + 5996, + 5997, + 5998, + 5999, + 6000, + 6001, + 6002, + 6003, + 6004 + ] + }, + { + "teal": 2953, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 6005, + 6006 + ] + }, + { + "teal": 2954, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 6007, + 6008 + ] + }, + { + "teal": 2955, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 6009 + ] + }, + { + "teal": 2956, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 6010 + ] + }, + { + "teal": 2960, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 6011, + 6012, + 6013 + ] + }, + { + "teal": 2961, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 6014, + 6015 + ] + }, + { + "teal": 2962, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 6016, + 6017 + ] + }, + { + "teal": 2963, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 6018 + ] + }, + { + "teal": 2964, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 6019, + 6020, + 6021 + ] + }, + { + "teal": 2965, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 6022, + 6023, + 6024 + ] + }, + { + "teal": 2966, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 6025 + ] + }, + { + "teal": 2969, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 6026, + 6027 + ] + }, + { + "teal": 2970, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 6028, + 6029 + ] + }, + { + "teal": 2971, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 6030 + ] + }, + { + "teal": 2972, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 6031, + 6032 + ] + }, + { + "teal": 2973, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 6033 + ] + }, + { + "teal": 2974, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 6034, + 6035, + 6036 + ] + }, + { + "teal": 2975, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 6037, + 6038 + ] + }, + { + "teal": 2976, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 6039, + 6040 + ] + }, + { + "teal": 2977, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 6041 + ] + }, + { + "teal": 2978, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 6042, + 6043, + 6044 + ] + }, + { + "teal": 2979, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 6045, + 6046, + 6047 + ] + }, + { + "teal": 2982, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 6048, + 6049 + ] + }, + { + "teal": 2985, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 6050, + 6051 + ] + }, + { + "teal": 2986, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 6052, + 6053 + ] + }, + { + "teal": 2987, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 6054 + ] + }, + { + "teal": 2988, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 6055, + 6056, + 6057 + ] + }, + { + "teal": 2989, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 6058 + ] + }, + { + "teal": 2990, + "source": "tests/contracts/general.algo.ts:57", + "pc": [ + 6059 + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/IfTest.arc56_draft.json b/tests/contracts/artifacts/IfTest.arc56_draft.json index 678baa735..31dd5d2a1 100644 --- a/tests/contracts/artifacts/IfTest.arc56_draft.json +++ b/tests/contracts/artifacts/IfTest.arc56_draft.json @@ -365,166 +365,4502 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/if.algo.ts:5", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/if.algo.ts:5", + "pc": [ + 1, + 2, + 3, + 4 + ] + }, + { + "teal": 3, + "source": "tests/contracts/if.algo.ts:5", + "pc": [ + 5, + 6, + 7, + 8, + 9, + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38, + 39, + 40, + 41, + 42, + 43, + 44, + 45, + 46, + 47, + 48, + 49, + 50, + 51, + 52, + 53, + 54, + 55, + 56 + ] + }, + { + "teal": 15, + "source": "tests/contracts/if.algo.ts:5", + "pc": [ + 57, + 58 + ] + }, + { + "teal": 16, + "source": "tests/contracts/if.algo.ts:5", + "pc": [ + 59 + ] + }, + { + "teal": 17, + "source": "tests/contracts/if.algo.ts:5", + "pc": [ + 60, + 61 + ] + }, + { + "teal": 18, + "source": "tests/contracts/if.algo.ts:5", + "pc": [ + 62 + ] + }, + { + "teal": 19, + "source": "tests/contracts/if.algo.ts:5", + "pc": [ + 63, + 64 + ] + }, + { + "teal": 20, + "source": "tests/contracts/if.algo.ts:5", + "pc": [ + 65 + ] + }, + { + "teal": 21, + "source": "tests/contracts/if.algo.ts:5", + "pc": [ + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82, + 83, + 84, + 85, + 86, + 87, + 88, + 89, + 90, + 91 + ] + }, + { + "teal": 25, + "source": "tests/contracts/if.algo.ts:5", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 92 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 30, + "source": "tests/contracts/if.algo.ts:6", + "pc": [ + 93, + 94, + 95, + 96, + 97, + 98 + ] + }, + { + "teal": 33, + "source": "tests/contracts/if.algo.ts:6", + "pc": [ + 99, + 100, + 101 + ] + }, + { + "teal": 34, + "source": "tests/contracts/if.algo.ts:6", + "pc": [ + 102 + ] + }, + { + "teal": 35, + "source": "tests/contracts/if.algo.ts:6", + "pc": [ + 103 + ] + }, + { + "teal": 36, + "source": "tests/contracts/if.algo.ts:6", + "pc": [ + 104, + 105 + ] + }, + { + "teal": 37, + "source": "tests/contracts/if.algo.ts:6", + "pc": [ + 106 + ] }, { + "teal": 40, + "source": "tests/contracts/if.algo.ts:6", + "errorMessage": "argument 0 (arg0) for singleIf must be a bool", "pc": [ 107 - ], - "errorMessage": "argument 0 (arg0) for singleIf must be a bool" + ] + }, + { + "teal": 41, + "source": "tests/contracts/if.algo.ts:6", + "pc": [ + 108, + 109 + ] + }, + { + "teal": 42, + "source": "tests/contracts/if.algo.ts:6", + "pc": [ + 110 + ] + }, + { + "teal": 45, + "source": "tests/contracts/if.algo.ts:6", + "pc": [ + 111, + 112, + 113 + ] + }, + { + "teal": 46, + "source": "tests/contracts/if.algo.ts:6", + "pc": [ + 114 + ] + }, + { + "teal": 47, + "source": "tests/contracts/if.algo.ts:6", + "pc": [ + 115 + ] + }, + { + "teal": 48, + "source": "tests/contracts/if.algo.ts:6", + "pc": [ + 116 + ] + }, + { + "teal": 49, + "source": "tests/contracts/if.algo.ts:6", + "pc": [ + 117, + 118, + 119 + ] + }, + { + "teal": 50, + "source": "tests/contracts/if.algo.ts:6", + "pc": [ + 120 + ] + }, + { + "teal": 51, + "source": "tests/contracts/if.algo.ts:6", + "pc": [ + 121 + ] + }, + { + "teal": 52, + "source": "tests/contracts/if.algo.ts:6", + "pc": [ + 122 + ] + }, + { + "teal": 53, + "source": "tests/contracts/if.algo.ts:6", + "pc": [ + 123 + ] + }, + { + "teal": 54, + "source": "tests/contracts/if.algo.ts:6", + "pc": [ + 124, + 125 + ] + }, + { + "teal": 55, + "source": "tests/contracts/if.algo.ts:6", + "pc": [ + 126 + ] + }, + { + "teal": 59, + "source": "tests/contracts/if.algo.ts:6", + "pc": [ + 127, + 128, + 129 + ] + }, + { + "teal": 64, + "source": "tests/contracts/if.algo.ts:7", + "pc": [ + 130, + 131 + ] + }, + { + "teal": 65, + "source": "tests/contracts/if.algo.ts:7", + "pc": [ + 132, + 133, + 134 + ] }, { + "teal": 70, + "source": "tests/contracts/if.algo.ts:8", + "pc": [ + 135, + 136, + 137, + 138 + ] + }, + { + "teal": 71, + "source": "tests/contracts/if.algo.ts:8", + "pc": [ + 139 + ] + }, + { + "teal": 76, + "source": "tests/contracts/if.algo.ts:11", + "pc": [ + 140, + 141, + 142, + 143, + 144 + ] + }, + { + "teal": 77, + "source": "tests/contracts/if.algo.ts:6", + "pc": [ + 145 + ] + }, + { + "teal": 82, + "source": "tests/contracts/if.algo.ts:14", + "pc": [ + 146, + 147, + 148, + 149, + 150, + 151 + ] + }, + { + "teal": 85, + "source": "tests/contracts/if.algo.ts:14", + "pc": [ + 152, + 153, + 154 + ] + }, + { + "teal": 86, + "source": "tests/contracts/if.algo.ts:14", + "pc": [ + 155 + ] + }, + { + "teal": 87, + "source": "tests/contracts/if.algo.ts:14", + "pc": [ + 156 + ] + }, + { + "teal": 88, + "source": "tests/contracts/if.algo.ts:14", + "pc": [ + 157, + 158 + ] + }, + { + "teal": 89, + "source": "tests/contracts/if.algo.ts:14", + "pc": [ + 159 + ] + }, + { + "teal": 92, + "source": "tests/contracts/if.algo.ts:14", + "errorMessage": "argument 0 (arg0) for ifElse must be a bool", "pc": [ 160 - ], - "errorMessage": "argument 0 (arg0) for ifElse must be a bool" + ] + }, + { + "teal": 93, + "source": "tests/contracts/if.algo.ts:14", + "pc": [ + 161, + 162 + ] + }, + { + "teal": 94, + "source": "tests/contracts/if.algo.ts:14", + "pc": [ + 163 + ] + }, + { + "teal": 97, + "source": "tests/contracts/if.algo.ts:14", + "pc": [ + 164, + 165, + 166 + ] + }, + { + "teal": 98, + "source": "tests/contracts/if.algo.ts:14", + "pc": [ + 167 + ] + }, + { + "teal": 99, + "source": "tests/contracts/if.algo.ts:14", + "pc": [ + 168 + ] + }, + { + "teal": 100, + "source": "tests/contracts/if.algo.ts:14", + "pc": [ + 169 + ] + }, + { + "teal": 101, + "source": "tests/contracts/if.algo.ts:14", + "pc": [ + 170, + 171, + 172 + ] + }, + { + "teal": 102, + "source": "tests/contracts/if.algo.ts:14", + "pc": [ + 173 + ] + }, + { + "teal": 103, + "source": "tests/contracts/if.algo.ts:14", + "pc": [ + 174 + ] + }, + { + "teal": 104, + "source": "tests/contracts/if.algo.ts:14", + "pc": [ + 175 + ] + }, + { + "teal": 105, + "source": "tests/contracts/if.algo.ts:14", + "pc": [ + 176 + ] + }, + { + "teal": 106, + "source": "tests/contracts/if.algo.ts:14", + "pc": [ + 177, + 178 + ] + }, + { + "teal": 107, + "source": "tests/contracts/if.algo.ts:14", + "pc": [ + 179 + ] + }, + { + "teal": 111, + "source": "tests/contracts/if.algo.ts:14", + "pc": [ + 180, + 181, + 182 + ] + }, + { + "teal": 116, + "source": "tests/contracts/if.algo.ts:15", + "pc": [ + 183, + 184 + ] + }, + { + "teal": 117, + "source": "tests/contracts/if.algo.ts:15", + "pc": [ + 185, + 186, + 187 + ] + }, + { + "teal": 122, + "source": "tests/contracts/if.algo.ts:16", + "pc": [ + 188, + 189, + 190, + 191 + ] + }, + { + "teal": 123, + "source": "tests/contracts/if.algo.ts:16", + "pc": [ + 192 + ] + }, + { + "teal": 124, + "source": "tests/contracts/if.algo.ts:15", + "pc": [ + 193, + 194, + 195 + ] + }, + { + "teal": 129, + "source": "tests/contracts/if.algo.ts:18", + "pc": [ + 196, + 197, + 198, + 199, + 200, + 201 + ] + }, + { + "teal": 130, + "source": "tests/contracts/if.algo.ts:18", + "pc": [ + 202 + ] + }, + { + "teal": 133, + "source": "tests/contracts/if.algo.ts:14", + "pc": [ + 203 + ] }, { + "teal": 138, + "source": "tests/contracts/if.algo.ts:22", + "pc": [ + 204, + 205, + 206, + 207, + 208, + 209 + ] + }, + { + "teal": 141, + "source": "tests/contracts/if.algo.ts:22", + "pc": [ + 210, + 211, + 212 + ] + }, + { + "teal": 142, + "source": "tests/contracts/if.algo.ts:22", + "pc": [ + 213 + ] + }, + { + "teal": 143, + "source": "tests/contracts/if.algo.ts:22", + "pc": [ + 214 + ] + }, + { + "teal": 144, + "source": "tests/contracts/if.algo.ts:22", + "pc": [ + 215, + 216 + ] + }, + { + "teal": 145, + "source": "tests/contracts/if.algo.ts:22", + "pc": [ + 217 + ] + }, + { + "teal": 148, + "source": "tests/contracts/if.algo.ts:22", + "errorMessage": "argument 0 (arg1) for ifElseIf must be a bool", "pc": [ 218 - ], - "errorMessage": "argument 0 (arg1) for ifElseIf must be a bool" + ] + }, + { + "teal": 149, + "source": "tests/contracts/if.algo.ts:22", + "pc": [ + 219, + 220 + ] + }, + { + "teal": 150, + "source": "tests/contracts/if.algo.ts:22", + "pc": [ + 221 + ] + }, + { + "teal": 153, + "source": "tests/contracts/if.algo.ts:22", + "pc": [ + 222, + 223, + 224 + ] + }, + { + "teal": 154, + "source": "tests/contracts/if.algo.ts:22", + "pc": [ + 225 + ] + }, + { + "teal": 155, + "source": "tests/contracts/if.algo.ts:22", + "pc": [ + 226 + ] + }, + { + "teal": 156, + "source": "tests/contracts/if.algo.ts:22", + "pc": [ + 227, + 228 + ] }, { + "teal": 157, + "source": "tests/contracts/if.algo.ts:22", + "pc": [ + 229 + ] + }, + { + "teal": 160, + "source": "tests/contracts/if.algo.ts:22", + "errorMessage": "argument 1 (arg0) for ifElseIf must be a bool", "pc": [ 230 - ], - "errorMessage": "argument 1 (arg0) for ifElseIf must be a bool" + ] }, { + "teal": 161, + "source": "tests/contracts/if.algo.ts:22", "pc": [ - 301 - ], - "errorMessage": "argument 0 (arg1) for ifElseIfElse must be a bool" + 231, + 232 + ] }, { + "teal": 162, + "source": "tests/contracts/if.algo.ts:22", "pc": [ - 313 - ], - "errorMessage": "argument 1 (arg0) for ifElseIfElse must be a bool" + 233 + ] }, { + "teal": 165, + "source": "tests/contracts/if.algo.ts:22", "pc": [ - 389 - ], - "errorMessage": "argument 0 (arg2) for ifElseIfElseIf must be a bool" + 234, + 235, + 236 + ] }, { + "teal": 166, + "source": "tests/contracts/if.algo.ts:22", "pc": [ - 401 - ], - "errorMessage": "argument 1 (arg1) for ifElseIfElseIf must be a bool" + 237 + ] }, { + "teal": 167, + "source": "tests/contracts/if.algo.ts:22", "pc": [ - 413 - ], - "errorMessage": "argument 2 (arg0) for ifElseIfElseIf must be a bool" + 238 + ] }, { + "teal": 168, + "source": "tests/contracts/if.algo.ts:22", "pc": [ - 506 - ], - "errorMessage": "argument 0 (arg2) for ifElseIfElseIfElse must be a bool" + 239 + ] }, { + "teal": 169, + "source": "tests/contracts/if.algo.ts:22", "pc": [ - 518 - ], - "errorMessage": "argument 1 (arg1) for ifElseIfElseIfElse must be a bool" + 240, + 241, + 242 + ] }, { + "teal": 170, + "source": "tests/contracts/if.algo.ts:22", "pc": [ - 530 - ], - "errorMessage": "argument 2 (arg0) for ifElseIfElseIfElse must be a bool" + 243 + ] }, { + "teal": 171, + "source": "tests/contracts/if.algo.ts:22", "pc": [ - 628 - ], - "errorMessage": "argument 0 (arg1) for nestedIf must be a bool" + 244 + ] }, { + "teal": 172, + "source": "tests/contracts/if.algo.ts:22", "pc": [ - 640 - ], - "errorMessage": "argument 1 (arg0) for nestedIf must be a bool" + 245 + ] }, { + "teal": 173, + "source": "tests/contracts/if.algo.ts:22", "pc": [ - 715 - ], - "errorMessage": "argument 0 (arg0) for bracketlessIfElse must be a bool" + 246 + ] }, { + "teal": 174, + "source": "tests/contracts/if.algo.ts:22", "pc": [ - 773 - ], - "errorMessage": "argument 0 (arg1) for nestedTernary must be a bool" + 247, + 248 + ] }, { + "teal": 175, + "source": "tests/contracts/if.algo.ts:22", "pc": [ - 785 - ], - "errorMessage": "argument 1 (arg0) for nestedTernary must be a bool" + 249 + ] }, { + "teal": 179, + "source": "tests/contracts/if.algo.ts:22", "pc": [ - 910 - ], - "errorMessage": "argument 0 (a) for smallUintConditional must be a uint16" + 250, + 251, + 252 + ] }, { + "teal": 184, + "source": "tests/contracts/if.algo.ts:23", "pc": [ - 944 - ], - "errorMessage": "argument 0 (b) for smallUintComparisonConditional must be a uint16" + 253, + 254 + ] }, { + "teal": 185, + "source": "tests/contracts/if.algo.ts:23", "pc": [ - 954 - ], - "errorMessage": "argument 1 (a) for smallUintComparisonConditional must be a uint16" + 255, + 256, + 257 + ] }, { + "teal": 190, + "source": "tests/contracts/if.algo.ts:24", "pc": [ - 988 - ], - "errorMessage": "argument 0 (b) for uint256ComparsionConditional must be a uint256" + 258, + 259, + 260, + 261 + ] }, { + "teal": 191, + "source": "tests/contracts/if.algo.ts:24", "pc": [ - 997 - ], - "errorMessage": "argument 1 (a) for uint256ComparsionConditional must be a uint256" + 262 + ] }, { + "teal": 192, + "source": "tests/contracts/if.algo.ts:23", "pc": [ - 1036 - ], - "errorMessage": "argument 0 (b) for nestedIfInElseIf must be a bool" + 263, + 264, + 265 + ] }, { + "teal": 197, + "source": "tests/contracts/if.algo.ts:25", "pc": [ - 1048 - ], - "errorMessage": "argument 1 (a) for nestedIfInElseIf must be a bool" + 266, + 267 + ] }, { + "teal": 198, + "source": "tests/contracts/if.algo.ts:25", "pc": [ - 1140 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + 268, + 269, + 270 + ] + }, + { + "teal": 203, + "source": "tests/contracts/if.algo.ts:26", + "pc": [ + 271, + 272, + 273, + 274, + 275, + 276, + 277, + 278, + 279 + ] + }, + { + "teal": 204, + "source": "tests/contracts/if.algo.ts:26", + "pc": [ + 280 + ] + }, + { + "teal": 209, + "source": "tests/contracts/if.algo.ts:29", + "pc": [ + 281, + 282, + 283, + 284, + 285 + ] + }, + { + "teal": 210, + "source": "tests/contracts/if.algo.ts:22", + "pc": [ + 286 + ] + }, + { + "teal": 215, + "source": "tests/contracts/if.algo.ts:32", + "pc": [ + 287, + 288, + 289, + 290, + 291, + 292 + ] + }, + { + "teal": 218, + "source": "tests/contracts/if.algo.ts:32", + "pc": [ + 293, + 294, + 295 + ] + }, + { + "teal": 219, + "source": "tests/contracts/if.algo.ts:32", + "pc": [ + 296 + ] + }, + { + "teal": 220, + "source": "tests/contracts/if.algo.ts:32", + "pc": [ + 297 + ] + }, + { + "teal": 221, + "source": "tests/contracts/if.algo.ts:32", + "pc": [ + 298, + 299 + ] + }, + { + "teal": 222, + "source": "tests/contracts/if.algo.ts:32", + "pc": [ + 300 + ] + }, + { + "teal": 225, + "source": "tests/contracts/if.algo.ts:32", + "errorMessage": "argument 0 (arg1) for ifElseIfElse must be a bool", + "pc": [ + 301 + ] + }, + { + "teal": 226, + "source": "tests/contracts/if.algo.ts:32", + "pc": [ + 302, + 303 + ] + }, + { + "teal": 227, + "source": "tests/contracts/if.algo.ts:32", + "pc": [ + 304 + ] + }, + { + "teal": 230, + "source": "tests/contracts/if.algo.ts:32", + "pc": [ + 305, + 306, + 307 + ] + }, + { + "teal": 231, + "source": "tests/contracts/if.algo.ts:32", + "pc": [ + 308 + ] + }, + { + "teal": 232, + "source": "tests/contracts/if.algo.ts:32", + "pc": [ + 309 + ] + }, + { + "teal": 233, + "source": "tests/contracts/if.algo.ts:32", + "pc": [ + 310, + 311 + ] + }, + { + "teal": 234, + "source": "tests/contracts/if.algo.ts:32", + "pc": [ + 312 + ] + }, + { + "teal": 237, + "source": "tests/contracts/if.algo.ts:32", + "errorMessage": "argument 1 (arg0) for ifElseIfElse must be a bool", + "pc": [ + 313 + ] + }, + { + "teal": 238, + "source": "tests/contracts/if.algo.ts:32", + "pc": [ + 314, + 315 + ] + }, + { + "teal": 239, + "source": "tests/contracts/if.algo.ts:32", + "pc": [ + 316 + ] + }, + { + "teal": 242, + "source": "tests/contracts/if.algo.ts:32", + "pc": [ + 317, + 318, + 319 + ] + }, + { + "teal": 243, + "source": "tests/contracts/if.algo.ts:32", + "pc": [ + 320 + ] + }, + { + "teal": 244, + "source": "tests/contracts/if.algo.ts:32", + "pc": [ + 321 + ] + }, + { + "teal": 245, + "source": "tests/contracts/if.algo.ts:32", + "pc": [ + 322 + ] + }, + { + "teal": 246, + "source": "tests/contracts/if.algo.ts:32", + "pc": [ + 323, + 324, + 325 + ] + }, + { + "teal": 247, + "source": "tests/contracts/if.algo.ts:32", + "pc": [ + 326 + ] + }, + { + "teal": 248, + "source": "tests/contracts/if.algo.ts:32", + "pc": [ + 327 + ] + }, + { + "teal": 249, + "source": "tests/contracts/if.algo.ts:32", + "pc": [ + 328 + ] + }, + { + "teal": 250, + "source": "tests/contracts/if.algo.ts:32", + "pc": [ + 329 + ] + }, + { + "teal": 251, + "source": "tests/contracts/if.algo.ts:32", + "pc": [ + 330, + 331 + ] + }, + { + "teal": 252, + "source": "tests/contracts/if.algo.ts:32", + "pc": [ + 332 + ] + }, + { + "teal": 256, + "source": "tests/contracts/if.algo.ts:32", + "pc": [ + 333, + 334, + 335 + ] + }, + { + "teal": 261, + "source": "tests/contracts/if.algo.ts:33", + "pc": [ + 336, + 337 + ] + }, + { + "teal": 262, + "source": "tests/contracts/if.algo.ts:33", + "pc": [ + 338, + 339, + 340 + ] + }, + { + "teal": 267, + "source": "tests/contracts/if.algo.ts:34", + "pc": [ + 341, + 342, + 343, + 344 + ] + }, + { + "teal": 268, + "source": "tests/contracts/if.algo.ts:34", + "pc": [ + 345 + ] + }, + { + "teal": 269, + "source": "tests/contracts/if.algo.ts:33", + "pc": [ + 346, + 347, + 348 + ] + }, + { + "teal": 274, + "source": "tests/contracts/if.algo.ts:35", + "pc": [ + 349, + 350 + ] + }, + { + "teal": 275, + "source": "tests/contracts/if.algo.ts:35", + "pc": [ + 351, + 352, + 353 + ] + }, + { + "teal": 280, + "source": "tests/contracts/if.algo.ts:36", + "pc": [ + 354, + 355, + 356, + 357, + 358, + 359, + 360, + 361, + 362 + ] + }, + { + "teal": 281, + "source": "tests/contracts/if.algo.ts:36", + "pc": [ + 363 + ] + }, + { + "teal": 282, + "source": "tests/contracts/if.algo.ts:35", + "pc": [ + 364, + 365, + 366 + ] + }, + { + "teal": 287, + "source": "tests/contracts/if.algo.ts:38", + "pc": [ + 367, + 368, + 369, + 370, + 371, + 372 + ] + }, + { + "teal": 288, + "source": "tests/contracts/if.algo.ts:38", + "pc": [ + 373 + ] + }, + { + "teal": 291, + "source": "tests/contracts/if.algo.ts:32", + "pc": [ + 374 + ] + }, + { + "teal": 296, + "source": "tests/contracts/if.algo.ts:42", + "pc": [ + 375, + 376, + 377, + 378, + 379, + 380 + ] + }, + { + "teal": 299, + "source": "tests/contracts/if.algo.ts:42", + "pc": [ + 381, + 382, + 383 + ] + }, + { + "teal": 300, + "source": "tests/contracts/if.algo.ts:42", + "pc": [ + 384 + ] + }, + { + "teal": 301, + "source": "tests/contracts/if.algo.ts:42", + "pc": [ + 385 + ] + }, + { + "teal": 302, + "source": "tests/contracts/if.algo.ts:42", + "pc": [ + 386, + 387 + ] + }, + { + "teal": 303, + "source": "tests/contracts/if.algo.ts:42", + "pc": [ + 388 + ] + }, + { + "teal": 306, + "source": "tests/contracts/if.algo.ts:42", + "errorMessage": "argument 0 (arg2) for ifElseIfElseIf must be a bool", + "pc": [ + 389 + ] + }, + { + "teal": 307, + "source": "tests/contracts/if.algo.ts:42", + "pc": [ + 390, + 391 + ] + }, + { + "teal": 308, + "source": "tests/contracts/if.algo.ts:42", + "pc": [ + 392 + ] + }, + { + "teal": 311, + "source": "tests/contracts/if.algo.ts:42", + "pc": [ + 393, + 394, + 395 + ] + }, + { + "teal": 312, + "source": "tests/contracts/if.algo.ts:42", + "pc": [ + 396 + ] + }, + { + "teal": 313, + "source": "tests/contracts/if.algo.ts:42", + "pc": [ + 397 + ] + }, + { + "teal": 314, + "source": "tests/contracts/if.algo.ts:42", + "pc": [ + 398, + 399 + ] + }, + { + "teal": 315, + "source": "tests/contracts/if.algo.ts:42", + "pc": [ + 400 + ] + }, + { + "teal": 318, + "source": "tests/contracts/if.algo.ts:42", + "errorMessage": "argument 1 (arg1) for ifElseIfElseIf must be a bool", + "pc": [ + 401 + ] + }, + { + "teal": 319, + "source": "tests/contracts/if.algo.ts:42", + "pc": [ + 402, + 403 + ] + }, + { + "teal": 320, + "source": "tests/contracts/if.algo.ts:42", + "pc": [ + 404 + ] + }, + { + "teal": 323, + "source": "tests/contracts/if.algo.ts:42", + "pc": [ + 405, + 406, + 407 + ] + }, + { + "teal": 324, + "source": "tests/contracts/if.algo.ts:42", + "pc": [ + 408 + ] + }, + { + "teal": 325, + "source": "tests/contracts/if.algo.ts:42", + "pc": [ + 409 + ] + }, + { + "teal": 326, + "source": "tests/contracts/if.algo.ts:42", + "pc": [ + 410, + 411 + ] + }, + { + "teal": 327, + "source": "tests/contracts/if.algo.ts:42", + "pc": [ + 412 + ] + }, + { + "teal": 330, + "source": "tests/contracts/if.algo.ts:42", + "errorMessage": "argument 2 (arg0) for ifElseIfElseIf must be a bool", + "pc": [ + 413 + ] + }, + { + "teal": 331, + "source": "tests/contracts/if.algo.ts:42", + "pc": [ + 414, + 415 + ] + }, + { + "teal": 332, + "source": "tests/contracts/if.algo.ts:42", + "pc": [ + 416 + ] + }, + { + "teal": 335, + "source": "tests/contracts/if.algo.ts:42", + "pc": [ + 417, + 418, + 419 + ] + }, + { + "teal": 336, + "source": "tests/contracts/if.algo.ts:42", + "pc": [ + 420 + ] + }, + { + "teal": 337, + "source": "tests/contracts/if.algo.ts:42", + "pc": [ + 421 + ] + }, + { + "teal": 338, + "source": "tests/contracts/if.algo.ts:42", + "pc": [ + 422 + ] + }, + { + "teal": 339, + "source": "tests/contracts/if.algo.ts:42", + "pc": [ + 423, + 424, + 425 + ] + }, + { + "teal": 340, + "source": "tests/contracts/if.algo.ts:42", + "pc": [ + 426 + ] + }, + { + "teal": 341, + "source": "tests/contracts/if.algo.ts:42", + "pc": [ + 427 + ] + }, + { + "teal": 342, + "source": "tests/contracts/if.algo.ts:42", + "pc": [ + 428 + ] + }, + { + "teal": 343, + "source": "tests/contracts/if.algo.ts:42", + "pc": [ + 429 + ] + }, + { + "teal": 344, + "source": "tests/contracts/if.algo.ts:42", + "pc": [ + 430, + 431 + ] + }, + { + "teal": 345, + "source": "tests/contracts/if.algo.ts:42", + "pc": [ + 432 + ] + }, + { + "teal": 349, + "source": "tests/contracts/if.algo.ts:42", + "pc": [ + 433, + 434, + 435 + ] + }, + { + "teal": 354, + "source": "tests/contracts/if.algo.ts:43", + "pc": [ + 436, + 437 + ] + }, + { + "teal": 355, + "source": "tests/contracts/if.algo.ts:43", + "pc": [ + 438, + 439, + 440 + ] + }, + { + "teal": 360, + "source": "tests/contracts/if.algo.ts:44", + "pc": [ + 441, + 442, + 443, + 444 + ] + }, + { + "teal": 361, + "source": "tests/contracts/if.algo.ts:44", + "pc": [ + 445 + ] + }, + { + "teal": 362, + "source": "tests/contracts/if.algo.ts:43", + "pc": [ + 446, + 447, + 448 + ] + }, + { + "teal": 367, + "source": "tests/contracts/if.algo.ts:45", + "pc": [ + 449, + 450 + ] + }, + { + "teal": 368, + "source": "tests/contracts/if.algo.ts:45", + "pc": [ + 451, + 452, + 453 + ] + }, + { + "teal": 373, + "source": "tests/contracts/if.algo.ts:46", + "pc": [ + 454, + 455, + 456, + 457, + 458, + 459, + 460, + 461, + 462, + 463, + 464 + ] + }, + { + "teal": 374, + "source": "tests/contracts/if.algo.ts:46", + "pc": [ + 465 + ] + }, + { + "teal": 375, + "source": "tests/contracts/if.algo.ts:45", + "pc": [ + 466, + 467, + 468 + ] + }, + { + "teal": 380, + "source": "tests/contracts/if.algo.ts:47", + "pc": [ + 469, + 470 + ] + }, + { + "teal": 381, + "source": "tests/contracts/if.algo.ts:47", + "pc": [ + 471, + 472, + 473 + ] + }, + { + "teal": 386, + "source": "tests/contracts/if.algo.ts:48", + "pc": [ + 474, + 475, + 476, + 477, + 478, + 479, + 480, + 481, + 482, + 483, + 484 + ] + }, + { + "teal": 387, + "source": "tests/contracts/if.algo.ts:48", + "pc": [ + 485 + ] + }, + { + "teal": 392, + "source": "tests/contracts/if.algo.ts:51", + "pc": [ + 486, + 487, + 488, + 489, + 490 + ] + }, + { + "teal": 393, + "source": "tests/contracts/if.algo.ts:42", + "pc": [ + 491 + ] + }, + { + "teal": 398, + "source": "tests/contracts/if.algo.ts:54", + "pc": [ + 492, + 493, + 494, + 495, + 496, + 497 + ] + }, + { + "teal": 401, + "source": "tests/contracts/if.algo.ts:54", + "pc": [ + 498, + 499, + 500 + ] + }, + { + "teal": 402, + "source": "tests/contracts/if.algo.ts:54", + "pc": [ + 501 + ] + }, + { + "teal": 403, + "source": "tests/contracts/if.algo.ts:54", + "pc": [ + 502 + ] + }, + { + "teal": 404, + "source": "tests/contracts/if.algo.ts:54", + "pc": [ + 503, + 504 + ] + }, + { + "teal": 405, + "source": "tests/contracts/if.algo.ts:54", + "pc": [ + 505 + ] + }, + { + "teal": 408, + "source": "tests/contracts/if.algo.ts:54", + "errorMessage": "argument 0 (arg2) for ifElseIfElseIfElse must be a bool", + "pc": [ + 506 + ] + }, + { + "teal": 409, + "source": "tests/contracts/if.algo.ts:54", + "pc": [ + 507, + 508 + ] + }, + { + "teal": 410, + "source": "tests/contracts/if.algo.ts:54", + "pc": [ + 509 + ] + }, + { + "teal": 413, + "source": "tests/contracts/if.algo.ts:54", + "pc": [ + 510, + 511, + 512 + ] + }, + { + "teal": 414, + "source": "tests/contracts/if.algo.ts:54", + "pc": [ + 513 + ] + }, + { + "teal": 415, + "source": "tests/contracts/if.algo.ts:54", + "pc": [ + 514 + ] + }, + { + "teal": 416, + "source": "tests/contracts/if.algo.ts:54", + "pc": [ + 515, + 516 + ] + }, + { + "teal": 417, + "source": "tests/contracts/if.algo.ts:54", + "pc": [ + 517 + ] + }, + { + "teal": 420, + "source": "tests/contracts/if.algo.ts:54", + "errorMessage": "argument 1 (arg1) for ifElseIfElseIfElse must be a bool", + "pc": [ + 518 + ] + }, + { + "teal": 421, + "source": "tests/contracts/if.algo.ts:54", + "pc": [ + 519, + 520 + ] + }, + { + "teal": 422, + "source": "tests/contracts/if.algo.ts:54", + "pc": [ + 521 + ] + }, + { + "teal": 425, + "source": "tests/contracts/if.algo.ts:54", + "pc": [ + 522, + 523, + 524 + ] + }, + { + "teal": 426, + "source": "tests/contracts/if.algo.ts:54", + "pc": [ + 525 + ] + }, + { + "teal": 427, + "source": "tests/contracts/if.algo.ts:54", + "pc": [ + 526 + ] + }, + { + "teal": 428, + "source": "tests/contracts/if.algo.ts:54", + "pc": [ + 527, + 528 + ] + }, + { + "teal": 429, + "source": "tests/contracts/if.algo.ts:54", + "pc": [ + 529 + ] + }, + { + "teal": 432, + "source": "tests/contracts/if.algo.ts:54", + "errorMessage": "argument 2 (arg0) for ifElseIfElseIfElse must be a bool", + "pc": [ + 530 + ] + }, + { + "teal": 433, + "source": "tests/contracts/if.algo.ts:54", + "pc": [ + 531, + 532 + ] + }, + { + "teal": 434, + "source": "tests/contracts/if.algo.ts:54", + "pc": [ + 533 + ] + }, + { + "teal": 437, + "source": "tests/contracts/if.algo.ts:54", + "pc": [ + 534, + 535, + 536 + ] + }, + { + "teal": 438, + "source": "tests/contracts/if.algo.ts:54", + "pc": [ + 537 + ] + }, + { + "teal": 439, + "source": "tests/contracts/if.algo.ts:54", + "pc": [ + 538 + ] + }, + { + "teal": 440, + "source": "tests/contracts/if.algo.ts:54", + "pc": [ + 539 + ] + }, + { + "teal": 441, + "source": "tests/contracts/if.algo.ts:54", + "pc": [ + 540, + 541, + 542 + ] + }, + { + "teal": 442, + "source": "tests/contracts/if.algo.ts:54", + "pc": [ + 543 + ] + }, + { + "teal": 443, + "source": "tests/contracts/if.algo.ts:54", + "pc": [ + 544 + ] + }, + { + "teal": 444, + "source": "tests/contracts/if.algo.ts:54", + "pc": [ + 545 + ] + }, + { + "teal": 445, + "source": "tests/contracts/if.algo.ts:54", + "pc": [ + 546 + ] + }, + { + "teal": 446, + "source": "tests/contracts/if.algo.ts:54", + "pc": [ + 547, + 548 + ] + }, + { + "teal": 447, + "source": "tests/contracts/if.algo.ts:54", + "pc": [ + 549 + ] + }, + { + "teal": 451, + "source": "tests/contracts/if.algo.ts:54", + "pc": [ + 550, + 551, + 552 + ] + }, + { + "teal": 456, + "source": "tests/contracts/if.algo.ts:55", + "pc": [ + 553, + 554 + ] + }, + { + "teal": 457, + "source": "tests/contracts/if.algo.ts:55", + "pc": [ + 555, + 556, + 557 + ] + }, + { + "teal": 462, + "source": "tests/contracts/if.algo.ts:56", + "pc": [ + 558, + 559, + 560, + 561 + ] + }, + { + "teal": 463, + "source": "tests/contracts/if.algo.ts:56", + "pc": [ + 562 + ] + }, + { + "teal": 464, + "source": "tests/contracts/if.algo.ts:55", + "pc": [ + 563, + 564, + 565 + ] + }, + { + "teal": 469, + "source": "tests/contracts/if.algo.ts:57", + "pc": [ + 566, + 567 + ] + }, + { + "teal": 470, + "source": "tests/contracts/if.algo.ts:57", + "pc": [ + 568, + 569, + 570 + ] + }, + { + "teal": 475, + "source": "tests/contracts/if.algo.ts:58", + "pc": [ + 571, + 572, + 573, + 574, + 575, + 576, + 577, + 578, + 579, + 580, + 581 + ] + }, + { + "teal": 476, + "source": "tests/contracts/if.algo.ts:58", + "pc": [ + 582 + ] + }, + { + "teal": 477, + "source": "tests/contracts/if.algo.ts:57", + "pc": [ + 583, + 584, + 585 + ] + }, + { + "teal": 482, + "source": "tests/contracts/if.algo.ts:59", + "pc": [ + 586, + 587 + ] + }, + { + "teal": 483, + "source": "tests/contracts/if.algo.ts:59", + "pc": [ + 588, + 589, + 590 + ] + }, + { + "teal": 488, + "source": "tests/contracts/if.algo.ts:60", + "pc": [ + 591, + 592, + 593, + 594, + 595, + 596, + 597, + 598, + 599, + 600, + 601 + ] + }, + { + "teal": 489, + "source": "tests/contracts/if.algo.ts:60", + "pc": [ + 602 + ] + }, + { + "teal": 490, + "source": "tests/contracts/if.algo.ts:59", + "pc": [ + 603, + 604, + 605 + ] + }, + { + "teal": 495, + "source": "tests/contracts/if.algo.ts:62", + "pc": [ + 606, + 607, + 608, + 609, + 610, + 611 + ] + }, + { + "teal": 496, + "source": "tests/contracts/if.algo.ts:62", + "pc": [ + 612 + ] + }, + { + "teal": 499, + "source": "tests/contracts/if.algo.ts:54", + "pc": [ + 613 + ] + }, + { + "teal": 504, + "source": "tests/contracts/if.algo.ts:66", + "pc": [ + 614, + 615, + 616, + 617, + 618, + 619 + ] + }, + { + "teal": 507, + "source": "tests/contracts/if.algo.ts:66", + "pc": [ + 620, + 621, + 622 + ] + }, + { + "teal": 508, + "source": "tests/contracts/if.algo.ts:66", + "pc": [ + 623 + ] + }, + { + "teal": 509, + "source": "tests/contracts/if.algo.ts:66", + "pc": [ + 624 + ] + }, + { + "teal": 510, + "source": "tests/contracts/if.algo.ts:66", + "pc": [ + 625, + 626 + ] + }, + { + "teal": 511, + "source": "tests/contracts/if.algo.ts:66", + "pc": [ + 627 + ] + }, + { + "teal": 514, + "source": "tests/contracts/if.algo.ts:66", + "errorMessage": "argument 0 (arg1) for nestedIf must be a bool", + "pc": [ + 628 + ] + }, + { + "teal": 515, + "source": "tests/contracts/if.algo.ts:66", + "pc": [ + 629, + 630 + ] + }, + { + "teal": 516, + "source": "tests/contracts/if.algo.ts:66", + "pc": [ + 631 + ] + }, + { + "teal": 519, + "source": "tests/contracts/if.algo.ts:66", + "pc": [ + 632, + 633, + 634 + ] + }, + { + "teal": 520, + "source": "tests/contracts/if.algo.ts:66", + "pc": [ + 635 + ] + }, + { + "teal": 521, + "source": "tests/contracts/if.algo.ts:66", + "pc": [ + 636 + ] + }, + { + "teal": 522, + "source": "tests/contracts/if.algo.ts:66", + "pc": [ + 637, + 638 + ] + }, + { + "teal": 523, + "source": "tests/contracts/if.algo.ts:66", + "pc": [ + 639 + ] + }, + { + "teal": 526, + "source": "tests/contracts/if.algo.ts:66", + "errorMessage": "argument 1 (arg0) for nestedIf must be a bool", + "pc": [ + 640 + ] + }, + { + "teal": 527, + "source": "tests/contracts/if.algo.ts:66", + "pc": [ + 641, + 642 + ] + }, + { + "teal": 528, + "source": "tests/contracts/if.algo.ts:66", + "pc": [ + 643 + ] + }, + { + "teal": 531, + "source": "tests/contracts/if.algo.ts:66", + "pc": [ + 644, + 645, + 646 + ] + }, + { + "teal": 532, + "source": "tests/contracts/if.algo.ts:66", + "pc": [ + 647 + ] + }, + { + "teal": 533, + "source": "tests/contracts/if.algo.ts:66", + "pc": [ + 648 + ] + }, + { + "teal": 534, + "source": "tests/contracts/if.algo.ts:66", + "pc": [ + 649 + ] + }, + { + "teal": 535, + "source": "tests/contracts/if.algo.ts:66", + "pc": [ + 650, + 651, + 652 + ] + }, + { + "teal": 536, + "source": "tests/contracts/if.algo.ts:66", + "pc": [ + 653 + ] + }, + { + "teal": 537, + "source": "tests/contracts/if.algo.ts:66", + "pc": [ + 654 + ] + }, + { + "teal": 538, + "source": "tests/contracts/if.algo.ts:66", + "pc": [ + 655 + ] + }, + { + "teal": 539, + "source": "tests/contracts/if.algo.ts:66", + "pc": [ + 656 + ] + }, + { + "teal": 540, + "source": "tests/contracts/if.algo.ts:66", + "pc": [ + 657, + 658 + ] + }, + { + "teal": 541, + "source": "tests/contracts/if.algo.ts:66", + "pc": [ + 659 + ] + }, + { + "teal": 545, + "source": "tests/contracts/if.algo.ts:66", + "pc": [ + 660, + 661, + 662 + ] + }, + { + "teal": 550, + "source": "tests/contracts/if.algo.ts:67", + "pc": [ + 663, + 664 + ] + }, + { + "teal": 551, + "source": "tests/contracts/if.algo.ts:67", + "pc": [ + 665, + 666, + 667 + ] + }, + { + "teal": 557, + "source": "tests/contracts/if.algo.ts:68", + "pc": [ + 668, + 669 + ] + }, + { + "teal": 558, + "source": "tests/contracts/if.algo.ts:68", + "pc": [ + 670, + 671, + 672 + ] + }, + { + "teal": 563, + "source": "tests/contracts/if.algo.ts:69", + "pc": [ + 673, + 674, + 675, + 676, + 677, + 678, + 679, + 680, + 681, + 682, + 683 + ] + }, + { + "teal": 564, + "source": "tests/contracts/if.algo.ts:69", + "pc": [ + 684 + ] + }, + { + "teal": 569, + "source": "tests/contracts/if.algo.ts:71", + "pc": [ + 685, + 686, + 687, + 688 + ] + }, + { + "teal": 570, + "source": "tests/contracts/if.algo.ts:71", + "pc": [ + 689 + ] + }, + { + "teal": 571, + "source": "tests/contracts/if.algo.ts:67", + "pc": [ + 690, + 691, + 692 + ] + }, + { + "teal": 576, + "source": "tests/contracts/if.algo.ts:73", + "pc": [ + 693, + 694, + 695, + 696, + 697, + 698 + ] + }, + { + "teal": 577, + "source": "tests/contracts/if.algo.ts:73", + "pc": [ + 699 + ] + }, + { + "teal": 580, + "source": "tests/contracts/if.algo.ts:66", + "pc": [ + 700 + ] + }, + { + "teal": 585, + "source": "tests/contracts/if.algo.ts:77", + "pc": [ + 701, + 702, + 703, + 704, + 705, + 706 + ] + }, + { + "teal": 588, + "source": "tests/contracts/if.algo.ts:77", + "pc": [ + 707, + 708, + 709 + ] + }, + { + "teal": 589, + "source": "tests/contracts/if.algo.ts:77", + "pc": [ + 710 + ] + }, + { + "teal": 590, + "source": "tests/contracts/if.algo.ts:77", + "pc": [ + 711 + ] + }, + { + "teal": 591, + "source": "tests/contracts/if.algo.ts:77", + "pc": [ + 712, + 713 + ] + }, + { + "teal": 592, + "source": "tests/contracts/if.algo.ts:77", + "pc": [ + 714 + ] + }, + { + "teal": 595, + "source": "tests/contracts/if.algo.ts:77", + "errorMessage": "argument 0 (arg0) for bracketlessIfElse must be a bool", + "pc": [ + 715 + ] + }, + { + "teal": 596, + "source": "tests/contracts/if.algo.ts:77", + "pc": [ + 716, + 717 + ] + }, + { + "teal": 597, + "source": "tests/contracts/if.algo.ts:77", + "pc": [ + 718 + ] + }, + { + "teal": 600, + "source": "tests/contracts/if.algo.ts:77", + "pc": [ + 719, + 720, + 721 + ] + }, + { + "teal": 601, + "source": "tests/contracts/if.algo.ts:77", + "pc": [ + 722 + ] + }, + { + "teal": 602, + "source": "tests/contracts/if.algo.ts:77", + "pc": [ + 723 + ] + }, + { + "teal": 603, + "source": "tests/contracts/if.algo.ts:77", + "pc": [ + 724 + ] + }, + { + "teal": 604, + "source": "tests/contracts/if.algo.ts:77", + "pc": [ + 725, + 726, + 727 + ] + }, + { + "teal": 605, + "source": "tests/contracts/if.algo.ts:77", + "pc": [ + 728 + ] + }, + { + "teal": 606, + "source": "tests/contracts/if.algo.ts:77", + "pc": [ + 729 + ] + }, + { + "teal": 607, + "source": "tests/contracts/if.algo.ts:77", + "pc": [ + 730 + ] + }, + { + "teal": 608, + "source": "tests/contracts/if.algo.ts:77", + "pc": [ + 731 + ] + }, + { + "teal": 609, + "source": "tests/contracts/if.algo.ts:77", + "pc": [ + 732, + 733 + ] + }, + { + "teal": 610, + "source": "tests/contracts/if.algo.ts:77", + "pc": [ + 734 + ] + }, + { + "teal": 614, + "source": "tests/contracts/if.algo.ts:77", + "pc": [ + 735, + 736, + 737 + ] + }, + { + "teal": 619, + "source": "tests/contracts/if.algo.ts:78", + "pc": [ + 738, + 739 + ] + }, + { + "teal": 620, + "source": "tests/contracts/if.algo.ts:78", + "pc": [ + 740, + 741, + 742 + ] + }, + { + "teal": 625, + "source": "tests/contracts/if.algo.ts:78", + "pc": [ + 743, + 744, + 745, + 746 + ] + }, + { + "teal": 626, + "source": "tests/contracts/if.algo.ts:78", + "pc": [ + 747 + ] + }, + { + "teal": 627, + "source": "tests/contracts/if.algo.ts:78", + "pc": [ + 748, + 749, + 750 + ] + }, + { + "teal": 632, + "source": "tests/contracts/if.algo.ts:79", + "pc": [ + 751, + 752, + 753, + 754, + 755, + 756 + ] + }, + { + "teal": 633, + "source": "tests/contracts/if.algo.ts:79", + "pc": [ + 757 + ] + }, + { + "teal": 636, + "source": "tests/contracts/if.algo.ts:77", + "pc": [ + 758 + ] + }, + { + "teal": 641, + "source": "tests/contracts/if.algo.ts:82", + "pc": [ + 759, + 760, + 761, + 762, + 763, + 764 + ] + }, + { + "teal": 644, + "source": "tests/contracts/if.algo.ts:82", + "pc": [ + 765, + 766, + 767 + ] + }, + { + "teal": 645, + "source": "tests/contracts/if.algo.ts:82", + "pc": [ + 768 + ] + }, + { + "teal": 646, + "source": "tests/contracts/if.algo.ts:82", + "pc": [ + 769 + ] + }, + { + "teal": 647, + "source": "tests/contracts/if.algo.ts:82", + "pc": [ + 770, + 771 + ] + }, + { + "teal": 648, + "source": "tests/contracts/if.algo.ts:82", + "pc": [ + 772 + ] + }, + { + "teal": 651, + "source": "tests/contracts/if.algo.ts:82", + "errorMessage": "argument 0 (arg1) for nestedTernary must be a bool", + "pc": [ + 773 + ] + }, + { + "teal": 652, + "source": "tests/contracts/if.algo.ts:82", + "pc": [ + 774, + 775 + ] + }, + { + "teal": 653, + "source": "tests/contracts/if.algo.ts:82", + "pc": [ + 776 + ] + }, + { + "teal": 656, + "source": "tests/contracts/if.algo.ts:82", + "pc": [ + 777, + 778, + 779 + ] + }, + { + "teal": 657, + "source": "tests/contracts/if.algo.ts:82", + "pc": [ + 780 + ] + }, + { + "teal": 658, + "source": "tests/contracts/if.algo.ts:82", + "pc": [ + 781 + ] + }, + { + "teal": 659, + "source": "tests/contracts/if.algo.ts:82", + "pc": [ + 782, + 783 + ] + }, + { + "teal": 660, + "source": "tests/contracts/if.algo.ts:82", + "pc": [ + 784 + ] + }, + { + "teal": 663, + "source": "tests/contracts/if.algo.ts:82", + "errorMessage": "argument 1 (arg0) for nestedTernary must be a bool", + "pc": [ + 785 + ] + }, + { + "teal": 664, + "source": "tests/contracts/if.algo.ts:82", + "pc": [ + 786, + 787 + ] + }, + { + "teal": 665, + "source": "tests/contracts/if.algo.ts:82", + "pc": [ + 788 + ] + }, + { + "teal": 668, + "source": "tests/contracts/if.algo.ts:82", + "pc": [ + 789, + 790, + 791 + ] + }, + { + "teal": 669, + "source": "tests/contracts/if.algo.ts:82", + "pc": [ + 792 + ] + }, + { + "teal": 670, + "source": "tests/contracts/if.algo.ts:82", + "pc": [ + 793 + ] + }, + { + "teal": 671, + "source": "tests/contracts/if.algo.ts:82", + "pc": [ + 794 + ] + }, + { + "teal": 672, + "source": "tests/contracts/if.algo.ts:82", + "pc": [ + 795, + 796 + ] + }, + { + "teal": 673, + "source": "tests/contracts/if.algo.ts:82", + "pc": [ + 797 + ] + }, + { + "teal": 677, + "source": "tests/contracts/if.algo.ts:82", + "pc": [ + 798, + 799, + 800 + ] + }, + { + "teal": 681, + "source": "tests/contracts/if.algo.ts:84", + "pc": [ + 801, + 802 + ] + }, + { + "teal": 682, + "source": "tests/contracts/if.algo.ts:84", + "pc": [ + 803, + 804, + 805 + ] + }, + { + "teal": 683, + "source": "tests/contracts/if.algo.ts:84", + "pc": [ + 806, + 807 + ] + }, + { + "teal": 684, + "source": "tests/contracts/if.algo.ts:84", + "pc": [ + 808, + 809, + 810 + ] + }, + { + "teal": 687, + "source": "tests/contracts/if.algo.ts:84", + "pc": [ + 811, + 812 + ] + }, + { + "teal": 688, + "source": "tests/contracts/if.algo.ts:84", + "pc": [ + 813, + 814, + 815 + ] + }, + { + "teal": 689, + "source": "tests/contracts/if.algo.ts:84", + "pc": [ + 816, + 817 + ] + }, + { + "teal": 690, + "source": "tests/contracts/if.algo.ts:84", + "pc": [ + 818, + 819, + 820 + ] + }, + { + "teal": 693, + "source": "tests/contracts/if.algo.ts:84", + "pc": [ + 821, + 822 + ] + }, + { + "teal": 698, + "source": "tests/contracts/if.algo.ts:82", + "pc": [ + 823 + ] + }, + { + "teal": 703, + "source": "tests/contracts/if.algo.ts:87", + "pc": [ + 824, + 825, + 826, + 827, + 828, + 829 + ] + }, + { + "teal": 706, + "source": "tests/contracts/if.algo.ts:87", + "pc": [ + 830, + 831, + 832 + ] + }, + { + "teal": 707, + "source": "tests/contracts/if.algo.ts:87", + "pc": [ + 833, + 834, + 835 + ] + }, + { + "teal": 710, + "source": "tests/contracts/if.algo.ts:87", + "pc": [ + 836, + 837, + 838 + ] + }, + { + "teal": 711, + "source": "tests/contracts/if.algo.ts:87", + "pc": [ + 839 + ] + }, + { + "teal": 712, + "source": "tests/contracts/if.algo.ts:87", + "pc": [ + 840 + ] + }, + { + "teal": 713, + "source": "tests/contracts/if.algo.ts:87", + "pc": [ + 841 + ] + }, + { + "teal": 714, + "source": "tests/contracts/if.algo.ts:87", + "pc": [ + 842, + 843 + ] + }, + { + "teal": 715, + "source": "tests/contracts/if.algo.ts:87", + "pc": [ + 844 + ] + }, + { + "teal": 719, + "source": "tests/contracts/if.algo.ts:87", + "pc": [ + 845, + 846, + 847 + ] + }, + { + "teal": 724, + "source": "tests/contracts/if.algo.ts:88", + "pc": [ + 848, + 849 + ] + }, + { + "teal": 725, + "source": "tests/contracts/if.algo.ts:88", + "pc": [ + 850, + 851 + ] + }, + { + "teal": 726, + "source": "tests/contracts/if.algo.ts:88", + "pc": [ + 852 + ] + }, + { + "teal": 727, + "source": "tests/contracts/if.algo.ts:88", + "pc": [ + 853, + 854, + 855 + ] + }, + { + "teal": 732, + "source": "tests/contracts/if.algo.ts:89", + "pc": [ + 856, + 857 + ] + }, + { + "teal": 733, + "source": "tests/contracts/if.algo.ts:89", + "pc": [ + 858 + ] + }, + { + "teal": 738, + "source": "tests/contracts/if.algo.ts:92", + "pc": [ + 859, + 860 + ] + }, + { + "teal": 739, + "source": "tests/contracts/if.algo.ts:87", + "pc": [ + 861 + ] + }, + { + "teal": 744, + "source": "tests/contracts/if.algo.ts:95", + "pc": [ + 862, + 863, + 864, + 865, + 866, + 867 + ] + }, + { + "teal": 747, + "source": "tests/contracts/if.algo.ts:95", + "pc": [ + 868, + 869, + 870 + ] + }, + { + "teal": 748, + "source": "tests/contracts/if.algo.ts:95", + "pc": [ + 871, + 872, + 873 + ] + }, + { + "teal": 751, + "source": "tests/contracts/if.algo.ts:95", + "pc": [ + 874, + 875, + 876 + ] + }, + { + "teal": 752, + "source": "tests/contracts/if.algo.ts:95", + "pc": [ + 877 + ] + }, + { + "teal": 753, + "source": "tests/contracts/if.algo.ts:95", + "pc": [ + 878 + ] + }, + { + "teal": 754, + "source": "tests/contracts/if.algo.ts:95", + "pc": [ + 879 + ] + }, + { + "teal": 755, + "source": "tests/contracts/if.algo.ts:95", + "pc": [ + 880, + 881 + ] + }, + { + "teal": 756, + "source": "tests/contracts/if.algo.ts:95", + "pc": [ + 882 + ] + }, + { + "teal": 760, + "source": "tests/contracts/if.algo.ts:95", + "pc": [ + 883, + 884, + 885 + ] + }, + { + "teal": 764, + "source": "tests/contracts/if.algo.ts:96", + "pc": [ + 886, + 887 + ] + }, + { + "teal": 765, + "source": "tests/contracts/if.algo.ts:96", + "pc": [ + 888, + 889 + ] + }, + { + "teal": 766, + "source": "tests/contracts/if.algo.ts:96", + "pc": [ + 890 + ] + }, + { + "teal": 767, + "source": "tests/contracts/if.algo.ts:96", + "pc": [ + 891, + 892, + 893 + ] + }, + { + "teal": 768, + "source": "tests/contracts/if.algo.ts:96", + "pc": [ + 894, + 895 + ] + }, + { + "teal": 769, + "source": "tests/contracts/if.algo.ts:96", + "pc": [ + 896, + 897, + 898 + ] + }, + { + "teal": 772, + "source": "tests/contracts/if.algo.ts:96", + "pc": [ + 899, + 900 + ] + }, + { + "teal": 775, + "source": "tests/contracts/if.algo.ts:95", + "pc": [ + 901 + ] + }, + { + "teal": 780, + "source": "tests/contracts/if.algo.ts:99", + "pc": [ + 902, + 903, + 904 + ] + }, + { + "teal": 781, + "source": "tests/contracts/if.algo.ts:99", + "pc": [ + 905 + ] + }, + { + "teal": 782, + "source": "tests/contracts/if.algo.ts:99", + "pc": [ + 906 + ] + }, + { + "teal": 783, + "source": "tests/contracts/if.algo.ts:99", + "pc": [ + 907, + 908 + ] + }, + { + "teal": 784, + "source": "tests/contracts/if.algo.ts:99", + "pc": [ + 909 + ] + }, + { + "teal": 787, + "source": "tests/contracts/if.algo.ts:99", + "errorMessage": "argument 0 (a) for smallUintConditional must be a uint16", + "pc": [ + 910 + ] + }, + { + "teal": 788, + "source": "tests/contracts/if.algo.ts:99", + "pc": [ + 911 + ] + }, + { + "teal": 791, + "source": "tests/contracts/if.algo.ts:99", + "pc": [ + 912, + 913, + 914 + ] + }, + { + "teal": 792, + "source": "tests/contracts/if.algo.ts:99", + "pc": [ + 915, + 916 + ] + }, + { + "teal": 793, + "source": "tests/contracts/if.algo.ts:99", + "pc": [ + 917 + ] + }, + { + "teal": 797, + "source": "tests/contracts/if.algo.ts:99", + "pc": [ + 918, + 919, + 920 + ] + }, + { + "teal": 802, + "source": "tests/contracts/if.algo.ts:100", + "pc": [ + 921, + 922 + ] + }, + { + "teal": 803, + "source": "tests/contracts/if.algo.ts:100", + "pc": [ + 923, + 924 + ] + }, + { + "teal": 804, + "source": "tests/contracts/if.algo.ts:100", + "pc": [ + 925 + ] + }, + { + "teal": 805, + "source": "tests/contracts/if.algo.ts:100", + "pc": [ + 926, + 927, + 928 + ] + }, + { + "teal": 810, + "source": "tests/contracts/if.algo.ts:101", + "pc": [ + 929, + 930, + 931, + 932, + 933 + ] + }, + { + "teal": 811, + "source": "tests/contracts/if.algo.ts:101", + "pc": [ + 934 + ] + }, + { + "teal": 814, + "source": "tests/contracts/if.algo.ts:99", + "pc": [ + 935 + ] + }, + { + "teal": 819, + "source": "tests/contracts/if.algo.ts:105", + "pc": [ + 936, + 937, + 938 + ] + }, + { + "teal": 820, + "source": "tests/contracts/if.algo.ts:105", + "pc": [ + 939 + ] + }, + { + "teal": 821, + "source": "tests/contracts/if.algo.ts:105", + "pc": [ + 940 + ] + }, + { + "teal": 822, + "source": "tests/contracts/if.algo.ts:105", + "pc": [ + 941, + 942 + ] + }, + { + "teal": 823, + "source": "tests/contracts/if.algo.ts:105", + "pc": [ + 943 + ] + }, + { + "teal": 826, + "source": "tests/contracts/if.algo.ts:105", + "errorMessage": "argument 0 (b) for smallUintComparisonConditional must be a uint16", + "pc": [ + 944 + ] + }, + { + "teal": 827, + "source": "tests/contracts/if.algo.ts:105", + "pc": [ + 945 + ] + }, + { + "teal": 830, + "source": "tests/contracts/if.algo.ts:105", + "pc": [ + 946, + 947, + 948 + ] + }, + { + "teal": 831, + "source": "tests/contracts/if.algo.ts:105", + "pc": [ + 949 + ] + }, + { + "teal": 832, + "source": "tests/contracts/if.algo.ts:105", + "pc": [ + 950 + ] + }, + { + "teal": 833, + "source": "tests/contracts/if.algo.ts:105", + "pc": [ + 951, + 952 + ] + }, + { + "teal": 834, + "source": "tests/contracts/if.algo.ts:105", + "pc": [ + 953 + ] + }, + { + "teal": 837, + "source": "tests/contracts/if.algo.ts:105", + "errorMessage": "argument 1 (a) for smallUintComparisonConditional must be a uint16", + "pc": [ + 954 + ] + }, + { + "teal": 838, + "source": "tests/contracts/if.algo.ts:105", + "pc": [ + 955 + ] + }, + { + "teal": 841, + "source": "tests/contracts/if.algo.ts:105", + "pc": [ + 956, + 957, + 958 + ] + }, + { + "teal": 842, + "source": "tests/contracts/if.algo.ts:105", + "pc": [ + 959, + 960 + ] + }, + { + "teal": 843, + "source": "tests/contracts/if.algo.ts:105", + "pc": [ + 961 + ] + }, + { + "teal": 847, + "source": "tests/contracts/if.algo.ts:105", + "pc": [ + 962, + 963, + 964 + ] + }, + { + "teal": 852, + "source": "tests/contracts/if.algo.ts:106", + "pc": [ + 965, + 966 + ] + }, + { + "teal": 853, + "source": "tests/contracts/if.algo.ts:106", + "pc": [ + 967, + 968 + ] + }, + { + "teal": 854, + "source": "tests/contracts/if.algo.ts:106", + "pc": [ + 969 + ] + }, + { + "teal": 855, + "source": "tests/contracts/if.algo.ts:106", + "pc": [ + 970, + 971, + 972 + ] + }, + { + "teal": 860, + "source": "tests/contracts/if.algo.ts:107", + "pc": [ + 973, + 974, + 975, + 976, + 977 + ] + }, + { + "teal": 861, + "source": "tests/contracts/if.algo.ts:107", + "pc": [ + 978 + ] + }, + { + "teal": 864, + "source": "tests/contracts/if.algo.ts:105", + "pc": [ + 979 + ] + }, + { + "teal": 869, + "source": "tests/contracts/if.algo.ts:111", + "pc": [ + 980, + 981, + 982 + ] + }, + { + "teal": 870, + "source": "tests/contracts/if.algo.ts:111", + "pc": [ + 983 + ] + }, + { + "teal": 871, + "source": "tests/contracts/if.algo.ts:111", + "pc": [ + 984 + ] + }, + { + "teal": 872, + "source": "tests/contracts/if.algo.ts:111", + "pc": [ + 985, + 986 + ] + }, + { + "teal": 873, + "source": "tests/contracts/if.algo.ts:111", + "pc": [ + 987 + ] + }, + { + "teal": 876, + "source": "tests/contracts/if.algo.ts:111", + "errorMessage": "argument 0 (b) for uint256ComparsionConditional must be a uint256", + "pc": [ + 988 + ] + }, + { + "teal": 879, + "source": "tests/contracts/if.algo.ts:111", + "pc": [ + 989, + 990, + 991 + ] + }, + { + "teal": 880, + "source": "tests/contracts/if.algo.ts:111", + "pc": [ + 992 + ] + }, + { + "teal": 881, + "source": "tests/contracts/if.algo.ts:111", + "pc": [ + 993 + ] + }, + { + "teal": 882, + "source": "tests/contracts/if.algo.ts:111", + "pc": [ + 994, + 995 + ] + }, + { + "teal": 883, + "source": "tests/contracts/if.algo.ts:111", + "pc": [ + 996 + ] + }, + { + "teal": 886, + "source": "tests/contracts/if.algo.ts:111", + "errorMessage": "argument 1 (a) for uint256ComparsionConditional must be a uint256", + "pc": [ + 997 + ] + }, + { + "teal": 889, + "source": "tests/contracts/if.algo.ts:111", + "pc": [ + 998, + 999, + 1000 + ] + }, + { + "teal": 890, + "source": "tests/contracts/if.algo.ts:111", + "pc": [ + 1001, + 1002 + ] + }, + { + "teal": 891, + "source": "tests/contracts/if.algo.ts:111", + "pc": [ + 1003 + ] + }, + { + "teal": 895, + "source": "tests/contracts/if.algo.ts:111", + "pc": [ + 1004, + 1005, + 1006 + ] + }, + { + "teal": 900, + "source": "tests/contracts/if.algo.ts:112", + "pc": [ + 1007, + 1008 + ] + }, + { + "teal": 901, + "source": "tests/contracts/if.algo.ts:112", + "pc": [ + 1009, + 1010 + ] + }, + { + "teal": 902, + "source": "tests/contracts/if.algo.ts:112", + "pc": [ + 1011 + ] + }, + { + "teal": 903, + "source": "tests/contracts/if.algo.ts:112", + "pc": [ + 1012, + 1013, + 1014 + ] + }, + { + "teal": 908, + "source": "tests/contracts/if.algo.ts:113", + "pc": [ + 1015, + 1016, + 1017, + 1018, + 1019 + ] + }, + { + "teal": 909, + "source": "tests/contracts/if.algo.ts:113", + "pc": [ + 1020 + ] + }, + { + "teal": 912, + "source": "tests/contracts/if.algo.ts:111", + "pc": [ + 1021 + ] + }, + { + "teal": 917, + "source": "tests/contracts/if.algo.ts:117", + "pc": [ + 1022, + 1023, + 1024, + 1025, + 1026, + 1027 + ] + }, + { + "teal": 920, + "source": "tests/contracts/if.algo.ts:117", + "pc": [ + 1028, + 1029, + 1030 + ] + }, + { + "teal": 921, + "source": "tests/contracts/if.algo.ts:117", + "pc": [ + 1031 + ] + }, + { + "teal": 922, + "source": "tests/contracts/if.algo.ts:117", + "pc": [ + 1032 + ] + }, + { + "teal": 923, + "source": "tests/contracts/if.algo.ts:117", + "pc": [ + 1033, + 1034 + ] + }, + { + "teal": 924, + "source": "tests/contracts/if.algo.ts:117", + "pc": [ + 1035 + ] + }, + { + "teal": 927, + "source": "tests/contracts/if.algo.ts:117", + "errorMessage": "argument 0 (b) for nestedIfInElseIf must be a bool", + "pc": [ + 1036 + ] + }, + { + "teal": 928, + "source": "tests/contracts/if.algo.ts:117", + "pc": [ + 1037, + 1038 + ] + }, + { + "teal": 929, + "source": "tests/contracts/if.algo.ts:117", + "pc": [ + 1039 + ] + }, + { + "teal": 932, + "source": "tests/contracts/if.algo.ts:117", + "pc": [ + 1040, + 1041, + 1042 + ] + }, + { + "teal": 933, + "source": "tests/contracts/if.algo.ts:117", + "pc": [ + 1043 + ] + }, + { + "teal": 934, + "source": "tests/contracts/if.algo.ts:117", + "pc": [ + 1044 + ] + }, + { + "teal": 935, + "source": "tests/contracts/if.algo.ts:117", + "pc": [ + 1045, + 1046 + ] + }, + { + "teal": 936, + "source": "tests/contracts/if.algo.ts:117", + "pc": [ + 1047 + ] + }, + { + "teal": 939, + "source": "tests/contracts/if.algo.ts:117", + "errorMessage": "argument 1 (a) for nestedIfInElseIf must be a bool", + "pc": [ + 1048 + ] + }, + { + "teal": 940, + "source": "tests/contracts/if.algo.ts:117", + "pc": [ + 1049, + 1050 + ] + }, + { + "teal": 941, + "source": "tests/contracts/if.algo.ts:117", + "pc": [ + 1051 + ] + }, + { + "teal": 944, + "source": "tests/contracts/if.algo.ts:117", + "pc": [ + 1052, + 1053, + 1054 + ] + }, + { + "teal": 945, + "source": "tests/contracts/if.algo.ts:117", + "pc": [ + 1055 + ] + }, + { + "teal": 946, + "source": "tests/contracts/if.algo.ts:117", + "pc": [ + 1056 + ] + }, + { + "teal": 947, + "source": "tests/contracts/if.algo.ts:117", + "pc": [ + 1057 + ] + }, + { + "teal": 948, + "source": "tests/contracts/if.algo.ts:117", + "pc": [ + 1058, + 1059, + 1060 + ] + }, + { + "teal": 949, + "source": "tests/contracts/if.algo.ts:117", + "pc": [ + 1061 + ] + }, + { + "teal": 950, + "source": "tests/contracts/if.algo.ts:117", + "pc": [ + 1062 + ] + }, + { + "teal": 951, + "source": "tests/contracts/if.algo.ts:117", + "pc": [ + 1063 + ] + }, + { + "teal": 952, + "source": "tests/contracts/if.algo.ts:117", + "pc": [ + 1064 + ] + }, + { + "teal": 953, + "source": "tests/contracts/if.algo.ts:117", + "pc": [ + 1065, + 1066 + ] + }, + { + "teal": 954, + "source": "tests/contracts/if.algo.ts:117", + "pc": [ + 1067 + ] + }, + { + "teal": 958, + "source": "tests/contracts/if.algo.ts:117", + "pc": [ + 1068, + 1069, + 1070 + ] + }, + { + "teal": 963, + "source": "tests/contracts/if.algo.ts:118", + "pc": [ + 1071, + 1072 + ] + }, + { + "teal": 964, + "source": "tests/contracts/if.algo.ts:118", + "pc": [ + 1073, + 1074, + 1075 + ] + }, + { + "teal": 970, + "source": "tests/contracts/if.algo.ts:119", + "pc": [ + 1076, + 1077 + ] + }, + { + "teal": 971, + "source": "tests/contracts/if.algo.ts:119", + "pc": [ + 1078, + 1079, + 1080 + ] + }, + { + "teal": 976, + "source": "tests/contracts/if.algo.ts:120", + "pc": [ + 1081, + 1082, + 1083, + 1084, + 1085, + 1086, + 1087, + 1088, + 1089 + ] + }, + { + "teal": 977, + "source": "tests/contracts/if.algo.ts:120", + "pc": [ + 1090 + ] + }, + { + "teal": 978, + "source": "tests/contracts/if.algo.ts:119", + "pc": [ + 1091, + 1092, + 1093 + ] + }, + { + "teal": 983, + "source": "tests/contracts/if.algo.ts:122", + "pc": [ + 1094, + 1095, + 1096 + ] + }, + { + "teal": 984, + "source": "tests/contracts/if.algo.ts:122", + "pc": [ + 1097 + ] + }, + { + "teal": 987, + "source": "tests/contracts/if.algo.ts:118", + "pc": [ + 1098, + 1099, + 1100 + ] + }, + { + "teal": 992, + "source": "tests/contracts/if.algo.ts:124", + "pc": [ + 1101, + 1102 + ] + }, + { + "teal": 993, + "source": "tests/contracts/if.algo.ts:124", + "pc": [ + 1103, + 1104, + 1105 + ] + }, + { + "teal": 998, + "source": "tests/contracts/if.algo.ts:125", + "pc": [ + 1106, + 1107, + 1108 + ] + }, + { + "teal": 999, + "source": "tests/contracts/if.algo.ts:125", + "pc": [ + 1109 + ] + }, + { + "teal": 1000, + "source": "tests/contracts/if.algo.ts:124", + "pc": [ + 1110, + 1111, + 1112 + ] + }, + { + "teal": 1005, + "source": "tests/contracts/if.algo.ts:127", + "pc": [ + 1113, + 1114, + 1115, + 1116, + 1117, + 1118, + 1119, + 1120, + 1121 + ] + }, + { + "teal": 1006, + "source": "tests/contracts/if.algo.ts:127", + "pc": [ + 1122 + ] + }, + { + "teal": 1009, + "source": "tests/contracts/if.algo.ts:117", + "pc": [ + 1123 + ] + }, + { + "teal": 1012, + "source": "tests/contracts/if.algo.ts:5", + "pc": [ + 1124, + 1125 + ] + }, + { + "teal": 1013, + "source": "tests/contracts/if.algo.ts:5", + "pc": [ + 1126 + ] + }, + { + "teal": 1016, + "source": "tests/contracts/if.algo.ts:5", + "pc": [ + 1127, + 1128, + 1129, + 1130, + 1131, + 1132 + ] + }, + { + "teal": 1017, + "source": "tests/contracts/if.algo.ts:5", + "pc": [ + 1133, + 1134, + 1135 + ] + }, + { + "teal": 1018, + "source": "tests/contracts/if.algo.ts:5", + "pc": [ + 1136, + 1137, + 1138, + 1139 + ] + }, + { + "teal": 1021, + "source": "tests/contracts/if.algo.ts:5", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", + "pc": [ + 1140 + ] + }, + { + "teal": 1024, + "source": "tests/contracts/if.algo.ts:5", + "pc": [ + 1141, + 1142, + 1143, + 1144, + 1145, + 1146 + ] + }, + { + "teal": 1025, + "source": "tests/contracts/if.algo.ts:5", + "pc": [ + 1147, + 1148, + 1149, + 1150, + 1151, + 1152 + ] + }, + { + "teal": 1026, + "source": "tests/contracts/if.algo.ts:5", + "pc": [ + 1153, + 1154, + 1155, + 1156, + 1157, + 1158 + ] + }, + { + "teal": 1027, + "source": "tests/contracts/if.algo.ts:5", + "pc": [ + 1159, + 1160, + 1161, + 1162, + 1163, + 1164 + ] + }, + { + "teal": 1028, + "source": "tests/contracts/if.algo.ts:5", + "pc": [ + 1165, + 1166, + 1167, + 1168, + 1169, + 1170 + ] + }, + { + "teal": 1029, + "source": "tests/contracts/if.algo.ts:5", + "pc": [ + 1171, + 1172, + 1173, + 1174, + 1175, + 1176 + ] + }, + { + "teal": 1030, + "source": "tests/contracts/if.algo.ts:5", + "pc": [ + 1177, + 1178, + 1179, + 1180, + 1181, + 1182 + ] + }, + { + "teal": 1031, + "source": "tests/contracts/if.algo.ts:5", + "pc": [ + 1183, + 1184, + 1185, + 1186, + 1187, + 1188 + ] + }, + { + "teal": 1032, + "source": "tests/contracts/if.algo.ts:5", + "pc": [ + 1189, + 1190, + 1191, + 1192, + 1193, + 1194 + ] + }, + { + "teal": 1033, + "source": "tests/contracts/if.algo.ts:5", + "pc": [ + 1195, + 1196, + 1197, + 1198, + 1199, + 1200 + ] + }, + { + "teal": 1034, + "source": "tests/contracts/if.algo.ts:5", + "pc": [ + 1201, + 1202, + 1203, + 1204, + 1205, + 1206 + ] + }, + { + "teal": 1035, + "source": "tests/contracts/if.algo.ts:5", + "pc": [ + 1207, + 1208, + 1209, + 1210, + 1211, + 1212 + ] + }, + { + "teal": 1036, + "source": "tests/contracts/if.algo.ts:5", + "pc": [ + 1213, + 1214, + 1215, + 1216, + 1217, + 1218 + ] + }, + { + "teal": 1037, + "source": "tests/contracts/if.algo.ts:5", + "pc": [ + 1219, + 1220, + 1221, + 1222, + 1223, + 1224 + ] + }, + { + "teal": 1038, + "source": "tests/contracts/if.algo.ts:5", + "pc": [ + 1225, + 1226, + 1227, + 1228, + 1229, + 1230 + ] + }, + { + "teal": 1039, + "source": "tests/contracts/if.algo.ts:5", + "pc": [ + 1231, + 1232, + 1233 + ] + }, + { + "teal": 1040, + "source": "tests/contracts/if.algo.ts:5", + "pc": [ + 1234, + 1235, + 1236, + 1237, + 1238, + 1239, + 1240, + 1241, + 1242, + 1243, + 1244, + 1245, + 1246, + 1247, + 1248, + 1249, + 1250, + 1251, + 1252, + 1253, + 1254, + 1255, + 1256, + 1257, + 1258, + 1259, + 1260, + 1261, + 1262, + 1263, + 1264, + 1265 + ] }, { + "teal": 1043, + "source": "tests/contracts/if.algo.ts:5", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 1266 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/IntcblockTest.arc56_draft.json b/tests/contracts/artifacts/IntcblockTest.arc56_draft.json index 873faf6e8..771bb3edc 100644 --- a/tests/contracts/artifacts/IntcblockTest.arc56_draft.json +++ b/tests/contracts/artifacts/IntcblockTest.arc56_draft.json @@ -70,22 +70,4225 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/cblocks.algo.ts:4", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/cblocks.algo.ts:4", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/cblocks.algo.ts:4", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/cblocks.algo.ts:4", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/cblocks.algo.ts:4", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/cblocks.algo.ts:4", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/cblocks.algo.ts:4", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/cblocks.algo.ts:4", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/cblocks.algo.ts:4", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/cblocks.algo.ts:7", + "pc": [ + 37, + 38, + 39, + 40, + 41, + 42 + ] + }, + { + "teal": 31, + "source": "tests/contracts/cblocks.algo.ts:7", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 32, + "source": "tests/contracts/cblocks.algo.ts:7", + "pc": [ + 46 + ] + }, + { + "teal": 33, + "source": "tests/contracts/cblocks.algo.ts:7", + "pc": [ + 47 + ] + }, + { + "teal": 34, + "source": "tests/contracts/cblocks.algo.ts:7", + "pc": [ + 48 + ] + }, + { + "teal": 35, + "source": "tests/contracts/cblocks.algo.ts:7", + "pc": [ + 49, + 50 + ] + }, + { + "teal": 36, + "source": "tests/contracts/cblocks.algo.ts:7", + "pc": [ + 51 + ] + }, + { + "teal": 40, + "source": "tests/contracts/cblocks.algo.ts:7", + "pc": [ + 52, + 53, + 54 + ] + }, + { + "teal": 44, + "source": "tests/contracts/cblocks.algo.ts:9", + "pc": [ + 55, + 56 + ] + }, + { + "teal": 45, + "source": "tests/contracts/cblocks.algo.ts:9", + "pc": [ + 57 + ] + }, + { + "teal": 49, + "source": "tests/contracts/cblocks.algo.ts:10", + "pc": [ + 58, + 59 + ] + }, + { + "teal": 50, + "source": "tests/contracts/cblocks.algo.ts:10", + "pc": [ + 60 + ] + }, + { + "teal": 54, + "source": "tests/contracts/cblocks.algo.ts:11", + "pc": [ + 61, + 62 + ] + }, + { + "teal": 55, + "source": "tests/contracts/cblocks.algo.ts:11", + "pc": [ + 63 + ] + }, + { + "teal": 59, + "source": "tests/contracts/cblocks.algo.ts:12", + "pc": [ + 64, + 65 + ] + }, + { + "teal": 60, + "source": "tests/contracts/cblocks.algo.ts:12", + "pc": [ + 66 + ] + }, + { + "teal": 64, + "source": "tests/contracts/cblocks.algo.ts:13", + "pc": [ + 67, + 68 + ] + }, + { + "teal": 65, + "source": "tests/contracts/cblocks.algo.ts:13", + "pc": [ + 69 + ] + }, + { + "teal": 69, + "source": "tests/contracts/cblocks.algo.ts:14", + "pc": [ + 70, + 71 + ] + }, + { + "teal": 70, + "source": "tests/contracts/cblocks.algo.ts:14", + "pc": [ + 72 + ] + }, + { + "teal": 74, + "source": "tests/contracts/cblocks.algo.ts:15", + "pc": [ + 73, + 74 + ] + }, + { + "teal": 75, + "source": "tests/contracts/cblocks.algo.ts:15", + "pc": [ + 75 + ] + }, + { + "teal": 79, + "source": "tests/contracts/cblocks.algo.ts:16", + "pc": [ + 76, + 77 + ] + }, + { + "teal": 80, + "source": "tests/contracts/cblocks.algo.ts:16", + "pc": [ + 78 + ] + }, + { + "teal": 84, + "source": "tests/contracts/cblocks.algo.ts:17", + "pc": [ + 79, + 80 + ] + }, + { + "teal": 85, + "source": "tests/contracts/cblocks.algo.ts:17", + "pc": [ + 81 + ] + }, + { + "teal": 89, + "source": "tests/contracts/cblocks.algo.ts:18", + "pc": [ + 82, + 83 + ] + }, + { + "teal": 90, + "source": "tests/contracts/cblocks.algo.ts:18", + "pc": [ + 84 + ] + }, + { + "teal": 94, + "source": "tests/contracts/cblocks.algo.ts:19", + "pc": [ + 85, + 86 + ] + }, + { + "teal": 95, + "source": "tests/contracts/cblocks.algo.ts:19", + "pc": [ + 87 + ] + }, + { + "teal": 99, + "source": "tests/contracts/cblocks.algo.ts:20", + "pc": [ + 88, + 89 + ] + }, + { + "teal": 100, + "source": "tests/contracts/cblocks.algo.ts:20", + "pc": [ + 90 + ] + }, + { + "teal": 104, + "source": "tests/contracts/cblocks.algo.ts:21", + "pc": [ + 91, + 92 + ] + }, + { + "teal": 105, + "source": "tests/contracts/cblocks.algo.ts:21", + "pc": [ + 93 + ] + }, + { + "teal": 109, + "source": "tests/contracts/cblocks.algo.ts:22", + "pc": [ + 94, + 95 + ] + }, + { + "teal": 110, + "source": "tests/contracts/cblocks.algo.ts:22", + "pc": [ + 96 + ] + }, + { + "teal": 114, + "source": "tests/contracts/cblocks.algo.ts:23", + "pc": [ + 97, + 98 + ] + }, + { + "teal": 115, + "source": "tests/contracts/cblocks.algo.ts:23", + "pc": [ + 99 + ] + }, + { + "teal": 119, + "source": "tests/contracts/cblocks.algo.ts:24", + "pc": [ + 100, + 101 + ] + }, + { + "teal": 120, + "source": "tests/contracts/cblocks.algo.ts:24", + "pc": [ + 102 + ] + }, + { + "teal": 124, + "source": "tests/contracts/cblocks.algo.ts:25", + "pc": [ + 103, + 104 + ] + }, + { + "teal": 125, + "source": "tests/contracts/cblocks.algo.ts:25", + "pc": [ + 105 + ] + }, + { + "teal": 129, + "source": "tests/contracts/cblocks.algo.ts:26", + "pc": [ + 106, + 107 + ] + }, + { + "teal": 130, + "source": "tests/contracts/cblocks.algo.ts:26", + "pc": [ + 108 + ] + }, + { + "teal": 134, + "source": "tests/contracts/cblocks.algo.ts:27", + "pc": [ + 109, + 110 + ] + }, + { + "teal": 135, + "source": "tests/contracts/cblocks.algo.ts:27", + "pc": [ + 111 + ] + }, + { + "teal": 139, + "source": "tests/contracts/cblocks.algo.ts:28", + "pc": [ + 112, + 113 + ] + }, + { + "teal": 140, + "source": "tests/contracts/cblocks.algo.ts:28", + "pc": [ + 114 + ] + }, + { + "teal": 144, + "source": "tests/contracts/cblocks.algo.ts:29", + "pc": [ + 115, + 116 + ] + }, + { + "teal": 145, + "source": "tests/contracts/cblocks.algo.ts:29", + "pc": [ + 117 + ] + }, + { + "teal": 149, + "source": "tests/contracts/cblocks.algo.ts:30", + "pc": [ + 118, + 119 + ] + }, + { + "teal": 150, + "source": "tests/contracts/cblocks.algo.ts:30", + "pc": [ + 120 + ] + }, + { + "teal": 154, + "source": "tests/contracts/cblocks.algo.ts:31", + "pc": [ + 121, + 122 + ] + }, + { + "teal": 155, + "source": "tests/contracts/cblocks.algo.ts:31", + "pc": [ + 123 + ] + }, + { + "teal": 159, + "source": "tests/contracts/cblocks.algo.ts:32", + "pc": [ + 124, + 125 + ] + }, + { + "teal": 160, + "source": "tests/contracts/cblocks.algo.ts:32", + "pc": [ + 126 + ] + }, + { + "teal": 164, + "source": "tests/contracts/cblocks.algo.ts:33", + "pc": [ + 127, + 128 + ] + }, + { + "teal": 165, + "source": "tests/contracts/cblocks.algo.ts:33", + "pc": [ + 129 + ] + }, + { + "teal": 169, + "source": "tests/contracts/cblocks.algo.ts:34", + "pc": [ + 130, + 131 + ] + }, + { + "teal": 170, + "source": "tests/contracts/cblocks.algo.ts:34", + "pc": [ + 132 + ] + }, + { + "teal": 174, + "source": "tests/contracts/cblocks.algo.ts:35", + "pc": [ + 133, + 134 + ] + }, + { + "teal": 175, + "source": "tests/contracts/cblocks.algo.ts:35", + "pc": [ + 135 + ] + }, + { + "teal": 179, + "source": "tests/contracts/cblocks.algo.ts:36", + "pc": [ + 136, + 137 + ] + }, + { + "teal": 180, + "source": "tests/contracts/cblocks.algo.ts:36", + "pc": [ + 138 + ] + }, + { + "teal": 184, + "source": "tests/contracts/cblocks.algo.ts:37", + "pc": [ + 139, + 140 + ] + }, + { + "teal": 185, + "source": "tests/contracts/cblocks.algo.ts:37", + "pc": [ + 141 + ] + }, + { + "teal": 189, + "source": "tests/contracts/cblocks.algo.ts:38", + "pc": [ + 142, + 143 + ] + }, + { + "teal": 190, + "source": "tests/contracts/cblocks.algo.ts:38", + "pc": [ + 144 + ] + }, + { + "teal": 194, + "source": "tests/contracts/cblocks.algo.ts:39", + "pc": [ + 145, + 146 + ] + }, + { + "teal": 195, + "source": "tests/contracts/cblocks.algo.ts:39", + "pc": [ + 147 + ] + }, + { + "teal": 199, + "source": "tests/contracts/cblocks.algo.ts:40", + "pc": [ + 148, + 149 + ] + }, + { + "teal": 200, + "source": "tests/contracts/cblocks.algo.ts:40", + "pc": [ + 150 + ] + }, + { + "teal": 204, + "source": "tests/contracts/cblocks.algo.ts:41", + "pc": [ + 151, + 152 + ] + }, + { + "teal": 205, + "source": "tests/contracts/cblocks.algo.ts:41", + "pc": [ + 153 + ] + }, + { + "teal": 209, + "source": "tests/contracts/cblocks.algo.ts:42", + "pc": [ + 154, + 155 + ] + }, + { + "teal": 210, + "source": "tests/contracts/cblocks.algo.ts:42", + "pc": [ + 156 + ] + }, + { + "teal": 214, + "source": "tests/contracts/cblocks.algo.ts:43", + "pc": [ + 157, + 158 + ] + }, + { + "teal": 215, + "source": "tests/contracts/cblocks.algo.ts:43", + "pc": [ + 159 + ] + }, + { + "teal": 219, + "source": "tests/contracts/cblocks.algo.ts:44", + "pc": [ + 160, + 161 + ] + }, + { + "teal": 220, + "source": "tests/contracts/cblocks.algo.ts:44", + "pc": [ + 162 + ] + }, + { + "teal": 224, + "source": "tests/contracts/cblocks.algo.ts:45", + "pc": [ + 163, + 164 + ] + }, + { + "teal": 225, + "source": "tests/contracts/cblocks.algo.ts:45", + "pc": [ + 165 + ] + }, + { + "teal": 229, + "source": "tests/contracts/cblocks.algo.ts:46", + "pc": [ + 166, + 167 + ] + }, + { + "teal": 230, + "source": "tests/contracts/cblocks.algo.ts:46", + "pc": [ + 168 + ] + }, + { + "teal": 234, + "source": "tests/contracts/cblocks.algo.ts:47", + "pc": [ + 169, + 170 + ] + }, + { + "teal": 235, + "source": "tests/contracts/cblocks.algo.ts:47", + "pc": [ + 171 + ] + }, + { + "teal": 239, + "source": "tests/contracts/cblocks.algo.ts:48", + "pc": [ + 172, + 173 + ] + }, + { + "teal": 240, + "source": "tests/contracts/cblocks.algo.ts:48", + "pc": [ + 174 + ] + }, + { + "teal": 244, + "source": "tests/contracts/cblocks.algo.ts:49", + "pc": [ + 175, + 176 + ] + }, + { + "teal": 245, + "source": "tests/contracts/cblocks.algo.ts:49", + "pc": [ + 177 + ] + }, + { + "teal": 249, + "source": "tests/contracts/cblocks.algo.ts:50", + "pc": [ + 178, + 179 + ] + }, + { + "teal": 250, + "source": "tests/contracts/cblocks.algo.ts:50", + "pc": [ + 180 + ] + }, + { + "teal": 254, + "source": "tests/contracts/cblocks.algo.ts:51", + "pc": [ + 181, + 182 + ] + }, + { + "teal": 255, + "source": "tests/contracts/cblocks.algo.ts:51", + "pc": [ + 183 + ] + }, + { + "teal": 259, + "source": "tests/contracts/cblocks.algo.ts:52", + "pc": [ + 184, + 185 + ] + }, + { + "teal": 260, + "source": "tests/contracts/cblocks.algo.ts:52", + "pc": [ + 186 + ] + }, + { + "teal": 264, + "source": "tests/contracts/cblocks.algo.ts:53", + "pc": [ + 187, + 188 + ] + }, + { + "teal": 265, + "source": "tests/contracts/cblocks.algo.ts:53", + "pc": [ + 189 + ] + }, + { + "teal": 269, + "source": "tests/contracts/cblocks.algo.ts:54", + "pc": [ + 190, + 191 + ] + }, + { + "teal": 270, + "source": "tests/contracts/cblocks.algo.ts:54", + "pc": [ + 192 + ] + }, + { + "teal": 274, + "source": "tests/contracts/cblocks.algo.ts:55", + "pc": [ + 193, + 194 + ] + }, + { + "teal": 275, + "source": "tests/contracts/cblocks.algo.ts:55", + "pc": [ + 195 + ] + }, + { + "teal": 279, + "source": "tests/contracts/cblocks.algo.ts:56", + "pc": [ + 196, + 197 + ] + }, + { + "teal": 280, + "source": "tests/contracts/cblocks.algo.ts:56", + "pc": [ + 198 + ] + }, + { + "teal": 284, + "source": "tests/contracts/cblocks.algo.ts:57", + "pc": [ + 199, + 200 + ] + }, + { + "teal": 285, + "source": "tests/contracts/cblocks.algo.ts:57", + "pc": [ + 201 + ] + }, + { + "teal": 289, + "source": "tests/contracts/cblocks.algo.ts:58", + "pc": [ + 202, + 203 + ] + }, + { + "teal": 290, + "source": "tests/contracts/cblocks.algo.ts:58", + "pc": [ + 204 + ] + }, + { + "teal": 294, + "source": "tests/contracts/cblocks.algo.ts:59", + "pc": [ + 205, + 206 + ] + }, + { + "teal": 295, + "source": "tests/contracts/cblocks.algo.ts:59", + "pc": [ + 207 + ] + }, + { + "teal": 299, + "source": "tests/contracts/cblocks.algo.ts:60", + "pc": [ + 208, + 209 + ] + }, + { + "teal": 300, + "source": "tests/contracts/cblocks.algo.ts:60", + "pc": [ + 210 + ] + }, + { + "teal": 304, + "source": "tests/contracts/cblocks.algo.ts:61", + "pc": [ + 211, + 212 + ] + }, + { + "teal": 305, + "source": "tests/contracts/cblocks.algo.ts:61", + "pc": [ + 213 + ] + }, + { + "teal": 309, + "source": "tests/contracts/cblocks.algo.ts:62", + "pc": [ + 214, + 215 + ] + }, + { + "teal": 310, + "source": "tests/contracts/cblocks.algo.ts:62", + "pc": [ + 216 + ] + }, + { + "teal": 314, + "source": "tests/contracts/cblocks.algo.ts:63", + "pc": [ + 217, + 218 + ] + }, + { + "teal": 315, + "source": "tests/contracts/cblocks.algo.ts:63", + "pc": [ + 219 + ] + }, + { + "teal": 319, + "source": "tests/contracts/cblocks.algo.ts:64", + "pc": [ + 220, + 221 + ] + }, + { + "teal": 320, + "source": "tests/contracts/cblocks.algo.ts:64", + "pc": [ + 222 + ] + }, + { + "teal": 324, + "source": "tests/contracts/cblocks.algo.ts:65", + "pc": [ + 223, + 224 + ] + }, + { + "teal": 325, + "source": "tests/contracts/cblocks.algo.ts:65", + "pc": [ + 225 + ] + }, + { + "teal": 329, + "source": "tests/contracts/cblocks.algo.ts:66", + "pc": [ + 226, + 227 + ] + }, + { + "teal": 330, + "source": "tests/contracts/cblocks.algo.ts:66", + "pc": [ + 228 + ] + }, + { + "teal": 334, + "source": "tests/contracts/cblocks.algo.ts:67", + "pc": [ + 229, + 230 + ] + }, + { + "teal": 335, + "source": "tests/contracts/cblocks.algo.ts:67", + "pc": [ + 231 + ] + }, + { + "teal": 339, + "source": "tests/contracts/cblocks.algo.ts:68", + "pc": [ + 232, + 233 + ] + }, + { + "teal": 340, + "source": "tests/contracts/cblocks.algo.ts:68", + "pc": [ + 234 + ] + }, + { + "teal": 344, + "source": "tests/contracts/cblocks.algo.ts:69", + "pc": [ + 235, + 236 + ] + }, + { + "teal": 345, + "source": "tests/contracts/cblocks.algo.ts:69", + "pc": [ + 237 + ] + }, + { + "teal": 349, + "source": "tests/contracts/cblocks.algo.ts:70", + "pc": [ + 238, + 239 + ] + }, + { + "teal": 350, + "source": "tests/contracts/cblocks.algo.ts:70", + "pc": [ + 240 + ] + }, + { + "teal": 354, + "source": "tests/contracts/cblocks.algo.ts:71", + "pc": [ + 241, + 242 + ] + }, + { + "teal": 355, + "source": "tests/contracts/cblocks.algo.ts:71", + "pc": [ + 243 + ] + }, + { + "teal": 359, + "source": "tests/contracts/cblocks.algo.ts:72", + "pc": [ + 244, + 245 + ] + }, + { + "teal": 360, + "source": "tests/contracts/cblocks.algo.ts:72", + "pc": [ + 246 + ] + }, + { + "teal": 364, + "source": "tests/contracts/cblocks.algo.ts:73", + "pc": [ + 247, + 248 + ] + }, + { + "teal": 365, + "source": "tests/contracts/cblocks.algo.ts:73", + "pc": [ + 249 + ] + }, + { + "teal": 369, + "source": "tests/contracts/cblocks.algo.ts:74", + "pc": [ + 250, + 251 + ] + }, + { + "teal": 370, + "source": "tests/contracts/cblocks.algo.ts:74", + "pc": [ + 252 + ] + }, + { + "teal": 374, + "source": "tests/contracts/cblocks.algo.ts:75", + "pc": [ + 253, + 254 + ] + }, + { + "teal": 375, + "source": "tests/contracts/cblocks.algo.ts:75", + "pc": [ + 255 + ] + }, + { + "teal": 379, + "source": "tests/contracts/cblocks.algo.ts:76", + "pc": [ + 256, + 257 + ] + }, + { + "teal": 380, + "source": "tests/contracts/cblocks.algo.ts:76", + "pc": [ + 258 + ] + }, + { + "teal": 384, + "source": "tests/contracts/cblocks.algo.ts:77", + "pc": [ + 259, + 260 + ] + }, + { + "teal": 385, + "source": "tests/contracts/cblocks.algo.ts:77", + "pc": [ + 261 + ] + }, + { + "teal": 389, + "source": "tests/contracts/cblocks.algo.ts:78", + "pc": [ + 262, + 263 + ] + }, + { + "teal": 390, + "source": "tests/contracts/cblocks.algo.ts:78", + "pc": [ + 264 + ] + }, + { + "teal": 394, + "source": "tests/contracts/cblocks.algo.ts:79", + "pc": [ + 265, + 266 + ] + }, + { + "teal": 395, + "source": "tests/contracts/cblocks.algo.ts:79", + "pc": [ + 267 + ] + }, + { + "teal": 399, + "source": "tests/contracts/cblocks.algo.ts:80", + "pc": [ + 268, + 269 + ] + }, + { + "teal": 400, + "source": "tests/contracts/cblocks.algo.ts:80", + "pc": [ + 270 + ] + }, + { + "teal": 404, + "source": "tests/contracts/cblocks.algo.ts:81", + "pc": [ + 271, + 272 + ] + }, + { + "teal": 405, + "source": "tests/contracts/cblocks.algo.ts:81", + "pc": [ + 273 + ] + }, + { + "teal": 409, + "source": "tests/contracts/cblocks.algo.ts:82", + "pc": [ + 274, + 275 + ] + }, + { + "teal": 410, + "source": "tests/contracts/cblocks.algo.ts:82", + "pc": [ + 276 + ] + }, + { + "teal": 414, + "source": "tests/contracts/cblocks.algo.ts:83", + "pc": [ + 277, + 278 + ] + }, + { + "teal": 415, + "source": "tests/contracts/cblocks.algo.ts:83", + "pc": [ + 279 + ] + }, + { + "teal": 419, + "source": "tests/contracts/cblocks.algo.ts:84", + "pc": [ + 280, + 281 + ] + }, + { + "teal": 420, + "source": "tests/contracts/cblocks.algo.ts:84", + "pc": [ + 282 + ] + }, + { + "teal": 424, + "source": "tests/contracts/cblocks.algo.ts:85", + "pc": [ + 283, + 284 + ] + }, + { + "teal": 425, + "source": "tests/contracts/cblocks.algo.ts:85", + "pc": [ + 285 + ] + }, + { + "teal": 429, + "source": "tests/contracts/cblocks.algo.ts:86", + "pc": [ + 286, + 287 + ] + }, + { + "teal": 430, + "source": "tests/contracts/cblocks.algo.ts:86", + "pc": [ + 288 + ] + }, + { + "teal": 434, + "source": "tests/contracts/cblocks.algo.ts:87", + "pc": [ + 289, + 290 + ] + }, + { + "teal": 435, + "source": "tests/contracts/cblocks.algo.ts:87", + "pc": [ + 291 + ] + }, + { + "teal": 439, + "source": "tests/contracts/cblocks.algo.ts:88", + "pc": [ + 292, + 293 + ] + }, + { + "teal": 440, + "source": "tests/contracts/cblocks.algo.ts:88", + "pc": [ + 294 + ] + }, + { + "teal": 444, + "source": "tests/contracts/cblocks.algo.ts:89", + "pc": [ + 295, + 296 + ] + }, + { + "teal": 445, + "source": "tests/contracts/cblocks.algo.ts:89", + "pc": [ + 297 + ] + }, + { + "teal": 449, + "source": "tests/contracts/cblocks.algo.ts:90", + "pc": [ + 298, + 299 + ] + }, + { + "teal": 450, + "source": "tests/contracts/cblocks.algo.ts:90", + "pc": [ + 300 + ] + }, + { + "teal": 454, + "source": "tests/contracts/cblocks.algo.ts:91", + "pc": [ + 301, + 302 + ] + }, + { + "teal": 455, + "source": "tests/contracts/cblocks.algo.ts:91", + "pc": [ + 303 + ] + }, + { + "teal": 459, + "source": "tests/contracts/cblocks.algo.ts:92", + "pc": [ + 304, + 305 + ] + }, + { + "teal": 460, + "source": "tests/contracts/cblocks.algo.ts:92", + "pc": [ + 306 + ] + }, + { + "teal": 464, + "source": "tests/contracts/cblocks.algo.ts:93", + "pc": [ + 307, + 308 + ] + }, + { + "teal": 465, + "source": "tests/contracts/cblocks.algo.ts:93", + "pc": [ + 309 + ] + }, + { + "teal": 469, + "source": "tests/contracts/cblocks.algo.ts:94", + "pc": [ + 310, + 311 + ] + }, + { + "teal": 470, + "source": "tests/contracts/cblocks.algo.ts:94", + "pc": [ + 312 + ] + }, + { + "teal": 474, + "source": "tests/contracts/cblocks.algo.ts:95", + "pc": [ + 313, + 314 + ] + }, + { + "teal": 475, + "source": "tests/contracts/cblocks.algo.ts:95", + "pc": [ + 315 + ] + }, + { + "teal": 479, + "source": "tests/contracts/cblocks.algo.ts:96", + "pc": [ + 316, + 317 + ] + }, + { + "teal": 480, + "source": "tests/contracts/cblocks.algo.ts:96", + "pc": [ + 318 + ] + }, + { + "teal": 484, + "source": "tests/contracts/cblocks.algo.ts:97", + "pc": [ + 319, + 320 + ] + }, + { + "teal": 485, + "source": "tests/contracts/cblocks.algo.ts:97", + "pc": [ + 321 + ] + }, + { + "teal": 489, + "source": "tests/contracts/cblocks.algo.ts:98", + "pc": [ + 322, + 323 + ] + }, + { + "teal": 490, + "source": "tests/contracts/cblocks.algo.ts:98", + "pc": [ + 324 + ] + }, + { + "teal": 494, + "source": "tests/contracts/cblocks.algo.ts:99", + "pc": [ + 325, + 326 + ] + }, + { + "teal": 495, + "source": "tests/contracts/cblocks.algo.ts:99", + "pc": [ + 327 + ] + }, + { + "teal": 499, + "source": "tests/contracts/cblocks.algo.ts:100", + "pc": [ + 328, + 329 + ] + }, + { + "teal": 500, + "source": "tests/contracts/cblocks.algo.ts:100", + "pc": [ + 330 + ] + }, + { + "teal": 504, + "source": "tests/contracts/cblocks.algo.ts:101", + "pc": [ + 331, + 332 + ] + }, + { + "teal": 505, + "source": "tests/contracts/cblocks.algo.ts:101", + "pc": [ + 333 + ] + }, + { + "teal": 509, + "source": "tests/contracts/cblocks.algo.ts:102", + "pc": [ + 334, + 335 + ] + }, + { + "teal": 510, + "source": "tests/contracts/cblocks.algo.ts:102", + "pc": [ + 336 + ] + }, + { + "teal": 514, + "source": "tests/contracts/cblocks.algo.ts:103", + "pc": [ + 337, + 338 + ] + }, + { + "teal": 515, + "source": "tests/contracts/cblocks.algo.ts:103", + "pc": [ + 339 + ] + }, + { + "teal": 519, + "source": "tests/contracts/cblocks.algo.ts:104", + "pc": [ + 340, + 341 + ] + }, + { + "teal": 520, + "source": "tests/contracts/cblocks.algo.ts:104", + "pc": [ + 342 + ] + }, + { + "teal": 524, + "source": "tests/contracts/cblocks.algo.ts:105", + "pc": [ + 343, + 344 + ] + }, + { + "teal": 525, + "source": "tests/contracts/cblocks.algo.ts:105", + "pc": [ + 345 + ] + }, + { + "teal": 529, + "source": "tests/contracts/cblocks.algo.ts:106", + "pc": [ + 346, + 347 + ] + }, + { + "teal": 530, + "source": "tests/contracts/cblocks.algo.ts:106", + "pc": [ + 348 + ] + }, + { + "teal": 534, + "source": "tests/contracts/cblocks.algo.ts:107", + "pc": [ + 349, + 350 + ] + }, + { + "teal": 535, + "source": "tests/contracts/cblocks.algo.ts:107", + "pc": [ + 351 + ] + }, + { + "teal": 539, + "source": "tests/contracts/cblocks.algo.ts:108", + "pc": [ + 352, + 353 + ] + }, + { + "teal": 540, + "source": "tests/contracts/cblocks.algo.ts:108", + "pc": [ + 354 + ] + }, + { + "teal": 544, + "source": "tests/contracts/cblocks.algo.ts:109", + "pc": [ + 355, + 356 + ] + }, + { + "teal": 545, + "source": "tests/contracts/cblocks.algo.ts:109", + "pc": [ + 357 + ] + }, + { + "teal": 549, + "source": "tests/contracts/cblocks.algo.ts:110", + "pc": [ + 358, + 359 + ] + }, + { + "teal": 550, + "source": "tests/contracts/cblocks.algo.ts:110", + "pc": [ + 360 + ] + }, + { + "teal": 554, + "source": "tests/contracts/cblocks.algo.ts:111", + "pc": [ + 361, + 362 + ] + }, + { + "teal": 555, + "source": "tests/contracts/cblocks.algo.ts:111", + "pc": [ + 363 + ] + }, + { + "teal": 559, + "source": "tests/contracts/cblocks.algo.ts:112", + "pc": [ + 364, + 365 + ] + }, + { + "teal": 560, + "source": "tests/contracts/cblocks.algo.ts:112", + "pc": [ + 366 + ] + }, + { + "teal": 564, + "source": "tests/contracts/cblocks.algo.ts:113", + "pc": [ + 367, + 368 + ] + }, + { + "teal": 565, + "source": "tests/contracts/cblocks.algo.ts:113", + "pc": [ + 369 + ] + }, + { + "teal": 569, + "source": "tests/contracts/cblocks.algo.ts:114", + "pc": [ + 370, + 371 + ] + }, + { + "teal": 570, + "source": "tests/contracts/cblocks.algo.ts:114", + "pc": [ + 372 + ] + }, + { + "teal": 574, + "source": "tests/contracts/cblocks.algo.ts:115", + "pc": [ + 373, + 374 + ] + }, + { + "teal": 575, + "source": "tests/contracts/cblocks.algo.ts:115", + "pc": [ + 375 + ] + }, + { + "teal": 579, + "source": "tests/contracts/cblocks.algo.ts:116", + "pc": [ + 376, + 377 + ] + }, + { + "teal": 580, + "source": "tests/contracts/cblocks.algo.ts:116", + "pc": [ + 378 + ] + }, + { + "teal": 584, + "source": "tests/contracts/cblocks.algo.ts:117", + "pc": [ + 379, + 380 + ] + }, + { + "teal": 585, + "source": "tests/contracts/cblocks.algo.ts:117", + "pc": [ + 381 + ] + }, + { + "teal": 589, + "source": "tests/contracts/cblocks.algo.ts:118", + "pc": [ + 382, + 383 + ] + }, + { + "teal": 590, + "source": "tests/contracts/cblocks.algo.ts:118", + "pc": [ + 384 + ] + }, + { + "teal": 594, + "source": "tests/contracts/cblocks.algo.ts:119", + "pc": [ + 385, + 386 + ] + }, + { + "teal": 595, + "source": "tests/contracts/cblocks.algo.ts:119", + "pc": [ + 387 + ] + }, + { + "teal": 599, + "source": "tests/contracts/cblocks.algo.ts:120", + "pc": [ + 388, + 389 + ] + }, + { + "teal": 600, + "source": "tests/contracts/cblocks.algo.ts:120", + "pc": [ + 390 + ] + }, + { + "teal": 604, + "source": "tests/contracts/cblocks.algo.ts:121", + "pc": [ + 391, + 392 + ] + }, + { + "teal": 605, + "source": "tests/contracts/cblocks.algo.ts:121", + "pc": [ + 393 + ] + }, + { + "teal": 609, + "source": "tests/contracts/cblocks.algo.ts:122", + "pc": [ + 394, + 395 + ] + }, + { + "teal": 610, + "source": "tests/contracts/cblocks.algo.ts:122", + "pc": [ + 396 + ] + }, + { + "teal": 614, + "source": "tests/contracts/cblocks.algo.ts:123", + "pc": [ + 397, + 398 + ] + }, + { + "teal": 615, + "source": "tests/contracts/cblocks.algo.ts:123", + "pc": [ + 399 + ] + }, + { + "teal": 619, + "source": "tests/contracts/cblocks.algo.ts:124", + "pc": [ + 400, + 401 + ] + }, + { + "teal": 620, + "source": "tests/contracts/cblocks.algo.ts:124", + "pc": [ + 402 + ] + }, + { + "teal": 624, + "source": "tests/contracts/cblocks.algo.ts:125", + "pc": [ + 403, + 404 + ] + }, + { + "teal": 625, + "source": "tests/contracts/cblocks.algo.ts:125", + "pc": [ + 405 + ] + }, + { + "teal": 629, + "source": "tests/contracts/cblocks.algo.ts:126", + "pc": [ + 406, + 407 + ] + }, + { + "teal": 630, + "source": "tests/contracts/cblocks.algo.ts:126", + "pc": [ + 408 + ] + }, + { + "teal": 634, + "source": "tests/contracts/cblocks.algo.ts:127", + "pc": [ + 409, + 410 + ] + }, + { + "teal": 635, + "source": "tests/contracts/cblocks.algo.ts:127", + "pc": [ + 411 + ] + }, + { + "teal": 639, + "source": "tests/contracts/cblocks.algo.ts:128", + "pc": [ + 412, + 413 + ] + }, + { + "teal": 640, + "source": "tests/contracts/cblocks.algo.ts:128", + "pc": [ + 414 + ] + }, + { + "teal": 644, + "source": "tests/contracts/cblocks.algo.ts:129", + "pc": [ + 415, + 416 + ] + }, + { + "teal": 645, + "source": "tests/contracts/cblocks.algo.ts:129", + "pc": [ + 417 + ] + }, + { + "teal": 649, + "source": "tests/contracts/cblocks.algo.ts:130", + "pc": [ + 418, + 419 + ] + }, + { + "teal": 650, + "source": "tests/contracts/cblocks.algo.ts:130", + "pc": [ + 420 + ] + }, + { + "teal": 654, + "source": "tests/contracts/cblocks.algo.ts:131", + "pc": [ + 421, + 422 + ] + }, + { + "teal": 655, + "source": "tests/contracts/cblocks.algo.ts:131", + "pc": [ + 423 + ] + }, + { + "teal": 659, + "source": "tests/contracts/cblocks.algo.ts:132", + "pc": [ + 424, + 425 + ] + }, + { + "teal": 660, + "source": "tests/contracts/cblocks.algo.ts:132", + "pc": [ + 426 + ] + }, + { + "teal": 664, + "source": "tests/contracts/cblocks.algo.ts:133", + "pc": [ + 427, + 428 + ] + }, + { + "teal": 665, + "source": "tests/contracts/cblocks.algo.ts:133", + "pc": [ + 429 + ] + }, + { + "teal": 669, + "source": "tests/contracts/cblocks.algo.ts:134", + "pc": [ + 430, + 431 + ] + }, + { + "teal": 670, + "source": "tests/contracts/cblocks.algo.ts:134", + "pc": [ + 432 + ] + }, + { + "teal": 674, + "source": "tests/contracts/cblocks.algo.ts:135", + "pc": [ + 433, + 434, + 435 + ] + }, + { + "teal": 675, + "source": "tests/contracts/cblocks.algo.ts:135", + "pc": [ + 436 + ] + }, + { + "teal": 679, + "source": "tests/contracts/cblocks.algo.ts:136", + "pc": [ + 437, + 438, + 439 + ] + }, + { + "teal": 680, + "source": "tests/contracts/cblocks.algo.ts:136", + "pc": [ + 440 + ] + }, + { + "teal": 684, + "source": "tests/contracts/cblocks.algo.ts:137", + "pc": [ + 441, + 442, + 443 + ] + }, + { + "teal": 685, + "source": "tests/contracts/cblocks.algo.ts:137", + "pc": [ + 444 + ] + }, + { + "teal": 689, + "source": "tests/contracts/cblocks.algo.ts:138", + "pc": [ + 445, + 446, + 447 + ] + }, + { + "teal": 690, + "source": "tests/contracts/cblocks.algo.ts:138", + "pc": [ + 448 + ] + }, + { + "teal": 694, + "source": "tests/contracts/cblocks.algo.ts:139", + "pc": [ + 449, + 450, + 451 + ] + }, + { + "teal": 695, + "source": "tests/contracts/cblocks.algo.ts:139", + "pc": [ + 452 + ] + }, + { + "teal": 699, + "source": "tests/contracts/cblocks.algo.ts:140", + "pc": [ + 453, + 454, + 455 + ] + }, + { + "teal": 700, + "source": "tests/contracts/cblocks.algo.ts:140", + "pc": [ + 456 + ] + }, + { + "teal": 704, + "source": "tests/contracts/cblocks.algo.ts:141", + "pc": [ + 457, + 458, + 459 + ] + }, + { + "teal": 705, + "source": "tests/contracts/cblocks.algo.ts:141", + "pc": [ + 460 + ] + }, + { + "teal": 709, + "source": "tests/contracts/cblocks.algo.ts:142", + "pc": [ + 461, + 462, + 463 + ] + }, + { + "teal": 710, + "source": "tests/contracts/cblocks.algo.ts:142", + "pc": [ + 464 + ] + }, + { + "teal": 714, + "source": "tests/contracts/cblocks.algo.ts:143", + "pc": [ + 465, + 466, + 467 + ] + }, + { + "teal": 715, + "source": "tests/contracts/cblocks.algo.ts:143", + "pc": [ + 468 + ] + }, + { + "teal": 719, + "source": "tests/contracts/cblocks.algo.ts:144", + "pc": [ + 469, + 470, + 471 + ] + }, + { + "teal": 720, + "source": "tests/contracts/cblocks.algo.ts:144", + "pc": [ + 472 + ] + }, + { + "teal": 724, + "source": "tests/contracts/cblocks.algo.ts:145", + "pc": [ + 473, + 474, + 475 + ] + }, + { + "teal": 725, + "source": "tests/contracts/cblocks.algo.ts:145", + "pc": [ + 476 + ] + }, + { + "teal": 729, + "source": "tests/contracts/cblocks.algo.ts:146", + "pc": [ + 477, + 478, + 479 + ] + }, + { + "teal": 730, + "source": "tests/contracts/cblocks.algo.ts:146", + "pc": [ + 480 + ] + }, + { + "teal": 734, + "source": "tests/contracts/cblocks.algo.ts:147", + "pc": [ + 481, + 482, + 483 + ] + }, + { + "teal": 735, + "source": "tests/contracts/cblocks.algo.ts:147", + "pc": [ + 484 + ] + }, + { + "teal": 739, + "source": "tests/contracts/cblocks.algo.ts:148", + "pc": [ + 485, + 486, + 487 + ] + }, + { + "teal": 740, + "source": "tests/contracts/cblocks.algo.ts:148", + "pc": [ + 488 + ] + }, + { + "teal": 744, + "source": "tests/contracts/cblocks.algo.ts:149", + "pc": [ + 489, + 490, + 491 + ] + }, + { + "teal": 745, + "source": "tests/contracts/cblocks.algo.ts:149", + "pc": [ + 492 + ] + }, + { + "teal": 749, + "source": "tests/contracts/cblocks.algo.ts:150", + "pc": [ + 493, + 494, + 495 + ] + }, + { + "teal": 750, + "source": "tests/contracts/cblocks.algo.ts:150", + "pc": [ + 496 + ] + }, + { + "teal": 754, + "source": "tests/contracts/cblocks.algo.ts:151", + "pc": [ + 497, + 498, + 499 + ] + }, + { + "teal": 755, + "source": "tests/contracts/cblocks.algo.ts:151", + "pc": [ + 500 + ] + }, + { + "teal": 759, + "source": "tests/contracts/cblocks.algo.ts:152", + "pc": [ + 501, + 502, + 503 + ] + }, + { + "teal": 760, + "source": "tests/contracts/cblocks.algo.ts:152", + "pc": [ + 504 + ] + }, + { + "teal": 764, + "source": "tests/contracts/cblocks.algo.ts:153", + "pc": [ + 505, + 506, + 507 + ] + }, + { + "teal": 765, + "source": "tests/contracts/cblocks.algo.ts:153", + "pc": [ + 508 + ] + }, + { + "teal": 769, + "source": "tests/contracts/cblocks.algo.ts:154", + "pc": [ + 509, + 510, + 511 + ] + }, + { + "teal": 770, + "source": "tests/contracts/cblocks.algo.ts:154", + "pc": [ + 512 + ] + }, + { + "teal": 774, + "source": "tests/contracts/cblocks.algo.ts:155", + "pc": [ + 513, + 514, + 515 + ] + }, + { + "teal": 775, + "source": "tests/contracts/cblocks.algo.ts:155", + "pc": [ + 516 + ] + }, + { + "teal": 779, + "source": "tests/contracts/cblocks.algo.ts:156", + "pc": [ + 517, + 518, + 519 + ] + }, + { + "teal": 780, + "source": "tests/contracts/cblocks.algo.ts:156", + "pc": [ + 520 + ] + }, + { + "teal": 784, + "source": "tests/contracts/cblocks.algo.ts:157", + "pc": [ + 521, + 522, + 523 + ] + }, + { + "teal": 785, + "source": "tests/contracts/cblocks.algo.ts:157", + "pc": [ + 524 + ] + }, + { + "teal": 789, + "source": "tests/contracts/cblocks.algo.ts:158", + "pc": [ + 525, + 526, + 527 + ] + }, + { + "teal": 790, + "source": "tests/contracts/cblocks.algo.ts:158", + "pc": [ + 528 + ] + }, + { + "teal": 794, + "source": "tests/contracts/cblocks.algo.ts:159", + "pc": [ + 529, + 530, + 531 + ] + }, + { + "teal": 795, + "source": "tests/contracts/cblocks.algo.ts:159", + "pc": [ + 532 + ] + }, + { + "teal": 799, + "source": "tests/contracts/cblocks.algo.ts:160", + "pc": [ + 533, + 534, + 535 + ] + }, + { + "teal": 800, + "source": "tests/contracts/cblocks.algo.ts:160", + "pc": [ + 536 + ] + }, + { + "teal": 804, + "source": "tests/contracts/cblocks.algo.ts:161", + "pc": [ + 537, + 538, + 539 + ] + }, + { + "teal": 805, + "source": "tests/contracts/cblocks.algo.ts:161", + "pc": [ + 540 + ] + }, + { + "teal": 809, + "source": "tests/contracts/cblocks.algo.ts:162", + "pc": [ + 541, + 542, + 543 + ] + }, + { + "teal": 810, + "source": "tests/contracts/cblocks.algo.ts:162", + "pc": [ + 544 + ] + }, + { + "teal": 814, + "source": "tests/contracts/cblocks.algo.ts:163", + "pc": [ + 545, + 546, + 547 + ] + }, + { + "teal": 815, + "source": "tests/contracts/cblocks.algo.ts:163", + "pc": [ + 548 + ] + }, + { + "teal": 819, + "source": "tests/contracts/cblocks.algo.ts:164", + "pc": [ + 549, + 550, + 551 + ] + }, + { + "teal": 820, + "source": "tests/contracts/cblocks.algo.ts:164", + "pc": [ + 552 + ] + }, + { + "teal": 824, + "source": "tests/contracts/cblocks.algo.ts:165", + "pc": [ + 553, + 554, + 555 + ] + }, + { + "teal": 825, + "source": "tests/contracts/cblocks.algo.ts:165", + "pc": [ + 556 + ] + }, + { + "teal": 829, + "source": "tests/contracts/cblocks.algo.ts:166", + "pc": [ + 557, + 558, + 559 + ] + }, + { + "teal": 830, + "source": "tests/contracts/cblocks.algo.ts:166", + "pc": [ + 560 + ] + }, + { + "teal": 834, + "source": "tests/contracts/cblocks.algo.ts:167", + "pc": [ + 561, + 562, + 563 + ] + }, + { + "teal": 835, + "source": "tests/contracts/cblocks.algo.ts:167", + "pc": [ + 564 + ] + }, + { + "teal": 839, + "source": "tests/contracts/cblocks.algo.ts:168", + "pc": [ + 565, + 566, + 567 + ] + }, + { + "teal": 840, + "source": "tests/contracts/cblocks.algo.ts:168", + "pc": [ + 568 + ] + }, + { + "teal": 844, + "source": "tests/contracts/cblocks.algo.ts:169", + "pc": [ + 569, + 570, + 571 + ] + }, + { + "teal": 845, + "source": "tests/contracts/cblocks.algo.ts:169", + "pc": [ + 572 + ] + }, + { + "teal": 849, + "source": "tests/contracts/cblocks.algo.ts:170", + "pc": [ + 573, + 574, + 575 + ] + }, + { + "teal": 850, + "source": "tests/contracts/cblocks.algo.ts:170", + "pc": [ + 576 + ] + }, + { + "teal": 854, + "source": "tests/contracts/cblocks.algo.ts:171", + "pc": [ + 577, + 578, + 579 + ] + }, + { + "teal": 855, + "source": "tests/contracts/cblocks.algo.ts:171", + "pc": [ + 580 + ] + }, + { + "teal": 859, + "source": "tests/contracts/cblocks.algo.ts:172", + "pc": [ + 581, + 582, + 583 + ] + }, + { + "teal": 860, + "source": "tests/contracts/cblocks.algo.ts:172", + "pc": [ + 584 + ] + }, + { + "teal": 864, + "source": "tests/contracts/cblocks.algo.ts:173", + "pc": [ + 585, + 586, + 587 + ] + }, + { + "teal": 865, + "source": "tests/contracts/cblocks.algo.ts:173", + "pc": [ + 588 + ] + }, + { + "teal": 869, + "source": "tests/contracts/cblocks.algo.ts:174", + "pc": [ + 589, + 590, + 591 + ] + }, + { + "teal": 870, + "source": "tests/contracts/cblocks.algo.ts:174", + "pc": [ + 592 + ] + }, + { + "teal": 874, + "source": "tests/contracts/cblocks.algo.ts:175", + "pc": [ + 593, + 594, + 595 + ] + }, + { + "teal": 875, + "source": "tests/contracts/cblocks.algo.ts:175", + "pc": [ + 596 + ] + }, + { + "teal": 879, + "source": "tests/contracts/cblocks.algo.ts:176", + "pc": [ + 597, + 598, + 599 + ] + }, + { + "teal": 880, + "source": "tests/contracts/cblocks.algo.ts:176", + "pc": [ + 600 + ] + }, + { + "teal": 884, + "source": "tests/contracts/cblocks.algo.ts:177", + "pc": [ + 601, + 602, + 603 + ] + }, + { + "teal": 885, + "source": "tests/contracts/cblocks.algo.ts:177", + "pc": [ + 604 + ] + }, + { + "teal": 889, + "source": "tests/contracts/cblocks.algo.ts:178", + "pc": [ + 605, + 606, + 607 + ] + }, + { + "teal": 890, + "source": "tests/contracts/cblocks.algo.ts:178", + "pc": [ + 608 + ] + }, + { + "teal": 894, + "source": "tests/contracts/cblocks.algo.ts:179", + "pc": [ + 609, + 610, + 611 + ] + }, + { + "teal": 895, + "source": "tests/contracts/cblocks.algo.ts:179", + "pc": [ + 612 + ] + }, + { + "teal": 899, + "source": "tests/contracts/cblocks.algo.ts:180", + "pc": [ + 613, + 614, + 615 + ] + }, + { + "teal": 900, + "source": "tests/contracts/cblocks.algo.ts:180", + "pc": [ + 616 + ] + }, + { + "teal": 904, + "source": "tests/contracts/cblocks.algo.ts:181", + "pc": [ + 617, + 618, + 619 + ] + }, + { + "teal": 905, + "source": "tests/contracts/cblocks.algo.ts:181", + "pc": [ + 620 + ] + }, + { + "teal": 909, + "source": "tests/contracts/cblocks.algo.ts:182", + "pc": [ + 621, + 622, + 623 + ] + }, + { + "teal": 910, + "source": "tests/contracts/cblocks.algo.ts:182", + "pc": [ + 624 + ] + }, + { + "teal": 914, + "source": "tests/contracts/cblocks.algo.ts:183", + "pc": [ + 625, + 626, + 627 + ] + }, + { + "teal": 915, + "source": "tests/contracts/cblocks.algo.ts:183", + "pc": [ + 628 + ] + }, + { + "teal": 919, + "source": "tests/contracts/cblocks.algo.ts:184", + "pc": [ + 629, + 630, + 631 + ] + }, + { + "teal": 920, + "source": "tests/contracts/cblocks.algo.ts:184", + "pc": [ + 632 + ] + }, + { + "teal": 924, + "source": "tests/contracts/cblocks.algo.ts:185", + "pc": [ + 633, + 634, + 635 + ] + }, + { + "teal": 925, + "source": "tests/contracts/cblocks.algo.ts:185", + "pc": [ + 636 + ] + }, + { + "teal": 929, + "source": "tests/contracts/cblocks.algo.ts:186", + "pc": [ + 637, + 638, + 639 + ] + }, + { + "teal": 930, + "source": "tests/contracts/cblocks.algo.ts:186", + "pc": [ + 640 + ] + }, + { + "teal": 934, + "source": "tests/contracts/cblocks.algo.ts:187", + "pc": [ + 641, + 642, + 643 + ] + }, + { + "teal": 935, + "source": "tests/contracts/cblocks.algo.ts:187", + "pc": [ + 644 + ] + }, + { + "teal": 939, + "source": "tests/contracts/cblocks.algo.ts:188", + "pc": [ + 645, + 646, + 647 + ] + }, + { + "teal": 940, + "source": "tests/contracts/cblocks.algo.ts:188", + "pc": [ + 648 + ] + }, + { + "teal": 944, + "source": "tests/contracts/cblocks.algo.ts:189", + "pc": [ + 649, + 650, + 651 + ] + }, + { + "teal": 945, + "source": "tests/contracts/cblocks.algo.ts:189", + "pc": [ + 652 + ] + }, + { + "teal": 949, + "source": "tests/contracts/cblocks.algo.ts:190", + "pc": [ + 653, + 654, + 655 + ] + }, + { + "teal": 950, + "source": "tests/contracts/cblocks.algo.ts:190", + "pc": [ + 656 + ] + }, + { + "teal": 954, + "source": "tests/contracts/cblocks.algo.ts:191", + "pc": [ + 657, + 658, + 659 + ] + }, + { + "teal": 955, + "source": "tests/contracts/cblocks.algo.ts:191", + "pc": [ + 660 + ] + }, + { + "teal": 959, + "source": "tests/contracts/cblocks.algo.ts:192", + "pc": [ + 661, + 662, + 663 + ] + }, + { + "teal": 960, + "source": "tests/contracts/cblocks.algo.ts:192", + "pc": [ + 664 + ] + }, + { + "teal": 964, + "source": "tests/contracts/cblocks.algo.ts:193", + "pc": [ + 665, + 666, + 667 + ] + }, + { + "teal": 965, + "source": "tests/contracts/cblocks.algo.ts:193", + "pc": [ + 668 + ] + }, + { + "teal": 969, + "source": "tests/contracts/cblocks.algo.ts:194", + "pc": [ + 669, + 670, + 671 + ] + }, + { + "teal": 970, + "source": "tests/contracts/cblocks.algo.ts:194", + "pc": [ + 672 + ] + }, + { + "teal": 974, + "source": "tests/contracts/cblocks.algo.ts:195", + "pc": [ + 673, + 674, + 675 + ] + }, + { + "teal": 975, + "source": "tests/contracts/cblocks.algo.ts:195", + "pc": [ + 676 + ] + }, + { + "teal": 979, + "source": "tests/contracts/cblocks.algo.ts:196", + "pc": [ + 677, + 678, + 679 + ] + }, + { + "teal": 980, + "source": "tests/contracts/cblocks.algo.ts:196", + "pc": [ + 680 + ] + }, + { + "teal": 984, + "source": "tests/contracts/cblocks.algo.ts:197", + "pc": [ + 681, + 682, + 683 + ] + }, + { + "teal": 985, + "source": "tests/contracts/cblocks.algo.ts:197", + "pc": [ + 684 + ] + }, + { + "teal": 989, + "source": "tests/contracts/cblocks.algo.ts:198", + "pc": [ + 685, + 686, + 687 + ] + }, + { + "teal": 990, + "source": "tests/contracts/cblocks.algo.ts:198", + "pc": [ + 688 + ] + }, + { + "teal": 994, + "source": "tests/contracts/cblocks.algo.ts:199", + "pc": [ + 689, + 690, + 691 + ] + }, + { + "teal": 995, + "source": "tests/contracts/cblocks.algo.ts:199", + "pc": [ + 692 + ] + }, + { + "teal": 999, + "source": "tests/contracts/cblocks.algo.ts:200", + "pc": [ + 693, + 694, + 695 + ] + }, + { + "teal": 1000, + "source": "tests/contracts/cblocks.algo.ts:200", + "pc": [ + 696 + ] + }, + { + "teal": 1004, + "source": "tests/contracts/cblocks.algo.ts:201", + "pc": [ + 697, + 698, + 699 + ] + }, + { + "teal": 1005, + "source": "tests/contracts/cblocks.algo.ts:201", + "pc": [ + 700 + ] + }, + { + "teal": 1009, + "source": "tests/contracts/cblocks.algo.ts:202", + "pc": [ + 701, + 702, + 703 + ] + }, + { + "teal": 1010, + "source": "tests/contracts/cblocks.algo.ts:202", + "pc": [ + 704 + ] + }, + { + "teal": 1014, + "source": "tests/contracts/cblocks.algo.ts:203", + "pc": [ + 705, + 706, + 707 + ] + }, + { + "teal": 1015, + "source": "tests/contracts/cblocks.algo.ts:203", + "pc": [ + 708 + ] + }, + { + "teal": 1019, + "source": "tests/contracts/cblocks.algo.ts:204", + "pc": [ + 709, + 710, + 711 + ] + }, + { + "teal": 1020, + "source": "tests/contracts/cblocks.algo.ts:204", + "pc": [ + 712 + ] + }, + { + "teal": 1024, + "source": "tests/contracts/cblocks.algo.ts:205", + "pc": [ + 713, + 714, + 715 + ] + }, + { + "teal": 1025, + "source": "tests/contracts/cblocks.algo.ts:205", + "pc": [ + 716 + ] + }, + { + "teal": 1029, + "source": "tests/contracts/cblocks.algo.ts:206", + "pc": [ + 717, + 718, + 719 + ] + }, + { + "teal": 1030, + "source": "tests/contracts/cblocks.algo.ts:206", + "pc": [ + 720 + ] + }, + { + "teal": 1034, + "source": "tests/contracts/cblocks.algo.ts:207", + "pc": [ + 721, + 722, + 723 + ] + }, + { + "teal": 1035, + "source": "tests/contracts/cblocks.algo.ts:207", + "pc": [ + 724 + ] + }, + { + "teal": 1039, + "source": "tests/contracts/cblocks.algo.ts:208", + "pc": [ + 725, + 726, + 727 + ] + }, + { + "teal": 1040, + "source": "tests/contracts/cblocks.algo.ts:208", + "pc": [ + 728 + ] + }, + { + "teal": 1044, + "source": "tests/contracts/cblocks.algo.ts:209", + "pc": [ + 729, + 730, + 731 + ] + }, + { + "teal": 1045, + "source": "tests/contracts/cblocks.algo.ts:209", + "pc": [ + 732 + ] + }, + { + "teal": 1049, + "source": "tests/contracts/cblocks.algo.ts:210", + "pc": [ + 733, + 734, + 735 + ] + }, + { + "teal": 1050, + "source": "tests/contracts/cblocks.algo.ts:210", + "pc": [ + 736 + ] + }, + { + "teal": 1054, + "source": "tests/contracts/cblocks.algo.ts:211", + "pc": [ + 737, + 738, + 739 + ] + }, + { + "teal": 1055, + "source": "tests/contracts/cblocks.algo.ts:211", + "pc": [ + 740 + ] + }, + { + "teal": 1059, + "source": "tests/contracts/cblocks.algo.ts:212", + "pc": [ + 741, + 742, + 743 + ] + }, + { + "teal": 1060, + "source": "tests/contracts/cblocks.algo.ts:212", + "pc": [ + 744 + ] + }, + { + "teal": 1064, + "source": "tests/contracts/cblocks.algo.ts:213", + "pc": [ + 745, + 746, + 747 + ] + }, + { + "teal": 1065, + "source": "tests/contracts/cblocks.algo.ts:213", + "pc": [ + 748 + ] + }, + { + "teal": 1069, + "source": "tests/contracts/cblocks.algo.ts:214", + "pc": [ + 749, + 750, + 751 + ] + }, + { + "teal": 1070, + "source": "tests/contracts/cblocks.algo.ts:214", + "pc": [ + 752 + ] + }, + { + "teal": 1074, + "source": "tests/contracts/cblocks.algo.ts:215", + "pc": [ + 753, + 754, + 755 + ] + }, + { + "teal": 1075, + "source": "tests/contracts/cblocks.algo.ts:215", + "pc": [ + 756 + ] + }, + { + "teal": 1079, + "source": "tests/contracts/cblocks.algo.ts:216", + "pc": [ + 757, + 758, + 759 + ] + }, + { + "teal": 1080, + "source": "tests/contracts/cblocks.algo.ts:216", + "pc": [ + 760 + ] + }, + { + "teal": 1084, + "source": "tests/contracts/cblocks.algo.ts:217", + "pc": [ + 761, + 762, + 763 + ] + }, + { + "teal": 1085, + "source": "tests/contracts/cblocks.algo.ts:217", + "pc": [ + 764 + ] + }, + { + "teal": 1089, + "source": "tests/contracts/cblocks.algo.ts:218", + "pc": [ + 765, + 766, + 767 + ] + }, + { + "teal": 1090, + "source": "tests/contracts/cblocks.algo.ts:218", + "pc": [ + 768 + ] + }, + { + "teal": 1094, + "source": "tests/contracts/cblocks.algo.ts:219", + "pc": [ + 769, + 770, + 771 + ] + }, + { + "teal": 1095, + "source": "tests/contracts/cblocks.algo.ts:219", + "pc": [ + 772 + ] + }, + { + "teal": 1099, + "source": "tests/contracts/cblocks.algo.ts:220", + "pc": [ + 773, + 774, + 775 + ] + }, + { + "teal": 1100, + "source": "tests/contracts/cblocks.algo.ts:220", + "pc": [ + 776 + ] + }, + { + "teal": 1104, + "source": "tests/contracts/cblocks.algo.ts:221", + "pc": [ + 777, + 778, + 779 + ] + }, + { + "teal": 1105, + "source": "tests/contracts/cblocks.algo.ts:221", + "pc": [ + 780 + ] + }, + { + "teal": 1109, + "source": "tests/contracts/cblocks.algo.ts:222", + "pc": [ + 781, + 782, + 783 + ] + }, + { + "teal": 1110, + "source": "tests/contracts/cblocks.algo.ts:222", + "pc": [ + 784 + ] + }, + { + "teal": 1114, + "source": "tests/contracts/cblocks.algo.ts:223", + "pc": [ + 785, + 786, + 787 + ] + }, + { + "teal": 1115, + "source": "tests/contracts/cblocks.algo.ts:223", + "pc": [ + 788 + ] + }, + { + "teal": 1119, + "source": "tests/contracts/cblocks.algo.ts:224", + "pc": [ + 789, + 790, + 791 + ] + }, + { + "teal": 1120, + "source": "tests/contracts/cblocks.algo.ts:224", + "pc": [ + 792 + ] + }, + { + "teal": 1124, + "source": "tests/contracts/cblocks.algo.ts:225", + "pc": [ + 793, + 794, + 795 + ] + }, + { + "teal": 1125, + "source": "tests/contracts/cblocks.algo.ts:225", + "pc": [ + 796 + ] + }, + { + "teal": 1129, + "source": "tests/contracts/cblocks.algo.ts:226", + "pc": [ + 797, + 798, + 799 + ] + }, + { + "teal": 1130, + "source": "tests/contracts/cblocks.algo.ts:226", + "pc": [ + 800 + ] + }, + { + "teal": 1134, + "source": "tests/contracts/cblocks.algo.ts:227", + "pc": [ + 801, + 802, + 803 + ] + }, + { + "teal": 1135, + "source": "tests/contracts/cblocks.algo.ts:227", + "pc": [ + 804 + ] + }, + { + "teal": 1139, + "source": "tests/contracts/cblocks.algo.ts:228", + "pc": [ + 805, + 806, + 807 + ] + }, + { + "teal": 1140, + "source": "tests/contracts/cblocks.algo.ts:228", + "pc": [ + 808 + ] + }, + { + "teal": 1144, + "source": "tests/contracts/cblocks.algo.ts:229", + "pc": [ + 809, + 810, + 811 + ] + }, + { + "teal": 1145, + "source": "tests/contracts/cblocks.algo.ts:229", + "pc": [ + 812 + ] + }, + { + "teal": 1149, + "source": "tests/contracts/cblocks.algo.ts:230", + "pc": [ + 813, + 814, + 815 + ] + }, + { + "teal": 1150, + "source": "tests/contracts/cblocks.algo.ts:230", + "pc": [ + 816 + ] + }, + { + "teal": 1154, + "source": "tests/contracts/cblocks.algo.ts:231", + "pc": [ + 817, + 818, + 819 + ] + }, + { + "teal": 1155, + "source": "tests/contracts/cblocks.algo.ts:231", + "pc": [ + 820 + ] + }, + { + "teal": 1159, + "source": "tests/contracts/cblocks.algo.ts:232", + "pc": [ + 821, + 822, + 823 + ] + }, + { + "teal": 1160, + "source": "tests/contracts/cblocks.algo.ts:232", + "pc": [ + 824 + ] + }, + { + "teal": 1164, + "source": "tests/contracts/cblocks.algo.ts:233", + "pc": [ + 825, + 826, + 827 + ] + }, + { + "teal": 1165, + "source": "tests/contracts/cblocks.algo.ts:233", + "pc": [ + 828 + ] + }, + { + "teal": 1169, + "source": "tests/contracts/cblocks.algo.ts:234", + "pc": [ + 829, + 830, + 831 + ] + }, + { + "teal": 1170, + "source": "tests/contracts/cblocks.algo.ts:234", + "pc": [ + 832 + ] + }, + { + "teal": 1174, + "source": "tests/contracts/cblocks.algo.ts:235", + "pc": [ + 833, + 834, + 835 + ] + }, + { + "teal": 1175, + "source": "tests/contracts/cblocks.algo.ts:235", + "pc": [ + 836 + ] + }, + { + "teal": 1179, + "source": "tests/contracts/cblocks.algo.ts:236", + "pc": [ + 837, + 838, + 839 + ] + }, + { + "teal": 1180, + "source": "tests/contracts/cblocks.algo.ts:236", + "pc": [ + 840 + ] + }, + { + "teal": 1184, + "source": "tests/contracts/cblocks.algo.ts:237", + "pc": [ + 841, + 842, + 843 + ] + }, + { + "teal": 1185, + "source": "tests/contracts/cblocks.algo.ts:237", + "pc": [ + 844 + ] + }, + { + "teal": 1189, + "source": "tests/contracts/cblocks.algo.ts:238", + "pc": [ + 845, + 846, + 847 + ] + }, + { + "teal": 1190, + "source": "tests/contracts/cblocks.algo.ts:238", + "pc": [ + 848 + ] + }, + { + "teal": 1194, + "source": "tests/contracts/cblocks.algo.ts:239", + "pc": [ + 849, + 850, + 851 + ] + }, + { + "teal": 1195, + "source": "tests/contracts/cblocks.algo.ts:239", + "pc": [ + 852 + ] + }, + { + "teal": 1199, + "source": "tests/contracts/cblocks.algo.ts:240", + "pc": [ + 853, + 854, + 855 + ] + }, + { + "teal": 1200, + "source": "tests/contracts/cblocks.algo.ts:240", + "pc": [ + 856 + ] + }, + { + "teal": 1204, + "source": "tests/contracts/cblocks.algo.ts:241", + "pc": [ + 857, + 858, + 859 + ] + }, + { + "teal": 1205, + "source": "tests/contracts/cblocks.algo.ts:241", + "pc": [ + 860 + ] + }, + { + "teal": 1209, + "source": "tests/contracts/cblocks.algo.ts:242", + "pc": [ + 861, + 862, + 863 + ] + }, + { + "teal": 1210, + "source": "tests/contracts/cblocks.algo.ts:242", + "pc": [ + 864 + ] + }, + { + "teal": 1214, + "source": "tests/contracts/cblocks.algo.ts:243", + "pc": [ + 865, + 866, + 867 + ] + }, + { + "teal": 1215, + "source": "tests/contracts/cblocks.algo.ts:243", + "pc": [ + 868 + ] + }, + { + "teal": 1219, + "source": "tests/contracts/cblocks.algo.ts:244", + "pc": [ + 869, + 870, + 871 + ] + }, + { + "teal": 1220, + "source": "tests/contracts/cblocks.algo.ts:244", + "pc": [ + 872 + ] + }, + { + "teal": 1224, + "source": "tests/contracts/cblocks.algo.ts:245", + "pc": [ + 873, + 874, + 875 + ] + }, + { + "teal": 1225, + "source": "tests/contracts/cblocks.algo.ts:245", + "pc": [ + 876 + ] + }, + { + "teal": 1229, + "source": "tests/contracts/cblocks.algo.ts:246", + "pc": [ + 877, + 878, + 879 + ] + }, + { + "teal": 1230, + "source": "tests/contracts/cblocks.algo.ts:246", + "pc": [ + 880 + ] + }, + { + "teal": 1234, + "source": "tests/contracts/cblocks.algo.ts:247", + "pc": [ + 881, + 882, + 883 + ] + }, + { + "teal": 1235, + "source": "tests/contracts/cblocks.algo.ts:247", + "pc": [ + 884 + ] + }, + { + "teal": 1239, + "source": "tests/contracts/cblocks.algo.ts:248", + "pc": [ + 885, + 886, + 887 + ] + }, + { + "teal": 1240, + "source": "tests/contracts/cblocks.algo.ts:248", + "pc": [ + 888 + ] + }, + { + "teal": 1244, + "source": "tests/contracts/cblocks.algo.ts:249", + "pc": [ + 889, + 890, + 891 + ] + }, + { + "teal": 1245, + "source": "tests/contracts/cblocks.algo.ts:249", + "pc": [ + 892 + ] + }, + { + "teal": 1249, + "source": "tests/contracts/cblocks.algo.ts:250", + "pc": [ + 893, + 894, + 895 + ] + }, + { + "teal": 1250, + "source": "tests/contracts/cblocks.algo.ts:250", + "pc": [ + 896 + ] + }, + { + "teal": 1254, + "source": "tests/contracts/cblocks.algo.ts:251", + "pc": [ + 897, + 898, + 899 + ] + }, + { + "teal": 1255, + "source": "tests/contracts/cblocks.algo.ts:251", + "pc": [ + 900 + ] + }, + { + "teal": 1259, + "source": "tests/contracts/cblocks.algo.ts:252", + "pc": [ + 901, + 902, + 903 + ] + }, + { + "teal": 1260, + "source": "tests/contracts/cblocks.algo.ts:252", + "pc": [ + 904 + ] + }, + { + "teal": 1264, + "source": "tests/contracts/cblocks.algo.ts:253", + "pc": [ + 905, + 906, + 907 + ] + }, + { + "teal": 1265, + "source": "tests/contracts/cblocks.algo.ts:253", + "pc": [ + 908 + ] + }, + { + "teal": 1269, + "source": "tests/contracts/cblocks.algo.ts:254", + "pc": [ + 909, + 910, + 911 + ] + }, + { + "teal": 1270, + "source": "tests/contracts/cblocks.algo.ts:254", + "pc": [ + 912 + ] + }, + { + "teal": 1274, + "source": "tests/contracts/cblocks.algo.ts:255", + "pc": [ + 913, + 914, + 915 + ] + }, + { + "teal": 1275, + "source": "tests/contracts/cblocks.algo.ts:255", + "pc": [ + 916 + ] + }, + { + "teal": 1279, + "source": "tests/contracts/cblocks.algo.ts:256", + "pc": [ + 917, + 918, + 919 + ] + }, + { + "teal": 1280, + "source": "tests/contracts/cblocks.algo.ts:256", + "pc": [ + 920 + ] + }, + { + "teal": 1284, + "source": "tests/contracts/cblocks.algo.ts:257", + "pc": [ + 921, + 922, + 923 + ] + }, + { + "teal": 1285, + "source": "tests/contracts/cblocks.algo.ts:257", + "pc": [ + 924 + ] + }, + { + "teal": 1289, + "source": "tests/contracts/cblocks.algo.ts:258", + "pc": [ + 925, + 926, + 927 + ] + }, + { + "teal": 1290, + "source": "tests/contracts/cblocks.algo.ts:258", + "pc": [ + 928 + ] + }, + { + "teal": 1294, + "source": "tests/contracts/cblocks.algo.ts:259", + "pc": [ + 929, + 930, + 931 + ] + }, + { + "teal": 1295, + "source": "tests/contracts/cblocks.algo.ts:259", + "pc": [ + 932 + ] + }, + { + "teal": 1299, + "source": "tests/contracts/cblocks.algo.ts:260", + "pc": [ + 933, + 934, + 935 + ] + }, + { + "teal": 1300, + "source": "tests/contracts/cblocks.algo.ts:260", + "pc": [ + 936 + ] + }, + { + "teal": 1304, + "source": "tests/contracts/cblocks.algo.ts:261", + "pc": [ + 937, + 938, + 939 + ] + }, + { + "teal": 1305, + "source": "tests/contracts/cblocks.algo.ts:261", + "pc": [ + 940 + ] + }, + { + "teal": 1309, + "source": "tests/contracts/cblocks.algo.ts:262", + "pc": [ + 941, + 942, + 943 + ] + }, + { + "teal": 1310, + "source": "tests/contracts/cblocks.algo.ts:262", + "pc": [ + 944 + ] + }, + { + "teal": 1314, + "source": "tests/contracts/cblocks.algo.ts:263", + "pc": [ + 945, + 946, + 947 + ] + }, + { + "teal": 1315, + "source": "tests/contracts/cblocks.algo.ts:263", + "pc": [ + 948 + ] + }, + { + "teal": 1319, + "source": "tests/contracts/cblocks.algo.ts:266", + "pc": [ + 949, + 950, + 951 + ] + }, + { + "teal": 1320, + "source": "tests/contracts/cblocks.algo.ts:7", + "pc": [ + 952 + ] + }, + { + "teal": 1323, + "source": "tests/contracts/cblocks.algo.ts:4", + "pc": [ + 953, + 954 + ] + }, + { + "teal": 1324, + "source": "tests/contracts/cblocks.algo.ts:4", + "pc": [ + 955 + ] + }, + { + "teal": 1327, + "source": "tests/contracts/cblocks.algo.ts:4", + "pc": [ + 956, + 957, + 958, + 959, + 960, + 961 + ] + }, + { + "teal": 1328, + "source": "tests/contracts/cblocks.algo.ts:4", + "pc": [ + 962, + 963, + 964 + ] }, { + "teal": 1329, + "source": "tests/contracts/cblocks.algo.ts:4", + "pc": [ + 965, + 966, + 967, + 968 + ] + }, + { + "teal": 1332, + "source": "tests/contracts/cblocks.algo.ts:4", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 969 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 1335, + "source": "tests/contracts/cblocks.algo.ts:4", + "pc": [ + 970, + 971, + 972, + 973, + 974, + 975 + ] + }, + { + "teal": 1336, + "source": "tests/contracts/cblocks.algo.ts:4", + "pc": [ + 976, + 977, + 978 + ] + }, + { + "teal": 1337, + "source": "tests/contracts/cblocks.algo.ts:4", + "pc": [ + 979, + 980, + 981, + 982 + ] }, { + "teal": 1340, + "source": "tests/contracts/cblocks.algo.ts:4", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 983 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ItxnsTest.arc56_draft.json b/tests/contracts/artifacts/ItxnsTest.arc56_draft.json index bc1f74ead..523349628 100644 --- a/tests/contracts/artifacts/ItxnsTest.arc56_draft.json +++ b/tests/contracts/artifacts/ItxnsTest.arc56_draft.json @@ -181,22 +181,2441 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/itxns.algo.ts:4", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/itxns.algo.ts:4", + "pc": [ + 1, + 2, + 3, + 4 + ] + }, + { + "teal": 3, + "source": "tests/contracts/itxns.algo.ts:4", + "pc": [ + 5, + 6, + 7, + 8, + 9, + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38, + 39, + 40, + 41, + 42, + 43, + 44 + ] + }, + { + "teal": 15, + "source": "tests/contracts/itxns.algo.ts:4", + "pc": [ + 45, + 46 + ] + }, + { + "teal": 16, + "source": "tests/contracts/itxns.algo.ts:4", + "pc": [ + 47 + ] + }, + { + "teal": 17, + "source": "tests/contracts/itxns.algo.ts:4", + "pc": [ + 48, + 49 + ] + }, + { + "teal": 18, + "source": "tests/contracts/itxns.algo.ts:4", + "pc": [ + 50 + ] + }, + { + "teal": 19, + "source": "tests/contracts/itxns.algo.ts:4", + "pc": [ + 51, + 52 + ] + }, + { + "teal": 20, + "source": "tests/contracts/itxns.algo.ts:4", + "pc": [ + 53 + ] + }, + { + "teal": 21, + "source": "tests/contracts/itxns.algo.ts:4", + "pc": [ + 54, + 55, + 56, + 57, + 58, + 59, + 60, + 61, + 62, + 63, + 64, + 65, + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79 + ] + }, + { + "teal": 25, + "source": "tests/contracts/itxns.algo.ts:4", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 80 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 30, + "source": "tests/contracts/itxns.algo.ts:5", + "pc": [ + 81, + 82, + 83 + ] + }, + { + "teal": 31, + "source": "tests/contracts/itxns.algo.ts:5", + "pc": [ + 84, + 85 + ] + }, + { + "teal": 32, + "source": "tests/contracts/itxns.algo.ts:5", + "pc": [ + 86 + ] + }, + { + "teal": 36, + "source": "tests/contracts/itxns.algo.ts:5", + "pc": [ + 87, + 88, + 89 + ] + }, + { + "teal": 47, + "source": "tests/contracts/itxns.algo.ts:6", + "pc": [ + 90 + ] + }, + { + "teal": 48, + "source": "tests/contracts/itxns.algo.ts:6", + "pc": [ + 91, + 92 + ] + }, + { + "teal": 49, + "source": "tests/contracts/itxns.algo.ts:6", + "pc": [ + 93, + 94 + ] + }, + { + "teal": 53, + "source": "tests/contracts/itxns.algo.ts:7", + "pc": [ + 95, + 96 + ] + }, + { + "teal": 54, + "source": "tests/contracts/itxns.algo.ts:7", + "pc": [ + 97, + 98 + ] + }, + { + "teal": 58, + "source": "tests/contracts/itxns.algo.ts:8", + "pc": [ + 99, + 100 + ] + }, + { + "teal": 59, + "source": "tests/contracts/itxns.algo.ts:8", + "pc": [ + 101, + 102 + ] + }, + { + "teal": 63, + "source": "tests/contracts/itxns.algo.ts:9", + "pc": [ + 103, + 104 + ] + }, + { + "teal": 64, + "source": "tests/contracts/itxns.algo.ts:9", + "pc": [ + 105, + 106 + ] + }, + { + "teal": 68, + "source": "tests/contracts/itxns.algo.ts:10", + "pc": [ + 107, + 108 + ] + }, + { + "teal": 69, + "source": "tests/contracts/itxns.algo.ts:10", + "pc": [ + 109, + 110 + ] + }, + { + "teal": 73, + "source": "tests/contracts/itxns.algo.ts:11", + "pc": [ + 111, + 112 + ] + }, + { + "teal": 74, + "source": "tests/contracts/itxns.algo.ts:11", + "pc": [ + 113, + 114 + ] + }, + { + "teal": 78, + "source": "tests/contracts/itxns.algo.ts:12", + "pc": [ + 115, + 116, + 117, + 118, + 119, + 120, + 121, + 122, + 123, + 124, + 125, + 126, + 127, + 128 + ] + }, + { + "teal": 79, + "source": "tests/contracts/itxns.algo.ts:12", + "pc": [ + 129, + 130 + ] + }, + { + "teal": 82, + "source": "tests/contracts/itxns.algo.ts:6", + "pc": [ + 131, + 132 + ] + }, + { + "teal": 83, + "source": "tests/contracts/itxns.algo.ts:6", + "pc": [ + 133, + 134 + ] + }, + { + "teal": 86, + "source": "tests/contracts/itxns.algo.ts:6", + "pc": [ + 135 + ] + }, + { + "teal": 87, + "source": "tests/contracts/itxns.algo.ts:5", + "pc": [ + 136 + ] + }, + { + "teal": 92, + "source": "tests/contracts/itxns.algo.ts:16", + "pc": [ + 137, + 138, + 139, + 140, + 141, + 142 + ] + }, + { + "teal": 95, + "source": "tests/contracts/itxns.algo.ts:16", + "pc": [ + 143, + 144, + 145 + ] + }, + { + "teal": 96, + "source": "tests/contracts/itxns.algo.ts:16", + "pc": [ + 146 + ] + }, + { + "teal": 97, + "source": "tests/contracts/itxns.algo.ts:16", + "pc": [ + 147 + ] + }, + { + "teal": 98, + "source": "tests/contracts/itxns.algo.ts:16", + "pc": [ + 148 + ] + }, + { + "teal": 99, + "source": "tests/contracts/itxns.algo.ts:16", + "pc": [ + 149, + 150 + ] + }, + { + "teal": 100, + "source": "tests/contracts/itxns.algo.ts:16", + "pc": [ + 151 + ] + }, + { + "teal": 104, + "source": "tests/contracts/itxns.algo.ts:16", + "pc": [ + 152, + 153, + 154 + ] + }, + { + "teal": 119, + "source": "tests/contracts/itxns.algo.ts:17", + "pc": [ + 155 + ] + }, + { + "teal": 120, + "source": "tests/contracts/itxns.algo.ts:17", + "pc": [ + 156, + 157 + ] + }, + { + "teal": 121, + "source": "tests/contracts/itxns.algo.ts:17", + "pc": [ + 158, + 159 + ] + }, + { + "teal": 125, + "source": "tests/contracts/itxns.algo.ts:18", + "pc": [ + 160, + 161, + 162, + 163, + 164, + 165 + ] + }, + { + "teal": 126, + "source": "tests/contracts/itxns.algo.ts:18", + "pc": [ + 166, + 167 + ] + }, + { + "teal": 130, + "source": "tests/contracts/itxns.algo.ts:19", + "pc": [ + 168, + 169, + 170, + 171, + 172, + 173 + ] + }, + { + "teal": 131, + "source": "tests/contracts/itxns.algo.ts:19", + "pc": [ + 174, + 175 + ] + }, + { + "teal": 135, + "source": "tests/contracts/itxns.algo.ts:20", + "pc": [ + 176, + 177 + ] + }, + { + "teal": 136, + "source": "tests/contracts/itxns.algo.ts:20", + "pc": [ + 178, + 179 + ] + }, + { + "teal": 140, + "source": "tests/contracts/itxns.algo.ts:21", + "pc": [ + 180, + 181 + ] + }, + { + "teal": 141, + "source": "tests/contracts/itxns.algo.ts:21", + "pc": [ + 182, + 183 + ] + }, + { + "teal": 145, + "source": "tests/contracts/itxns.algo.ts:22", + "pc": [ + 184, + 185 + ] + }, + { + "teal": 146, + "source": "tests/contracts/itxns.algo.ts:22", + "pc": [ + 186, + 187 + ] + }, + { + "teal": 150, + "source": "tests/contracts/itxns.algo.ts:23", + "pc": [ + 188, + 189 + ] + }, + { + "teal": 151, + "source": "tests/contracts/itxns.algo.ts:23", + "pc": [ + 190, + 191 + ] + }, + { + "teal": 155, + "source": "tests/contracts/itxns.algo.ts:24", + "pc": [ + 192, + 193 + ] + }, + { + "teal": 156, + "source": "tests/contracts/itxns.algo.ts:24", + "pc": [ + 194, + 195 + ] + }, + { + "teal": 160, + "source": "tests/contracts/itxns.algo.ts:25", + "pc": [ + 196, + 197 + ] + }, + { + "teal": 161, + "source": "tests/contracts/itxns.algo.ts:25", + "pc": [ + 198, + 199 + ] + }, + { + "teal": 165, + "source": "tests/contracts/itxns.algo.ts:26", + "pc": [ + 200, + 201, + 202, + 203, + 204 + ] + }, + { + "teal": 166, + "source": "tests/contracts/itxns.algo.ts:26", + "pc": [ + 205, + 206 + ] + }, + { + "teal": 170, + "source": "tests/contracts/itxns.algo.ts:27", + "pc": [ + 207, + 208, + 209, + 210, + 211, + 212, + 213, + 214, + 215, + 216, + 217, + 218, + 219, + 220, + 221, + 222, + 223, + 224, + 225, + 226, + 227, + 228, + 229, + 230, + 231, + 232, + 233, + 234, + 235, + 236, + 237, + 238, + 239, + 240 + ] + }, + { + "teal": 171, + "source": "tests/contracts/itxns.algo.ts:27", + "pc": [ + 241, + 242 + ] + }, + { + "teal": 174, + "source": "tests/contracts/itxns.algo.ts:17", + "pc": [ + 243, + 244 + ] + }, + { + "teal": 175, + "source": "tests/contracts/itxns.algo.ts:17", + "pc": [ + 245, + 246 + ] + }, + { + "teal": 178, + "source": "tests/contracts/itxns.algo.ts:17", + "pc": [ + 247 + ] + }, + { + "teal": 179, + "source": "tests/contracts/itxns.algo.ts:17", + "pc": [ + 248, + 249 + ] + }, + { + "teal": 180, + "source": "tests/contracts/itxns.algo.ts:16", + "pc": [ + 250 + ] + }, + { + "teal": 185, + "source": "tests/contracts/itxns.algo.ts:31", + "pc": [ + 251, + 252, + 253 + ] + }, + { + "teal": 186, + "source": "tests/contracts/itxns.algo.ts:31", + "pc": [ + 254, + 255 + ] + }, + { + "teal": 187, + "source": "tests/contracts/itxns.algo.ts:31", + "pc": [ + 256 + ] + }, + { + "teal": 191, + "source": "tests/contracts/itxns.algo.ts:31", + "pc": [ + 257, + 258, + 259 + ] + }, + { + "teal": 208, + "source": "tests/contracts/itxns.algo.ts:32", + "pc": [ + 260 + ] + }, + { + "teal": 209, + "source": "tests/contracts/itxns.algo.ts:32", + "pc": [ + 261, + 262 + ] + }, + { + "teal": 210, + "source": "tests/contracts/itxns.algo.ts:32", + "pc": [ + 263, + 264 + ] + }, + { + "teal": 214, + "source": "tests/contracts/itxns.algo.ts:33", + "pc": [ + 265, + 266 + ] + }, + { + "teal": 215, + "source": "tests/contracts/itxns.algo.ts:33", + "pc": [ + 267, + 268 + ] + }, + { + "teal": 219, + "source": "tests/contracts/itxns.algo.ts:34", + "pc": [ + 269, + 270, + 271, + 272, + 273, + 274 + ] + }, + { + "teal": 220, + "source": "tests/contracts/itxns.algo.ts:34", + "pc": [ + 275, + 276 + ] + }, + { + "teal": 221, + "source": "tests/contracts/itxns.algo.ts:34", + "pc": [ + 277, + 278, + 279, + 280, + 281, + 282 + ] + }, + { + "teal": 222, + "source": "tests/contracts/itxns.algo.ts:34", + "pc": [ + 283, + 284 + ] + }, + { + "teal": 226, + "source": "tests/contracts/itxns.algo.ts:35", + "pc": [ + 285, + 286, + 287 + ] + }, + { + "teal": 227, + "source": "tests/contracts/itxns.algo.ts:35", + "pc": [ + 288, + 289 + ] + }, + { + "teal": 231, + "source": "tests/contracts/itxns.algo.ts:36", + "pc": [ + 290, + 291, + 292 + ] + }, + { + "teal": 232, + "source": "tests/contracts/itxns.algo.ts:36", + "pc": [ + 293, + 294 + ] + }, + { + "teal": 236, + "source": "tests/contracts/itxns.algo.ts:37", + "pc": [ + 295, + 296, + 297, + 298, + 299, + 300, + 301, + 302, + 303, + 304 + ] + }, + { + "teal": 237, + "source": "tests/contracts/itxns.algo.ts:37", + "pc": [ + 305, + 306 + ] + }, + { + "teal": 241, + "source": "tests/contracts/itxns.algo.ts:38", + "pc": [ + 307, + 308 + ] + }, + { + "teal": 242, + "source": "tests/contracts/itxns.algo.ts:38", + "pc": [ + 309, + 310 + ] + }, + { + "teal": 246, + "source": "tests/contracts/itxns.algo.ts:39", + "pc": [ + 311, + 312, + 313, + 314, + 315, + 316, + 317 + ] + }, + { + "teal": 247, + "source": "tests/contracts/itxns.algo.ts:39", + "pc": [ + 318, + 319 + ] + }, + { + "teal": 251, + "source": "tests/contracts/itxns.algo.ts:40", + "pc": [ + 320, + 321 + ] + }, + { + "teal": 252, + "source": "tests/contracts/itxns.algo.ts:40", + "pc": [ + 322, + 323 + ] + }, + { + "teal": 256, + "source": "tests/contracts/itxns.algo.ts:41", + "pc": [ + 324, + 325 + ] + }, + { + "teal": 257, + "source": "tests/contracts/itxns.algo.ts:41", + "pc": [ + 326, + 327 + ] + }, + { + "teal": 261, + "source": "tests/contracts/itxns.algo.ts:42", + "pc": [ + 328, + 329 + ] + }, + { + "teal": 262, + "source": "tests/contracts/itxns.algo.ts:42", + "pc": [ + 330, + 331 + ] + }, + { + "teal": 266, + "source": "tests/contracts/itxns.algo.ts:43", + "pc": [ + 332, + 333 + ] + }, + { + "teal": 267, + "source": "tests/contracts/itxns.algo.ts:43", + "pc": [ + 334, + 335 + ] + }, + { + "teal": 271, + "source": "tests/contracts/itxns.algo.ts:44", + "pc": [ + 336, + 337, + 338, + 339, + 340, + 341 + ] + }, + { + "teal": 272, + "source": "tests/contracts/itxns.algo.ts:44", + "pc": [ + 342, + 343 + ] + }, + { + "teal": 275, + "source": "tests/contracts/itxns.algo.ts:32", + "pc": [ + 344, + 345 + ] + }, + { + "teal": 276, + "source": "tests/contracts/itxns.algo.ts:32", + "pc": [ + 346, + 347 + ] + }, + { + "teal": 279, + "source": "tests/contracts/itxns.algo.ts:32", + "pc": [ + 348 + ] + }, + { + "teal": 280, + "source": "tests/contracts/itxns.algo.ts:31", + "pc": [ + 349 + ] + }, + { + "teal": 285, + "source": "tests/contracts/itxns.algo.ts:48", + "pc": [ + 350, + 351, + 352 + ] + }, + { + "teal": 286, + "source": "tests/contracts/itxns.algo.ts:48", + "pc": [ + 353, + 354 + ] + }, + { + "teal": 287, + "source": "tests/contracts/itxns.algo.ts:48", + "pc": [ + 355 + ] + }, + { + "teal": 291, + "source": "tests/contracts/itxns.algo.ts:48", + "pc": [ + 356, + 357, + 358 + ] + }, + { + "teal": 301, + "source": "tests/contracts/itxns.algo.ts:49", + "pc": [ + 359 + ] + }, + { + "teal": 302, + "source": "tests/contracts/itxns.algo.ts:49", + "pc": [ + 360, + 361 + ] + }, + { + "teal": 303, + "source": "tests/contracts/itxns.algo.ts:49", + "pc": [ + 362, + 363 + ] + }, + { + "teal": 307, + "source": "tests/contracts/itxns.algo.ts:50", + "pc": [ + 364, + 365 + ] + }, + { + "teal": 308, + "source": "tests/contracts/itxns.algo.ts:50", + "pc": [ + 366, + 367 + ] + }, + { + "teal": 312, + "source": "tests/contracts/itxns.algo.ts:51", + "pc": [ + 368, + 369 + ] + }, + { + "teal": 313, + "source": "tests/contracts/itxns.algo.ts:51", + "pc": [ + 370, + 371 + ] + }, + { + "teal": 317, + "source": "tests/contracts/itxns.algo.ts:52", + "pc": [ + 372, + 373 + ] + }, + { + "teal": 318, + "source": "tests/contracts/itxns.algo.ts:52", + "pc": [ + 374, + 375 + ] + }, + { + "teal": 322, + "source": "tests/contracts/itxns.algo.ts:53", + "pc": [ + 376, + 377 + ] + }, + { + "teal": 323, + "source": "tests/contracts/itxns.algo.ts:53", + "pc": [ + 378, + 379 + ] + }, + { + "teal": 327, + "source": "tests/contracts/itxns.algo.ts:54", + "pc": [ + 380, + 381 + ] + }, + { + "teal": 328, + "source": "tests/contracts/itxns.algo.ts:54", + "pc": [ + 382, + 383 + ] + }, + { + "teal": 331, + "source": "tests/contracts/itxns.algo.ts:49", + "pc": [ + 384, + 385 + ] + }, + { + "teal": 332, + "source": "tests/contracts/itxns.algo.ts:49", + "pc": [ + 386, + 387 + ] + }, + { + "teal": 335, + "source": "tests/contracts/itxns.algo.ts:49", + "pc": [ + 388 + ] + }, + { + "teal": 336, + "source": "tests/contracts/itxns.algo.ts:48", + "pc": [ + 389 + ] + }, + { + "teal": 341, + "source": "tests/contracts/itxns.algo.ts:58", + "pc": [ + 390, + 391, + 392 + ] + }, + { + "teal": 342, + "source": "tests/contracts/itxns.algo.ts:58", + "pc": [ + 393, + 394 + ] + }, + { + "teal": 343, + "source": "tests/contracts/itxns.algo.ts:58", + "pc": [ + 395 + ] + }, + { + "teal": 347, + "source": "tests/contracts/itxns.algo.ts:58", + "pc": [ + 396, + 397, + 398 + ] + }, + { + "teal": 355, + "source": "tests/contracts/itxns.algo.ts:59", + "pc": [ + 399 + ] + }, + { + "teal": 356, + "source": "tests/contracts/itxns.algo.ts:59", + "pc": [ + 400, + 401 + ] + }, + { + "teal": 357, + "source": "tests/contracts/itxns.algo.ts:59", + "pc": [ + 402, + 403 + ] + }, + { + "teal": 361, + "source": "tests/contracts/itxns.algo.ts:60", + "pc": [ + 404, + 405 + ] + }, + { + "teal": 362, + "source": "tests/contracts/itxns.algo.ts:60", + "pc": [ + 406, + 407 + ] + }, + { + "teal": 366, + "source": "tests/contracts/itxns.algo.ts:61", + "pc": [ + 408, + 409 + ] + }, + { + "teal": 367, + "source": "tests/contracts/itxns.algo.ts:61", + "pc": [ + 410, + 411 + ] + }, + { + "teal": 371, + "source": "tests/contracts/itxns.algo.ts:62", + "pc": [ + 412, + 413 + ] + }, + { + "teal": 372, + "source": "tests/contracts/itxns.algo.ts:62", + "pc": [ + 414, + 415 + ] + }, + { + "teal": 375, + "source": "tests/contracts/itxns.algo.ts:59", + "pc": [ + 416, + 417 + ] + }, + { + "teal": 376, + "source": "tests/contracts/itxns.algo.ts:59", + "pc": [ + 418, + 419 + ] + }, + { + "teal": 379, + "source": "tests/contracts/itxns.algo.ts:59", + "pc": [ + 420 + ] + }, + { + "teal": 380, + "source": "tests/contracts/itxns.algo.ts:58", + "pc": [ + 421 + ] + }, + { + "teal": 385, + "source": "tests/contracts/itxns.algo.ts:66", + "pc": [ + 422, + 423, + 424 + ] + }, + { + "teal": 386, + "source": "tests/contracts/itxns.algo.ts:66", + "pc": [ + 425, + 426 + ] + }, + { + "teal": 387, + "source": "tests/contracts/itxns.algo.ts:66", + "pc": [ + 427 + ] + }, + { + "teal": 391, + "source": "tests/contracts/itxns.algo.ts:66", + "pc": [ + 428, + 429, + 430 + ] + }, + { + "teal": 401, + "source": "tests/contracts/itxns.algo.ts:67", + "pc": [ + 431 + ] + }, + { + "teal": 402, + "source": "tests/contracts/itxns.algo.ts:67", + "pc": [ + 432, + 433 + ] + }, + { + "teal": 403, + "source": "tests/contracts/itxns.algo.ts:67", + "pc": [ + 434, + 435 + ] + }, + { + "teal": 407, + "source": "tests/contracts/itxns.algo.ts:68", + "pc": [ + 436, + 437 + ] + }, + { + "teal": 408, + "source": "tests/contracts/itxns.algo.ts:68", + "pc": [ + 438, + 439 + ] + }, + { + "teal": 412, + "source": "tests/contracts/itxns.algo.ts:69", + "pc": [ + 440, + 441 + ] + }, + { + "teal": 413, + "source": "tests/contracts/itxns.algo.ts:69", + "pc": [ + 442, + 443 + ] + }, + { + "teal": 417, + "source": "tests/contracts/itxns.algo.ts:70", + "pc": [ + 444, + 445 + ] + }, + { + "teal": 418, + "source": "tests/contracts/itxns.algo.ts:70", + "pc": [ + 446, + 447 + ] + }, + { + "teal": 422, + "source": "tests/contracts/itxns.algo.ts:71", + "pc": [ + 448, + 449 + ] + }, + { + "teal": 423, + "source": "tests/contracts/itxns.algo.ts:71", + "pc": [ + 450, + 451 + ] + }, + { + "teal": 427, + "source": "tests/contracts/itxns.algo.ts:72", + "pc": [ + 452, + 453 + ] + }, + { + "teal": 428, + "source": "tests/contracts/itxns.algo.ts:72", + "pc": [ + 454, + 455 + ] + }, + { + "teal": 431, + "source": "tests/contracts/itxns.algo.ts:67", + "pc": [ + 456, + 457 + ] + }, + { + "teal": 432, + "source": "tests/contracts/itxns.algo.ts:67", + "pc": [ + 458, + 459 + ] + }, + { + "teal": 435, + "source": "tests/contracts/itxns.algo.ts:67", + "pc": [ + 460 + ] + }, + { + "teal": 436, + "source": "tests/contracts/itxns.algo.ts:66", + "pc": [ + 461 + ] + }, + { + "teal": 441, + "source": "tests/contracts/itxns.algo.ts:76", + "pc": [ + 462, + 463, + 464, + 465, + 466, + 467 + ] + }, + { + "teal": 444, + "source": "tests/contracts/itxns.algo.ts:76", + "pc": [ + 468, + 469, + 470 + ] + }, + { + "teal": 445, + "source": "tests/contracts/itxns.algo.ts:76", + "pc": [ + 471 + ] + }, + { + "teal": 446, + "source": "tests/contracts/itxns.algo.ts:76", + "pc": [ + 472 + ] + }, + { + "teal": 447, + "source": "tests/contracts/itxns.algo.ts:76", + "pc": [ + 473 + ] + }, + { + "teal": 448, + "source": "tests/contracts/itxns.algo.ts:76", + "pc": [ + 474, + 475 + ] + }, + { + "teal": 449, + "source": "tests/contracts/itxns.algo.ts:76", + "pc": [ + 476 + ] + }, + { + "teal": 453, + "source": "tests/contracts/itxns.algo.ts:76", + "pc": [ + 477, + 478, + 479 + ] + }, + { + "teal": 460, + "source": "tests/contracts/itxns.algo.ts:77", + "pc": [ + 480 + ] + }, + { + "teal": 461, + "source": "tests/contracts/itxns.algo.ts:77", + "pc": [ + 481, + 482 + ] + }, + { + "teal": 462, + "source": "tests/contracts/itxns.algo.ts:77", + "pc": [ + 483, + 484 + ] + }, + { + "teal": 463, + "source": "tests/contracts/itxns.algo.ts:78", + "pc": [ + 485, + 486, + 487, + 488, + 489, + 490 + ] + }, + { + "teal": 464, + "source": "tests/contracts/itxns.algo.ts:78", + "pc": [ + 491, + 492 + ] + }, + { + "teal": 468, + "source": "tests/contracts/itxns.algo.ts:79", + "pc": [ + 493, + 494, + 495 + ] + }, + { + "teal": 469, + "source": "tests/contracts/itxns.algo.ts:79", + "pc": [ + 496 + ] + }, + { + "teal": 470, + "source": "tests/contracts/itxns.algo.ts:79", + "pc": [ + 497, + 498 + ] + }, + { + "teal": 471, + "source": "tests/contracts/itxns.algo.ts:79", + "pc": [ + 499, + 500, + 501, + 502, + 503, + 504, + 505, + 506, + 507, + 508 + ] + }, + { + "teal": 472, + "source": "tests/contracts/itxns.algo.ts:79", + "pc": [ + 509, + 510 + ] + }, + { + "teal": 475, + "source": "tests/contracts/itxns.algo.ts:77", + "pc": [ + 511, + 512 + ] + }, + { + "teal": 476, + "source": "tests/contracts/itxns.algo.ts:77", + "pc": [ + 513, + 514 + ] + }, + { + "teal": 479, + "source": "tests/contracts/itxns.algo.ts:77", + "pc": [ + 515 + ] + }, + { + "teal": 480, + "source": "tests/contracts/itxns.algo.ts:77", + "pc": [ + 516, + 517 + ] + }, + { + "teal": 481, + "source": "tests/contracts/itxns.algo.ts:77", + "pc": [ + 518, + 519 + ] + }, + { + "teal": 482, + "source": "tests/contracts/itxns.algo.ts:77", + "pc": [ + 520 + ] + }, + { + "teal": 483, + "source": "tests/contracts/itxns.algo.ts:77", + "pc": [ + 521, + 522 + ] + }, + { + "teal": 484, + "source": "tests/contracts/itxns.algo.ts:77", + "pc": [ + 523, + 524, + 525 + ] + }, + { + "teal": 485, + "source": "tests/contracts/itxns.algo.ts:77", + "pc": [ + 526 + ] + }, + { + "teal": 486, + "source": "tests/contracts/itxns.algo.ts:76", + "pc": [ + 527 + ] + }, + { + "teal": 491, + "source": "tests/contracts/itxns.algo.ts:83", + "pc": [ + 528, + 529, + 530 + ] + }, + { + "teal": 492, + "source": "tests/contracts/itxns.algo.ts:83", + "pc": [ + 531, + 532 + ] + }, + { + "teal": 493, + "source": "tests/contracts/itxns.algo.ts:83", + "pc": [ + 533 + ] + }, + { + "teal": 497, + "source": "tests/contracts/itxns.algo.ts:83", + "pc": [ + 534, + 535, + 536 + ] + }, + { + "teal": 508, + "source": "tests/contracts/itxns.algo.ts:84", + "pc": [ + 537 + ] + }, + { + "teal": 509, + "source": "tests/contracts/itxns.algo.ts:84", + "pc": [ + 538, + 539 + ] + }, + { + "teal": 510, + "source": "tests/contracts/itxns.algo.ts:84", + "pc": [ + 540, + 541 + ] + }, + { + "teal": 514, + "source": "tests/contracts/itxns.algo.ts:85", + "pc": [ + 542, + 543, + 544, + 545, + 546, + 547, + 548, + 549, + 550, + 551, + 552, + 553, + 554, + 555, + 556, + 557, + 558, + 559, + 560, + 561, + 562, + 563, + 564, + 565, + 566, + 567, + 568, + 569, + 570, + 571, + 572, + 573, + 574, + 575 + ] + }, + { + "teal": 515, + "source": "tests/contracts/itxns.algo.ts:85", + "pc": [ + 576, + 577 + ] + }, + { + "teal": 519, + "source": "tests/contracts/itxns.algo.ts:86", + "pc": [ + 578, + 579, + 580, + 581, + 582, + 583, + 584, + 585, + 586, + 587, + 588, + 589, + 590, + 591, + 592, + 593, + 594, + 595, + 596, + 597, + 598, + 599, + 600, + 601, + 602, + 603, + 604, + 605, + 606, + 607, + 608, + 609, + 610, + 611 + ] + }, + { + "teal": 520, + "source": "tests/contracts/itxns.algo.ts:86", + "pc": [ + 612, + 613 + ] + }, + { + "teal": 524, + "source": "tests/contracts/itxns.algo.ts:87", + "pc": [ + 614, + 615 + ] + }, + { + "teal": 525, + "source": "tests/contracts/itxns.algo.ts:87", + "pc": [ + 616, + 617 + ] + }, + { + "teal": 529, + "source": "tests/contracts/itxns.algo.ts:88", + "pc": [ + 618, + 619 + ] + }, + { + "teal": 530, + "source": "tests/contracts/itxns.algo.ts:88", + "pc": [ + 620, + 621 + ] + }, + { + "teal": 534, + "source": "tests/contracts/itxns.algo.ts:89", + "pc": [ + 622, + 623 + ] + }, + { + "teal": 535, + "source": "tests/contracts/itxns.algo.ts:89", + "pc": [ + 624, + 625 + ] + }, + { + "teal": 539, + "source": "tests/contracts/itxns.algo.ts:90", + "pc": [ + 626, + 627, + 628, + 629, + 630, + 631, + 632, + 633, + 634, + 635, + 636, + 637, + 638, + 639, + 640, + 641, + 642, + 643, + 644, + 645, + 646, + 647, + 648, + 649, + 650, + 651, + 652, + 653, + 654, + 655, + 656, + 657, + 658, + 659 + ] + }, + { + "teal": 540, + "source": "tests/contracts/itxns.algo.ts:90", + "pc": [ + 660, + 661 + ] + }, + { + "teal": 543, + "source": "tests/contracts/itxns.algo.ts:84", + "pc": [ + 662, + 663 + ] + }, + { + "teal": 544, + "source": "tests/contracts/itxns.algo.ts:84", + "pc": [ + 664, + 665 + ] + }, + { + "teal": 547, + "source": "tests/contracts/itxns.algo.ts:84", + "pc": [ + 666 + ] + }, + { + "teal": 548, + "source": "tests/contracts/itxns.algo.ts:83", + "pc": [ + 667 + ] + }, + { + "teal": 553, + "source": "tests/contracts/itxns.algo.ts:94", + "pc": [ + 668, + 669, + 670 + ] + }, + { + "teal": 554, + "source": "tests/contracts/itxns.algo.ts:94", + "pc": [ + 671, + 672 + ] + }, + { + "teal": 555, + "source": "tests/contracts/itxns.algo.ts:94", + "pc": [ + 673 + ] + }, + { + "teal": 559, + "source": "tests/contracts/itxns.algo.ts:94", + "pc": [ + 674, + 675, + 676 + ] + }, + { + "teal": 563, + "source": "tests/contracts/itxns.algo.ts:95", + "pc": [ + 677 + ] + }, + { + "teal": 564, + "source": "tests/contracts/itxns.algo.ts:95", + "pc": [ + 678, + 679 + ] + }, + { + "teal": 565, + "source": "tests/contracts/itxns.algo.ts:95", + "pc": [ + 680, + 681 + ] + }, + { + "teal": 568, + "source": "tests/contracts/itxns.algo.ts:95", + "pc": [ + 682, + 683 + ] + }, + { + "teal": 569, + "source": "tests/contracts/itxns.algo.ts:95", + "pc": [ + 684, + 685 + ] + }, + { + "teal": 572, + "source": "tests/contracts/itxns.algo.ts:95", + "pc": [ + 686 + ] + }, + { + "teal": 573, + "source": "tests/contracts/itxns.algo.ts:94", + "pc": [ + 687 + ] + }, + { + "teal": 578, + "source": "tests/contracts/itxns.algo.ts:98", + "pc": [ + 688, + 689, + 690 + ] + }, + { + "teal": 579, + "source": "tests/contracts/itxns.algo.ts:98", + "pc": [ + 691, + 692 + ] + }, + { + "teal": 580, + "source": "tests/contracts/itxns.algo.ts:98", + "pc": [ + 693 + ] + }, + { + "teal": 584, + "source": "tests/contracts/itxns.algo.ts:98", + "pc": [ + 694, + 695, + 696 + ] + }, + { + "teal": 591, + "source": "tests/contracts/itxns.algo.ts:101", + "pc": [ + 697 + ] + }, + { + "teal": 592, + "source": "tests/contracts/itxns.algo.ts:101", + "pc": [ + 698, + 699 + ] + }, + { + "teal": 593, + "source": "tests/contracts/itxns.algo.ts:101", + "pc": [ + 700, + 701 + ] + }, + { + "teal": 597, + "source": "tests/contracts/itxns.algo.ts:101", + "pc": [ + 702, + 703 + ] + }, + { + "teal": 598, + "source": "tests/contracts/itxns.algo.ts:101", + "pc": [ + 704, + 705 + ] + }, + { + "teal": 601, + "source": "tests/contracts/itxns.algo.ts:101", + "pc": [ + 706, + 707 + ] + }, + { + "teal": 602, + "source": "tests/contracts/itxns.algo.ts:101", + "pc": [ + 708, + 709 + ] + }, + { + "teal": 603, + "source": "tests/contracts/itxns.algo.ts:99", + "pc": [ + 710 + ] + }, + { + "teal": 604, + "source": "tests/contracts/itxns.algo.ts:99", + "pc": [ + 711, + 712 + ] + }, + { + "teal": 605, + "source": "tests/contracts/itxns.algo.ts:99", + "pc": [ + 713, + 714 + ] + }, + { + "teal": 606, + "source": "tests/contracts/itxns.algo.ts:100", + "pc": [ + 715, + 716, + 717, + 718, + 719, + 720 + ] + }, + { + "teal": 607, + "source": "tests/contracts/itxns.algo.ts:100", + "pc": [ + 721, + 722 + ] + }, + { + "teal": 612, + "source": "tests/contracts/itxns.algo.ts:99", + "pc": [ + 723, + 724 + ] + }, + { + "teal": 613, + "source": "tests/contracts/itxns.algo.ts:99", + "pc": [ + 725, + 726 + ] + }, + { + "teal": 616, + "source": "tests/contracts/itxns.algo.ts:99", + "pc": [ + 727 + ] + }, + { + "teal": 617, + "source": "tests/contracts/itxns.algo.ts:98", + "pc": [ + 728 + ] + }, + { + "teal": 620, + "source": "tests/contracts/itxns.algo.ts:4", + "pc": [ + 729, + 730 + ] }, { + "teal": 621, + "source": "tests/contracts/itxns.algo.ts:4", + "pc": [ + 731 + ] + }, + { + "teal": 624, + "source": "tests/contracts/itxns.algo.ts:4", + "pc": [ + 732, + 733, + 734, + 735, + 736, + 737 + ] + }, + { + "teal": 625, + "source": "tests/contracts/itxns.algo.ts:4", + "pc": [ + 738, + 739, + 740 + ] + }, + { + "teal": 626, + "source": "tests/contracts/itxns.algo.ts:4", + "pc": [ + 741, + 742, + 743, + 744 + ] + }, + { + "teal": 629, + "source": "tests/contracts/itxns.algo.ts:4", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 745 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 632, + "source": "tests/contracts/itxns.algo.ts:4", + "pc": [ + 746, + 747, + 748, + 749, + 750, + 751 + ] + }, + { + "teal": 633, + "source": "tests/contracts/itxns.algo.ts:4", + "pc": [ + 752, + 753, + 754, + 755, + 756, + 757 + ] + }, + { + "teal": 634, + "source": "tests/contracts/itxns.algo.ts:4", + "pc": [ + 758, + 759, + 760, + 761, + 762, + 763 + ] + }, + { + "teal": 635, + "source": "tests/contracts/itxns.algo.ts:4", + "pc": [ + 764, + 765, + 766, + 767, + 768, + 769 + ] + }, + { + "teal": 636, + "source": "tests/contracts/itxns.algo.ts:4", + "pc": [ + 770, + 771, + 772, + 773, + 774, + 775 + ] + }, + { + "teal": 637, + "source": "tests/contracts/itxns.algo.ts:4", + "pc": [ + 776, + 777, + 778, + 779, + 780, + 781 + ] + }, + { + "teal": 638, + "source": "tests/contracts/itxns.algo.ts:4", + "pc": [ + 782, + 783, + 784, + 785, + 786, + 787 + ] + }, + { + "teal": 639, + "source": "tests/contracts/itxns.algo.ts:4", + "pc": [ + 788, + 789, + 790, + 791, + 792, + 793 + ] + }, + { + "teal": 640, + "source": "tests/contracts/itxns.algo.ts:4", + "pc": [ + 794, + 795, + 796, + 797, + 798, + 799 + ] + }, + { + "teal": 641, + "source": "tests/contracts/itxns.algo.ts:4", + "pc": [ + 800, + 801, + 802, + 803, + 804, + 805 + ] + }, + { + "teal": 642, + "source": "tests/contracts/itxns.algo.ts:4", + "pc": [ + 806, + 807, + 808 + ] + }, + { + "teal": 643, + "source": "tests/contracts/itxns.algo.ts:4", + "pc": [ + 809, + 810, + 811, + 812, + 813, + 814, + 815, + 816, + 817, + 818, + 819, + 820, + 821, + 822, + 823, + 824, + 825, + 826, + 827, + 828, + 829, + 830 + ] }, { + "teal": 646, + "source": "tests/contracts/itxns.algo.ts:4", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 831 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/LoopsTest.arc56_draft.json b/tests/contracts/artifacts/LoopsTest.arc56_draft.json index c8799198c..3e9329193 100644 --- a/tests/contracts/artifacts/LoopsTest.arc56_draft.json +++ b/tests/contracts/artifacts/LoopsTest.arc56_draft.json @@ -168,22 +168,2447 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/loops.algo.ts:5", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/loops.algo.ts:5", + "pc": [ + 1, + 2, + 3, + 4, + 5 + ] + }, + { + "teal": 3, + "source": "tests/contracts/loops.algo.ts:5", + "pc": [ + 6, + 7, + 8, + 9, + 10, + 11, + 12, + 13 + ] + }, + { + "teal": 15, + "source": "tests/contracts/loops.algo.ts:5", + "pc": [ + 14, + 15 + ] + }, + { + "teal": 16, + "source": "tests/contracts/loops.algo.ts:5", + "pc": [ + 16 + ] + }, + { + "teal": 17, + "source": "tests/contracts/loops.algo.ts:5", + "pc": [ + 17, + 18 + ] + }, + { + "teal": 18, + "source": "tests/contracts/loops.algo.ts:5", + "pc": [ + 19 + ] + }, + { + "teal": 19, + "source": "tests/contracts/loops.algo.ts:5", + "pc": [ + 20, + 21 + ] + }, + { + "teal": 20, + "source": "tests/contracts/loops.algo.ts:5", + "pc": [ + 22 + ] + }, + { + "teal": 21, + "source": "tests/contracts/loops.algo.ts:5", + "pc": [ + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38, + 39, + 40, + 41, + 42, + 43, + 44, + 45, + 46, + 47, + 48 + ] + }, + { + "teal": 25, + "source": "tests/contracts/loops.algo.ts:5", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 49 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 30, + "source": "tests/contracts/loops.algo.ts:6", + "pc": [ + 50, + 51, + 52, + 53, + 54, + 55 + ] + }, + { + "teal": 33, + "source": "tests/contracts/loops.algo.ts:6", + "pc": [ + 56, + 57, + 58 + ] + }, + { + "teal": 34, + "source": "tests/contracts/loops.algo.ts:6", + "pc": [ + 59 + ] + }, + { + "teal": 35, + "source": "tests/contracts/loops.algo.ts:6", + "pc": [ + 60 + ] + }, + { + "teal": 36, + "source": "tests/contracts/loops.algo.ts:6", + "pc": [ + 61 + ] + }, + { + "teal": 37, + "source": "tests/contracts/loops.algo.ts:6", + "pc": [ + 62, + 63 + ] + }, + { + "teal": 38, + "source": "tests/contracts/loops.algo.ts:6", + "pc": [ + 64 + ] + }, + { + "teal": 42, + "source": "tests/contracts/loops.algo.ts:6", + "pc": [ + 65, + 66, + 67 + ] + }, + { + "teal": 45, + "source": "tests/contracts/loops.algo.ts:6", + "pc": [ + 68, + 69 + ] + }, + { + "teal": 49, + "source": "tests/contracts/loops.algo.ts:7", + "pc": [ + 70, + 71 + ] + }, + { + "teal": 50, + "source": "tests/contracts/loops.algo.ts:7", + "pc": [ + 72, + 73 + ] + }, + { + "teal": 57, + "source": "tests/contracts/loops.algo.ts:9", + "pc": [ + 74, + 75 + ] + }, + { + "teal": 58, + "source": "tests/contracts/loops.algo.ts:9", + "pc": [ + 76, + 77 + ] + }, + { + "teal": 59, + "source": "tests/contracts/loops.algo.ts:9", + "pc": [ + 78 + ] + }, + { + "teal": 60, + "source": "tests/contracts/loops.algo.ts:9", + "pc": [ + 79, + 80, + 81 + ] + }, + { + "teal": 64, + "source": "tests/contracts/loops.algo.ts:10", + "pc": [ + 82, + 83 + ] + }, + { + "teal": 65, + "source": "tests/contracts/loops.algo.ts:10", + "pc": [ + 84, + 85 + ] + }, + { + "teal": 66, + "source": "tests/contracts/loops.algo.ts:10", + "pc": [ + 86 + ] + }, + { + "teal": 67, + "source": "tests/contracts/loops.algo.ts:10", + "pc": [ + 87, + 88 + ] + }, + { + "teal": 68, + "source": "tests/contracts/loops.algo.ts:9", + "pc": [ + 89, + 90, + 91 + ] + }, + { + "teal": 73, + "source": "tests/contracts/loops.algo.ts:13", + "pc": [ + 92, + 93 + ] + }, + { + "teal": 76, + "source": "tests/contracts/loops.algo.ts:6", + "pc": [ + 94, + 95 + ] + }, + { + "teal": 77, + "source": "tests/contracts/loops.algo.ts:6", + "pc": [ + 96 + ] + }, + { + "teal": 82, + "source": "tests/contracts/loops.algo.ts:16", + "pc": [ + 97, + 98, + 99, + 100, + 101, + 102 + ] + }, + { + "teal": 85, + "source": "tests/contracts/loops.algo.ts:16", + "pc": [ + 103, + 104, + 105 + ] + }, + { + "teal": 86, + "source": "tests/contracts/loops.algo.ts:16", + "pc": [ + 106 + ] + }, + { + "teal": 87, + "source": "tests/contracts/loops.algo.ts:16", + "pc": [ + 107 + ] + }, + { + "teal": 88, + "source": "tests/contracts/loops.algo.ts:16", + "pc": [ + 108 + ] + }, + { + "teal": 89, + "source": "tests/contracts/loops.algo.ts:16", + "pc": [ + 109, + 110 + ] + }, + { + "teal": 90, + "source": "tests/contracts/loops.algo.ts:16", + "pc": [ + 111 + ] + }, + { + "teal": 94, + "source": "tests/contracts/loops.algo.ts:16", + "pc": [ + 112, + 113, + 114 + ] + }, + { + "teal": 97, + "source": "tests/contracts/loops.algo.ts:16", + "pc": [ + 115, + 116 + ] + }, + { + "teal": 98, + "source": "tests/contracts/loops.algo.ts:16", + "pc": [ + 117 + ] + }, + { + "teal": 102, + "source": "tests/contracts/loops.algo.ts:17", + "pc": [ + 118, + 119 + ] + }, + { + "teal": 103, + "source": "tests/contracts/loops.algo.ts:17", + "pc": [ + 120, + 121 + ] + }, + { + "teal": 107, + "source": "tests/contracts/loops.algo.ts:19", + "pc": [ + 122, + 123 + ] + }, + { + "teal": 108, + "source": "tests/contracts/loops.algo.ts:19", + "pc": [ + 124, + 125 + ] + }, + { + "teal": 113, + "source": "tests/contracts/loops.algo.ts:19", + "pc": [ + 126, + 127 + ] + }, + { + "teal": 114, + "source": "tests/contracts/loops.algo.ts:19", + "pc": [ + 128, + 129 + ] + }, + { + "teal": 115, + "source": "tests/contracts/loops.algo.ts:19", + "pc": [ + 130 + ] + }, + { + "teal": 116, + "source": "tests/contracts/loops.algo.ts:19", + "pc": [ + 131, + 132, + 133 + ] + }, + { + "teal": 120, + "source": "tests/contracts/loops.algo.ts:20", + "pc": [ + 134, + 135 + ] + }, + { + "teal": 121, + "source": "tests/contracts/loops.algo.ts:20", + "pc": [ + 136, + 137 + ] + }, + { + "teal": 122, + "source": "tests/contracts/loops.algo.ts:20", + "pc": [ + 138 + ] + }, + { + "teal": 123, + "source": "tests/contracts/loops.algo.ts:20", + "pc": [ + 139, + 140 + ] + }, + { + "teal": 128, + "source": "tests/contracts/loops.algo.ts:19", + "pc": [ + 141, + 142 + ] + }, + { + "teal": 129, + "source": "tests/contracts/loops.algo.ts:19", + "pc": [ + 143, + 144 + ] + }, + { + "teal": 130, + "source": "tests/contracts/loops.algo.ts:19", + "pc": [ + 145 + ] + }, + { + "teal": 131, + "source": "tests/contracts/loops.algo.ts:19", + "pc": [ + 146, + 147 + ] + }, + { + "teal": 132, + "source": "tests/contracts/loops.algo.ts:19", + "pc": [ + 148, + 149, + 150 + ] + }, + { + "teal": 137, + "source": "tests/contracts/loops.algo.ts:23", + "pc": [ + 151, + 152 + ] + }, + { + "teal": 140, + "source": "tests/contracts/loops.algo.ts:16", + "pc": [ + 153, + 154 + ] + }, + { + "teal": 143, + "source": "tests/contracts/loops.algo.ts:16", + "pc": [ + 155, + 156 + ] + }, + { + "teal": 144, + "source": "tests/contracts/loops.algo.ts:16", + "pc": [ + 157 + ] + }, + { + "teal": 149, + "source": "tests/contracts/loops.algo.ts:26", + "pc": [ + 158, + 159, + 160, + 161, + 162, + 163 + ] + }, + { + "teal": 152, + "source": "tests/contracts/loops.algo.ts:26", + "pc": [ + 164, + 165, + 166 + ] + }, + { + "teal": 153, + "source": "tests/contracts/loops.algo.ts:26", + "pc": [ + 167 + ] + }, + { + "teal": 154, + "source": "tests/contracts/loops.algo.ts:26", + "pc": [ + 168 + ] + }, + { + "teal": 155, + "source": "tests/contracts/loops.algo.ts:26", + "pc": [ + 169 + ] + }, + { + "teal": 156, + "source": "tests/contracts/loops.algo.ts:26", + "pc": [ + 170, + 171 + ] + }, + { + "teal": 157, + "source": "tests/contracts/loops.algo.ts:26", + "pc": [ + 172 + ] + }, + { + "teal": 161, + "source": "tests/contracts/loops.algo.ts:26", + "pc": [ + 173, + 174, + 175 + ] + }, + { + "teal": 164, + "source": "tests/contracts/loops.algo.ts:26", + "pc": [ + 176, + 177 + ] + }, + { + "teal": 168, + "source": "tests/contracts/loops.algo.ts:27", + "pc": [ + 178, + 179 + ] + }, + { + "teal": 169, + "source": "tests/contracts/loops.algo.ts:27", + "pc": [ + 180, + 181 + ] + }, + { + "teal": 174, + "source": "tests/contracts/loops.algo.ts:30", + "pc": [ + 182, + 183 + ] + }, + { + "teal": 175, + "source": "tests/contracts/loops.algo.ts:30", + "pc": [ + 184, + 185 + ] + }, + { + "teal": 176, + "source": "tests/contracts/loops.algo.ts:30", + "pc": [ + 186 + ] + }, + { + "teal": 177, + "source": "tests/contracts/loops.algo.ts:30", + "pc": [ + 187, + 188 + ] + }, + { + "teal": 184, + "source": "tests/contracts/loops.algo.ts:31", + "pc": [ + 189, + 190 + ] + }, + { + "teal": 185, + "source": "tests/contracts/loops.algo.ts:31", + "pc": [ + 191, + 192 + ] + }, + { + "teal": 186, + "source": "tests/contracts/loops.algo.ts:31", + "pc": [ + 193 + ] + }, + { + "teal": 187, + "source": "tests/contracts/loops.algo.ts:29", + "pc": [ + 194, + 195, + 196 + ] + }, + { + "teal": 192, + "source": "tests/contracts/loops.algo.ts:33", + "pc": [ + 197, + 198 + ] + }, + { + "teal": 195, + "source": "tests/contracts/loops.algo.ts:26", + "pc": [ + 199, + 200 + ] + }, + { + "teal": 196, + "source": "tests/contracts/loops.algo.ts:26", + "pc": [ + 201 + ] + }, + { + "teal": 201, + "source": "tests/contracts/loops.algo.ts:36", + "pc": [ + 202, + 203, + 204, + 205, + 206, + 207 + ] + }, + { + "teal": 204, + "source": "tests/contracts/loops.algo.ts:36", + "pc": [ + 208, + 209, + 210 + ] + }, + { + "teal": 205, + "source": "tests/contracts/loops.algo.ts:36", + "pc": [ + 211 + ] + }, + { + "teal": 206, + "source": "tests/contracts/loops.algo.ts:36", + "pc": [ + 212 + ] + }, + { + "teal": 207, + "source": "tests/contracts/loops.algo.ts:36", + "pc": [ + 213 + ] + }, + { + "teal": 208, + "source": "tests/contracts/loops.algo.ts:36", + "pc": [ + 214, + 215 + ] + }, + { + "teal": 209, + "source": "tests/contracts/loops.algo.ts:36", + "pc": [ + 216 + ] + }, + { + "teal": 213, + "source": "tests/contracts/loops.algo.ts:36", + "pc": [ + 217, + 218, + 219 + ] + }, + { + "teal": 216, + "source": "tests/contracts/loops.algo.ts:36", + "pc": [ + 220, + 221 + ] + }, + { + "teal": 220, + "source": "tests/contracts/loops.algo.ts:37", + "pc": [ + 222, + 223 + ] + }, + { + "teal": 221, + "source": "tests/contracts/loops.algo.ts:37", + "pc": [ + 224, + 225 + ] + }, + { + "teal": 228, + "source": "tests/contracts/loops.algo.ts:39", + "pc": [ + 226, + 227 + ] + }, + { + "teal": 229, + "source": "tests/contracts/loops.algo.ts:39", + "pc": [ + 228, + 229 + ] + }, + { + "teal": 230, + "source": "tests/contracts/loops.algo.ts:39", + "pc": [ + 230 + ] + }, + { + "teal": 231, + "source": "tests/contracts/loops.algo.ts:39", + "pc": [ + 231, + 232, + 233 + ] + }, + { + "teal": 235, + "source": "tests/contracts/loops.algo.ts:40", + "pc": [ + 234, + 235 + ] + }, + { + "teal": 236, + "source": "tests/contracts/loops.algo.ts:40", + "pc": [ + 236, + 237 + ] + }, + { + "teal": 237, + "source": "tests/contracts/loops.algo.ts:40", + "pc": [ + 238 + ] + }, + { + "teal": 238, + "source": "tests/contracts/loops.algo.ts:40", + "pc": [ + 239, + 240 + ] + }, + { + "teal": 243, + "source": "tests/contracts/loops.algo.ts:41", + "pc": [ + 241, + 242 + ] + }, + { + "teal": 244, + "source": "tests/contracts/loops.algo.ts:41", + "pc": [ + 243, + 244 + ] + }, + { + "teal": 245, + "source": "tests/contracts/loops.algo.ts:41", + "pc": [ + 245 + ] + }, + { + "teal": 246, + "source": "tests/contracts/loops.algo.ts:41", + "pc": [ + 246, + 247, + 248 + ] + }, + { + "teal": 249, + "source": "tests/contracts/loops.algo.ts:41", + "pc": [ + 249, + 250, + 251 + ] + }, + { + "teal": 252, + "source": "tests/contracts/loops.algo.ts:39", + "pc": [ + 252, + 253, + 254 + ] + }, + { + "teal": 257, + "source": "tests/contracts/loops.algo.ts:44", + "pc": [ + 255, + 256 + ] + }, + { + "teal": 260, + "source": "tests/contracts/loops.algo.ts:36", + "pc": [ + 257, + 258 + ] + }, + { + "teal": 261, + "source": "tests/contracts/loops.algo.ts:36", + "pc": [ + 259 + ] + }, + { + "teal": 266, + "source": "tests/contracts/loops.algo.ts:47", + "pc": [ + 260, + 261, + 262, + 263, + 264, + 265 + ] + }, + { + "teal": 269, + "source": "tests/contracts/loops.algo.ts:47", + "pc": [ + 266, + 267, + 268 + ] + }, + { + "teal": 270, + "source": "tests/contracts/loops.algo.ts:47", + "pc": [ + 269 + ] + }, + { + "teal": 271, + "source": "tests/contracts/loops.algo.ts:47", + "pc": [ + 270 + ] + }, + { + "teal": 272, + "source": "tests/contracts/loops.algo.ts:47", + "pc": [ + 271 + ] + }, + { + "teal": 273, + "source": "tests/contracts/loops.algo.ts:47", + "pc": [ + 272, + 273 + ] + }, + { + "teal": 274, + "source": "tests/contracts/loops.algo.ts:47", + "pc": [ + 274 + ] + }, + { + "teal": 278, + "source": "tests/contracts/loops.algo.ts:47", + "pc": [ + 275, + 276, + 277 + ] + }, + { + "teal": 281, + "source": "tests/contracts/loops.algo.ts:47", + "pc": [ + 278, + 279 + ] + }, + { + "teal": 285, + "source": "tests/contracts/loops.algo.ts:48", + "pc": [ + 280, + 281 + ] + }, + { + "teal": 286, + "source": "tests/contracts/loops.algo.ts:48", + "pc": [ + 282, + 283 + ] + }, + { + "teal": 293, + "source": "tests/contracts/loops.algo.ts:50", + "pc": [ + 284, + 285 + ] + }, + { + "teal": 294, + "source": "tests/contracts/loops.algo.ts:50", + "pc": [ + 286, + 287 + ] + }, + { + "teal": 295, + "source": "tests/contracts/loops.algo.ts:50", + "pc": [ + 288 + ] + }, + { + "teal": 296, + "source": "tests/contracts/loops.algo.ts:50", + "pc": [ + 289, + 290, + 291 + ] + }, + { + "teal": 301, + "source": "tests/contracts/loops.algo.ts:51", + "pc": [ + 292, + 293 + ] + }, + { + "teal": 302, + "source": "tests/contracts/loops.algo.ts:51", + "pc": [ + 294, + 295 + ] + }, + { + "teal": 303, + "source": "tests/contracts/loops.algo.ts:51", + "pc": [ + 296 + ] + }, + { + "teal": 304, + "source": "tests/contracts/loops.algo.ts:51", + "pc": [ + 297, + 298, + 299 + ] + }, + { + "teal": 309, + "source": "tests/contracts/loops.algo.ts:52", + "pc": [ + 300, + 301, + 302 + ] + }, + { + "teal": 310, + "source": "tests/contracts/loops.algo.ts:52", + "pc": [ + 303, + 304 + ] + }, + { + "teal": 311, + "source": "tests/contracts/loops.algo.ts:53", + "pc": [ + 305, + 306, + 307 + ] + }, + { + "teal": 316, + "source": "tests/contracts/loops.algo.ts:55", + "pc": [ + 308, + 309 + ] + }, + { + "teal": 317, + "source": "tests/contracts/loops.algo.ts:55", + "pc": [ + 310, + 311 + ] + }, + { + "teal": 318, + "source": "tests/contracts/loops.algo.ts:55", + "pc": [ + 312 + ] + }, + { + "teal": 319, + "source": "tests/contracts/loops.algo.ts:55", + "pc": [ + 313, + 314 + ] + }, + { + "teal": 320, + "source": "tests/contracts/loops.algo.ts:50", + "pc": [ + 315, + 316, + 317 + ] + }, + { + "teal": 325, + "source": "tests/contracts/loops.algo.ts:58", + "pc": [ + 318, + 319 + ] + }, + { + "teal": 328, + "source": "tests/contracts/loops.algo.ts:47", + "pc": [ + 320, + 321 + ] + }, + { + "teal": 329, + "source": "tests/contracts/loops.algo.ts:47", + "pc": [ + 322 + ] + }, + { + "teal": 334, + "source": "tests/contracts/loops.algo.ts:61", + "pc": [ + 323, + 324, + 325, + 326, + 327, + 328 + ] + }, + { + "teal": 337, + "source": "tests/contracts/loops.algo.ts:61", + "pc": [ + 329, + 330, + 331 + ] + }, + { + "teal": 338, + "source": "tests/contracts/loops.algo.ts:61", + "pc": [ + 332 + ] + }, + { + "teal": 339, + "source": "tests/contracts/loops.algo.ts:61", + "pc": [ + 333 + ] + }, + { + "teal": 340, + "source": "tests/contracts/loops.algo.ts:61", + "pc": [ + 334 + ] + }, + { + "teal": 341, + "source": "tests/contracts/loops.algo.ts:61", + "pc": [ + 335, + 336 + ] + }, + { + "teal": 342, + "source": "tests/contracts/loops.algo.ts:61", + "pc": [ + 337 + ] + }, + { + "teal": 346, + "source": "tests/contracts/loops.algo.ts:61", + "pc": [ + 338, + 339, + 340 + ] + }, + { + "teal": 349, + "source": "tests/contracts/loops.algo.ts:61", + "pc": [ + 341, + 342 + ] + }, + { + "teal": 350, + "source": "tests/contracts/loops.algo.ts:61", + "pc": [ + 343 + ] + }, + { + "teal": 354, + "source": "tests/contracts/loops.algo.ts:62", + "pc": [ + 344, + 345 + ] + }, + { + "teal": 355, + "source": "tests/contracts/loops.algo.ts:62", + "pc": [ + 346, + 347 + ] + }, + { + "teal": 359, + "source": "tests/contracts/loops.algo.ts:64", + "pc": [ + 348, + 349 + ] + }, + { + "teal": 360, + "source": "tests/contracts/loops.algo.ts:64", + "pc": [ + 350, + 351 + ] + }, + { + "teal": 365, + "source": "tests/contracts/loops.algo.ts:64", + "pc": [ + 352, + 353 + ] + }, + { + "teal": 366, + "source": "tests/contracts/loops.algo.ts:64", + "pc": [ + 354, + 355 + ] + }, + { + "teal": 367, + "source": "tests/contracts/loops.algo.ts:64", + "pc": [ + 356 + ] + }, + { + "teal": 368, + "source": "tests/contracts/loops.algo.ts:64", + "pc": [ + 357, + 358, + 359 + ] + }, + { + "teal": 372, + "source": "tests/contracts/loops.algo.ts:65", + "pc": [ + 360, + 361 + ] + }, + { + "teal": 373, + "source": "tests/contracts/loops.algo.ts:65", + "pc": [ + 362, + 363 + ] + }, + { + "teal": 374, + "source": "tests/contracts/loops.algo.ts:65", + "pc": [ + 364 + ] + }, + { + "teal": 375, + "source": "tests/contracts/loops.algo.ts:65", + "pc": [ + 365, + 366 + ] + }, + { + "teal": 380, + "source": "tests/contracts/loops.algo.ts:66", + "pc": [ + 367, + 368 + ] + }, + { + "teal": 381, + "source": "tests/contracts/loops.algo.ts:66", + "pc": [ + 369, + 370 + ] + }, + { + "teal": 382, + "source": "tests/contracts/loops.algo.ts:66", + "pc": [ + 371 + ] + }, + { + "teal": 383, + "source": "tests/contracts/loops.algo.ts:66", + "pc": [ + 372, + 373, + 374 + ] + }, + { + "teal": 386, + "source": "tests/contracts/loops.algo.ts:66", + "pc": [ + 375, + 376, + 377 + ] + }, + { + "teal": 393, + "source": "tests/contracts/loops.algo.ts:64", + "pc": [ + 378, + 379 + ] + }, + { + "teal": 394, + "source": "tests/contracts/loops.algo.ts:64", + "pc": [ + 380, + 381 + ] + }, + { + "teal": 395, + "source": "tests/contracts/loops.algo.ts:64", + "pc": [ + 382 + ] + }, + { + "teal": 396, + "source": "tests/contracts/loops.algo.ts:64", + "pc": [ + 383, + 384 + ] + }, + { + "teal": 397, + "source": "tests/contracts/loops.algo.ts:64", + "pc": [ + 385, + 386, + 387 + ] + }, + { + "teal": 402, + "source": "tests/contracts/loops.algo.ts:69", + "pc": [ + 388, + 389 + ] + }, + { + "teal": 405, + "source": "tests/contracts/loops.algo.ts:61", + "pc": [ + 390, + 391 + ] + }, + { + "teal": 408, + "source": "tests/contracts/loops.algo.ts:61", + "pc": [ + 392, + 393 + ] + }, + { + "teal": 409, + "source": "tests/contracts/loops.algo.ts:61", + "pc": [ + 394 + ] + }, + { + "teal": 414, + "source": "tests/contracts/loops.algo.ts:72", + "pc": [ + 395, + 396, + 397, + 398, + 399, + 400 + ] + }, + { + "teal": 417, + "source": "tests/contracts/loops.algo.ts:72", + "pc": [ + 401, + 402, + 403 + ] + }, + { + "teal": 418, + "source": "tests/contracts/loops.algo.ts:72", + "pc": [ + 404 + ] + }, + { + "teal": 419, + "source": "tests/contracts/loops.algo.ts:72", + "pc": [ + 405 + ] + }, + { + "teal": 420, + "source": "tests/contracts/loops.algo.ts:72", + "pc": [ + 406 + ] + }, + { + "teal": 421, + "source": "tests/contracts/loops.algo.ts:72", + "pc": [ + 407, + 408 + ] + }, + { + "teal": 422, + "source": "tests/contracts/loops.algo.ts:72", + "pc": [ + 409 + ] + }, + { + "teal": 426, + "source": "tests/contracts/loops.algo.ts:72", + "pc": [ + 410, + 411, + 412 + ] + }, + { + "teal": 429, + "source": "tests/contracts/loops.algo.ts:72", + "pc": [ + 413, + 414 + ] + }, + { + "teal": 430, + "source": "tests/contracts/loops.algo.ts:72", + "pc": [ + 415 + ] + }, + { + "teal": 434, + "source": "tests/contracts/loops.algo.ts:73", + "pc": [ + 416, + 417 + ] + }, + { + "teal": 435, + "source": "tests/contracts/loops.algo.ts:73", + "pc": [ + 418, + 419 + ] + }, + { + "teal": 439, + "source": "tests/contracts/loops.algo.ts:75", + "pc": [ + 420, + 421 + ] + }, + { + "teal": 440, + "source": "tests/contracts/loops.algo.ts:75", + "pc": [ + 422, + 423 + ] + }, + { + "teal": 445, + "source": "tests/contracts/loops.algo.ts:75", + "pc": [ + 424, + 425 + ] + }, + { + "teal": 446, + "source": "tests/contracts/loops.algo.ts:75", + "pc": [ + 426, + 427 + ] + }, + { + "teal": 447, + "source": "tests/contracts/loops.algo.ts:75", + "pc": [ + 428 + ] + }, + { + "teal": 448, + "source": "tests/contracts/loops.algo.ts:75", + "pc": [ + 429, + 430, + 431 + ] + }, + { + "teal": 453, + "source": "tests/contracts/loops.algo.ts:76", + "pc": [ + 432, + 433 + ] + }, + { + "teal": 454, + "source": "tests/contracts/loops.algo.ts:76", + "pc": [ + 434, + 435 + ] + }, + { + "teal": 455, + "source": "tests/contracts/loops.algo.ts:76", + "pc": [ + 436 + ] + }, + { + "teal": 456, + "source": "tests/contracts/loops.algo.ts:76", + "pc": [ + 437, + 438, + 439 + ] + }, + { + "teal": 461, + "source": "tests/contracts/loops.algo.ts:77", + "pc": [ + 440, + 441, + 442 + ] + }, + { + "teal": 462, + "source": "tests/contracts/loops.algo.ts:77", + "pc": [ + 443, + 444 + ] + }, + { + "teal": 463, + "source": "tests/contracts/loops.algo.ts:78", + "pc": [ + 445, + 446, + 447 + ] + }, + { + "teal": 468, + "source": "tests/contracts/loops.algo.ts:80", + "pc": [ + 448, + 449 + ] + }, + { + "teal": 469, + "source": "tests/contracts/loops.algo.ts:80", + "pc": [ + 450, + 451 + ] + }, + { + "teal": 470, + "source": "tests/contracts/loops.algo.ts:80", + "pc": [ + 452 + ] + }, + { + "teal": 471, + "source": "tests/contracts/loops.algo.ts:80", + "pc": [ + 453, + 454 + ] + }, + { + "teal": 476, + "source": "tests/contracts/loops.algo.ts:75", + "pc": [ + 455, + 456 + ] + }, + { + "teal": 477, + "source": "tests/contracts/loops.algo.ts:75", + "pc": [ + 457, + 458 + ] + }, + { + "teal": 478, + "source": "tests/contracts/loops.algo.ts:75", + "pc": [ + 459 + ] + }, + { + "teal": 479, + "source": "tests/contracts/loops.algo.ts:75", + "pc": [ + 460, + 461 + ] + }, + { + "teal": 480, + "source": "tests/contracts/loops.algo.ts:75", + "pc": [ + 462, + 463, + 464 + ] + }, + { + "teal": 485, + "source": "tests/contracts/loops.algo.ts:83", + "pc": [ + 465, + 466 + ] + }, + { + "teal": 488, + "source": "tests/contracts/loops.algo.ts:72", + "pc": [ + 467, + 468 + ] + }, + { + "teal": 491, + "source": "tests/contracts/loops.algo.ts:72", + "pc": [ + 469, + 470 + ] + }, + { + "teal": 492, + "source": "tests/contracts/loops.algo.ts:72", + "pc": [ + 471 + ] + }, + { + "teal": 497, + "source": "tests/contracts/loops.algo.ts:86", + "pc": [ + 472, + 473, + 474, + 475, + 476, + 477 + ] + }, + { + "teal": 500, + "source": "tests/contracts/loops.algo.ts:86", + "pc": [ + 478, + 479, + 480 + ] + }, + { + "teal": 501, + "source": "tests/contracts/loops.algo.ts:86", + "pc": [ + 481 + ] + }, + { + "teal": 502, + "source": "tests/contracts/loops.algo.ts:86", + "pc": [ + 482 + ] + }, + { + "teal": 503, + "source": "tests/contracts/loops.algo.ts:86", + "pc": [ + 483 + ] + }, + { + "teal": 504, + "source": "tests/contracts/loops.algo.ts:86", + "pc": [ + 484, + 485 + ] + }, + { + "teal": 505, + "source": "tests/contracts/loops.algo.ts:86", + "pc": [ + 486 + ] + }, + { + "teal": 509, + "source": "tests/contracts/loops.algo.ts:86", + "pc": [ + 487, + 488, + 489 + ] + }, + { + "teal": 512, + "source": "tests/contracts/loops.algo.ts:86", + "pc": [ + 490, + 491 + ] + }, + { + "teal": 516, + "source": "tests/contracts/loops.algo.ts:87", + "pc": [ + 492, + 493 + ] + }, + { + "teal": 517, + "source": "tests/contracts/loops.algo.ts:87", + "pc": [ + 494, + 495 + ] + }, + { + "teal": 522, + "source": "tests/contracts/loops.algo.ts:90", + "pc": [ + 496, + 497 + ] + }, + { + "teal": 523, + "source": "tests/contracts/loops.algo.ts:90", + "pc": [ + 498, + 499 + ] + }, + { + "teal": 524, + "source": "tests/contracts/loops.algo.ts:90", + "pc": [ + 500 + ] + }, + { + "teal": 525, + "source": "tests/contracts/loops.algo.ts:90", + "pc": [ + 501, + 502 + ] + }, + { + "teal": 530, + "source": "tests/contracts/loops.algo.ts:91", + "pc": [ + 503, + 504 + ] + }, + { + "teal": 531, + "source": "tests/contracts/loops.algo.ts:91", + "pc": [ + 505, + 506 + ] + }, + { + "teal": 532, + "source": "tests/contracts/loops.algo.ts:91", + "pc": [ + 507 + ] + }, + { + "teal": 533, + "source": "tests/contracts/loops.algo.ts:91", + "pc": [ + 508, + 509, + 510 + ] + }, + { + "teal": 536, + "source": "tests/contracts/loops.algo.ts:91", + "pc": [ + 511, + 512, + 513 + ] + }, + { + "teal": 545, + "source": "tests/contracts/loops.algo.ts:92", + "pc": [ + 514, + 515 + ] + }, + { + "teal": 546, + "source": "tests/contracts/loops.algo.ts:92", + "pc": [ + 516, + 517 + ] + }, + { + "teal": 547, + "source": "tests/contracts/loops.algo.ts:92", + "pc": [ + 518 + ] + }, + { + "teal": 548, + "source": "tests/contracts/loops.algo.ts:89", + "pc": [ + 519, + 520, + 521 + ] + }, + { + "teal": 553, + "source": "tests/contracts/loops.algo.ts:94", + "pc": [ + 522, + 523 + ] + }, + { + "teal": 556, + "source": "tests/contracts/loops.algo.ts:86", + "pc": [ + 524, + 525 + ] + }, + { + "teal": 557, + "source": "tests/contracts/loops.algo.ts:86", + "pc": [ + 526 + ] + }, + { + "teal": 562, + "source": "tests/contracts/loops.algo.ts:97", + "pc": [ + 527, + 528, + 529, + 530, + 531, + 532 + ] + }, + { + "teal": 565, + "source": "tests/contracts/loops.algo.ts:97", + "pc": [ + 533, + 534, + 535 + ] + }, + { + "teal": 566, + "source": "tests/contracts/loops.algo.ts:97", + "pc": [ + 536 + ] + }, + { + "teal": 567, + "source": "tests/contracts/loops.algo.ts:97", + "pc": [ + 537 + ] + }, + { + "teal": 568, + "source": "tests/contracts/loops.algo.ts:97", + "pc": [ + 538 + ] + }, + { + "teal": 569, + "source": "tests/contracts/loops.algo.ts:97", + "pc": [ + 539, + 540 + ] + }, + { + "teal": 570, + "source": "tests/contracts/loops.algo.ts:97", + "pc": [ + 541 + ] + }, + { + "teal": 574, + "source": "tests/contracts/loops.algo.ts:97", + "pc": [ + 542, + 543, + 544 + ] + }, + { + "teal": 577, + "source": "tests/contracts/loops.algo.ts:97", + "pc": [ + 545, + 546 + ] + }, + { + "teal": 581, + "source": "tests/contracts/loops.algo.ts:98", + "pc": [ + 547, + 548 + ] + }, + { + "teal": 582, + "source": "tests/contracts/loops.algo.ts:98", + "pc": [ + 549, + 550 + ] + }, + { + "teal": 588, + "source": "tests/contracts/loops.algo.ts:101", + "pc": [ + 551, + 552 + ] + }, + { + "teal": 589, + "source": "tests/contracts/loops.algo.ts:101", + "pc": [ + 553, + 554 + ] + }, + { + "teal": 590, + "source": "tests/contracts/loops.algo.ts:101", + "pc": [ + 555 + ] + }, + { + "teal": 591, + "source": "tests/contracts/loops.algo.ts:101", + "pc": [ + 556, + 557, + 558 + ] + }, + { + "teal": 596, + "source": "tests/contracts/loops.algo.ts:102", + "pc": [ + 559, + 560, + 561 + ] + }, + { + "teal": 597, + "source": "tests/contracts/loops.algo.ts:102", + "pc": [ + 562, + 563 + ] + }, + { + "teal": 598, + "source": "tests/contracts/loops.algo.ts:103", + "pc": [ + 564, + 565, + 566 + ] + }, + { + "teal": 603, + "source": "tests/contracts/loops.algo.ts:105", + "pc": [ + 567, + 568 + ] + }, + { + "teal": 604, + "source": "tests/contracts/loops.algo.ts:105", + "pc": [ + 569, + 570 + ] + }, + { + "teal": 605, + "source": "tests/contracts/loops.algo.ts:105", + "pc": [ + 571 + ] + }, + { + "teal": 606, + "source": "tests/contracts/loops.algo.ts:105", + "pc": [ + 572, + 573 + ] + }, + { + "teal": 613, + "source": "tests/contracts/loops.algo.ts:106", + "pc": [ + 574, + 575 + ] + }, + { + "teal": 614, + "source": "tests/contracts/loops.algo.ts:106", + "pc": [ + 576, + 577 + ] + }, + { + "teal": 615, + "source": "tests/contracts/loops.algo.ts:106", + "pc": [ + 578 + ] + }, + { + "teal": 616, + "source": "tests/contracts/loops.algo.ts:100", + "pc": [ + 579, + 580, + 581 + ] + }, + { + "teal": 621, + "source": "tests/contracts/loops.algo.ts:108", + "pc": [ + 582, + 583 + ] + }, + { + "teal": 624, + "source": "tests/contracts/loops.algo.ts:97", + "pc": [ + 584, + 585 + ] + }, + { + "teal": 625, + "source": "tests/contracts/loops.algo.ts:97", + "pc": [ + 586 + ] }, { + "teal": 628, + "source": "tests/contracts/loops.algo.ts:5", + "pc": [ + 587, + 588 + ] + }, + { + "teal": 629, + "source": "tests/contracts/loops.algo.ts:5", + "pc": [ + 589 + ] + }, + { + "teal": 632, + "source": "tests/contracts/loops.algo.ts:5", + "pc": [ + 590, + 591, + 592, + 593, + 594, + 595 + ] + }, + { + "teal": 633, + "source": "tests/contracts/loops.algo.ts:5", + "pc": [ + 596, + 597, + 598 + ] + }, + { + "teal": 634, + "source": "tests/contracts/loops.algo.ts:5", + "pc": [ + 599, + 600, + 601, + 602 + ] + }, + { + "teal": 637, + "source": "tests/contracts/loops.algo.ts:5", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 603 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 640, + "source": "tests/contracts/loops.algo.ts:5", + "pc": [ + 604, + 605, + 606, + 607, + 608, + 609 + ] + }, + { + "teal": 641, + "source": "tests/contracts/loops.algo.ts:5", + "pc": [ + 610, + 611, + 612, + 613, + 614, + 615 + ] + }, + { + "teal": 642, + "source": "tests/contracts/loops.algo.ts:5", + "pc": [ + 616, + 617, + 618, + 619, + 620, + 621 + ] + }, + { + "teal": 643, + "source": "tests/contracts/loops.algo.ts:5", + "pc": [ + 622, + 623, + 624, + 625, + 626, + 627 + ] + }, + { + "teal": 644, + "source": "tests/contracts/loops.algo.ts:5", + "pc": [ + 628, + 629, + 630, + 631, + 632, + 633 + ] + }, + { + "teal": 645, + "source": "tests/contracts/loops.algo.ts:5", + "pc": [ + 634, + 635, + 636, + 637, + 638, + 639 + ] + }, + { + "teal": 646, + "source": "tests/contracts/loops.algo.ts:5", + "pc": [ + 640, + 641, + 642, + 643, + 644, + 645 + ] + }, + { + "teal": 647, + "source": "tests/contracts/loops.algo.ts:5", + "pc": [ + 646, + 647, + 648, + 649, + 650, + 651 + ] + }, + { + "teal": 648, + "source": "tests/contracts/loops.algo.ts:5", + "pc": [ + 652, + 653, + 654, + 655, + 656, + 657 + ] + }, + { + "teal": 649, + "source": "tests/contracts/loops.algo.ts:5", + "pc": [ + 658, + 659, + 660 + ] + }, + { + "teal": 650, + "source": "tests/contracts/loops.algo.ts:5", + "pc": [ + 661, + 662, + 663, + 664, + 665, + 666, + 667, + 668, + 669, + 670, + 671, + 672, + 673, + 674, + 675, + 676, + 677, + 678, + 679, + 680 + ] }, { + "teal": 653, + "source": "tests/contracts/loops.algo.ts:5", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 681 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/MathTest.arc56_draft.json b/tests/contracts/artifacts/MathTest.arc56_draft.json index 704b2d1cb..5ebfcb2e9 100644 --- a/tests/contracts/artifacts/MathTest.arc56_draft.json +++ b/tests/contracts/artifacts/MathTest.arc56_draft.json @@ -913,358 +913,11135 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 1, + 2, + 3, + 4, + 5, + 6, + 7, + 8, + 9, + 10, + 11, + 12, + 13, + 14, + 15, + 16 + ] + }, + { + "teal": 3, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38, + 39, + 40, + 41, + 42, + 43, + 44, + 45, + 46, + 47, + 48, + 49, + 50, + 51, + 52, + 53, + 54, + 55, + 56, + 57, + 58, + 59, + 60, + 61, + 62, + 63, + 64, + 65, + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82, + 83, + 84, + 85, + 86, + 87, + 88, + 89, + 90, + 91, + 92, + 93, + 94, + 95, + 96, + 97, + 98, + 99, + 100, + 101, + 102, + 103, + 104, + 105, + 106, + 107, + 108, + 109, + 110, + 111, + 112, + 113, + 114, + 115, + 116, + 117, + 118, + 119, + 120, + 121, + 122, + 123, + 124, + 125, + 126, + 127, + 128, + 129, + 130, + 131, + 132, + 133, + 134, + 135, + 136, + 137, + 138, + 139, + 140, + 141, + 142, + 143, + 144, + 145, + 146, + 147, + 148, + 149, + 150, + 151, + 152, + 153, + 154, + 155, + 156, + 157, + 158, + 159, + 160, + 161 + ] + }, + { + "teal": 15, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 162, + 163 + ] + }, + { + "teal": 16, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 164 + ] + }, + { + "teal": 17, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 165, + 166 + ] + }, + { + "teal": 18, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 167 + ] + }, + { + "teal": 19, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 168, + 169 + ] + }, + { + "teal": 20, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 170 + ] + }, + { + "teal": 21, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 171, + 172, + 173, + 174, + 175, + 176, + 177, + 178, + 179, + 180, + 181, + 182, + 183, + 184, + 185, + 186, + 187, + 188, + 189, + 190, + 191, + 192, + 193, + 194, + 195, + 196 + ] + }, + { + "teal": 25, + "source": "tests/contracts/math.algo.ts:4", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 197 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 30, + "source": "tests/contracts/math.algo.ts:7", + "pc": [ + 198, + 199, + 200, + 201, + 202, + 203 + ] + }, + { + "teal": 33, + "source": "tests/contracts/math.algo.ts:7", + "pc": [ + 204, + 205, + 206 + ] + }, + { + "teal": 34, + "source": "tests/contracts/math.algo.ts:7", + "pc": [ + 207 + ] + }, + { + "teal": 37, + "source": "tests/contracts/math.algo.ts:7", + "pc": [ + 208, + 209, + 210 + ] + }, + { + "teal": 38, + "source": "tests/contracts/math.algo.ts:7", + "pc": [ + 211 + ] + }, + { + "teal": 41, + "source": "tests/contracts/math.algo.ts:7", + "pc": [ + 212, + 213, + 214 + ] + }, + { + "teal": 42, + "source": "tests/contracts/math.algo.ts:7", + "pc": [ + 215 + ] + }, + { + "teal": 43, + "source": "tests/contracts/math.algo.ts:7", + "pc": [ + 216 + ] + }, + { + "teal": 44, + "source": "tests/contracts/math.algo.ts:7", + "pc": [ + 217 + ] + }, + { + "teal": 45, + "source": "tests/contracts/math.algo.ts:7", + "pc": [ + 218, + 219 + ] + }, + { + "teal": 46, + "source": "tests/contracts/math.algo.ts:7", + "pc": [ + 220 + ] + }, + { + "teal": 50, + "source": "tests/contracts/math.algo.ts:7", + "pc": [ + 221, + 222, + 223 + ] + }, + { + "teal": 54, + "source": "tests/contracts/math.algo.ts:8", + "pc": [ + 224, + 225 + ] + }, + { + "teal": 55, + "source": "tests/contracts/math.algo.ts:8", + "pc": [ + 226, + 227 + ] + }, + { + "teal": 56, + "source": "tests/contracts/math.algo.ts:8", + "pc": [ + 228 + ] + }, + { + "teal": 57, + "source": "tests/contracts/math.algo.ts:7", + "pc": [ + 229 + ] + }, + { + "teal": 62, + "source": "tests/contracts/math.algo.ts:11", + "pc": [ + 230, + 231, + 232, + 233, + 234, + 235 + ] + }, + { + "teal": 65, + "source": "tests/contracts/math.algo.ts:11", + "pc": [ + 236, + 237, + 238 + ] + }, + { + "teal": 66, + "source": "tests/contracts/math.algo.ts:11", + "pc": [ + 239 + ] + }, + { + "teal": 69, + "source": "tests/contracts/math.algo.ts:11", + "pc": [ + 240, + 241, + 242 + ] + }, + { + "teal": 70, + "source": "tests/contracts/math.algo.ts:11", + "pc": [ + 243 + ] + }, + { + "teal": 73, + "source": "tests/contracts/math.algo.ts:11", + "pc": [ + 244, + 245, + 246 + ] + }, + { + "teal": 74, + "source": "tests/contracts/math.algo.ts:11", + "pc": [ + 247 + ] + }, + { + "teal": 75, + "source": "tests/contracts/math.algo.ts:11", + "pc": [ + 248 + ] + }, + { + "teal": 76, + "source": "tests/contracts/math.algo.ts:11", + "pc": [ + 249 + ] + }, + { + "teal": 77, + "source": "tests/contracts/math.algo.ts:11", + "pc": [ + 250, + 251 + ] + }, + { + "teal": 78, + "source": "tests/contracts/math.algo.ts:11", + "pc": [ + 252 + ] + }, + { + "teal": 82, + "source": "tests/contracts/math.algo.ts:11", + "pc": [ + 253, + 254, + 255 + ] + }, + { + "teal": 86, + "source": "tests/contracts/math.algo.ts:12", + "pc": [ + 256, + 257 + ] + }, + { + "teal": 87, + "source": "tests/contracts/math.algo.ts:12", + "pc": [ + 258, + 259 + ] + }, + { + "teal": 88, + "source": "tests/contracts/math.algo.ts:12", + "pc": [ + 260 + ] + }, + { + "teal": 89, + "source": "tests/contracts/math.algo.ts:11", + "pc": [ + 261 + ] + }, + { + "teal": 94, + "source": "tests/contracts/math.algo.ts:15", + "pc": [ + 262, + 263, + 264, + 265, + 266, + 267 + ] + }, + { + "teal": 97, + "source": "tests/contracts/math.algo.ts:15", + "pc": [ + 268, + 269, + 270 + ] + }, + { + "teal": 98, + "source": "tests/contracts/math.algo.ts:15", + "pc": [ + 271 + ] + }, + { + "teal": 101, + "source": "tests/contracts/math.algo.ts:15", + "pc": [ + 272, + 273, + 274 + ] + }, + { + "teal": 102, + "source": "tests/contracts/math.algo.ts:15", + "pc": [ + 275 + ] + }, + { + "teal": 105, + "source": "tests/contracts/math.algo.ts:15", + "pc": [ + 276, + 277, + 278 + ] + }, + { + "teal": 106, + "source": "tests/contracts/math.algo.ts:15", + "pc": [ + 279 + ] + }, + { + "teal": 107, + "source": "tests/contracts/math.algo.ts:15", + "pc": [ + 280 + ] + }, + { + "teal": 108, + "source": "tests/contracts/math.algo.ts:15", + "pc": [ + 281 + ] + }, + { + "teal": 109, + "source": "tests/contracts/math.algo.ts:15", + "pc": [ + 282, + 283 + ] + }, + { + "teal": 110, + "source": "tests/contracts/math.algo.ts:15", + "pc": [ + 284 + ] + }, + { + "teal": 114, + "source": "tests/contracts/math.algo.ts:15", + "pc": [ + 285, + 286, + 287 + ] + }, + { + "teal": 118, + "source": "tests/contracts/math.algo.ts:16", + "pc": [ + 288, + 289 + ] + }, + { + "teal": 119, + "source": "tests/contracts/math.algo.ts:16", + "pc": [ + 290, + 291 + ] + }, + { + "teal": 120, + "source": "tests/contracts/math.algo.ts:16", + "pc": [ + 292 + ] + }, + { + "teal": 121, + "source": "tests/contracts/math.algo.ts:15", + "pc": [ + 293 + ] + }, + { + "teal": 126, + "source": "tests/contracts/math.algo.ts:19", + "pc": [ + 294, + 295, + 296, + 297, + 298, + 299 + ] + }, + { + "teal": 129, + "source": "tests/contracts/math.algo.ts:19", + "pc": [ + 300, + 301, + 302 + ] + }, + { + "teal": 130, + "source": "tests/contracts/math.algo.ts:19", + "pc": [ + 303 + ] + }, + { + "teal": 133, + "source": "tests/contracts/math.algo.ts:19", + "pc": [ + 304, + 305, + 306 + ] + }, + { + "teal": 134, + "source": "tests/contracts/math.algo.ts:19", + "pc": [ + 307 + ] + }, + { + "teal": 137, + "source": "tests/contracts/math.algo.ts:19", + "pc": [ + 308, + 309, + 310 + ] + }, + { + "teal": 138, + "source": "tests/contracts/math.algo.ts:19", + "pc": [ + 311 + ] + }, + { + "teal": 139, + "source": "tests/contracts/math.algo.ts:19", + "pc": [ + 312 + ] + }, + { + "teal": 140, + "source": "tests/contracts/math.algo.ts:19", + "pc": [ + 313 + ] + }, + { + "teal": 141, + "source": "tests/contracts/math.algo.ts:19", + "pc": [ + 314, + 315 + ] + }, + { + "teal": 142, + "source": "tests/contracts/math.algo.ts:19", + "pc": [ + 316 + ] + }, + { + "teal": 146, + "source": "tests/contracts/math.algo.ts:19", + "pc": [ + 317, + 318, + 319 + ] + }, + { + "teal": 150, + "source": "tests/contracts/math.algo.ts:20", + "pc": [ + 320, + 321 + ] + }, + { + "teal": 151, + "source": "tests/contracts/math.algo.ts:20", + "pc": [ + 322, + 323 + ] + }, + { + "teal": 152, + "source": "tests/contracts/math.algo.ts:20", + "pc": [ + 324 + ] + }, + { + "teal": 153, + "source": "tests/contracts/math.algo.ts:19", + "pc": [ + 325 + ] + }, + { + "teal": 158, + "source": "tests/contracts/math.algo.ts:23", + "pc": [ + 326, + 327, + 328, + 329, + 330, + 331 + ] + }, + { + "teal": 161, + "source": "tests/contracts/math.algo.ts:23", + "pc": [ + 332, + 333, + 334 + ] + }, + { + "teal": 162, + "source": "tests/contracts/math.algo.ts:23", + "pc": [ + 335 + ] + }, + { + "teal": 163, + "source": "tests/contracts/math.algo.ts:23", + "pc": [ + 336 + ] + }, + { + "teal": 164, + "source": "tests/contracts/math.algo.ts:23", + "pc": [ + 337, + 338 + ] + }, + { + "teal": 165, + "source": "tests/contracts/math.algo.ts:23", + "pc": [ + 339 + ] + }, + { + "teal": 168, + "source": "tests/contracts/math.algo.ts:23", + "errorMessage": "argument 0 (b) for u256plus must be a uint256", + "pc": [ + 340 + ] + }, + { + "teal": 171, + "source": "tests/contracts/math.algo.ts:23", + "pc": [ + 341, + 342, + 343 + ] + }, + { + "teal": 172, + "source": "tests/contracts/math.algo.ts:23", + "pc": [ + 344 + ] + }, + { + "teal": 173, + "source": "tests/contracts/math.algo.ts:23", + "pc": [ + 345 + ] + }, + { + "teal": 174, + "source": "tests/contracts/math.algo.ts:23", + "pc": [ + 346, + 347 + ] + }, + { + "teal": 175, + "source": "tests/contracts/math.algo.ts:23", + "pc": [ + 348 + ] + }, + { + "teal": 178, + "source": "tests/contracts/math.algo.ts:23", + "errorMessage": "argument 1 (a) for u256plus must be a uint256", + "pc": [ + 349 + ] + }, + { + "teal": 181, + "source": "tests/contracts/math.algo.ts:23", + "pc": [ + 350, + 351, + 352 + ] + }, + { + "teal": 182, + "source": "tests/contracts/math.algo.ts:23", + "pc": [ + 353 + ] + }, + { + "teal": 183, + "source": "tests/contracts/math.algo.ts:23", + "pc": [ + 354 + ] + }, + { + "teal": 184, + "source": "tests/contracts/math.algo.ts:23", + "pc": [ + 355, + 356, + 357 + ] + }, + { + "teal": 185, + "source": "tests/contracts/math.algo.ts:23", + "pc": [ + 358 + ] + }, + { + "teal": 188, + "source": "tests/contracts/math.algo.ts:23", + "errorMessage": "u256plus return value overflowed 256 bits", + "pc": [ + 359 + ] + }, + { + "teal": 189, + "source": "tests/contracts/math.algo.ts:23", + "pc": [ + 360, + 361, + 362, + 363, + 364, + 365, + 366, + 367, + 368, + 369, + 370, + 371, + 372, + 373, + 374, + 375, + 376, + 377, + 378, + 379, + 380, + 381, + 382, + 383, + 384, + 385, + 386, + 387, + 388, + 389, + 390, + 391, + 392, + 393 + ] + }, + { + "teal": 190, + "source": "tests/contracts/math.algo.ts:23", + "pc": [ + 394 + ] + }, + { + "teal": 191, + "source": "tests/contracts/math.algo.ts:23", + "pc": [ + 395 + ] + }, + { + "teal": 192, + "source": "tests/contracts/math.algo.ts:23", + "pc": [ + 396 + ] + }, + { + "teal": 193, + "source": "tests/contracts/math.algo.ts:23", + "pc": [ + 397 + ] + }, + { + "teal": 194, + "source": "tests/contracts/math.algo.ts:23", + "pc": [ + 398, + 399 + ] + }, + { + "teal": 195, + "source": "tests/contracts/math.algo.ts:23", + "pc": [ + 400 + ] + }, + { + "teal": 196, + "source": "tests/contracts/math.algo.ts:23", + "pc": [ + 401 + ] + }, + { + "teal": 197, + "source": "tests/contracts/math.algo.ts:23", + "pc": [ + 402 + ] + }, + { + "teal": 198, + "source": "tests/contracts/math.algo.ts:23", + "pc": [ + 403 + ] + }, + { + "teal": 199, + "source": "tests/contracts/math.algo.ts:23", + "pc": [ + 404 + ] + }, + { + "teal": 200, + "source": "tests/contracts/math.algo.ts:23", + "pc": [ + 405, + 406 + ] + }, + { + "teal": 201, + "source": "tests/contracts/math.algo.ts:23", + "pc": [ + 407 + ] + }, + { + "teal": 205, + "source": "tests/contracts/math.algo.ts:23", + "pc": [ + 408, + 409, + 410 + ] + }, + { + "teal": 209, + "source": "tests/contracts/math.algo.ts:24", + "pc": [ + 411, + 412 + ] + }, + { + "teal": 210, + "source": "tests/contracts/math.algo.ts:24", + "pc": [ + 413, + 414 + ] + }, + { + "teal": 211, + "source": "tests/contracts/math.algo.ts:24", + "pc": [ + 415 + ] + }, + { + "teal": 212, + "source": "tests/contracts/math.algo.ts:23", + "pc": [ + 416 + ] + }, + { + "teal": 217, + "source": "tests/contracts/math.algo.ts:27", + "pc": [ + 417, + 418, + 419, + 420, + 421, + 422 + ] + }, + { + "teal": 220, + "source": "tests/contracts/math.algo.ts:27", + "pc": [ + 423, + 424, + 425 + ] + }, + { + "teal": 221, + "source": "tests/contracts/math.algo.ts:27", + "pc": [ + 426 + ] + }, + { + "teal": 222, + "source": "tests/contracts/math.algo.ts:27", + "pc": [ + 427 + ] + }, + { + "teal": 223, + "source": "tests/contracts/math.algo.ts:27", + "pc": [ + 428, + 429 + ] + }, + { + "teal": 224, + "source": "tests/contracts/math.algo.ts:27", + "pc": [ + 430 + ] + }, + { + "teal": 227, + "source": "tests/contracts/math.algo.ts:27", + "errorMessage": "argument 0 (b) for u256minus must be a uint256", + "pc": [ + 431 + ] + }, + { + "teal": 230, + "source": "tests/contracts/math.algo.ts:27", + "pc": [ + 432, + 433, + 434 + ] + }, + { + "teal": 231, + "source": "tests/contracts/math.algo.ts:27", + "pc": [ + 435 + ] + }, + { + "teal": 232, + "source": "tests/contracts/math.algo.ts:27", + "pc": [ + 436 + ] + }, + { + "teal": 233, + "source": "tests/contracts/math.algo.ts:27", + "pc": [ + 437, + 438 + ] + }, + { + "teal": 234, + "source": "tests/contracts/math.algo.ts:27", + "pc": [ + 439 + ] + }, + { + "teal": 237, + "source": "tests/contracts/math.algo.ts:27", + "errorMessage": "argument 1 (a) for u256minus must be a uint256", + "pc": [ + 440 + ] + }, + { + "teal": 240, + "source": "tests/contracts/math.algo.ts:27", + "pc": [ + 441, + 442, + 443 + ] + }, + { + "teal": 241, + "source": "tests/contracts/math.algo.ts:27", + "pc": [ + 444 + ] + }, + { + "teal": 242, + "source": "tests/contracts/math.algo.ts:27", + "pc": [ + 445 + ] + }, + { + "teal": 243, + "source": "tests/contracts/math.algo.ts:27", + "pc": [ + 446, + 447, + 448 + ] + }, + { + "teal": 244, + "source": "tests/contracts/math.algo.ts:27", + "pc": [ + 449 + ] + }, + { + "teal": 247, + "source": "tests/contracts/math.algo.ts:27", + "errorMessage": "u256minus return value overflowed 256 bits", + "pc": [ + 450 + ] + }, + { + "teal": 248, + "source": "tests/contracts/math.algo.ts:27", + "pc": [ + 451, + 452, + 453, + 454, + 455, + 456, + 457, + 458, + 459, + 460, + 461, + 462, + 463, + 464, + 465, + 466, + 467, + 468, + 469, + 470, + 471, + 472, + 473, + 474, + 475, + 476, + 477, + 478, + 479, + 480, + 481, + 482, + 483, + 484 + ] + }, + { + "teal": 249, + "source": "tests/contracts/math.algo.ts:27", + "pc": [ + 485 + ] + }, + { + "teal": 250, + "source": "tests/contracts/math.algo.ts:27", + "pc": [ + 486 + ] + }, + { + "teal": 251, + "source": "tests/contracts/math.algo.ts:27", + "pc": [ + 487 + ] + }, + { + "teal": 252, + "source": "tests/contracts/math.algo.ts:27", + "pc": [ + 488 + ] + }, + { + "teal": 253, + "source": "tests/contracts/math.algo.ts:27", + "pc": [ + 489, + 490 + ] + }, + { + "teal": 254, + "source": "tests/contracts/math.algo.ts:27", + "pc": [ + 491 + ] + }, + { + "teal": 255, + "source": "tests/contracts/math.algo.ts:27", + "pc": [ + 492 + ] + }, + { + "teal": 256, + "source": "tests/contracts/math.algo.ts:27", + "pc": [ + 493 + ] + }, + { + "teal": 257, + "source": "tests/contracts/math.algo.ts:27", + "pc": [ + 494 + ] + }, + { + "teal": 258, + "source": "tests/contracts/math.algo.ts:27", + "pc": [ + 495 + ] + }, + { + "teal": 259, + "source": "tests/contracts/math.algo.ts:27", + "pc": [ + 496, + 497 + ] + }, + { + "teal": 260, + "source": "tests/contracts/math.algo.ts:27", + "pc": [ + 498 + ] + }, + { + "teal": 264, + "source": "tests/contracts/math.algo.ts:27", + "pc": [ + 499, + 500, + 501 + ] + }, + { + "teal": 268, + "source": "tests/contracts/math.algo.ts:28", + "pc": [ + 502, + 503 + ] + }, + { + "teal": 269, + "source": "tests/contracts/math.algo.ts:28", + "pc": [ + 504, + 505 + ] + }, + { + "teal": 270, + "source": "tests/contracts/math.algo.ts:28", + "pc": [ + 506 + ] + }, + { + "teal": 271, + "source": "tests/contracts/math.algo.ts:27", + "pc": [ + 507 + ] + }, + { + "teal": 276, + "source": "tests/contracts/math.algo.ts:31", + "pc": [ + 508, + 509, + 510, + 511, + 512, + 513 + ] + }, + { + "teal": 279, + "source": "tests/contracts/math.algo.ts:31", + "pc": [ + 514, + 515, + 516 + ] + }, + { + "teal": 280, + "source": "tests/contracts/math.algo.ts:31", + "pc": [ + 517 + ] + }, + { + "teal": 281, + "source": "tests/contracts/math.algo.ts:31", + "pc": [ + 518 + ] + }, + { + "teal": 282, + "source": "tests/contracts/math.algo.ts:31", + "pc": [ + 519, + 520 + ] + }, + { + "teal": 283, + "source": "tests/contracts/math.algo.ts:31", + "pc": [ + 521 + ] + }, + { + "teal": 286, + "source": "tests/contracts/math.algo.ts:31", + "errorMessage": "argument 0 (b) for u256mul must be a uint256", + "pc": [ + 522 + ] + }, + { + "teal": 289, + "source": "tests/contracts/math.algo.ts:31", + "pc": [ + 523, + 524, + 525 + ] + }, + { + "teal": 290, + "source": "tests/contracts/math.algo.ts:31", + "pc": [ + 526 + ] + }, + { + "teal": 291, + "source": "tests/contracts/math.algo.ts:31", + "pc": [ + 527 + ] + }, + { + "teal": 292, + "source": "tests/contracts/math.algo.ts:31", + "pc": [ + 528, + 529 + ] + }, + { + "teal": 293, + "source": "tests/contracts/math.algo.ts:31", + "pc": [ + 530 + ] + }, + { + "teal": 296, + "source": "tests/contracts/math.algo.ts:31", + "errorMessage": "argument 1 (a) for u256mul must be a uint256", + "pc": [ + 531 + ] + }, + { + "teal": 299, + "source": "tests/contracts/math.algo.ts:31", + "pc": [ + 532, + 533, + 534 + ] + }, + { + "teal": 300, + "source": "tests/contracts/math.algo.ts:31", + "pc": [ + 535 + ] + }, + { + "teal": 301, + "source": "tests/contracts/math.algo.ts:31", + "pc": [ + 536 + ] + }, + { + "teal": 302, + "source": "tests/contracts/math.algo.ts:31", + "pc": [ + 537, + 538, + 539 + ] + }, + { + "teal": 303, + "source": "tests/contracts/math.algo.ts:31", + "pc": [ + 540 + ] + }, + { + "teal": 306, + "source": "tests/contracts/math.algo.ts:31", + "errorMessage": "u256mul return value overflowed 256 bits", + "pc": [ + 541 + ] + }, + { + "teal": 307, + "source": "tests/contracts/math.algo.ts:31", + "pc": [ + 542, + 543, + 544, + 545, + 546, + 547, + 548, + 549, + 550, + 551, + 552, + 553, + 554, + 555, + 556, + 557, + 558, + 559, + 560, + 561, + 562, + 563, + 564, + 565, + 566, + 567, + 568, + 569, + 570, + 571, + 572, + 573, + 574, + 575 + ] + }, + { + "teal": 308, + "source": "tests/contracts/math.algo.ts:31", + "pc": [ + 576 + ] + }, + { + "teal": 309, + "source": "tests/contracts/math.algo.ts:31", + "pc": [ + 577 + ] + }, + { + "teal": 310, + "source": "tests/contracts/math.algo.ts:31", + "pc": [ + 578 + ] + }, + { + "teal": 311, + "source": "tests/contracts/math.algo.ts:31", + "pc": [ + 579 + ] + }, + { + "teal": 312, + "source": "tests/contracts/math.algo.ts:31", + "pc": [ + 580, + 581 + ] + }, + { + "teal": 313, + "source": "tests/contracts/math.algo.ts:31", + "pc": [ + 582 + ] + }, + { + "teal": 314, + "source": "tests/contracts/math.algo.ts:31", + "pc": [ + 583 + ] + }, + { + "teal": 315, + "source": "tests/contracts/math.algo.ts:31", + "pc": [ + 584 + ] + }, + { + "teal": 316, + "source": "tests/contracts/math.algo.ts:31", + "pc": [ + 585 + ] + }, + { + "teal": 317, + "source": "tests/contracts/math.algo.ts:31", + "pc": [ + 586 + ] + }, + { + "teal": 318, + "source": "tests/contracts/math.algo.ts:31", + "pc": [ + 587, + 588 + ] + }, + { + "teal": 319, + "source": "tests/contracts/math.algo.ts:31", + "pc": [ + 589 + ] + }, + { + "teal": 323, + "source": "tests/contracts/math.algo.ts:31", + "pc": [ + 590, + 591, + 592 + ] + }, + { + "teal": 327, + "source": "tests/contracts/math.algo.ts:32", + "pc": [ + 593, + 594 + ] + }, + { + "teal": 328, + "source": "tests/contracts/math.algo.ts:32", + "pc": [ + 595, + 596 + ] + }, + { + "teal": 329, + "source": "tests/contracts/math.algo.ts:32", + "pc": [ + 597 + ] + }, + { + "teal": 330, + "source": "tests/contracts/math.algo.ts:31", + "pc": [ + 598 + ] + }, + { + "teal": 335, + "source": "tests/contracts/math.algo.ts:35", + "pc": [ + 599, + 600, + 601, + 602, + 603, + 604 + ] + }, + { + "teal": 338, + "source": "tests/contracts/math.algo.ts:35", + "pc": [ + 605, + 606, + 607 + ] + }, + { + "teal": 339, + "source": "tests/contracts/math.algo.ts:35", + "pc": [ + 608 + ] + }, + { + "teal": 340, + "source": "tests/contracts/math.algo.ts:35", + "pc": [ + 609 + ] + }, + { + "teal": 341, + "source": "tests/contracts/math.algo.ts:35", + "pc": [ + 610, + 611 + ] + }, + { + "teal": 342, + "source": "tests/contracts/math.algo.ts:35", + "pc": [ + 612 + ] + }, + { + "teal": 345, + "source": "tests/contracts/math.algo.ts:35", + "errorMessage": "argument 0 (b) for u256div must be a uint256", + "pc": [ + 613 + ] + }, + { + "teal": 348, + "source": "tests/contracts/math.algo.ts:35", + "pc": [ + 614, + 615, + 616 + ] + }, + { + "teal": 349, + "source": "tests/contracts/math.algo.ts:35", + "pc": [ + 617 + ] + }, + { + "teal": 350, + "source": "tests/contracts/math.algo.ts:35", + "pc": [ + 618 + ] + }, + { + "teal": 351, + "source": "tests/contracts/math.algo.ts:35", + "pc": [ + 619, + 620 + ] + }, + { + "teal": 352, + "source": "tests/contracts/math.algo.ts:35", + "pc": [ + 621 + ] + }, + { + "teal": 355, + "source": "tests/contracts/math.algo.ts:35", + "errorMessage": "argument 1 (a) for u256div must be a uint256", + "pc": [ + 622 + ] + }, + { + "teal": 358, + "source": "tests/contracts/math.algo.ts:35", + "pc": [ + 623, + 624, + 625 + ] + }, + { + "teal": 359, + "source": "tests/contracts/math.algo.ts:35", + "pc": [ + 626 + ] + }, + { + "teal": 360, + "source": "tests/contracts/math.algo.ts:35", + "pc": [ + 627 + ] + }, + { + "teal": 361, + "source": "tests/contracts/math.algo.ts:35", + "pc": [ + 628, + 629, + 630 + ] + }, + { + "teal": 362, + "source": "tests/contracts/math.algo.ts:35", + "pc": [ + 631 + ] + }, + { + "teal": 365, + "source": "tests/contracts/math.algo.ts:35", + "errorMessage": "u256div return value overflowed 256 bits", + "pc": [ + 632 + ] + }, + { + "teal": 366, + "source": "tests/contracts/math.algo.ts:35", + "pc": [ + 633, + 634, + 635, + 636, + 637, + 638, + 639, + 640, + 641, + 642, + 643, + 644, + 645, + 646, + 647, + 648, + 649, + 650, + 651, + 652, + 653, + 654, + 655, + 656, + 657, + 658, + 659, + 660, + 661, + 662, + 663, + 664, + 665, + 666 + ] + }, + { + "teal": 367, + "source": "tests/contracts/math.algo.ts:35", + "pc": [ + 667 + ] + }, + { + "teal": 368, + "source": "tests/contracts/math.algo.ts:35", + "pc": [ + 668 + ] + }, + { + "teal": 369, + "source": "tests/contracts/math.algo.ts:35", + "pc": [ + 669 + ] + }, + { + "teal": 370, + "source": "tests/contracts/math.algo.ts:35", + "pc": [ + 670 + ] + }, + { + "teal": 371, + "source": "tests/contracts/math.algo.ts:35", + "pc": [ + 671, + 672 + ] + }, + { + "teal": 372, + "source": "tests/contracts/math.algo.ts:35", + "pc": [ + 673 + ] + }, + { + "teal": 373, + "source": "tests/contracts/math.algo.ts:35", + "pc": [ + 674 + ] + }, + { + "teal": 374, + "source": "tests/contracts/math.algo.ts:35", + "pc": [ + 675 + ] + }, + { + "teal": 375, + "source": "tests/contracts/math.algo.ts:35", + "pc": [ + 676 + ] + }, + { + "teal": 376, + "source": "tests/contracts/math.algo.ts:35", + "pc": [ + 677 + ] + }, + { + "teal": 377, + "source": "tests/contracts/math.algo.ts:35", + "pc": [ + 678, + 679 + ] + }, + { + "teal": 378, + "source": "tests/contracts/math.algo.ts:35", + "pc": [ + 680 + ] + }, + { + "teal": 382, + "source": "tests/contracts/math.algo.ts:35", + "pc": [ + 681, + 682, + 683 + ] + }, + { + "teal": 386, + "source": "tests/contracts/math.algo.ts:36", + "pc": [ + 684, + 685 + ] + }, + { + "teal": 387, + "source": "tests/contracts/math.algo.ts:36", + "pc": [ + 686, + 687 + ] + }, + { + "teal": 388, + "source": "tests/contracts/math.algo.ts:36", + "pc": [ + 688 + ] + }, + { + "teal": 389, + "source": "tests/contracts/math.algo.ts:35", + "pc": [ + 689 + ] + }, + { + "teal": 394, + "source": "tests/contracts/math.algo.ts:39", + "pc": [ + 690, + 691, + 692, + 693, + 694, + 695 + ] + }, + { + "teal": 397, + "source": "tests/contracts/math.algo.ts:39", + "pc": [ + 696, + 697, + 698 + ] + }, + { + "teal": 398, + "source": "tests/contracts/math.algo.ts:39", + "pc": [ + 699 + ] + }, + { + "teal": 401, + "source": "tests/contracts/math.algo.ts:39", + "pc": [ + 700, + 701, + 702 + ] + }, + { + "teal": 402, + "source": "tests/contracts/math.algo.ts:39", + "pc": [ + 703 + ] + }, + { + "teal": 405, + "source": "tests/contracts/math.algo.ts:39", + "pc": [ + 704, + 705, + 706 + ] + }, + { + "teal": 406, + "source": "tests/contracts/math.algo.ts:39", + "pc": [ + 707 + ] + }, + { + "teal": 407, + "source": "tests/contracts/math.algo.ts:39", + "pc": [ + 708 + ] + }, + { + "teal": 408, + "source": "tests/contracts/math.algo.ts:39", + "pc": [ + 709, + 710, + 711 + ] + }, + { + "teal": 409, + "source": "tests/contracts/math.algo.ts:39", + "pc": [ + 712 + ] + }, + { + "teal": 412, + "source": "tests/contracts/math.algo.ts:39", + "errorMessage": "u64Return256 return value overflowed 256 bits", + "pc": [ + 713 + ] + }, + { + "teal": 413, + "source": "tests/contracts/math.algo.ts:39", + "pc": [ + 714, + 715, + 716, + 717, + 718, + 719, + 720, + 721, + 722, + 723, + 724, + 725, + 726, + 727, + 728, + 729, + 730, + 731, + 732, + 733, + 734, + 735, + 736, + 737, + 738, + 739, + 740, + 741, + 742, + 743, + 744, + 745, + 746, + 747 + ] + }, + { + "teal": 414, + "source": "tests/contracts/math.algo.ts:39", + "pc": [ + 748 + ] + }, + { + "teal": 415, + "source": "tests/contracts/math.algo.ts:39", + "pc": [ + 749 + ] + }, + { + "teal": 416, + "source": "tests/contracts/math.algo.ts:39", + "pc": [ + 750 + ] + }, + { + "teal": 417, + "source": "tests/contracts/math.algo.ts:39", + "pc": [ + 751 + ] + }, + { + "teal": 418, + "source": "tests/contracts/math.algo.ts:39", + "pc": [ + 752, + 753 + ] + }, + { + "teal": 419, + "source": "tests/contracts/math.algo.ts:39", + "pc": [ + 754 + ] + }, + { + "teal": 420, + "source": "tests/contracts/math.algo.ts:39", + "pc": [ + 755 + ] + }, + { + "teal": 421, + "source": "tests/contracts/math.algo.ts:39", + "pc": [ + 756 + ] + }, + { + "teal": 422, + "source": "tests/contracts/math.algo.ts:39", + "pc": [ + 757 + ] + }, + { + "teal": 423, + "source": "tests/contracts/math.algo.ts:39", + "pc": [ + 758 + ] + }, + { + "teal": 424, + "source": "tests/contracts/math.algo.ts:39", + "pc": [ + 759, + 760 + ] + }, + { + "teal": 425, + "source": "tests/contracts/math.algo.ts:39", + "pc": [ + 761 + ] + }, + { + "teal": 429, + "source": "tests/contracts/math.algo.ts:39", + "pc": [ + 762, + 763, + 764 + ] + }, + { + "teal": 433, + "source": "tests/contracts/math.algo.ts:40", + "pc": [ + 765, + 766 + ] + }, + { + "teal": 434, + "source": "tests/contracts/math.algo.ts:40", + "pc": [ + 767, + 768 + ] + }, + { + "teal": 435, + "source": "tests/contracts/math.algo.ts:40", + "pc": [ + 769 + ] + }, + { + "teal": 436, + "source": "tests/contracts/math.algo.ts:40", + "pc": [ + 770 + ] + }, + { + "teal": 437, + "source": "tests/contracts/math.algo.ts:39", + "pc": [ + 771 + ] + }, + { + "teal": 442, + "source": "tests/contracts/math.algo.ts:43", + "pc": [ + 772, + 773, + 774, + 775, + 776, + 777 + ] + }, + { + "teal": 445, + "source": "tests/contracts/math.algo.ts:43", + "pc": [ + 778, + 779, + 780 + ] + }, + { + "teal": 446, + "source": "tests/contracts/math.algo.ts:43", + "pc": [ + 781 + ] + }, + { + "teal": 447, + "source": "tests/contracts/math.algo.ts:43", + "pc": [ + 782 + ] + }, + { + "teal": 448, + "source": "tests/contracts/math.algo.ts:43", + "pc": [ + 783 + ] + }, + { + "teal": 449, + "source": "tests/contracts/math.algo.ts:43", + "pc": [ + 784, + 785 + ] + }, + { + "teal": 450, + "source": "tests/contracts/math.algo.ts:43", + "pc": [ + 786 + ] + }, + { + "teal": 454, + "source": "tests/contracts/math.algo.ts:43", + "pc": [ + 787, + 788, + 789 + ] + }, + { + "teal": 458, + "source": "tests/contracts/math.algo.ts:44", + "pc": [ + 790, + 791, + 792, + 793, + 794, + 795, + 796, + 797, + 798, + 799, + 800 + ] + }, + { + "teal": 459, + "source": "tests/contracts/math.algo.ts:43", + "pc": [ + 801 + ] + }, + { + "teal": 464, + "source": "tests/contracts/math.algo.ts:47", + "pc": [ + 802, + 803, + 804, + 805, + 806, + 807 + ] + }, + { + "teal": 467, + "source": "tests/contracts/math.algo.ts:47", + "pc": [ + 808, + 809, + 810 + ] + }, + { + "teal": 468, + "source": "tests/contracts/math.algo.ts:47", + "pc": [ + 811 + ] + }, + { + "teal": 471, + "source": "tests/contracts/math.algo.ts:47", + "pc": [ + 812, + 813, + 814 + ] + }, + { + "teal": 472, + "source": "tests/contracts/math.algo.ts:47", + "pc": [ + 815 + ] + }, + { + "teal": 475, + "source": "tests/contracts/math.algo.ts:47", + "pc": [ + 816, + 817, + 818 + ] + }, + { + "teal": 476, + "source": "tests/contracts/math.algo.ts:47", + "pc": [ + 819 + ] + }, + { + "teal": 477, + "source": "tests/contracts/math.algo.ts:47", + "pc": [ + 820 + ] + }, + { + "teal": 478, + "source": "tests/contracts/math.algo.ts:47", + "pc": [ + 821 + ] + }, + { + "teal": 479, + "source": "tests/contracts/math.algo.ts:47", + "pc": [ + 822, + 823 + ] + }, + { + "teal": 480, + "source": "tests/contracts/math.algo.ts:47", + "pc": [ + 824 + ] + }, + { + "teal": 484, + "source": "tests/contracts/math.algo.ts:47", + "pc": [ + 825, + 826, + 827 + ] + }, + { + "teal": 488, + "source": "tests/contracts/math.algo.ts:48", + "pc": [ + 828, + 829 + ] + }, + { + "teal": 489, + "source": "tests/contracts/math.algo.ts:48", + "pc": [ + 830, + 831 + ] + }, + { + "teal": 490, + "source": "tests/contracts/math.algo.ts:48", + "pc": [ + 832 + ] + }, + { + "teal": 491, + "source": "tests/contracts/math.algo.ts:47", + "pc": [ + 833 + ] + }, + { + "teal": 496, + "source": "tests/contracts/math.algo.ts:51", + "pc": [ + 834, + 835, + 836, + 837, + 838, + 839 + ] + }, + { + "teal": 499, + "source": "tests/contracts/math.algo.ts:51", + "pc": [ + 840, + 841, + 842 + ] + }, + { + "teal": 500, + "source": "tests/contracts/math.algo.ts:51", + "pc": [ + 843 + ] + }, + { + "teal": 501, + "source": "tests/contracts/math.algo.ts:51", + "pc": [ + 844 + ] + }, + { + "teal": 502, + "source": "tests/contracts/math.algo.ts:51", + "pc": [ + 845, + 846 + ] + }, + { + "teal": 503, + "source": "tests/contracts/math.algo.ts:51", + "pc": [ + 847 + ] + }, + { + "teal": 506, + "source": "tests/contracts/math.algo.ts:51", + "errorMessage": "argument 0 (y) for variableTypeHint must be a uint8", + "pc": [ + 848 + ] + }, + { + "teal": 507, + "source": "tests/contracts/math.algo.ts:51", + "pc": [ + 849 + ] + }, + { + "teal": 510, + "source": "tests/contracts/math.algo.ts:51", + "pc": [ + 850, + 851, + 852 + ] + }, + { + "teal": 511, + "source": "tests/contracts/math.algo.ts:51", + "pc": [ + 853 + ] + }, + { + "teal": 512, + "source": "tests/contracts/math.algo.ts:51", + "pc": [ + 854 + ] + }, + { + "teal": 513, + "source": "tests/contracts/math.algo.ts:51", + "pc": [ + 855, + 856 + ] + }, + { + "teal": 514, + "source": "tests/contracts/math.algo.ts:51", + "pc": [ + 857 + ] + }, + { + "teal": 517, + "source": "tests/contracts/math.algo.ts:51", + "errorMessage": "argument 1 (x) for variableTypeHint must be a uint8", + "pc": [ + 858 + ] + }, + { + "teal": 518, + "source": "tests/contracts/math.algo.ts:51", + "pc": [ + 859 + ] + }, + { + "teal": 521, + "source": "tests/contracts/math.algo.ts:51", + "pc": [ + 860, + 861, + 862 + ] + }, + { + "teal": 522, + "source": "tests/contracts/math.algo.ts:51", + "pc": [ + 863 + ] + }, + { + "teal": 523, + "source": "tests/contracts/math.algo.ts:51", + "pc": [ + 864 + ] + }, + { + "teal": 524, + "source": "tests/contracts/math.algo.ts:51", + "pc": [ + 865 + ] + }, + { + "teal": 525, + "source": "tests/contracts/math.algo.ts:51", + "pc": [ + 866, + 867 + ] + }, + { + "teal": 526, + "source": "tests/contracts/math.algo.ts:51", + "pc": [ + 868 + ] + }, + { + "teal": 529, + "source": "tests/contracts/math.algo.ts:51", + "errorMessage": "variableTypeHint return value overflowed 16 bits", + "pc": [ + 869 + ] + }, + { + "teal": 530, + "source": "tests/contracts/math.algo.ts:51", + "pc": [ + 870, + 871, + 872 + ] + }, + { + "teal": 531, + "source": "tests/contracts/math.algo.ts:51", + "pc": [ + 873 + ] + }, + { + "teal": 532, + "source": "tests/contracts/math.algo.ts:51", + "pc": [ + 874 + ] + }, + { + "teal": 533, + "source": "tests/contracts/math.algo.ts:51", + "pc": [ + 875, + 876 + ] + }, + { + "teal": 534, + "source": "tests/contracts/math.algo.ts:51", + "pc": [ + 877 + ] + }, + { + "teal": 538, + "source": "tests/contracts/math.algo.ts:51", + "pc": [ + 878, + 879, + 880 + ] + }, + { + "teal": 541, + "source": "tests/contracts/math.algo.ts:51", + "pc": [ + 881, + 882 + ] + }, + { + "teal": 545, + "source": "tests/contracts/math.algo.ts:52", + "pc": [ + 883, + 884 + ] + }, + { + "teal": 546, + "source": "tests/contracts/math.algo.ts:52", + "pc": [ + 885, + 886 + ] + }, + { + "teal": 547, + "source": "tests/contracts/math.algo.ts:52", + "pc": [ + 887 + ] + }, + { + "teal": 548, + "source": "tests/contracts/math.algo.ts:52", + "pc": [ + 888, + 889 + ] + }, + { + "teal": 552, + "source": "tests/contracts/math.algo.ts:54", + "pc": [ + 890, + 891 + ] + }, + { + "teal": 555, + "source": "tests/contracts/math.algo.ts:51", + "pc": [ + 892, + 893 + ] + }, + { + "teal": 556, + "source": "tests/contracts/math.algo.ts:51", + "pc": [ + 894 + ] + }, + { + "teal": 561, + "source": "tests/contracts/math.algo.ts:57", + "pc": [ + 895, + 896, + 897, + 898, + 899, + 900 + ] + }, + { + "teal": 564, + "source": "tests/contracts/math.algo.ts:57", + "pc": [ + 901, + 902, + 903 + ] + }, + { + "teal": 565, + "source": "tests/contracts/math.algo.ts:57", + "pc": [ + 904 + ] + }, + { + "teal": 566, + "source": "tests/contracts/math.algo.ts:57", + "pc": [ + 905 + ] + }, + { + "teal": 567, + "source": "tests/contracts/math.algo.ts:57", + "pc": [ + 906, + 907 + ] + }, + { + "teal": 568, + "source": "tests/contracts/math.algo.ts:57", + "pc": [ + 908 + ] + }, + { + "teal": 571, + "source": "tests/contracts/math.algo.ts:57", + "errorMessage": "argument 0 (b) for uint8plus must be a uint8", + "pc": [ + 909 + ] + }, + { + "teal": 572, + "source": "tests/contracts/math.algo.ts:57", + "pc": [ + 910 + ] + }, + { + "teal": 575, + "source": "tests/contracts/math.algo.ts:57", + "pc": [ + 911, + 912, + 913 + ] + }, + { + "teal": 576, + "source": "tests/contracts/math.algo.ts:57", + "pc": [ + 914 + ] + }, + { + "teal": 577, + "source": "tests/contracts/math.algo.ts:57", + "pc": [ + 915 + ] + }, + { + "teal": 578, + "source": "tests/contracts/math.algo.ts:57", + "pc": [ + 916, + 917 + ] + }, + { + "teal": 579, + "source": "tests/contracts/math.algo.ts:57", + "pc": [ + 918 + ] + }, + { + "teal": 582, + "source": "tests/contracts/math.algo.ts:57", + "errorMessage": "argument 1 (a) for uint8plus must be a uint8", + "pc": [ + 919 + ] + }, + { + "teal": 583, + "source": "tests/contracts/math.algo.ts:57", + "pc": [ + 920 + ] + }, + { + "teal": 586, + "source": "tests/contracts/math.algo.ts:57", + "pc": [ + 921, + 922, + 923 + ] + }, + { + "teal": 587, + "source": "tests/contracts/math.algo.ts:57", + "pc": [ + 924 + ] + }, + { + "teal": 588, + "source": "tests/contracts/math.algo.ts:57", + "pc": [ + 925 + ] + }, + { + "teal": 589, + "source": "tests/contracts/math.algo.ts:57", + "pc": [ + 926 + ] + }, + { + "teal": 590, + "source": "tests/contracts/math.algo.ts:57", + "pc": [ + 927, + 928 + ] + }, + { + "teal": 591, + "source": "tests/contracts/math.algo.ts:57", + "pc": [ + 929 + ] + }, + { + "teal": 594, + "source": "tests/contracts/math.algo.ts:57", + "errorMessage": "uint8plus return value overflowed 8 bits", + "pc": [ + 930 + ] + }, + { + "teal": 595, + "source": "tests/contracts/math.algo.ts:57", + "pc": [ + 931, + 932, + 933 + ] + }, + { + "teal": 596, + "source": "tests/contracts/math.algo.ts:57", + "pc": [ + 934 + ] + }, + { + "teal": 597, + "source": "tests/contracts/math.algo.ts:57", + "pc": [ + 935 + ] + }, + { + "teal": 598, + "source": "tests/contracts/math.algo.ts:57", + "pc": [ + 936, + 937 + ] + }, + { + "teal": 599, + "source": "tests/contracts/math.algo.ts:57", + "pc": [ + 938 + ] + }, + { + "teal": 603, + "source": "tests/contracts/math.algo.ts:57", + "pc": [ + 939, + 940, + 941 + ] + }, + { + "teal": 607, + "source": "tests/contracts/math.algo.ts:58", + "pc": [ + 942, + 943 + ] + }, + { + "teal": 608, + "source": "tests/contracts/math.algo.ts:58", + "pc": [ + 944, + 945 + ] + }, + { + "teal": 609, + "source": "tests/contracts/math.algo.ts:58", + "pc": [ + 946 + ] + }, + { + "teal": 610, + "source": "tests/contracts/math.algo.ts:57", + "pc": [ + 947 + ] + }, + { + "teal": 615, + "source": "tests/contracts/math.algo.ts:61", + "pc": [ + 948, + 949, + 950, + 951, + 952, + 953 + ] + }, + { + "teal": 618, + "source": "tests/contracts/math.algo.ts:61", + "pc": [ + 954, + 955, + 956 + ] + }, + { + "teal": 619, + "source": "tests/contracts/math.algo.ts:61", + "pc": [ + 957 + ] + }, + { + "teal": 620, + "source": "tests/contracts/math.algo.ts:61", + "pc": [ + 958 + ] + }, + { + "teal": 621, + "source": "tests/contracts/math.algo.ts:61", + "pc": [ + 959, + 960 + ] + }, + { + "teal": 622, + "source": "tests/contracts/math.algo.ts:61", + "pc": [ + 961 + ] + }, + { + "teal": 625, + "source": "tests/contracts/math.algo.ts:61", + "errorMessage": "argument 0 (b) for uint8exp must be a uint8", + "pc": [ + 962 + ] + }, + { + "teal": 626, + "source": "tests/contracts/math.algo.ts:61", + "pc": [ + 963 + ] + }, + { + "teal": 629, + "source": "tests/contracts/math.algo.ts:61", + "pc": [ + 964, + 965, + 966 + ] + }, + { + "teal": 630, + "source": "tests/contracts/math.algo.ts:61", + "pc": [ + 967 + ] + }, + { + "teal": 631, + "source": "tests/contracts/math.algo.ts:61", + "pc": [ + 968 + ] + }, + { + "teal": 632, + "source": "tests/contracts/math.algo.ts:61", + "pc": [ + 969, + 970 + ] + }, + { + "teal": 633, + "source": "tests/contracts/math.algo.ts:61", + "pc": [ + 971 + ] + }, + { + "teal": 636, + "source": "tests/contracts/math.algo.ts:61", + "errorMessage": "argument 1 (a) for uint8exp must be a uint8", + "pc": [ + 972 + ] + }, + { + "teal": 637, + "source": "tests/contracts/math.algo.ts:61", + "pc": [ + 973 + ] + }, + { + "teal": 640, + "source": "tests/contracts/math.algo.ts:61", + "pc": [ + 974, + 975, + 976 + ] + }, + { + "teal": 641, + "source": "tests/contracts/math.algo.ts:61", + "pc": [ + 977 + ] + }, + { + "teal": 642, + "source": "tests/contracts/math.algo.ts:61", + "pc": [ + 978 + ] + }, + { + "teal": 643, + "source": "tests/contracts/math.algo.ts:61", + "pc": [ + 979 + ] + }, + { + "teal": 644, + "source": "tests/contracts/math.algo.ts:61", + "pc": [ + 980, + 981 + ] + }, + { + "teal": 645, + "source": "tests/contracts/math.algo.ts:61", + "pc": [ + 982 + ] + }, + { + "teal": 648, + "source": "tests/contracts/math.algo.ts:61", + "errorMessage": "uint8exp return value overflowed 8 bits", + "pc": [ + 983 + ] + }, + { + "teal": 649, + "source": "tests/contracts/math.algo.ts:61", + "pc": [ + 984, + 985, + 986 + ] + }, + { + "teal": 650, + "source": "tests/contracts/math.algo.ts:61", + "pc": [ + 987 + ] + }, + { + "teal": 651, + "source": "tests/contracts/math.algo.ts:61", + "pc": [ + 988 + ] + }, + { + "teal": 652, + "source": "tests/contracts/math.algo.ts:61", + "pc": [ + 989, + 990 + ] + }, + { + "teal": 653, + "source": "tests/contracts/math.algo.ts:61", + "pc": [ + 991 + ] + }, + { + "teal": 657, + "source": "tests/contracts/math.algo.ts:61", + "pc": [ + 992, + 993, + 994 + ] + }, + { + "teal": 661, + "source": "tests/contracts/math.algo.ts:62", + "pc": [ + 995, + 996 + ] + }, + { + "teal": 662, + "source": "tests/contracts/math.algo.ts:62", + "pc": [ + 997, + 998 + ] + }, + { + "teal": 663, + "source": "tests/contracts/math.algo.ts:62", + "pc": [ + 999 + ] + }, + { + "teal": 664, + "source": "tests/contracts/math.algo.ts:61", + "pc": [ + 1000 + ] + }, + { + "teal": 669, + "source": "tests/contracts/math.algo.ts:65", + "pc": [ + 1001, + 1002, + 1003, + 1004, + 1005, + 1006 + ] + }, + { + "teal": 672, + "source": "tests/contracts/math.algo.ts:65", + "pc": [ + 1007, + 1008, + 1009 + ] + }, + { + "teal": 673, + "source": "tests/contracts/math.algo.ts:65", + "pc": [ + 1010 + ] + }, + { + "teal": 676, + "source": "tests/contracts/math.algo.ts:65", + "pc": [ + 1011, + 1012, + 1013 + ] + }, + { + "teal": 677, + "source": "tests/contracts/math.algo.ts:65", + "pc": [ + 1014 + ] + }, + { + "teal": 680, + "source": "tests/contracts/math.algo.ts:65", + "pc": [ + 1015, + 1016, + 1017 + ] + }, + { + "teal": 681, + "source": "tests/contracts/math.algo.ts:65", + "pc": [ + 1018 + ] + }, + { + "teal": 682, + "source": "tests/contracts/math.algo.ts:65", + "pc": [ + 1019 + ] + }, + { + "teal": 683, + "source": "tests/contracts/math.algo.ts:65", + "pc": [ + 1020 + ] + }, + { + "teal": 684, + "source": "tests/contracts/math.algo.ts:65", + "pc": [ + 1021, + 1022 + ] + }, + { + "teal": 685, + "source": "tests/contracts/math.algo.ts:65", + "pc": [ + 1023 + ] + }, + { + "teal": 689, + "source": "tests/contracts/math.algo.ts:65", + "pc": [ + 1024, + 1025, + 1026 + ] + }, + { + "teal": 692, + "source": "tests/contracts/math.algo.ts:65", + "pc": [ + 1027, + 1028 + ] + }, + { + "teal": 696, + "source": "tests/contracts/math.algo.ts:66", + "pc": [ + 1029, + 1030 + ] + }, + { + "teal": 697, + "source": "tests/contracts/math.algo.ts:66", + "pc": [ + 1031, + 1032 + ] + }, + { + "teal": 701, + "source": "tests/contracts/math.algo.ts:68", + "pc": [ + 1033, + 1034 + ] + }, + { + "teal": 702, + "source": "tests/contracts/math.algo.ts:68", + "pc": [ + 1035, + 1036 + ] + }, + { + "teal": 703, + "source": "tests/contracts/math.algo.ts:68", + "pc": [ + 1037 + ] + }, + { + "teal": 704, + "source": "tests/contracts/math.algo.ts:68", + "pc": [ + 1038, + 1039 + ] + }, + { + "teal": 708, + "source": "tests/contracts/math.algo.ts:70", + "pc": [ + 1040, + 1041 + ] + }, + { + "teal": 711, + "source": "tests/contracts/math.algo.ts:65", + "pc": [ + 1042, + 1043 + ] + }, + { + "teal": 712, + "source": "tests/contracts/math.algo.ts:65", + "pc": [ + 1044 + ] + }, + { + "teal": 717, + "source": "tests/contracts/math.algo.ts:73", + "pc": [ + 1045, + 1046, + 1047, + 1048, + 1049, + 1050 + ] + }, + { + "teal": 720, + "source": "tests/contracts/math.algo.ts:73", + "pc": [ + 1051, + 1052, + 1053 + ] + }, + { + "teal": 721, + "source": "tests/contracts/math.algo.ts:73", + "pc": [ + 1054 + ] + }, + { + "teal": 724, + "source": "tests/contracts/math.algo.ts:73", + "pc": [ + 1055, + 1056, + 1057 + ] + }, + { + "teal": 725, + "source": "tests/contracts/math.algo.ts:73", + "pc": [ + 1058 + ] + }, + { + "teal": 728, + "source": "tests/contracts/math.algo.ts:73", + "pc": [ + 1059, + 1060, + 1061 + ] + }, + { + "teal": 729, + "source": "tests/contracts/math.algo.ts:73", + "pc": [ + 1062 + ] + }, + { + "teal": 730, + "source": "tests/contracts/math.algo.ts:73", + "pc": [ + 1063 + ] + }, + { + "teal": 731, + "source": "tests/contracts/math.algo.ts:73", + "pc": [ + 1064 + ] + }, + { + "teal": 732, + "source": "tests/contracts/math.algo.ts:73", + "pc": [ + 1065, + 1066 + ] + }, + { + "teal": 733, + "source": "tests/contracts/math.algo.ts:73", + "pc": [ + 1067 + ] + }, + { + "teal": 737, + "source": "tests/contracts/math.algo.ts:73", + "pc": [ + 1068, + 1069, + 1070 + ] + }, + { + "teal": 741, + "source": "tests/contracts/math.algo.ts:74", + "pc": [ + 1071, + 1072, + 1073, + 1074, + 1075, + 1076 + ] + }, + { + "teal": 742, + "source": "tests/contracts/math.algo.ts:74", + "pc": [ + 1077, + 1078 + ] + }, + { + "teal": 743, + "source": "tests/contracts/math.algo.ts:74", + "pc": [ + 1079 + ] + }, + { + "teal": 747, + "source": "tests/contracts/math.algo.ts:76", + "pc": [ + 1080, + 1081, + 1082, + 1083, + 1084, + 1085 + ] + }, + { + "teal": 748, + "source": "tests/contracts/math.algo.ts:76", + "pc": [ + 1086 + ] + }, + { + "teal": 749, + "source": "tests/contracts/math.algo.ts:76", + "pc": [ + 1087, + 1088 + ] + }, + { + "teal": 750, + "source": "tests/contracts/math.algo.ts:76", + "pc": [ + 1089 + ] + }, + { + "teal": 751, + "source": "tests/contracts/math.algo.ts:76", + "pc": [ + 1090, + 1091, + 1092, + 1093, + 1094, + 1095 + ] + }, + { + "teal": 752, + "source": "tests/contracts/math.algo.ts:76", + "pc": [ + 1096 + ] + }, + { + "teal": 753, + "source": "tests/contracts/math.algo.ts:76", + "pc": [ + 1097 + ] + }, + { + "teal": 757, + "source": "tests/contracts/math.algo.ts:78", + "pc": [ + 1098, + 1099, + 1100, + 1101, + 1102, + 1103 + ] + }, + { + "teal": 758, + "source": "tests/contracts/math.algo.ts:78", + "pc": [ + 1104 + ] + }, + { + "teal": 759, + "source": "tests/contracts/math.algo.ts:73", + "pc": [ + 1105 + ] + }, + { + "teal": 764, + "source": "tests/contracts/math.algo.ts:83", + "pc": [ + 1106, + 1107, + 1108, + 1109, + 1110, + 1111 + ] + }, + { + "teal": 767, + "source": "tests/contracts/math.algo.ts:83", + "pc": [ + 1112, + 1113, + 1114 + ] + }, + { + "teal": 768, + "source": "tests/contracts/math.algo.ts:83", + "pc": [ + 1115 + ] + }, + { + "teal": 769, + "source": "tests/contracts/math.algo.ts:83", + "pc": [ + 1116 + ] + }, + { + "teal": 770, + "source": "tests/contracts/math.algo.ts:83", + "pc": [ + 1117, + 1118, + 1119 + ] + }, + { + "teal": 771, + "source": "tests/contracts/math.algo.ts:83", + "pc": [ + 1120 + ] + }, + { + "teal": 774, + "source": "tests/contracts/math.algo.ts:83", + "errorMessage": "boxTest return value overflowed 256 bits", + "pc": [ + 1121 + ] + }, + { + "teal": 775, + "source": "tests/contracts/math.algo.ts:83", + "pc": [ + 1122, + 1123, + 1124, + 1125, + 1126, + 1127, + 1128, + 1129, + 1130, + 1131, + 1132, + 1133, + 1134, + 1135, + 1136, + 1137, + 1138, + 1139, + 1140, + 1141, + 1142, + 1143, + 1144, + 1145, + 1146, + 1147, + 1148, + 1149, + 1150, + 1151, + 1152, + 1153, + 1154, + 1155 + ] + }, + { + "teal": 776, + "source": "tests/contracts/math.algo.ts:83", + "pc": [ + 1156 + ] + }, + { + "teal": 777, + "source": "tests/contracts/math.algo.ts:83", + "pc": [ + 1157 + ] + }, + { + "teal": 778, + "source": "tests/contracts/math.algo.ts:83", + "pc": [ + 1158 + ] + }, + { + "teal": 779, + "source": "tests/contracts/math.algo.ts:83", + "pc": [ + 1159 + ] + }, + { + "teal": 780, + "source": "tests/contracts/math.algo.ts:83", + "pc": [ + 1160, + 1161 + ] + }, + { + "teal": 781, + "source": "tests/contracts/math.algo.ts:83", + "pc": [ + 1162 + ] + }, + { + "teal": 782, + "source": "tests/contracts/math.algo.ts:83", + "pc": [ + 1163 + ] + }, + { + "teal": 783, + "source": "tests/contracts/math.algo.ts:83", + "pc": [ + 1164 + ] + }, + { + "teal": 784, + "source": "tests/contracts/math.algo.ts:83", + "pc": [ + 1165 + ] + }, + { + "teal": 785, + "source": "tests/contracts/math.algo.ts:83", + "pc": [ + 1166 + ] + }, + { + "teal": 786, + "source": "tests/contracts/math.algo.ts:83", + "pc": [ + 1167, + 1168 + ] + }, + { + "teal": 787, + "source": "tests/contracts/math.algo.ts:83", + "pc": [ + 1169 + ] + }, + { + "teal": 791, + "source": "tests/contracts/math.algo.ts:83", + "pc": [ + 1170, + 1171, + 1172 + ] + }, + { + "teal": 795, + "source": "tests/contracts/math.algo.ts:84", + "pc": [ + 1173, + 1174, + 1175, + 1176, + 1177, + 1178, + 1179, + 1180 + ] + }, + { + "teal": 796, + "source": "tests/contracts/math.algo.ts:84", + "pc": [ + 1181, + 1182, + 1183, + 1184, + 1185, + 1186, + 1187, + 1188, + 1189, + 1190, + 1191, + 1192, + 1193, + 1194, + 1195, + 1196, + 1197, + 1198, + 1199, + 1200, + 1201, + 1202, + 1203, + 1204, + 1205, + 1206, + 1207, + 1208, + 1209, + 1210, + 1211, + 1212, + 1213, + 1214 + ] + }, + { + "teal": 797, + "source": "tests/contracts/math.algo.ts:84", + "pc": [ + 1215 + ] + }, + { + "teal": 801, + "source": "tests/contracts/math.algo.ts:85", + "pc": [ + 1216, + 1217, + 1218, + 1219, + 1220, + 1221, + 1222, + 1223 + ] + }, + { + "teal": 802, + "source": "tests/contracts/math.algo.ts:85", + "pc": [ + 1224 + ] + }, + { + "teal": 805, + "source": "tests/contracts/math.algo.ts:85", + "errorMessage": "box value does not exist: this.boxKey.value", + "pc": [ + 1225 + ] + }, + { + "teal": 806, + "source": "tests/contracts/math.algo.ts:85", + "pc": [ + 1226, + 1227, + 1228, + 1229, + 1230, + 1231, + 1232, + 1233, + 1234, + 1235, + 1236, + 1237, + 1238, + 1239, + 1240, + 1241, + 1242, + 1243, + 1244, + 1245, + 1246, + 1247, + 1248, + 1249, + 1250, + 1251, + 1252, + 1253, + 1254, + 1255, + 1256, + 1257, + 1258, + 1259 + ] + }, + { + "teal": 807, + "source": "tests/contracts/math.algo.ts:85", + "pc": [ + 1260 + ] + }, + { + "teal": 808, + "source": "tests/contracts/math.algo.ts:85", + "pc": [ + 1261, + 1262, + 1263, + 1264, + 1265, + 1266, + 1267, + 1268 + ] + }, + { + "teal": 809, + "source": "tests/contracts/math.algo.ts:85", + "pc": [ + 1269 + ] + }, + { + "teal": 810, + "source": "tests/contracts/math.algo.ts:85", + "pc": [ + 1270 + ] + }, + { + "teal": 811, + "source": "tests/contracts/math.algo.ts:85", + "pc": [ + 1271, + 1272, + 1273 + ] + }, + { + "teal": 812, + "source": "tests/contracts/math.algo.ts:85", + "pc": [ + 1274 + ] + }, + { + "teal": 815, + "source": "tests/contracts/math.algo.ts:85", + "errorMessage": "this.boxKey.value overflowed 256 bits", + "pc": [ + 1275 + ] + }, + { + "teal": 816, + "source": "tests/contracts/math.algo.ts:85", + "pc": [ + 1276, + 1277, + 1278, + 1279, + 1280, + 1281, + 1282, + 1283, + 1284, + 1285, + 1286, + 1287, + 1288, + 1289, + 1290, + 1291, + 1292, + 1293, + 1294, + 1295, + 1296, + 1297, + 1298, + 1299, + 1300, + 1301, + 1302, + 1303, + 1304, + 1305, + 1306, + 1307, + 1308, + 1309 + ] + }, + { + "teal": 817, + "source": "tests/contracts/math.algo.ts:85", + "pc": [ + 1310 + ] + }, + { + "teal": 818, + "source": "tests/contracts/math.algo.ts:85", + "pc": [ + 1311 + ] + }, + { + "teal": 819, + "source": "tests/contracts/math.algo.ts:85", + "pc": [ + 1312 + ] + }, + { + "teal": 820, + "source": "tests/contracts/math.algo.ts:85", + "pc": [ + 1313 + ] + }, + { + "teal": 821, + "source": "tests/contracts/math.algo.ts:85", + "pc": [ + 1314, + 1315 + ] + }, + { + "teal": 822, + "source": "tests/contracts/math.algo.ts:85", + "pc": [ + 1316 + ] + }, + { + "teal": 823, + "source": "tests/contracts/math.algo.ts:85", + "pc": [ + 1317 + ] + }, + { + "teal": 824, + "source": "tests/contracts/math.algo.ts:85", + "pc": [ + 1318 + ] + }, + { + "teal": 825, + "source": "tests/contracts/math.algo.ts:85", + "pc": [ + 1319 + ] + }, + { + "teal": 826, + "source": "tests/contracts/math.algo.ts:85", + "pc": [ + 1320 + ] + }, + { + "teal": 830, + "source": "tests/contracts/math.algo.ts:87", + "pc": [ + 1321, + 1322, + 1323, + 1324, + 1325, + 1326, + 1327, + 1328 + ] + }, + { + "teal": 831, + "source": "tests/contracts/math.algo.ts:87", + "pc": [ + 1329 + ] + }, + { + "teal": 834, + "source": "tests/contracts/math.algo.ts:87", + "errorMessage": "box value does not exist: this.boxKey.value", + "pc": [ + 1330 + ] + }, + { + "teal": 835, + "source": "tests/contracts/math.algo.ts:83", + "pc": [ + 1331 + ] + }, + { + "teal": 839, + "source": "tests/contracts/math.algo.ts:90", + "pc": [ + 1332, + 1333, + 1334 + ] + }, + { + "teal": 843, + "source": "tests/contracts/math.algo.ts:91", + "pc": [ + 1335, + 1336 + ] + }, + { + "teal": 844, + "source": "tests/contracts/math.algo.ts:90", + "pc": [ + 1337 + ] + }, + { + "teal": 849, + "source": "tests/contracts/math.algo.ts:94", + "pc": [ + 1338, + 1339, + 1340, + 1341, + 1342, + 1343 + ] + }, + { + "teal": 852, + "source": "tests/contracts/math.algo.ts:94", + "pc": [ + 1344, + 1345, + 1346 + ] + }, + { + "teal": 853, + "source": "tests/contracts/math.algo.ts:94", + "pc": [ + 1347 + ] + }, + { + "teal": 854, + "source": "tests/contracts/math.algo.ts:94", + "pc": [ + 1348 + ] + }, + { + "teal": 855, + "source": "tests/contracts/math.algo.ts:94", + "pc": [ + 1349, + 1350 + ] + }, + { + "teal": 856, + "source": "tests/contracts/math.algo.ts:94", + "pc": [ + 1351 + ] + }, + { + "teal": 859, + "source": "tests/contracts/math.algo.ts:94", + "errorMessage": "argument 0 (b) for unsafeMethodArgs must be a uint256", + "pc": [ + 1352 + ] + }, + { + "teal": 862, + "source": "tests/contracts/math.algo.ts:94", + "pc": [ + 1353, + 1354, + 1355 + ] + }, + { + "teal": 863, + "source": "tests/contracts/math.algo.ts:94", + "pc": [ + 1356 + ] + }, + { + "teal": 864, + "source": "tests/contracts/math.algo.ts:94", + "pc": [ + 1357 + ] + }, + { + "teal": 865, + "source": "tests/contracts/math.algo.ts:94", + "pc": [ + 1358, + 1359 + ] + }, + { + "teal": 866, + "source": "tests/contracts/math.algo.ts:94", + "pc": [ + 1360 + ] + }, + { + "teal": 869, + "source": "tests/contracts/math.algo.ts:94", + "errorMessage": "argument 1 (a) for unsafeMethodArgs must be a uint256", + "pc": [ + 1361 + ] + }, + { + "teal": 872, + "source": "tests/contracts/math.algo.ts:94", + "pc": [ + 1362, + 1363, + 1364 + ] + }, + { + "teal": 873, + "source": "tests/contracts/math.algo.ts:94", + "pc": [ + 1365 + ] + }, + { + "teal": 874, + "source": "tests/contracts/math.algo.ts:94", + "pc": [ + 1366 + ] + }, + { + "teal": 875, + "source": "tests/contracts/math.algo.ts:94", + "pc": [ + 1367, + 1368, + 1369 + ] + }, + { + "teal": 876, + "source": "tests/contracts/math.algo.ts:94", + "pc": [ + 1370 + ] + }, + { + "teal": 879, + "source": "tests/contracts/math.algo.ts:94", + "errorMessage": "unsafeMethodArgs return value overflowed 256 bits", + "pc": [ + 1371 + ] + }, + { + "teal": 880, + "source": "tests/contracts/math.algo.ts:94", + "pc": [ + 1372, + 1373, + 1374, + 1375, + 1376, + 1377, + 1378, + 1379, + 1380, + 1381, + 1382, + 1383, + 1384, + 1385, + 1386, + 1387, + 1388, + 1389, + 1390, + 1391, + 1392, + 1393, + 1394, + 1395, + 1396, + 1397, + 1398, + 1399, + 1400, + 1401, + 1402, + 1403, + 1404, + 1405 + ] + }, + { + "teal": 881, + "source": "tests/contracts/math.algo.ts:94", + "pc": [ + 1406 + ] + }, + { + "teal": 882, + "source": "tests/contracts/math.algo.ts:94", + "pc": [ + 1407 + ] + }, + { + "teal": 883, + "source": "tests/contracts/math.algo.ts:94", + "pc": [ + 1408 + ] + }, + { + "teal": 884, + "source": "tests/contracts/math.algo.ts:94", + "pc": [ + 1409 + ] + }, + { + "teal": 885, + "source": "tests/contracts/math.algo.ts:94", + "pc": [ + 1410, + 1411 + ] + }, + { + "teal": 886, + "source": "tests/contracts/math.algo.ts:94", + "pc": [ + 1412 + ] + }, + { + "teal": 887, + "source": "tests/contracts/math.algo.ts:94", + "pc": [ + 1413 + ] + }, + { + "teal": 888, + "source": "tests/contracts/math.algo.ts:94", + "pc": [ + 1414 + ] + }, + { + "teal": 889, + "source": "tests/contracts/math.algo.ts:94", + "pc": [ + 1415 + ] + }, + { + "teal": 890, + "source": "tests/contracts/math.algo.ts:94", + "pc": [ + 1416 + ] + }, + { + "teal": 891, + "source": "tests/contracts/math.algo.ts:94", + "pc": [ + 1417, + 1418 + ] + }, + { + "teal": 892, + "source": "tests/contracts/math.algo.ts:94", + "pc": [ + 1419 + ] + }, + { + "teal": 896, + "source": "tests/contracts/math.algo.ts:94", + "pc": [ + 1420, + 1421, + 1422 + ] + }, + { + "teal": 899, + "source": "tests/contracts/math.algo.ts:94", + "pc": [ + 1423, + 1424 + ] + }, + { + "teal": 903, + "source": "tests/contracts/math.algo.ts:95", + "pc": [ + 1425, + 1426 + ] + }, + { + "teal": 904, + "source": "tests/contracts/math.algo.ts:95", + "pc": [ + 1427, + 1428 + ] + }, + { + "teal": 905, + "source": "tests/contracts/math.algo.ts:95", + "pc": [ + 1429 + ] + }, + { + "teal": 906, + "source": "tests/contracts/math.algo.ts:95", + "pc": [ + 1430, + 1431 + ] + }, + { + "teal": 910, + "source": "tests/contracts/math.algo.ts:97", + "pc": [ + 1432, + 1433 + ] + }, + { + "teal": 911, + "source": "tests/contracts/math.algo.ts:97", + "pc": [ + 1434 + ] + }, + { + "teal": 912, + "source": "tests/contracts/math.algo.ts:97", + "pc": [ + 1435 + ] + }, + { + "teal": 913, + "source": "tests/contracts/math.algo.ts:97", + "pc": [ + 1436, + 1437, + 1438 + ] + }, + { + "teal": 914, + "source": "tests/contracts/math.algo.ts:97", + "pc": [ + 1439 + ] + }, + { + "teal": 917, + "source": "tests/contracts/math.algo.ts:97", + "errorMessage": "c overflowed 256 bits", + "pc": [ + 1440 + ] + }, + { + "teal": 918, + "source": "tests/contracts/math.algo.ts:97", + "pc": [ + 1441, + 1442, + 1443, + 1444, + 1445, + 1446, + 1447, + 1448, + 1449, + 1450, + 1451, + 1452, + 1453, + 1454, + 1455, + 1456, + 1457, + 1458, + 1459, + 1460, + 1461, + 1462, + 1463, + 1464, + 1465, + 1466, + 1467, + 1468, + 1469, + 1470, + 1471, + 1472, + 1473, + 1474 + ] + }, + { + "teal": 919, + "source": "tests/contracts/math.algo.ts:97", + "pc": [ + 1475 + ] + }, + { + "teal": 920, + "source": "tests/contracts/math.algo.ts:97", + "pc": [ + 1476 + ] + }, + { + "teal": 921, + "source": "tests/contracts/math.algo.ts:97", + "pc": [ + 1477 + ] + }, + { + "teal": 922, + "source": "tests/contracts/math.algo.ts:97", + "pc": [ + 1478 + ] + }, + { + "teal": 923, + "source": "tests/contracts/math.algo.ts:97", + "pc": [ + 1479, + 1480 + ] + }, + { + "teal": 924, + "source": "tests/contracts/math.algo.ts:97", + "pc": [ + 1481 + ] + }, + { + "teal": 925, + "source": "tests/contracts/math.algo.ts:97", + "pc": [ + 1482 + ] + }, + { + "teal": 926, + "source": "tests/contracts/math.algo.ts:97", + "pc": [ + 1483 + ] + }, + { + "teal": 927, + "source": "tests/contracts/math.algo.ts:97", + "pc": [ + 1484, + 1485, + 1486 + ] + }, + { + "teal": 930, + "source": "tests/contracts/math.algo.ts:94", + "pc": [ + 1487, + 1488 + ] + }, + { + "teal": 931, + "source": "tests/contracts/math.algo.ts:94", + "pc": [ + 1489 + ] + }, + { + "teal": 936, + "source": "tests/contracts/math.algo.ts:100", + "pc": [ + 1490, + 1491, + 1492 + ] + }, + { + "teal": 937, + "source": "tests/contracts/math.algo.ts:100", + "pc": [ + 1493 + ] + }, + { + "teal": 938, + "source": "tests/contracts/math.algo.ts:100", + "pc": [ + 1494 + ] + }, + { + "teal": 939, + "source": "tests/contracts/math.algo.ts:100", + "pc": [ + 1495, + 1496 + ] + }, + { + "teal": 940, + "source": "tests/contracts/math.algo.ts:100", + "pc": [ + 1497 + ] + }, + { + "teal": 943, + "source": "tests/contracts/math.algo.ts:100", + "errorMessage": "argument 0 (b) for uint256ComparisonType must be a uint256", + "pc": [ + 1498 + ] + }, + { + "teal": 946, + "source": "tests/contracts/math.algo.ts:100", + "pc": [ + 1499, + 1500, + 1501 + ] + }, + { + "teal": 947, + "source": "tests/contracts/math.algo.ts:100", + "pc": [ + 1502 + ] + }, + { + "teal": 948, + "source": "tests/contracts/math.algo.ts:100", + "pc": [ + 1503 + ] + }, + { + "teal": 949, + "source": "tests/contracts/math.algo.ts:100", + "pc": [ + 1504, + 1505 + ] + }, + { + "teal": 950, + "source": "tests/contracts/math.algo.ts:100", + "pc": [ + 1506 + ] + }, + { + "teal": 953, + "source": "tests/contracts/math.algo.ts:100", + "errorMessage": "argument 1 (a) for uint256ComparisonType must be a uint256", + "pc": [ + 1507 + ] + }, + { + "teal": 956, + "source": "tests/contracts/math.algo.ts:100", + "pc": [ + 1508, + 1509, + 1510 + ] + }, + { + "teal": 957, + "source": "tests/contracts/math.algo.ts:100", + "pc": [ + 1511, + 1512 + ] + }, + { + "teal": 958, + "source": "tests/contracts/math.algo.ts:100", + "pc": [ + 1513 + ] + }, + { + "teal": 962, + "source": "tests/contracts/math.algo.ts:100", + "pc": [ + 1514, + 1515, + 1516 + ] + }, + { + "teal": 965, + "source": "tests/contracts/math.algo.ts:100", + "pc": [ + 1517, + 1518 + ] + }, + { + "teal": 969, + "source": "tests/contracts/math.algo.ts:101", + "pc": [ + 1519, + 1520 + ] + }, + { + "teal": 970, + "source": "tests/contracts/math.algo.ts:101", + "pc": [ + 1521, + 1522 + ] + }, + { + "teal": 971, + "source": "tests/contracts/math.algo.ts:101", + "pc": [ + 1523 + ] + }, + { + "teal": 972, + "source": "tests/contracts/math.algo.ts:101", + "pc": [ + 1524, + 1525 + ] + }, + { + "teal": 977, + "source": "tests/contracts/math.algo.ts:102", + "pc": [ + 1526, + 1527 + ] + }, + { + "teal": 978, + "source": "tests/contracts/math.algo.ts:102", + "pc": [ + 1528, + 1529, + 1530, + 1531, + 1532, + 1533, + 1534, + 1535, + 1536, + 1537, + 1538, + 1539, + 1540, + 1541, + 1542, + 1543, + 1544, + 1545, + 1546, + 1547, + 1548, + 1549, + 1550, + 1551, + 1552, + 1553, + 1554, + 1555, + 1556, + 1557, + 1558, + 1559, + 1560, + 1561 + ] + }, + { + "teal": 979, + "source": "tests/contracts/math.algo.ts:102", + "pc": [ + 1562 + ] + }, + { + "teal": 980, + "source": "tests/contracts/math.algo.ts:102", + "pc": [ + 1563, + 1564, + 1565 + ] + }, + { + "teal": 985, + "source": "tests/contracts/math.algo.ts:103", + "pc": [ + 1566, + 1567, + 1568, + 1569, + 1570, + 1571, + 1572, + 1573, + 1574 + ] + }, + { + "teal": 986, + "source": "tests/contracts/math.algo.ts:103", + "pc": [ + 1575 + ] + }, + { + "teal": 987, + "source": "tests/contracts/math.algo.ts:102", + "pc": [ + 1576, + 1577, + 1578 + ] + }, + { + "teal": 992, + "source": "tests/contracts/math.algo.ts:105", + "pc": [ + 1579, + 1580, + 1581, + 1582, + 1583, + 1584 + ] + }, + { + "teal": 993, + "source": "tests/contracts/math.algo.ts:105", + "pc": [ + 1585 + ] + }, + { + "teal": 996, + "source": "tests/contracts/math.algo.ts:100", + "pc": [ + 1586 + ] + }, + { + "teal": 1001, + "source": "tests/contracts/math.algo.ts:109", + "pc": [ + 1587, + 1588, + 1589, + 1590, + 1591, + 1592 + ] + }, + { + "teal": 1004, + "source": "tests/contracts/math.algo.ts:109", + "pc": [ + 1593, + 1594, + 1595 + ] + }, + { + "teal": 1005, + "source": "tests/contracts/math.algo.ts:109", + "pc": [ + 1596 + ] + }, + { + "teal": 1006, + "source": "tests/contracts/math.algo.ts:109", + "pc": [ + 1597 + ] + }, + { + "teal": 1007, + "source": "tests/contracts/math.algo.ts:109", + "pc": [ + 1598, + 1599 + ] + }, + { + "teal": 1008, + "source": "tests/contracts/math.algo.ts:109", + "pc": [ + 1600 + ] + }, + { + "teal": 1011, + "source": "tests/contracts/math.algo.ts:109", + "errorMessage": "argument 0 (b) for squareRoot256 must be a uint256", + "pc": [ + 1601 + ] + }, + { + "teal": 1014, + "source": "tests/contracts/math.algo.ts:109", + "pc": [ + 1602, + 1603, + 1604 + ] + }, + { + "teal": 1015, + "source": "tests/contracts/math.algo.ts:109", + "pc": [ + 1605 + ] + }, + { + "teal": 1016, + "source": "tests/contracts/math.algo.ts:109", + "pc": [ + 1606 + ] + }, + { + "teal": 1017, + "source": "tests/contracts/math.algo.ts:109", + "pc": [ + 1607, + 1608 + ] + }, + { + "teal": 1018, + "source": "tests/contracts/math.algo.ts:109", + "pc": [ + 1609 + ] + }, + { + "teal": 1021, + "source": "tests/contracts/math.algo.ts:109", + "errorMessage": "argument 1 (a) for squareRoot256 must be a uint256", + "pc": [ + 1610 + ] + }, + { + "teal": 1024, + "source": "tests/contracts/math.algo.ts:109", + "pc": [ + 1611, + 1612, + 1613 + ] + }, + { + "teal": 1025, + "source": "tests/contracts/math.algo.ts:109", + "pc": [ + 1614 + ] + }, + { + "teal": 1026, + "source": "tests/contracts/math.algo.ts:109", + "pc": [ + 1615 + ] + }, + { + "teal": 1027, + "source": "tests/contracts/math.algo.ts:109", + "pc": [ + 1616, + 1617, + 1618 + ] + }, + { + "teal": 1028, + "source": "tests/contracts/math.algo.ts:109", + "pc": [ + 1619 + ] + }, + { + "teal": 1031, + "source": "tests/contracts/math.algo.ts:109", + "errorMessage": "squareRoot256 return value overflowed 256 bits", + "pc": [ + 1620 + ] + }, + { + "teal": 1032, + "source": "tests/contracts/math.algo.ts:109", + "pc": [ + 1621, + 1622, + 1623, + 1624, + 1625, + 1626, + 1627, + 1628, + 1629, + 1630, + 1631, + 1632, + 1633, + 1634, + 1635, + 1636, + 1637, + 1638, + 1639, + 1640, + 1641, + 1642, + 1643, + 1644, + 1645, + 1646, + 1647, + 1648, + 1649, + 1650, + 1651, + 1652, + 1653, + 1654 + ] + }, + { + "teal": 1033, + "source": "tests/contracts/math.algo.ts:109", + "pc": [ + 1655 + ] + }, + { + "teal": 1034, + "source": "tests/contracts/math.algo.ts:109", + "pc": [ + 1656 + ] + }, + { + "teal": 1035, + "source": "tests/contracts/math.algo.ts:109", + "pc": [ + 1657 + ] + }, + { + "teal": 1036, + "source": "tests/contracts/math.algo.ts:109", + "pc": [ + 1658 + ] + }, + { + "teal": 1037, + "source": "tests/contracts/math.algo.ts:109", + "pc": [ + 1659, + 1660 + ] + }, + { + "teal": 1038, + "source": "tests/contracts/math.algo.ts:109", + "pc": [ + 1661 + ] + }, + { + "teal": 1039, + "source": "tests/contracts/math.algo.ts:109", + "pc": [ + 1662 + ] + }, + { + "teal": 1040, + "source": "tests/contracts/math.algo.ts:109", + "pc": [ + 1663 + ] + }, + { + "teal": 1041, + "source": "tests/contracts/math.algo.ts:109", + "pc": [ + 1664 + ] + }, + { + "teal": 1042, + "source": "tests/contracts/math.algo.ts:109", + "pc": [ + 1665 + ] + }, + { + "teal": 1043, + "source": "tests/contracts/math.algo.ts:109", + "pc": [ + 1666, + 1667 + ] + }, + { + "teal": 1044, + "source": "tests/contracts/math.algo.ts:109", + "pc": [ + 1668 + ] + }, + { + "teal": 1048, + "source": "tests/contracts/math.algo.ts:109", + "pc": [ + 1669, + 1670, + 1671 + ] + }, + { + "teal": 1052, + "source": "tests/contracts/math.algo.ts:110", + "pc": [ + 1672, + 1673 + ] + }, + { + "teal": 1053, + "source": "tests/contracts/math.algo.ts:110", + "pc": [ + 1674, + 1675 + ] + }, + { + "teal": 1054, + "source": "tests/contracts/math.algo.ts:110", + "pc": [ + 1676 + ] + }, + { + "teal": 1055, + "source": "tests/contracts/math.algo.ts:110", + "pc": [ + 1677 + ] + }, + { + "teal": 1056, + "source": "tests/contracts/math.algo.ts:109", + "pc": [ + 1678 + ] + }, + { + "teal": 1061, + "source": "tests/contracts/math.algo.ts:113", + "pc": [ + 1679, + 1680, + 1681, + 1682, + 1683, + 1684 + ] + }, + { + "teal": 1064, + "source": "tests/contracts/math.algo.ts:113", + "pc": [ + 1685, + 1686, + 1687 + ] + }, + { + "teal": 1065, + "source": "tests/contracts/math.algo.ts:113", + "pc": [ + 1688 + ] + }, + { + "teal": 1068, + "source": "tests/contracts/math.algo.ts:113", + "pc": [ + 1689, + 1690, + 1691 + ] + }, + { + "teal": 1069, + "source": "tests/contracts/math.algo.ts:113", + "pc": [ + 1692 + ] + }, + { + "teal": 1072, + "source": "tests/contracts/math.algo.ts:113", + "pc": [ + 1693, + 1694, + 1695 + ] + }, + { + "teal": 1073, + "source": "tests/contracts/math.algo.ts:113", + "pc": [ + 1696 + ] + }, + { + "teal": 1074, + "source": "tests/contracts/math.algo.ts:113", + "pc": [ + 1697 + ] + }, + { + "teal": 1075, + "source": "tests/contracts/math.algo.ts:113", + "pc": [ + 1698 + ] + }, + { + "teal": 1076, + "source": "tests/contracts/math.algo.ts:113", + "pc": [ + 1699, + 1700 + ] + }, + { + "teal": 1077, + "source": "tests/contracts/math.algo.ts:113", + "pc": [ + 1701 + ] + }, + { + "teal": 1081, + "source": "tests/contracts/math.algo.ts:113", + "pc": [ + 1702, + 1703, + 1704 + ] + }, + { + "teal": 1085, + "source": "tests/contracts/math.algo.ts:114", + "pc": [ + 1705, + 1706 + ] + }, + { + "teal": 1086, + "source": "tests/contracts/math.algo.ts:114", + "pc": [ + 1707, + 1708 + ] + }, + { + "teal": 1087, + "source": "tests/contracts/math.algo.ts:114", + "pc": [ + 1709 + ] + }, + { + "teal": 1088, + "source": "tests/contracts/math.algo.ts:114", + "pc": [ + 1710 + ] + }, + { + "teal": 1089, + "source": "tests/contracts/math.algo.ts:113", + "pc": [ + 1711 + ] + }, + { + "teal": 1094, + "source": "tests/contracts/math.algo.ts:117", + "pc": [ + 1712, + 1713, + 1714, + 1715, + 1716, + 1717 + ] + }, + { + "teal": 1097, + "source": "tests/contracts/math.algo.ts:117", + "pc": [ + 1718, + 1719, + 1720 + ] + }, + { + "teal": 1098, + "source": "tests/contracts/math.algo.ts:117", + "pc": [ + 1721 + ] + }, + { + "teal": 1099, + "source": "tests/contracts/math.algo.ts:117", + "pc": [ + 1722 + ] + }, + { + "teal": 1100, + "source": "tests/contracts/math.algo.ts:117", + "pc": [ + 1723, + 1724 + ] + }, + { + "teal": 1101, + "source": "tests/contracts/math.algo.ts:117", + "pc": [ + 1725 + ] + }, + { + "teal": 1104, + "source": "tests/contracts/math.algo.ts:117", + "errorMessage": "argument 0 (addr) for addressToBigInt must be a address", + "pc": [ + 1726 + ] + }, + { + "teal": 1107, + "source": "tests/contracts/math.algo.ts:117", + "pc": [ + 1727, + 1728, + 1729 + ] + }, + { + "teal": 1108, + "source": "tests/contracts/math.algo.ts:117", + "pc": [ + 1730, + 1731, + 1732 + ] + }, + { + "teal": 1109, + "source": "tests/contracts/math.algo.ts:117", + "pc": [ + 1733, + 1734 + ] + }, + { + "teal": 1110, + "source": "tests/contracts/math.algo.ts:117", + "pc": [ + 1735, + 1736 + ] + }, + { + "teal": 1111, + "source": "tests/contracts/math.algo.ts:117", + "pc": [ + 1737 + ] + }, + { + "teal": 1112, + "source": "tests/contracts/math.algo.ts:117", + "pc": [ + 1738 + ] + }, + { + "teal": 1113, + "source": "tests/contracts/math.algo.ts:117", + "pc": [ + 1739 + ] + }, + { + "teal": 1114, + "source": "tests/contracts/math.algo.ts:117", + "pc": [ + 1740, + 1741 + ] + }, + { + "teal": 1115, + "source": "tests/contracts/math.algo.ts:117", + "pc": [ + 1742 + ] + }, + { + "teal": 1119, + "source": "tests/contracts/math.algo.ts:117", + "pc": [ + 1743, + 1744, + 1745 + ] + }, + { + "teal": 1123, + "source": "tests/contracts/math.algo.ts:118", + "pc": [ + 1746, + 1747 + ] + }, + { + "teal": 1124, + "source": "tests/contracts/math.algo.ts:118", + "pc": [ + 1748, + 1749 + ] + }, + { + "teal": 1125, + "source": "tests/contracts/math.algo.ts:118", + "pc": [ + 1750 + ] + }, + { + "teal": 1126, + "source": "tests/contracts/math.algo.ts:117", + "pc": [ + 1751 + ] + }, + { + "teal": 1131, + "source": "tests/contracts/math.algo.ts:121", + "pc": [ + 1752, + 1753, + 1754, + 1755, + 1756, + 1757 + ] + }, + { + "teal": 1134, + "source": "tests/contracts/math.algo.ts:121", + "pc": [ + 1758, + 1759, + 1760 + ] + }, + { + "teal": 1135, + "source": "tests/contracts/math.algo.ts:121", + "pc": [ + 1761 + ] + }, + { + "teal": 1136, + "source": "tests/contracts/math.algo.ts:121", + "pc": [ + 1762 + ] + }, + { + "teal": 1137, + "source": "tests/contracts/math.algo.ts:121", + "pc": [ + 1763 + ] + }, + { + "teal": 1138, + "source": "tests/contracts/math.algo.ts:121", + "pc": [ + 1764, + 1765 + ] + }, + { + "teal": 1139, + "source": "tests/contracts/math.algo.ts:121", + "pc": [ + 1766 + ] + }, + { + "teal": 1143, + "source": "tests/contracts/math.algo.ts:121", + "pc": [ + 1767, + 1768, + 1769 + ] + }, + { + "teal": 1146, + "source": "tests/contracts/math.algo.ts:121", + "pc": [ + 1770, + 1771 + ] + }, + { + "teal": 1150, + "source": "tests/contracts/math.algo.ts:122", + "pc": [ + 1772, + 1773 + ] + }, + { + "teal": 1151, + "source": "tests/contracts/math.algo.ts:122", + "pc": [ + 1774, + 1775 + ] + }, + { + "teal": 1155, + "source": "tests/contracts/math.algo.ts:123", + "pc": [ + 1776, + 1777 + ] + }, + { + "teal": 1158, + "source": "tests/contracts/math.algo.ts:121", + "pc": [ + 1778, + 1779 + ] + }, + { + "teal": 1159, + "source": "tests/contracts/math.algo.ts:121", + "pc": [ + 1780 + ] + }, + { + "teal": 1163, + "source": "tests/contracts/math.algo.ts:126", + "pc": [ + 1781, + 1782, + 1783 + ] + }, + { + "teal": 1167, + "source": "tests/contracts/math.algo.ts:127", + "pc": [ + 1784, + 1785 + ] + }, + { + "teal": 1168, + "source": "tests/contracts/math.algo.ts:127", + "pc": [ + 1786, + 1787 + ] + }, + { + "teal": 1169, + "source": "tests/contracts/math.algo.ts:127", + "pc": [ + 1788 + ] + }, + { + "teal": 1170, + "source": "tests/contracts/math.algo.ts:127", + "pc": [ + 1789 + ] + }, + { + "teal": 1171, + "source": "tests/contracts/math.algo.ts:126", + "pc": [ + 1790 + ] + }, + { + "teal": 1176, + "source": "tests/contracts/math.algo.ts:130", + "pc": [ + 1791, + 1792, + 1793 + ] + }, + { + "teal": 1177, + "source": "tests/contracts/math.algo.ts:130", + "pc": [ + 1794 + ] + }, + { + "teal": 1178, + "source": "tests/contracts/math.algo.ts:130", + "pc": [ + 1795 + ] + }, + { + "teal": 1179, + "source": "tests/contracts/math.algo.ts:130", + "pc": [ + 1796, + 1797 + ] + }, + { + "teal": 1180, + "source": "tests/contracts/math.algo.ts:130", + "pc": [ + 1798 + ] + }, + { + "teal": 1183, + "source": "tests/contracts/math.algo.ts:130", + "errorMessage": "argument 0 (x) for funcName must be a uint256", + "pc": [ + 1799 + ] + }, + { + "teal": 1186, + "source": "tests/contracts/math.algo.ts:130", + "pc": [ + 1800, + 1801, + 1802 + ] + }, + { + "teal": 1187, + "source": "tests/contracts/math.algo.ts:130", + "pc": [ + 1803, + 1804 + ] + }, + { + "teal": 1188, + "source": "tests/contracts/math.algo.ts:130", + "pc": [ + 1805 + ] + }, + { + "teal": 1192, + "source": "tests/contracts/math.algo.ts:130", + "pc": [ + 1806, + 1807, + 1808 + ] + }, + { + "teal": 1196, + "source": "tests/contracts/math.algo.ts:131", + "pc": [ + 1809, + 1810, + 1811 + ] + }, + { + "teal": 1197, + "source": "tests/contracts/math.algo.ts:131", + "pc": [ + 1812, + 1813 + ] + }, + { + "teal": 1198, + "source": "tests/contracts/math.algo.ts:131", + "pc": [ + 1814 + ] + }, + { + "teal": 1199, + "source": "tests/contracts/math.algo.ts:131", + "pc": [ + 1815 + ] + }, + { + "teal": 1200, + "source": "tests/contracts/math.algo.ts:131", + "pc": [ + 1816, + 1817 + ] + }, + { + "teal": 1201, + "source": "tests/contracts/math.algo.ts:131", + "pc": [ + 1818 + ] + }, + { + "teal": 1204, + "source": "tests/contracts/math.algo.ts:131", + "errorMessage": "x overflowed 8 bits", + "pc": [ + 1819 + ] + }, + { + "teal": 1205, + "source": "tests/contracts/math.algo.ts:131", + "pc": [ + 1820, + 1821, + 1822 + ] + }, + { + "teal": 1206, + "source": "tests/contracts/math.algo.ts:131", + "pc": [ + 1823 + ] + }, + { + "teal": 1207, + "source": "tests/contracts/math.algo.ts:131", + "pc": [ + 1824, + 1825, + 1826 + ] + }, + { + "teal": 1208, + "source": "tests/contracts/math.algo.ts:130", + "pc": [ + 1827 + ] + }, + { + "teal": 1213, + "source": "tests/contracts/math.algo.ts:134", + "pc": [ + 1828, + 1829, + 1830, + 1831, + 1832, + 1833 + ] + }, + { + "teal": 1216, + "source": "tests/contracts/math.algo.ts:134", + "pc": [ + 1834, + 1835, + 1836 + ] + }, + { + "teal": 1217, + "source": "tests/contracts/math.algo.ts:134", + "pc": [ + 1837 + ] + }, + { + "teal": 1220, + "source": "tests/contracts/math.algo.ts:134", + "pc": [ + 1838, + 1839, + 1840 + ] + }, + { + "teal": 1221, + "source": "tests/contracts/math.algo.ts:134", + "pc": [ + 1841 + ] + }, + { + "teal": 1224, + "source": "tests/contracts/math.algo.ts:134", + "pc": [ + 1842, + 1843, + 1844 + ] + }, + { + "teal": 1225, + "source": "tests/contracts/math.algo.ts:134", + "pc": [ + 1845 + ] + }, + { + "teal": 1226, + "source": "tests/contracts/math.algo.ts:134", + "pc": [ + 1846 + ] + }, + { + "teal": 1227, + "source": "tests/contracts/math.algo.ts:134", + "pc": [ + 1847 + ] + }, + { + "teal": 1228, + "source": "tests/contracts/math.algo.ts:134", + "pc": [ + 1848, + 1849 + ] + }, + { + "teal": 1229, + "source": "tests/contracts/math.algo.ts:134", + "pc": [ + 1850 + ] + }, + { + "teal": 1233, + "source": "tests/contracts/math.algo.ts:134", + "pc": [ + 1851, + 1852, + 1853 + ] + }, + { + "teal": 1236, + "source": "tests/contracts/math.algo.ts:134", + "pc": [ + 1854, + 1855 + ] + }, + { + "teal": 1237, + "source": "tests/contracts/math.algo.ts:134", + "pc": [ + 1856 + ] + }, + { + "teal": 1241, + "source": "tests/contracts/math.algo.ts:135", + "pc": [ + 1857, + 1858 + ] + }, + { + "teal": 1242, + "source": "tests/contracts/math.algo.ts:135", + "pc": [ + 1859 + ] + }, + { + "teal": 1243, + "source": "tests/contracts/math.algo.ts:135", + "pc": [ + 1860, + 1861 + ] + }, + { + "teal": 1247, + "source": "tests/contracts/math.algo.ts:136", + "pc": [ + 1862, + 1863 + ] + }, + { + "teal": 1248, + "source": "tests/contracts/math.algo.ts:136", + "pc": [ + 1864 + ] + }, + { + "teal": 1249, + "source": "tests/contracts/math.algo.ts:136", + "pc": [ + 1865, + 1866 + ] + }, + { + "teal": 1253, + "source": "tests/contracts/math.algo.ts:137", + "pc": [ + 1867, + 1868 + ] + }, + { + "teal": 1254, + "source": "tests/contracts/math.algo.ts:137", + "pc": [ + 1869, + 1870 + ] + }, + { + "teal": 1255, + "source": "tests/contracts/math.algo.ts:137", + "pc": [ + 1871 + ] + }, + { + "teal": 1256, + "source": "tests/contracts/math.algo.ts:137", + "pc": [ + 1872 + ] + }, + { + "teal": 1257, + "source": "tests/contracts/math.algo.ts:137", + "pc": [ + 1873 + ] + }, + { + "teal": 1258, + "source": "tests/contracts/math.algo.ts:137", + "pc": [ + 1874, + 1875 + ] + }, + { + "teal": 1259, + "source": "tests/contracts/math.algo.ts:137", + "pc": [ + 1876 + ] + }, + { + "teal": 1262, + "source": "tests/contracts/math.algo.ts:137", + "errorMessage": "(btobigint(x) + btobigint(y)) as uint64 overflowed 64 bits", + "pc": [ + 1877 + ] + }, + { + "teal": 1263, + "source": "tests/contracts/math.algo.ts:137", + "pc": [ + 1878, + 1879, + 1880, + 1881, + 1882, + 1883, + 1884, + 1885, + 1886, + 1887 + ] + }, + { + "teal": 1264, + "source": "tests/contracts/math.algo.ts:137", + "pc": [ + 1888 + ] + }, + { + "teal": 1265, + "source": "tests/contracts/math.algo.ts:137", + "pc": [ + 1889 + ] + }, + { + "teal": 1266, + "source": "tests/contracts/math.algo.ts:137", + "pc": [ + 1890 + ] + }, + { + "teal": 1267, + "source": "tests/contracts/math.algo.ts:137", + "pc": [ + 1891 + ] + }, + { + "teal": 1268, + "source": "tests/contracts/math.algo.ts:137", + "pc": [ + 1892, + 1893 + ] + }, + { + "teal": 1269, + "source": "tests/contracts/math.algo.ts:137", + "pc": [ + 1894 + ] + }, + { + "teal": 1270, + "source": "tests/contracts/math.algo.ts:137", + "pc": [ + 1895 + ] + }, + { + "teal": 1271, + "source": "tests/contracts/math.algo.ts:137", + "pc": [ + 1896 + ] + }, + { + "teal": 1272, + "source": "tests/contracts/math.algo.ts:137", + "pc": [ + 1897 + ] + }, + { + "teal": 1275, + "source": "tests/contracts/math.algo.ts:134", + "pc": [ + 1898, + 1899 + ] + }, + { + "teal": 1278, + "source": "tests/contracts/math.algo.ts:134", + "pc": [ + 1900, + 1901 + ] + }, + { + "teal": 1279, + "source": "tests/contracts/math.algo.ts:134", + "pc": [ + 1902 + ] + }, + { + "teal": 1284, + "source": "tests/contracts/math.algo.ts:140", + "pc": [ + 1903, + 1904, + 1905, + 1906, + 1907, + 1908 + ] + }, + { + "teal": 1287, + "source": "tests/contracts/math.algo.ts:140", + "pc": [ + 1909, + 1910, + 1911 + ] + }, + { + "teal": 1288, + "source": "tests/contracts/math.algo.ts:140", + "pc": [ + 1912 + ] + }, + { + "teal": 1291, + "source": "tests/contracts/math.algo.ts:140", + "pc": [ + 1913, + 1914, + 1915 + ] + }, + { + "teal": 1292, + "source": "tests/contracts/math.algo.ts:140", + "pc": [ + 1916 + ] + }, + { + "teal": 1295, + "source": "tests/contracts/math.algo.ts:140", + "pc": [ + 1917, + 1918, + 1919 + ] + }, + { + "teal": 1296, + "source": "tests/contracts/math.algo.ts:140", + "pc": [ + 1920 + ] + }, + { + "teal": 1297, + "source": "tests/contracts/math.algo.ts:140", + "pc": [ + 1921 + ] + }, + { + "teal": 1298, + "source": "tests/contracts/math.algo.ts:140", + "pc": [ + 1922 + ] + }, + { + "teal": 1299, + "source": "tests/contracts/math.algo.ts:140", + "pc": [ + 1923, + 1924 + ] + }, + { + "teal": 1300, + "source": "tests/contracts/math.algo.ts:140", + "pc": [ + 1925 + ] + }, + { + "teal": 1304, + "source": "tests/contracts/math.algo.ts:140", + "pc": [ + 1926, + 1927, + 1928 + ] + }, + { + "teal": 1308, + "source": "tests/contracts/math.algo.ts:141", + "pc": [ + 1929, + 1930 + ] + }, + { + "teal": 1309, + "source": "tests/contracts/math.algo.ts:141", + "pc": [ + 1931, + 1932 + ] + }, + { + "teal": 1310, + "source": "tests/contracts/math.algo.ts:141", + "pc": [ + 1933 + ] + }, + { + "teal": 1311, + "source": "tests/contracts/math.algo.ts:140", + "pc": [ + 1934 + ] + }, + { + "teal": 1316, + "source": "tests/contracts/math.algo.ts:144", + "pc": [ + 1935, + 1936, + 1937, + 1938, + 1939, + 1940 + ] + }, + { + "teal": 1319, + "source": "tests/contracts/math.algo.ts:144", + "pc": [ + 1941, + 1942, + 1943 + ] + }, + { + "teal": 1320, + "source": "tests/contracts/math.algo.ts:144", + "pc": [ + 1944 + ] + }, + { + "teal": 1323, + "source": "tests/contracts/math.algo.ts:144", + "pc": [ + 1945, + 1946, + 1947 + ] + }, + { + "teal": 1324, + "source": "tests/contracts/math.algo.ts:144", + "pc": [ + 1948 + ] + }, + { + "teal": 1327, + "source": "tests/contracts/math.algo.ts:144", + "pc": [ + 1949, + 1950, + 1951 + ] + }, + { + "teal": 1328, + "source": "tests/contracts/math.algo.ts:144", + "pc": [ + 1952 + ] + }, + { + "teal": 1329, + "source": "tests/contracts/math.algo.ts:144", + "pc": [ + 1953 + ] + }, + { + "teal": 1330, + "source": "tests/contracts/math.algo.ts:144", + "pc": [ + 1954 + ] + }, + { + "teal": 1331, + "source": "tests/contracts/math.algo.ts:144", + "pc": [ + 1955, + 1956 + ] + }, + { + "teal": 1332, + "source": "tests/contracts/math.algo.ts:144", + "pc": [ + 1957 + ] + }, + { + "teal": 1336, + "source": "tests/contracts/math.algo.ts:144", + "pc": [ + 1958, + 1959, + 1960 + ] + }, + { + "teal": 1340, + "source": "tests/contracts/math.algo.ts:145", + "pc": [ + 1961, + 1962 + ] + }, + { + "teal": 1341, + "source": "tests/contracts/math.algo.ts:145", + "pc": [ + 1963, + 1964 + ] + }, + { + "teal": 1342, + "source": "tests/contracts/math.algo.ts:145", + "pc": [ + 1965 + ] + }, + { + "teal": 1343, + "source": "tests/contracts/math.algo.ts:144", + "pc": [ + 1966 + ] + }, + { + "teal": 1348, + "source": "tests/contracts/math.algo.ts:148", + "pc": [ + 1967, + 1968, + 1969, + 1970, + 1971, + 1972 + ] + }, + { + "teal": 1351, + "source": "tests/contracts/math.algo.ts:148", + "pc": [ + 1973, + 1974, + 1975 + ] + }, + { + "teal": 1352, + "source": "tests/contracts/math.algo.ts:148", + "pc": [ + 1976 + ] + }, + { + "teal": 1355, + "source": "tests/contracts/math.algo.ts:148", + "pc": [ + 1977, + 1978, + 1979 + ] + }, + { + "teal": 1356, + "source": "tests/contracts/math.algo.ts:148", + "pc": [ + 1980 + ] + }, + { + "teal": 1359, + "source": "tests/contracts/math.algo.ts:148", + "pc": [ + 1981, + 1982, + 1983 + ] + }, + { + "teal": 1360, + "source": "tests/contracts/math.algo.ts:148", + "pc": [ + 1984 + ] + }, + { + "teal": 1361, + "source": "tests/contracts/math.algo.ts:148", + "pc": [ + 1985 + ] + }, + { + "teal": 1362, + "source": "tests/contracts/math.algo.ts:148", + "pc": [ + 1986 + ] + }, + { + "teal": 1363, + "source": "tests/contracts/math.algo.ts:148", + "pc": [ + 1987, + 1988 + ] + }, + { + "teal": 1364, + "source": "tests/contracts/math.algo.ts:148", + "pc": [ + 1989 + ] + }, + { + "teal": 1368, + "source": "tests/contracts/math.algo.ts:148", + "pc": [ + 1990, + 1991, + 1992 + ] + }, + { + "teal": 1372, + "source": "tests/contracts/math.algo.ts:149", + "pc": [ + 1993, + 1994 + ] + }, + { + "teal": 1373, + "source": "tests/contracts/math.algo.ts:149", + "pc": [ + 1995, + 1996 + ] + }, + { + "teal": 1374, + "source": "tests/contracts/math.algo.ts:149", + "pc": [ + 1997 + ] + }, + { + "teal": 1375, + "source": "tests/contracts/math.algo.ts:148", + "pc": [ + 1998 + ] + }, + { + "teal": 1380, + "source": "tests/contracts/math.algo.ts:152", + "pc": [ + 1999, + 2000, + 2001, + 2002, + 2003, + 2004 + ] + }, + { + "teal": 1383, + "source": "tests/contracts/math.algo.ts:152", + "pc": [ + 2005, + 2006, + 2007 + ] + }, + { + "teal": 1384, + "source": "tests/contracts/math.algo.ts:152", + "pc": [ + 2008 + ] + }, + { + "teal": 1385, + "source": "tests/contracts/math.algo.ts:152", + "pc": [ + 2009 + ] + }, + { + "teal": 1386, + "source": "tests/contracts/math.algo.ts:152", + "pc": [ + 2010, + 2011 + ] + }, + { + "teal": 1387, + "source": "tests/contracts/math.algo.ts:152", + "pc": [ + 2012 + ] + }, + { + "teal": 1390, + "source": "tests/contracts/math.algo.ts:152", + "errorMessage": "argument 0 (b) for bitwiseOrU256 must be a uint256", + "pc": [ + 2013 + ] + }, + { + "teal": 1393, + "source": "tests/contracts/math.algo.ts:152", + "pc": [ + 2014, + 2015, + 2016 + ] + }, + { + "teal": 1394, + "source": "tests/contracts/math.algo.ts:152", + "pc": [ + 2017 + ] + }, + { + "teal": 1395, + "source": "tests/contracts/math.algo.ts:152", + "pc": [ + 2018 + ] + }, + { + "teal": 1396, + "source": "tests/contracts/math.algo.ts:152", + "pc": [ + 2019, + 2020 + ] + }, + { + "teal": 1397, + "source": "tests/contracts/math.algo.ts:152", + "pc": [ + 2021 + ] + }, + { + "teal": 1400, + "source": "tests/contracts/math.algo.ts:152", + "errorMessage": "argument 1 (a) for bitwiseOrU256 must be a uint256", + "pc": [ + 2022 + ] + }, + { + "teal": 1403, + "source": "tests/contracts/math.algo.ts:152", + "pc": [ + 2023, + 2024, + 2025 + ] + }, + { + "teal": 1404, + "source": "tests/contracts/math.algo.ts:152", + "pc": [ + 2026 + ] + }, + { + "teal": 1405, + "source": "tests/contracts/math.algo.ts:152", + "pc": [ + 2027 + ] + }, + { + "teal": 1406, + "source": "tests/contracts/math.algo.ts:152", + "pc": [ + 2028, + 2029, + 2030 + ] + }, + { + "teal": 1407, + "source": "tests/contracts/math.algo.ts:152", + "pc": [ + 2031 + ] + }, + { + "teal": 1410, + "source": "tests/contracts/math.algo.ts:152", + "errorMessage": "bitwiseOrU256 return value overflowed 256 bits", + "pc": [ + 2032 + ] + }, + { + "teal": 1411, + "source": "tests/contracts/math.algo.ts:152", + "pc": [ + 2033, + 2034, + 2035, + 2036, + 2037, + 2038, + 2039, + 2040, + 2041, + 2042, + 2043, + 2044, + 2045, + 2046, + 2047, + 2048, + 2049, + 2050, + 2051, + 2052, + 2053, + 2054, + 2055, + 2056, + 2057, + 2058, + 2059, + 2060, + 2061, + 2062, + 2063, + 2064, + 2065, + 2066 + ] + }, + { + "teal": 1412, + "source": "tests/contracts/math.algo.ts:152", + "pc": [ + 2067 + ] + }, + { + "teal": 1413, + "source": "tests/contracts/math.algo.ts:152", + "pc": [ + 2068 + ] + }, + { + "teal": 1414, + "source": "tests/contracts/math.algo.ts:152", + "pc": [ + 2069 + ] + }, + { + "teal": 1415, + "source": "tests/contracts/math.algo.ts:152", + "pc": [ + 2070 + ] + }, + { + "teal": 1416, + "source": "tests/contracts/math.algo.ts:152", + "pc": [ + 2071, + 2072 + ] + }, + { + "teal": 1417, + "source": "tests/contracts/math.algo.ts:152", + "pc": [ + 2073 + ] + }, + { + "teal": 1418, + "source": "tests/contracts/math.algo.ts:152", + "pc": [ + 2074 + ] + }, + { + "teal": 1419, + "source": "tests/contracts/math.algo.ts:152", + "pc": [ + 2075 + ] + }, + { + "teal": 1420, + "source": "tests/contracts/math.algo.ts:152", + "pc": [ + 2076 + ] + }, + { + "teal": 1421, + "source": "tests/contracts/math.algo.ts:152", + "pc": [ + 2077 + ] + }, + { + "teal": 1422, + "source": "tests/contracts/math.algo.ts:152", + "pc": [ + 2078, + 2079 + ] + }, + { + "teal": 1423, + "source": "tests/contracts/math.algo.ts:152", + "pc": [ + 2080 + ] + }, + { + "teal": 1427, + "source": "tests/contracts/math.algo.ts:152", + "pc": [ + 2081, + 2082, + 2083 + ] + }, + { + "teal": 1431, + "source": "tests/contracts/math.algo.ts:153", + "pc": [ + 2084, + 2085 + ] + }, + { + "teal": 1432, + "source": "tests/contracts/math.algo.ts:153", + "pc": [ + 2086, + 2087 + ] + }, + { + "teal": 1433, + "source": "tests/contracts/math.algo.ts:153", + "pc": [ + 2088 + ] + }, + { + "teal": 1434, + "source": "tests/contracts/math.algo.ts:152", + "pc": [ + 2089 + ] + }, + { + "teal": 1439, + "source": "tests/contracts/math.algo.ts:156", + "pc": [ + 2090, + 2091, + 2092, + 2093, + 2094, + 2095 + ] + }, + { + "teal": 1442, + "source": "tests/contracts/math.algo.ts:156", + "pc": [ + 2096, + 2097, + 2098 + ] + }, + { + "teal": 1443, + "source": "tests/contracts/math.algo.ts:156", + "pc": [ + 2099 + ] + }, + { + "teal": 1444, + "source": "tests/contracts/math.algo.ts:156", + "pc": [ + 2100 + ] + }, + { + "teal": 1445, + "source": "tests/contracts/math.algo.ts:156", + "pc": [ + 2101, + 2102 + ] + }, + { + "teal": 1446, + "source": "tests/contracts/math.algo.ts:156", + "pc": [ + 2103 + ] + }, + { + "teal": 1449, + "source": "tests/contracts/math.algo.ts:156", + "errorMessage": "argument 0 (b) for bitwiseAndU256 must be a uint256", + "pc": [ + 2104 + ] + }, + { + "teal": 1452, + "source": "tests/contracts/math.algo.ts:156", + "pc": [ + 2105, + 2106, + 2107 + ] + }, + { + "teal": 1453, + "source": "tests/contracts/math.algo.ts:156", + "pc": [ + 2108 + ] + }, + { + "teal": 1454, + "source": "tests/contracts/math.algo.ts:156", + "pc": [ + 2109 + ] + }, + { + "teal": 1455, + "source": "tests/contracts/math.algo.ts:156", + "pc": [ + 2110, + 2111 + ] + }, + { + "teal": 1456, + "source": "tests/contracts/math.algo.ts:156", + "pc": [ + 2112 + ] + }, + { + "teal": 1459, + "source": "tests/contracts/math.algo.ts:156", + "errorMessage": "argument 1 (a) for bitwiseAndU256 must be a uint256", + "pc": [ + 2113 + ] + }, + { + "teal": 1462, + "source": "tests/contracts/math.algo.ts:156", + "pc": [ + 2114, + 2115, + 2116 + ] + }, + { + "teal": 1463, + "source": "tests/contracts/math.algo.ts:156", + "pc": [ + 2117 + ] + }, + { + "teal": 1464, + "source": "tests/contracts/math.algo.ts:156", + "pc": [ + 2118 + ] + }, + { + "teal": 1465, + "source": "tests/contracts/math.algo.ts:156", + "pc": [ + 2119, + 2120, + 2121 + ] + }, + { + "teal": 1466, + "source": "tests/contracts/math.algo.ts:156", + "pc": [ + 2122 + ] + }, + { + "teal": 1469, + "source": "tests/contracts/math.algo.ts:156", + "errorMessage": "bitwiseAndU256 return value overflowed 256 bits", + "pc": [ + 2123 + ] + }, + { + "teal": 1470, + "source": "tests/contracts/math.algo.ts:156", + "pc": [ + 2124, + 2125, + 2126, + 2127, + 2128, + 2129, + 2130, + 2131, + 2132, + 2133, + 2134, + 2135, + 2136, + 2137, + 2138, + 2139, + 2140, + 2141, + 2142, + 2143, + 2144, + 2145, + 2146, + 2147, + 2148, + 2149, + 2150, + 2151, + 2152, + 2153, + 2154, + 2155, + 2156, + 2157 + ] + }, + { + "teal": 1471, + "source": "tests/contracts/math.algo.ts:156", + "pc": [ + 2158 + ] + }, + { + "teal": 1472, + "source": "tests/contracts/math.algo.ts:156", + "pc": [ + 2159 + ] + }, + { + "teal": 1473, + "source": "tests/contracts/math.algo.ts:156", + "pc": [ + 2160 + ] + }, + { + "teal": 1474, + "source": "tests/contracts/math.algo.ts:156", + "pc": [ + 2161 + ] + }, + { + "teal": 1475, + "source": "tests/contracts/math.algo.ts:156", + "pc": [ + 2162, + 2163 + ] + }, + { + "teal": 1476, + "source": "tests/contracts/math.algo.ts:156", + "pc": [ + 2164 + ] + }, + { + "teal": 1477, + "source": "tests/contracts/math.algo.ts:156", + "pc": [ + 2165 + ] + }, + { + "teal": 1478, + "source": "tests/contracts/math.algo.ts:156", + "pc": [ + 2166 + ] + }, + { + "teal": 1479, + "source": "tests/contracts/math.algo.ts:156", + "pc": [ + 2167 + ] + }, + { + "teal": 1480, + "source": "tests/contracts/math.algo.ts:156", + "pc": [ + 2168 + ] + }, + { + "teal": 1481, + "source": "tests/contracts/math.algo.ts:156", + "pc": [ + 2169, + 2170 + ] + }, + { + "teal": 1482, + "source": "tests/contracts/math.algo.ts:156", + "pc": [ + 2171 + ] + }, + { + "teal": 1486, + "source": "tests/contracts/math.algo.ts:156", + "pc": [ + 2172, + 2173, + 2174 + ] + }, + { + "teal": 1490, + "source": "tests/contracts/math.algo.ts:157", + "pc": [ + 2175, + 2176 + ] + }, + { + "teal": 1491, + "source": "tests/contracts/math.algo.ts:157", + "pc": [ + 2177, + 2178 + ] + }, + { + "teal": 1492, + "source": "tests/contracts/math.algo.ts:157", + "pc": [ + 2179 + ] + }, + { + "teal": 1493, + "source": "tests/contracts/math.algo.ts:156", + "pc": [ + 2180 + ] + }, + { + "teal": 1498, + "source": "tests/contracts/math.algo.ts:160", + "pc": [ + 2181, + 2182, + 2183, + 2184, + 2185, + 2186 + ] + }, + { + "teal": 1501, + "source": "tests/contracts/math.algo.ts:160", + "pc": [ + 2187, + 2188, + 2189 + ] + }, + { + "teal": 1502, + "source": "tests/contracts/math.algo.ts:160", + "pc": [ + 2190 + ] + }, + { + "teal": 1503, + "source": "tests/contracts/math.algo.ts:160", + "pc": [ + 2191 + ] + }, + { + "teal": 1504, + "source": "tests/contracts/math.algo.ts:160", + "pc": [ + 2192, + 2193 + ] + }, + { + "teal": 1505, + "source": "tests/contracts/math.algo.ts:160", + "pc": [ + 2194 + ] + }, + { + "teal": 1508, + "source": "tests/contracts/math.algo.ts:160", + "errorMessage": "argument 0 (b) for bitwiseXorU256 must be a uint256", + "pc": [ + 2195 + ] + }, + { + "teal": 1511, + "source": "tests/contracts/math.algo.ts:160", + "pc": [ + 2196, + 2197, + 2198 + ] + }, + { + "teal": 1512, + "source": "tests/contracts/math.algo.ts:160", + "pc": [ + 2199 + ] + }, + { + "teal": 1513, + "source": "tests/contracts/math.algo.ts:160", + "pc": [ + 2200 + ] + }, + { + "teal": 1514, + "source": "tests/contracts/math.algo.ts:160", + "pc": [ + 2201, + 2202 + ] + }, + { + "teal": 1515, + "source": "tests/contracts/math.algo.ts:160", + "pc": [ + 2203 + ] + }, + { + "teal": 1518, + "source": "tests/contracts/math.algo.ts:160", + "errorMessage": "argument 1 (a) for bitwiseXorU256 must be a uint256", + "pc": [ + 2204 + ] + }, + { + "teal": 1521, + "source": "tests/contracts/math.algo.ts:160", + "pc": [ + 2205, + 2206, + 2207 + ] + }, + { + "teal": 1522, + "source": "tests/contracts/math.algo.ts:160", + "pc": [ + 2208 + ] + }, + { + "teal": 1523, + "source": "tests/contracts/math.algo.ts:160", + "pc": [ + 2209 + ] + }, + { + "teal": 1524, + "source": "tests/contracts/math.algo.ts:160", + "pc": [ + 2210, + 2211, + 2212 + ] + }, + { + "teal": 1525, + "source": "tests/contracts/math.algo.ts:160", + "pc": [ + 2213 + ] + }, + { + "teal": 1528, + "source": "tests/contracts/math.algo.ts:160", + "errorMessage": "bitwiseXorU256 return value overflowed 256 bits", + "pc": [ + 2214 + ] + }, + { + "teal": 1529, + "source": "tests/contracts/math.algo.ts:160", + "pc": [ + 2215, + 2216, + 2217, + 2218, + 2219, + 2220, + 2221, + 2222, + 2223, + 2224, + 2225, + 2226, + 2227, + 2228, + 2229, + 2230, + 2231, + 2232, + 2233, + 2234, + 2235, + 2236, + 2237, + 2238, + 2239, + 2240, + 2241, + 2242, + 2243, + 2244, + 2245, + 2246, + 2247, + 2248 + ] + }, + { + "teal": 1530, + "source": "tests/contracts/math.algo.ts:160", + "pc": [ + 2249 + ] + }, + { + "teal": 1531, + "source": "tests/contracts/math.algo.ts:160", + "pc": [ + 2250 + ] + }, + { + "teal": 1532, + "source": "tests/contracts/math.algo.ts:160", + "pc": [ + 2251 + ] + }, + { + "teal": 1533, + "source": "tests/contracts/math.algo.ts:160", + "pc": [ + 2252 + ] + }, + { + "teal": 1534, + "source": "tests/contracts/math.algo.ts:160", + "pc": [ + 2253, + 2254 + ] + }, + { + "teal": 1535, + "source": "tests/contracts/math.algo.ts:160", + "pc": [ + 2255 + ] + }, + { + "teal": 1536, + "source": "tests/contracts/math.algo.ts:160", + "pc": [ + 2256 + ] + }, + { + "teal": 1537, + "source": "tests/contracts/math.algo.ts:160", + "pc": [ + 2257 + ] + }, + { + "teal": 1538, + "source": "tests/contracts/math.algo.ts:160", + "pc": [ + 2258 + ] + }, + { + "teal": 1539, + "source": "tests/contracts/math.algo.ts:160", + "pc": [ + 2259 + ] + }, + { + "teal": 1540, + "source": "tests/contracts/math.algo.ts:160", + "pc": [ + 2260, + 2261 + ] + }, + { + "teal": 1541, + "source": "tests/contracts/math.algo.ts:160", + "pc": [ + 2262 + ] + }, + { + "teal": 1545, + "source": "tests/contracts/math.algo.ts:160", + "pc": [ + 2263, + 2264, + 2265 + ] + }, + { + "teal": 1549, + "source": "tests/contracts/math.algo.ts:161", + "pc": [ + 2266, + 2267 + ] + }, + { + "teal": 1550, + "source": "tests/contracts/math.algo.ts:161", + "pc": [ + 2268, + 2269 + ] + }, + { + "teal": 1551, + "source": "tests/contracts/math.algo.ts:161", + "pc": [ + 2270 + ] + }, + { + "teal": 1552, + "source": "tests/contracts/math.algo.ts:160", + "pc": [ + 2271 + ] + }, + { + "teal": 1557, + "source": "tests/contracts/math.algo.ts:164", + "pc": [ + 2272, + 2273, + 2274, + 2275, + 2276, + 2277 + ] + }, + { + "teal": 1560, + "source": "tests/contracts/math.algo.ts:164", + "pc": [ + 2278, + 2279, + 2280 + ] + }, + { + "teal": 1561, + "source": "tests/contracts/math.algo.ts:164", + "pc": [ + 2281 + ] + }, + { + "teal": 1564, + "source": "tests/contracts/math.algo.ts:164", + "pc": [ + 2282, + 2283, + 2284 + ] + }, + { + "teal": 1565, + "source": "tests/contracts/math.algo.ts:164", + "pc": [ + 2285 + ] + }, + { + "teal": 1566, + "source": "tests/contracts/math.algo.ts:164", + "pc": [ + 2286 + ] + }, + { + "teal": 1567, + "source": "tests/contracts/math.algo.ts:164", + "pc": [ + 2287 + ] + }, + { + "teal": 1568, + "source": "tests/contracts/math.algo.ts:164", + "pc": [ + 2288, + 2289 + ] + }, + { + "teal": 1569, + "source": "tests/contracts/math.algo.ts:164", + "pc": [ + 2290 + ] + }, + { + "teal": 1573, + "source": "tests/contracts/math.algo.ts:164", + "pc": [ + 2291, + 2292, + 2293 + ] + }, + { + "teal": 1577, + "source": "tests/contracts/math.algo.ts:165", + "pc": [ + 2294, + 2295 + ] + }, + { + "teal": 1578, + "source": "tests/contracts/math.algo.ts:165", + "pc": [ + 2296 + ] + }, + { + "teal": 1579, + "source": "tests/contracts/math.algo.ts:164", + "pc": [ + 2297 + ] + }, + { + "teal": 1584, + "source": "tests/contracts/math.algo.ts:168", + "pc": [ + 2298, + 2299, + 2300, + 2301, + 2302, + 2303 + ] + }, + { + "teal": 1587, + "source": "tests/contracts/math.algo.ts:168", + "pc": [ + 2304, + 2305, + 2306 + ] + }, + { + "teal": 1588, + "source": "tests/contracts/math.algo.ts:168", + "pc": [ + 2307 + ] + }, + { + "teal": 1589, + "source": "tests/contracts/math.algo.ts:168", + "pc": [ + 2308 + ] + }, + { + "teal": 1590, + "source": "tests/contracts/math.algo.ts:168", + "pc": [ + 2309, + 2310 + ] + }, + { + "teal": 1591, + "source": "tests/contracts/math.algo.ts:168", + "pc": [ + 2311 + ] + }, + { + "teal": 1594, + "source": "tests/contracts/math.algo.ts:168", + "errorMessage": "argument 0 (a) for bitwiseNotU256 must be a uint256", + "pc": [ + 2312 + ] + }, + { + "teal": 1597, + "source": "tests/contracts/math.algo.ts:168", + "pc": [ + 2313, + 2314, + 2315 + ] + }, + { + "teal": 1598, + "source": "tests/contracts/math.algo.ts:168", + "pc": [ + 2316 + ] + }, + { + "teal": 1599, + "source": "tests/contracts/math.algo.ts:168", + "pc": [ + 2317 + ] + }, + { + "teal": 1600, + "source": "tests/contracts/math.algo.ts:168", + "pc": [ + 2318, + 2319, + 2320 + ] + }, + { + "teal": 1601, + "source": "tests/contracts/math.algo.ts:168", + "pc": [ + 2321 + ] + }, + { + "teal": 1604, + "source": "tests/contracts/math.algo.ts:168", + "errorMessage": "bitwiseNotU256 return value overflowed 256 bits", + "pc": [ + 2322 + ] + }, + { + "teal": 1605, + "source": "tests/contracts/math.algo.ts:168", + "pc": [ + 2323, + 2324, + 2325, + 2326, + 2327, + 2328, + 2329, + 2330, + 2331, + 2332, + 2333, + 2334, + 2335, + 2336, + 2337, + 2338, + 2339, + 2340, + 2341, + 2342, + 2343, + 2344, + 2345, + 2346, + 2347, + 2348, + 2349, + 2350, + 2351, + 2352, + 2353, + 2354, + 2355, + 2356 + ] + }, + { + "teal": 1606, + "source": "tests/contracts/math.algo.ts:168", + "pc": [ + 2357 + ] + }, + { + "teal": 1607, + "source": "tests/contracts/math.algo.ts:168", + "pc": [ + 2358 + ] + }, + { + "teal": 1608, + "source": "tests/contracts/math.algo.ts:168", + "pc": [ + 2359 + ] + }, + { + "teal": 1609, + "source": "tests/contracts/math.algo.ts:168", + "pc": [ + 2360 + ] + }, + { + "teal": 1610, + "source": "tests/contracts/math.algo.ts:168", + "pc": [ + 2361, + 2362 + ] + }, + { + "teal": 1611, + "source": "tests/contracts/math.algo.ts:168", + "pc": [ + 2363 + ] + }, + { + "teal": 1612, + "source": "tests/contracts/math.algo.ts:168", + "pc": [ + 2364 + ] + }, + { + "teal": 1613, + "source": "tests/contracts/math.algo.ts:168", + "pc": [ + 2365 + ] + }, + { + "teal": 1614, + "source": "tests/contracts/math.algo.ts:168", + "pc": [ + 2366 + ] + }, + { + "teal": 1615, + "source": "tests/contracts/math.algo.ts:168", + "pc": [ + 2367 + ] + }, + { + "teal": 1616, + "source": "tests/contracts/math.algo.ts:168", + "pc": [ + 2368, + 2369 + ] + }, + { + "teal": 1617, + "source": "tests/contracts/math.algo.ts:168", + "pc": [ + 2370 + ] + }, + { + "teal": 1621, + "source": "tests/contracts/math.algo.ts:168", + "pc": [ + 2371, + 2372, + 2373 + ] + }, + { + "teal": 1625, + "source": "tests/contracts/math.algo.ts:169", + "pc": [ + 2374, + 2375 + ] + }, + { + "teal": 1626, + "source": "tests/contracts/math.algo.ts:169", + "pc": [ + 2376 + ] + }, + { + "teal": 1627, + "source": "tests/contracts/math.algo.ts:168", + "pc": [ + 2377 + ] + }, + { + "teal": 1632, + "source": "tests/contracts/math.algo.ts:172", + "pc": [ + 2378, + 2379, + 2380, + 2381, + 2382, + 2383 + ] + }, + { + "teal": 1635, + "source": "tests/contracts/math.algo.ts:172", + "pc": [ + 2384, + 2385, + 2386 + ] + }, + { + "teal": 1636, + "source": "tests/contracts/math.algo.ts:172", + "pc": [ + 2387 + ] + }, + { + "teal": 1639, + "source": "tests/contracts/math.algo.ts:172", + "pc": [ + 2388, + 2389, + 2390 + ] + }, + { + "teal": 1640, + "source": "tests/contracts/math.algo.ts:172", + "pc": [ + 2391 + ] + }, + { + "teal": 1643, + "source": "tests/contracts/math.algo.ts:172", + "pc": [ + 2392, + 2393, + 2394 + ] + }, + { + "teal": 1644, + "source": "tests/contracts/math.algo.ts:172", + "pc": [ + 2395 + ] + }, + { + "teal": 1645, + "source": "tests/contracts/math.algo.ts:172", + "pc": [ + 2396 + ] + }, + { + "teal": 1646, + "source": "tests/contracts/math.algo.ts:172", + "pc": [ + 2397 + ] + }, + { + "teal": 1647, + "source": "tests/contracts/math.algo.ts:172", + "pc": [ + 2398, + 2399 + ] + }, + { + "teal": 1648, + "source": "tests/contracts/math.algo.ts:172", + "pc": [ + 2400 + ] + }, + { + "teal": 1652, + "source": "tests/contracts/math.algo.ts:172", + "pc": [ + 2401, + 2402, + 2403 + ] + }, + { + "teal": 1655, + "source": "tests/contracts/math.algo.ts:172", + "pc": [ + 2404, + 2405 + ] + }, + { + "teal": 1656, + "source": "tests/contracts/math.algo.ts:172", + "pc": [ + 2406 + ] + }, + { + "teal": 1660, + "source": "tests/contracts/math.algo.ts:173", + "pc": [ + 2407, + 2408 + ] + }, + { + "teal": 1661, + "source": "tests/contracts/math.algo.ts:173", + "pc": [ + 2409, + 2410 + ] + }, + { + "teal": 1662, + "source": "tests/contracts/math.algo.ts:173", + "pc": [ + 2411 + ] + }, + { + "teal": 1663, + "source": "tests/contracts/math.algo.ts:173", + "pc": [ + 2412, + 2413 + ] + }, + { + "teal": 1664, + "source": "tests/contracts/math.algo.ts:173", + "pc": [ + 2414, + 2415 + ] + }, + { + "teal": 1668, + "source": "tests/contracts/math.algo.ts:177", + "pc": [ + 2416, + 2417 + ] + }, + { + "teal": 1671, + "source": "tests/contracts/math.algo.ts:172", + "pc": [ + 2418, + 2419 + ] + }, + { + "teal": 1674, + "source": "tests/contracts/math.algo.ts:172", + "pc": [ + 2420, + 2421 + ] + }, + { + "teal": 1675, + "source": "tests/contracts/math.algo.ts:172", + "pc": [ + 2422 + ] + }, + { + "teal": 1680, + "source": "tests/contracts/math.algo.ts:180", + "pc": [ + 2423, + 2424, + 2425, + 2426, + 2427, + 2428 + ] + }, + { + "teal": 1683, + "source": "tests/contracts/math.algo.ts:180", + "pc": [ + 2429, + 2430, + 2431 + ] + }, + { + "teal": 1684, + "source": "tests/contracts/math.algo.ts:180", + "pc": [ + 2432 + ] + }, + { + "teal": 1687, + "source": "tests/contracts/math.algo.ts:180", + "pc": [ + 2433, + 2434, + 2435 + ] + }, + { + "teal": 1688, + "source": "tests/contracts/math.algo.ts:180", + "pc": [ + 2436 + ] + }, + { + "teal": 1691, + "source": "tests/contracts/math.algo.ts:180", + "pc": [ + 2437, + 2438, + 2439 + ] + }, + { + "teal": 1692, + "source": "tests/contracts/math.algo.ts:180", + "pc": [ + 2440 + ] + }, + { + "teal": 1693, + "source": "tests/contracts/math.algo.ts:180", + "pc": [ + 2441 + ] + }, + { + "teal": 1694, + "source": "tests/contracts/math.algo.ts:180", + "pc": [ + 2442 + ] + }, + { + "teal": 1695, + "source": "tests/contracts/math.algo.ts:180", + "pc": [ + 2443, + 2444 + ] + }, + { + "teal": 1696, + "source": "tests/contracts/math.algo.ts:180", + "pc": [ + 2445 + ] + }, + { + "teal": 1700, + "source": "tests/contracts/math.algo.ts:180", + "pc": [ + 2446, + 2447, + 2448 + ] + }, + { + "teal": 1703, + "source": "tests/contracts/math.algo.ts:180", + "pc": [ + 2449, + 2450 + ] + }, + { + "teal": 1704, + "source": "tests/contracts/math.algo.ts:180", + "pc": [ + 2451 + ] + }, + { + "teal": 1708, + "source": "tests/contracts/math.algo.ts:181", + "pc": [ + 2452, + 2453 + ] + }, + { + "teal": 1709, + "source": "tests/contracts/math.algo.ts:181", + "pc": [ + 2454, + 2455 + ] + }, + { + "teal": 1710, + "source": "tests/contracts/math.algo.ts:181", + "pc": [ + 2456 + ] + }, + { + "teal": 1711, + "source": "tests/contracts/math.algo.ts:181", + "pc": [ + 2457, + 2458 + ] + }, + { + "teal": 1712, + "source": "tests/contracts/math.algo.ts:181", + "pc": [ + 2459, + 2460 + ] + }, + { + "teal": 1716, + "source": "tests/contracts/math.algo.ts:185", + "pc": [ + 2461, + 2462 + ] + }, + { + "teal": 1719, + "source": "tests/contracts/math.algo.ts:180", + "pc": [ + 2463, + 2464 + ] + }, + { + "teal": 1722, + "source": "tests/contracts/math.algo.ts:180", + "pc": [ + 2465, + 2466 + ] + }, + { + "teal": 1723, + "source": "tests/contracts/math.algo.ts:180", + "pc": [ + 2467 + ] + }, + { + "teal": 1728, + "source": "tests/contracts/math.algo.ts:188", + "pc": [ + 2468, + 2469, + 2470, + 2471, + 2472, + 2473 + ] + }, + { + "teal": 1731, + "source": "tests/contracts/math.algo.ts:188", + "pc": [ + 2474, + 2475, + 2476 + ] + }, + { + "teal": 1732, + "source": "tests/contracts/math.algo.ts:188", + "pc": [ + 2477 + ] + }, + { + "teal": 1735, + "source": "tests/contracts/math.algo.ts:188", + "pc": [ + 2478, + 2479, + 2480 + ] + }, + { + "teal": 1736, + "source": "tests/contracts/math.algo.ts:188", + "pc": [ + 2481 + ] + }, + { + "teal": 1739, + "source": "tests/contracts/math.algo.ts:188", + "pc": [ + 2482, + 2483, + 2484 + ] + }, + { + "teal": 1740, + "source": "tests/contracts/math.algo.ts:188", + "pc": [ + 2485 + ] + }, + { + "teal": 1741, + "source": "tests/contracts/math.algo.ts:188", + "pc": [ + 2486 + ] + }, + { + "teal": 1742, + "source": "tests/contracts/math.algo.ts:188", + "pc": [ + 2487 + ] + }, + { + "teal": 1743, + "source": "tests/contracts/math.algo.ts:188", + "pc": [ + 2488, + 2489 + ] + }, + { + "teal": 1744, + "source": "tests/contracts/math.algo.ts:188", + "pc": [ + 2490 + ] + }, + { + "teal": 1748, + "source": "tests/contracts/math.algo.ts:188", + "pc": [ + 2491, + 2492, + 2493 + ] + }, + { + "teal": 1751, + "source": "tests/contracts/math.algo.ts:188", + "pc": [ + 2494, + 2495 + ] + }, + { + "teal": 1752, + "source": "tests/contracts/math.algo.ts:188", + "pc": [ + 2496 + ] + }, + { + "teal": 1756, + "source": "tests/contracts/math.algo.ts:189", + "pc": [ + 2497, + 2498 + ] + }, + { + "teal": 1757, + "source": "tests/contracts/math.algo.ts:189", + "pc": [ + 2499, + 2500 + ] + }, + { + "teal": 1758, + "source": "tests/contracts/math.algo.ts:189", + "pc": [ + 2501 + ] + }, + { + "teal": 1759, + "source": "tests/contracts/math.algo.ts:189", + "pc": [ + 2502, + 2503 + ] + }, + { + "teal": 1760, + "source": "tests/contracts/math.algo.ts:189", + "pc": [ + 2504, + 2505 + ] + }, + { + "teal": 1764, + "source": "tests/contracts/math.algo.ts:193", + "pc": [ + 2506, + 2507 + ] + }, + { + "teal": 1767, + "source": "tests/contracts/math.algo.ts:188", + "pc": [ + 2508, + 2509 + ] + }, + { + "teal": 1770, + "source": "tests/contracts/math.algo.ts:188", + "pc": [ + 2510, + 2511 + ] + }, + { + "teal": 1771, + "source": "tests/contracts/math.algo.ts:188", + "pc": [ + 2512 + ] + }, + { + "teal": 1776, + "source": "tests/contracts/math.algo.ts:196", + "pc": [ + 2513, + 2514, + 2515, + 2516, + 2517, + 2518 + ] + }, + { + "teal": 1779, + "source": "tests/contracts/math.algo.ts:196", + "pc": [ + 2519, + 2520, + 2521 + ] + }, + { + "teal": 1780, + "source": "tests/contracts/math.algo.ts:196", + "pc": [ + 2522 + ] + }, + { + "teal": 1783, + "source": "tests/contracts/math.algo.ts:196", + "pc": [ + 2523, + 2524, + 2525 + ] + }, + { + "teal": 1784, + "source": "tests/contracts/math.algo.ts:196", + "pc": [ + 2526 + ] + }, + { + "teal": 1787, + "source": "tests/contracts/math.algo.ts:196", + "pc": [ + 2527, + 2528, + 2529 + ] + }, + { + "teal": 1788, + "source": "tests/contracts/math.algo.ts:196", + "pc": [ + 2530 + ] + }, + { + "teal": 1789, + "source": "tests/contracts/math.algo.ts:196", + "pc": [ + 2531 + ] + }, + { + "teal": 1790, + "source": "tests/contracts/math.algo.ts:196", + "pc": [ + 2532 + ] + }, + { + "teal": 1791, + "source": "tests/contracts/math.algo.ts:196", + "pc": [ + 2533, + 2534 + ] + }, + { + "teal": 1792, + "source": "tests/contracts/math.algo.ts:196", + "pc": [ + 2535 + ] + }, + { + "teal": 1796, + "source": "tests/contracts/math.algo.ts:196", + "pc": [ + 2536, + 2537, + 2538 + ] + }, + { + "teal": 1800, + "source": "tests/contracts/math.algo.ts:197", + "pc": [ + 2539, + 2540 + ] + }, + { + "teal": 1801, + "source": "tests/contracts/math.algo.ts:197", + "pc": [ + 2541, + 2542 + ] + }, + { + "teal": 1802, + "source": "tests/contracts/math.algo.ts:197", + "pc": [ + 2543, + 2544 + ] + }, + { + "teal": 1803, + "source": "tests/contracts/math.algo.ts:197", + "pc": [ + 2545 + ] + }, + { + "teal": 1804, + "source": "tests/contracts/math.algo.ts:196", + "pc": [ + 2546 + ] + }, + { + "teal": 1809, + "source": "tests/contracts/math.algo.ts:200", + "pc": [ + 2547, + 2548, + 2549, + 2550, + 2551, + 2552 + ] + }, + { + "teal": 1812, + "source": "tests/contracts/math.algo.ts:200", + "pc": [ + 2553, + 2554, + 2555 + ] + }, + { + "teal": 1813, + "source": "tests/contracts/math.algo.ts:200", + "pc": [ + 2556 + ] + }, + { + "teal": 1816, + "source": "tests/contracts/math.algo.ts:200", + "pc": [ + 2557, + 2558, + 2559 + ] + }, + { + "teal": 1817, + "source": "tests/contracts/math.algo.ts:200", + "pc": [ + 2560 + ] + }, + { + "teal": 1820, + "source": "tests/contracts/math.algo.ts:200", + "pc": [ + 2561, + 2562, + 2563 + ] + }, + { + "teal": 1821, + "source": "tests/contracts/math.algo.ts:200", + "pc": [ + 2564 + ] + }, + { + "teal": 1822, + "source": "tests/contracts/math.algo.ts:200", + "pc": [ + 2565 + ] + }, + { + "teal": 1823, + "source": "tests/contracts/math.algo.ts:200", + "pc": [ + 2566 + ] + }, + { + "teal": 1824, + "source": "tests/contracts/math.algo.ts:200", + "pc": [ + 2567, + 2568 + ] + }, + { + "teal": 1825, + "source": "tests/contracts/math.algo.ts:200", + "pc": [ + 2569 + ] + }, + { + "teal": 1829, + "source": "tests/contracts/math.algo.ts:200", + "pc": [ + 2570, + 2571, + 2572 + ] + }, + { + "teal": 1832, + "source": "tests/contracts/math.algo.ts:200", + "pc": [ + 2573, + 2574 + ] + }, + { + "teal": 1833, + "source": "tests/contracts/math.algo.ts:200", + "pc": [ + 2575, + 2576 + ] + }, + { + "teal": 1837, + "source": "tests/contracts/math.algo.ts:201", + "pc": [ + 2577, + 2578 + ] + }, + { + "teal": 1838, + "source": "tests/contracts/math.algo.ts:201", + "pc": [ + 2579, + 2580 + ] + }, + { + "teal": 1839, + "source": "tests/contracts/math.algo.ts:201", + "pc": [ + 2581, + 2582 + ] + }, + { + "teal": 1840, + "source": "tests/contracts/math.algo.ts:201", + "pc": [ + 2583, + 2584 + ] + }, + { + "teal": 1841, + "source": "tests/contracts/math.algo.ts:201", + "pc": [ + 2585 + ] + }, + { + "teal": 1842, + "source": "tests/contracts/math.algo.ts:201", + "pc": [ + 2586, + 2587 + ] + }, + { + "teal": 1843, + "source": "tests/contracts/math.algo.ts:201", + "pc": [ + 2588, + 2589 + ] + }, + { + "teal": 1844, + "source": "tests/contracts/math.algo.ts:201", + "pc": [ + 2590, + 2591 + ] + }, + { + "teal": 1845, + "source": "tests/contracts/math.algo.ts:201", + "pc": [ + 2592, + 2593 + ] + }, + { + "teal": 1849, + "source": "tests/contracts/math.algo.ts:205", + "pc": [ + 2594, + 2595 + ] + }, + { + "teal": 1852, + "source": "tests/contracts/math.algo.ts:200", + "pc": [ + 2596, + 2597 + ] + }, + { + "teal": 1855, + "source": "tests/contracts/math.algo.ts:200", + "pc": [ + 2598, + 2599 + ] + }, + { + "teal": 1856, + "source": "tests/contracts/math.algo.ts:200", + "pc": [ + 2600 + ] + }, + { + "teal": 1861, + "source": "tests/contracts/math.algo.ts:208", + "pc": [ + 2601, + 2602, + 2603, + 2604, + 2605, + 2606 + ] + }, + { + "teal": 1864, + "source": "tests/contracts/math.algo.ts:208", + "pc": [ + 2607, + 2608, + 2609 + ] + }, + { + "teal": 1865, + "source": "tests/contracts/math.algo.ts:208", + "pc": [ + 2610 + ] + }, + { + "teal": 1866, + "source": "tests/contracts/math.algo.ts:208", + "pc": [ + 2611 + ] + }, + { + "teal": 1867, + "source": "tests/contracts/math.algo.ts:208", + "pc": [ + 2612 + ] + }, + { + "teal": 1868, + "source": "tests/contracts/math.algo.ts:208", + "pc": [ + 2613, + 2614 + ] + }, + { + "teal": 1869, + "source": "tests/contracts/math.algo.ts:208", + "pc": [ + 2615 + ] + }, + { + "teal": 1873, + "source": "tests/contracts/math.algo.ts:208", + "pc": [ + 2616, + 2617, + 2618 + ] + }, + { + "teal": 1876, + "source": "tests/contracts/math.algo.ts:208", + "pc": [ + 2619, + 2620 + ] + }, + { + "teal": 1877, + "source": "tests/contracts/math.algo.ts:208", + "pc": [ + 2621, + 2622 + ] + }, + { + "teal": 1881, + "source": "tests/contracts/math.algo.ts:209", + "pc": [ + 2623, + 2624, + 2625, + 2626, + 2627, + 2628, + 2629, + 2630, + 2631, + 2632, + 2633, + 2634, + 2635, + 2636, + 2637, + 2638, + 2639, + 2640, + 2641, + 2642, + 2643, + 2644, + 2645, + 2646, + 2647, + 2648, + 2649, + 2650, + 2651, + 2652, + 2653, + 2654, + 2655, + 2656 + ] + }, + { + "teal": 1882, + "source": "tests/contracts/math.algo.ts:209", + "pc": [ + 2657, + 2658 + ] + }, + { + "teal": 1886, + "source": "tests/contracts/math.algo.ts:210", + "pc": [ + 2659, + 2660, + 2661, + 2662, + 2663, + 2664, + 2665, + 2666, + 2667, + 2668, + 2669, + 2670, + 2671, + 2672, + 2673, + 2674, + 2675, + 2676, + 2677, + 2678, + 2679, + 2680, + 2681, + 2682, + 2683, + 2684, + 2685, + 2686, + 2687, + 2688, + 2689, + 2690, + 2691, + 2692 + ] + }, + { + "teal": 1887, + "source": "tests/contracts/math.algo.ts:210", + "pc": [ + 2693, + 2694 + ] + }, + { + "teal": 1891, + "source": "tests/contracts/math.algo.ts:212", + "pc": [ + 2695, + 2696 + ] + }, + { + "teal": 1892, + "source": "tests/contracts/math.algo.ts:212", + "pc": [ + 2697, + 2698, + 2699, + 2700, + 2701, + 2702, + 2703, + 2704, + 2705, + 2706, + 2707, + 2708, + 2709, + 2710, + 2711, + 2712, + 2713, + 2714, + 2715, + 2716, + 2717, + 2718, + 2719, + 2720, + 2721, + 2722, + 2723, + 2724, + 2725, + 2726, + 2727, + 2728, + 2729, + 2730 + ] + }, + { + "teal": 1893, + "source": "tests/contracts/math.algo.ts:212", + "pc": [ + 2731 + ] + }, + { + "teal": 1894, + "source": "tests/contracts/math.algo.ts:212", + "pc": [ + 2732, + 2733 + ] + }, + { + "teal": 1898, + "source": "tests/contracts/math.algo.ts:214", + "pc": [ + 2734, + 2735 + ] + }, + { + "teal": 1899, + "source": "tests/contracts/math.algo.ts:214", + "pc": [ + 2736 + ] + }, + { + "teal": 1900, + "source": "tests/contracts/math.algo.ts:214", + "pc": [ + 2737 + ] + }, + { + "teal": 1901, + "source": "tests/contracts/math.algo.ts:214", + "pc": [ + 2738, + 2739 + ] + }, + { + "teal": 1902, + "source": "tests/contracts/math.algo.ts:214", + "pc": [ + 2740 + ] + }, + { + "teal": 1905, + "source": "tests/contracts/math.algo.ts:214", + "errorMessage": "A as uint64 overflowed 64 bits", + "pc": [ + 2741 + ] + }, + { + "teal": 1906, + "source": "tests/contracts/math.algo.ts:214", + "pc": [ + 2742, + 2743, + 2744, + 2745, + 2746, + 2747, + 2748, + 2749, + 2750, + 2751 + ] + }, + { + "teal": 1907, + "source": "tests/contracts/math.algo.ts:214", + "pc": [ + 2752 + ] + }, + { + "teal": 1908, + "source": "tests/contracts/math.algo.ts:214", + "pc": [ + 2753 + ] + }, + { + "teal": 1909, + "source": "tests/contracts/math.algo.ts:214", + "pc": [ + 2754 + ] + }, + { + "teal": 1910, + "source": "tests/contracts/math.algo.ts:214", + "pc": [ + 2755 + ] + }, + { + "teal": 1911, + "source": "tests/contracts/math.algo.ts:214", + "pc": [ + 2756, + 2757 + ] + }, + { + "teal": 1912, + "source": "tests/contracts/math.algo.ts:214", + "pc": [ + 2758 + ] + }, + { + "teal": 1913, + "source": "tests/contracts/math.algo.ts:214", + "pc": [ + 2759 + ] + }, + { + "teal": 1914, + "source": "tests/contracts/math.algo.ts:214", + "pc": [ + 2760 + ] + }, + { + "teal": 1915, + "source": "tests/contracts/math.algo.ts:214", + "pc": [ + 2761 + ] + }, + { + "teal": 1916, + "source": "tests/contracts/math.algo.ts:214", + "pc": [ + 2762, + 2763 + ] + }, + { + "teal": 1920, + "source": "tests/contracts/math.algo.ts:216", + "pc": [ + 2764, + 2765 + ] + }, + { + "teal": 1923, + "source": "tests/contracts/math.algo.ts:208", + "pc": [ + 2766, + 2767 + ] + }, + { + "teal": 1926, + "source": "tests/contracts/math.algo.ts:208", + "pc": [ + 2768, + 2769 + ] + }, + { + "teal": 1927, + "source": "tests/contracts/math.algo.ts:208", + "pc": [ + 2770 + ] + }, + { + "teal": 1932, + "source": "tests/contracts/math.algo.ts:219", + "pc": [ + 2771, + 2772, + 2773, + 2774, + 2775, + 2776 + ] + }, + { + "teal": 1935, + "source": "tests/contracts/math.algo.ts:219", + "pc": [ + 2777, + 2778, + 2779 + ] + }, + { + "teal": 1936, + "source": "tests/contracts/math.algo.ts:219", + "pc": [ + 2780 + ] + }, + { + "teal": 1937, + "source": "tests/contracts/math.algo.ts:219", + "pc": [ + 2781 + ] + }, + { + "teal": 1938, + "source": "tests/contracts/math.algo.ts:219", + "pc": [ + 2782, + 2783 + ] + }, + { + "teal": 1939, + "source": "tests/contracts/math.algo.ts:219", + "pc": [ + 2784 + ] + }, + { + "teal": 1942, + "source": "tests/contracts/math.algo.ts:219", + "errorMessage": "argument 0 (x) for foobar must be a uint128", + "pc": [ + 2785 + ] + }, + { + "teal": 1945, + "source": "tests/contracts/math.algo.ts:219", + "pc": [ + 2786, + 2787, + 2788 + ] + }, + { + "teal": 1946, + "source": "tests/contracts/math.algo.ts:219", + "pc": [ + 2789 + ] + }, + { + "teal": 1947, + "source": "tests/contracts/math.algo.ts:219", + "pc": [ + 2790 + ] + }, + { + "teal": 1948, + "source": "tests/contracts/math.algo.ts:219", + "pc": [ + 2791, + 2792, + 2793 + ] + }, + { + "teal": 1949, + "source": "tests/contracts/math.algo.ts:219", + "pc": [ + 2794 + ] + }, + { + "teal": 1952, + "source": "tests/contracts/math.algo.ts:219", + "errorMessage": "foobar return value overflowed 128 bits", + "pc": [ + 2795 + ] + }, + { + "teal": 1953, + "source": "tests/contracts/math.algo.ts:219", + "pc": [ + 2796, + 2797, + 2798, + 2799, + 2800, + 2801, + 2802, + 2803, + 2804, + 2805, + 2806, + 2807, + 2808, + 2809, + 2810, + 2811, + 2812, + 2813 + ] + }, + { + "teal": 1954, + "source": "tests/contracts/math.algo.ts:219", + "pc": [ + 2814 + ] + }, + { + "teal": 1955, + "source": "tests/contracts/math.algo.ts:219", + "pc": [ + 2815 + ] + }, + { + "teal": 1956, + "source": "tests/contracts/math.algo.ts:219", + "pc": [ + 2816 + ] + }, + { + "teal": 1957, + "source": "tests/contracts/math.algo.ts:219", + "pc": [ + 2817 + ] + }, + { + "teal": 1958, + "source": "tests/contracts/math.algo.ts:219", + "pc": [ + 2818, + 2819 + ] + }, + { + "teal": 1959, + "source": "tests/contracts/math.algo.ts:219", + "pc": [ + 2820 + ] + }, + { + "teal": 1960, + "source": "tests/contracts/math.algo.ts:219", + "pc": [ + 2821 + ] + }, + { + "teal": 1961, + "source": "tests/contracts/math.algo.ts:219", + "pc": [ + 2822 + ] + }, + { + "teal": 1962, + "source": "tests/contracts/math.algo.ts:219", + "pc": [ + 2823 + ] + }, + { + "teal": 1963, + "source": "tests/contracts/math.algo.ts:219", + "pc": [ + 2824 + ] + }, + { + "teal": 1964, + "source": "tests/contracts/math.algo.ts:219", + "pc": [ + 2825, + 2826 + ] + }, + { + "teal": 1965, + "source": "tests/contracts/math.algo.ts:219", + "pc": [ + 2827 + ] + }, + { + "teal": 1969, + "source": "tests/contracts/math.algo.ts:219", + "pc": [ + 2828, + 2829, + 2830 + ] + }, + { + "teal": 1972, + "source": "tests/contracts/math.algo.ts:219", + "pc": [ + 2831, + 2832 + ] + }, + { + "teal": 1976, + "source": "tests/contracts/math.algo.ts:220", + "pc": [ + 2833, + 2834 + ] + }, + { + "teal": 1977, + "source": "tests/contracts/math.algo.ts:220", + "pc": [ + 2835, + 2836, + 2837, + 2838, + 2839, + 2840, + 2841, + 2842, + 2843, + 2844, + 2845, + 2846, + 2847, + 2848, + 2849, + 2850, + 2851, + 2852 + ] + }, + { + "teal": 1978, + "source": "tests/contracts/math.algo.ts:220", + "pc": [ + 2853 + ] + }, + { + "teal": 1979, + "source": "tests/contracts/math.algo.ts:220", + "pc": [ + 2854 + ] + }, + { + "teal": 1980, + "source": "tests/contracts/math.algo.ts:220", + "pc": [ + 2855 + ] + }, + { + "teal": 1981, + "source": "tests/contracts/math.algo.ts:220", + "pc": [ + 2856, + 2857, + 2858 + ] + }, + { + "teal": 1982, + "source": "tests/contracts/math.algo.ts:220", + "pc": [ + 2859 + ] + }, + { + "teal": 1985, + "source": "tests/contracts/math.algo.ts:220", + "errorMessage": "x / (30000 as uint128) overflowed 128 bits", + "pc": [ + 2860 + ] + }, + { + "teal": 1986, + "source": "tests/contracts/math.algo.ts:220", + "pc": [ + 2861, + 2862, + 2863, + 2864, + 2865, + 2866, + 2867, + 2868, + 2869, + 2870, + 2871, + 2872, + 2873, + 2874, + 2875, + 2876, + 2877, + 2878 + ] + }, + { + "teal": 1987, + "source": "tests/contracts/math.algo.ts:220", + "pc": [ + 2879 + ] + }, + { + "teal": 1988, + "source": "tests/contracts/math.algo.ts:220", + "pc": [ + 2880 + ] + }, + { + "teal": 1989, + "source": "tests/contracts/math.algo.ts:220", + "pc": [ + 2881 + ] + }, + { + "teal": 1990, + "source": "tests/contracts/math.algo.ts:220", + "pc": [ + 2882 + ] + }, + { + "teal": 1991, + "source": "tests/contracts/math.algo.ts:220", + "pc": [ + 2883, + 2884 + ] + }, + { + "teal": 1992, + "source": "tests/contracts/math.algo.ts:220", + "pc": [ + 2885 + ] + }, + { + "teal": 1993, + "source": "tests/contracts/math.algo.ts:220", + "pc": [ + 2886 + ] + }, + { + "teal": 1994, + "source": "tests/contracts/math.algo.ts:220", + "pc": [ + 2887 + ] + }, + { + "teal": 1995, + "source": "tests/contracts/math.algo.ts:220", + "pc": [ + 2888, + 2889 + ] + }, + { + "teal": 1999, + "source": "tests/contracts/math.algo.ts:222", + "pc": [ + 2890, + 2891 + ] + }, + { + "teal": 2002, + "source": "tests/contracts/math.algo.ts:219", + "pc": [ + 2892, + 2893 + ] + }, + { + "teal": 2003, + "source": "tests/contracts/math.algo.ts:219", + "pc": [ + 2894 + ] + }, + { + "teal": 2008, + "source": "tests/contracts/math.algo.ts:225", + "pc": [ + 2895, + 2896, + 2897, + 2898, + 2899, + 2900 + ] + }, + { + "teal": 2011, + "source": "tests/contracts/math.algo.ts:225", + "pc": [ + 2901, + 2902, + 2903 + ] + }, + { + "teal": 2012, + "source": "tests/contracts/math.algo.ts:225", + "pc": [ + 2904 + ] + }, + { + "teal": 2013, + "source": "tests/contracts/math.algo.ts:225", + "pc": [ + 2905 + ] + }, + { + "teal": 2014, + "source": "tests/contracts/math.algo.ts:225", + "pc": [ + 2906, + 2907, + 2908 + ] + }, + { + "teal": 2015, + "source": "tests/contracts/math.algo.ts:225", + "pc": [ + 2909 + ] + }, + { + "teal": 2018, + "source": "tests/contracts/math.algo.ts:225", + "errorMessage": "uintFromHex return value overflowed 256 bits", + "pc": [ + 2910 + ] + }, + { + "teal": 2019, + "source": "tests/contracts/math.algo.ts:225", + "pc": [ + 2911, + 2912, + 2913, + 2914, + 2915, + 2916, + 2917, + 2918, + 2919, + 2920, + 2921, + 2922, + 2923, + 2924, + 2925, + 2926, + 2927, + 2928, + 2929, + 2930, + 2931, + 2932, + 2933, + 2934, + 2935, + 2936, + 2937, + 2938, + 2939, + 2940, + 2941, + 2942, + 2943, + 2944 + ] + }, + { + "teal": 2020, + "source": "tests/contracts/math.algo.ts:225", + "pc": [ + 2945 + ] + }, + { + "teal": 2021, + "source": "tests/contracts/math.algo.ts:225", + "pc": [ + 2946 + ] + }, + { + "teal": 2022, + "source": "tests/contracts/math.algo.ts:225", + "pc": [ + 2947 + ] + }, + { + "teal": 2023, + "source": "tests/contracts/math.algo.ts:225", + "pc": [ + 2948 + ] + }, + { + "teal": 2024, + "source": "tests/contracts/math.algo.ts:225", + "pc": [ + 2949, + 2950 + ] + }, + { + "teal": 2025, + "source": "tests/contracts/math.algo.ts:225", + "pc": [ + 2951 + ] + }, + { + "teal": 2026, + "source": "tests/contracts/math.algo.ts:225", + "pc": [ + 2952 + ] }, { + "teal": 2027, + "source": "tests/contracts/math.algo.ts:225", "pc": [ - 340 - ], - "errorMessage": "argument 0 (b) for u256plus must be a uint256" + 2953 + ] }, { + "teal": 2028, + "source": "tests/contracts/math.algo.ts:225", "pc": [ - 349 - ], - "errorMessage": "argument 1 (a) for u256plus must be a uint256" + 2954 + ] }, { + "teal": 2029, + "source": "tests/contracts/math.algo.ts:225", "pc": [ - 359 - ], - "errorMessage": "u256plus return value overflowed 256 bits" + 2955 + ] }, { + "teal": 2030, + "source": "tests/contracts/math.algo.ts:225", "pc": [ - 431 - ], - "errorMessage": "argument 0 (b) for u256minus must be a uint256" + 2956, + 2957 + ] }, { + "teal": 2031, + "source": "tests/contracts/math.algo.ts:225", "pc": [ - 440 - ], - "errorMessage": "argument 1 (a) for u256minus must be a uint256" + 2958 + ] }, { + "teal": 2035, + "source": "tests/contracts/math.algo.ts:225", "pc": [ - 450 - ], - "errorMessage": "u256minus return value overflowed 256 bits" + 2959, + 2960, + 2961 + ] }, { + "teal": 2039, + "source": "tests/contracts/math.algo.ts:226", "pc": [ - 522 - ], - "errorMessage": "argument 0 (b) for u256mul must be a uint256" + 2962, + 2963, + 2964, + 2965, + 2966, + 2967, + 2968, + 2969, + 2970, + 2971, + 2972, + 2973, + 2974, + 2975, + 2976, + 2977, + 2978, + 2979, + 2980, + 2981, + 2982, + 2983, + 2984, + 2985, + 2986, + 2987, + 2988, + 2989, + 2990, + 2991, + 2992, + 2993, + 2994, + 2995 + ] }, { + "teal": 2040, + "source": "tests/contracts/math.algo.ts:225", "pc": [ - 531 - ], - "errorMessage": "argument 1 (a) for u256mul must be a uint256" + 2996 + ] }, { + "teal": 2045, + "source": "tests/contracts/math.algo.ts:229", "pc": [ - 541 - ], - "errorMessage": "u256mul return value overflowed 256 bits" + 2997, + 2998, + 2999, + 3000, + 3001, + 3002 + ] }, { + "teal": 2048, + "source": "tests/contracts/math.algo.ts:229", "pc": [ - 613 - ], - "errorMessage": "argument 0 (b) for u256div must be a uint256" + 3003, + 3004, + 3005 + ] }, { + "teal": 2049, + "source": "tests/contracts/math.algo.ts:229", "pc": [ - 622 - ], - "errorMessage": "argument 1 (a) for u256div must be a uint256" + 3006 + ] }, { + "teal": 2050, + "source": "tests/contracts/math.algo.ts:229", "pc": [ - 632 - ], - "errorMessage": "u256div return value overflowed 256 bits" + 3007 + ] }, { + "teal": 2051, + "source": "tests/contracts/math.algo.ts:229", "pc": [ - 713 - ], - "errorMessage": "u64Return256 return value overflowed 256 bits" + 3008 + ] }, { + "teal": 2052, + "source": "tests/contracts/math.algo.ts:229", "pc": [ - 848 - ], - "errorMessage": "argument 0 (y) for variableTypeHint must be a uint8" + 3009, + 3010 + ] }, { + "teal": 2053, + "source": "tests/contracts/math.algo.ts:229", "pc": [ - 858 - ], - "errorMessage": "argument 1 (x) for variableTypeHint must be a uint8" + 3011 + ] }, { + "teal": 2057, + "source": "tests/contracts/math.algo.ts:229", "pc": [ - 869 - ], - "errorMessage": "variableTypeHint return value overflowed 16 bits" + 3012, + 3013, + 3014 + ] }, { + "teal": 2061, + "source": "tests/contracts/math.algo.ts:230", "pc": [ - 909 - ], - "errorMessage": "argument 0 (b) for uint8plus must be a uint8" + 3015, + 3016, + 3017, + 3018, + 3019, + 3020, + 3021, + 3022, + 3023, + 3024, + 3025 + ] }, { + "teal": 2062, + "source": "tests/contracts/math.algo.ts:230", "pc": [ - 919 - ], - "errorMessage": "argument 1 (a) for uint8plus must be a uint8" + 3026, + 3027 + ] }, { + "teal": 2063, + "source": "tests/contracts/math.algo.ts:230", "pc": [ - 930 - ], - "errorMessage": "uint8plus return value overflowed 8 bits" + 3028 + ] }, { + "teal": 2064, + "source": "tests/contracts/math.algo.ts:230", "pc": [ - 962 - ], - "errorMessage": "argument 0 (b) for uint8exp must be a uint8" + 3029, + 3030 + ] }, { + "teal": 2065, + "source": "tests/contracts/math.algo.ts:230", "pc": [ - 972 - ], - "errorMessage": "argument 1 (a) for uint8exp must be a uint8" + 3031, + 3032 + ] }, { + "teal": 2066, + "source": "tests/contracts/math.algo.ts:230", "pc": [ - 983 - ], - "errorMessage": "uint8exp return value overflowed 8 bits" + 3033, + 3034 + ] }, { + "teal": 2067, + "source": "tests/contracts/math.algo.ts:230", "pc": [ - 1121 - ], - "errorMessage": "boxTest return value overflowed 256 bits" + 3035 + ] }, { + "teal": 2068, + "source": "tests/contracts/math.algo.ts:230", "pc": [ - 1225 - ], - "errorMessage": "box value does not exist: this.boxKey.value" + 3036, + 3037 + ] }, { + "teal": 2069, + "source": "tests/contracts/math.algo.ts:230", "pc": [ - 1275 - ], - "errorMessage": "this.boxKey.value overflowed 256 bits" + 3038 + ] }, { + "teal": 2070, + "source": "tests/contracts/math.algo.ts:230", "pc": [ - 1330 - ], - "errorMessage": "box value does not exist: this.boxKey.value" + 3039, + 3040 + ] }, { + "teal": 2071, + "source": "tests/contracts/math.algo.ts:230", "pc": [ - 1352 - ], - "errorMessage": "argument 0 (b) for unsafeMethodArgs must be a uint256" + 3041 + ] }, { + "teal": 2072, + "source": "tests/contracts/math.algo.ts:230", "pc": [ - 1361 - ], - "errorMessage": "argument 1 (a) for unsafeMethodArgs must be a uint256" + 3042 + ] }, { + "teal": 2073, + "source": "tests/contracts/math.algo.ts:230", "pc": [ - 1371 - ], - "errorMessage": "unsafeMethodArgs return value overflowed 256 bits" + 3043, + 3044 + ] }, { + "teal": 2074, + "source": "tests/contracts/math.algo.ts:230", "pc": [ - 1440 - ], - "errorMessage": "c overflowed 256 bits" + 3045, + 3046 + ] }, { + "teal": 2075, + "source": "tests/contracts/math.algo.ts:230", "pc": [ - 1498 - ], - "errorMessage": "argument 0 (b) for uint256ComparisonType must be a uint256" + 3047, + 3048 + ] }, { + "teal": 2076, + "source": "tests/contracts/math.algo.ts:230", "pc": [ - 1507 - ], - "errorMessage": "argument 1 (a) for uint256ComparisonType must be a uint256" + 3049 + ] }, { + "teal": 2077, + "source": "tests/contracts/math.algo.ts:230", "pc": [ - 1601 - ], - "errorMessage": "argument 0 (b) for squareRoot256 must be a uint256" + 3050, + 3051 + ] }, { + "teal": 2078, + "source": "tests/contracts/math.algo.ts:230", "pc": [ - 1610 - ], - "errorMessage": "argument 1 (a) for squareRoot256 must be a uint256" + 3052 + ] }, { + "teal": 2079, + "source": "tests/contracts/math.algo.ts:230", "pc": [ - 1620 - ], - "errorMessage": "squareRoot256 return value overflowed 256 bits" + 3053, + 3054 + ] }, { + "teal": 2080, + "source": "tests/contracts/math.algo.ts:230", "pc": [ - 1726 - ], - "errorMessage": "argument 0 (addr) for addressToBigInt must be a address" + 3055 + ] }, { + "teal": 2081, + "source": "tests/contracts/math.algo.ts:230", "pc": [ - 1799 - ], - "errorMessage": "argument 0 (x) for funcName must be a uint256" + 3056 + ] }, { + "teal": 2082, + "source": "tests/contracts/math.algo.ts:230", "pc": [ - 1819 - ], - "errorMessage": "x overflowed 8 bits" + 3057, + 3058 + ] }, { + "teal": 2083, + "source": "tests/contracts/math.algo.ts:230", "pc": [ - 1877 - ], - "errorMessage": "(btobigint(x) + btobigint(y)) as uint64 overflowed 64 bits" + 3059, + 3060 + ] }, { + "teal": 2084, + "source": "tests/contracts/math.algo.ts:230", "pc": [ - 2013 - ], - "errorMessage": "argument 0 (b) for bitwiseOrU256 must be a uint256" + 3061, + 3062 + ] }, { + "teal": 2085, + "source": "tests/contracts/math.algo.ts:230", "pc": [ - 2022 - ], - "errorMessage": "argument 1 (a) for bitwiseOrU256 must be a uint256" + 3063 + ] }, { + "teal": 2086, + "source": "tests/contracts/math.algo.ts:230", "pc": [ - 2032 - ], - "errorMessage": "bitwiseOrU256 return value overflowed 256 bits" + 3064, + 3065 + ] }, { + "teal": 2087, + "source": "tests/contracts/math.algo.ts:230", "pc": [ - 2104 - ], - "errorMessage": "argument 0 (b) for bitwiseAndU256 must be a uint256" + 3066 + ] }, { + "teal": 2088, + "source": "tests/contracts/math.algo.ts:230", "pc": [ - 2113 - ], - "errorMessage": "argument 1 (a) for bitwiseAndU256 must be a uint256" + 3067, + 3068 + ] }, { + "teal": 2089, + "source": "tests/contracts/math.algo.ts:230", "pc": [ - 2123 - ], - "errorMessage": "bitwiseAndU256 return value overflowed 256 bits" + 3069 + ] }, { + "teal": 2090, + "source": "tests/contracts/math.algo.ts:230", "pc": [ - 2195 - ], - "errorMessage": "argument 0 (b) for bitwiseXorU256 must be a uint256" + 3070 + ] }, { + "teal": 2091, + "source": "tests/contracts/math.algo.ts:230", "pc": [ - 2204 - ], - "errorMessage": "argument 1 (a) for bitwiseXorU256 must be a uint256" + 3071, + 3072 + ] }, { + "teal": 2092, + "source": "tests/contracts/math.algo.ts:230", "pc": [ - 2214 - ], - "errorMessage": "bitwiseXorU256 return value overflowed 256 bits" + 3073, + 3074 + ] }, { + "teal": 2093, + "source": "tests/contracts/math.algo.ts:230", "pc": [ - 2312 - ], - "errorMessage": "argument 0 (a) for bitwiseNotU256 must be a uint256" + 3075 + ] }, { + "teal": 2094, + "source": "tests/contracts/math.algo.ts:230", "pc": [ - 2322 - ], - "errorMessage": "bitwiseNotU256 return value overflowed 256 bits" + 3076, + 3077 + ] }, { + "teal": 2095, + "source": "tests/contracts/math.algo.ts:230", "pc": [ - 2741 - ], - "errorMessage": "A as uint64 overflowed 64 bits" + 3078, + 3079 + ] }, { + "teal": 2096, + "source": "tests/contracts/math.algo.ts:230", "pc": [ - 2785 - ], - "errorMessage": "argument 0 (x) for foobar must be a uint128" + 3080, + 3081 + ] }, { + "teal": 2097, + "source": "tests/contracts/math.algo.ts:230", "pc": [ - 2795 - ], - "errorMessage": "foobar return value overflowed 128 bits" + 3082 + ] }, { + "teal": 2098, + "source": "tests/contracts/math.algo.ts:230", "pc": [ - 2860 - ], - "errorMessage": "x / (30000 as uint128) overflowed 128 bits" + 3083, + 3084 + ] }, { + "teal": 2099, + "source": "tests/contracts/math.algo.ts:230", "pc": [ - 2910 - ], - "errorMessage": "uintFromHex return value overflowed 256 bits" + 3085 + ] + }, + { + "teal": 2100, + "source": "tests/contracts/math.algo.ts:230", + "pc": [ + 3086, + 3087 + ] + }, + { + "teal": 2101, + "source": "tests/contracts/math.algo.ts:230", + "pc": [ + 3088 + ] + }, + { + "teal": 2102, + "source": "tests/contracts/math.algo.ts:230", + "pc": [ + 3089 + ] }, { + "teal": 2103, + "source": "tests/contracts/math.algo.ts:230", + "pc": [ + 3090, + 3091 + ] + }, + { + "teal": 2104, + "source": "tests/contracts/math.algo.ts:230", + "pc": [ + 3092, + 3093 + ] + }, + { + "teal": 2105, + "source": "tests/contracts/math.algo.ts:230", + "pc": [ + 3094, + 3095 + ] + }, + { + "teal": 2106, + "source": "tests/contracts/math.algo.ts:230", + "pc": [ + 3096 + ] + }, + { + "teal": 2107, + "source": "tests/contracts/math.algo.ts:230", + "pc": [ + 3097, + 3098 + ] + }, + { + "teal": 2108, + "source": "tests/contracts/math.algo.ts:230", + "pc": [ + 3099 + ] + }, + { + "teal": 2109, + "source": "tests/contracts/math.algo.ts:230", + "pc": [ + 3100, + 3101 + ] + }, + { + "teal": 2110, + "source": "tests/contracts/math.algo.ts:230", + "pc": [ + 3102 + ] + }, + { + "teal": 2111, + "source": "tests/contracts/math.algo.ts:230", + "pc": [ + 3103 + ] + }, + { + "teal": 2112, + "source": "tests/contracts/math.algo.ts:230", + "pc": [ + 3104 + ] + }, + { + "teal": 2113, + "source": "tests/contracts/math.algo.ts:230", + "pc": [ + 3105 + ] + }, + { + "teal": 2114, + "source": "tests/contracts/math.algo.ts:230", + "pc": [ + 3106 + ] + }, + { + "teal": 2115, + "source": "tests/contracts/math.algo.ts:230", + "pc": [ + 3107 + ] + }, + { + "teal": 2116, + "source": "tests/contracts/math.algo.ts:230", + "pc": [ + 3108 + ] + }, + { + "teal": 2119, + "source": "tests/contracts/math.algo.ts:230", + "errorMessage": "wideRatio failed", "pc": [ 3109 - ], - "errorMessage": "wideRatio failed" + ] + }, + { + "teal": 2120, + "source": "tests/contracts/math.algo.ts:229", + "pc": [ + 3110 + ] + }, + { + "teal": 2123, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 3111, + 3112 + ] }, { + "teal": 2124, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 3113 + ] + }, + { + "teal": 2127, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 3114, + 3115, + 3116, + 3117, + 3118, + 3119 + ] + }, + { + "teal": 2128, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 3120, + 3121, + 3122 + ] + }, + { + "teal": 2129, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 3123, + 3124, + 3125, + 3126 + ] + }, + { + "teal": 2132, + "source": "tests/contracts/math.algo.ts:4", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 3127 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 2135, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 3128, + 3129, + 3130, + 3131, + 3132, + 3133 + ] + }, + { + "teal": 2136, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 3134, + 3135, + 3136, + 3137, + 3138, + 3139 + ] + }, + { + "teal": 2137, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 3140, + 3141, + 3142, + 3143, + 3144, + 3145 + ] + }, + { + "teal": 2138, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 3146, + 3147, + 3148, + 3149, + 3150, + 3151 + ] + }, + { + "teal": 2139, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 3152, + 3153, + 3154, + 3155, + 3156, + 3157 + ] + }, + { + "teal": 2140, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 3158, + 3159, + 3160, + 3161, + 3162, + 3163 + ] + }, + { + "teal": 2141, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 3164, + 3165, + 3166, + 3167, + 3168, + 3169 + ] + }, + { + "teal": 2142, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 3170, + 3171, + 3172, + 3173, + 3174, + 3175 + ] + }, + { + "teal": 2143, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 3176, + 3177, + 3178, + 3179, + 3180, + 3181 + ] + }, + { + "teal": 2144, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 3182, + 3183, + 3184, + 3185, + 3186, + 3187 + ] + }, + { + "teal": 2145, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 3188, + 3189, + 3190, + 3191, + 3192, + 3193 + ] + }, + { + "teal": 2146, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 3194, + 3195, + 3196, + 3197, + 3198, + 3199 + ] + }, + { + "teal": 2147, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 3200, + 3201, + 3202, + 3203, + 3204, + 3205 + ] + }, + { + "teal": 2148, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 3206, + 3207, + 3208, + 3209, + 3210, + 3211 + ] + }, + { + "teal": 2149, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 3212, + 3213, + 3214, + 3215, + 3216, + 3217 + ] + }, + { + "teal": 2150, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 3218, + 3219, + 3220, + 3221, + 3222, + 3223 + ] + }, + { + "teal": 2151, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 3224, + 3225, + 3226, + 3227, + 3228, + 3229 + ] + }, + { + "teal": 2152, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 3230, + 3231, + 3232, + 3233, + 3234, + 3235 + ] + }, + { + "teal": 2153, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 3236, + 3237, + 3238, + 3239, + 3240, + 3241 + ] + }, + { + "teal": 2154, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 3242, + 3243, + 3244, + 3245, + 3246, + 3247 + ] + }, + { + "teal": 2155, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 3248, + 3249, + 3250, + 3251, + 3252, + 3253 + ] + }, + { + "teal": 2156, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 3254, + 3255, + 3256, + 3257, + 3258, + 3259 + ] + }, + { + "teal": 2157, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 3260, + 3261, + 3262, + 3263, + 3264, + 3265 + ] + }, + { + "teal": 2158, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 3266, + 3267, + 3268, + 3269, + 3270, + 3271 + ] + }, + { + "teal": 2159, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 3272, + 3273, + 3274, + 3275, + 3276, + 3277 + ] + }, + { + "teal": 2160, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 3278, + 3279, + 3280, + 3281, + 3282, + 3283 + ] + }, + { + "teal": 2161, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 3284, + 3285, + 3286, + 3287, + 3288, + 3289 + ] + }, + { + "teal": 2162, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 3290, + 3291, + 3292, + 3293, + 3294, + 3295 + ] + }, + { + "teal": 2163, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 3296, + 3297, + 3298, + 3299, + 3300, + 3301 + ] + }, + { + "teal": 2164, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 3302, + 3303, + 3304, + 3305, + 3306, + 3307 + ] + }, + { + "teal": 2165, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 3308, + 3309, + 3310, + 3311, + 3312, + 3313 + ] + }, + { + "teal": 2166, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 3314, + 3315, + 3316, + 3317, + 3318, + 3319 + ] + }, + { + "teal": 2167, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 3320, + 3321, + 3322, + 3323, + 3324, + 3325 + ] + }, + { + "teal": 2168, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 3326, + 3327, + 3328, + 3329, + 3330, + 3331 + ] + }, + { + "teal": 2169, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 3332, + 3333, + 3334, + 3335, + 3336, + 3337 + ] + }, + { + "teal": 2170, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 3338, + 3339, + 3340, + 3341, + 3342, + 3343 + ] + }, + { + "teal": 2171, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 3344, + 3345, + 3346, + 3347, + 3348, + 3349 + ] + }, + { + "teal": 2172, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 3350, + 3351, + 3352, + 3353, + 3354, + 3355 + ] + }, + { + "teal": 2173, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 3356, + 3357, + 3358, + 3359, + 3360, + 3361 + ] + }, + { + "teal": 2174, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 3362, + 3363, + 3364, + 3365, + 3366, + 3367 + ] + }, + { + "teal": 2175, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 3368, + 3369, + 3370, + 3371, + 3372, + 3373 + ] + }, + { + "teal": 2176, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 3374, + 3375, + 3376, + 3377, + 3378, + 3379 + ] + }, + { + "teal": 2177, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 3380, + 3381, + 3382 + ] + }, + { + "teal": 2178, + "source": "tests/contracts/math.algo.ts:4", + "pc": [ + 3383, + 3384, + 3385, + 3386, + 3387, + 3388, + 3389, + 3390, + 3391, + 3392, + 3393, + 3394, + 3395, + 3396, + 3397, + 3398, + 3399, + 3400, + 3401, + 3402, + 3403, + 3404, + 3405, + 3406, + 3407, + 3408, + 3409, + 3410, + 3411, + 3412, + 3413, + 3414, + 3415, + 3416, + 3417, + 3418, + 3419, + 3420, + 3421, + 3422, + 3423, + 3424, + 3425, + 3426, + 3427, + 3428, + 3429, + 3430, + 3431, + 3432, + 3433, + 3434, + 3435, + 3436, + 3437, + 3438, + 3439, + 3440, + 3441, + 3442, + 3443, + 3444, + 3445, + 3446, + 3447, + 3448, + 3449, + 3450, + 3451, + 3452, + 3453, + 3454, + 3455, + 3456, + 3457, + 3458, + 3459, + 3460, + 3461, + 3462, + 3463, + 3464, + 3465, + 3466, + 3467, + 3468 + ] }, { + "teal": 2181, + "source": "tests/contracts/math.algo.ts:4", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 3469 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/MultiInheritance.arc56_draft.json b/tests/contracts/artifacts/MultiInheritance.arc56_draft.json index aa342625d..22d4ff858 100644 --- a/tests/contracts/artifacts/MultiInheritance.arc56_draft.json +++ b/tests/contracts/artifacts/MultiInheritance.arc56_draft.json @@ -114,22 +114,629 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/inheritance.algo.ts:92", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/inheritance.algo.ts:92", + "pc": [ + 1, + 2, + 3, + 4 + ] + }, + { + "teal": 14, + "source": "tests/contracts/inheritance.algo.ts:92", + "pc": [ + 5, + 6 + ] + }, + { + "teal": 15, + "source": "tests/contracts/inheritance.algo.ts:92", + "pc": [ + 7 + ] + }, + { + "teal": 16, + "source": "tests/contracts/inheritance.algo.ts:92", + "pc": [ + 8, + 9 + ] + }, + { + "teal": 17, + "source": "tests/contracts/inheritance.algo.ts:92", + "pc": [ + 10 + ] + }, + { + "teal": 18, + "source": "tests/contracts/inheritance.algo.ts:92", + "pc": [ + 11, + 12 + ] + }, + { + "teal": 19, + "source": "tests/contracts/inheritance.algo.ts:92", + "pc": [ + 13 + ] + }, + { + "teal": 20, + "source": "tests/contracts/inheritance.algo.ts:92", + "pc": [ + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38, + 39 + ] + }, + { + "teal": 24, + "source": "tests/contracts/inheritance.algo.ts:92", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 40 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 29, + "source": "tests/contracts/inheritance.algo.ts:15", + "pc": [ + 41, + 42, + 43 + ] + }, + { + "teal": 30, + "source": "tests/contracts/inheritance.algo.ts:15", + "pc": [ + 44, + 45 + ] + }, + { + "teal": 31, + "source": "tests/contracts/inheritance.algo.ts:15", + "pc": [ + 46 + ] + }, + { + "teal": 35, + "source": "tests/contracts/inheritance.algo.ts:15", + "pc": [ + 47, + 48, + 49 + ] + }, + { + "teal": 39, + "source": "tests/contracts/inheritance.algo.ts:16", + "pc": [ + 50, + 51, + 52 + ] }, { + "teal": 40, + "source": "tests/contracts/inheritance.algo.ts:16", + "pc": [ + 53, + 54, + 55 + ] + }, + { + "teal": 41, + "source": "tests/contracts/inheritance.algo.ts:16", + "pc": [ + 56 + ] + }, + { + "teal": 42, + "source": "tests/contracts/inheritance.algo.ts:15", + "pc": [ + 57 + ] + }, + { + "teal": 47, + "source": "tests/contracts/inheritance.algo.ts:23", + "pc": [ + 58, + 59, + 60 + ] + }, + { + "teal": 48, + "source": "tests/contracts/inheritance.algo.ts:23", + "pc": [ + 61, + 62 + ] + }, + { + "teal": 49, + "source": "tests/contracts/inheritance.algo.ts:23", + "pc": [ + 63 + ] + }, + { + "teal": 53, + "source": "tests/contracts/inheritance.algo.ts:23", + "pc": [ + 64, + 65, + 66 + ] + }, + { + "teal": 57, + "source": "tests/contracts/inheritance.algo.ts:24", + "pc": [ + 67, + 68, + 69 + ] + }, + { + "teal": 58, + "source": "tests/contracts/inheritance.algo.ts:24", + "pc": [ + 70 + ] + }, + { + "teal": 59, + "source": "tests/contracts/inheritance.algo.ts:24", + "pc": [ + 71, + 72, + 73 + ] + }, + { + "teal": 60, + "source": "tests/contracts/inheritance.algo.ts:24", + "pc": [ + 74 + ] + }, + { + "teal": 61, + "source": "tests/contracts/inheritance.algo.ts:24", + "pc": [ + 75 + ] + }, + { + "teal": 65, + "source": "tests/contracts/inheritance.algo.ts:25", + "pc": [ + 76, + 77, + 78 + ] + }, + { + "teal": 66, + "source": "tests/contracts/inheritance.algo.ts:25", + "pc": [ + 79, + 80 + ] + }, + { + "teal": 67, + "source": "tests/contracts/inheritance.algo.ts:25", + "pc": [ + 81 + ] + }, + { + "teal": 68, + "source": "tests/contracts/inheritance.algo.ts:23", + "pc": [ + 82 + ] + }, + { + "teal": 73, + "source": "tests/contracts/inheritance.algo.ts:87", + "pc": [ + 83, + 84, + 85 + ] + }, + { + "teal": 74, + "source": "tests/contracts/inheritance.algo.ts:87", + "pc": [ + 86, + 87 + ] + }, + { + "teal": 75, + "source": "tests/contracts/inheritance.algo.ts:87", + "pc": [ + 88 + ] + }, + { + "teal": 79, + "source": "tests/contracts/inheritance.algo.ts:87", + "pc": [ + 89, + 90, + 91 + ] + }, + { + "teal": 83, + "source": "tests/contracts/inheritance.algo.ts:88", + "pc": [ + 92, + 93, + 94, + 95 + ] + }, + { + "teal": 84, + "source": "tests/contracts/inheritance.algo.ts:88", + "pc": [ + 96 + ] + }, + { + "teal": 85, + "source": "tests/contracts/inheritance.algo.ts:87", + "pc": [ + 97 + ] + }, + { + "teal": 90, + "source": "tests/contracts/inheritance.algo.ts:93", + "pc": [ + 98, + 99, + 100 + ] + }, + { + "teal": 91, + "source": "tests/contracts/inheritance.algo.ts:93", + "pc": [ + 101, + 102 + ] + }, + { + "teal": 92, + "source": "tests/contracts/inheritance.algo.ts:93", + "pc": [ + 103 + ] + }, + { + "teal": 96, + "source": "tests/contracts/inheritance.algo.ts:93", + "pc": [ + 104, + 105, + 106 + ] + }, + { + "teal": 100, + "source": "tests/contracts/inheritance.algo.ts:94", + "pc": [ + 107, + 108, + 109, + 110, + 111, + 112, + 113, + 114, + 115, + 116, + 117, + 118, + 119, + 120, + 121, + 122, + 123, + 124, + 125, + 126, + 127, + 128, + 129, + 130, + 131, + 132, + 133, + 134, + 135, + 136, + 137, + 138, + 139, + 140, + 141, + 142, + 143, + 144, + 145, + 146, + 147, + 148, + 149, + 150, + 151, + 152, + 153, + 154, + 155, + 156, + 157, + 158, + 159, + 160, + 161, + 162, + 163, + 164, + 165, + 166, + 167, + 168, + 169, + 170, + 171, + 172, + 173, + 174, + 175, + 176, + 177, + 178, + 179, + 180, + 181, + 182, + 183, + 184, + 185, + 186, + 187, + 188, + 189, + 190, + 191, + 192, + 193, + 194, + 195, + 196, + 197, + 198, + 199, + 200, + 201, + 202, + 203, + 204, + 205, + 206, + 207, + 208, + 209, + 210, + 211, + 212, + 213, + 214, + 215, + 216 + ] + }, + { + "teal": 101, + "source": "tests/contracts/inheritance.algo.ts:94", + "pc": [ + 217 + ] + }, + { + "teal": 102, + "source": "tests/contracts/inheritance.algo.ts:93", + "pc": [ + 218 + ] + }, + { + "teal": 105, + "source": "tests/contracts/inheritance.algo.ts:92", + "pc": [ + 219, + 220 + ] + }, + { + "teal": 106, + "source": "tests/contracts/inheritance.algo.ts:92", + "pc": [ + 221 + ] + }, + { + "teal": 109, + "source": "tests/contracts/inheritance.algo.ts:92", + "pc": [ + 222, + 223, + 224, + 225, + 226, + 227 + ] + }, + { + "teal": 110, + "source": "tests/contracts/inheritance.algo.ts:92", + "pc": [ + 228, + 229, + 230 + ] + }, + { + "teal": 111, + "source": "tests/contracts/inheritance.algo.ts:92", + "pc": [ + 231, + 232, + 233, + 234 + ] + }, + { + "teal": 114, + "source": "tests/contracts/inheritance.algo.ts:92", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 235 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 117, + "source": "tests/contracts/inheritance.algo.ts:92", + "pc": [ + 236, + 237, + 238, + 239, + 240, + 241 + ] + }, + { + "teal": 118, + "source": "tests/contracts/inheritance.algo.ts:92", + "pc": [ + 242, + 243, + 244, + 245, + 246, + 247 + ] + }, + { + "teal": 119, + "source": "tests/contracts/inheritance.algo.ts:92", + "pc": [ + 248, + 249, + 250, + 251, + 252, + 253 + ] + }, + { + "teal": 120, + "source": "tests/contracts/inheritance.algo.ts:92", + "pc": [ + 254, + 255, + 256, + 257, + 258, + 259 + ] + }, + { + "teal": 121, + "source": "tests/contracts/inheritance.algo.ts:92", + "pc": [ + 260, + 261, + 262 + ] + }, + { + "teal": 122, + "source": "tests/contracts/inheritance.algo.ts:92", + "pc": [ + 263, + 264, + 265, + 266, + 267, + 268, + 269, + 270, + 271, + 272 + ] }, { + "teal": 125, + "source": "tests/contracts/inheritance.algo.ts:92", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 273 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/MultiInheritanceProgram.arc56_draft.json b/tests/contracts/artifacts/MultiInheritanceProgram.arc56_draft.json index 348d72651..ed729c355 100644 --- a/tests/contracts/artifacts/MultiInheritanceProgram.arc56_draft.json +++ b/tests/contracts/artifacts/MultiInheritanceProgram.arc56_draft.json @@ -64,22 +64,519 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/inheritance.algo.ts:98", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/inheritance.algo.ts:98", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/inheritance.algo.ts:98", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/inheritance.algo.ts:98", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/inheritance.algo.ts:98", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/inheritance.algo.ts:98", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/inheritance.algo.ts:98", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/inheritance.algo.ts:98", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/inheritance.algo.ts:98", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 28, + "source": "tests/contracts/inheritance.algo.ts:99", + "pc": [ + 37, + 38, + 39 + ] }, { + "teal": 29, + "source": "tests/contracts/inheritance.algo.ts:99", + "pc": [ + 40, + 41 + ] + }, + { + "teal": 30, + "source": "tests/contracts/inheritance.algo.ts:99", + "pc": [ + 42 + ] + }, + { + "teal": 34, + "source": "tests/contracts/inheritance.algo.ts:99", + "pc": [ + 43, + 44, + 45 + ] + }, + { + "teal": 38, + "source": "tests/contracts/inheritance.algo.ts:100", + "pc": [ + 46, + 47, + 48, + 49, + 50, + 51, + 52, + 53, + 54, + 55, + 56, + 57, + 58, + 59, + 60, + 61, + 62, + 63, + 64, + 65, + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82, + 83, + 84, + 85, + 86, + 87, + 88, + 89, + 90, + 91, + 92, + 93, + 94, + 95, + 96, + 97, + 98, + 99, + 100, + 101, + 102, + 103, + 104, + 105, + 106, + 107, + 108, + 109, + 110, + 111, + 112, + 113, + 114, + 115, + 116, + 117, + 118, + 119, + 120, + 121, + 122, + 123, + 124, + 125, + 126, + 127, + 128, + 129, + 130, + 131, + 132, + 133, + 134, + 135, + 136, + 137, + 138, + 139, + 140, + 141, + 142, + 143, + 144, + 145, + 146, + 147, + 148, + 149, + 150, + 151, + 152, + 153, + 154, + 155, + 156, + 157, + 158, + 159, + 160, + 161, + 162, + 163, + 164, + 165, + 166, + 167, + 168, + 169, + 170, + 171, + 172, + 173, + 174, + 175, + 176, + 177, + 178, + 179, + 180, + 181, + 182, + 183, + 184, + 185, + 186, + 187, + 188, + 189, + 190, + 191, + 192, + 193, + 194, + 195, + 196, + 197, + 198, + 199, + 200, + 201, + 202, + 203, + 204, + 205, + 206, + 207, + 208, + 209, + 210, + 211, + 212, + 213, + 214, + 215, + 216, + 217, + 218, + 219, + 220, + 221, + 222, + 223, + 224, + 225, + 226, + 227, + 228, + 229, + 230, + 231, + 232, + 233, + 234, + 235, + 236, + 237, + 238, + 239, + 240, + 241, + 242, + 243, + 244, + 245, + 246, + 247, + 248, + 249, + 250, + 251, + 252, + 253, + 254, + 255, + 256, + 257, + 258, + 259, + 260, + 261, + 262, + 263, + 264, + 265, + 266, + 267, + 268, + 269, + 270, + 271, + 272, + 273, + 274, + 275, + 276, + 277, + 278, + 279, + 280, + 281, + 282, + 283, + 284, + 285, + 286, + 287, + 288, + 289, + 290, + 291, + 292, + 293, + 294, + 295, + 296, + 297, + 298, + 299, + 300, + 301, + 302, + 303, + 304, + 305, + 306, + 307, + 308, + 309, + 310, + 311, + 312, + 313, + 314, + 315, + 316, + 317, + 318, + 319, + 320, + 321, + 322 + ] + }, + { + "teal": 39, + "source": "tests/contracts/inheritance.algo.ts:100", + "pc": [ + 323 + ] + }, + { + "teal": 40, + "source": "tests/contracts/inheritance.algo.ts:99", + "pc": [ + 324 + ] + }, + { + "teal": 43, + "source": "tests/contracts/inheritance.algo.ts:98", + "pc": [ + 325, + 326 + ] + }, + { + "teal": 44, + "source": "tests/contracts/inheritance.algo.ts:98", + "pc": [ + 327 + ] + }, + { + "teal": 47, + "source": "tests/contracts/inheritance.algo.ts:98", + "pc": [ + 328, + 329, + 330, + 331, + 332, + 333 + ] + }, + { + "teal": 48, + "source": "tests/contracts/inheritance.algo.ts:98", + "pc": [ + 334, + 335, + 336 + ] + }, + { + "teal": 49, + "source": "tests/contracts/inheritance.algo.ts:98", + "pc": [ + 337, + 338, + 339, + 340 + ] + }, + { + "teal": 52, + "source": "tests/contracts/inheritance.algo.ts:98", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 341 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 55, + "source": "tests/contracts/inheritance.algo.ts:98", + "pc": [ + 342, + 343, + 344, + 345, + 346, + 347 + ] + }, + { + "teal": 56, + "source": "tests/contracts/inheritance.algo.ts:98", + "pc": [ + 348, + 349, + 350 + ] + }, + { + "teal": 57, + "source": "tests/contracts/inheritance.algo.ts:98", + "pc": [ + 351, + 352, + 353, + 354 + ] }, { + "teal": 60, + "source": "tests/contracts/inheritance.algo.ts:98", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 355 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/ProgramVersion.arc56_draft.json b/tests/contracts/artifacts/ProgramVersion.arc56_draft.json index 2a0cb08e9..c13725044 100644 --- a/tests/contracts/artifacts/ProgramVersion.arc56_draft.json +++ b/tests/contracts/artifacts/ProgramVersion.arc56_draft.json @@ -51,16 +51,150 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/general.algo.ts:52", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/general.algo.ts:52", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/general.algo.ts:52", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/general.algo.ts:52", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/general.algo.ts:52", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/general.algo.ts:52", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/general.algo.ts:52", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/general.algo.ts:52", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/general.algo.ts:52", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 26, + "source": "tests/contracts/general.algo.ts:52", + "pc": [ + 37, + 38 + ] + }, + { + "teal": 27, + "source": "tests/contracts/general.algo.ts:52", + "pc": [ + 39 + ] + }, + { + "teal": 30, + "source": "tests/contracts/general.algo.ts:52", + "pc": [ + 40, + 41, + 42, + 43, + 44, + 45 + ] + }, + { + "teal": 31, + "source": "tests/contracts/general.algo.ts:52", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 32, + "source": "tests/contracts/general.algo.ts:52", + "pc": [ + 49, + 50, + 51, + 52 + ] }, { + "teal": 35, + "source": "tests/contracts/general.algo.ts:52", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 53 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/SchemaContract.arc56_draft.json b/tests/contracts/artifacts/SchemaContract.arc56_draft.json index 728ee4585..dd355e719 100644 --- a/tests/contracts/artifacts/SchemaContract.arc56_draft.json +++ b/tests/contracts/artifacts/SchemaContract.arc56_draft.json @@ -69,16 +69,150 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/general.algo.ts:13", + "pc": [ + 0 + ] + }, + { + "teal": 13, + "source": "tests/contracts/general.algo.ts:13", + "pc": [ + 1, + 2 + ] + }, + { + "teal": 14, + "source": "tests/contracts/general.algo.ts:13", + "pc": [ + 3 + ] + }, + { + "teal": 15, + "source": "tests/contracts/general.algo.ts:13", + "pc": [ + 4, + 5 + ] + }, + { + "teal": 16, + "source": "tests/contracts/general.algo.ts:13", + "pc": [ + 6 + ] + }, + { + "teal": 17, + "source": "tests/contracts/general.algo.ts:13", + "pc": [ + 7, + 8 + ] + }, + { + "teal": 18, + "source": "tests/contracts/general.algo.ts:13", + "pc": [ + 9 + ] + }, + { + "teal": 19, + "source": "tests/contracts/general.algo.ts:13", + "pc": [ + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35 + ] + }, + { + "teal": 23, + "source": "tests/contracts/general.algo.ts:13", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 36 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 26, + "source": "tests/contracts/general.algo.ts:13", + "pc": [ + 37, + 38 + ] + }, + { + "teal": 27, + "source": "tests/contracts/general.algo.ts:13", + "pc": [ + 39 + ] + }, + { + "teal": 30, + "source": "tests/contracts/general.algo.ts:13", + "pc": [ + 40, + 41, + 42, + 43, + 44, + 45 + ] + }, + { + "teal": 31, + "source": "tests/contracts/general.algo.ts:13", + "pc": [ + 46, + 47, + 48 + ] + }, + { + "teal": 32, + "source": "tests/contracts/general.algo.ts:13", + "pc": [ + 49, + 50, + 51, + 52 + ] }, { + "teal": 35, + "source": "tests/contracts/general.algo.ts:13", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 53 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/StorageTest.arc56_draft.json b/tests/contracts/artifacts/StorageTest.arc56_draft.json index 881aa768e..22756b967 100644 --- a/tests/contracts/artifacts/StorageTest.arc56_draft.json +++ b/tests/contracts/artifacts/StorageTest.arc56_draft.json @@ -682,118 +682,5267 @@ "approval": { "sourceInfo": [ { + "teal": 1, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 0 + ] + }, + { + "teal": 2, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 1, + 2, + 3, + 4, + 5, + 6 + ] + }, + { + "teal": 3, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 7, + 8, + 9, + 10, + 11, + 12, + 13, + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38, + 39, + 40, + 41, + 42, + 43, + 44, + 45, + 46, + 47, + 48, + 49, + 50 + ] + }, + { + "teal": 15, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 51, + 52 + ] + }, + { + "teal": 16, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 53 + ] + }, + { + "teal": 17, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 54, + 55 + ] + }, + { + "teal": 18, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 56 + ] + }, + { + "teal": 19, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 57, + 58 + ] + }, + { + "teal": 20, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 59 + ] + }, + { + "teal": 21, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 60, + 61, + 62, + 63, + 64, + 65, + 66, + 67, + 68, + 69, + 70, + 71, + 72, + 73, + 74, + 75, + 76, + 77, + 78, + 79, + 80, + 81, + 82, + 83, + 84, + 85 + ] + }, + { + "teal": 25, + "source": "tests/contracts/storage.algo.ts:4", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 86 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 30, + "source": "tests/contracts/storage.algo.ts:25", + "pc": [ + 87, + 88, + 89 + ] + }, + { + "teal": 31, + "source": "tests/contracts/storage.algo.ts:25", + "pc": [ + 90, + 91 + ] + }, + { + "teal": 32, + "source": "tests/contracts/storage.algo.ts:25", + "pc": [ + 92 + ] + }, + { + "teal": 36, + "source": "tests/contracts/storage.algo.ts:25", + "pc": [ + 93, + 94, + 95 + ] + }, + { + "teal": 40, + "source": "tests/contracts/storage.algo.ts:26", + "pc": [ + 96, + 97, + 98, + 99, + 100 + ] + }, + { + "teal": 41, + "source": "tests/contracts/storage.algo.ts:26", + "pc": [ + 101 + ] + }, + { + "teal": 42, + "source": "tests/contracts/storage.algo.ts:26", + "pc": [ + 102 + ] + }, + { + "teal": 43, + "source": "tests/contracts/storage.algo.ts:26", + "pc": [ + 103 + ] + }, + { + "teal": 44, + "source": "tests/contracts/storage.algo.ts:26", + "pc": [ + 104, + 105, + 106, + 107, + 108 + ] + }, + { + "teal": 45, + "source": "tests/contracts/storage.algo.ts:26", + "pc": [ + 109 + ] + }, + { + "teal": 49, + "source": "tests/contracts/storage.algo.ts:27", + "pc": [ + 110, + 111, + 112, + 113, + 114 + ] + }, + { + "teal": 50, + "source": "tests/contracts/storage.algo.ts:27", + "pc": [ + 115, + 116, + 117, + 118, + 119 + ] + }, + { + "teal": 51, + "source": "tests/contracts/storage.algo.ts:27", + "pc": [ + 120 + ] + }, + { + "teal": 55, + "source": "tests/contracts/storage.algo.ts:28", + "pc": [ + 121, + 122 + ] + }, + { + "teal": 56, + "source": "tests/contracts/storage.algo.ts:28", + "pc": [ + 123, + 124, + 125, + 126, + 127 + ] + }, + { + "teal": 57, + "source": "tests/contracts/storage.algo.ts:28", + "pc": [ + 128, + 129, + 130, + 131, + 132 + ] + }, + { + "teal": 58, + "source": "tests/contracts/storage.algo.ts:28", + "pc": [ + 133 + ] + }, + { + "teal": 59, + "source": "tests/contracts/storage.algo.ts:25", + "pc": [ + 134 + ] + }, + { + "teal": 64, + "source": "tests/contracts/storage.algo.ts:31", + "pc": [ + 135, + 136, + 137 + ] + }, + { + "teal": 65, + "source": "tests/contracts/storage.algo.ts:31", + "pc": [ + 138, + 139 + ] + }, + { + "teal": 66, + "source": "tests/contracts/storage.algo.ts:31", + "pc": [ + 140 + ] + }, + { + "teal": 70, + "source": "tests/contracts/storage.algo.ts:31", + "pc": [ + 141, + 142, + 143 + ] + }, + { + "teal": 74, + "source": "tests/contracts/storage.algo.ts:32", + "pc": [ + 144, + 145, + 146, + 147, + 148 + ] + }, + { + "teal": 75, + "source": "tests/contracts/storage.algo.ts:32", + "pc": [ + 149, + 150, + 151, + 152, + 153 + ] + }, + { + "teal": 76, + "source": "tests/contracts/storage.algo.ts:32", + "pc": [ + 154 + ] + }, + { + "teal": 77, + "source": "tests/contracts/storage.algo.ts:31", + "pc": [ + 155 + ] + }, + { + "teal": 82, + "source": "tests/contracts/storage.algo.ts:35", + "pc": [ + 156, + 157, + 158 + ] + }, + { + "teal": 83, + "source": "tests/contracts/storage.algo.ts:35", + "pc": [ + 159, + 160 + ] + }, + { + "teal": 84, + "source": "tests/contracts/storage.algo.ts:35", + "pc": [ + 161 + ] + }, + { + "teal": 88, + "source": "tests/contracts/storage.algo.ts:35", + "pc": [ + 162, + 163, + 164 + ] + }, + { + "teal": 92, + "source": "tests/contracts/storage.algo.ts:36", + "pc": [ + 165, + 166, + 167, + 168, + 169 + ] + }, + { + "teal": 93, + "source": "tests/contracts/storage.algo.ts:36", + "pc": [ + 170 + ] + }, + { + "teal": 94, + "source": "tests/contracts/storage.algo.ts:36", + "pc": [ + 171, + 172, + 173, + 174, + 175 + ] + }, + { + "teal": 95, + "source": "tests/contracts/storage.algo.ts:36", + "pc": [ + 176 + ] + }, + { + "teal": 96, + "source": "tests/contracts/storage.algo.ts:36", + "pc": [ + 177 + ] + }, + { + "teal": 97, + "source": "tests/contracts/storage.algo.ts:35", + "pc": [ + 178 + ] + }, + { + "teal": 102, + "source": "tests/contracts/storage.algo.ts:39", + "pc": [ + 179, + 180, + 181 + ] + }, + { + "teal": 103, + "source": "tests/contracts/storage.algo.ts:39", + "pc": [ + 182, + 183 + ] + }, + { + "teal": 104, + "source": "tests/contracts/storage.algo.ts:39", + "pc": [ + 184 + ] + }, + { + "teal": 108, + "source": "tests/contracts/storage.algo.ts:39", + "pc": [ + 185, + 186, + 187 + ] + }, + { + "teal": 112, + "source": "tests/contracts/storage.algo.ts:40", + "pc": [ + 188, + 189, + 190, + 191, + 192 + ] + }, + { + "teal": 113, + "source": "tests/contracts/storage.algo.ts:40", + "pc": [ + 193 + ] + }, + { + "teal": 114, + "source": "tests/contracts/storage.algo.ts:39", + "pc": [ + 194 + ] + }, + { + "teal": 119, + "source": "tests/contracts/storage.algo.ts:43", + "pc": [ + 195, + 196, + 197 + ] + }, + { + "teal": 120, + "source": "tests/contracts/storage.algo.ts:43", + "pc": [ + 198, + 199 + ] + }, + { + "teal": 121, + "source": "tests/contracts/storage.algo.ts:43", + "pc": [ + 200 + ] + }, + { + "teal": 125, + "source": "tests/contracts/storage.algo.ts:43", + "pc": [ + 201, + 202, + 203 + ] + }, + { + "teal": 129, + "source": "tests/contracts/storage.algo.ts:44", + "pc": [ + 204, + 205, + 206 + ] + }, + { + "teal": 130, + "source": "tests/contracts/storage.algo.ts:44", + "pc": [ + 207, + 208, + 209, + 210, + 211 + ] + }, + { + "teal": 131, + "source": "tests/contracts/storage.algo.ts:44", + "pc": [ + 212 + ] + }, + { + "teal": 132, + "source": "tests/contracts/storage.algo.ts:44", + "pc": [ + 213 + ] + }, + { + "teal": 133, + "source": "tests/contracts/storage.algo.ts:44", + "pc": [ + 214 + ] + }, + { + "teal": 134, + "source": "tests/contracts/storage.algo.ts:44", + "pc": [ + 215 + ] + }, + { + "teal": 135, + "source": "tests/contracts/storage.algo.ts:43", + "pc": [ + 216 + ] }, { + "teal": 140, + "source": "tests/contracts/storage.algo.ts:47", + "pc": [ + 217, + 218, + 219 + ] + }, + { + "teal": 141, + "source": "tests/contracts/storage.algo.ts:47", + "pc": [ + 220 + ] + }, + { + "teal": 142, + "source": "tests/contracts/storage.algo.ts:47", + "pc": [ + 221 + ] + }, + { + "teal": 143, + "source": "tests/contracts/storage.algo.ts:47", + "pc": [ + 222, + 223 + ] + }, + { + "teal": 144, + "source": "tests/contracts/storage.algo.ts:47", + "pc": [ + 224 + ] + }, + { + "teal": 147, + "source": "tests/contracts/storage.algo.ts:47", + "errorMessage": "argument 0 (a) for localKeyPut must be a address", "pc": [ 225 - ], - "errorMessage": "argument 0 (a) for localKeyPut must be a address" + ] }, { + "teal": 150, + "source": "tests/contracts/storage.algo.ts:47", "pc": [ - 257 - ], - "errorMessage": "argument 0 (a) for localKeyGet must be a address" + 226, + 227, + 228 + ] }, { + "teal": 151, + "source": "tests/contracts/storage.algo.ts:47", "pc": [ - 291 - ], - "errorMessage": "argument 0 (a) for localKeyDelete must be a address" + 229, + 230 + ] }, { + "teal": 152, + "source": "tests/contracts/storage.algo.ts:47", "pc": [ - 318 - ], - "errorMessage": "argument 0 (a) for localKeyExists must be a address" + 231 + ] }, { + "teal": 156, + "source": "tests/contracts/storage.algo.ts:47", "pc": [ - 379 - ], - "errorMessage": "box value does not exist: this.boxKey.value" + 232, + 233, + 234 + ] }, { + "teal": 160, + "source": "tests/contracts/storage.algo.ts:48", "pc": [ - 513 - ], - "errorMessage": "argument 0 (a) for localMapPut must be a address" + 235, + 236 + ] }, { + "teal": 161, + "source": "tests/contracts/storage.algo.ts:48", "pc": [ - 545 - ], - "errorMessage": "argument 0 (a) for localMapGet must be a address" + 237, + 238, + 239, + 240, + 241 + ] }, { + "teal": 162, + "source": "tests/contracts/storage.algo.ts:48", "pc": [ - 579 - ], - "errorMessage": "argument 0 (a) for localMapDelete must be a address" + 242, + 243, + 244, + 245, + 246 + ] }, { + "teal": 163, + "source": "tests/contracts/storage.algo.ts:48", "pc": [ - 606 - ], - "errorMessage": "argument 0 (a) for localMapExists must be a address" + 247 + ] }, { + "teal": 164, + "source": "tests/contracts/storage.algo.ts:47", "pc": [ - 667 - ], - "errorMessage": "box value does not exist: this.boxMap('foo').value" + 248 + ] }, { + "teal": 169, + "source": "tests/contracts/storage.algo.ts:51", "pc": [ - 775 - ], - "errorMessage": "box value does not exist: this.boxKey.size" + 249, + 250, + 251 + ] }, { + "teal": 170, + "source": "tests/contracts/storage.algo.ts:51", "pc": [ - 801 - ], - "errorMessage": "box value does not exist: this.boxMap('bar').size" + 252 + ] }, { + "teal": 171, + "source": "tests/contracts/storage.algo.ts:51", "pc": [ - 971 - ], - "errorMessage": "global state value does not exist: this.app.globalState('foo')" + 253 + ] }, { + "teal": 172, + "source": "tests/contracts/storage.algo.ts:51", "pc": [ - 994 - ], - "errorMessage": "local state value does not exist: this.app.localState(this.txn.sender, 'foo')" + 254, + 255 + ] }, { + "teal": 173, + "source": "tests/contracts/storage.algo.ts:51", "pc": [ - 1012 - ], - "errorMessage": "accessStaticValueInLargeBox return value overflowed 16 bits" + 256 + ] }, { + "teal": 176, + "source": "tests/contracts/storage.algo.ts:51", + "errorMessage": "argument 0 (a) for localKeyGet must be a address", "pc": [ - 1133 - ], - "errorMessage": "dynamicAccessStaticValueInLargeBox return value overflowed 16 bits" + 257 + ] }, { + "teal": 179, + "source": "tests/contracts/storage.algo.ts:51", "pc": [ - 1363 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + 258, + 259, + 260 + ] + }, + { + "teal": 180, + "source": "tests/contracts/storage.algo.ts:51", + "pc": [ + 261, + 262 + ] + }, + { + "teal": 181, + "source": "tests/contracts/storage.algo.ts:51", + "pc": [ + 263 + ] + }, + { + "teal": 185, + "source": "tests/contracts/storage.algo.ts:51", + "pc": [ + 264, + 265, + 266 + ] + }, + { + "teal": 189, + "source": "tests/contracts/storage.algo.ts:52", + "pc": [ + 267, + 268 + ] + }, + { + "teal": 190, + "source": "tests/contracts/storage.algo.ts:52", + "pc": [ + 269, + 270, + 271, + 272, + 273 + ] + }, + { + "teal": 191, + "source": "tests/contracts/storage.algo.ts:52", + "pc": [ + 274 + ] + }, + { + "teal": 192, + "source": "tests/contracts/storage.algo.ts:52", + "pc": [ + 275, + 276, + 277, + 278, + 279 + ] + }, + { + "teal": 193, + "source": "tests/contracts/storage.algo.ts:52", + "pc": [ + 280 + ] + }, + { + "teal": 194, + "source": "tests/contracts/storage.algo.ts:52", + "pc": [ + 281 + ] + }, + { + "teal": 195, + "source": "tests/contracts/storage.algo.ts:51", + "pc": [ + 282 + ] + }, + { + "teal": 200, + "source": "tests/contracts/storage.algo.ts:55", + "pc": [ + 283, + 284, + 285 + ] + }, + { + "teal": 201, + "source": "tests/contracts/storage.algo.ts:55", + "pc": [ + 286 + ] + }, + { + "teal": 202, + "source": "tests/contracts/storage.algo.ts:55", + "pc": [ + 287 + ] + }, + { + "teal": 203, + "source": "tests/contracts/storage.algo.ts:55", + "pc": [ + 288, + 289 + ] + }, + { + "teal": 204, + "source": "tests/contracts/storage.algo.ts:55", + "pc": [ + 290 + ] + }, + { + "teal": 207, + "source": "tests/contracts/storage.algo.ts:55", + "errorMessage": "argument 0 (a) for localKeyDelete must be a address", + "pc": [ + 291 + ] + }, + { + "teal": 210, + "source": "tests/contracts/storage.algo.ts:55", + "pc": [ + 292, + 293, + 294 + ] + }, + { + "teal": 211, + "source": "tests/contracts/storage.algo.ts:55", + "pc": [ + 295, + 296 + ] + }, + { + "teal": 212, + "source": "tests/contracts/storage.algo.ts:55", + "pc": [ + 297 + ] + }, + { + "teal": 216, + "source": "tests/contracts/storage.algo.ts:55", + "pc": [ + 298, + 299, + 300 + ] + }, + { + "teal": 220, + "source": "tests/contracts/storage.algo.ts:56", + "pc": [ + 301, + 302 + ] + }, + { + "teal": 221, + "source": "tests/contracts/storage.algo.ts:56", + "pc": [ + 303, + 304, + 305, + 306, + 307 + ] + }, + { + "teal": 222, + "source": "tests/contracts/storage.algo.ts:56", + "pc": [ + 308 + ] + }, + { + "teal": 223, + "source": "tests/contracts/storage.algo.ts:55", + "pc": [ + 309 + ] + }, + { + "teal": 228, + "source": "tests/contracts/storage.algo.ts:59", + "pc": [ + 310, + 311, + 312 + ] + }, + { + "teal": 229, + "source": "tests/contracts/storage.algo.ts:59", + "pc": [ + 313 + ] + }, + { + "teal": 230, + "source": "tests/contracts/storage.algo.ts:59", + "pc": [ + 314 + ] + }, + { + "teal": 231, + "source": "tests/contracts/storage.algo.ts:59", + "pc": [ + 315, + 316 + ] + }, + { + "teal": 232, + "source": "tests/contracts/storage.algo.ts:59", + "pc": [ + 317 + ] + }, + { + "teal": 235, + "source": "tests/contracts/storage.algo.ts:59", + "errorMessage": "argument 0 (a) for localKeyExists must be a address", + "pc": [ + 318 + ] + }, + { + "teal": 238, + "source": "tests/contracts/storage.algo.ts:59", + "pc": [ + 319, + 320, + 321 + ] + }, + { + "teal": 239, + "source": "tests/contracts/storage.algo.ts:59", + "pc": [ + 322, + 323 + ] + }, + { + "teal": 240, + "source": "tests/contracts/storage.algo.ts:59", + "pc": [ + 324 + ] + }, + { + "teal": 244, + "source": "tests/contracts/storage.algo.ts:59", + "pc": [ + 325, + 326, + 327 + ] + }, + { + "teal": 248, + "source": "tests/contracts/storage.algo.ts:60", + "pc": [ + 328, + 329 + ] + }, + { + "teal": 249, + "source": "tests/contracts/storage.algo.ts:60", + "pc": [ + 330, + 331, + 332 + ] + }, + { + "teal": 250, + "source": "tests/contracts/storage.algo.ts:60", + "pc": [ + 333, + 334, + 335, + 336, + 337 + ] + }, + { + "teal": 251, + "source": "tests/contracts/storage.algo.ts:60", + "pc": [ + 338 + ] + }, + { + "teal": 252, + "source": "tests/contracts/storage.algo.ts:60", + "pc": [ + 339 + ] + }, + { + "teal": 253, + "source": "tests/contracts/storage.algo.ts:60", + "pc": [ + 340 + ] + }, + { + "teal": 254, + "source": "tests/contracts/storage.algo.ts:60", + "pc": [ + 341 + ] + }, + { + "teal": 255, + "source": "tests/contracts/storage.algo.ts:59", + "pc": [ + 342 + ] + }, + { + "teal": 260, + "source": "tests/contracts/storage.algo.ts:63", + "pc": [ + 343, + 344, + 345 + ] + }, + { + "teal": 261, + "source": "tests/contracts/storage.algo.ts:63", + "pc": [ + 346, + 347 + ] + }, + { + "teal": 262, + "source": "tests/contracts/storage.algo.ts:63", + "pc": [ + 348 + ] + }, + { + "teal": 266, + "source": "tests/contracts/storage.algo.ts:63", + "pc": [ + 349, + 350, + 351 + ] + }, + { + "teal": 270, + "source": "tests/contracts/storage.algo.ts:64", + "pc": [ + 352, + 353, + 354, + 355, + 356 + ] + }, + { + "teal": 271, + "source": "tests/contracts/storage.algo.ts:64", + "pc": [ + 357, + 358, + 359, + 360, + 361 + ] + }, + { + "teal": 272, + "source": "tests/contracts/storage.algo.ts:64", + "pc": [ + 362 + ] + }, + { + "teal": 273, + "source": "tests/contracts/storage.algo.ts:63", + "pc": [ + 363 + ] + }, + { + "teal": 278, + "source": "tests/contracts/storage.algo.ts:67", + "pc": [ + 364, + 365, + 366 + ] + }, + { + "teal": 279, + "source": "tests/contracts/storage.algo.ts:67", + "pc": [ + 367, + 368 + ] + }, + { + "teal": 280, + "source": "tests/contracts/storage.algo.ts:67", + "pc": [ + 369 + ] + }, + { + "teal": 284, + "source": "tests/contracts/storage.algo.ts:67", + "pc": [ + 370, + 371, + 372 + ] + }, + { + "teal": 288, + "source": "tests/contracts/storage.algo.ts:68", + "pc": [ + 373, + 374, + 375, + 376, + 377 + ] + }, + { + "teal": 289, + "source": "tests/contracts/storage.algo.ts:68", + "pc": [ + 378 + ] + }, + { + "teal": 292, + "source": "tests/contracts/storage.algo.ts:68", + "errorMessage": "box value does not exist: this.boxKey.value", + "pc": [ + 379 + ] + }, + { + "teal": 293, + "source": "tests/contracts/storage.algo.ts:68", + "pc": [ + 380, + 381, + 382, + 383, + 384 + ] + }, + { + "teal": 294, + "source": "tests/contracts/storage.algo.ts:68", + "pc": [ + 385 + ] + }, + { + "teal": 295, + "source": "tests/contracts/storage.algo.ts:68", + "pc": [ + 386 + ] + }, + { + "teal": 296, + "source": "tests/contracts/storage.algo.ts:67", + "pc": [ + 387 + ] + }, + { + "teal": 301, + "source": "tests/contracts/storage.algo.ts:71", + "pc": [ + 388, + 389, + 390 + ] + }, + { + "teal": 302, + "source": "tests/contracts/storage.algo.ts:71", + "pc": [ + 391, + 392 + ] + }, + { + "teal": 303, + "source": "tests/contracts/storage.algo.ts:71", + "pc": [ + 393 + ] + }, + { + "teal": 307, + "source": "tests/contracts/storage.algo.ts:71", + "pc": [ + 394, + 395, + 396 + ] + }, + { + "teal": 311, + "source": "tests/contracts/storage.algo.ts:72", + "pc": [ + 397, + 398, + 399, + 400, + 401 + ] + }, + { + "teal": 312, + "source": "tests/contracts/storage.algo.ts:72", + "pc": [ + 402 + ] + }, + { + "teal": 313, + "source": "tests/contracts/storage.algo.ts:71", + "pc": [ + 403 + ] + }, + { + "teal": 318, + "source": "tests/contracts/storage.algo.ts:75", + "pc": [ + 404, + 405, + 406 + ] + }, + { + "teal": 319, + "source": "tests/contracts/storage.algo.ts:75", + "pc": [ + 407, + 408 + ] + }, + { + "teal": 320, + "source": "tests/contracts/storage.algo.ts:75", + "pc": [ + 409 + ] + }, + { + "teal": 324, + "source": "tests/contracts/storage.algo.ts:75", + "pc": [ + 410, + 411, + 412 + ] + }, + { + "teal": 328, + "source": "tests/contracts/storage.algo.ts:76", + "pc": [ + 413, + 414, + 415, + 416, + 417 + ] + }, + { + "teal": 329, + "source": "tests/contracts/storage.algo.ts:76", + "pc": [ + 418 + ] + }, + { + "teal": 330, + "source": "tests/contracts/storage.algo.ts:76", + "pc": [ + 419 + ] + }, + { + "teal": 331, + "source": "tests/contracts/storage.algo.ts:76", + "pc": [ + 420 + ] + }, + { + "teal": 332, + "source": "tests/contracts/storage.algo.ts:76", + "pc": [ + 421 + ] + }, + { + "teal": 333, + "source": "tests/contracts/storage.algo.ts:75", + "pc": [ + 422 + ] + }, + { + "teal": 338, + "source": "tests/contracts/storage.algo.ts:79", + "pc": [ + 423, + 424, + 425 + ] + }, + { + "teal": 339, + "source": "tests/contracts/storage.algo.ts:79", + "pc": [ + 426, + 427 + ] + }, + { + "teal": 340, + "source": "tests/contracts/storage.algo.ts:79", + "pc": [ + 428 + ] + }, + { + "teal": 344, + "source": "tests/contracts/storage.algo.ts:79", + "pc": [ + 429, + 430, + 431 + ] + }, + { + "teal": 348, + "source": "tests/contracts/storage.algo.ts:80", + "pc": [ + 432, + 433, + 434, + 435, + 436 + ] + }, + { + "teal": 349, + "source": "tests/contracts/storage.algo.ts:80", + "pc": [ + 437, + 438, + 439, + 440, + 441 + ] + }, + { + "teal": 350, + "source": "tests/contracts/storage.algo.ts:80", + "pc": [ + 442 + ] + }, + { + "teal": 351, + "source": "tests/contracts/storage.algo.ts:79", + "pc": [ + 443 + ] + }, + { + "teal": 356, + "source": "tests/contracts/storage.algo.ts:83", + "pc": [ + 444, + 445, + 446 + ] + }, + { + "teal": 357, + "source": "tests/contracts/storage.algo.ts:83", + "pc": [ + 447, + 448 + ] + }, + { + "teal": 358, + "source": "tests/contracts/storage.algo.ts:83", + "pc": [ + 449 + ] + }, + { + "teal": 362, + "source": "tests/contracts/storage.algo.ts:83", + "pc": [ + 450, + 451, + 452 + ] + }, + { + "teal": 366, + "source": "tests/contracts/storage.algo.ts:84", + "pc": [ + 453, + 454, + 455, + 456, + 457 + ] + }, + { + "teal": 367, + "source": "tests/contracts/storage.algo.ts:84", + "pc": [ + 458 + ] + }, + { + "teal": 368, + "source": "tests/contracts/storage.algo.ts:84", + "pc": [ + 459, + 460, + 461, + 462, + 463 + ] + }, + { + "teal": 369, + "source": "tests/contracts/storage.algo.ts:84", + "pc": [ + 464 + ] + }, + { + "teal": 370, + "source": "tests/contracts/storage.algo.ts:84", + "pc": [ + 465 + ] + }, + { + "teal": 371, + "source": "tests/contracts/storage.algo.ts:83", + "pc": [ + 466 + ] + }, + { + "teal": 376, + "source": "tests/contracts/storage.algo.ts:87", + "pc": [ + 467, + 468, + 469 + ] + }, + { + "teal": 377, + "source": "tests/contracts/storage.algo.ts:87", + "pc": [ + 470, + 471 + ] + }, + { + "teal": 378, + "source": "tests/contracts/storage.algo.ts:87", + "pc": [ + 472 + ] + }, + { + "teal": 382, + "source": "tests/contracts/storage.algo.ts:87", + "pc": [ + 473, + 474, + 475 + ] + }, + { + "teal": 386, + "source": "tests/contracts/storage.algo.ts:88", + "pc": [ + 476, + 477, + 478, + 479, + 480 + ] + }, + { + "teal": 387, + "source": "tests/contracts/storage.algo.ts:88", + "pc": [ + 481 + ] + }, + { + "teal": 388, + "source": "tests/contracts/storage.algo.ts:87", + "pc": [ + 482 + ] + }, + { + "teal": 393, + "source": "tests/contracts/storage.algo.ts:91", + "pc": [ + 483, + 484, + 485 + ] + }, + { + "teal": 394, + "source": "tests/contracts/storage.algo.ts:91", + "pc": [ + 486, + 487 + ] + }, + { + "teal": 395, + "source": "tests/contracts/storage.algo.ts:91", + "pc": [ + 488 + ] + }, + { + "teal": 399, + "source": "tests/contracts/storage.algo.ts:91", + "pc": [ + 489, + 490, + 491 + ] + }, + { + "teal": 403, + "source": "tests/contracts/storage.algo.ts:92", + "pc": [ + 492, + 493, + 494 + ] + }, + { + "teal": 404, + "source": "tests/contracts/storage.algo.ts:92", + "pc": [ + 495, + 496, + 497, + 498, + 499 + ] + }, + { + "teal": 405, + "source": "tests/contracts/storage.algo.ts:92", + "pc": [ + 500 + ] + }, + { + "teal": 406, + "source": "tests/contracts/storage.algo.ts:92", + "pc": [ + 501 + ] + }, + { + "teal": 407, + "source": "tests/contracts/storage.algo.ts:92", + "pc": [ + 502 + ] + }, + { + "teal": 408, + "source": "tests/contracts/storage.algo.ts:92", + "pc": [ + 503 + ] + }, + { + "teal": 409, + "source": "tests/contracts/storage.algo.ts:91", + "pc": [ + 504 + ] + }, + { + "teal": 414, + "source": "tests/contracts/storage.algo.ts:95", + "pc": [ + 505, + 506, + 507 + ] + }, + { + "teal": 415, + "source": "tests/contracts/storage.algo.ts:95", + "pc": [ + 508 + ] + }, + { + "teal": 416, + "source": "tests/contracts/storage.algo.ts:95", + "pc": [ + 509 + ] + }, + { + "teal": 417, + "source": "tests/contracts/storage.algo.ts:95", + "pc": [ + 510, + 511 + ] + }, + { + "teal": 418, + "source": "tests/contracts/storage.algo.ts:95", + "pc": [ + 512 + ] + }, + { + "teal": 421, + "source": "tests/contracts/storage.algo.ts:95", + "errorMessage": "argument 0 (a) for localMapPut must be a address", + "pc": [ + 513 + ] + }, + { + "teal": 424, + "source": "tests/contracts/storage.algo.ts:95", + "pc": [ + 514, + 515, + 516 + ] + }, + { + "teal": 425, + "source": "tests/contracts/storage.algo.ts:95", + "pc": [ + 517, + 518 + ] + }, + { + "teal": 426, + "source": "tests/contracts/storage.algo.ts:95", + "pc": [ + 519 + ] + }, + { + "teal": 430, + "source": "tests/contracts/storage.algo.ts:95", + "pc": [ + 520, + 521, + 522 + ] + }, + { + "teal": 434, + "source": "tests/contracts/storage.algo.ts:96", + "pc": [ + 523, + 524 + ] + }, + { + "teal": 435, + "source": "tests/contracts/storage.algo.ts:96", + "pc": [ + 525, + 526, + 527, + 528, + 529 + ] + }, + { + "teal": 436, + "source": "tests/contracts/storage.algo.ts:96", + "pc": [ + 530, + 531, + 532, + 533, + 534 + ] + }, + { + "teal": 437, + "source": "tests/contracts/storage.algo.ts:96", + "pc": [ + 535 + ] + }, + { + "teal": 438, + "source": "tests/contracts/storage.algo.ts:95", + "pc": [ + 536 + ] + }, + { + "teal": 443, + "source": "tests/contracts/storage.algo.ts:99", + "pc": [ + 537, + 538, + 539 + ] + }, + { + "teal": 444, + "source": "tests/contracts/storage.algo.ts:99", + "pc": [ + 540 + ] + }, + { + "teal": 445, + "source": "tests/contracts/storage.algo.ts:99", + "pc": [ + 541 + ] + }, + { + "teal": 446, + "source": "tests/contracts/storage.algo.ts:99", + "pc": [ + 542, + 543 + ] + }, + { + "teal": 447, + "source": "tests/contracts/storage.algo.ts:99", + "pc": [ + 544 + ] + }, + { + "teal": 450, + "source": "tests/contracts/storage.algo.ts:99", + "errorMessage": "argument 0 (a) for localMapGet must be a address", + "pc": [ + 545 + ] + }, + { + "teal": 453, + "source": "tests/contracts/storage.algo.ts:99", + "pc": [ + 546, + 547, + 548 + ] + }, + { + "teal": 454, + "source": "tests/contracts/storage.algo.ts:99", + "pc": [ + 549, + 550 + ] + }, + { + "teal": 455, + "source": "tests/contracts/storage.algo.ts:99", + "pc": [ + 551 + ] + }, + { + "teal": 459, + "source": "tests/contracts/storage.algo.ts:99", + "pc": [ + 552, + 553, + 554 + ] + }, + { + "teal": 463, + "source": "tests/contracts/storage.algo.ts:100", + "pc": [ + 555, + 556 + ] + }, + { + "teal": 464, + "source": "tests/contracts/storage.algo.ts:100", + "pc": [ + 557, + 558, + 559, + 560, + 561 + ] + }, + { + "teal": 465, + "source": "tests/contracts/storage.algo.ts:100", + "pc": [ + 562 + ] + }, + { + "teal": 466, + "source": "tests/contracts/storage.algo.ts:100", + "pc": [ + 563, + 564, + 565, + 566, + 567 + ] + }, + { + "teal": 467, + "source": "tests/contracts/storage.algo.ts:100", + "pc": [ + 568 + ] + }, + { + "teal": 468, + "source": "tests/contracts/storage.algo.ts:100", + "pc": [ + 569 + ] + }, + { + "teal": 469, + "source": "tests/contracts/storage.algo.ts:99", + "pc": [ + 570 + ] + }, + { + "teal": 474, + "source": "tests/contracts/storage.algo.ts:103", + "pc": [ + 571, + 572, + 573 + ] + }, + { + "teal": 475, + "source": "tests/contracts/storage.algo.ts:103", + "pc": [ + 574 + ] + }, + { + "teal": 476, + "source": "tests/contracts/storage.algo.ts:103", + "pc": [ + 575 + ] + }, + { + "teal": 477, + "source": "tests/contracts/storage.algo.ts:103", + "pc": [ + 576, + 577 + ] + }, + { + "teal": 478, + "source": "tests/contracts/storage.algo.ts:103", + "pc": [ + 578 + ] + }, + { + "teal": 481, + "source": "tests/contracts/storage.algo.ts:103", + "errorMessage": "argument 0 (a) for localMapDelete must be a address", + "pc": [ + 579 + ] + }, + { + "teal": 484, + "source": "tests/contracts/storage.algo.ts:103", + "pc": [ + 580, + 581, + 582 + ] + }, + { + "teal": 485, + "source": "tests/contracts/storage.algo.ts:103", + "pc": [ + 583, + 584 + ] + }, + { + "teal": 486, + "source": "tests/contracts/storage.algo.ts:103", + "pc": [ + 585 + ] + }, + { + "teal": 490, + "source": "tests/contracts/storage.algo.ts:103", + "pc": [ + 586, + 587, + 588 + ] + }, + { + "teal": 494, + "source": "tests/contracts/storage.algo.ts:104", + "pc": [ + 589, + 590 + ] + }, + { + "teal": 495, + "source": "tests/contracts/storage.algo.ts:104", + "pc": [ + 591, + 592, + 593, + 594, + 595 + ] + }, + { + "teal": 496, + "source": "tests/contracts/storage.algo.ts:104", + "pc": [ + 596 + ] + }, + { + "teal": 497, + "source": "tests/contracts/storage.algo.ts:103", + "pc": [ + 597 + ] + }, + { + "teal": 502, + "source": "tests/contracts/storage.algo.ts:107", + "pc": [ + 598, + 599, + 600 + ] + }, + { + "teal": 503, + "source": "tests/contracts/storage.algo.ts:107", + "pc": [ + 601 + ] + }, + { + "teal": 504, + "source": "tests/contracts/storage.algo.ts:107", + "pc": [ + 602 + ] + }, + { + "teal": 505, + "source": "tests/contracts/storage.algo.ts:107", + "pc": [ + 603, + 604 + ] + }, + { + "teal": 506, + "source": "tests/contracts/storage.algo.ts:107", + "pc": [ + 605 + ] + }, + { + "teal": 509, + "source": "tests/contracts/storage.algo.ts:107", + "errorMessage": "argument 0 (a) for localMapExists must be a address", + "pc": [ + 606 + ] + }, + { + "teal": 512, + "source": "tests/contracts/storage.algo.ts:107", + "pc": [ + 607, + 608, + 609 + ] + }, + { + "teal": 513, + "source": "tests/contracts/storage.algo.ts:107", + "pc": [ + 610, + 611 + ] + }, + { + "teal": 514, + "source": "tests/contracts/storage.algo.ts:107", + "pc": [ + 612 + ] + }, + { + "teal": 518, + "source": "tests/contracts/storage.algo.ts:107", + "pc": [ + 613, + 614, + 615 + ] + }, + { + "teal": 522, + "source": "tests/contracts/storage.algo.ts:108", + "pc": [ + 616, + 617 + ] + }, + { + "teal": 523, + "source": "tests/contracts/storage.algo.ts:108", + "pc": [ + 618, + 619, + 620 + ] + }, + { + "teal": 524, + "source": "tests/contracts/storage.algo.ts:108", + "pc": [ + 621, + 622, + 623, + 624, + 625 + ] + }, + { + "teal": 525, + "source": "tests/contracts/storage.algo.ts:108", + "pc": [ + 626 + ] + }, + { + "teal": 526, + "source": "tests/contracts/storage.algo.ts:108", + "pc": [ + 627 + ] + }, + { + "teal": 527, + "source": "tests/contracts/storage.algo.ts:108", + "pc": [ + 628 + ] + }, + { + "teal": 528, + "source": "tests/contracts/storage.algo.ts:108", + "pc": [ + 629 + ] + }, + { + "teal": 529, + "source": "tests/contracts/storage.algo.ts:107", + "pc": [ + 630 + ] + }, + { + "teal": 534, + "source": "tests/contracts/storage.algo.ts:111", + "pc": [ + 631, + 632, + 633 + ] + }, + { + "teal": 535, + "source": "tests/contracts/storage.algo.ts:111", + "pc": [ + 634, + 635 + ] + }, + { + "teal": 536, + "source": "tests/contracts/storage.algo.ts:111", + "pc": [ + 636 + ] + }, + { + "teal": 540, + "source": "tests/contracts/storage.algo.ts:111", + "pc": [ + 637, + 638, + 639 + ] + }, + { + "teal": 544, + "source": "tests/contracts/storage.algo.ts:112", + "pc": [ + 640, + 641, + 642, + 643, + 644 + ] + }, + { + "teal": 545, + "source": "tests/contracts/storage.algo.ts:112", + "pc": [ + 645, + 646, + 647, + 648, + 649 + ] + }, + { + "teal": 546, + "source": "tests/contracts/storage.algo.ts:112", + "pc": [ + 650 + ] + }, + { + "teal": 547, + "source": "tests/contracts/storage.algo.ts:111", + "pc": [ + 651 + ] + }, + { + "teal": 552, + "source": "tests/contracts/storage.algo.ts:115", + "pc": [ + 652, + 653, + 654 + ] + }, + { + "teal": 553, + "source": "tests/contracts/storage.algo.ts:115", + "pc": [ + 655, + 656 + ] + }, + { + "teal": 554, + "source": "tests/contracts/storage.algo.ts:115", + "pc": [ + 657 + ] + }, + { + "teal": 558, + "source": "tests/contracts/storage.algo.ts:115", + "pc": [ + 658, + 659, + 660 + ] + }, + { + "teal": 562, + "source": "tests/contracts/storage.algo.ts:116", + "pc": [ + 661, + 662, + 663, + 664, + 665 + ] + }, + { + "teal": 563, + "source": "tests/contracts/storage.algo.ts:116", + "pc": [ + 666 + ] + }, + { + "teal": 566, + "source": "tests/contracts/storage.algo.ts:116", + "errorMessage": "box value does not exist: this.boxMap('foo').value", + "pc": [ + 667 + ] + }, + { + "teal": 567, + "source": "tests/contracts/storage.algo.ts:116", + "pc": [ + 668, + 669, + 670, + 671, + 672 + ] + }, + { + "teal": 568, + "source": "tests/contracts/storage.algo.ts:116", + "pc": [ + 673 + ] + }, + { + "teal": 569, + "source": "tests/contracts/storage.algo.ts:116", + "pc": [ + 674 + ] + }, + { + "teal": 570, + "source": "tests/contracts/storage.algo.ts:115", + "pc": [ + 675 + ] + }, + { + "teal": 575, + "source": "tests/contracts/storage.algo.ts:119", + "pc": [ + 676, + 677, + 678 + ] + }, + { + "teal": 576, + "source": "tests/contracts/storage.algo.ts:119", + "pc": [ + 679, + 680 + ] + }, + { + "teal": 577, + "source": "tests/contracts/storage.algo.ts:119", + "pc": [ + 681 + ] + }, + { + "teal": 581, + "source": "tests/contracts/storage.algo.ts:119", + "pc": [ + 682, + 683, + 684 + ] + }, + { + "teal": 585, + "source": "tests/contracts/storage.algo.ts:120", + "pc": [ + 685, + 686, + 687, + 688, + 689 + ] + }, + { + "teal": 586, + "source": "tests/contracts/storage.algo.ts:120", + "pc": [ + 690 + ] + }, + { + "teal": 587, + "source": "tests/contracts/storage.algo.ts:119", + "pc": [ + 691 + ] + }, + { + "teal": 592, + "source": "tests/contracts/storage.algo.ts:123", + "pc": [ + 692, + 693, + 694 + ] + }, + { + "teal": 593, + "source": "tests/contracts/storage.algo.ts:123", + "pc": [ + 695, + 696 + ] + }, + { + "teal": 594, + "source": "tests/contracts/storage.algo.ts:123", + "pc": [ + 697 + ] + }, + { + "teal": 598, + "source": "tests/contracts/storage.algo.ts:123", + "pc": [ + 698, + 699, + 700 + ] + }, + { + "teal": 602, + "source": "tests/contracts/storage.algo.ts:124", + "pc": [ + 701, + 702, + 703, + 704, + 705 + ] + }, + { + "teal": 603, + "source": "tests/contracts/storage.algo.ts:124", + "pc": [ + 706 + ] + }, + { + "teal": 604, + "source": "tests/contracts/storage.algo.ts:124", + "pc": [ + 707 + ] + }, + { + "teal": 605, + "source": "tests/contracts/storage.algo.ts:124", + "pc": [ + 708 + ] + }, + { + "teal": 606, + "source": "tests/contracts/storage.algo.ts:124", + "pc": [ + 709 + ] + }, + { + "teal": 607, + "source": "tests/contracts/storage.algo.ts:123", + "pc": [ + 710 + ] + }, + { + "teal": 612, + "source": "tests/contracts/storage.algo.ts:127", + "pc": [ + 711, + 712, + 713 + ] + }, + { + "teal": 613, + "source": "tests/contracts/storage.algo.ts:127", + "pc": [ + 714, + 715 + ] + }, + { + "teal": 614, + "source": "tests/contracts/storage.algo.ts:127", + "pc": [ + 716 + ] + }, + { + "teal": 618, + "source": "tests/contracts/storage.algo.ts:127", + "pc": [ + 717, + 718, + 719 + ] + }, + { + "teal": 622, + "source": "tests/contracts/storage.algo.ts:128", + "pc": [ + 720, + 721, + 722, + 723, + 724 + ] + }, + { + "teal": 623, + "source": "tests/contracts/storage.algo.ts:128", + "pc": [ + 725, + 726, + 727 + ] + }, + { + "teal": 624, + "source": "tests/contracts/storage.algo.ts:128", + "pc": [ + 728 + ] + }, + { + "teal": 625, + "source": "tests/contracts/storage.algo.ts:128", + "pc": [ + 729 + ] + }, + { + "teal": 626, + "source": "tests/contracts/storage.algo.ts:127", + "pc": [ + 730 + ] + }, + { + "teal": 631, + "source": "tests/contracts/storage.algo.ts:131", + "pc": [ + 731, + 732, + 733 + ] + }, + { + "teal": 632, + "source": "tests/contracts/storage.algo.ts:131", + "pc": [ + 734, + 735 + ] + }, + { + "teal": 633, + "source": "tests/contracts/storage.algo.ts:131", + "pc": [ + 736 + ] + }, + { + "teal": 637, + "source": "tests/contracts/storage.algo.ts:131", + "pc": [ + 737, + 738, + 739 + ] + }, + { + "teal": 641, + "source": "tests/contracts/storage.algo.ts:132", + "pc": [ + 740, + 741, + 742, + 743, + 744 + ] + }, + { + "teal": 642, + "source": "tests/contracts/storage.algo.ts:132", + "pc": [ + 745, + 746, + 747 + ] + }, + { + "teal": 643, + "source": "tests/contracts/storage.algo.ts:132", + "pc": [ + 748 + ] + }, + { + "teal": 644, + "source": "tests/contracts/storage.algo.ts:132", + "pc": [ + 749 + ] + }, + { + "teal": 645, + "source": "tests/contracts/storage.algo.ts:131", + "pc": [ + 750 + ] + }, + { + "teal": 650, + "source": "tests/contracts/storage.algo.ts:135", + "pc": [ + 751, + 752, + 753, + 754, + 755, + 756 + ] + }, + { + "teal": 653, + "source": "tests/contracts/storage.algo.ts:135", + "pc": [ + 757, + 758, + 759 + ] + }, + { + "teal": 654, + "source": "tests/contracts/storage.algo.ts:135", + "pc": [ + 760 + ] + }, + { + "teal": 655, + "source": "tests/contracts/storage.algo.ts:135", + "pc": [ + 761 + ] + }, + { + "teal": 656, + "source": "tests/contracts/storage.algo.ts:135", + "pc": [ + 762 + ] + }, + { + "teal": 657, + "source": "tests/contracts/storage.algo.ts:135", + "pc": [ + 763, + 764 + ] + }, + { + "teal": 658, + "source": "tests/contracts/storage.algo.ts:135", + "pc": [ + 765 + ] + }, + { + "teal": 662, + "source": "tests/contracts/storage.algo.ts:135", + "pc": [ + 766, + 767, + 768 + ] + }, + { + "teal": 666, + "source": "tests/contracts/storage.algo.ts:136", + "pc": [ + 769, + 770, + 771, + 772, + 773 + ] + }, + { + "teal": 667, + "source": "tests/contracts/storage.algo.ts:136", + "pc": [ + 774 + ] + }, + { + "teal": 670, + "source": "tests/contracts/storage.algo.ts:136", + "errorMessage": "box value does not exist: this.boxKey.size", + "pc": [ + 775 + ] + }, + { + "teal": 671, + "source": "tests/contracts/storage.algo.ts:135", + "pc": [ + 776 + ] + }, + { + "teal": 676, + "source": "tests/contracts/storage.algo.ts:139", + "pc": [ + 777, + 778, + 779, + 780, + 781, + 782 + ] + }, + { + "teal": 679, + "source": "tests/contracts/storage.algo.ts:139", + "pc": [ + 783, + 784, + 785 + ] + }, + { + "teal": 680, + "source": "tests/contracts/storage.algo.ts:139", + "pc": [ + 786 + ] + }, + { + "teal": 681, + "source": "tests/contracts/storage.algo.ts:139", + "pc": [ + 787 + ] + }, + { + "teal": 682, + "source": "tests/contracts/storage.algo.ts:139", + "pc": [ + 788 + ] + }, + { + "teal": 683, + "source": "tests/contracts/storage.algo.ts:139", + "pc": [ + 789, + 790 + ] + }, + { + "teal": 684, + "source": "tests/contracts/storage.algo.ts:139", + "pc": [ + 791 + ] + }, + { + "teal": 688, + "source": "tests/contracts/storage.algo.ts:139", + "pc": [ + 792, + 793, + 794 + ] + }, + { + "teal": 692, + "source": "tests/contracts/storage.algo.ts:140", + "pc": [ + 795, + 796, + 797, + 798, + 799 + ] + }, + { + "teal": 693, + "source": "tests/contracts/storage.algo.ts:140", + "pc": [ + 800 + ] + }, + { + "teal": 696, + "source": "tests/contracts/storage.algo.ts:140", + "errorMessage": "box value does not exist: this.boxMap('bar').size", + "pc": [ + 801 + ] + }, + { + "teal": 697, + "source": "tests/contracts/storage.algo.ts:139", + "pc": [ + 802 + ] + }, + { + "teal": 702, + "source": "tests/contracts/storage.algo.ts:143", + "pc": [ + 803, + 804, + 805 + ] + }, + { + "teal": 703, + "source": "tests/contracts/storage.algo.ts:143", + "pc": [ + 806, + 807 + ] + }, + { + "teal": 704, + "source": "tests/contracts/storage.algo.ts:143", + "pc": [ + 808 + ] + }, + { + "teal": 708, + "source": "tests/contracts/storage.algo.ts:143", + "pc": [ + 809, + 810, + 811 + ] + }, + { + "teal": 712, + "source": "tests/contracts/storage.algo.ts:144", + "pc": [ + 812, + 813, + 814, + 815, + 816 + ] + }, + { + "teal": 713, + "source": "tests/contracts/storage.algo.ts:144", + "pc": [ + 817, + 818 + ] + }, + { + "teal": 714, + "source": "tests/contracts/storage.algo.ts:144", + "pc": [ + 819, + 820, + 821, + 822, + 823 + ] + }, + { + "teal": 715, + "source": "tests/contracts/storage.algo.ts:144", + "pc": [ + 824 + ] + }, + { + "teal": 716, + "source": "tests/contracts/storage.algo.ts:143", + "pc": [ + 825 + ] + }, + { + "teal": 721, + "source": "tests/contracts/storage.algo.ts:147", + "pc": [ + 826, + 827, + 828 + ] + }, + { + "teal": 722, + "source": "tests/contracts/storage.algo.ts:147", + "pc": [ + 829, + 830 + ] + }, + { + "teal": 723, + "source": "tests/contracts/storage.algo.ts:147", + "pc": [ + 831 + ] + }, + { + "teal": 727, + "source": "tests/contracts/storage.algo.ts:147", + "pc": [ + 832, + 833, + 834 + ] + }, + { + "teal": 731, + "source": "tests/contracts/storage.algo.ts:148", + "pc": [ + 835, + 836, + 837, + 838, + 839 + ] + }, + { + "teal": 732, + "source": "tests/contracts/storage.algo.ts:148", + "pc": [ + 840, + 841 + ] + }, + { + "teal": 733, + "source": "tests/contracts/storage.algo.ts:148", + "pc": [ + 842, + 843, + 844, + 845, + 846 + ] + }, + { + "teal": 734, + "source": "tests/contracts/storage.algo.ts:148", + "pc": [ + 847 + ] + }, + { + "teal": 735, + "source": "tests/contracts/storage.algo.ts:147", + "pc": [ + 848 + ] + }, + { + "teal": 740, + "source": "tests/contracts/storage.algo.ts:151", + "pc": [ + 849, + 850, + 851, + 852, + 853, + 854 + ] + }, + { + "teal": 743, + "source": "tests/contracts/storage.algo.ts:151", + "pc": [ + 855, + 856, + 857 + ] + }, + { + "teal": 744, + "source": "tests/contracts/storage.algo.ts:151", + "pc": [ + 858 + ] + }, + { + "teal": 745, + "source": "tests/contracts/storage.algo.ts:151", + "pc": [ + 859 + ] + }, + { + "teal": 746, + "source": "tests/contracts/storage.algo.ts:151", + "pc": [ + 860 + ] + }, + { + "teal": 747, + "source": "tests/contracts/storage.algo.ts:151", + "pc": [ + 861, + 862, + 863 + ] + }, + { + "teal": 748, + "source": "tests/contracts/storage.algo.ts:151", + "pc": [ + 864 + ] + }, + { + "teal": 749, + "source": "tests/contracts/storage.algo.ts:151", + "pc": [ + 865 + ] + }, + { + "teal": 750, + "source": "tests/contracts/storage.algo.ts:151", + "pc": [ + 866 + ] + }, + { + "teal": 751, + "source": "tests/contracts/storage.algo.ts:151", + "pc": [ + 867 + ] + }, + { + "teal": 752, + "source": "tests/contracts/storage.algo.ts:151", + "pc": [ + 868, + 869 + ] + }, + { + "teal": 753, + "source": "tests/contracts/storage.algo.ts:151", + "pc": [ + 870 + ] + }, + { + "teal": 757, + "source": "tests/contracts/storage.algo.ts:151", + "pc": [ + 871, + 872, + 873 + ] + }, + { + "teal": 761, + "source": "tests/contracts/storage.algo.ts:152", + "pc": [ + 874, + 875, + 876, + 877, + 878 + ] + }, + { + "teal": 762, + "source": "tests/contracts/storage.algo.ts:152", + "pc": [ + 879, + 880 + ] + }, + { + "teal": 763, + "source": "tests/contracts/storage.algo.ts:152", + "pc": [ + 881, + 882 + ] + }, + { + "teal": 764, + "source": "tests/contracts/storage.algo.ts:152", + "pc": [ + 883 + ] + }, + { + "teal": 765, + "source": "tests/contracts/storage.algo.ts:151", + "pc": [ + 884 + ] + }, + { + "teal": 770, + "source": "tests/contracts/storage.algo.ts:155", + "pc": [ + 885, + 886, + 887, + 888, + 889, + 890 + ] + }, + { + "teal": 773, + "source": "tests/contracts/storage.algo.ts:155", + "pc": [ + 891, + 892, + 893 + ] + }, + { + "teal": 774, + "source": "tests/contracts/storage.algo.ts:155", + "pc": [ + 894 + ] + }, + { + "teal": 775, + "source": "tests/contracts/storage.algo.ts:155", + "pc": [ + 895 + ] + }, + { + "teal": 776, + "source": "tests/contracts/storage.algo.ts:155", + "pc": [ + 896 + ] + }, + { + "teal": 777, + "source": "tests/contracts/storage.algo.ts:155", + "pc": [ + 897, + 898, + 899 + ] + }, + { + "teal": 778, + "source": "tests/contracts/storage.algo.ts:155", + "pc": [ + 900 + ] + }, + { + "teal": 779, + "source": "tests/contracts/storage.algo.ts:155", + "pc": [ + 901 + ] + }, + { + "teal": 780, + "source": "tests/contracts/storage.algo.ts:155", + "pc": [ + 902 + ] + }, + { + "teal": 781, + "source": "tests/contracts/storage.algo.ts:155", + "pc": [ + 903 + ] + }, + { + "teal": 782, + "source": "tests/contracts/storage.algo.ts:155", + "pc": [ + 904, + 905 + ] + }, + { + "teal": 783, + "source": "tests/contracts/storage.algo.ts:155", + "pc": [ + 906 + ] + }, + { + "teal": 787, + "source": "tests/contracts/storage.algo.ts:155", + "pc": [ + 907, + 908, + 909 + ] + }, + { + "teal": 791, + "source": "tests/contracts/storage.algo.ts:156", + "pc": [ + 910, + 911, + 912, + 913, + 914 + ] + }, + { + "teal": 792, + "source": "tests/contracts/storage.algo.ts:156", + "pc": [ + 915, + 916 + ] + }, + { + "teal": 793, + "source": "tests/contracts/storage.algo.ts:156", + "pc": [ + 917, + 918 + ] + }, + { + "teal": 794, + "source": "tests/contracts/storage.algo.ts:156", + "pc": [ + 919 + ] + }, + { + "teal": 795, + "source": "tests/contracts/storage.algo.ts:155", + "pc": [ + 920 + ] + }, + { + "teal": 800, + "source": "tests/contracts/storage.algo.ts:159", + "pc": [ + 921, + 922, + 923, + 924, + 925, + 926 + ] + }, + { + "teal": 803, + "source": "tests/contracts/storage.algo.ts:159", + "pc": [ + 927, + 928, + 929 + ] + }, + { + "teal": 804, + "source": "tests/contracts/storage.algo.ts:159", + "pc": [ + 930, + 931, + 932 + ] + }, + { + "teal": 805, + "source": "tests/contracts/storage.algo.ts:159", + "pc": [ + 933, + 934 + ] + }, + { + "teal": 806, + "source": "tests/contracts/storage.algo.ts:159", + "pc": [ + 935, + 936 + ] + }, + { + "teal": 807, + "source": "tests/contracts/storage.algo.ts:159", + "pc": [ + 937 + ] + }, + { + "teal": 808, + "source": "tests/contracts/storage.algo.ts:159", + "pc": [ + 938 + ] + }, + { + "teal": 809, + "source": "tests/contracts/storage.algo.ts:159", + "pc": [ + 939 + ] + }, + { + "teal": 810, + "source": "tests/contracts/storage.algo.ts:159", + "pc": [ + 940, + 941 + ] + }, + { + "teal": 811, + "source": "tests/contracts/storage.algo.ts:159", + "pc": [ + 942 + ] + }, + { + "teal": 815, + "source": "tests/contracts/storage.algo.ts:159", + "pc": [ + 943, + 944, + 945 + ] + }, + { + "teal": 819, + "source": "tests/contracts/storage.algo.ts:160", + "pc": [ + 946, + 947 + ] + }, + { + "teal": 820, + "source": "tests/contracts/storage.algo.ts:160", + "pc": [ + 948, + 949, + 950 + ] + }, + { + "teal": 821, + "source": "tests/contracts/storage.algo.ts:160", + "pc": [ + 951 + ] + }, + { + "teal": 822, + "source": "tests/contracts/storage.algo.ts:159", + "pc": [ + 952 + ] + }, + { + "teal": 827, + "source": "tests/contracts/storage.algo.ts:163", + "pc": [ + 953, + 954, + 955 + ] + }, + { + "teal": 828, + "source": "tests/contracts/storage.algo.ts:163", + "pc": [ + 956, + 957 + ] + }, + { + "teal": 829, + "source": "tests/contracts/storage.algo.ts:163", + "pc": [ + 958 + ] + }, + { + "teal": 833, + "source": "tests/contracts/storage.algo.ts:163", + "pc": [ + 959, + 960, + 961 + ] + }, + { + "teal": 837, + "source": "tests/contracts/storage.algo.ts:164", + "pc": [ + 962, + 963, + 964 + ] + }, + { + "teal": 838, + "source": "tests/contracts/storage.algo.ts:164", + "pc": [ + 965, + 966, + 967, + 968, + 969 + ] + }, + { + "teal": 839, + "source": "tests/contracts/storage.algo.ts:164", + "pc": [ + 970 + ] + }, + { + "teal": 842, + "source": "tests/contracts/storage.algo.ts:164", + "errorMessage": "global state value does not exist: this.app.globalState('foo')", + "pc": [ + 971 + ] + }, + { + "teal": 843, + "source": "tests/contracts/storage.algo.ts:164", + "pc": [ + 972 + ] + }, + { + "teal": 844, + "source": "tests/contracts/storage.algo.ts:163", + "pc": [ + 973 + ] + }, + { + "teal": 849, + "source": "tests/contracts/storage.algo.ts:167", + "pc": [ + 974, + 975, + 976 + ] + }, + { + "teal": 850, + "source": "tests/contracts/storage.algo.ts:167", + "pc": [ + 977, + 978 + ] + }, + { + "teal": 851, + "source": "tests/contracts/storage.algo.ts:167", + "pc": [ + 979 + ] + }, + { + "teal": 855, + "source": "tests/contracts/storage.algo.ts:167", + "pc": [ + 980, + 981, + 982 + ] + }, + { + "teal": 859, + "source": "tests/contracts/storage.algo.ts:168", + "pc": [ + 983, + 984 + ] + }, + { + "teal": 860, + "source": "tests/contracts/storage.algo.ts:168", + "pc": [ + 985, + 986, + 987 + ] + }, + { + "teal": 861, + "source": "tests/contracts/storage.algo.ts:168", + "pc": [ + 988, + 989, + 990, + 991, + 992 + ] + }, + { + "teal": 862, + "source": "tests/contracts/storage.algo.ts:168", + "pc": [ + 993 + ] + }, + { + "teal": 865, + "source": "tests/contracts/storage.algo.ts:168", + "errorMessage": "local state value does not exist: this.app.localState(this.txn.sender, 'foo')", + "pc": [ + 994 + ] + }, + { + "teal": 866, + "source": "tests/contracts/storage.algo.ts:168", + "pc": [ + 995 + ] + }, + { + "teal": 867, + "source": "tests/contracts/storage.algo.ts:167", + "pc": [ + 996 + ] + }, + { + "teal": 872, + "source": "tests/contracts/storage.algo.ts:171", + "pc": [ + 997, + 998, + 999, + 1000, + 1001, + 1002 + ] + }, + { + "teal": 875, + "source": "tests/contracts/storage.algo.ts:171", + "pc": [ + 1003, + 1004, + 1005 + ] + }, + { + "teal": 876, + "source": "tests/contracts/storage.algo.ts:171", + "pc": [ + 1006 + ] + }, + { + "teal": 877, + "source": "tests/contracts/storage.algo.ts:171", + "pc": [ + 1007 + ] + }, + { + "teal": 878, + "source": "tests/contracts/storage.algo.ts:171", + "pc": [ + 1008 + ] + }, + { + "teal": 879, + "source": "tests/contracts/storage.algo.ts:171", + "pc": [ + 1009, + 1010 + ] + }, + { + "teal": 880, + "source": "tests/contracts/storage.algo.ts:171", + "pc": [ + 1011 + ] + }, + { + "teal": 883, + "source": "tests/contracts/storage.algo.ts:171", + "errorMessage": "accessStaticValueInLargeBox return value overflowed 16 bits", + "pc": [ + 1012 + ] + }, + { + "teal": 884, + "source": "tests/contracts/storage.algo.ts:171", + "pc": [ + 1013, + 1014, + 1015 + ] + }, + { + "teal": 885, + "source": "tests/contracts/storage.algo.ts:171", + "pc": [ + 1016 + ] + }, + { + "teal": 886, + "source": "tests/contracts/storage.algo.ts:171", + "pc": [ + 1017 + ] + }, + { + "teal": 887, + "source": "tests/contracts/storage.algo.ts:171", + "pc": [ + 1018, + 1019 + ] + }, + { + "teal": 888, + "source": "tests/contracts/storage.algo.ts:171", + "pc": [ + 1020 + ] + }, + { + "teal": 892, + "source": "tests/contracts/storage.algo.ts:171", + "pc": [ + 1021, + 1022, + 1023 + ] + }, + { + "teal": 896, + "source": "tests/contracts/storage.algo.ts:172", + "pc": [ + 1024, + 1025, + 1026, + 1027, + 1028, + 1029, + 1030, + 1031, + 1032, + 1033, + 1034, + 1035, + 1036, + 1037, + 1038, + 1039, + 1040, + 1041, + 1042, + 1043, + 1044, + 1045, + 1046 + ] + }, + { + "teal": 897, + "source": "tests/contracts/storage.algo.ts:172", + "pc": [ + 1047, + 1048, + 1049 + ] + }, + { + "teal": 898, + "source": "tests/contracts/storage.algo.ts:172", + "pc": [ + 1050 + ] + }, + { + "teal": 899, + "source": "tests/contracts/storage.algo.ts:172", + "pc": [ + 1051 + ] + }, + { + "teal": 903, + "source": "tests/contracts/storage.algo.ts:173", + "pc": [ + 1052, + 1053, + 1054, + 1055, + 1056, + 1057, + 1058, + 1059, + 1060, + 1061, + 1062, + 1063, + 1064, + 1065, + 1066, + 1067, + 1068, + 1069, + 1070, + 1071, + 1072, + 1073, + 1074 + ] + }, + { + "teal": 904, + "source": "tests/contracts/storage.algo.ts:173", + "pc": [ + 1075, + 1076, + 1077 + ] + }, + { + "teal": 905, + "source": "tests/contracts/storage.algo.ts:173", + "pc": [ + 1078, + 1079, + 1080, + 1081 + ] + }, + { + "teal": 906, + "source": "tests/contracts/storage.algo.ts:173", + "pc": [ + 1082 + ] + }, + { + "teal": 910, + "source": "tests/contracts/storage.algo.ts:175", + "pc": [ + 1083, + 1084, + 1085, + 1086, + 1087, + 1088, + 1089, + 1090, + 1091, + 1092, + 1093, + 1094, + 1095, + 1096, + 1097, + 1098, + 1099, + 1100, + 1101, + 1102, + 1103, + 1104, + 1105 + ] + }, + { + "teal": 911, + "source": "tests/contracts/storage.algo.ts:175", + "pc": [ + 1106, + 1107, + 1108 + ] + }, + { + "teal": 912, + "source": "tests/contracts/storage.algo.ts:175", + "pc": [ + 1109, + 1110 + ] + }, + { + "teal": 913, + "source": "tests/contracts/storage.algo.ts:175", + "pc": [ + 1111 + ] + }, + { + "teal": 914, + "source": "tests/contracts/storage.algo.ts:175", + "pc": [ + 1112 + ] + }, + { + "teal": 915, + "source": "tests/contracts/storage.algo.ts:171", + "pc": [ + 1113 + ] + }, + { + "teal": 920, + "source": "tests/contracts/storage.algo.ts:178", + "pc": [ + 1114, + 1115, + 1116, + 1117, + 1118, + 1119 + ] + }, + { + "teal": 923, + "source": "tests/contracts/storage.algo.ts:178", + "pc": [ + 1120, + 1121, + 1122 + ] + }, + { + "teal": 924, + "source": "tests/contracts/storage.algo.ts:178", + "pc": [ + 1123 + ] + }, + { + "teal": 927, + "source": "tests/contracts/storage.algo.ts:178", + "pc": [ + 1124, + 1125, + 1126 + ] + }, + { + "teal": 928, + "source": "tests/contracts/storage.algo.ts:178", + "pc": [ + 1127 + ] + }, + { + "teal": 929, + "source": "tests/contracts/storage.algo.ts:178", + "pc": [ + 1128 + ] + }, + { + "teal": 930, + "source": "tests/contracts/storage.algo.ts:178", + "pc": [ + 1129 + ] + }, + { + "teal": 931, + "source": "tests/contracts/storage.algo.ts:178", + "pc": [ + 1130, + 1131 + ] + }, + { + "teal": 932, + "source": "tests/contracts/storage.algo.ts:178", + "pc": [ + 1132 + ] + }, + { + "teal": 935, + "source": "tests/contracts/storage.algo.ts:178", + "errorMessage": "dynamicAccessStaticValueInLargeBox return value overflowed 16 bits", + "pc": [ + 1133 + ] + }, + { + "teal": 936, + "source": "tests/contracts/storage.algo.ts:178", + "pc": [ + 1134, + 1135, + 1136 + ] + }, + { + "teal": 937, + "source": "tests/contracts/storage.algo.ts:178", + "pc": [ + 1137 + ] + }, + { + "teal": 938, + "source": "tests/contracts/storage.algo.ts:178", + "pc": [ + 1138 + ] + }, + { + "teal": 939, + "source": "tests/contracts/storage.algo.ts:178", + "pc": [ + 1139, + 1140 + ] + }, + { + "teal": 940, + "source": "tests/contracts/storage.algo.ts:178", + "pc": [ + 1141 + ] + }, + { + "teal": 944, + "source": "tests/contracts/storage.algo.ts:178", + "pc": [ + 1142, + 1143, + 1144 + ] + }, + { + "teal": 948, + "source": "tests/contracts/storage.algo.ts:179", + "pc": [ + 1145, + 1146, + 1147, + 1148, + 1149, + 1150, + 1151, + 1152, + 1153, + 1154, + 1155, + 1156, + 1157, + 1158, + 1159, + 1160, + 1161, + 1162, + 1163, + 1164, + 1165, + 1166, + 1167 + ] + }, + { + "teal": 949, + "source": "tests/contracts/storage.algo.ts:179", + "pc": [ + 1168, + 1169, + 1170 + ] + }, + { + "teal": 950, + "source": "tests/contracts/storage.algo.ts:179", + "pc": [ + 1171 + ] + }, + { + "teal": 951, + "source": "tests/contracts/storage.algo.ts:179", + "pc": [ + 1172 + ] + }, + { + "teal": 955, + "source": "tests/contracts/storage.algo.ts:180", + "pc": [ + 1173, + 1174 + ] + }, + { + "teal": 956, + "source": "tests/contracts/storage.algo.ts:180", + "pc": [ + 1175, + 1176 + ] + }, + { + "teal": 957, + "source": "tests/contracts/storage.algo.ts:180", + "pc": [ + 1177 + ] + }, + { + "teal": 958, + "source": "tests/contracts/storage.algo.ts:180", + "pc": [ + 1178, + 1179, + 1180, + 1181 + ] + }, + { + "teal": 959, + "source": "tests/contracts/storage.algo.ts:180", + "pc": [ + 1182, + 1183, + 1184, + 1185, + 1186, + 1187, + 1188, + 1189, + 1190, + 1191, + 1192, + 1193, + 1194, + 1195, + 1196, + 1197, + 1198, + 1199, + 1200, + 1201, + 1202, + 1203, + 1204 + ] + }, + { + "teal": 960, + "source": "tests/contracts/storage.algo.ts:180", + "pc": [ + 1205, + 1206 + ] + }, + { + "teal": 961, + "source": "tests/contracts/storage.algo.ts:180", + "pc": [ + 1207 + ] + }, + { + "teal": 965, + "source": "tests/contracts/storage.algo.ts:184", + "pc": [ + 1208, + 1209 + ] + }, + { + "teal": 966, + "source": "tests/contracts/storage.algo.ts:184", + "pc": [ + 1210, + 1211 + ] + }, + { + "teal": 967, + "source": "tests/contracts/storage.algo.ts:184", + "pc": [ + 1212 + ] + }, + { + "teal": 968, + "source": "tests/contracts/storage.algo.ts:184", + "pc": [ + 1213, + 1214 + ] + }, + { + "teal": 969, + "source": "tests/contracts/storage.algo.ts:182", + "pc": [ + 1215, + 1216, + 1217, + 1218, + 1219, + 1220, + 1221, + 1222, + 1223, + 1224, + 1225, + 1226, + 1227, + 1228, + 1229, + 1230, + 1231, + 1232, + 1233, + 1234, + 1235, + 1236, + 1237 + ] + }, + { + "teal": 970, + "source": "tests/contracts/storage.algo.ts:182", + "pc": [ + 1238, + 1239 + ] + }, + { + "teal": 971, + "source": "tests/contracts/storage.algo.ts:182", + "pc": [ + 1240 + ] + }, + { + "teal": 972, + "source": "tests/contracts/storage.algo.ts:184", + "pc": [ + 1241 + ] + }, + { + "teal": 973, + "source": "tests/contracts/storage.algo.ts:178", + "pc": [ + 1242 + ] + }, + { + "teal": 978, + "source": "tests/contracts/storage.algo.ts:187", + "pc": [ + 1243, + 1244, + 1245 + ] + }, + { + "teal": 979, + "source": "tests/contracts/storage.algo.ts:187", + "pc": [ + 1246, + 1247 + ] + }, + { + "teal": 980, + "source": "tests/contracts/storage.algo.ts:187", + "pc": [ + 1248 + ] + }, + { + "teal": 984, + "source": "tests/contracts/storage.algo.ts:187", + "pc": [ + 1249, + 1250, + 1251 + ] + }, + { + "teal": 988, + "source": "tests/contracts/storage.algo.ts:188", + "pc": [ + 1252, + 1253, + 1254, + 1255, + 1256 + ] + }, + { + "teal": 989, + "source": "tests/contracts/storage.algo.ts:188", + "pc": [ + 1257, + 1258, + 1259 + ] + }, + { + "teal": 990, + "source": "tests/contracts/storage.algo.ts:188", + "pc": [ + 1260 + ] + }, + { + "teal": 994, + "source": "tests/contracts/storage.algo.ts:189", + "pc": [ + 1261, + 1262, + 1263, + 1264, + 1265 + ] + }, + { + "teal": 995, + "source": "tests/contracts/storage.algo.ts:189", + "pc": [ + 1266, + 1267, + 1268 + ] + }, + { + "teal": 996, + "source": "tests/contracts/storage.algo.ts:189", + "pc": [ + 1269 + ] + }, + { + "teal": 997, + "source": "tests/contracts/storage.algo.ts:187", + "pc": [ + 1270 + ] + }, + { + "teal": 1002, + "source": "tests/contracts/storage.algo.ts:192", + "pc": [ + 1271, + 1272, + 1273 + ] + }, + { + "teal": 1003, + "source": "tests/contracts/storage.algo.ts:192", + "pc": [ + 1274, + 1275 + ] + }, + { + "teal": 1004, + "source": "tests/contracts/storage.algo.ts:192", + "pc": [ + 1276 + ] + }, + { + "teal": 1008, + "source": "tests/contracts/storage.algo.ts:192", + "pc": [ + 1277, + 1278, + 1279 + ] + }, + { + "teal": 1012, + "source": "tests/contracts/storage.algo.ts:193", + "pc": [ + 1280, + 1281, + 1282, + 1283, + 1284 + ] + }, + { + "teal": 1013, + "source": "tests/contracts/storage.algo.ts:193", + "pc": [ + 1285, + 1286 + ] + }, + { + "teal": 1014, + "source": "tests/contracts/storage.algo.ts:193", + "pc": [ + 1287, + 1288 + ] + }, + { + "teal": 1015, + "source": "tests/contracts/storage.algo.ts:193", + "pc": [ + 1289, + 1290, + 1291, + 1292, + 1293 + ] + }, + { + "teal": 1016, + "source": "tests/contracts/storage.algo.ts:193", + "pc": [ + 1294 + ] + }, + { + "teal": 1020, + "source": "tests/contracts/storage.algo.ts:194", + "pc": [ + 1295, + 1296, + 1297, + 1298, + 1299 + ] + }, + { + "teal": 1021, + "source": "tests/contracts/storage.algo.ts:194", + "pc": [ + 1300, + 1301 + ] + }, + { + "teal": 1022, + "source": "tests/contracts/storage.algo.ts:194", + "pc": [ + 1302, + 1303 + ] + }, + { + "teal": 1023, + "source": "tests/contracts/storage.algo.ts:194", + "pc": [ + 1304, + 1305, + 1306, + 1307, + 1308 + ] + }, + { + "teal": 1024, + "source": "tests/contracts/storage.algo.ts:194", + "pc": [ + 1309 + ] + }, + { + "teal": 1025, + "source": "tests/contracts/storage.algo.ts:192", + "pc": [ + 1310 + ] + }, + { + "teal": 1030, + "source": "tests/contracts/storage.algo.ts:197", + "pc": [ + 1311, + 1312, + 1313 + ] + }, + { + "teal": 1031, + "source": "tests/contracts/storage.algo.ts:197", + "pc": [ + 1314, + 1315 + ] + }, + { + "teal": 1032, + "source": "tests/contracts/storage.algo.ts:197", + "pc": [ + 1316 + ] + }, + { + "teal": 1036, + "source": "tests/contracts/storage.algo.ts:197", + "pc": [ + 1317, + 1318, + 1319 + ] + }, + { + "teal": 1040, + "source": "tests/contracts/storage.algo.ts:198", + "pc": [ + 1320, + 1321, + 1322 + ] + }, + { + "teal": 1041, + "source": "tests/contracts/storage.algo.ts:198", + "pc": [ + 1323, + 1324, + 1325, + 1326, + 1327 + ] + }, + { + "teal": 1042, + "source": "tests/contracts/storage.algo.ts:198", + "pc": [ + 1328 + ] + }, + { + "teal": 1043, + "source": "tests/contracts/storage.algo.ts:198", + "pc": [ + 1329 + ] + }, + { + "teal": 1044, + "source": "tests/contracts/storage.algo.ts:198", + "pc": [ + 1330 + ] + }, + { + "teal": 1045, + "source": "tests/contracts/storage.algo.ts:198", + "pc": [ + 1331 + ] + }, + { + "teal": 1049, + "source": "tests/contracts/storage.algo.ts:199", + "pc": [ + 1332, + 1333 + ] + }, + { + "teal": 1050, + "source": "tests/contracts/storage.algo.ts:199", + "pc": [ + 1334, + 1335, + 1336 + ] + }, + { + "teal": 1051, + "source": "tests/contracts/storage.algo.ts:199", + "pc": [ + 1337, + 1338, + 1339, + 1340, + 1341 + ] + }, + { + "teal": 1052, + "source": "tests/contracts/storage.algo.ts:199", + "pc": [ + 1342 + ] + }, + { + "teal": 1053, + "source": "tests/contracts/storage.algo.ts:199", + "pc": [ + 1343 + ] + }, + { + "teal": 1054, + "source": "tests/contracts/storage.algo.ts:199", + "pc": [ + 1344 + ] + }, + { + "teal": 1055, + "source": "tests/contracts/storage.algo.ts:199", + "pc": [ + 1345 + ] + }, + { + "teal": 1056, + "source": "tests/contracts/storage.algo.ts:197", + "pc": [ + 1346 + ] + }, + { + "teal": 1059, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 1347, + 1348 + ] + }, + { + "teal": 1060, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 1349 + ] + }, + { + "teal": 1063, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 1350, + 1351, + 1352, + 1353, + 1354, + 1355 + ] + }, + { + "teal": 1064, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 1356, + 1357, + 1358 + ] + }, + { + "teal": 1065, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 1359, + 1360, + 1361, + 1362 + ] + }, + { + "teal": 1068, + "source": "tests/contracts/storage.algo.ts:4", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", + "pc": [ + 1363 + ] + }, + { + "teal": 1071, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 1364, + 1365, + 1366, + 1367, + 1368, + 1369 + ] + }, + { + "teal": 1072, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 1370, + 1371, + 1372, + 1373, + 1374, + 1375 + ] + }, + { + "teal": 1073, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 1376, + 1377, + 1378, + 1379, + 1380, + 1381 + ] + }, + { + "teal": 1074, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 1382, + 1383, + 1384, + 1385, + 1386, + 1387 + ] + }, + { + "teal": 1075, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 1388, + 1389, + 1390, + 1391, + 1392, + 1393 + ] + }, + { + "teal": 1076, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 1394, + 1395, + 1396, + 1397, + 1398, + 1399 + ] + }, + { + "teal": 1077, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 1400, + 1401, + 1402, + 1403, + 1404, + 1405 + ] + }, + { + "teal": 1078, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 1406, + 1407, + 1408, + 1409, + 1410, + 1411 + ] + }, + { + "teal": 1079, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 1412, + 1413, + 1414, + 1415, + 1416, + 1417 + ] + }, + { + "teal": 1080, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 1418, + 1419, + 1420, + 1421, + 1422, + 1423 + ] + }, + { + "teal": 1081, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 1424, + 1425, + 1426, + 1427, + 1428, + 1429 + ] + }, + { + "teal": 1082, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 1430, + 1431, + 1432, + 1433, + 1434, + 1435 + ] + }, + { + "teal": 1083, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 1436, + 1437, + 1438, + 1439, + 1440, + 1441 + ] + }, + { + "teal": 1084, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 1442, + 1443, + 1444, + 1445, + 1446, + 1447 + ] + }, + { + "teal": 1085, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 1448, + 1449, + 1450, + 1451, + 1452, + 1453 + ] + }, + { + "teal": 1086, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 1454, + 1455, + 1456, + 1457, + 1458, + 1459 + ] + }, + { + "teal": 1087, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 1460, + 1461, + 1462, + 1463, + 1464, + 1465 + ] + }, + { + "teal": 1088, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 1466, + 1467, + 1468, + 1469, + 1470, + 1471 + ] + }, + { + "teal": 1089, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 1472, + 1473, + 1474, + 1475, + 1476, + 1477 + ] + }, + { + "teal": 1090, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 1478, + 1479, + 1480, + 1481, + 1482, + 1483 + ] + }, + { + "teal": 1091, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 1484, + 1485, + 1486, + 1487, + 1488, + 1489 + ] + }, + { + "teal": 1092, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 1490, + 1491, + 1492, + 1493, + 1494, + 1495 + ] + }, + { + "teal": 1093, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 1496, + 1497, + 1498, + 1499, + 1500, + 1501 + ] + }, + { + "teal": 1094, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 1502, + 1503, + 1504, + 1505, + 1506, + 1507 + ] + }, + { + "teal": 1095, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 1508, + 1509, + 1510, + 1511, + 1512, + 1513 + ] + }, + { + "teal": 1096, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 1514, + 1515, + 1516, + 1517, + 1518, + 1519 + ] + }, + { + "teal": 1097, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 1520, + 1521, + 1522, + 1523, + 1524, + 1525 + ] + }, + { + "teal": 1098, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 1526, + 1527, + 1528, + 1529, + 1530, + 1531 + ] + }, + { + "teal": 1099, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 1532, + 1533, + 1534, + 1535, + 1536, + 1537 + ] + }, + { + "teal": 1100, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 1538, + 1539, + 1540, + 1541, + 1542, + 1543 + ] + }, + { + "teal": 1101, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 1544, + 1545, + 1546, + 1547, + 1548, + 1549 + ] + }, + { + "teal": 1102, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 1550, + 1551, + 1552, + 1553, + 1554, + 1555 + ] + }, + { + "teal": 1103, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 1556, + 1557, + 1558, + 1559, + 1560, + 1561 + ] + }, + { + "teal": 1104, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 1562, + 1563, + 1564, + 1565, + 1566, + 1567 + ] + }, + { + "teal": 1105, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 1568, + 1569, + 1570, + 1571, + 1572, + 1573 + ] + }, + { + "teal": 1106, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 1574, + 1575, + 1576, + 1577, + 1578, + 1579 + ] + }, + { + "teal": 1107, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 1580, + 1581, + 1582, + 1583, + 1584, + 1585 + ] + }, + { + "teal": 1108, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 1586, + 1587, + 1588, + 1589, + 1590, + 1591 + ] + }, + { + "teal": 1109, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 1592, + 1593, + 1594, + 1595, + 1596, + 1597 + ] + }, + { + "teal": 1110, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 1598, + 1599, + 1600, + 1601, + 1602, + 1603 + ] + }, + { + "teal": 1111, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 1604, + 1605, + 1606, + 1607, + 1608, + 1609 + ] + }, + { + "teal": 1112, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 1610, + 1611, + 1612 + ] + }, + { + "teal": 1113, + "source": "tests/contracts/storage.algo.ts:4", + "pc": [ + 1613, + 1614, + 1615, + 1616, + 1617, + 1618, + 1619, + 1620, + 1621, + 1622, + 1623, + 1624, + 1625, + 1626, + 1627, + 1628, + 1629, + 1630, + 1631, + 1632, + 1633, + 1634, + 1635, + 1636, + 1637, + 1638, + 1639, + 1640, + 1641, + 1642, + 1643, + 1644, + 1645, + 1646, + 1647, + 1648, + 1649, + 1650, + 1651, + 1652, + 1653, + 1654, + 1655, + 1656, + 1657, + 1658, + 1659, + 1660, + 1661, + 1662, + 1663, + 1664, + 1665, + 1666, + 1667, + 1668, + 1669, + 1670, + 1671, + 1672, + 1673, + 1674, + 1675, + 1676, + 1677, + 1678, + 1679, + 1680, + 1681, + 1682, + 1683, + 1684, + 1685, + 1686, + 1687, + 1688, + 1689, + 1690, + 1691, + 1692, + 1693, + 1694, + 1695, + 1696 + ] }, { + "teal": 1116, + "source": "tests/contracts/storage.algo.ts:4", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 1697 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "none" diff --git a/tests/contracts/artifacts/Templates.arc56_draft.json b/tests/contracts/artifacts/Templates.arc56_draft.json index 13a1cb5e5..72a5f3930 100644 --- a/tests/contracts/artifacts/Templates.arc56_draft.json +++ b/tests/contracts/artifacts/Templates.arc56_draft.json @@ -103,28 +103,560 @@ "approval": { "sourceInfo": [ { + "teal": 11, + "source": "tests/contracts/general.algo.ts:24", + "pc": [ + 1 + ] + }, + { + "teal": 12, + "source": "tests/contracts/general.algo.ts:24", + "pc": [ + 2 + ] + }, + { + "teal": 13, + "source": "tests/contracts/general.algo.ts:24", + "pc": [ + 3 + ] + }, + { + "teal": 14, + "source": "tests/contracts/general.algo.ts:24", + "pc": [ + 4 + ] + }, + { + "teal": 21, + "source": "tests/contracts/general.algo.ts:24", + "pc": [ + 5, + 6 + ] + }, + { + "teal": 22, + "source": "tests/contracts/general.algo.ts:24", + "pc": [ + 7 + ] + }, + { + "teal": 23, + "source": "tests/contracts/general.algo.ts:24", + "pc": [ + 8, + 9 + ] + }, + { + "teal": 24, + "source": "tests/contracts/general.algo.ts:24", + "pc": [ + 10 + ] + }, + { + "teal": 25, + "source": "tests/contracts/general.algo.ts:24", + "pc": [ + 11, + 12 + ] + }, + { + "teal": 26, + "source": "tests/contracts/general.algo.ts:24", + "pc": [ + 13 + ] + }, + { + "teal": 27, + "source": "tests/contracts/general.algo.ts:24", + "pc": [ + 14, + 15, + 16, + 17, + 18, + 19, + 20, + 21, + 22, + 23, + 24, + 25, + 26, + 27, + 28, + 29, + 30, + 31, + 32, + 33, + 34, + 35, + 36, + 37, + 38, + 39 + ] + }, + { + "teal": 31, + "source": "tests/contracts/general.algo.ts:24", + "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?", "pc": [ 40 - ], - "errorMessage": "The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?" + ] + }, + { + "teal": 36, + "source": "tests/contracts/general.algo.ts:33", + "pc": [ + 41, + 42, + 43 + ] + }, + { + "teal": 37, + "source": "tests/contracts/general.algo.ts:33", + "pc": [ + 44, + 45 + ] + }, + { + "teal": 38, + "source": "tests/contracts/general.algo.ts:33", + "pc": [ + 46 + ] + }, + { + "teal": 42, + "source": "tests/contracts/general.algo.ts:33", + "pc": [ + 47, + 48, + 49 + ] + }, + { + "teal": 46, + "source": "tests/contracts/general.algo.ts:34", + "pc": [ + 50 + ] + }, + { + "teal": 47, + "source": "tests/contracts/general.algo.ts:34", + "pc": [ + 51 + ] + }, + { + "teal": 51, + "source": "tests/contracts/general.algo.ts:35", + "pc": [ + 52 + ] + }, + { + "teal": 52, + "source": "tests/contracts/general.algo.ts:35", + "pc": [ + 53 + ] + }, + { + "teal": 53, + "source": "tests/contracts/general.algo.ts:33", + "pc": [ + 54 + ] + }, + { + "teal": 58, + "source": "tests/contracts/general.algo.ts:38", + "pc": [ + 55, + 56, + 57 + ] + }, + { + "teal": 59, + "source": "tests/contracts/general.algo.ts:38", + "pc": [ + 58, + 59 + ] + }, + { + "teal": 60, + "source": "tests/contracts/general.algo.ts:38", + "pc": [ + 60 + ] }, { + "teal": 64, + "source": "tests/contracts/general.algo.ts:38", + "pc": [ + 61, + 62, + 63 + ] + }, + { + "teal": 68, + "source": "tests/contracts/general.algo.ts:39", + "pc": [ + 64 + ] + }, + { + "teal": 69, + "source": "tests/contracts/general.algo.ts:39", + "pc": [ + 65 + ] + }, + { + "teal": 70, + "source": "tests/contracts/general.algo.ts:39", + "pc": [ + 66 + ] + }, + { + "teal": 71, + "source": "tests/contracts/general.algo.ts:39", + "pc": [ + 67 + ] + }, + { + "teal": 72, + "source": "tests/contracts/general.algo.ts:38", + "pc": [ + 68 + ] + }, + { + "teal": 77, + "source": "tests/contracts/general.algo.ts:42", + "pc": [ + 69, + 70, + 71 + ] + }, + { + "teal": 78, + "source": "tests/contracts/general.algo.ts:42", + "pc": [ + 72, + 73 + ] + }, + { + "teal": 79, + "source": "tests/contracts/general.algo.ts:42", + "pc": [ + 74 + ] + }, + { + "teal": 83, + "source": "tests/contracts/general.algo.ts:42", + "pc": [ + 75, + 76, + 77 + ] + }, + { + "teal": 86, + "source": "tests/contracts/general.algo.ts:43", + "errorMessage": "this is an error", "pc": [ 78 - ], - "errorMessage": "this is an error" + ] + }, + { + "teal": 87, + "source": "tests/contracts/general.algo.ts:42", + "pc": [ + 79 + ] + }, + { + "teal": 92, + "source": "tests/contracts/general.algo.ts:46", + "pc": [ + 80, + 81, + 82, + 83, + 84, + 85 + ] + }, + { + "teal": 95, + "source": "tests/contracts/general.algo.ts:46", + "pc": [ + 86, + 87, + 88 + ] + }, + { + "teal": 96, + "source": "tests/contracts/general.algo.ts:46", + "pc": [ + 89 + ] + }, + { + "teal": 97, + "source": "tests/contracts/general.algo.ts:46", + "pc": [ + 90 + ] + }, + { + "teal": 98, + "source": "tests/contracts/general.algo.ts:46", + "pc": [ + 91 + ] + }, + { + "teal": 99, + "source": "tests/contracts/general.algo.ts:46", + "pc": [ + 92, + 93, + 94 + ] + }, + { + "teal": 100, + "source": "tests/contracts/general.algo.ts:46", + "pc": [ + 95 + ] + }, + { + "teal": 101, + "source": "tests/contracts/general.algo.ts:46", + "pc": [ + 96 + ] + }, + { + "teal": 102, + "source": "tests/contracts/general.algo.ts:46", + "pc": [ + 97 + ] + }, + { + "teal": 103, + "source": "tests/contracts/general.algo.ts:46", + "pc": [ + 98 + ] + }, + { + "teal": 104, + "source": "tests/contracts/general.algo.ts:46", + "pc": [ + 99, + 100 + ] + }, + { + "teal": 105, + "source": "tests/contracts/general.algo.ts:46", + "pc": [ + 101 + ] }, { + "teal": 109, + "source": "tests/contracts/general.algo.ts:46", + "pc": [ + 102, + 103, + 104 + ] + }, + { + "teal": 113, + "source": "tests/contracts/general.algo.ts:47", + "pc": [ + 105 + ] + }, + { + "teal": 114, + "source": "tests/contracts/general.algo.ts:47", + "pc": [ + 106 + ] + }, + { + "teal": 115, + "source": "tests/contracts/general.algo.ts:46", + "pc": [ + 107 + ] + }, + { + "teal": 118, + "source": "tests/contracts/general.algo.ts:24", + "pc": [ + 108, + 109 + ] + }, + { + "teal": 119, + "source": "tests/contracts/general.algo.ts:24", + "pc": [ + 110 + ] + }, + { + "teal": 122, + "source": "tests/contracts/general.algo.ts:24", + "pc": [ + 111, + 112, + 113, + 114, + 115, + 116 + ] + }, + { + "teal": 123, + "source": "tests/contracts/general.algo.ts:24", + "pc": [ + 117, + 118, + 119 + ] + }, + { + "teal": 124, + "source": "tests/contracts/general.algo.ts:24", + "pc": [ + 120, + 121, + 122, + 123 + ] + }, + { + "teal": 127, + "source": "tests/contracts/general.algo.ts:24", + "errorMessage": "this contract does not implement the given ABI method for create NoOp", "pc": [ 124 - ], - "errorMessage": "this contract does not implement the given ABI method for create NoOp" + ] + }, + { + "teal": 130, + "source": "tests/contracts/general.algo.ts:24", + "pc": [ + 125, + 126, + 127, + 128, + 129, + 130 + ] + }, + { + "teal": 131, + "source": "tests/contracts/general.algo.ts:24", + "pc": [ + 131, + 132, + 133, + 134, + 135, + 136 + ] + }, + { + "teal": 132, + "source": "tests/contracts/general.algo.ts:24", + "pc": [ + 137, + 138, + 139, + 140, + 141, + 142 + ] + }, + { + "teal": 133, + "source": "tests/contracts/general.algo.ts:24", + "pc": [ + 143, + 144, + 145, + 146, + 147, + 148 + ] + }, + { + "teal": 134, + "source": "tests/contracts/general.algo.ts:24", + "pc": [ + 149, + 150, + 151 + ] + }, + { + "teal": 135, + "source": "tests/contracts/general.algo.ts:24", + "pc": [ + 152, + 153, + 154, + 155, + 156, + 157, + 158, + 159, + 160, + 161 + ] }, { + "teal": 138, + "source": "tests/contracts/general.algo.ts:24", + "errorMessage": "this contract does not implement the given ABI method for call NoOp", "pc": [ 162 - ], - "errorMessage": "this contract does not implement the given ABI method for call NoOp" + ] } ], "pcOffsetMethod": "cblocks" From 60fa88ebf38fcea4f112f3b7b7c0467507838d1e Mon Sep 17 00:00:00 2001 From: Joe Polny Date: Wed, 23 Oct 2024 08:17:25 -0400 Subject: [PATCH 2/4] feat: only warn once on dynamic tmpl vars and improve error message --- src/lib/compiler.ts | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/src/lib/compiler.ts b/src/lib/compiler.ts index c625af767..eea3c5389 100644 --- a/src/lib/compiler.ts +++ b/src/lib/compiler.ts @@ -7491,6 +7491,7 @@ declare type AssetFreezeTxn = Required; } async algodCompileProgram(program: 'approval' | 'clear' | 'lsig'): Promise<{ result: string; hash: string }> { + let dynamicTemplateWarning = false; const body = this.teal[program] .map((t) => t.teal) .map((t) => { @@ -7502,14 +7503,15 @@ declare type AssetFreezeTxn = Required; if (tVar === undefined) return arg; if (this.isDynamicType(tVar.type) || isNumeric(tVar.type)) { - if (program === 'lsig' || program === 'approval') { + if (program === 'lsig' || (program === 'approval' && !dynamicTemplateWarning)) { console.warn( `WARNING: Due to dynamic template variable type for ${tVar.name} (${typeInfoToABIString( tVar.type - )}) PC values will be offset from first opcode after constant blocks` + )}) PC values will be offset from first opcode after constant blocks. This will be handled by algokit clients, but ARC56 has a minimal reference implementation available for scenarios where algokit is not being used: https://github.com/joe-p/ARCs/blob/extended_app_description/ARCs/arc-0056.md#calculating-cblock-offsets` ); this.hasDynamicTemplateVar = true; + dynamicTemplateWarning = true; } return isNumeric(tVar.type) ? '0' : '0x'; From bd92778bf7b97b6a1ca463387c1dee062b4360a3 Mon Sep 17 00:00:00 2001 From: Joe Polny Date: Wed, 23 Oct 2024 08:33:32 -0400 Subject: [PATCH 3/4] fix: improve internal error message for pc mapping --- src/lib/compiler.ts | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/src/lib/compiler.ts b/src/lib/compiler.ts index eea3c5389..3caa964ce 100644 --- a/src/lib/compiler.ts +++ b/src/lib/compiler.ts @@ -7613,6 +7613,16 @@ declare type AssetFreezeTxn = Required; this.sourceInfo.forEach((sm) => { if (this.hasDynamicTemplateVar) { if (sm.teal - 1 <= lastCblockLine) return; + const pcs = this.lineToPc[sm.teal - 1]; + + if (pcs === undefined) { + throw new Error( + `Internal Compiler Error: PC values not found when trying to calculate cblock offsets for TEAL line ${ + sm.teal + } (${this.teal[program][sm.teal - 1].teal}). Last cblock line was ${lastCblockLine}.` + ); + } + // eslint-disable-next-line no-param-reassign sm.pc = this.lineToPc[sm.teal - 1].map((pc) => pc - lastCblockPc); return; From 21dc643d57c85aca0af08bafe8721860f799c7c0 Mon Sep 17 00:00:00 2001 From: Joe Polny Date: Wed, 23 Oct 2024 08:43:26 -0400 Subject: [PATCH 4/4] 0.105.0 --- .../amm/tealscript_artifacts/ConstantProductAMM.approval.teal | 2 +- examples/amm/tealscript_artifacts/ConstantProductAMM.arc32.json | 2 +- .../tealscript_artifacts/ConstantProductAMM.arc56_draft.json | 2 +- examples/arc58/artifacts/AbstractedAccount.approval.teal | 2 +- examples/arc58/artifacts/AbstractedAccount.arc32.json | 2 +- examples/arc58/artifacts/AbstractedAccount.arc56_draft.json | 2 +- examples/arc72/artifacts/ARC72.approval.teal | 2 +- examples/arc72/artifacts/ARC72.arc32.json | 2 +- examples/arc72/artifacts/ARC72.arc56_draft.json | 2 +- examples/arc75/artifacts/ARC75.approval.teal | 2 +- examples/arc75/artifacts/ARC75.arc32.json | 2 +- examples/arc75/artifacts/ARC75.arc56_draft.json | 2 +- examples/auction/tealscript_artifacts/Auction.approval.teal | 2 +- examples/auction/tealscript_artifacts/Auction.arc32.json | 2 +- examples/auction/tealscript_artifacts/Auction.arc56_draft.json | 2 +- examples/big_box/artifacts/BigBox.approval.teal | 2 +- examples/big_box/artifacts/BigBox.arc32.json | 2 +- examples/big_box/artifacts/BigBox.arc56_draft.json | 2 +- examples/calculator/artifacts/Calculator.approval.teal | 2 +- examples/calculator/artifacts/Calculator.arc32.json | 2 +- examples/calculator/artifacts/Calculator.arc56_draft.json | 2 +- examples/itxns/artifacts/FactoryCaller.approval.teal | 2 +- examples/itxns/artifacts/FactoryCaller.arc32.json | 2 +- examples/itxns/artifacts/FactoryCaller.arc56_draft.json | 2 +- examples/itxns/artifacts/NFTFactory.approval.teal | 2 +- examples/itxns/artifacts/NFTFactory.arc32.json | 2 +- examples/itxns/artifacts/NFTFactory.arc56_draft.json | 2 +- examples/lsig_with_app/artifacts/CreatorVerifier.approval.teal | 2 +- examples/lsig_with_app/artifacts/CreatorVerifier.arc32.json | 2 +- .../lsig_with_app/artifacts/CreatorVerifier.arc56_draft.json | 2 +- examples/lsig_with_app/artifacts/OptInLsig.lsig.teal | 2 +- examples/merkle/artifacts/MerkleTree.approval.teal | 2 +- examples/merkle/artifacts/MerkleTree.arc32.json | 2 +- examples/merkle/artifacts/MerkleTree.arc56_draft.json | 2 +- examples/non_abi/artifacts/NonABIExample.approval.teal | 2 +- examples/non_abi/artifacts/NonABIExample.arc32.json | 2 +- examples/non_abi/artifacts/NonABIExample.arc56_draft.json | 2 +- examples/optin-lsig/artifacts/LsigExample.lsig.teal | 2 +- examples/reti/artifacts/StakingPool.approval.teal | 2 +- examples/reti/artifacts/StakingPool.arc32.json | 2 +- examples/reti/artifacts/StakingPool.arc56_draft.json | 2 +- examples/reti/artifacts/ValidatorRegistry.approval.teal | 2 +- examples/reti/artifacts/ValidatorRegistry.arc32.json | 2 +- examples/reti/artifacts/ValidatorRegistry.arc56_draft.json | 2 +- examples/simple/artifacts/Simple.approval.teal | 2 +- examples/simple/artifacts/Simple.arc32.json | 2 +- examples/simple/artifacts/Simple.arc56_draft.json | 2 +- .../tuple_in_box/tealscript_artifacts/ContactsApp.approval.teal | 2 +- .../tuple_in_box/tealscript_artifacts/ContactsApp.arc32.json | 2 +- .../tealscript_artifacts/ContactsApp.arc56_draft.json | 2 +- package.json | 2 +- src/version.ts | 2 +- tests/contracts/artifacts/A.approval.teal | 2 +- tests/contracts/artifacts/A.arc32.json | 2 +- tests/contracts/artifacts/A.arc56_draft.json | 2 +- .../contracts/artifacts/ABITestAccesStringInTuple.approval.teal | 2 +- tests/contracts/artifacts/ABITestAccesStringInTuple.arc32.json | 2 +- .../artifacts/ABITestAccesStringInTuple.arc56_draft.json | 2 +- .../ABITestAccessDynamicArrayElementInTuple.approval.teal | 2 +- .../ABITestAccessDynamicArrayElementInTuple.arc32.json | 2 +- .../ABITestAccessDynamicArrayElementInTuple.arc56_draft.json | 2 +- .../ABITestAccessDynamicArrayInMiddleOfTuple.approval.teal | 2 +- .../ABITestAccessDynamicArrayInMiddleOfTuple.arc32.json | 2 +- .../ABITestAccessDynamicArrayInMiddleOfTuple.arc56_draft.json | 2 +- .../artifacts/ABITestAccessDynamicStringArray.approval.teal | 2 +- .../artifacts/ABITestAccessDynamicStringArray.arc32.json | 2 +- .../artifacts/ABITestAccessDynamicStringArray.arc56_draft.json | 2 +- .../ABITestAccessStaticArrayInBoxInVariable.approval.teal | 2 +- .../ABITestAccessStaticArrayInBoxInVariable.arc32.json | 2 +- .../ABITestAccessStaticArrayInBoxInVariable.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestAngularCasting.approval.teal | 2 +- tests/contracts/artifacts/ABITestAngularCasting.arc32.json | 2 +- .../contracts/artifacts/ABITestAngularCasting.arc56_draft.json | 2 +- .../contracts/artifacts/ABITestArrayInMethodCall.approval.teal | 2 +- tests/contracts/artifacts/ABITestArrayInMethodCall.arc32.json | 2 +- .../artifacts/ABITestArrayInMethodCall.arc56_draft.json | 2 +- .../artifacts/ABITestArrayInObjectInState.approval.teal | 2 +- .../contracts/artifacts/ABITestArrayInObjectInState.arc32.json | 2 +- .../artifacts/ABITestArrayInObjectInState.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestArrayInTuple.approval.teal | 2 +- tests/contracts/artifacts/ABITestArrayInTuple.arc32.json | 2 +- tests/contracts/artifacts/ABITestArrayInTuple.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestArrayLength.approval.teal | 2 +- tests/contracts/artifacts/ABITestArrayLength.arc32.json | 2 +- tests/contracts/artifacts/ABITestArrayLength.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestArrayPop.approval.teal | 2 +- tests/contracts/artifacts/ABITestArrayPop.arc32.json | 2 +- tests/contracts/artifacts/ABITestArrayPop.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestArrayPopValue.approval.teal | 2 +- tests/contracts/artifacts/ABITestArrayPopValue.arc32.json | 2 +- tests/contracts/artifacts/ABITestArrayPopValue.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestArrayPush.approval.teal | 2 +- tests/contracts/artifacts/ABITestArrayPush.arc32.json | 2 +- tests/contracts/artifacts/ABITestArrayPush.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestArrayRef.approval.teal | 2 +- tests/contracts/artifacts/ABITestArrayRef.arc32.json | 2 +- tests/contracts/artifacts/ABITestArrayRef.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestArraySplice.approval.teal | 2 +- tests/contracts/artifacts/ABITestArraySplice.arc32.json | 2 +- tests/contracts/artifacts/ABITestArraySplice.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestArraySpliceValue.approval.teal | 2 +- tests/contracts/artifacts/ABITestArraySpliceValue.arc32.json | 2 +- .../artifacts/ABITestArraySpliceValue.arc56_draft.json | 2 +- .../contracts/artifacts/ABITestBiggerByteCasting.approval.teal | 2 +- tests/contracts/artifacts/ABITestBiggerByteCasting.arc32.json | 2 +- .../artifacts/ABITestBiggerByteCasting.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestBoolFirstInTuple.approval.teal | 2 +- tests/contracts/artifacts/ABITestBoolFirstInTuple.arc32.json | 2 +- .../artifacts/ABITestBoolFirstInTuple.arc56_draft.json | 2 +- .../contracts/artifacts/ABITestBoolInNestedTuple.approval.teal | 2 +- tests/contracts/artifacts/ABITestBoolInNestedTuple.arc32.json | 2 +- .../artifacts/ABITestBoolInNestedTuple.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestBoolInObj.approval.teal | 2 +- tests/contracts/artifacts/ABITestBoolInObj.arc32.json | 2 +- tests/contracts/artifacts/ABITestBoolInObj.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestBoolTuple.approval.teal | 2 +- tests/contracts/artifacts/ABITestBoolTuple.arc32.json | 2 +- tests/contracts/artifacts/ABITestBoolTuple.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestBoolTupleAccess.approval.teal | 2 +- tests/contracts/artifacts/ABITestBoolTupleAccess.arc32.json | 2 +- .../contracts/artifacts/ABITestBoolTupleAccess.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestBoolTupleUpdate.approval.teal | 2 +- tests/contracts/artifacts/ABITestBoolTupleUpdate.arc32.json | 2 +- .../contracts/artifacts/ABITestBoolTupleUpdate.arc56_draft.json | 2 +- .../artifacts/ABITestBooleanArgAndReturn.approval.teal | 2 +- tests/contracts/artifacts/ABITestBooleanArgAndReturn.arc32.json | 2 +- .../artifacts/ABITestBooleanArgAndReturn.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestBooleanLastInObj.approval.teal | 2 +- tests/contracts/artifacts/ABITestBooleanLastInObj.arc32.json | 2 +- .../artifacts/ABITestBooleanLastInObj.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestBytesCasting.approval.teal | 2 +- tests/contracts/artifacts/ABITestBytesCasting.arc32.json | 2 +- tests/contracts/artifacts/ABITestBytesCasting.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestBytesReturn.approval.teal | 2 +- tests/contracts/artifacts/ABITestBytesReturn.arc32.json | 2 +- tests/contracts/artifacts/ABITestBytesReturn.arc56_draft.json | 2 +- .../contracts/artifacts/ABITestCastBytesFunction.approval.teal | 2 +- tests/contracts/artifacts/ABITestCastBytesFunction.arc32.json | 2 +- .../artifacts/ABITestCastBytesFunction.arc56_draft.json | 2 +- .../artifacts/ABITestChainedPropertyAfterTuple.approval.teal | 2 +- .../artifacts/ABITestChainedPropertyAfterTuple.arc32.json | 2 +- .../artifacts/ABITestChainedPropertyAfterTuple.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestCustomTypes.approval.teal | 2 +- tests/contracts/artifacts/ABITestCustomTypes.arc32.json | 2 +- tests/contracts/artifacts/ABITestCustomTypes.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestDisgusting.approval.teal | 2 +- tests/contracts/artifacts/ABITestDisgusting.arc32.json | 2 +- tests/contracts/artifacts/ABITestDisgusting.arc56_draft.json | 2 +- ...TestDynamicAccessOfDynamicElementInStaticArray.approval.teal | 2 +- ...ABITestDynamicAccessOfDynamicElementInStaticArray.arc32.json | 2 +- ...tDynamicAccessOfDynamicElementInStaticArray.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestDynamicArray.approval.teal | 2 +- tests/contracts/artifacts/ABITestDynamicArray.arc32.json | 2 +- tests/contracts/artifacts/ABITestDynamicArray.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestDynamicArrayArg.approval.teal | 2 +- tests/contracts/artifacts/ABITestDynamicArrayArg.arc32.json | 2 +- .../contracts/artifacts/ABITestDynamicArrayArg.arc56_draft.json | 2 +- .../artifacts/ABITestDynamicArrayElements.approval.teal | 2 +- .../contracts/artifacts/ABITestDynamicArrayElements.arc32.json | 2 +- .../artifacts/ABITestDynamicArrayElements.arc56_draft.json | 2 +- .../artifacts/ABITestDynamicArrayInMiddleOfTuple.approval.teal | 2 +- .../artifacts/ABITestDynamicArrayInMiddleOfTuple.arc32.json | 2 +- .../ABITestDynamicArrayInMiddleOfTuple.arc56_draft.json | 2 +- .../artifacts/ABITestDynamicArrayIteration.approval.teal | 2 +- .../contracts/artifacts/ABITestDynamicArrayIteration.arc32.json | 2 +- .../artifacts/ABITestDynamicArrayIteration.arc56_draft.json | 2 +- .../contracts/artifacts/ABITestDynamicArrayLength.approval.teal | 2 +- tests/contracts/artifacts/ABITestDynamicArrayLength.arc32.json | 2 +- .../artifacts/ABITestDynamicArrayLength.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestDynamicBoolArray.approval.teal | 2 +- tests/contracts/artifacts/ABITestDynamicBoolArray.arc32.json | 2 +- .../artifacts/ABITestDynamicBoolArray.arc56_draft.json | 2 +- .../artifacts/ABITestDynamicBoolArrayAccess.approval.teal | 2 +- .../artifacts/ABITestDynamicBoolArrayAccess.arc32.json | 2 +- .../artifacts/ABITestDynamicBoolArrayAccess.arc56_draft.json | 2 +- .../artifacts/ABITestDynamicBoolArrayUpdate.approval.teal | 2 +- .../artifacts/ABITestDynamicBoolArrayUpdate.arc32.json | 2 +- .../artifacts/ABITestDynamicBoolArrayUpdate.arc56_draft.json | 2 +- .../contracts/artifacts/ABITestDynamicTupleArray.approval.teal | 2 +- tests/contracts/artifacts/ABITestDynamicTupleArray.arc32.json | 2 +- .../artifacts/ABITestDynamicTupleArray.arc56_draft.json | 2 +- .../contracts/artifacts/ABITestEmptyDynamicArray.approval.teal | 2 +- tests/contracts/artifacts/ABITestEmptyDynamicArray.arc32.json | 2 +- .../artifacts/ABITestEmptyDynamicArray.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestEmptyStaticArray.approval.teal | 2 +- tests/contracts/artifacts/ABITestEmptyStaticArray.arc32.json | 2 +- .../artifacts/ABITestEmptyStaticArray.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestExtractUint.approval.teal | 2 +- tests/contracts/artifacts/ABITestExtractUint.arc32.json | 2 +- tests/contracts/artifacts/ABITestExtractUint.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestForEachReturn.approval.teal | 2 +- tests/contracts/artifacts/ABITestForEachReturn.arc32.json | 2 +- tests/contracts/artifacts/ABITestForEachReturn.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestForOfBreak.approval.teal | 2 +- tests/contracts/artifacts/ABITestForOfBreak.arc32.json | 2 +- tests/contracts/artifacts/ABITestForOfBreak.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestForOfContinue.approval.teal | 2 +- tests/contracts/artifacts/ABITestForOfContinue.arc32.json | 2 +- tests/contracts/artifacts/ABITestForOfContinue.arc56_draft.json | 2 +- .../artifacts/ABITestGlobalMethodInChain.approval.teal | 2 +- tests/contracts/artifacts/ABITestGlobalMethodInChain.arc32.json | 2 +- .../artifacts/ABITestGlobalMethodInChain.arc56_draft.json | 2 +- .../ABITestLargeNestedStaticForEachInBox.approval.teal | 2 +- .../artifacts/ABITestLargeNestedStaticForEachInBox.arc32.json | 2 +- .../ABITestLargeNestedStaticForEachInBox.arc56_draft.json | 2 +- .../artifacts/ABITestLargeNestedStaticForOfInBox.approval.teal | 2 +- .../artifacts/ABITestLargeNestedStaticForOfInBox.arc32.json | 2 +- .../ABITestLargeNestedStaticForOfInBox.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestMaxUfixed.approval.teal | 2 +- tests/contracts/artifacts/ABITestMaxUfixed.arc32.json | 2 +- tests/contracts/artifacts/ABITestMaxUfixed.arc56_draft.json | 2 +- .../artifacts/ABITestMixedStaticArrayElements.approval.teal | 2 +- .../artifacts/ABITestMixedStaticArrayElements.arc32.json | 2 +- .../artifacts/ABITestMixedStaticArrayElements.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestMultiBytesTuple.approval.teal | 2 +- tests/contracts/artifacts/ABITestMultiBytesTuple.arc32.json | 2 +- .../contracts/artifacts/ABITestMultiBytesTuple.arc56_draft.json | 2 +- .../artifacts/ABITestMultiNestedArrayRef.approval.teal | 2 +- tests/contracts/artifacts/ABITestMultiNestedArrayRef.arc32.json | 2 +- .../artifacts/ABITestMultiNestedArrayRef.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestNamedTuple.approval.teal | 2 +- tests/contracts/artifacts/ABITestNamedTuple.arc32.json | 2 +- tests/contracts/artifacts/ABITestNamedTuple.arc56_draft.json | 2 +- .../artifacts/ABITestNestedArrayLengthInObject.approval.teal | 2 +- .../artifacts/ABITestNestedArrayLengthInObject.arc32.json | 2 +- .../artifacts/ABITestNestedArrayLengthInObject.arc56_draft.json | 2 +- .../ABITestNestedArrayLengthInObjectVariable.approval.teal | 2 +- .../ABITestNestedArrayLengthInObjectVariable.arc32.json | 2 +- .../ABITestNestedArrayLengthInObjectVariable.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestNestedArrayRef.approval.teal | 2 +- tests/contracts/artifacts/ABITestNestedArrayRef.arc32.json | 2 +- .../contracts/artifacts/ABITestNestedArrayRef.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestNestedObject.approval.teal | 2 +- tests/contracts/artifacts/ABITestNestedObject.arc32.json | 2 +- tests/contracts/artifacts/ABITestNestedObject.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestNestedObjectType.approval.teal | 2 +- tests/contracts/artifacts/ABITestNestedObjectType.arc32.json | 2 +- .../artifacts/ABITestNestedObjectType.arc56_draft.json | 2 +- .../contracts/artifacts/ABITestNestedStaticArray.approval.teal | 2 +- tests/contracts/artifacts/ABITestNestedStaticArray.arc32.json | 2 +- .../artifacts/ABITestNestedStaticArray.arc56_draft.json | 2 +- .../artifacts/ABITestNestedStaticArrayLength.approval.teal | 2 +- .../artifacts/ABITestNestedStaticArrayLength.arc32.json | 2 +- .../artifacts/ABITestNestedStaticArrayLength.arc56_draft.json | 2 +- .../artifacts/ABITestNestedStaticForEach.approval.teal | 2 +- tests/contracts/artifacts/ABITestNestedStaticForEach.arc32.json | 2 +- .../artifacts/ABITestNestedStaticForEach.arc56_draft.json | 2 +- .../artifacts/ABITestNestedStaticForEachInBox.approval.teal | 2 +- .../artifacts/ABITestNestedStaticForEachInBox.arc32.json | 2 +- .../artifacts/ABITestNestedStaticForEachInBox.arc56_draft.json | 2 +- .../artifacts/ABITestNestedStructInBoxMap.approval.teal | 2 +- .../contracts/artifacts/ABITestNestedStructInBoxMap.arc32.json | 2 +- .../artifacts/ABITestNestedStructInBoxMap.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestNestedTuple.approval.teal | 2 +- tests/contracts/artifacts/ABITestNestedTuple.arc32.json | 2 +- tests/contracts/artifacts/ABITestNestedTuple.arc56_draft.json | 2 +- .../artifacts/ABITestNestedTypesInSignature.approval.teal | 2 +- .../artifacts/ABITestNestedTypesInSignature.arc32.json | 2 +- .../artifacts/ABITestNestedTypesInSignature.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestNonE2E.approval.teal | 2 +- tests/contracts/artifacts/ABITestNonE2E.arc32.json | 2 +- tests/contracts/artifacts/ABITestNonE2E.arc56_draft.json | 2 +- .../ABITestNonLiteralDynamicElementInTuple.approval.teal | 2 +- .../artifacts/ABITestNonLiteralDynamicElementInTuple.arc32.json | 2 +- .../ABITestNonLiteralDynamicElementInTuple.arc56_draft.json | 2 +- .../artifacts/ABITestNonLiteralNestedArrayRef.approval.teal | 2 +- .../artifacts/ABITestNonLiteralNestedArrayRef.arc32.json | 2 +- .../artifacts/ABITestNonLiteralNestedArrayRef.arc56_draft.json | 2 +- .../artifacts/ABITestNonLiteralStaticArrayAccess.approval.teal | 2 +- .../artifacts/ABITestNonLiteralStaticArrayAccess.arc32.json | 2 +- .../ABITestNonLiteralStaticArrayAccess.arc56_draft.json | 2 +- .../ABITestNonLiteralStaticArrayElements.approval.teal | 2 +- .../artifacts/ABITestNonLiteralStaticArrayElements.arc32.json | 2 +- .../ABITestNonLiteralStaticArrayElements.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestObjectArrayRef.approval.teal | 2 +- tests/contracts/artifacts/ABITestObjectArrayRef.arc32.json | 2 +- .../contracts/artifacts/ABITestObjectArrayRef.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestObjectInArgs.approval.teal | 2 +- tests/contracts/artifacts/ABITestObjectInArgs.arc32.json | 2 +- tests/contracts/artifacts/ABITestObjectInArgs.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestObjectRef.approval.teal | 2 +- tests/contracts/artifacts/ABITestObjectRef.arc32.json | 2 +- tests/contracts/artifacts/ABITestObjectRef.arc56_draft.json | 2 +- .../artifacts/ABITestOpcodeParamFromObject.approval.teal | 2 +- .../contracts/artifacts/ABITestOpcodeParamFromObject.arc32.json | 2 +- .../artifacts/ABITestOpcodeParamFromObject.arc56_draft.json | 2 +- .../contracts/artifacts/ABITestPartialStaticArray.approval.teal | 2 +- tests/contracts/artifacts/ABITestPartialStaticArray.arc32.json | 2 +- .../artifacts/ABITestPartialStaticArray.arc56_draft.json | 2 +- .../artifacts/ABITestPlusEqualsArrayValue.approval.teal | 2 +- .../contracts/artifacts/ABITestPlusEqualsArrayValue.arc32.json | 2 +- .../artifacts/ABITestPlusEqualsArrayValue.arc56_draft.json | 2 +- .../contracts/artifacts/ABITestPlusEqualsObjValue.approval.teal | 2 +- tests/contracts/artifacts/ABITestPlusEqualsObjValue.arc32.json | 2 +- .../artifacts/ABITestPlusEqualsObjValue.arc56_draft.json | 2 +- .../artifacts/ABITestPlusEqualsObjValueInBox.approval.teal | 2 +- .../artifacts/ABITestPlusEqualsObjValueInBox.arc32.json | 2 +- .../artifacts/ABITestPlusEqualsObjValueInBox.arc56_draft.json | 2 +- .../artifacts/ABITestPostBoolTupleOffset.approval.teal | 2 +- tests/contracts/artifacts/ABITestPostBoolTupleOffset.arc32.json | 2 +- .../artifacts/ABITestPostBoolTupleOffset.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestPushToArrayInBox.approval.teal | 2 +- tests/contracts/artifacts/ABITestPushToArrayInBox.arc32.json | 2 +- .../artifacts/ABITestPushToArrayInBox.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestRawBytesFunction.approval.teal | 2 +- tests/contracts/artifacts/ABITestRawBytesFunction.arc32.json | 2 +- .../artifacts/ABITestRawBytesFunction.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestRefTypes.approval.teal | 2 +- tests/contracts/artifacts/ABITestRefTypes.arc32.json | 2 +- tests/contracts/artifacts/ABITestRefTypes.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestReturnByte.approval.teal | 2 +- tests/contracts/artifacts/ABITestReturnByte.arc32.json | 2 +- tests/contracts/artifacts/ABITestReturnByte.arc56_draft.json | 2 +- .../contracts/artifacts/ABITestReturnDynamicArray.approval.teal | 2 +- tests/contracts/artifacts/ABITestReturnDynamicArray.arc32.json | 2 +- .../artifacts/ABITestReturnDynamicArray.arc56_draft.json | 2 +- .../artifacts/ABITestReturnDynamicArrayFromTuple.approval.teal | 2 +- .../artifacts/ABITestReturnDynamicArrayFromTuple.arc32.json | 2 +- .../ABITestReturnDynamicArrayFromTuple.arc56_draft.json | 2 +- .../contracts/artifacts/ABITestReturnStaticArray.approval.teal | 2 +- tests/contracts/artifacts/ABITestReturnStaticArray.arc32.json | 2 +- .../artifacts/ABITestReturnStaticArray.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestReturnTuple.approval.teal | 2 +- tests/contracts/artifacts/ABITestReturnTuple.arc32.json | 2 +- tests/contracts/artifacts/ABITestReturnTuple.arc56_draft.json | 2 +- .../artifacts/ABITestReturnTupleWithDyamicArray.approval.teal | 2 +- .../artifacts/ABITestReturnTupleWithDyamicArray.arc32.json | 2 +- .../ABITestReturnTupleWithDyamicArray.arc56_draft.json | 2 +- .../artifacts/ABITestSetStaticArrayElement.approval.teal | 2 +- .../contracts/artifacts/ABITestSetStaticArrayElement.arc32.json | 2 +- .../artifacts/ABITestSetStaticArrayElement.arc56_draft.json | 2 +- .../contracts/artifacts/ABITestShortTypeNotation.approval.teal | 2 +- tests/contracts/artifacts/ABITestShortTypeNotation.arc32.json | 2 +- .../artifacts/ABITestShortTypeNotation.arc56_draft.json | 2 +- .../artifacts/ABITestShortenDynamicElementInTuple.approval.teal | 2 +- .../artifacts/ABITestShortenDynamicElementInTuple.arc32.json | 2 +- .../ABITestShortenDynamicElementInTuple.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestSimpleTuple.approval.teal | 2 +- tests/contracts/artifacts/ABITestSimpleTuple.arc32.json | 2 +- tests/contracts/artifacts/ABITestSimpleTuple.arc56_draft.json | 2 +- .../contracts/artifacts/ABITestSmallerByteCasting.approval.teal | 2 +- tests/contracts/artifacts/ABITestSmallerByteCasting.arc32.json | 2 +- .../artifacts/ABITestSmallerByteCasting.arc56_draft.json | 2 +- .../contracts/artifacts/ABITestSpliceFirstElement.approval.teal | 2 +- tests/contracts/artifacts/ABITestSpliceFirstElement.arc32.json | 2 +- .../artifacts/ABITestSpliceFirstElement.arc56_draft.json | 2 +- .../artifacts/ABITestSpliceFirstElementValue.approval.teal | 2 +- .../artifacts/ABITestSpliceFirstElementValue.arc32.json | 2 +- .../artifacts/ABITestSpliceFirstElementValue.arc56_draft.json | 2 +- .../contracts/artifacts/ABITestSpliceLastElement.approval.teal | 2 +- tests/contracts/artifacts/ABITestSpliceLastElement.arc32.json | 2 +- .../artifacts/ABITestSpliceLastElement.arc56_draft.json | 2 +- .../artifacts/ABITestSpliceLastElementValue.approval.teal | 2 +- .../artifacts/ABITestSpliceLastElementValue.arc32.json | 2 +- .../artifacts/ABITestSpliceLastElementValue.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestStaticArray.approval.teal | 2 +- tests/contracts/artifacts/ABITestStaticArray.arc32.json | 2 +- tests/contracts/artifacts/ABITestStaticArray.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestStaticArrayArg.approval.teal | 2 +- tests/contracts/artifacts/ABITestStaticArrayArg.arc32.json | 2 +- .../contracts/artifacts/ABITestStaticArrayArg.arc56_draft.json | 2 +- .../artifacts/ABITestStaticArrayInStorageMap.approval.teal | 2 +- .../artifacts/ABITestStaticArrayInStorageMap.arc32.json | 2 +- .../artifacts/ABITestStaticArrayInStorageMap.arc56_draft.json | 2 +- .../artifacts/ABITestStaticArrayInStorageRef.approval.teal | 2 +- .../artifacts/ABITestStaticArrayInStorageRef.arc32.json | 2 +- .../artifacts/ABITestStaticArrayInStorageRef.arc56_draft.json | 2 +- .../contracts/artifacts/ABITestStaticArrayLength.approval.teal | 2 +- tests/contracts/artifacts/ABITestStaticArrayLength.arc32.json | 2 +- .../artifacts/ABITestStaticArrayLength.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestStaticBoolArray.approval.teal | 2 +- tests/contracts/artifacts/ABITestStaticBoolArray.arc32.json | 2 +- .../contracts/artifacts/ABITestStaticBoolArray.arc56_draft.json | 2 +- .../artifacts/ABITestStaticBoolArrayAccess.approval.teal | 2 +- .../contracts/artifacts/ABITestStaticBoolArrayAccess.arc32.json | 2 +- .../artifacts/ABITestStaticBoolArrayAccess.arc56_draft.json | 2 +- .../artifacts/ABITestStaticBoolArrayUpdate.approval.teal | 2 +- .../contracts/artifacts/ABITestStaticBoolArrayUpdate.arc32.json | 2 +- .../artifacts/ABITestStaticBoolArrayUpdate.arc56_draft.json | 2 +- .../contracts/artifacts/ABITestStaticByteCasting.approval.teal | 2 +- tests/contracts/artifacts/ABITestStaticByteCasting.arc32.json | 2 +- .../artifacts/ABITestStaticByteCasting.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestStaticForEach.approval.teal | 2 +- tests/contracts/artifacts/ABITestStaticForEach.arc32.json | 2 +- tests/contracts/artifacts/ABITestStaticForEach.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestStaticForOf.approval.teal | 2 +- tests/contracts/artifacts/ABITestStaticForOf.arc32.json | 2 +- tests/contracts/artifacts/ABITestStaticForOf.arc56_draft.json | 2 +- .../artifacts/ABITestStaticStringArrayArg.approval.teal | 2 +- .../contracts/artifacts/ABITestStaticStringArrayArg.arc32.json | 2 +- .../artifacts/ABITestStaticStringArrayArg.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestStaticTypeInBox.approval.teal | 2 +- tests/contracts/artifacts/ABITestStaticTypeInBox.arc32.json | 2 +- .../contracts/artifacts/ABITestStaticTypeInBox.arc56_draft.json | 2 +- .../ABITestStoragePropertyReferenceInBox.approval.teal | 2 +- .../artifacts/ABITestStoragePropertyReferenceInBox.arc32.json | 2 +- .../ABITestStoragePropertyReferenceInBox.arc56_draft.json | 2 +- .../contracts/artifacts/ABITestStorageRefAccount.approval.teal | 2 +- tests/contracts/artifacts/ABITestStorageRefAccount.arc32.json | 2 +- .../artifacts/ABITestStorageRefAccount.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestStorageRefKey.approval.teal | 2 +- tests/contracts/artifacts/ABITestStorageRefKey.arc32.json | 2 +- tests/contracts/artifacts/ABITestStorageRefKey.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestStorageTypeHint.approval.teal | 2 +- tests/contracts/artifacts/ABITestStorageTypeHint.arc32.json | 2 +- .../contracts/artifacts/ABITestStorageTypeHint.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestStringAccessor.approval.teal | 2 +- tests/contracts/artifacts/ABITestStringAccessor.arc32.json | 2 +- .../contracts/artifacts/ABITestStringAccessor.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestStringArg.approval.teal | 2 +- tests/contracts/artifacts/ABITestStringArg.arc32.json | 2 +- tests/contracts/artifacts/ABITestStringArg.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestStringArray.approval.teal | 2 +- tests/contracts/artifacts/ABITestStringArray.arc32.json | 2 +- tests/contracts/artifacts/ABITestStringArray.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestStringInTuple.approval.teal | 2 +- tests/contracts/artifacts/ABITestStringInTuple.arc32.json | 2 +- tests/contracts/artifacts/ABITestStringInTuple.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestStringLength.approval.teal | 2 +- tests/contracts/artifacts/ABITestStringLength.arc32.json | 2 +- tests/contracts/artifacts/ABITestStringLength.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestStringReturn.approval.teal | 2 +- tests/contracts/artifacts/ABITestStringReturn.arc32.json | 2 +- tests/contracts/artifacts/ABITestStringReturn.arc56_draft.json | 2 +- .../artifacts/ABITestThreeDimensionalUint16Array.approval.teal | 2 +- .../artifacts/ABITestThreeDimensionalUint16Array.arc32.json | 2 +- .../ABITestThreeDimensionalUint16Array.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestTupleArg.approval.teal | 2 +- tests/contracts/artifacts/ABITestTupleArg.arc32.json | 2 +- tests/contracts/artifacts/ABITestTupleArg.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestTupleInArray.approval.teal | 2 +- tests/contracts/artifacts/ABITestTupleInArray.arc32.json | 2 +- tests/contracts/artifacts/ABITestTupleInArray.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestTupleInTuple.approval.teal | 2 +- tests/contracts/artifacts/ABITestTupleInTuple.arc32.json | 2 +- tests/contracts/artifacts/ABITestTupleInTuple.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestTxnTypes.approval.teal | 2 +- tests/contracts/artifacts/ABITestTxnTypes.arc32.json | 2 +- tests/contracts/artifacts/ABITestTxnTypes.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestTypedConst.approval.teal | 2 +- tests/contracts/artifacts/ABITestTypedConst.arc32.json | 2 +- tests/contracts/artifacts/ABITestTypedConst.arc56_draft.json | 2 +- .../artifacts/ABITestTypedVarFromStorage.approval.teal | 2 +- tests/contracts/artifacts/ABITestTypedVarFromStorage.arc32.json | 2 +- .../artifacts/ABITestTypedVarFromStorage.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestUint64Casting.approval.teal | 2 +- tests/contracts/artifacts/ABITestUint64Casting.arc32.json | 2 +- tests/contracts/artifacts/ABITestUint64Casting.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestUintCasting.approval.teal | 2 +- tests/contracts/artifacts/ABITestUintCasting.arc32.json | 2 +- tests/contracts/artifacts/ABITestUintCasting.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestUintNComparison.approval.teal | 2 +- tests/contracts/artifacts/ABITestUintNComparison.arc32.json | 2 +- .../contracts/artifacts/ABITestUintNComparison.arc56_draft.json | 2 +- .../artifacts/ABITestUpdateArrayRefInBoxStorage.approval.teal | 2 +- .../artifacts/ABITestUpdateArrayRefInBoxStorage.arc32.json | 2 +- .../ABITestUpdateArrayRefInBoxStorage.arc56_draft.json | 2 +- .../artifacts/ABITestUpdateDynamicArrayElement.approval.teal | 2 +- .../artifacts/ABITestUpdateDynamicArrayElement.arc32.json | 2 +- .../artifacts/ABITestUpdateDynamicArrayElement.arc56_draft.json | 2 +- .../ABITestUpdateDynamicArrayInMiddleOfTuple.approval.teal | 2 +- .../ABITestUpdateDynamicArrayInMiddleOfTuple.arc32.json | 2 +- .../ABITestUpdateDynamicArrayInMiddleOfTuple.arc56_draft.json | 2 +- .../artifacts/ABITestUpdateDynamicArrayInTuple.approval.teal | 2 +- .../artifacts/ABITestUpdateDynamicArrayInTuple.arc32.json | 2 +- .../artifacts/ABITestUpdateDynamicArrayInTuple.arc56_draft.json | 2 +- ...ITestUpdateDynamicElementInTupleWithSameLength.approval.teal | 2 +- .../ABITestUpdateDynamicElementInTupleWithSameLength.arc32.json | 2 +- ...stUpdateDynamicElementInTupleWithSameLength.arc56_draft.json | 2 +- tests/contracts/artifacts/ABITestUpdateNamedTuple.approval.teal | 2 +- tests/contracts/artifacts/ABITestUpdateNamedTuple.arc32.json | 2 +- .../artifacts/ABITestUpdateNamedTuple.arc56_draft.json | 2 +- .../artifacts/ABITestUpdateNestedStaticArray.approval.teal | 2 +- .../artifacts/ABITestUpdateNestedStaticArray.arc32.json | 2 +- .../artifacts/ABITestUpdateNestedStaticArray.arc56_draft.json | 2 +- .../ABITestUpdateNestedStaticArrayElement.approval.teal | 2 +- .../artifacts/ABITestUpdateNestedStaticArrayElement.arc32.json | 2 +- .../ABITestUpdateNestedStaticArrayElement.arc56_draft.json | 2 +- .../ABITestUpdateStaticArrayInStorageMap.approval.teal | 2 +- .../artifacts/ABITestUpdateStaticArrayInStorageMap.arc32.json | 2 +- .../ABITestUpdateStaticArrayInStorageMap.arc56_draft.json | 2 +- .../ABITestUpdateStaticArrayInStorageRef.approval.teal | 2 +- .../artifacts/ABITestUpdateStaticArrayInStorageRef.arc32.json | 2 +- .../ABITestUpdateStaticArrayInStorageRef.arc56_draft.json | 2 +- .../ABITestUpdateStaticFieldInDynamicObjectInBox.approval.teal | 2 +- .../ABITestUpdateStaticFieldInDynamicObjectInBox.arc32.json | 2 +- ...BITestUpdateStaticFieldInDynamicObjectInBox.arc56_draft.json | 2 +- .../artifacts/ABITestUpdateStringInTuple.approval.teal | 2 +- tests/contracts/artifacts/ABITestUpdateStringInTuple.arc32.json | 2 +- .../artifacts/ABITestUpdateStringInTuple.arc56_draft.json | 2 +- .../ABITestUpdateTupleWithOnlyDynamicTypes.approval.teal | 2 +- .../artifacts/ABITestUpdateTupleWithOnlyDynamicTypes.arc32.json | 2 +- .../ABITestUpdateTupleWithOnlyDynamicTypes.arc56_draft.json | 2 +- tests/contracts/artifacts/AD.approval.teal | 2 +- tests/contracts/artifacts/AD.arc32.json | 2 +- tests/contracts/artifacts/AD.arc56_draft.json | 2 +- tests/contracts/artifacts/ARC56Test.approval.teal | 2 +- tests/contracts/artifacts/ARC56Test.arc32.json | 2 +- tests/contracts/artifacts/ARC56Test.arc56_draft.json | 2 +- tests/contracts/artifacts/ARC56TestNoTemplateVars.approval.teal | 2 +- tests/contracts/artifacts/ARC56TestNoTemplateVars.arc32.json | 2 +- .../artifacts/ARC56TestNoTemplateVars.arc56_draft.json | 2 +- tests/contracts/artifacts/AVM11.approval.teal | 2 +- tests/contracts/artifacts/AVM11.arc32.json | 2 +- tests/contracts/artifacts/AVM11.arc56_draft.json | 2 +- tests/contracts/artifacts/AccountTest.approval.teal | 2 +- tests/contracts/artifacts/AccountTest.arc32.json | 2 +- tests/contracts/artifacts/AccountTest.arc56_draft.json | 2 +- tests/contracts/artifacts/B.approval.teal | 2 +- tests/contracts/artifacts/B.arc32.json | 2 +- tests/contracts/artifacts/B.arc56_draft.json | 2 +- tests/contracts/artifacts/B2.approval.teal | 2 +- tests/contracts/artifacts/B2.arc32.json | 2 +- tests/contracts/artifacts/B2.arc56_draft.json | 2 +- tests/contracts/artifacts/BasicLsig.lsig.teal | 2 +- tests/contracts/artifacts/BinaryTest.approval.teal | 2 +- tests/contracts/artifacts/BinaryTest.arc32.json | 2 +- tests/contracts/artifacts/BinaryTest.arc56_draft.json | 2 +- tests/contracts/artifacts/BytecblockTest.approval.teal | 2 +- tests/contracts/artifacts/BytecblockTest.arc32.json | 2 +- tests/contracts/artifacts/BytecblockTest.arc56_draft.json | 2 +- tests/contracts/artifacts/C.approval.teal | 2 +- tests/contracts/artifacts/C.arc32.json | 2 +- tests/contracts/artifacts/C.arc56_draft.json | 2 +- .../contracts/artifacts/ContractWithCustomStruct.approval.teal | 2 +- tests/contracts/artifacts/ContractWithCustomStruct.arc32.json | 2 +- .../artifacts/ContractWithCustomStruct.arc56_draft.json | 2 +- tests/contracts/artifacts/ContractWithLsigProgram.approval.teal | 2 +- tests/contracts/artifacts/ContractWithLsigProgram.arc32.json | 2 +- .../artifacts/ContractWithLsigProgram.arc56_draft.json | 2 +- tests/contracts/artifacts/ContratWithLsigAddress.approval.teal | 2 +- tests/contracts/artifacts/ContratWithLsigAddress.arc32.json | 2 +- .../contracts/artifacts/ContratWithLsigAddress.arc56_draft.json | 2 +- tests/contracts/artifacts/D.approval.teal | 2 +- tests/contracts/artifacts/D.arc32.json | 2 +- tests/contracts/artifacts/D.arc56_draft.json | 2 +- tests/contracts/artifacts/DummyContract.approval.teal | 2 +- tests/contracts/artifacts/DummyContract.arc32.json | 2 +- tests/contracts/artifacts/DummyContract.arc56_draft.json | 2 +- tests/contracts/artifacts/E.approval.teal | 2 +- tests/contracts/artifacts/E.arc32.json | 2 +- tests/contracts/artifacts/E.arc56_draft.json | 2 +- tests/contracts/artifacts/ExternalContract.approval.teal | 2 +- tests/contracts/artifacts/ExternalContract.arc32.json | 2 +- tests/contracts/artifacts/ExternalContract.arc56_draft.json | 2 +- tests/contracts/artifacts/F.approval.teal | 2 +- tests/contracts/artifacts/F.arc32.json | 2 +- tests/contracts/artifacts/F.arc56_draft.json | 2 +- tests/contracts/artifacts/FunctionsTest.approval.teal | 2 +- tests/contracts/artifacts/FunctionsTest.arc32.json | 2 +- tests/contracts/artifacts/FunctionsTest.arc56_draft.json | 2 +- tests/contracts/artifacts/G.approval.teal | 2 +- tests/contracts/artifacts/G.arc32.json | 2 +- tests/contracts/artifacts/G.arc56_draft.json | 2 +- tests/contracts/artifacts/GeneralTest.approval.teal | 2 +- tests/contracts/artifacts/GeneralTest.arc32.json | 2 +- tests/contracts/artifacts/GeneralTest.arc56_draft.json | 2 +- tests/contracts/artifacts/IfTest.approval.teal | 2 +- tests/contracts/artifacts/IfTest.arc32.json | 2 +- tests/contracts/artifacts/IfTest.arc56_draft.json | 2 +- tests/contracts/artifacts/IntcblockTest.approval.teal | 2 +- tests/contracts/artifacts/IntcblockTest.arc32.json | 2 +- tests/contracts/artifacts/IntcblockTest.arc56_draft.json | 2 +- tests/contracts/artifacts/ItxnsTest.approval.teal | 2 +- tests/contracts/artifacts/ItxnsTest.arc32.json | 2 +- tests/contracts/artifacts/ItxnsTest.arc56_draft.json | 2 +- tests/contracts/artifacts/LoopsTest.approval.teal | 2 +- tests/contracts/artifacts/LoopsTest.arc32.json | 2 +- tests/contracts/artifacts/LoopsTest.arc56_draft.json | 2 +- tests/contracts/artifacts/LsigWithArgs.lsig.teal | 2 +- tests/contracts/artifacts/LsigWithPrivateMethod.lsig.teal | 2 +- tests/contracts/artifacts/MathTest.approval.teal | 2 +- tests/contracts/artifacts/MathTest.arc32.json | 2 +- tests/contracts/artifacts/MathTest.arc56_draft.json | 2 +- tests/contracts/artifacts/MultiInheritance.approval.teal | 2 +- tests/contracts/artifacts/MultiInheritance.arc32.json | 2 +- tests/contracts/artifacts/MultiInheritance.arc56_draft.json | 2 +- tests/contracts/artifacts/MultiInheritanceProgram.approval.teal | 2 +- tests/contracts/artifacts/MultiInheritanceProgram.arc32.json | 2 +- .../artifacts/MultiInheritanceProgram.arc56_draft.json | 2 +- tests/contracts/artifacts/ProgramVersion.approval.teal | 2 +- tests/contracts/artifacts/ProgramVersion.arc32.json | 2 +- tests/contracts/artifacts/ProgramVersion.arc56_draft.json | 2 +- tests/contracts/artifacts/SchemaContract.approval.teal | 2 +- tests/contracts/artifacts/SchemaContract.arc32.json | 2 +- tests/contracts/artifacts/SchemaContract.arc56_draft.json | 2 +- tests/contracts/artifacts/StorageTest.approval.teal | 2 +- tests/contracts/artifacts/StorageTest.arc32.json | 2 +- tests/contracts/artifacts/StorageTest.arc56_draft.json | 2 +- tests/contracts/artifacts/Templates.approval.teal | 2 +- tests/contracts/artifacts/Templates.arc32.json | 2 +- tests/contracts/artifacts/Templates.arc56_draft.json | 2 +- 592 files changed, 592 insertions(+), 592 deletions(-) diff --git a/examples/amm/tealscript_artifacts/ConstantProductAMM.approval.teal b/examples/amm/tealscript_artifacts/ConstantProductAMM.approval.teal index d24731201..c33a87c92 100644 --- a/examples/amm/tealscript_artifacts/ConstantProductAMM.approval.teal +++ b/examples/amm/tealscript_artifacts/ConstantProductAMM.approval.teal @@ -2,7 +2,7 @@ intcblock 0 10000000000 1 1000 bytecblock 0x 0x61 0x62 0x67 0x70 0x72 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/examples/amm/tealscript_artifacts/ConstantProductAMM.arc32.json b/examples/amm/tealscript_artifacts/ConstantProductAMM.arc32.json index 3b0fd2a9f..f495aabce 100644 --- a/examples/amm/tealscript_artifacts/ConstantProductAMM.arc32.json +++ b/examples/amm/tealscript_artifacts/ConstantProductAMM.arc32.json @@ -80,7 +80,7 @@ } }, "source": { - "approval": "#pragma version 10
intcblock 0 10000000000 1 1000
bytecblock 0x 0x61 0x62 0x67 0x70 0x72

// This TEAL was generated by TEALScript v0.104.1
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// createApplication()void
*abi_route_createApplication:
	// execute createApplication()void
	callsub createApplication
	int 1
	return

// createApplication(): void
createApplication:
	proto 0 0

	// examples/amm/amm.algo.ts:20
	// this.governor.value = this.txn.sender
	byte 0x67 // "g"
	txn Sender
	app_global_put
	retsub

// doCreatePoolToken(aAsset: AssetID, bAsset: AssetID): AssetID
doCreatePoolToken:
	proto 2 1

	// examples/amm/amm.algo.ts:26
	// return sendAssetCreation({
	//       configAssetName: 'DPT-' + aAsset.unitName + '-' + bAsset.unitName,
	//       configAssetUnitName: 'dpt',
	//       configAssetTotal: TOTAL_SUPPLY,
	//       configAssetDecimals: 3,
	//       configAssetManager: this.app.address,
	//       configAssetReserve: this.app.address,
	//     });
	itxn_begin
	pushint 3 // acfg
	itxn_field TypeEnum

	// examples/amm/amm.algo.ts:27
	// configAssetName: 'DPT-' + aAsset.unitName + '-' + bAsset.unitName
	pushbytes 0x4450542d // "DPT-"
	frame_dig -1 // aAsset: AssetID
	asset_params_get AssetUnitName
	pop
	concat
	pushbytes 0x2d // "-"
	concat
	frame_dig -2 // bAsset: AssetID
	asset_params_get AssetUnitName
	pop
	concat
	itxn_field ConfigAssetName

	// examples/amm/amm.algo.ts:28
	// configAssetUnitName: 'dpt'
	pushbytes 0x647074 // "dpt"
	itxn_field ConfigAssetUnitName

	// examples/amm/amm.algo.ts:29
	// configAssetTotal: TOTAL_SUPPLY
	int 10000000000
	itxn_field ConfigAssetTotal

	// examples/amm/amm.algo.ts:30
	// configAssetDecimals: 3
	pushint 3
	itxn_field ConfigAssetDecimals

	// examples/amm/amm.algo.ts:31
	// configAssetManager: this.app.address
	global CurrentApplicationAddress
	itxn_field ConfigAssetManager

	// examples/amm/amm.algo.ts:32
	// configAssetReserve: this.app.address
	global CurrentApplicationAddress
	itxn_field ConfigAssetReserve

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn CreatedAssetID
	retsub

// doAxfer(receiver: Address, asset: AssetID, amount: uint64): void
doAxfer:
	proto 3 0

	// examples/amm/amm.algo.ts:37
	// sendAssetTransfer({
	//       assetReceiver: receiver,
	//       xferAsset: asset,
	//       assetAmount: amount,
	//     })
	itxn_begin
	pushint 4 // axfer
	itxn_field TypeEnum

	// examples/amm/amm.algo.ts:38
	// assetReceiver: receiver
	frame_dig -1 // receiver: Address
	itxn_field AssetReceiver

	// examples/amm/amm.algo.ts:39
	// xferAsset: asset
	frame_dig -2 // asset: AssetID
	itxn_field XferAsset

	// examples/amm/amm.algo.ts:40
	// assetAmount: amount
	frame_dig -3 // amount: uint64
	itxn_field AssetAmount

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// doOptIn(asset: AssetID): void
doOptIn:
	proto 1 0

	// examples/amm/amm.algo.ts:45
	// this.doAxfer(this.app.address, asset, 0)
	int 0
	frame_dig -1 // asset: AssetID
	global CurrentApplicationAddress
	callsub doAxfer
	retsub

// tokensToMintIntial(aAmount: uint64, bAmount: uint64): uint64
tokensToMintIntial:
	proto 2 1

	// examples/amm/amm.algo.ts:49
	// return sqrt(aAmount * bAmount);
	frame_dig -1 // aAmount: uint64
	frame_dig -2 // bAmount: uint64
	*
	sqrt
	retsub

// tokensToMint(issued: uint64, aSupply: uint64, bSupply: uint64, aAmount: uint64, bAmount: uint64): uint64
tokensToMint:
	proto 5 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// examples/amm/amm.algo.ts:53
	// aRatio = wideRatio([aAmount, SCALE], [aSupply])
	frame_dig -4 // aAmount: uint64
	int 1000
	mulw
	int 0
	frame_dig -2 // aSupply: uint64
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	frame_bury 0 // aRatio: uint64

	// examples/amm/amm.algo.ts:54
	// bRatio = wideRatio([bAmount, SCALE], [bSupply])
	frame_dig -5 // bAmount: uint64
	int 1000
	mulw
	int 0
	frame_dig -3 // bSupply: uint64
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	frame_bury 1 // bRatio: uint64

	// examples/amm/amm.algo.ts:56
	// ratio = aRatio < bRatio ? aRatio : bRatio
	frame_dig 0 // aRatio: uint64
	frame_dig 1 // bRatio: uint64
	<
	bz *ternary0_false
	frame_dig 0 // aRatio: uint64
	b *ternary0_end

*ternary0_false:
	frame_dig 1 // bRatio: uint64

*ternary0_end:
	frame_bury 2 // ratio: uint64

	// examples/amm/amm.algo.ts:58
	// return wideRatio([ratio, issued], [SCALE]);
	frame_dig 2 // ratio: uint64
	frame_dig -1 // issued: uint64
	mulw
	int 0
	int 1000
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 2
	retsub

// computeRatio(): uint64
computeRatio:
	proto 0 1

	// examples/amm/amm.algo.ts:62
	// return wideRatio(
	//       [this.app.address.assetBalance(this.assetA.value), SCALE],
	//       [this.app.address.assetBalance(this.assetB.value)]
	//     );
	global CurrentApplicationAddress
	byte 0x61 // "a"
	app_global_get
	asset_holding_get AssetBalance
	pop
	int 1000
	mulw
	int 0
	global CurrentApplicationAddress
	byte 0x62 // "b"
	app_global_get
	asset_holding_get AssetBalance
	pop
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	retsub

// tokensToBurn(issued: uint64, supply: uint64, amount: uint64): uint64
tokensToBurn:
	proto 3 1

	// examples/amm/amm.algo.ts:69
	// return wideRatio([supply, amount], [issued]);
	frame_dig -2 // supply: uint64
	frame_dig -3 // amount: uint64
	mulw
	int 0
	frame_dig -1 // issued: uint64
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	retsub

// tokensToSwap(inAmount: uint64, inSupply: uint64, outSupply: uint64): uint64
tokensToSwap:
	proto 3 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/amm/amm.algo.ts:73
	// factor = SCALE - FEE
	pushint 995
	frame_bury 0 // factor: uint64

	// examples/amm/amm.algo.ts:74
	// return wideRatio([inAmount, factor, outSupply], [inSupply * SCALE + inAmount * factor]);
	frame_dig -1 // inAmount: uint64
	frame_dig 0 // factor: uint64
	mulw
	frame_dig -3 // outSupply: uint64
	uncover 2
	dig 1
	*
	cover 2
	mulw
	cover 2
	+
	swap
	int 0
	frame_dig -2 // inSupply: uint64
	int 1000
	*
	frame_dig -1 // inAmount: uint64
	frame_dig 0 // factor: uint64
	*
	+
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert

	// set the subroutine return value
	frame_bury 0
	retsub

// set_governor(address)void
*abi_route_set_governor:
	// governor: address
	txna ApplicationArgs 1
	dup
	len
	pushint 32
	==

	// argument 0 (governor) for set_governor must be a address
	assert

	// execute set_governor(address)void
	callsub set_governor
	int 1
	return

// set_governor(governor: Address): void
set_governor:
	proto 1 0

	// examples/amm/amm.algo.ts:78
	// verifyAppCallTxn(this.txn, { sender: this.governor.value })
	// verify sender
	txn Sender
	byte 0x67 // "g"
	app_global_get
	==

	// transaction verification failed: {"txn":"this.txn","field":"sender","expected":"this.governor.value"}
	assert

	// examples/amm/amm.algo.ts:79
	// this.governor.value = governor
	byte 0x67 // "g"
	frame_dig -1 // governor: Address
	app_global_put
	retsub

// bootstrap(pay,uint64,uint64)uint64
*abi_route_bootstrap:
	// The ABI return prefix
	pushbytes 0x151f7c75

	// bAsset: uint64
	txna ApplicationArgs 2
	btoi

	// aAsset: uint64
	txna ApplicationArgs 1
	btoi

	// seed: pay
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// argument 2 (seed) for bootstrap must be a pay transaction
	assert

	// execute bootstrap(pay,uint64,uint64)uint64
	callsub bootstrap
	itob
	concat
	log
	int 1
	return

// bootstrap(seed: PayTxn, aAsset: AssetID, bAsset: AssetID): AssetID
bootstrap:
	proto 3 1

	// examples/amm/amm.algo.ts:83
	// verifyAppCallTxn(this.txn, { sender: this.governor.value })
	// verify sender
	txn Sender
	byte 0x67 // "g"
	app_global_get
	==

	// transaction verification failed: {"txn":"this.txn","field":"sender","expected":"this.governor.value"}
	assert

	// examples/amm/amm.algo.ts:85
	// assert(globals.groupSize === 2)
	global GroupSize
	pushint 2
	==
	assert

	// examples/amm/amm.algo.ts:87
	// verifyPayTxn(seed, { receiver: this.app.address, amount: { greaterThanEqualTo: 300_000 } })
	// verify receiver
	frame_dig -1 // seed: PayTxn
	gtxns Receiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"seed","field":"receiver","expected":"this.app.address"}
	assert

	// verify amount
	frame_dig -1 // seed: PayTxn
	gtxns Amount
	pushint 300_000
	>=

	// transaction verification failed: {"txn":"seed","field":"amount","condition":"greaterThanEqualTo","expected":">=300_000"}
	assert

	// examples/amm/amm.algo.ts:88
	// assert(aAsset < bAsset)
	frame_dig -2 // aAsset: AssetID
	frame_dig -3 // bAsset: AssetID
	<
	assert

	// examples/amm/amm.algo.ts:90
	// this.assetA.value = aAsset
	byte 0x61 // "a"
	frame_dig -2 // aAsset: AssetID
	app_global_put

	// examples/amm/amm.algo.ts:91
	// this.assetB.value = bAsset
	byte 0x62 // "b"
	frame_dig -3 // bAsset: AssetID
	app_global_put

	// examples/amm/amm.algo.ts:92
	// this.poolToken.value = this.doCreatePoolToken(aAsset, bAsset)
	byte 0x70 // "p"
	frame_dig -3 // bAsset: AssetID
	frame_dig -2 // aAsset: AssetID
	callsub doCreatePoolToken
	app_global_put

	// examples/amm/amm.algo.ts:94
	// this.doOptIn(aAsset)
	frame_dig -2 // aAsset: AssetID
	callsub doOptIn

	// examples/amm/amm.algo.ts:95
	// this.doOptIn(bAsset)
	frame_dig -3 // bAsset: AssetID
	callsub doOptIn

	// examples/amm/amm.algo.ts:97
	// return this.poolToken.value;
	byte 0x70 // "p"
	app_global_get
	retsub

// mint(axfer,axfer,uint64,uint64,uint64)void
*abi_route_mint:
	// bAsset: uint64
	txna ApplicationArgs 3
	btoi

	// aAsset: uint64
	txna ApplicationArgs 2
	btoi

	// poolAsset: uint64
	txna ApplicationArgs 1
	btoi

	// bXfer: axfer
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	pushint 4 // axfer
	==

	// argument 3 (bXfer) for mint must be a axfer transaction
	assert

	// aXfer: axfer
	txn GroupIndex
	pushint 2
	-
	dup
	gtxns TypeEnum
	pushint 4 // axfer
	==

	// argument 4 (aXfer) for mint must be a axfer transaction
	assert

	// execute mint(axfer,axfer,uint64,uint64,uint64)void
	callsub mint
	int 1
	return

// mint(aXfer: AssetTransferTxn, bXfer: AssetTransferTxn, poolAsset: AssetID, aAsset: AssetID, bAsset: AssetID): void
mint:
	proto 5 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// well formed mint
	// examples/amm/amm.algo.ts:102
	// assert(aAsset === this.assetA.value)
	frame_dig -4 // aAsset: AssetID
	byte 0x61 // "a"
	app_global_get
	==
	assert

	// examples/amm/amm.algo.ts:103
	// assert(bAsset === this.assetB.value)
	frame_dig -5 // bAsset: AssetID
	byte 0x62 // "b"
	app_global_get
	==
	assert

	// examples/amm/amm.algo.ts:104
	// assert(poolAsset === this.poolToken.value)
	frame_dig -3 // poolAsset: AssetID
	byte 0x70 // "p"
	app_global_get
	==
	assert

	// valid asset A axfer
	// examples/amm/amm.algo.ts:107
	// verifyAssetTransferTxn(aXfer, {
	//       sender: this.txn.sender,
	//       assetAmount: { greaterThan: 0 },
	//       assetReceiver: this.app.address,
	//       xferAsset: aAsset,
	//     })
	// verify sender
	frame_dig -1 // aXfer: AssetTransferTxn
	gtxns Sender
	txn Sender
	==

	// transaction verification failed: {"txn":"aXfer","field":"sender","expected":"this.txn.sender"}
	assert

	// verify assetAmount
	frame_dig -1 // aXfer: AssetTransferTxn
	gtxns AssetAmount
	int 0
	>

	// transaction verification failed: {"txn":"aXfer","field":"assetAmount","condition":"greaterThan","expected":">0"}
	assert

	// verify assetReceiver
	frame_dig -1 // aXfer: AssetTransferTxn
	gtxns AssetReceiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"aXfer","field":"assetReceiver","expected":"this.app.address"}
	assert

	// verify xferAsset
	frame_dig -1 // aXfer: AssetTransferTxn
	gtxns XferAsset
	frame_dig -4 // aAsset: AssetID
	==

	// transaction verification failed: {"txn":"aXfer","field":"xferAsset","expected":"aAsset"}
	assert

	// valid asset B axfer
	// examples/amm/amm.algo.ts:115
	// verifyAssetTransferTxn(bXfer, {
	//       sender: this.txn.sender,
	//       assetAmount: { greaterThan: 0 },
	//       assetReceiver: this.app.address,
	//       xferAsset: bAsset,
	//     })
	// verify sender
	frame_dig -2 // bXfer: AssetTransferTxn
	gtxns Sender
	txn Sender
	==

	// transaction verification failed: {"txn":"bXfer","field":"sender","expected":"this.txn.sender"}
	assert

	// verify assetAmount
	frame_dig -2 // bXfer: AssetTransferTxn
	gtxns AssetAmount
	int 0
	>

	// transaction verification failed: {"txn":"bXfer","field":"assetAmount","condition":"greaterThan","expected":">0"}
	assert

	// verify assetReceiver
	frame_dig -2 // bXfer: AssetTransferTxn
	gtxns AssetReceiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"bXfer","field":"assetReceiver","expected":"this.app.address"}
	assert

	// verify xferAsset
	frame_dig -2 // bXfer: AssetTransferTxn
	gtxns XferAsset
	frame_dig -5 // bAsset: AssetID
	==

	// transaction verification failed: {"txn":"bXfer","field":"xferAsset","expected":"bAsset"}
	assert

	// *if0_condition
	// examples/amm/amm.algo.ts:123
	// this.app.address.assetBalance(aAsset) === aXfer.assetAmount &&
	//       this.app.address.assetBalance(bAsset) === bXfer.assetAmount
	global CurrentApplicationAddress
	frame_dig -4 // aAsset: AssetID
	asset_holding_get AssetBalance
	pop
	frame_dig -1 // aXfer: AssetTransferTxn
	gtxns AssetAmount
	==
	dup
	bz *skip_and0
	global CurrentApplicationAddress
	frame_dig -5 // bAsset: AssetID
	asset_holding_get AssetBalance
	pop
	frame_dig -2 // bXfer: AssetTransferTxn
	gtxns AssetAmount
	==
	&&

*skip_and0:
	bz *if0_else

	// *if0_consequent
	// examples/amm/amm.algo.ts:126
	// this.tokensToMintIntial(aXfer.assetAmount, bXfer.assetAmount)
	frame_dig -2 // bXfer: AssetTransferTxn
	gtxns AssetAmount
	frame_dig -1 // aXfer: AssetTransferTxn
	gtxns AssetAmount
	callsub tokensToMintIntial
	b *if0_end

*if0_else:
	// examples/amm/amm.algo.ts:128
	// toMint = this.tokensToMint(
	//         TOTAL_SUPPLY - this.app.address.assetBalance(poolAsset),
	//         this.app.address.assetBalance(aAsset) - aXfer.assetAmount,
	//         this.app.address.assetBalance(bAsset) - bXfer.assetAmount,
	//         aXfer.assetAmount,
	//         bXfer.assetAmount
	//       )
	frame_dig -2 // bXfer: AssetTransferTxn
	gtxns AssetAmount
	frame_dig -1 // aXfer: AssetTransferTxn
	gtxns AssetAmount
	global CurrentApplicationAddress
	frame_dig -5 // bAsset: AssetID
	asset_holding_get AssetBalance
	pop
	frame_dig -2 // bXfer: AssetTransferTxn
	gtxns AssetAmount
	-
	global CurrentApplicationAddress
	frame_dig -4 // aAsset: AssetID
	asset_holding_get AssetBalance
	pop
	frame_dig -1 // aXfer: AssetTransferTxn
	gtxns AssetAmount
	-
	int 10000000000
	global CurrentApplicationAddress
	frame_dig -3 // poolAsset: AssetID
	asset_holding_get AssetBalance
	pop
	-
	callsub tokensToMint
	frame_bury 0 // toMint: uint64

	// examples/amm/amm.algo.ts:136
	// assert(toMint > 0)
	frame_dig 0 // toMint: uint64
	int 0
	>
	assert

	// examples/amm/amm.algo.ts:138
	// this.doAxfer(this.txn.sender, poolAsset, toMint)
	frame_dig 0 // toMint: uint64
	frame_dig -3 // poolAsset: AssetID
	txn Sender
	callsub doAxfer

*if0_end:
	retsub

// burn(axfer,uint64,uint64,uint64)void
*abi_route_burn:
	// bAsset: uint64
	txna ApplicationArgs 3
	btoi

	// aAsset: uint64
	txna ApplicationArgs 2
	btoi

	// poolAsset: uint64
	txna ApplicationArgs 1
	btoi

	// poolXfer: axfer
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	pushint 4 // axfer
	==

	// argument 3 (poolXfer) for burn must be a axfer transaction
	assert

	// execute burn(axfer,uint64,uint64,uint64)void
	callsub burn
	int 1
	return

// burn(poolXfer: AssetTransferTxn, poolAsset: AssetID, aAsset: AssetID, bAsset: AssetID): void
burn:
	proto 4 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// well formed burn
	// examples/amm/amm.algo.ts:144
	// assert(poolAsset === this.poolToken.value)
	frame_dig -2 // poolAsset: AssetID
	byte 0x70 // "p"
	app_global_get
	==
	assert

	// examples/amm/amm.algo.ts:145
	// assert(aAsset === this.assetA.value)
	frame_dig -3 // aAsset: AssetID
	byte 0x61 // "a"
	app_global_get
	==
	assert

	// examples/amm/amm.algo.ts:146
	// assert(bAsset === this.assetB.value)
	frame_dig -4 // bAsset: AssetID
	byte 0x62 // "b"
	app_global_get
	==
	assert

	// valid pool axfer
	// examples/amm/amm.algo.ts:149
	// verifyAssetTransferTxn(poolXfer, {
	//       sender: this.txn.sender,
	//       assetAmount: { greaterThan: 0 },
	//       assetReceiver: this.app.address,
	//       xferAsset: poolAsset,
	//     })
	// verify sender
	frame_dig -1 // poolXfer: AssetTransferTxn
	gtxns Sender
	txn Sender
	==

	// transaction verification failed: {"txn":"poolXfer","field":"sender","expected":"this.txn.sender"}
	assert

	// verify assetAmount
	frame_dig -1 // poolXfer: AssetTransferTxn
	gtxns AssetAmount
	int 0
	>

	// transaction verification failed: {"txn":"poolXfer","field":"assetAmount","condition":"greaterThan","expected":">0"}
	assert

	// verify assetReceiver
	frame_dig -1 // poolXfer: AssetTransferTxn
	gtxns AssetReceiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"poolXfer","field":"assetReceiver","expected":"this.app.address"}
	assert

	// verify xferAsset
	frame_dig -1 // poolXfer: AssetTransferTxn
	gtxns XferAsset
	frame_dig -2 // poolAsset: AssetID
	==

	// transaction verification failed: {"txn":"poolXfer","field":"xferAsset","expected":"poolAsset"}
	assert

	// examples/amm/amm.algo.ts:156
	// issued = TOTAL_SUPPLY - (this.app.address.assetBalance(poolAsset) - poolXfer.assetAmount)
	int 10000000000
	global CurrentApplicationAddress
	frame_dig -2 // poolAsset: AssetID
	asset_holding_get AssetBalance
	pop
	frame_dig -1 // poolXfer: AssetTransferTxn
	gtxns AssetAmount
	-
	-
	frame_bury 0 // issued: uint64

	// examples/amm/amm.algo.ts:158
	// aAmt = this.tokensToBurn(issued, this.app.address.assetBalance(aAsset), poolXfer.assetAmount)
	frame_dig -1 // poolXfer: AssetTransferTxn
	gtxns AssetAmount
	global CurrentApplicationAddress
	frame_dig -3 // aAsset: AssetID
	asset_holding_get AssetBalance
	pop
	frame_dig 0 // issued: uint64
	callsub tokensToBurn
	frame_bury 1 // aAmt: uint64

	// examples/amm/amm.algo.ts:160
	// bAmt = this.tokensToBurn(issued, this.app.address.assetBalance(bAsset), poolXfer.assetAmount)
	frame_dig -1 // poolXfer: AssetTransferTxn
	gtxns AssetAmount
	global CurrentApplicationAddress
	frame_dig -4 // bAsset: AssetID
	asset_holding_get AssetBalance
	pop
	frame_dig 0 // issued: uint64
	callsub tokensToBurn
	frame_bury 2 // bAmt: uint64

	// examples/amm/amm.algo.ts:162
	// this.doAxfer(this.txn.sender, aAsset, aAmt)
	frame_dig 1 // aAmt: uint64
	frame_dig -3 // aAsset: AssetID
	txn Sender
	callsub doAxfer

	// examples/amm/amm.algo.ts:163
	// this.doAxfer(this.txn.sender, bAsset, bAmt)
	frame_dig 2 // bAmt: uint64
	frame_dig -4 // bAsset: AssetID
	txn Sender
	callsub doAxfer

	// examples/amm/amm.algo.ts:165
	// this.ratio.value = this.computeRatio()
	byte 0x72 // "r"
	callsub computeRatio
	app_global_put
	retsub

// swap(axfer,uint64,uint64)void
*abi_route_swap:
	// bAsset: uint64
	txna ApplicationArgs 2
	btoi

	// aAsset: uint64
	txna ApplicationArgs 1
	btoi

	// swapXfer: axfer
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	pushint 4 // axfer
	==

	// argument 2 (swapXfer) for swap must be a axfer transaction
	assert

	// execute swap(axfer,uint64,uint64)void
	callsub swap
	int 1
	return

// swap(swapXfer: AssetTransferTxn, aAsset: AssetID, bAsset: AssetID): void
swap:
	proto 3 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// well formed swap
	// examples/amm/amm.algo.ts:170
	// assert(aAsset === this.assetA.value)
	frame_dig -2 // aAsset: AssetID
	byte 0x61 // "a"
	app_global_get
	==
	assert

	// examples/amm/amm.algo.ts:171
	// assert(bAsset === this.assetB.value)
	frame_dig -3 // bAsset: AssetID
	byte 0x62 // "b"
	app_global_get
	==
	assert

	// examples/amm/amm.algo.ts:173
	// verifyAssetTransferTxn(swapXfer, {
	//       assetAmount: { greaterThan: 0 },
	//       assetReceiver: this.app.address,
	//       sender: this.txn.sender,
	//       xferAsset: { includedIn: [aAsset, bAsset] },
	//     })
	// verify assetAmount
	frame_dig -1 // swapXfer: AssetTransferTxn
	gtxns AssetAmount
	int 0
	>

	// transaction verification failed: {"txn":"swapXfer","field":"assetAmount","condition":"greaterThan","expected":">0"}
	assert

	// verify assetReceiver
	frame_dig -1 // swapXfer: AssetTransferTxn
	gtxns AssetReceiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"swapXfer","field":"assetReceiver","expected":"this.app.address"}
	assert

	// verify sender
	frame_dig -1 // swapXfer: AssetTransferTxn
	gtxns Sender
	txn Sender
	==

	// transaction verification failed: {"txn":"swapXfer","field":"sender","expected":"this.txn.sender"}
	assert

	// verify xferAsset
	frame_dig -1 // swapXfer: AssetTransferTxn
	gtxns XferAsset
	frame_dig -2 // aAsset: AssetID
	==
	frame_dig -1 // swapXfer: AssetTransferTxn
	gtxns XferAsset
	frame_dig -3 // bAsset: AssetID
	==
	||

	// transaction verification failed: {"txn":{"txnText":"swapXfer"},"field":"xferAsset","condition":"includedIn","expected":"[aAsset, bAsset]"}
	assert

	// examples/amm/amm.algo.ts:180
	// outId = swapXfer.xferAsset === aAsset ? aAsset : bAsset
	frame_dig -1 // swapXfer: AssetTransferTxn
	gtxns XferAsset
	frame_dig -2 // aAsset: AssetID
	==
	bz *ternary1_false
	frame_dig -2 // aAsset: AssetID
	b *ternary1_end

*ternary1_false:
	frame_dig -3 // bAsset: AssetID

*ternary1_end:
	frame_bury 0 // outId: uint64

	// examples/amm/amm.algo.ts:182
	// inId = swapXfer.xferAsset
	frame_dig -1 // swapXfer: AssetTransferTxn
	gtxns XferAsset
	frame_bury 1 // inId: uint64

	// examples/amm/amm.algo.ts:184
	// toSwap = this.tokensToSwap(
	//       swapXfer.assetAmount,
	//       this.app.address.assetBalance(inId) - swapXfer.assetAmount,
	//       this.app.address.assetBalance(outId)
	//     )
	global CurrentApplicationAddress
	frame_dig 0 // outId: uint64
	asset_holding_get AssetBalance
	pop
	global CurrentApplicationAddress
	frame_dig 1 // inId: uint64
	asset_holding_get AssetBalance
	pop
	frame_dig -1 // swapXfer: AssetTransferTxn
	gtxns AssetAmount
	-
	frame_dig -1 // swapXfer: AssetTransferTxn
	gtxns AssetAmount
	callsub tokensToSwap
	frame_bury 2 // toSwap: uint64

	// examples/amm/amm.algo.ts:190
	// assert(toSwap > 0)
	frame_dig 2 // toSwap: uint64
	int 0
	>
	assert

	// examples/amm/amm.algo.ts:192
	// this.doAxfer(this.txn.sender, outId, toSwap)
	frame_dig 2 // toSwap: uint64
	frame_dig 0 // outId: uint64
	txn Sender
	callsub doAxfer

	// examples/amm/amm.algo.ts:194
	// this.ratio.value = this.computeRatio()
	byte 0x72 // "r"
	callsub computeRatio
	app_global_put
	retsub

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0xddc4cb4a // method "set_governor(address)void"
	pushbytes 0x25e6c376 // method "bootstrap(pay,uint64,uint64)uint64"
	pushbytes 0x10045c79 // method "mint(axfer,axfer,uint64,uint64,uint64)void"
	pushbytes 0x028e37c1 // method "burn(axfer,uint64,uint64,uint64)void"
	pushbytes 0x632aaed8 // method "swap(axfer,uint64,uint64)void"
	txna ApplicationArgs 0
	match *abi_route_set_governor *abi_route_bootstrap *abi_route_mint *abi_route_burn *abi_route_swap

	// this contract does not implement the given ABI method for call NoOp
	err", + "approval": "#pragma version 10
intcblock 0 10000000000 1 1000
bytecblock 0x 0x61 0x62 0x67 0x70 0x72

// This TEAL was generated by TEALScript v0.105.0
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// createApplication()void
*abi_route_createApplication:
	// execute createApplication()void
	callsub createApplication
	int 1
	return

// createApplication(): void
createApplication:
	proto 0 0

	// examples/amm/amm.algo.ts:20
	// this.governor.value = this.txn.sender
	byte 0x67 // "g"
	txn Sender
	app_global_put
	retsub

// doCreatePoolToken(aAsset: AssetID, bAsset: AssetID): AssetID
doCreatePoolToken:
	proto 2 1

	// examples/amm/amm.algo.ts:26
	// return sendAssetCreation({
	//       configAssetName: 'DPT-' + aAsset.unitName + '-' + bAsset.unitName,
	//       configAssetUnitName: 'dpt',
	//       configAssetTotal: TOTAL_SUPPLY,
	//       configAssetDecimals: 3,
	//       configAssetManager: this.app.address,
	//       configAssetReserve: this.app.address,
	//     });
	itxn_begin
	pushint 3 // acfg
	itxn_field TypeEnum

	// examples/amm/amm.algo.ts:27
	// configAssetName: 'DPT-' + aAsset.unitName + '-' + bAsset.unitName
	pushbytes 0x4450542d // "DPT-"
	frame_dig -1 // aAsset: AssetID
	asset_params_get AssetUnitName
	pop
	concat
	pushbytes 0x2d // "-"
	concat
	frame_dig -2 // bAsset: AssetID
	asset_params_get AssetUnitName
	pop
	concat
	itxn_field ConfigAssetName

	// examples/amm/amm.algo.ts:28
	// configAssetUnitName: 'dpt'
	pushbytes 0x647074 // "dpt"
	itxn_field ConfigAssetUnitName

	// examples/amm/amm.algo.ts:29
	// configAssetTotal: TOTAL_SUPPLY
	int 10000000000
	itxn_field ConfigAssetTotal

	// examples/amm/amm.algo.ts:30
	// configAssetDecimals: 3
	pushint 3
	itxn_field ConfigAssetDecimals

	// examples/amm/amm.algo.ts:31
	// configAssetManager: this.app.address
	global CurrentApplicationAddress
	itxn_field ConfigAssetManager

	// examples/amm/amm.algo.ts:32
	// configAssetReserve: this.app.address
	global CurrentApplicationAddress
	itxn_field ConfigAssetReserve

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn CreatedAssetID
	retsub

// doAxfer(receiver: Address, asset: AssetID, amount: uint64): void
doAxfer:
	proto 3 0

	// examples/amm/amm.algo.ts:37
	// sendAssetTransfer({
	//       assetReceiver: receiver,
	//       xferAsset: asset,
	//       assetAmount: amount,
	//     })
	itxn_begin
	pushint 4 // axfer
	itxn_field TypeEnum

	// examples/amm/amm.algo.ts:38
	// assetReceiver: receiver
	frame_dig -1 // receiver: Address
	itxn_field AssetReceiver

	// examples/amm/amm.algo.ts:39
	// xferAsset: asset
	frame_dig -2 // asset: AssetID
	itxn_field XferAsset

	// examples/amm/amm.algo.ts:40
	// assetAmount: amount
	frame_dig -3 // amount: uint64
	itxn_field AssetAmount

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// doOptIn(asset: AssetID): void
doOptIn:
	proto 1 0

	// examples/amm/amm.algo.ts:45
	// this.doAxfer(this.app.address, asset, 0)
	int 0
	frame_dig -1 // asset: AssetID
	global CurrentApplicationAddress
	callsub doAxfer
	retsub

// tokensToMintIntial(aAmount: uint64, bAmount: uint64): uint64
tokensToMintIntial:
	proto 2 1

	// examples/amm/amm.algo.ts:49
	// return sqrt(aAmount * bAmount);
	frame_dig -1 // aAmount: uint64
	frame_dig -2 // bAmount: uint64
	*
	sqrt
	retsub

// tokensToMint(issued: uint64, aSupply: uint64, bSupply: uint64, aAmount: uint64, bAmount: uint64): uint64
tokensToMint:
	proto 5 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// examples/amm/amm.algo.ts:53
	// aRatio = wideRatio([aAmount, SCALE], [aSupply])
	frame_dig -4 // aAmount: uint64
	int 1000
	mulw
	int 0
	frame_dig -2 // aSupply: uint64
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	frame_bury 0 // aRatio: uint64

	// examples/amm/amm.algo.ts:54
	// bRatio = wideRatio([bAmount, SCALE], [bSupply])
	frame_dig -5 // bAmount: uint64
	int 1000
	mulw
	int 0
	frame_dig -3 // bSupply: uint64
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	frame_bury 1 // bRatio: uint64

	// examples/amm/amm.algo.ts:56
	// ratio = aRatio < bRatio ? aRatio : bRatio
	frame_dig 0 // aRatio: uint64
	frame_dig 1 // bRatio: uint64
	<
	bz *ternary0_false
	frame_dig 0 // aRatio: uint64
	b *ternary0_end

*ternary0_false:
	frame_dig 1 // bRatio: uint64

*ternary0_end:
	frame_bury 2 // ratio: uint64

	// examples/amm/amm.algo.ts:58
	// return wideRatio([ratio, issued], [SCALE]);
	frame_dig 2 // ratio: uint64
	frame_dig -1 // issued: uint64
	mulw
	int 0
	int 1000
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 2
	retsub

// computeRatio(): uint64
computeRatio:
	proto 0 1

	// examples/amm/amm.algo.ts:62
	// return wideRatio(
	//       [this.app.address.assetBalance(this.assetA.value), SCALE],
	//       [this.app.address.assetBalance(this.assetB.value)]
	//     );
	global CurrentApplicationAddress
	byte 0x61 // "a"
	app_global_get
	asset_holding_get AssetBalance
	pop
	int 1000
	mulw
	int 0
	global CurrentApplicationAddress
	byte 0x62 // "b"
	app_global_get
	asset_holding_get AssetBalance
	pop
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	retsub

// tokensToBurn(issued: uint64, supply: uint64, amount: uint64): uint64
tokensToBurn:
	proto 3 1

	// examples/amm/amm.algo.ts:69
	// return wideRatio([supply, amount], [issued]);
	frame_dig -2 // supply: uint64
	frame_dig -3 // amount: uint64
	mulw
	int 0
	frame_dig -1 // issued: uint64
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	retsub

// tokensToSwap(inAmount: uint64, inSupply: uint64, outSupply: uint64): uint64
tokensToSwap:
	proto 3 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/amm/amm.algo.ts:73
	// factor = SCALE - FEE
	pushint 995
	frame_bury 0 // factor: uint64

	// examples/amm/amm.algo.ts:74
	// return wideRatio([inAmount, factor, outSupply], [inSupply * SCALE + inAmount * factor]);
	frame_dig -1 // inAmount: uint64
	frame_dig 0 // factor: uint64
	mulw
	frame_dig -3 // outSupply: uint64
	uncover 2
	dig 1
	*
	cover 2
	mulw
	cover 2
	+
	swap
	int 0
	frame_dig -2 // inSupply: uint64
	int 1000
	*
	frame_dig -1 // inAmount: uint64
	frame_dig 0 // factor: uint64
	*
	+
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert

	// set the subroutine return value
	frame_bury 0
	retsub

// set_governor(address)void
*abi_route_set_governor:
	// governor: address
	txna ApplicationArgs 1
	dup
	len
	pushint 32
	==

	// argument 0 (governor) for set_governor must be a address
	assert

	// execute set_governor(address)void
	callsub set_governor
	int 1
	return

// set_governor(governor: Address): void
set_governor:
	proto 1 0

	// examples/amm/amm.algo.ts:78
	// verifyAppCallTxn(this.txn, { sender: this.governor.value })
	// verify sender
	txn Sender
	byte 0x67 // "g"
	app_global_get
	==

	// transaction verification failed: {"txn":"this.txn","field":"sender","expected":"this.governor.value"}
	assert

	// examples/amm/amm.algo.ts:79
	// this.governor.value = governor
	byte 0x67 // "g"
	frame_dig -1 // governor: Address
	app_global_put
	retsub

// bootstrap(pay,uint64,uint64)uint64
*abi_route_bootstrap:
	// The ABI return prefix
	pushbytes 0x151f7c75

	// bAsset: uint64
	txna ApplicationArgs 2
	btoi

	// aAsset: uint64
	txna ApplicationArgs 1
	btoi

	// seed: pay
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// argument 2 (seed) for bootstrap must be a pay transaction
	assert

	// execute bootstrap(pay,uint64,uint64)uint64
	callsub bootstrap
	itob
	concat
	log
	int 1
	return

// bootstrap(seed: PayTxn, aAsset: AssetID, bAsset: AssetID): AssetID
bootstrap:
	proto 3 1

	// examples/amm/amm.algo.ts:83
	// verifyAppCallTxn(this.txn, { sender: this.governor.value })
	// verify sender
	txn Sender
	byte 0x67 // "g"
	app_global_get
	==

	// transaction verification failed: {"txn":"this.txn","field":"sender","expected":"this.governor.value"}
	assert

	// examples/amm/amm.algo.ts:85
	// assert(globals.groupSize === 2)
	global GroupSize
	pushint 2
	==
	assert

	// examples/amm/amm.algo.ts:87
	// verifyPayTxn(seed, { receiver: this.app.address, amount: { greaterThanEqualTo: 300_000 } })
	// verify receiver
	frame_dig -1 // seed: PayTxn
	gtxns Receiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"seed","field":"receiver","expected":"this.app.address"}
	assert

	// verify amount
	frame_dig -1 // seed: PayTxn
	gtxns Amount
	pushint 300_000
	>=

	// transaction verification failed: {"txn":"seed","field":"amount","condition":"greaterThanEqualTo","expected":">=300_000"}
	assert

	// examples/amm/amm.algo.ts:88
	// assert(aAsset < bAsset)
	frame_dig -2 // aAsset: AssetID
	frame_dig -3 // bAsset: AssetID
	<
	assert

	// examples/amm/amm.algo.ts:90
	// this.assetA.value = aAsset
	byte 0x61 // "a"
	frame_dig -2 // aAsset: AssetID
	app_global_put

	// examples/amm/amm.algo.ts:91
	// this.assetB.value = bAsset
	byte 0x62 // "b"
	frame_dig -3 // bAsset: AssetID
	app_global_put

	// examples/amm/amm.algo.ts:92
	// this.poolToken.value = this.doCreatePoolToken(aAsset, bAsset)
	byte 0x70 // "p"
	frame_dig -3 // bAsset: AssetID
	frame_dig -2 // aAsset: AssetID
	callsub doCreatePoolToken
	app_global_put

	// examples/amm/amm.algo.ts:94
	// this.doOptIn(aAsset)
	frame_dig -2 // aAsset: AssetID
	callsub doOptIn

	// examples/amm/amm.algo.ts:95
	// this.doOptIn(bAsset)
	frame_dig -3 // bAsset: AssetID
	callsub doOptIn

	// examples/amm/amm.algo.ts:97
	// return this.poolToken.value;
	byte 0x70 // "p"
	app_global_get
	retsub

// mint(axfer,axfer,uint64,uint64,uint64)void
*abi_route_mint:
	// bAsset: uint64
	txna ApplicationArgs 3
	btoi

	// aAsset: uint64
	txna ApplicationArgs 2
	btoi

	// poolAsset: uint64
	txna ApplicationArgs 1
	btoi

	// bXfer: axfer
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	pushint 4 // axfer
	==

	// argument 3 (bXfer) for mint must be a axfer transaction
	assert

	// aXfer: axfer
	txn GroupIndex
	pushint 2
	-
	dup
	gtxns TypeEnum
	pushint 4 // axfer
	==

	// argument 4 (aXfer) for mint must be a axfer transaction
	assert

	// execute mint(axfer,axfer,uint64,uint64,uint64)void
	callsub mint
	int 1
	return

// mint(aXfer: AssetTransferTxn, bXfer: AssetTransferTxn, poolAsset: AssetID, aAsset: AssetID, bAsset: AssetID): void
mint:
	proto 5 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// well formed mint
	// examples/amm/amm.algo.ts:102
	// assert(aAsset === this.assetA.value)
	frame_dig -4 // aAsset: AssetID
	byte 0x61 // "a"
	app_global_get
	==
	assert

	// examples/amm/amm.algo.ts:103
	// assert(bAsset === this.assetB.value)
	frame_dig -5 // bAsset: AssetID
	byte 0x62 // "b"
	app_global_get
	==
	assert

	// examples/amm/amm.algo.ts:104
	// assert(poolAsset === this.poolToken.value)
	frame_dig -3 // poolAsset: AssetID
	byte 0x70 // "p"
	app_global_get
	==
	assert

	// valid asset A axfer
	// examples/amm/amm.algo.ts:107
	// verifyAssetTransferTxn(aXfer, {
	//       sender: this.txn.sender,
	//       assetAmount: { greaterThan: 0 },
	//       assetReceiver: this.app.address,
	//       xferAsset: aAsset,
	//     })
	// verify sender
	frame_dig -1 // aXfer: AssetTransferTxn
	gtxns Sender
	txn Sender
	==

	// transaction verification failed: {"txn":"aXfer","field":"sender","expected":"this.txn.sender"}
	assert

	// verify assetAmount
	frame_dig -1 // aXfer: AssetTransferTxn
	gtxns AssetAmount
	int 0
	>

	// transaction verification failed: {"txn":"aXfer","field":"assetAmount","condition":"greaterThan","expected":">0"}
	assert

	// verify assetReceiver
	frame_dig -1 // aXfer: AssetTransferTxn
	gtxns AssetReceiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"aXfer","field":"assetReceiver","expected":"this.app.address"}
	assert

	// verify xferAsset
	frame_dig -1 // aXfer: AssetTransferTxn
	gtxns XferAsset
	frame_dig -4 // aAsset: AssetID
	==

	// transaction verification failed: {"txn":"aXfer","field":"xferAsset","expected":"aAsset"}
	assert

	// valid asset B axfer
	// examples/amm/amm.algo.ts:115
	// verifyAssetTransferTxn(bXfer, {
	//       sender: this.txn.sender,
	//       assetAmount: { greaterThan: 0 },
	//       assetReceiver: this.app.address,
	//       xferAsset: bAsset,
	//     })
	// verify sender
	frame_dig -2 // bXfer: AssetTransferTxn
	gtxns Sender
	txn Sender
	==

	// transaction verification failed: {"txn":"bXfer","field":"sender","expected":"this.txn.sender"}
	assert

	// verify assetAmount
	frame_dig -2 // bXfer: AssetTransferTxn
	gtxns AssetAmount
	int 0
	>

	// transaction verification failed: {"txn":"bXfer","field":"assetAmount","condition":"greaterThan","expected":">0"}
	assert

	// verify assetReceiver
	frame_dig -2 // bXfer: AssetTransferTxn
	gtxns AssetReceiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"bXfer","field":"assetReceiver","expected":"this.app.address"}
	assert

	// verify xferAsset
	frame_dig -2 // bXfer: AssetTransferTxn
	gtxns XferAsset
	frame_dig -5 // bAsset: AssetID
	==

	// transaction verification failed: {"txn":"bXfer","field":"xferAsset","expected":"bAsset"}
	assert

	// *if0_condition
	// examples/amm/amm.algo.ts:123
	// this.app.address.assetBalance(aAsset) === aXfer.assetAmount &&
	//       this.app.address.assetBalance(bAsset) === bXfer.assetAmount
	global CurrentApplicationAddress
	frame_dig -4 // aAsset: AssetID
	asset_holding_get AssetBalance
	pop
	frame_dig -1 // aXfer: AssetTransferTxn
	gtxns AssetAmount
	==
	dup
	bz *skip_and0
	global CurrentApplicationAddress
	frame_dig -5 // bAsset: AssetID
	asset_holding_get AssetBalance
	pop
	frame_dig -2 // bXfer: AssetTransferTxn
	gtxns AssetAmount
	==
	&&

*skip_and0:
	bz *if0_else

	// *if0_consequent
	// examples/amm/amm.algo.ts:126
	// this.tokensToMintIntial(aXfer.assetAmount, bXfer.assetAmount)
	frame_dig -2 // bXfer: AssetTransferTxn
	gtxns AssetAmount
	frame_dig -1 // aXfer: AssetTransferTxn
	gtxns AssetAmount
	callsub tokensToMintIntial
	b *if0_end

*if0_else:
	// examples/amm/amm.algo.ts:128
	// toMint = this.tokensToMint(
	//         TOTAL_SUPPLY - this.app.address.assetBalance(poolAsset),
	//         this.app.address.assetBalance(aAsset) - aXfer.assetAmount,
	//         this.app.address.assetBalance(bAsset) - bXfer.assetAmount,
	//         aXfer.assetAmount,
	//         bXfer.assetAmount
	//       )
	frame_dig -2 // bXfer: AssetTransferTxn
	gtxns AssetAmount
	frame_dig -1 // aXfer: AssetTransferTxn
	gtxns AssetAmount
	global CurrentApplicationAddress
	frame_dig -5 // bAsset: AssetID
	asset_holding_get AssetBalance
	pop
	frame_dig -2 // bXfer: AssetTransferTxn
	gtxns AssetAmount
	-
	global CurrentApplicationAddress
	frame_dig -4 // aAsset: AssetID
	asset_holding_get AssetBalance
	pop
	frame_dig -1 // aXfer: AssetTransferTxn
	gtxns AssetAmount
	-
	int 10000000000
	global CurrentApplicationAddress
	frame_dig -3 // poolAsset: AssetID
	asset_holding_get AssetBalance
	pop
	-
	callsub tokensToMint
	frame_bury 0 // toMint: uint64

	// examples/amm/amm.algo.ts:136
	// assert(toMint > 0)
	frame_dig 0 // toMint: uint64
	int 0
	>
	assert

	// examples/amm/amm.algo.ts:138
	// this.doAxfer(this.txn.sender, poolAsset, toMint)
	frame_dig 0 // toMint: uint64
	frame_dig -3 // poolAsset: AssetID
	txn Sender
	callsub doAxfer

*if0_end:
	retsub

// burn(axfer,uint64,uint64,uint64)void
*abi_route_burn:
	// bAsset: uint64
	txna ApplicationArgs 3
	btoi

	// aAsset: uint64
	txna ApplicationArgs 2
	btoi

	// poolAsset: uint64
	txna ApplicationArgs 1
	btoi

	// poolXfer: axfer
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	pushint 4 // axfer
	==

	// argument 3 (poolXfer) for burn must be a axfer transaction
	assert

	// execute burn(axfer,uint64,uint64,uint64)void
	callsub burn
	int 1
	return

// burn(poolXfer: AssetTransferTxn, poolAsset: AssetID, aAsset: AssetID, bAsset: AssetID): void
burn:
	proto 4 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// well formed burn
	// examples/amm/amm.algo.ts:144
	// assert(poolAsset === this.poolToken.value)
	frame_dig -2 // poolAsset: AssetID
	byte 0x70 // "p"
	app_global_get
	==
	assert

	// examples/amm/amm.algo.ts:145
	// assert(aAsset === this.assetA.value)
	frame_dig -3 // aAsset: AssetID
	byte 0x61 // "a"
	app_global_get
	==
	assert

	// examples/amm/amm.algo.ts:146
	// assert(bAsset === this.assetB.value)
	frame_dig -4 // bAsset: AssetID
	byte 0x62 // "b"
	app_global_get
	==
	assert

	// valid pool axfer
	// examples/amm/amm.algo.ts:149
	// verifyAssetTransferTxn(poolXfer, {
	//       sender: this.txn.sender,
	//       assetAmount: { greaterThan: 0 },
	//       assetReceiver: this.app.address,
	//       xferAsset: poolAsset,
	//     })
	// verify sender
	frame_dig -1 // poolXfer: AssetTransferTxn
	gtxns Sender
	txn Sender
	==

	// transaction verification failed: {"txn":"poolXfer","field":"sender","expected":"this.txn.sender"}
	assert

	// verify assetAmount
	frame_dig -1 // poolXfer: AssetTransferTxn
	gtxns AssetAmount
	int 0
	>

	// transaction verification failed: {"txn":"poolXfer","field":"assetAmount","condition":"greaterThan","expected":">0"}
	assert

	// verify assetReceiver
	frame_dig -1 // poolXfer: AssetTransferTxn
	gtxns AssetReceiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"poolXfer","field":"assetReceiver","expected":"this.app.address"}
	assert

	// verify xferAsset
	frame_dig -1 // poolXfer: AssetTransferTxn
	gtxns XferAsset
	frame_dig -2 // poolAsset: AssetID
	==

	// transaction verification failed: {"txn":"poolXfer","field":"xferAsset","expected":"poolAsset"}
	assert

	// examples/amm/amm.algo.ts:156
	// issued = TOTAL_SUPPLY - (this.app.address.assetBalance(poolAsset) - poolXfer.assetAmount)
	int 10000000000
	global CurrentApplicationAddress
	frame_dig -2 // poolAsset: AssetID
	asset_holding_get AssetBalance
	pop
	frame_dig -1 // poolXfer: AssetTransferTxn
	gtxns AssetAmount
	-
	-
	frame_bury 0 // issued: uint64

	// examples/amm/amm.algo.ts:158
	// aAmt = this.tokensToBurn(issued, this.app.address.assetBalance(aAsset), poolXfer.assetAmount)
	frame_dig -1 // poolXfer: AssetTransferTxn
	gtxns AssetAmount
	global CurrentApplicationAddress
	frame_dig -3 // aAsset: AssetID
	asset_holding_get AssetBalance
	pop
	frame_dig 0 // issued: uint64
	callsub tokensToBurn
	frame_bury 1 // aAmt: uint64

	// examples/amm/amm.algo.ts:160
	// bAmt = this.tokensToBurn(issued, this.app.address.assetBalance(bAsset), poolXfer.assetAmount)
	frame_dig -1 // poolXfer: AssetTransferTxn
	gtxns AssetAmount
	global CurrentApplicationAddress
	frame_dig -4 // bAsset: AssetID
	asset_holding_get AssetBalance
	pop
	frame_dig 0 // issued: uint64
	callsub tokensToBurn
	frame_bury 2 // bAmt: uint64

	// examples/amm/amm.algo.ts:162
	// this.doAxfer(this.txn.sender, aAsset, aAmt)
	frame_dig 1 // aAmt: uint64
	frame_dig -3 // aAsset: AssetID
	txn Sender
	callsub doAxfer

	// examples/amm/amm.algo.ts:163
	// this.doAxfer(this.txn.sender, bAsset, bAmt)
	frame_dig 2 // bAmt: uint64
	frame_dig -4 // bAsset: AssetID
	txn Sender
	callsub doAxfer

	// examples/amm/amm.algo.ts:165
	// this.ratio.value = this.computeRatio()
	byte 0x72 // "r"
	callsub computeRatio
	app_global_put
	retsub

// swap(axfer,uint64,uint64)void
*abi_route_swap:
	// bAsset: uint64
	txna ApplicationArgs 2
	btoi

	// aAsset: uint64
	txna ApplicationArgs 1
	btoi

	// swapXfer: axfer
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	pushint 4 // axfer
	==

	// argument 2 (swapXfer) for swap must be a axfer transaction
	assert

	// execute swap(axfer,uint64,uint64)void
	callsub swap
	int 1
	return

// swap(swapXfer: AssetTransferTxn, aAsset: AssetID, bAsset: AssetID): void
swap:
	proto 3 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// well formed swap
	// examples/amm/amm.algo.ts:170
	// assert(aAsset === this.assetA.value)
	frame_dig -2 // aAsset: AssetID
	byte 0x61 // "a"
	app_global_get
	==
	assert

	// examples/amm/amm.algo.ts:171
	// assert(bAsset === this.assetB.value)
	frame_dig -3 // bAsset: AssetID
	byte 0x62 // "b"
	app_global_get
	==
	assert

	// examples/amm/amm.algo.ts:173
	// verifyAssetTransferTxn(swapXfer, {
	//       assetAmount: { greaterThan: 0 },
	//       assetReceiver: this.app.address,
	//       sender: this.txn.sender,
	//       xferAsset: { includedIn: [aAsset, bAsset] },
	//     })
	// verify assetAmount
	frame_dig -1 // swapXfer: AssetTransferTxn
	gtxns AssetAmount
	int 0
	>

	// transaction verification failed: {"txn":"swapXfer","field":"assetAmount","condition":"greaterThan","expected":">0"}
	assert

	// verify assetReceiver
	frame_dig -1 // swapXfer: AssetTransferTxn
	gtxns AssetReceiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"swapXfer","field":"assetReceiver","expected":"this.app.address"}
	assert

	// verify sender
	frame_dig -1 // swapXfer: AssetTransferTxn
	gtxns Sender
	txn Sender
	==

	// transaction verification failed: {"txn":"swapXfer","field":"sender","expected":"this.txn.sender"}
	assert

	// verify xferAsset
	frame_dig -1 // swapXfer: AssetTransferTxn
	gtxns XferAsset
	frame_dig -2 // aAsset: AssetID
	==
	frame_dig -1 // swapXfer: AssetTransferTxn
	gtxns XferAsset
	frame_dig -3 // bAsset: AssetID
	==
	||

	// transaction verification failed: {"txn":{"txnText":"swapXfer"},"field":"xferAsset","condition":"includedIn","expected":"[aAsset, bAsset]"}
	assert

	// examples/amm/amm.algo.ts:180
	// outId = swapXfer.xferAsset === aAsset ? aAsset : bAsset
	frame_dig -1 // swapXfer: AssetTransferTxn
	gtxns XferAsset
	frame_dig -2 // aAsset: AssetID
	==
	bz *ternary1_false
	frame_dig -2 // aAsset: AssetID
	b *ternary1_end

*ternary1_false:
	frame_dig -3 // bAsset: AssetID

*ternary1_end:
	frame_bury 0 // outId: uint64

	// examples/amm/amm.algo.ts:182
	// inId = swapXfer.xferAsset
	frame_dig -1 // swapXfer: AssetTransferTxn
	gtxns XferAsset
	frame_bury 1 // inId: uint64

	// examples/amm/amm.algo.ts:184
	// toSwap = this.tokensToSwap(
	//       swapXfer.assetAmount,
	//       this.app.address.assetBalance(inId) - swapXfer.assetAmount,
	//       this.app.address.assetBalance(outId)
	//     )
	global CurrentApplicationAddress
	frame_dig 0 // outId: uint64
	asset_holding_get AssetBalance
	pop
	global CurrentApplicationAddress
	frame_dig 1 // inId: uint64
	asset_holding_get AssetBalance
	pop
	frame_dig -1 // swapXfer: AssetTransferTxn
	gtxns AssetAmount
	-
	frame_dig -1 // swapXfer: AssetTransferTxn
	gtxns AssetAmount
	callsub tokensToSwap
	frame_bury 2 // toSwap: uint64

	// examples/amm/amm.algo.ts:190
	// assert(toSwap > 0)
	frame_dig 2 // toSwap: uint64
	int 0
	>
	assert

	// examples/amm/amm.algo.ts:192
	// this.doAxfer(this.txn.sender, outId, toSwap)
	frame_dig 2 // toSwap: uint64
	frame_dig 0 // outId: uint64
	txn Sender
	callsub doAxfer

	// examples/amm/amm.algo.ts:194
	// this.ratio.value = this.computeRatio()
	byte 0x72 // "r"
	callsub computeRatio
	app_global_put
	retsub

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0xddc4cb4a // method "set_governor(address)void"
	pushbytes 0x25e6c376 // method "bootstrap(pay,uint64,uint64)uint64"
	pushbytes 0x10045c79 // method "mint(axfer,axfer,uint64,uint64,uint64)void"
	pushbytes 0x028e37c1 // method "burn(axfer,uint64,uint64,uint64)void"
	pushbytes 0x632aaed8 // method "swap(axfer,uint64,uint64)void"
	txna ApplicationArgs 0
	match *abi_route_set_governor *abi_route_bootstrap *abi_route_mint *abi_route_burn *abi_route_swap

	// this contract does not implement the given ABI method for call NoOp
	err", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/examples/amm/tealscript_artifacts/ConstantProductAMM.arc56_draft.json b/examples/amm/tealscript_artifacts/ConstantProductAMM.arc56_draft.json index 0bd1d58e8..68eed61b7 100644 --- a/examples/amm/tealscript_artifacts/ConstantProductAMM.arc56_draft.json +++ b/examples/amm/tealscript_artifacts/ConstantProductAMM.arc56_draft.json @@ -5095,7 +5095,7 @@ } }, "source": { - "approval": "#pragma version 10
intcblock 0 10000000000 1 1000
bytecblock 0x 0x61 0x62 0x67 0x70 0x72

// This TEAL was generated by TEALScript v0.104.1
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// createApplication()void
*abi_route_createApplication:
	// execute createApplication()void
	callsub createApplication
	int 1
	return

// createApplication(): void
createApplication:
	proto 0 0

	// examples/amm/amm.algo.ts:20
	// this.governor.value = this.txn.sender
	byte 0x67 // "g"
	txn Sender
	app_global_put
	retsub

// doCreatePoolToken(aAsset: AssetID, bAsset: AssetID): AssetID
doCreatePoolToken:
	proto 2 1

	// examples/amm/amm.algo.ts:26
	// return sendAssetCreation({
	//       configAssetName: 'DPT-' + aAsset.unitName + '-' + bAsset.unitName,
	//       configAssetUnitName: 'dpt',
	//       configAssetTotal: TOTAL_SUPPLY,
	//       configAssetDecimals: 3,
	//       configAssetManager: this.app.address,
	//       configAssetReserve: this.app.address,
	//     });
	itxn_begin
	pushint 3 // acfg
	itxn_field TypeEnum

	// examples/amm/amm.algo.ts:27
	// configAssetName: 'DPT-' + aAsset.unitName + '-' + bAsset.unitName
	pushbytes 0x4450542d // "DPT-"
	frame_dig -1 // aAsset: AssetID
	asset_params_get AssetUnitName
	pop
	concat
	pushbytes 0x2d // "-"
	concat
	frame_dig -2 // bAsset: AssetID
	asset_params_get AssetUnitName
	pop
	concat
	itxn_field ConfigAssetName

	// examples/amm/amm.algo.ts:28
	// configAssetUnitName: 'dpt'
	pushbytes 0x647074 // "dpt"
	itxn_field ConfigAssetUnitName

	// examples/amm/amm.algo.ts:29
	// configAssetTotal: TOTAL_SUPPLY
	int 10000000000
	itxn_field ConfigAssetTotal

	// examples/amm/amm.algo.ts:30
	// configAssetDecimals: 3
	pushint 3
	itxn_field ConfigAssetDecimals

	// examples/amm/amm.algo.ts:31
	// configAssetManager: this.app.address
	global CurrentApplicationAddress
	itxn_field ConfigAssetManager

	// examples/amm/amm.algo.ts:32
	// configAssetReserve: this.app.address
	global CurrentApplicationAddress
	itxn_field ConfigAssetReserve

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn CreatedAssetID
	retsub

// doAxfer(receiver: Address, asset: AssetID, amount: uint64): void
doAxfer:
	proto 3 0

	// examples/amm/amm.algo.ts:37
	// sendAssetTransfer({
	//       assetReceiver: receiver,
	//       xferAsset: asset,
	//       assetAmount: amount,
	//     })
	itxn_begin
	pushint 4 // axfer
	itxn_field TypeEnum

	// examples/amm/amm.algo.ts:38
	// assetReceiver: receiver
	frame_dig -1 // receiver: Address
	itxn_field AssetReceiver

	// examples/amm/amm.algo.ts:39
	// xferAsset: asset
	frame_dig -2 // asset: AssetID
	itxn_field XferAsset

	// examples/amm/amm.algo.ts:40
	// assetAmount: amount
	frame_dig -3 // amount: uint64
	itxn_field AssetAmount

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// doOptIn(asset: AssetID): void
doOptIn:
	proto 1 0

	// examples/amm/amm.algo.ts:45
	// this.doAxfer(this.app.address, asset, 0)
	int 0
	frame_dig -1 // asset: AssetID
	global CurrentApplicationAddress
	callsub doAxfer
	retsub

// tokensToMintIntial(aAmount: uint64, bAmount: uint64): uint64
tokensToMintIntial:
	proto 2 1

	// examples/amm/amm.algo.ts:49
	// return sqrt(aAmount * bAmount);
	frame_dig -1 // aAmount: uint64
	frame_dig -2 // bAmount: uint64
	*
	sqrt
	retsub

// tokensToMint(issued: uint64, aSupply: uint64, bSupply: uint64, aAmount: uint64, bAmount: uint64): uint64
tokensToMint:
	proto 5 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// examples/amm/amm.algo.ts:53
	// aRatio = wideRatio([aAmount, SCALE], [aSupply])
	frame_dig -4 // aAmount: uint64
	int 1000
	mulw
	int 0
	frame_dig -2 // aSupply: uint64
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	frame_bury 0 // aRatio: uint64

	// examples/amm/amm.algo.ts:54
	// bRatio = wideRatio([bAmount, SCALE], [bSupply])
	frame_dig -5 // bAmount: uint64
	int 1000
	mulw
	int 0
	frame_dig -3 // bSupply: uint64
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	frame_bury 1 // bRatio: uint64

	// examples/amm/amm.algo.ts:56
	// ratio = aRatio < bRatio ? aRatio : bRatio
	frame_dig 0 // aRatio: uint64
	frame_dig 1 // bRatio: uint64
	<
	bz *ternary0_false
	frame_dig 0 // aRatio: uint64
	b *ternary0_end

*ternary0_false:
	frame_dig 1 // bRatio: uint64

*ternary0_end:
	frame_bury 2 // ratio: uint64

	// examples/amm/amm.algo.ts:58
	// return wideRatio([ratio, issued], [SCALE]);
	frame_dig 2 // ratio: uint64
	frame_dig -1 // issued: uint64
	mulw
	int 0
	int 1000
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 2
	retsub

// computeRatio(): uint64
computeRatio:
	proto 0 1

	// examples/amm/amm.algo.ts:62
	// return wideRatio(
	//       [this.app.address.assetBalance(this.assetA.value), SCALE],
	//       [this.app.address.assetBalance(this.assetB.value)]
	//     );
	global CurrentApplicationAddress
	byte 0x61 // "a"
	app_global_get
	asset_holding_get AssetBalance
	pop
	int 1000
	mulw
	int 0
	global CurrentApplicationAddress
	byte 0x62 // "b"
	app_global_get
	asset_holding_get AssetBalance
	pop
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	retsub

// tokensToBurn(issued: uint64, supply: uint64, amount: uint64): uint64
tokensToBurn:
	proto 3 1

	// examples/amm/amm.algo.ts:69
	// return wideRatio([supply, amount], [issued]);
	frame_dig -2 // supply: uint64
	frame_dig -3 // amount: uint64
	mulw
	int 0
	frame_dig -1 // issued: uint64
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	retsub

// tokensToSwap(inAmount: uint64, inSupply: uint64, outSupply: uint64): uint64
tokensToSwap:
	proto 3 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/amm/amm.algo.ts:73
	// factor = SCALE - FEE
	pushint 995
	frame_bury 0 // factor: uint64

	// examples/amm/amm.algo.ts:74
	// return wideRatio([inAmount, factor, outSupply], [inSupply * SCALE + inAmount * factor]);
	frame_dig -1 // inAmount: uint64
	frame_dig 0 // factor: uint64
	mulw
	frame_dig -3 // outSupply: uint64
	uncover 2
	dig 1
	*
	cover 2
	mulw
	cover 2
	+
	swap
	int 0
	frame_dig -2 // inSupply: uint64
	int 1000
	*
	frame_dig -1 // inAmount: uint64
	frame_dig 0 // factor: uint64
	*
	+
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert

	// set the subroutine return value
	frame_bury 0
	retsub

// set_governor(address)void
*abi_route_set_governor:
	// governor: address
	txna ApplicationArgs 1
	dup
	len
	pushint 32
	==

	// argument 0 (governor) for set_governor must be a address
	assert

	// execute set_governor(address)void
	callsub set_governor
	int 1
	return

// set_governor(governor: Address): void
set_governor:
	proto 1 0

	// examples/amm/amm.algo.ts:78
	// verifyAppCallTxn(this.txn, { sender: this.governor.value })
	// verify sender
	txn Sender
	byte 0x67 // "g"
	app_global_get
	==

	// transaction verification failed: {"txn":"this.txn","field":"sender","expected":"this.governor.value"}
	assert

	// examples/amm/amm.algo.ts:79
	// this.governor.value = governor
	byte 0x67 // "g"
	frame_dig -1 // governor: Address
	app_global_put
	retsub

// bootstrap(pay,uint64,uint64)uint64
*abi_route_bootstrap:
	// The ABI return prefix
	pushbytes 0x151f7c75

	// bAsset: uint64
	txna ApplicationArgs 2
	btoi

	// aAsset: uint64
	txna ApplicationArgs 1
	btoi

	// seed: pay
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// argument 2 (seed) for bootstrap must be a pay transaction
	assert

	// execute bootstrap(pay,uint64,uint64)uint64
	callsub bootstrap
	itob
	concat
	log
	int 1
	return

// bootstrap(seed: PayTxn, aAsset: AssetID, bAsset: AssetID): AssetID
bootstrap:
	proto 3 1

	// examples/amm/amm.algo.ts:83
	// verifyAppCallTxn(this.txn, { sender: this.governor.value })
	// verify sender
	txn Sender
	byte 0x67 // "g"
	app_global_get
	==

	// transaction verification failed: {"txn":"this.txn","field":"sender","expected":"this.governor.value"}
	assert

	// examples/amm/amm.algo.ts:85
	// assert(globals.groupSize === 2)
	global GroupSize
	pushint 2
	==
	assert

	// examples/amm/amm.algo.ts:87
	// verifyPayTxn(seed, { receiver: this.app.address, amount: { greaterThanEqualTo: 300_000 } })
	// verify receiver
	frame_dig -1 // seed: PayTxn
	gtxns Receiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"seed","field":"receiver","expected":"this.app.address"}
	assert

	// verify amount
	frame_dig -1 // seed: PayTxn
	gtxns Amount
	pushint 300_000
	>=

	// transaction verification failed: {"txn":"seed","field":"amount","condition":"greaterThanEqualTo","expected":">=300_000"}
	assert

	// examples/amm/amm.algo.ts:88
	// assert(aAsset < bAsset)
	frame_dig -2 // aAsset: AssetID
	frame_dig -3 // bAsset: AssetID
	<
	assert

	// examples/amm/amm.algo.ts:90
	// this.assetA.value = aAsset
	byte 0x61 // "a"
	frame_dig -2 // aAsset: AssetID
	app_global_put

	// examples/amm/amm.algo.ts:91
	// this.assetB.value = bAsset
	byte 0x62 // "b"
	frame_dig -3 // bAsset: AssetID
	app_global_put

	// examples/amm/amm.algo.ts:92
	// this.poolToken.value = this.doCreatePoolToken(aAsset, bAsset)
	byte 0x70 // "p"
	frame_dig -3 // bAsset: AssetID
	frame_dig -2 // aAsset: AssetID
	callsub doCreatePoolToken
	app_global_put

	// examples/amm/amm.algo.ts:94
	// this.doOptIn(aAsset)
	frame_dig -2 // aAsset: AssetID
	callsub doOptIn

	// examples/amm/amm.algo.ts:95
	// this.doOptIn(bAsset)
	frame_dig -3 // bAsset: AssetID
	callsub doOptIn

	// examples/amm/amm.algo.ts:97
	// return this.poolToken.value;
	byte 0x70 // "p"
	app_global_get
	retsub

// mint(axfer,axfer,uint64,uint64,uint64)void
*abi_route_mint:
	// bAsset: uint64
	txna ApplicationArgs 3
	btoi

	// aAsset: uint64
	txna ApplicationArgs 2
	btoi

	// poolAsset: uint64
	txna ApplicationArgs 1
	btoi

	// bXfer: axfer
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	pushint 4 // axfer
	==

	// argument 3 (bXfer) for mint must be a axfer transaction
	assert

	// aXfer: axfer
	txn GroupIndex
	pushint 2
	-
	dup
	gtxns TypeEnum
	pushint 4 // axfer
	==

	// argument 4 (aXfer) for mint must be a axfer transaction
	assert

	// execute mint(axfer,axfer,uint64,uint64,uint64)void
	callsub mint
	int 1
	return

// mint(aXfer: AssetTransferTxn, bXfer: AssetTransferTxn, poolAsset: AssetID, aAsset: AssetID, bAsset: AssetID): void
mint:
	proto 5 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// well formed mint
	// examples/amm/amm.algo.ts:102
	// assert(aAsset === this.assetA.value)
	frame_dig -4 // aAsset: AssetID
	byte 0x61 // "a"
	app_global_get
	==
	assert

	// examples/amm/amm.algo.ts:103
	// assert(bAsset === this.assetB.value)
	frame_dig -5 // bAsset: AssetID
	byte 0x62 // "b"
	app_global_get
	==
	assert

	// examples/amm/amm.algo.ts:104
	// assert(poolAsset === this.poolToken.value)
	frame_dig -3 // poolAsset: AssetID
	byte 0x70 // "p"
	app_global_get
	==
	assert

	// valid asset A axfer
	// examples/amm/amm.algo.ts:107
	// verifyAssetTransferTxn(aXfer, {
	//       sender: this.txn.sender,
	//       assetAmount: { greaterThan: 0 },
	//       assetReceiver: this.app.address,
	//       xferAsset: aAsset,
	//     })
	// verify sender
	frame_dig -1 // aXfer: AssetTransferTxn
	gtxns Sender
	txn Sender
	==

	// transaction verification failed: {"txn":"aXfer","field":"sender","expected":"this.txn.sender"}
	assert

	// verify assetAmount
	frame_dig -1 // aXfer: AssetTransferTxn
	gtxns AssetAmount
	int 0
	>

	// transaction verification failed: {"txn":"aXfer","field":"assetAmount","condition":"greaterThan","expected":">0"}
	assert

	// verify assetReceiver
	frame_dig -1 // aXfer: AssetTransferTxn
	gtxns AssetReceiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"aXfer","field":"assetReceiver","expected":"this.app.address"}
	assert

	// verify xferAsset
	frame_dig -1 // aXfer: AssetTransferTxn
	gtxns XferAsset
	frame_dig -4 // aAsset: AssetID
	==

	// transaction verification failed: {"txn":"aXfer","field":"xferAsset","expected":"aAsset"}
	assert

	// valid asset B axfer
	// examples/amm/amm.algo.ts:115
	// verifyAssetTransferTxn(bXfer, {
	//       sender: this.txn.sender,
	//       assetAmount: { greaterThan: 0 },
	//       assetReceiver: this.app.address,
	//       xferAsset: bAsset,
	//     })
	// verify sender
	frame_dig -2 // bXfer: AssetTransferTxn
	gtxns Sender
	txn Sender
	==

	// transaction verification failed: {"txn":"bXfer","field":"sender","expected":"this.txn.sender"}
	assert

	// verify assetAmount
	frame_dig -2 // bXfer: AssetTransferTxn
	gtxns AssetAmount
	int 0
	>

	// transaction verification failed: {"txn":"bXfer","field":"assetAmount","condition":"greaterThan","expected":">0"}
	assert

	// verify assetReceiver
	frame_dig -2 // bXfer: AssetTransferTxn
	gtxns AssetReceiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"bXfer","field":"assetReceiver","expected":"this.app.address"}
	assert

	// verify xferAsset
	frame_dig -2 // bXfer: AssetTransferTxn
	gtxns XferAsset
	frame_dig -5 // bAsset: AssetID
	==

	// transaction verification failed: {"txn":"bXfer","field":"xferAsset","expected":"bAsset"}
	assert

	// *if0_condition
	// examples/amm/amm.algo.ts:123
	// this.app.address.assetBalance(aAsset) === aXfer.assetAmount &&
	//       this.app.address.assetBalance(bAsset) === bXfer.assetAmount
	global CurrentApplicationAddress
	frame_dig -4 // aAsset: AssetID
	asset_holding_get AssetBalance
	pop
	frame_dig -1 // aXfer: AssetTransferTxn
	gtxns AssetAmount
	==
	dup
	bz *skip_and0
	global CurrentApplicationAddress
	frame_dig -5 // bAsset: AssetID
	asset_holding_get AssetBalance
	pop
	frame_dig -2 // bXfer: AssetTransferTxn
	gtxns AssetAmount
	==
	&&

*skip_and0:
	bz *if0_else

	// *if0_consequent
	// examples/amm/amm.algo.ts:126
	// this.tokensToMintIntial(aXfer.assetAmount, bXfer.assetAmount)
	frame_dig -2 // bXfer: AssetTransferTxn
	gtxns AssetAmount
	frame_dig -1 // aXfer: AssetTransferTxn
	gtxns AssetAmount
	callsub tokensToMintIntial
	b *if0_end

*if0_else:
	// examples/amm/amm.algo.ts:128
	// toMint = this.tokensToMint(
	//         TOTAL_SUPPLY - this.app.address.assetBalance(poolAsset),
	//         this.app.address.assetBalance(aAsset) - aXfer.assetAmount,
	//         this.app.address.assetBalance(bAsset) - bXfer.assetAmount,
	//         aXfer.assetAmount,
	//         bXfer.assetAmount
	//       )
	frame_dig -2 // bXfer: AssetTransferTxn
	gtxns AssetAmount
	frame_dig -1 // aXfer: AssetTransferTxn
	gtxns AssetAmount
	global CurrentApplicationAddress
	frame_dig -5 // bAsset: AssetID
	asset_holding_get AssetBalance
	pop
	frame_dig -2 // bXfer: AssetTransferTxn
	gtxns AssetAmount
	-
	global CurrentApplicationAddress
	frame_dig -4 // aAsset: AssetID
	asset_holding_get AssetBalance
	pop
	frame_dig -1 // aXfer: AssetTransferTxn
	gtxns AssetAmount
	-
	int 10000000000
	global CurrentApplicationAddress
	frame_dig -3 // poolAsset: AssetID
	asset_holding_get AssetBalance
	pop
	-
	callsub tokensToMint
	frame_bury 0 // toMint: uint64

	// examples/amm/amm.algo.ts:136
	// assert(toMint > 0)
	frame_dig 0 // toMint: uint64
	int 0
	>
	assert

	// examples/amm/amm.algo.ts:138
	// this.doAxfer(this.txn.sender, poolAsset, toMint)
	frame_dig 0 // toMint: uint64
	frame_dig -3 // poolAsset: AssetID
	txn Sender
	callsub doAxfer

*if0_end:
	retsub

// burn(axfer,uint64,uint64,uint64)void
*abi_route_burn:
	// bAsset: uint64
	txna ApplicationArgs 3
	btoi

	// aAsset: uint64
	txna ApplicationArgs 2
	btoi

	// poolAsset: uint64
	txna ApplicationArgs 1
	btoi

	// poolXfer: axfer
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	pushint 4 // axfer
	==

	// argument 3 (poolXfer) for burn must be a axfer transaction
	assert

	// execute burn(axfer,uint64,uint64,uint64)void
	callsub burn
	int 1
	return

// burn(poolXfer: AssetTransferTxn, poolAsset: AssetID, aAsset: AssetID, bAsset: AssetID): void
burn:
	proto 4 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// well formed burn
	// examples/amm/amm.algo.ts:144
	// assert(poolAsset === this.poolToken.value)
	frame_dig -2 // poolAsset: AssetID
	byte 0x70 // "p"
	app_global_get
	==
	assert

	// examples/amm/amm.algo.ts:145
	// assert(aAsset === this.assetA.value)
	frame_dig -3 // aAsset: AssetID
	byte 0x61 // "a"
	app_global_get
	==
	assert

	// examples/amm/amm.algo.ts:146
	// assert(bAsset === this.assetB.value)
	frame_dig -4 // bAsset: AssetID
	byte 0x62 // "b"
	app_global_get
	==
	assert

	// valid pool axfer
	// examples/amm/amm.algo.ts:149
	// verifyAssetTransferTxn(poolXfer, {
	//       sender: this.txn.sender,
	//       assetAmount: { greaterThan: 0 },
	//       assetReceiver: this.app.address,
	//       xferAsset: poolAsset,
	//     })
	// verify sender
	frame_dig -1 // poolXfer: AssetTransferTxn
	gtxns Sender
	txn Sender
	==

	// transaction verification failed: {"txn":"poolXfer","field":"sender","expected":"this.txn.sender"}
	assert

	// verify assetAmount
	frame_dig -1 // poolXfer: AssetTransferTxn
	gtxns AssetAmount
	int 0
	>

	// transaction verification failed: {"txn":"poolXfer","field":"assetAmount","condition":"greaterThan","expected":">0"}
	assert

	// verify assetReceiver
	frame_dig -1 // poolXfer: AssetTransferTxn
	gtxns AssetReceiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"poolXfer","field":"assetReceiver","expected":"this.app.address"}
	assert

	// verify xferAsset
	frame_dig -1 // poolXfer: AssetTransferTxn
	gtxns XferAsset
	frame_dig -2 // poolAsset: AssetID
	==

	// transaction verification failed: {"txn":"poolXfer","field":"xferAsset","expected":"poolAsset"}
	assert

	// examples/amm/amm.algo.ts:156
	// issued = TOTAL_SUPPLY - (this.app.address.assetBalance(poolAsset) - poolXfer.assetAmount)
	int 10000000000
	global CurrentApplicationAddress
	frame_dig -2 // poolAsset: AssetID
	asset_holding_get AssetBalance
	pop
	frame_dig -1 // poolXfer: AssetTransferTxn
	gtxns AssetAmount
	-
	-
	frame_bury 0 // issued: uint64

	// examples/amm/amm.algo.ts:158
	// aAmt = this.tokensToBurn(issued, this.app.address.assetBalance(aAsset), poolXfer.assetAmount)
	frame_dig -1 // poolXfer: AssetTransferTxn
	gtxns AssetAmount
	global CurrentApplicationAddress
	frame_dig -3 // aAsset: AssetID
	asset_holding_get AssetBalance
	pop
	frame_dig 0 // issued: uint64
	callsub tokensToBurn
	frame_bury 1 // aAmt: uint64

	// examples/amm/amm.algo.ts:160
	// bAmt = this.tokensToBurn(issued, this.app.address.assetBalance(bAsset), poolXfer.assetAmount)
	frame_dig -1 // poolXfer: AssetTransferTxn
	gtxns AssetAmount
	global CurrentApplicationAddress
	frame_dig -4 // bAsset: AssetID
	asset_holding_get AssetBalance
	pop
	frame_dig 0 // issued: uint64
	callsub tokensToBurn
	frame_bury 2 // bAmt: uint64

	// examples/amm/amm.algo.ts:162
	// this.doAxfer(this.txn.sender, aAsset, aAmt)
	frame_dig 1 // aAmt: uint64
	frame_dig -3 // aAsset: AssetID
	txn Sender
	callsub doAxfer

	// examples/amm/amm.algo.ts:163
	// this.doAxfer(this.txn.sender, bAsset, bAmt)
	frame_dig 2 // bAmt: uint64
	frame_dig -4 // bAsset: AssetID
	txn Sender
	callsub doAxfer

	// examples/amm/amm.algo.ts:165
	// this.ratio.value = this.computeRatio()
	byte 0x72 // "r"
	callsub computeRatio
	app_global_put
	retsub

// swap(axfer,uint64,uint64)void
*abi_route_swap:
	// bAsset: uint64
	txna ApplicationArgs 2
	btoi

	// aAsset: uint64
	txna ApplicationArgs 1
	btoi

	// swapXfer: axfer
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	pushint 4 // axfer
	==

	// argument 2 (swapXfer) for swap must be a axfer transaction
	assert

	// execute swap(axfer,uint64,uint64)void
	callsub swap
	int 1
	return

// swap(swapXfer: AssetTransferTxn, aAsset: AssetID, bAsset: AssetID): void
swap:
	proto 3 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// well formed swap
	// examples/amm/amm.algo.ts:170
	// assert(aAsset === this.assetA.value)
	frame_dig -2 // aAsset: AssetID
	byte 0x61 // "a"
	app_global_get
	==
	assert

	// examples/amm/amm.algo.ts:171
	// assert(bAsset === this.assetB.value)
	frame_dig -3 // bAsset: AssetID
	byte 0x62 // "b"
	app_global_get
	==
	assert

	// examples/amm/amm.algo.ts:173
	// verifyAssetTransferTxn(swapXfer, {
	//       assetAmount: { greaterThan: 0 },
	//       assetReceiver: this.app.address,
	//       sender: this.txn.sender,
	//       xferAsset: { includedIn: [aAsset, bAsset] },
	//     })
	// verify assetAmount
	frame_dig -1 // swapXfer: AssetTransferTxn
	gtxns AssetAmount
	int 0
	>

	// transaction verification failed: {"txn":"swapXfer","field":"assetAmount","condition":"greaterThan","expected":">0"}
	assert

	// verify assetReceiver
	frame_dig -1 // swapXfer: AssetTransferTxn
	gtxns AssetReceiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"swapXfer","field":"assetReceiver","expected":"this.app.address"}
	assert

	// verify sender
	frame_dig -1 // swapXfer: AssetTransferTxn
	gtxns Sender
	txn Sender
	==

	// transaction verification failed: {"txn":"swapXfer","field":"sender","expected":"this.txn.sender"}
	assert

	// verify xferAsset
	frame_dig -1 // swapXfer: AssetTransferTxn
	gtxns XferAsset
	frame_dig -2 // aAsset: AssetID
	==
	frame_dig -1 // swapXfer: AssetTransferTxn
	gtxns XferAsset
	frame_dig -3 // bAsset: AssetID
	==
	||

	// transaction verification failed: {"txn":{"txnText":"swapXfer"},"field":"xferAsset","condition":"includedIn","expected":"[aAsset, bAsset]"}
	assert

	// examples/amm/amm.algo.ts:180
	// outId = swapXfer.xferAsset === aAsset ? aAsset : bAsset
	frame_dig -1 // swapXfer: AssetTransferTxn
	gtxns XferAsset
	frame_dig -2 // aAsset: AssetID
	==
	bz *ternary1_false
	frame_dig -2 // aAsset: AssetID
	b *ternary1_end

*ternary1_false:
	frame_dig -3 // bAsset: AssetID

*ternary1_end:
	frame_bury 0 // outId: uint64

	// examples/amm/amm.algo.ts:182
	// inId = swapXfer.xferAsset
	frame_dig -1 // swapXfer: AssetTransferTxn
	gtxns XferAsset
	frame_bury 1 // inId: uint64

	// examples/amm/amm.algo.ts:184
	// toSwap = this.tokensToSwap(
	//       swapXfer.assetAmount,
	//       this.app.address.assetBalance(inId) - swapXfer.assetAmount,
	//       this.app.address.assetBalance(outId)
	//     )
	global CurrentApplicationAddress
	frame_dig 0 // outId: uint64
	asset_holding_get AssetBalance
	pop
	global CurrentApplicationAddress
	frame_dig 1 // inId: uint64
	asset_holding_get AssetBalance
	pop
	frame_dig -1 // swapXfer: AssetTransferTxn
	gtxns AssetAmount
	-
	frame_dig -1 // swapXfer: AssetTransferTxn
	gtxns AssetAmount
	callsub tokensToSwap
	frame_bury 2 // toSwap: uint64

	// examples/amm/amm.algo.ts:190
	// assert(toSwap > 0)
	frame_dig 2 // toSwap: uint64
	int 0
	>
	assert

	// examples/amm/amm.algo.ts:192
	// this.doAxfer(this.txn.sender, outId, toSwap)
	frame_dig 2 // toSwap: uint64
	frame_dig 0 // outId: uint64
	txn Sender
	callsub doAxfer

	// examples/amm/amm.algo.ts:194
	// this.ratio.value = this.computeRatio()
	byte 0x72 // "r"
	callsub computeRatio
	app_global_put
	retsub

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0xddc4cb4a // method "set_governor(address)void"
	pushbytes 0x25e6c376 // method "bootstrap(pay,uint64,uint64)uint64"
	pushbytes 0x10045c79 // method "mint(axfer,axfer,uint64,uint64,uint64)void"
	pushbytes 0x028e37c1 // method "burn(axfer,uint64,uint64,uint64)void"
	pushbytes 0x632aaed8 // method "swap(axfer,uint64,uint64)void"
	txna ApplicationArgs 0
	match *abi_route_set_governor *abi_route_bootstrap *abi_route_mint *abi_route_burn *abi_route_swap

	// this contract does not implement the given ABI method for call NoOp
	err", + "approval": "#pragma version 10
intcblock 0 10000000000 1 1000
bytecblock 0x 0x61 0x62 0x67 0x70 0x72

// This TEAL was generated by TEALScript v0.105.0
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// createApplication()void
*abi_route_createApplication:
	// execute createApplication()void
	callsub createApplication
	int 1
	return

// createApplication(): void
createApplication:
	proto 0 0

	// examples/amm/amm.algo.ts:20
	// this.governor.value = this.txn.sender
	byte 0x67 // "g"
	txn Sender
	app_global_put
	retsub

// doCreatePoolToken(aAsset: AssetID, bAsset: AssetID): AssetID
doCreatePoolToken:
	proto 2 1

	// examples/amm/amm.algo.ts:26
	// return sendAssetCreation({
	//       configAssetName: 'DPT-' + aAsset.unitName + '-' + bAsset.unitName,
	//       configAssetUnitName: 'dpt',
	//       configAssetTotal: TOTAL_SUPPLY,
	//       configAssetDecimals: 3,
	//       configAssetManager: this.app.address,
	//       configAssetReserve: this.app.address,
	//     });
	itxn_begin
	pushint 3 // acfg
	itxn_field TypeEnum

	// examples/amm/amm.algo.ts:27
	// configAssetName: 'DPT-' + aAsset.unitName + '-' + bAsset.unitName
	pushbytes 0x4450542d // "DPT-"
	frame_dig -1 // aAsset: AssetID
	asset_params_get AssetUnitName
	pop
	concat
	pushbytes 0x2d // "-"
	concat
	frame_dig -2 // bAsset: AssetID
	asset_params_get AssetUnitName
	pop
	concat
	itxn_field ConfigAssetName

	// examples/amm/amm.algo.ts:28
	// configAssetUnitName: 'dpt'
	pushbytes 0x647074 // "dpt"
	itxn_field ConfigAssetUnitName

	// examples/amm/amm.algo.ts:29
	// configAssetTotal: TOTAL_SUPPLY
	int 10000000000
	itxn_field ConfigAssetTotal

	// examples/amm/amm.algo.ts:30
	// configAssetDecimals: 3
	pushint 3
	itxn_field ConfigAssetDecimals

	// examples/amm/amm.algo.ts:31
	// configAssetManager: this.app.address
	global CurrentApplicationAddress
	itxn_field ConfigAssetManager

	// examples/amm/amm.algo.ts:32
	// configAssetReserve: this.app.address
	global CurrentApplicationAddress
	itxn_field ConfigAssetReserve

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn CreatedAssetID
	retsub

// doAxfer(receiver: Address, asset: AssetID, amount: uint64): void
doAxfer:
	proto 3 0

	// examples/amm/amm.algo.ts:37
	// sendAssetTransfer({
	//       assetReceiver: receiver,
	//       xferAsset: asset,
	//       assetAmount: amount,
	//     })
	itxn_begin
	pushint 4 // axfer
	itxn_field TypeEnum

	// examples/amm/amm.algo.ts:38
	// assetReceiver: receiver
	frame_dig -1 // receiver: Address
	itxn_field AssetReceiver

	// examples/amm/amm.algo.ts:39
	// xferAsset: asset
	frame_dig -2 // asset: AssetID
	itxn_field XferAsset

	// examples/amm/amm.algo.ts:40
	// assetAmount: amount
	frame_dig -3 // amount: uint64
	itxn_field AssetAmount

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// doOptIn(asset: AssetID): void
doOptIn:
	proto 1 0

	// examples/amm/amm.algo.ts:45
	// this.doAxfer(this.app.address, asset, 0)
	int 0
	frame_dig -1 // asset: AssetID
	global CurrentApplicationAddress
	callsub doAxfer
	retsub

// tokensToMintIntial(aAmount: uint64, bAmount: uint64): uint64
tokensToMintIntial:
	proto 2 1

	// examples/amm/amm.algo.ts:49
	// return sqrt(aAmount * bAmount);
	frame_dig -1 // aAmount: uint64
	frame_dig -2 // bAmount: uint64
	*
	sqrt
	retsub

// tokensToMint(issued: uint64, aSupply: uint64, bSupply: uint64, aAmount: uint64, bAmount: uint64): uint64
tokensToMint:
	proto 5 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// examples/amm/amm.algo.ts:53
	// aRatio = wideRatio([aAmount, SCALE], [aSupply])
	frame_dig -4 // aAmount: uint64
	int 1000
	mulw
	int 0
	frame_dig -2 // aSupply: uint64
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	frame_bury 0 // aRatio: uint64

	// examples/amm/amm.algo.ts:54
	// bRatio = wideRatio([bAmount, SCALE], [bSupply])
	frame_dig -5 // bAmount: uint64
	int 1000
	mulw
	int 0
	frame_dig -3 // bSupply: uint64
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	frame_bury 1 // bRatio: uint64

	// examples/amm/amm.algo.ts:56
	// ratio = aRatio < bRatio ? aRatio : bRatio
	frame_dig 0 // aRatio: uint64
	frame_dig 1 // bRatio: uint64
	<
	bz *ternary0_false
	frame_dig 0 // aRatio: uint64
	b *ternary0_end

*ternary0_false:
	frame_dig 1 // bRatio: uint64

*ternary0_end:
	frame_bury 2 // ratio: uint64

	// examples/amm/amm.algo.ts:58
	// return wideRatio([ratio, issued], [SCALE]);
	frame_dig 2 // ratio: uint64
	frame_dig -1 // issued: uint64
	mulw
	int 0
	int 1000
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 2
	retsub

// computeRatio(): uint64
computeRatio:
	proto 0 1

	// examples/amm/amm.algo.ts:62
	// return wideRatio(
	//       [this.app.address.assetBalance(this.assetA.value), SCALE],
	//       [this.app.address.assetBalance(this.assetB.value)]
	//     );
	global CurrentApplicationAddress
	byte 0x61 // "a"
	app_global_get
	asset_holding_get AssetBalance
	pop
	int 1000
	mulw
	int 0
	global CurrentApplicationAddress
	byte 0x62 // "b"
	app_global_get
	asset_holding_get AssetBalance
	pop
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	retsub

// tokensToBurn(issued: uint64, supply: uint64, amount: uint64): uint64
tokensToBurn:
	proto 3 1

	// examples/amm/amm.algo.ts:69
	// return wideRatio([supply, amount], [issued]);
	frame_dig -2 // supply: uint64
	frame_dig -3 // amount: uint64
	mulw
	int 0
	frame_dig -1 // issued: uint64
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	retsub

// tokensToSwap(inAmount: uint64, inSupply: uint64, outSupply: uint64): uint64
tokensToSwap:
	proto 3 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/amm/amm.algo.ts:73
	// factor = SCALE - FEE
	pushint 995
	frame_bury 0 // factor: uint64

	// examples/amm/amm.algo.ts:74
	// return wideRatio([inAmount, factor, outSupply], [inSupply * SCALE + inAmount * factor]);
	frame_dig -1 // inAmount: uint64
	frame_dig 0 // factor: uint64
	mulw
	frame_dig -3 // outSupply: uint64
	uncover 2
	dig 1
	*
	cover 2
	mulw
	cover 2
	+
	swap
	int 0
	frame_dig -2 // inSupply: uint64
	int 1000
	*
	frame_dig -1 // inAmount: uint64
	frame_dig 0 // factor: uint64
	*
	+
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert

	// set the subroutine return value
	frame_bury 0
	retsub

// set_governor(address)void
*abi_route_set_governor:
	// governor: address
	txna ApplicationArgs 1
	dup
	len
	pushint 32
	==

	// argument 0 (governor) for set_governor must be a address
	assert

	// execute set_governor(address)void
	callsub set_governor
	int 1
	return

// set_governor(governor: Address): void
set_governor:
	proto 1 0

	// examples/amm/amm.algo.ts:78
	// verifyAppCallTxn(this.txn, { sender: this.governor.value })
	// verify sender
	txn Sender
	byte 0x67 // "g"
	app_global_get
	==

	// transaction verification failed: {"txn":"this.txn","field":"sender","expected":"this.governor.value"}
	assert

	// examples/amm/amm.algo.ts:79
	// this.governor.value = governor
	byte 0x67 // "g"
	frame_dig -1 // governor: Address
	app_global_put
	retsub

// bootstrap(pay,uint64,uint64)uint64
*abi_route_bootstrap:
	// The ABI return prefix
	pushbytes 0x151f7c75

	// bAsset: uint64
	txna ApplicationArgs 2
	btoi

	// aAsset: uint64
	txna ApplicationArgs 1
	btoi

	// seed: pay
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// argument 2 (seed) for bootstrap must be a pay transaction
	assert

	// execute bootstrap(pay,uint64,uint64)uint64
	callsub bootstrap
	itob
	concat
	log
	int 1
	return

// bootstrap(seed: PayTxn, aAsset: AssetID, bAsset: AssetID): AssetID
bootstrap:
	proto 3 1

	// examples/amm/amm.algo.ts:83
	// verifyAppCallTxn(this.txn, { sender: this.governor.value })
	// verify sender
	txn Sender
	byte 0x67 // "g"
	app_global_get
	==

	// transaction verification failed: {"txn":"this.txn","field":"sender","expected":"this.governor.value"}
	assert

	// examples/amm/amm.algo.ts:85
	// assert(globals.groupSize === 2)
	global GroupSize
	pushint 2
	==
	assert

	// examples/amm/amm.algo.ts:87
	// verifyPayTxn(seed, { receiver: this.app.address, amount: { greaterThanEqualTo: 300_000 } })
	// verify receiver
	frame_dig -1 // seed: PayTxn
	gtxns Receiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"seed","field":"receiver","expected":"this.app.address"}
	assert

	// verify amount
	frame_dig -1 // seed: PayTxn
	gtxns Amount
	pushint 300_000
	>=

	// transaction verification failed: {"txn":"seed","field":"amount","condition":"greaterThanEqualTo","expected":">=300_000"}
	assert

	// examples/amm/amm.algo.ts:88
	// assert(aAsset < bAsset)
	frame_dig -2 // aAsset: AssetID
	frame_dig -3 // bAsset: AssetID
	<
	assert

	// examples/amm/amm.algo.ts:90
	// this.assetA.value = aAsset
	byte 0x61 // "a"
	frame_dig -2 // aAsset: AssetID
	app_global_put

	// examples/amm/amm.algo.ts:91
	// this.assetB.value = bAsset
	byte 0x62 // "b"
	frame_dig -3 // bAsset: AssetID
	app_global_put

	// examples/amm/amm.algo.ts:92
	// this.poolToken.value = this.doCreatePoolToken(aAsset, bAsset)
	byte 0x70 // "p"
	frame_dig -3 // bAsset: AssetID
	frame_dig -2 // aAsset: AssetID
	callsub doCreatePoolToken
	app_global_put

	// examples/amm/amm.algo.ts:94
	// this.doOptIn(aAsset)
	frame_dig -2 // aAsset: AssetID
	callsub doOptIn

	// examples/amm/amm.algo.ts:95
	// this.doOptIn(bAsset)
	frame_dig -3 // bAsset: AssetID
	callsub doOptIn

	// examples/amm/amm.algo.ts:97
	// return this.poolToken.value;
	byte 0x70 // "p"
	app_global_get
	retsub

// mint(axfer,axfer,uint64,uint64,uint64)void
*abi_route_mint:
	// bAsset: uint64
	txna ApplicationArgs 3
	btoi

	// aAsset: uint64
	txna ApplicationArgs 2
	btoi

	// poolAsset: uint64
	txna ApplicationArgs 1
	btoi

	// bXfer: axfer
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	pushint 4 // axfer
	==

	// argument 3 (bXfer) for mint must be a axfer transaction
	assert

	// aXfer: axfer
	txn GroupIndex
	pushint 2
	-
	dup
	gtxns TypeEnum
	pushint 4 // axfer
	==

	// argument 4 (aXfer) for mint must be a axfer transaction
	assert

	// execute mint(axfer,axfer,uint64,uint64,uint64)void
	callsub mint
	int 1
	return

// mint(aXfer: AssetTransferTxn, bXfer: AssetTransferTxn, poolAsset: AssetID, aAsset: AssetID, bAsset: AssetID): void
mint:
	proto 5 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// well formed mint
	// examples/amm/amm.algo.ts:102
	// assert(aAsset === this.assetA.value)
	frame_dig -4 // aAsset: AssetID
	byte 0x61 // "a"
	app_global_get
	==
	assert

	// examples/amm/amm.algo.ts:103
	// assert(bAsset === this.assetB.value)
	frame_dig -5 // bAsset: AssetID
	byte 0x62 // "b"
	app_global_get
	==
	assert

	// examples/amm/amm.algo.ts:104
	// assert(poolAsset === this.poolToken.value)
	frame_dig -3 // poolAsset: AssetID
	byte 0x70 // "p"
	app_global_get
	==
	assert

	// valid asset A axfer
	// examples/amm/amm.algo.ts:107
	// verifyAssetTransferTxn(aXfer, {
	//       sender: this.txn.sender,
	//       assetAmount: { greaterThan: 0 },
	//       assetReceiver: this.app.address,
	//       xferAsset: aAsset,
	//     })
	// verify sender
	frame_dig -1 // aXfer: AssetTransferTxn
	gtxns Sender
	txn Sender
	==

	// transaction verification failed: {"txn":"aXfer","field":"sender","expected":"this.txn.sender"}
	assert

	// verify assetAmount
	frame_dig -1 // aXfer: AssetTransferTxn
	gtxns AssetAmount
	int 0
	>

	// transaction verification failed: {"txn":"aXfer","field":"assetAmount","condition":"greaterThan","expected":">0"}
	assert

	// verify assetReceiver
	frame_dig -1 // aXfer: AssetTransferTxn
	gtxns AssetReceiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"aXfer","field":"assetReceiver","expected":"this.app.address"}
	assert

	// verify xferAsset
	frame_dig -1 // aXfer: AssetTransferTxn
	gtxns XferAsset
	frame_dig -4 // aAsset: AssetID
	==

	// transaction verification failed: {"txn":"aXfer","field":"xferAsset","expected":"aAsset"}
	assert

	// valid asset B axfer
	// examples/amm/amm.algo.ts:115
	// verifyAssetTransferTxn(bXfer, {
	//       sender: this.txn.sender,
	//       assetAmount: { greaterThan: 0 },
	//       assetReceiver: this.app.address,
	//       xferAsset: bAsset,
	//     })
	// verify sender
	frame_dig -2 // bXfer: AssetTransferTxn
	gtxns Sender
	txn Sender
	==

	// transaction verification failed: {"txn":"bXfer","field":"sender","expected":"this.txn.sender"}
	assert

	// verify assetAmount
	frame_dig -2 // bXfer: AssetTransferTxn
	gtxns AssetAmount
	int 0
	>

	// transaction verification failed: {"txn":"bXfer","field":"assetAmount","condition":"greaterThan","expected":">0"}
	assert

	// verify assetReceiver
	frame_dig -2 // bXfer: AssetTransferTxn
	gtxns AssetReceiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"bXfer","field":"assetReceiver","expected":"this.app.address"}
	assert

	// verify xferAsset
	frame_dig -2 // bXfer: AssetTransferTxn
	gtxns XferAsset
	frame_dig -5 // bAsset: AssetID
	==

	// transaction verification failed: {"txn":"bXfer","field":"xferAsset","expected":"bAsset"}
	assert

	// *if0_condition
	// examples/amm/amm.algo.ts:123
	// this.app.address.assetBalance(aAsset) === aXfer.assetAmount &&
	//       this.app.address.assetBalance(bAsset) === bXfer.assetAmount
	global CurrentApplicationAddress
	frame_dig -4 // aAsset: AssetID
	asset_holding_get AssetBalance
	pop
	frame_dig -1 // aXfer: AssetTransferTxn
	gtxns AssetAmount
	==
	dup
	bz *skip_and0
	global CurrentApplicationAddress
	frame_dig -5 // bAsset: AssetID
	asset_holding_get AssetBalance
	pop
	frame_dig -2 // bXfer: AssetTransferTxn
	gtxns AssetAmount
	==
	&&

*skip_and0:
	bz *if0_else

	// *if0_consequent
	// examples/amm/amm.algo.ts:126
	// this.tokensToMintIntial(aXfer.assetAmount, bXfer.assetAmount)
	frame_dig -2 // bXfer: AssetTransferTxn
	gtxns AssetAmount
	frame_dig -1 // aXfer: AssetTransferTxn
	gtxns AssetAmount
	callsub tokensToMintIntial
	b *if0_end

*if0_else:
	// examples/amm/amm.algo.ts:128
	// toMint = this.tokensToMint(
	//         TOTAL_SUPPLY - this.app.address.assetBalance(poolAsset),
	//         this.app.address.assetBalance(aAsset) - aXfer.assetAmount,
	//         this.app.address.assetBalance(bAsset) - bXfer.assetAmount,
	//         aXfer.assetAmount,
	//         bXfer.assetAmount
	//       )
	frame_dig -2 // bXfer: AssetTransferTxn
	gtxns AssetAmount
	frame_dig -1 // aXfer: AssetTransferTxn
	gtxns AssetAmount
	global CurrentApplicationAddress
	frame_dig -5 // bAsset: AssetID
	asset_holding_get AssetBalance
	pop
	frame_dig -2 // bXfer: AssetTransferTxn
	gtxns AssetAmount
	-
	global CurrentApplicationAddress
	frame_dig -4 // aAsset: AssetID
	asset_holding_get AssetBalance
	pop
	frame_dig -1 // aXfer: AssetTransferTxn
	gtxns AssetAmount
	-
	int 10000000000
	global CurrentApplicationAddress
	frame_dig -3 // poolAsset: AssetID
	asset_holding_get AssetBalance
	pop
	-
	callsub tokensToMint
	frame_bury 0 // toMint: uint64

	// examples/amm/amm.algo.ts:136
	// assert(toMint > 0)
	frame_dig 0 // toMint: uint64
	int 0
	>
	assert

	// examples/amm/amm.algo.ts:138
	// this.doAxfer(this.txn.sender, poolAsset, toMint)
	frame_dig 0 // toMint: uint64
	frame_dig -3 // poolAsset: AssetID
	txn Sender
	callsub doAxfer

*if0_end:
	retsub

// burn(axfer,uint64,uint64,uint64)void
*abi_route_burn:
	// bAsset: uint64
	txna ApplicationArgs 3
	btoi

	// aAsset: uint64
	txna ApplicationArgs 2
	btoi

	// poolAsset: uint64
	txna ApplicationArgs 1
	btoi

	// poolXfer: axfer
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	pushint 4 // axfer
	==

	// argument 3 (poolXfer) for burn must be a axfer transaction
	assert

	// execute burn(axfer,uint64,uint64,uint64)void
	callsub burn
	int 1
	return

// burn(poolXfer: AssetTransferTxn, poolAsset: AssetID, aAsset: AssetID, bAsset: AssetID): void
burn:
	proto 4 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// well formed burn
	// examples/amm/amm.algo.ts:144
	// assert(poolAsset === this.poolToken.value)
	frame_dig -2 // poolAsset: AssetID
	byte 0x70 // "p"
	app_global_get
	==
	assert

	// examples/amm/amm.algo.ts:145
	// assert(aAsset === this.assetA.value)
	frame_dig -3 // aAsset: AssetID
	byte 0x61 // "a"
	app_global_get
	==
	assert

	// examples/amm/amm.algo.ts:146
	// assert(bAsset === this.assetB.value)
	frame_dig -4 // bAsset: AssetID
	byte 0x62 // "b"
	app_global_get
	==
	assert

	// valid pool axfer
	// examples/amm/amm.algo.ts:149
	// verifyAssetTransferTxn(poolXfer, {
	//       sender: this.txn.sender,
	//       assetAmount: { greaterThan: 0 },
	//       assetReceiver: this.app.address,
	//       xferAsset: poolAsset,
	//     })
	// verify sender
	frame_dig -1 // poolXfer: AssetTransferTxn
	gtxns Sender
	txn Sender
	==

	// transaction verification failed: {"txn":"poolXfer","field":"sender","expected":"this.txn.sender"}
	assert

	// verify assetAmount
	frame_dig -1 // poolXfer: AssetTransferTxn
	gtxns AssetAmount
	int 0
	>

	// transaction verification failed: {"txn":"poolXfer","field":"assetAmount","condition":"greaterThan","expected":">0"}
	assert

	// verify assetReceiver
	frame_dig -1 // poolXfer: AssetTransferTxn
	gtxns AssetReceiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"poolXfer","field":"assetReceiver","expected":"this.app.address"}
	assert

	// verify xferAsset
	frame_dig -1 // poolXfer: AssetTransferTxn
	gtxns XferAsset
	frame_dig -2 // poolAsset: AssetID
	==

	// transaction verification failed: {"txn":"poolXfer","field":"xferAsset","expected":"poolAsset"}
	assert

	// examples/amm/amm.algo.ts:156
	// issued = TOTAL_SUPPLY - (this.app.address.assetBalance(poolAsset) - poolXfer.assetAmount)
	int 10000000000
	global CurrentApplicationAddress
	frame_dig -2 // poolAsset: AssetID
	asset_holding_get AssetBalance
	pop
	frame_dig -1 // poolXfer: AssetTransferTxn
	gtxns AssetAmount
	-
	-
	frame_bury 0 // issued: uint64

	// examples/amm/amm.algo.ts:158
	// aAmt = this.tokensToBurn(issued, this.app.address.assetBalance(aAsset), poolXfer.assetAmount)
	frame_dig -1 // poolXfer: AssetTransferTxn
	gtxns AssetAmount
	global CurrentApplicationAddress
	frame_dig -3 // aAsset: AssetID
	asset_holding_get AssetBalance
	pop
	frame_dig 0 // issued: uint64
	callsub tokensToBurn
	frame_bury 1 // aAmt: uint64

	// examples/amm/amm.algo.ts:160
	// bAmt = this.tokensToBurn(issued, this.app.address.assetBalance(bAsset), poolXfer.assetAmount)
	frame_dig -1 // poolXfer: AssetTransferTxn
	gtxns AssetAmount
	global CurrentApplicationAddress
	frame_dig -4 // bAsset: AssetID
	asset_holding_get AssetBalance
	pop
	frame_dig 0 // issued: uint64
	callsub tokensToBurn
	frame_bury 2 // bAmt: uint64

	// examples/amm/amm.algo.ts:162
	// this.doAxfer(this.txn.sender, aAsset, aAmt)
	frame_dig 1 // aAmt: uint64
	frame_dig -3 // aAsset: AssetID
	txn Sender
	callsub doAxfer

	// examples/amm/amm.algo.ts:163
	// this.doAxfer(this.txn.sender, bAsset, bAmt)
	frame_dig 2 // bAmt: uint64
	frame_dig -4 // bAsset: AssetID
	txn Sender
	callsub doAxfer

	// examples/amm/amm.algo.ts:165
	// this.ratio.value = this.computeRatio()
	byte 0x72 // "r"
	callsub computeRatio
	app_global_put
	retsub

// swap(axfer,uint64,uint64)void
*abi_route_swap:
	// bAsset: uint64
	txna ApplicationArgs 2
	btoi

	// aAsset: uint64
	txna ApplicationArgs 1
	btoi

	// swapXfer: axfer
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	pushint 4 // axfer
	==

	// argument 2 (swapXfer) for swap must be a axfer transaction
	assert

	// execute swap(axfer,uint64,uint64)void
	callsub swap
	int 1
	return

// swap(swapXfer: AssetTransferTxn, aAsset: AssetID, bAsset: AssetID): void
swap:
	proto 3 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// well formed swap
	// examples/amm/amm.algo.ts:170
	// assert(aAsset === this.assetA.value)
	frame_dig -2 // aAsset: AssetID
	byte 0x61 // "a"
	app_global_get
	==
	assert

	// examples/amm/amm.algo.ts:171
	// assert(bAsset === this.assetB.value)
	frame_dig -3 // bAsset: AssetID
	byte 0x62 // "b"
	app_global_get
	==
	assert

	// examples/amm/amm.algo.ts:173
	// verifyAssetTransferTxn(swapXfer, {
	//       assetAmount: { greaterThan: 0 },
	//       assetReceiver: this.app.address,
	//       sender: this.txn.sender,
	//       xferAsset: { includedIn: [aAsset, bAsset] },
	//     })
	// verify assetAmount
	frame_dig -1 // swapXfer: AssetTransferTxn
	gtxns AssetAmount
	int 0
	>

	// transaction verification failed: {"txn":"swapXfer","field":"assetAmount","condition":"greaterThan","expected":">0"}
	assert

	// verify assetReceiver
	frame_dig -1 // swapXfer: AssetTransferTxn
	gtxns AssetReceiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"swapXfer","field":"assetReceiver","expected":"this.app.address"}
	assert

	// verify sender
	frame_dig -1 // swapXfer: AssetTransferTxn
	gtxns Sender
	txn Sender
	==

	// transaction verification failed: {"txn":"swapXfer","field":"sender","expected":"this.txn.sender"}
	assert

	// verify xferAsset
	frame_dig -1 // swapXfer: AssetTransferTxn
	gtxns XferAsset
	frame_dig -2 // aAsset: AssetID
	==
	frame_dig -1 // swapXfer: AssetTransferTxn
	gtxns XferAsset
	frame_dig -3 // bAsset: AssetID
	==
	||

	// transaction verification failed: {"txn":{"txnText":"swapXfer"},"field":"xferAsset","condition":"includedIn","expected":"[aAsset, bAsset]"}
	assert

	// examples/amm/amm.algo.ts:180
	// outId = swapXfer.xferAsset === aAsset ? aAsset : bAsset
	frame_dig -1 // swapXfer: AssetTransferTxn
	gtxns XferAsset
	frame_dig -2 // aAsset: AssetID
	==
	bz *ternary1_false
	frame_dig -2 // aAsset: AssetID
	b *ternary1_end

*ternary1_false:
	frame_dig -3 // bAsset: AssetID

*ternary1_end:
	frame_bury 0 // outId: uint64

	// examples/amm/amm.algo.ts:182
	// inId = swapXfer.xferAsset
	frame_dig -1 // swapXfer: AssetTransferTxn
	gtxns XferAsset
	frame_bury 1 // inId: uint64

	// examples/amm/amm.algo.ts:184
	// toSwap = this.tokensToSwap(
	//       swapXfer.assetAmount,
	//       this.app.address.assetBalance(inId) - swapXfer.assetAmount,
	//       this.app.address.assetBalance(outId)
	//     )
	global CurrentApplicationAddress
	frame_dig 0 // outId: uint64
	asset_holding_get AssetBalance
	pop
	global CurrentApplicationAddress
	frame_dig 1 // inId: uint64
	asset_holding_get AssetBalance
	pop
	frame_dig -1 // swapXfer: AssetTransferTxn
	gtxns AssetAmount
	-
	frame_dig -1 // swapXfer: AssetTransferTxn
	gtxns AssetAmount
	callsub tokensToSwap
	frame_bury 2 // toSwap: uint64

	// examples/amm/amm.algo.ts:190
	// assert(toSwap > 0)
	frame_dig 2 // toSwap: uint64
	int 0
	>
	assert

	// examples/amm/amm.algo.ts:192
	// this.doAxfer(this.txn.sender, outId, toSwap)
	frame_dig 2 // toSwap: uint64
	frame_dig 0 // outId: uint64
	txn Sender
	callsub doAxfer

	// examples/amm/amm.algo.ts:194
	// this.ratio.value = this.computeRatio()
	byte 0x72 // "r"
	callsub computeRatio
	app_global_put
	retsub

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0xddc4cb4a // method "set_governor(address)void"
	pushbytes 0x25e6c376 // method "bootstrap(pay,uint64,uint64)uint64"
	pushbytes 0x10045c79 // method "mint(axfer,axfer,uint64,uint64,uint64)void"
	pushbytes 0x028e37c1 // method "burn(axfer,uint64,uint64,uint64)void"
	pushbytes 0x632aaed8 // method "swap(axfer,uint64,uint64)void"
	txna ApplicationArgs 0
	match *abi_route_set_governor *abi_route_bootstrap *abi_route_mint *abi_route_burn *abi_route_swap

	// this contract does not implement the given ABI method for call NoOp
	err", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/examples/arc58/artifacts/AbstractedAccount.approval.teal b/examples/arc58/artifacts/AbstractedAccount.approval.teal index b73361342..7f2bdd301 100644 --- a/examples/arc58/artifacts/AbstractedAccount.approval.teal +++ b/examples/arc58/artifacts/AbstractedAccount.approval.teal @@ -2,7 +2,7 @@ intcblock 1 0 32 bytecblock 0x70 0x61 0x63 0x0000000000000000 0x 0x0f885493 0x6e 0x00 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/examples/arc58/artifacts/AbstractedAccount.arc32.json b/examples/arc58/artifacts/AbstractedAccount.arc32.json index d44bc61b4..c19d6b6d3 100644 --- a/examples/arc58/artifacts/AbstractedAccount.arc32.json +++ b/examples/arc58/artifacts/AbstractedAccount.arc32.json @@ -98,7 +98,7 @@ } }, "source": { - "approval": "#pragma version 10
intcblock 1 0 32
bytecblock 0x70 0x61 0x63 0x0000000000000000 0x 0x0f885493 0x6e 0x00

// This TEAL was generated by TEALScript v0.104.1
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// verifyRekeyToAbstractedAccount(): void
//
// Ensure that by the end of the group the abstracted account has control of its address
verifyRekeyToAbstractedAccount:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// examples/arc58/arc58.algo.ts:45
	// rekeyedBack = false
	int 0
	frame_bury 0 // rekeyedBack: bool

	// examples/arc58/arc58.algo.ts:47
	// for (let i = this.txn.groupIndex; i < this.txnGroup.length; i += 1)
	txn GroupIndex
	frame_bury 1 // i: uint64

*for_0:
	// examples/arc58/arc58.algo.ts:47
	// i < this.txnGroup.length
	frame_dig 1 // i: uint64
	global GroupSize
	<
	bz *for_0_end

	// examples/arc58/arc58.algo.ts:48
	// txn = this.txnGroup[i]
	frame_dig 1 // i: uint64
	frame_bury 2 // txn: txn

	// *if0_condition
	// examples/arc58/arc58.algo.ts:51
	// txn.sender === this.controlledAddress.value && txn.rekeyTo === this.controlledAddress.value
	frame_dig 2 // txn: txn
	gtxns Sender
	byte 0x63 // "c"
	app_global_get
	==
	dup
	bz *skip_and0
	frame_dig 2 // txn: txn
	gtxns RekeyTo
	byte 0x63 // "c"
	app_global_get
	==
	&&

*skip_and0:
	bz *if0_end

	// *if0_consequent
	// examples/arc58/arc58.algo.ts:52
	// rekeyedBack = true
	int 1
	frame_bury 0 // rekeyedBack: bool
	b *for_0_end

*if0_end:
	// *if1_condition
	// examples/arc58/arc58.algo.ts:58
	// txn.typeEnum === TransactionType.ApplicationCall &&
	//         txn.applicationID === this.app &&
	//         txn.numAppArgs === 1 &&
	//         txn.applicationArgs[0] === method('arc58_verifyAuthAddr()void')
	frame_dig 2 // txn: txn
	gtxns TypeEnum
	pushint 6 // appl
	==
	dup
	bz *skip_and1
	frame_dig 2 // txn: txn
	gtxns ApplicationID
	txna Applications 0
	==
	&&

*skip_and1:
	dup
	bz *skip_and2
	frame_dig 2 // txn: txn
	gtxns NumAppArgs
	int 1
	==
	&&

*skip_and2:
	dup
	bz *skip_and3
	frame_dig 2 // txn: txn
	gtxns ApplicationArgs 0
	byte 0x0f885493 // method "arc58_verifyAuthAddr()void"
	==
	&&

*skip_and3:
	bz *if1_end

	// *if1_consequent
	// examples/arc58/arc58.algo.ts:63
	// rekeyedBack = true
	int 1
	frame_bury 0 // rekeyedBack: bool
	b *for_0_end

*if1_end:

*for_0_continue:
	// examples/arc58/arc58.algo.ts:47
	// i += 1
	frame_dig 1 // i: uint64
	int 1
	+
	frame_bury 1 // i: uint64
	b *for_0

*for_0_end:
	// examples/arc58/arc58.algo.ts:68
	// assert(rekeyedBack)
	frame_dig 0 // rekeyedBack: bool
	assert
	retsub

// getAuthAddr(): Address
//
// What the value of this.address.value.authAddr should be when this.controlledAddress
// is able to be controlled by this app. It will either be this.app.address or zeroAddress
getAuthAddr:
	proto 0 1

	// examples/arc58/arc58.algo.ts:76
	// return this.controlledAddress.value === this.app.address ? Address.zeroAddress : this.app.address;
	byte 0x63 // "c"
	app_global_get
	global CurrentApplicationAddress
	==
	bz *ternary0_false
	global ZeroAddress
	b *ternary0_end

*ternary0_false:
	global CurrentApplicationAddress

*ternary0_end:
	retsub

// createApplication(address,address)void
*abi_route_createApplication:
	// admin: address
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (admin) for createApplication must be a address
	assert

	// controlledAddress: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (controlledAddress) for createApplication must be a address
	assert

	// execute createApplication(address,address)void
	callsub createApplication
	int 1
	return

// createApplication(controlledAddress: Address, admin: Address): void
//
// Create an abstracted account application.
// This is not part of ARC58 and implementation specific.
//
// @param controlledAddress The address of the abstracted account. If zeroAddress, then the address of the contract account will be used
// @param admin The admin for this app
createApplication:
	proto 2 0

	// examples/arc58/arc58.algo.ts:87
	// verifyAppCallTxn(this.txn, {
	//       sender: { includedIn: [controlledAddress, admin] },
	//     })
	// verify sender
	txn Sender
	frame_dig -1 // controlledAddress: Address
	==
	txn Sender
	frame_dig -2 // admin: Address
	==
	||

	// transaction verification failed: {"txn":{"txnText":"this.txn"},"field":"sender","condition":"includedIn","expected":"[controlledAddress, admin]"}
	assert

	// examples/arc58/arc58.algo.ts:91
	// assert(admin !== controlledAddress)
	frame_dig -2 // admin: Address
	frame_dig -1 // controlledAddress: Address
	!=
	assert

	// examples/arc58/arc58.algo.ts:93
	// this.admin.value = admin
	byte 0x61 // "a"
	frame_dig -2 // admin: Address
	app_global_put

	// examples/arc58/arc58.algo.ts:94
	// this.controlledAddress.value = controlledAddress === Address.zeroAddress ? this.app.address : controlledAddress
	byte 0x63 // "c"
	frame_dig -1 // controlledAddress: Address
	global ZeroAddress
	==
	bz *ternary1_false
	global CurrentApplicationAddress
	b *ternary1_end

*ternary1_false:
	frame_dig -1 // controlledAddress: Address

*ternary1_end:
	app_global_put
	retsub

// arc58_changeAdmin(address)void
*abi_route_arc58_changeAdmin:
	// newAdmin: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (newAdmin) for arc58_changeAdmin must be a address
	assert

	// execute arc58_changeAdmin(address)void
	callsub arc58_changeAdmin
	int 1
	return

// arc58_changeAdmin(newAdmin: Address): void
//
// Attempt to change the admin for this app. Some implementations MAY not support this.
//
// @param newAdmin The new admin
arc58_changeAdmin:
	proto 1 0

	// examples/arc58/arc58.algo.ts:103
	// verifyTxn(this.txn, { sender: this.admin.value })
	// verify sender
	txn Sender
	byte 0x61 // "a"
	app_global_get
	==

	// transaction verification failed: {"txn":"this.txn","field":"sender","expected":"this.admin.value"}
	assert

	// examples/arc58/arc58.algo.ts:104
	// this.admin.value = newAdmin
	byte 0x61 // "a"
	frame_dig -1 // newAdmin: Address
	app_global_put
	retsub

// arc58_pluginChangeAdmin(uint64,address,address)void
*abi_route_arc58_pluginChangeAdmin:
	// newAdmin: address
	txna ApplicationArgs 3
	dup
	len
	int 32
	==

	// argument 0 (newAdmin) for arc58_pluginChangeAdmin must be a address
	assert

	// allowedCaller: address
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 1 (allowedCaller) for arc58_pluginChangeAdmin must be a address
	assert

	// plugin: uint64
	txna ApplicationArgs 1
	btoi

	// execute arc58_pluginChangeAdmin(uint64,address,address)void
	callsub arc58_pluginChangeAdmin
	int 1
	return

// arc58_pluginChangeAdmin(plugin: AppID, allowedCaller: Address, newAdmin: Address): void
//
// Attempt to change the admin via plugin.
//
// @param plugin The app calling the plugin
// @param allowedCaller The address that triggered the plugin
// @param newAdmin The new admin
arc58_pluginChangeAdmin:
	proto 3 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/arc58/arc58.algo.ts:116
	// verifyTxn(this.txn, { sender: plugin.address })
	// verify sender
	txn Sender
	frame_dig -1 // plugin: AppID
	app_params_get AppAddress
	pop
	==

	// transaction verification failed: {"txn":"this.txn","field":"sender","expected":"plugin.address"}
	assert

	// examples/arc58/arc58.algo.ts:117
	// assert(this.controlledAddress.value.authAddr === plugin.address, 'This plugin is not in control of the account')
	byte 0x63 // "c"
	app_global_get
	acct_params_get AcctAuthAddr
	pop
	frame_dig -1 // plugin: AppID
	app_params_get AppAddress
	pop
	==

	// This plugin is not in control of the account
	assert

	// examples/arc58/arc58.algo.ts:119
	// key: PluginsKey = { application: plugin, allowedCaller: allowedCaller }
	frame_dig -1 // plugin: AppID
	itob
	frame_dig -2 // allowedCaller: Address
	concat
	frame_bury 0 // key: PluginsKey

	// examples/arc58/arc58.algo.ts:120
	// assert(
	//       this.plugins(key).exists && this.plugins(key).value.adminPrivileges,
	//       'This plugin does not have admin privileges'
	//     )
	byte 0x70 // "p"
	frame_dig 0 // key: PluginsKey
	concat
	box_len
	swap
	pop
	dup
	bz *skip_and4
	byte 0x70 // "p"
	frame_dig 0 // key: PluginsKey
	concat
	box_get

	// box value does not exist: this.plugins(key).value
	assert
	store 255 // full array
	load 255 // full array
	pushint 192
	getbit
	&&

*skip_and4:
	// This plugin does not have admin privileges
	assert

	// examples/arc58/arc58.algo.ts:125
	// this.admin.value = newAdmin
	byte 0x61 // "a"
	frame_dig -3 // newAdmin: Address
	app_global_put
	retsub

// arc58_getAdmin()address
*abi_route_arc58_getAdmin:
	// The ABI return prefix
	pushbytes 0x151f7c75

	// execute arc58_getAdmin()address
	callsub arc58_getAdmin
	concat
	log
	int 1
	return

// arc58_getAdmin(): Address
//
// Get the admin of this app. This method SHOULD always be used rather than reading directly from state
// because different implementations may have different ways of determining the admin.
arc58_getAdmin:
	proto 0 1

	// examples/arc58/arc58.algo.ts:133
	// return this.admin.value;
	byte 0x61 // "a"
	app_global_get
	retsub

// arc58_verifyAuthAddr()void
*abi_route_arc58_verifyAuthAddr:
	// execute arc58_verifyAuthAddr()void
	callsub arc58_verifyAuthAddr
	int 1
	return

// arc58_verifyAuthAddr(): void
//
// Verify the abstracted account is rekeyed to this app
arc58_verifyAuthAddr:
	proto 0 0

	// examples/arc58/arc58.algo.ts:140
	// assert(this.controlledAddress.value.authAddr === this.getAuthAddr())
	byte 0x63 // "c"
	app_global_get
	acct_params_get AcctAuthAddr
	pop
	callsub getAuthAddr
	==
	assert
	retsub

// arc58_rekeyTo(address,bool)void
*abi_route_arc58_rekeyTo:
	// flash: bool
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 0 (flash) for arc58_rekeyTo must be a bool
	assert
	int 0
	getbit

	// addr: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (addr) for arc58_rekeyTo must be a address
	assert

	// execute arc58_rekeyTo(address,bool)void
	callsub arc58_rekeyTo
	int 1
	return

// arc58_rekeyTo(addr: Address, flash: boolean): void
//
// Rekey the abstracted account to another address. Primarily useful for rekeying to an EOA.
//
// @param addr The address to rekey to
// @param flash Whether or not this should be a flash rekey. If true, the rekey back to the app address must done in the same txn group as this call
arc58_rekeyTo:
	proto 2 0

	// examples/arc58/arc58.algo.ts:150
	// verifyAppCallTxn(this.txn, { sender: this.admin.value })
	// verify sender
	txn Sender
	byte 0x61 // "a"
	app_global_get
	==

	// transaction verification failed: {"txn":"this.txn","field":"sender","expected":"this.admin.value"}
	assert

	// examples/arc58/arc58.algo.ts:152
	// sendPayment({
	//       sender: this.controlledAddress.value,
	//       receiver: addr,
	//       rekeyTo: addr,
	//       note: 'rekeying abstracted account',
	//     })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// examples/arc58/arc58.algo.ts:153
	// sender: this.controlledAddress.value
	byte 0x63 // "c"
	app_global_get
	itxn_field Sender

	// examples/arc58/arc58.algo.ts:154
	// receiver: addr
	frame_dig -1 // addr: Address
	itxn_field Receiver

	// examples/arc58/arc58.algo.ts:155
	// rekeyTo: addr
	frame_dig -1 // addr: Address
	itxn_field RekeyTo

	// examples/arc58/arc58.algo.ts:156
	// note: 'rekeying abstracted account'
	pushbytes 0x72656b6579696e672061627374726163746564206163636f756e74 // "rekeying abstracted account"
	itxn_field Note

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// *if2_condition
	// examples/arc58/arc58.algo.ts:159
	// flash
	frame_dig -2 // flash: boolean
	bz *if2_end

	// *if2_consequent
	// examples/arc58/arc58.algo.ts:159
	// this.verifyRekeyToAbstractedAccount()
	callsub verifyRekeyToAbstractedAccount

*if2_end:
	retsub

// pluginCallAllowed(app: AppID, caller: Address): boolean
pluginCallAllowed:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/arc58/arc58.algo.ts:163
	// key: PluginsKey = { application: app, allowedCaller: caller }
	frame_dig -1 // app: AppID
	itob
	frame_dig -2 // caller: Address
	concat
	frame_bury 0 // key: PluginsKey

	// examples/arc58/arc58.algo.ts:165
	// return (
	//       this.plugins(key).exists &&
	//       this.plugins(key).value.lastValidRound >= globals.round &&
	//       globals.round - this.plugins(key).value.lastCalled >= this.plugins(key).value.cooldown
	//     );
	byte 0x70 // "p"
	frame_dig 0 // key: PluginsKey
	concat
	box_len
	swap
	pop
	dup
	bz *skip_and5
	byte 0x70 // "p"
	frame_dig 0 // key: PluginsKey
	concat
	box_get

	// box value does not exist: this.plugins(key).value
	assert
	store 255 // full array
	load 255 // full array
	extract 0 8
	btoi
	global Round
	>=
	&&

*skip_and5:
	dup
	bz *skip_and6
	global Round
	byte 0x70 // "p"
	frame_dig 0 // key: PluginsKey
	concat
	box_get

	// box value does not exist: this.plugins(key).value
	assert
	store 255 // full array
	load 255 // full array
	extract 16 8
	btoi
	-
	byte 0x70 // "p"
	frame_dig 0 // key: PluginsKey
	concat
	box_get

	// box value does not exist: this.plugins(key).value
	assert
	store 255 // full array
	load 255 // full array
	extract 8 8
	btoi
	>=
	&&

*skip_and6:
	// set the subroutine return value
	frame_bury 0
	retsub

// arc58_rekeyToPlugin(uint64)void
*abi_route_arc58_rekeyToPlugin:
	// plugin: uint64
	txna ApplicationArgs 1
	btoi

	// execute arc58_rekeyToPlugin(uint64)void
	callsub arc58_rekeyToPlugin
	int 1
	return

// arc58_rekeyToPlugin(plugin: AppID): void
//
// Temporarily rekey to an approved plugin app address
//
// @param plugin The app to rekey to
arc58_rekeyToPlugin:
	proto 1 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/arc58/arc58.algo.ts:178
	// globalAllowed = this.pluginCallAllowed(plugin, Address.zeroAddress)
	global ZeroAddress
	frame_dig -1 // plugin: AppID
	callsub pluginCallAllowed
	frame_bury 0 // globalAllowed: bool

	// *if3_condition
	// examples/arc58/arc58.algo.ts:180
	// !globalAllowed
	frame_dig 0 // globalAllowed: bool
	!
	bz *if3_end

	// *if3_consequent
	// examples/arc58/arc58.algo.ts:181
	// assert(this.pluginCallAllowed(plugin, this.txn.sender), 'This sender is not allowed to trigger this plugin')
	txn Sender
	frame_dig -1 // plugin: AppID
	callsub pluginCallAllowed

	// This sender is not allowed to trigger this plugin
	assert

*if3_end:
	// examples/arc58/arc58.algo.ts:183
	// sendPayment({
	//       sender: this.controlledAddress.value,
	//       receiver: this.controlledAddress.value,
	//       rekeyTo: plugin.address,
	//       note: 'rekeying to plugin app',
	//     })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// examples/arc58/arc58.algo.ts:184
	// sender: this.controlledAddress.value
	byte 0x63 // "c"
	app_global_get
	itxn_field Sender

	// examples/arc58/arc58.algo.ts:185
	// receiver: this.controlledAddress.value
	byte 0x63 // "c"
	app_global_get
	itxn_field Receiver

	// examples/arc58/arc58.algo.ts:186
	// rekeyTo: plugin.address
	frame_dig -1 // plugin: AppID
	app_params_get AppAddress
	pop
	itxn_field RekeyTo

	// examples/arc58/arc58.algo.ts:187
	// note: 'rekeying to plugin app'
	pushbytes 0x72656b6579696e6720746f20706c7567696e20617070 // "rekeying to plugin app"
	itxn_field Note

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/arc58/arc58.algo.ts:190
	// this.plugins({
	//       application: plugin,
	//       allowedCaller: globalAllowed ? Address.zeroAddress : this.txn.sender,
	//     }).value.lastCalled = globals.round
	byte 0x70 // "p"
	frame_dig -1 // plugin: AppID
	itob
	frame_dig 0 // globalAllowed: bool
	bz *ternary3_false
	global ZeroAddress
	b *ternary3_end

*ternary3_false:
	txn Sender

*ternary3_end:
	concat
	concat
	box_get

	// box value does not exist: this.plugins({ application: plugin, allowedCaller: globalAllowed ? Address.zeroAddress : this.txn.sender, }).value
	assert
	store 255 // full array
	load 255 // full array
	pushint 16
	global Round
	itob
	byte 0x70 // "p"
	frame_dig -1 // plugin: AppID
	itob
	frame_dig 0 // globalAllowed: bool
	bz *ternary5_false
	global ZeroAddress
	b *ternary5_end

*ternary5_false:
	txn Sender

*ternary5_end:
	concat
	concat
	cover 2
	box_replace

	// examples/arc58/arc58.algo.ts:195
	// this.verifyRekeyToAbstractedAccount()
	callsub verifyRekeyToAbstractedAccount
	retsub

// arc58_rekeyToNamedPlugin(string)void
*abi_route_arc58_rekeyToNamedPlugin:
	// name: string
	txna ApplicationArgs 1
	extract 2 0

	// execute arc58_rekeyToNamedPlugin(string)void
	callsub arc58_rekeyToNamedPlugin
	int 1
	return

// arc58_rekeyToNamedPlugin(name: string): void
//
// Temporarily rekey to a named plugin app address
//
// @param name The name of the plugin to rekey to
arc58_rekeyToNamedPlugin:
	proto 1 0

	// examples/arc58/arc58.algo.ts:204
	// this.arc58_rekeyToPlugin(this.namedPlugins(name).value.application)
	int 0
	pushint 8
	byte 0x6e // "n"
	frame_dig -1 // name: string
	concat
	cover 2
	box_extract
	btoi
	callsub arc58_rekeyToPlugin
	retsub

// arc58_addPlugin(uint64,address,uint64,uint64,bool)void
*abi_route_arc58_addPlugin:
	// adminPrivileges: bool
	txna ApplicationArgs 5
	dup
	len
	int 1
	==

	// argument 0 (adminPrivileges) for arc58_addPlugin must be a bool
	assert
	int 0
	getbit

	// cooldown: uint64
	txna ApplicationArgs 4
	btoi

	// lastValidRound: uint64
	txna ApplicationArgs 3
	btoi

	// allowedCaller: address
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 3 (allowedCaller) for arc58_addPlugin must be a address
	assert

	// app: uint64
	txna ApplicationArgs 1
	btoi

	// execute arc58_addPlugin(uint64,address,uint64,uint64,bool)void
	callsub arc58_addPlugin
	int 1
	return

// arc58_addPlugin(app: AppID, allowedCaller: Address, lastValidRound: uint64, cooldown: uint64, adminPrivileges: boolean): void
//
// Add an app to the list of approved plugins
//
// @param app The app to add
// @param allowedCaller The address of that's allowed to call the app
// or the global zero address for all addresses
// @param lastValidRound The round when the permission expires
// @param cooldown  The number of rounds that must pass before the plugin can be called again
// @param adminPrivileges Whether the plugin has permissions to change the admin account
arc58_addPlugin:
	proto 5 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/arc58/arc58.algo.ts:224
	// verifyTxn(this.txn, { sender: this.admin.value })
	// verify sender
	txn Sender
	byte 0x61 // "a"
	app_global_get
	==

	// transaction verification failed: {"txn":"this.txn","field":"sender","expected":"this.admin.value"}
	assert

	// examples/arc58/arc58.algo.ts:225
	// key: PluginsKey = { application: app, allowedCaller: allowedCaller }
	frame_dig -1 // app: AppID
	itob
	frame_dig -2 // allowedCaller: Address
	concat
	frame_bury 0 // key: PluginsKey

	// examples/arc58/arc58.algo.ts:226
	// this.plugins(key).value = {
	//       lastValidRound: lastValidRound,
	//       cooldown: cooldown,
	//       lastCalled: 0,
	//       adminPrivileges: adminPrivileges,
	//     }
	byte 0x70 // "p"
	frame_dig 0 // key: PluginsKey
	concat
	frame_dig -3 // lastValidRound: uint64
	itob
	frame_dig -4 // cooldown: uint64
	itob
	concat
	byte 0x0000000000000000
	concat
	byte 0x00
	int 0
	frame_dig -5 // adminPrivileges: boolean
	setbit
	concat
	box_put
	retsub

// arc58_removePlugin(uint64,address)void
*abi_route_arc58_removePlugin:
	// allowedCaller: address
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (allowedCaller) for arc58_removePlugin must be a address
	assert

	// app: uint64
	txna ApplicationArgs 1
	btoi

	// execute arc58_removePlugin(uint64,address)void
	callsub arc58_removePlugin
	int 1
	return

// arc58_removePlugin(app: AppID, allowedCaller: Address): void
//
// Remove an app from the list of approved plugins
//
// @param app The app to remove
arc58_removePlugin:
	proto 2 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/arc58/arc58.algo.ts:240
	// verifyTxn(this.txn, { sender: this.admin.value })
	// verify sender
	txn Sender
	byte 0x61 // "a"
	app_global_get
	==

	// transaction verification failed: {"txn":"this.txn","field":"sender","expected":"this.admin.value"}
	assert

	// examples/arc58/arc58.algo.ts:242
	// key: PluginsKey = { application: app, allowedCaller: allowedCaller }
	frame_dig -1 // app: AppID
	itob
	frame_dig -2 // allowedCaller: Address
	concat
	frame_bury 0 // key: PluginsKey

	// examples/arc58/arc58.algo.ts:243
	// this.plugins(key).delete()
	byte 0x70 // "p"
	frame_dig 0 // key: PluginsKey
	concat
	box_del
	retsub

// arc58_addNamedPlugin(string,uint64,address,uint64,uint64,bool)void
*abi_route_arc58_addNamedPlugin:
	// adminPrivileges: bool
	txna ApplicationArgs 6
	dup
	len
	int 1
	==

	// argument 0 (adminPrivileges) for arc58_addNamedPlugin must be a bool
	assert
	int 0
	getbit

	// cooldown: uint64
	txna ApplicationArgs 5
	btoi

	// lastValidRound: uint64
	txna ApplicationArgs 4
	btoi

	// allowedCaller: address
	txna ApplicationArgs 3
	dup
	len
	int 32
	==

	// argument 3 (allowedCaller) for arc58_addNamedPlugin must be a address
	assert

	// app: uint64
	txna ApplicationArgs 2
	btoi

	// name: string
	txna ApplicationArgs 1
	extract 2 0

	// execute arc58_addNamedPlugin(string,uint64,address,uint64,uint64,bool)void
	callsub arc58_addNamedPlugin
	int 1
	return

// arc58_addNamedPlugin(name: string, app: AppID, allowedCaller: Address, lastValidRound: uint64, cooldown: uint64, adminPrivileges: boolean): void
//
// Add a named plugin
//
// @param app The plugin app
// @param name The plugin name
// @param allowedCaller The address of that's allowed to call the app
// or the global zero address for all addresses
// @param lastValidRound The round when the permission expires
// @param cooldown  The number of rounds that must pass before the plugin can be called again
// @param adminPrivileges Whether the plugin has permissions to change the admin account
arc58_addNamedPlugin:
	proto 6 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/arc58/arc58.algo.ts:265
	// verifyTxn(this.txn, { sender: this.admin.value })
	// verify sender
	txn Sender
	byte 0x61 // "a"
	app_global_get
	==

	// transaction verification failed: {"txn":"this.txn","field":"sender","expected":"this.admin.value"}
	assert

	// examples/arc58/arc58.algo.ts:266
	// assert(!this.namedPlugins(name).exists)
	byte 0x6e // "n"
	frame_dig -1 // name: string
	concat
	box_len
	swap
	pop
	!
	assert

	// examples/arc58/arc58.algo.ts:268
	// key: PluginsKey = { application: app, allowedCaller: allowedCaller }
	frame_dig -2 // app: AppID
	itob
	frame_dig -3 // allowedCaller: Address
	concat
	frame_bury 0 // key: PluginsKey

	// examples/arc58/arc58.algo.ts:269
	// this.namedPlugins(name).value = key
	byte 0x6e // "n"
	frame_dig -1 // name: string
	concat
	frame_dig 0 // key: PluginsKey
	box_put

	// examples/arc58/arc58.algo.ts:270
	// this.plugins(key).value = {
	//       lastValidRound: lastValidRound,
	//       cooldown: cooldown,
	//       lastCalled: 0,
	//       adminPrivileges: adminPrivileges,
	//     }
	byte 0x70 // "p"
	frame_dig 0 // key: PluginsKey
	concat
	frame_dig -4 // lastValidRound: uint64
	itob
	frame_dig -5 // cooldown: uint64
	itob
	concat
	byte 0x0000000000000000
	concat
	byte 0x00
	int 0
	frame_dig -6 // adminPrivileges: boolean
	setbit
	concat
	box_put
	retsub

// arc58_removeNamedPlugin(string)void
*abi_route_arc58_removeNamedPlugin:
	// name: string
	txna ApplicationArgs 1
	extract 2 0

	// execute arc58_removeNamedPlugin(string)void
	callsub arc58_removeNamedPlugin
	int 1
	return

// arc58_removeNamedPlugin(name: string): void
//
// Remove a named plugin
//
// @param name The plugin name
arc58_removeNamedPlugin:
	proto 1 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/arc58/arc58.algo.ts:284
	// verifyTxn(this.txn, { sender: this.admin.value })
	// verify sender
	txn Sender
	byte 0x61 // "a"
	app_global_get
	==

	// transaction verification failed: {"txn":"this.txn","field":"sender","expected":"this.admin.value"}
	assert

	// examples/arc58/arc58.algo.ts:286
	// app = this.namedPlugins(name).value
	byte 0x6e // "n"
	frame_dig -1 // name: string
	concat
	frame_bury 0 // storage key//app

	// examples/arc58/arc58.algo.ts:287
	// this.namedPlugins(name).delete()
	byte 0x6e // "n"
	frame_dig -1 // name: string
	concat
	box_del

	// examples/arc58/arc58.algo.ts:288
	// this.plugins(app).delete()
	byte 0x70 // "p"
	frame_dig 0 // storage key//app
	box_get

	// box value does not exist: this.namedPlugins(name).value
	assert
	concat
	box_del
	retsub

*create_NoOp:
	pushbytes 0xb4c77d71 // method "createApplication(address,address)void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0xd24b7556 // method "arc58_changeAdmin(address)void"
	pushbytes 0x5fa449c6 // method "arc58_pluginChangeAdmin(uint64,address,address)void"
	pushbytes 0x13bc44e4 // method "arc58_getAdmin()address"
	byte 0x0f885493 // method "arc58_verifyAuthAddr()void"
	pushbytes 0xc95a5d3d // method "arc58_rekeyTo(address,bool)void"
	pushbytes 0x7c766ddc // method "arc58_rekeyToPlugin(uint64)void"
	pushbytes 0x56f28b58 // method "arc58_rekeyToNamedPlugin(string)void"
	pushbytes 0xd12dcb61 // method "arc58_addPlugin(uint64,address,uint64,uint64,bool)void"
	pushbytes 0x4d372355 // method "arc58_removePlugin(uint64,address)void"
	pushbytes 0x8a72a750 // method "arc58_addNamedPlugin(string,uint64,address,uint64,uint64,bool)void"
	pushbytes 0xe350b9d4 // method "arc58_removeNamedPlugin(string)void"
	txna ApplicationArgs 0
	match *abi_route_arc58_changeAdmin *abi_route_arc58_pluginChangeAdmin *abi_route_arc58_getAdmin *abi_route_arc58_verifyAuthAddr *abi_route_arc58_rekeyTo *abi_route_arc58_rekeyToPlugin *abi_route_arc58_rekeyToNamedPlugin *abi_route_arc58_addPlugin *abi_route_arc58_removePlugin *abi_route_arc58_addNamedPlugin *abi_route_arc58_removeNamedPlugin

	// this contract does not implement the given ABI method for call NoOp
	err", + "approval": "#pragma version 10
intcblock 1 0 32
bytecblock 0x70 0x61 0x63 0x0000000000000000 0x 0x0f885493 0x6e 0x00

// This TEAL was generated by TEALScript v0.105.0
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// verifyRekeyToAbstractedAccount(): void
//
// Ensure that by the end of the group the abstracted account has control of its address
verifyRekeyToAbstractedAccount:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// examples/arc58/arc58.algo.ts:45
	// rekeyedBack = false
	int 0
	frame_bury 0 // rekeyedBack: bool

	// examples/arc58/arc58.algo.ts:47
	// for (let i = this.txn.groupIndex; i < this.txnGroup.length; i += 1)
	txn GroupIndex
	frame_bury 1 // i: uint64

*for_0:
	// examples/arc58/arc58.algo.ts:47
	// i < this.txnGroup.length
	frame_dig 1 // i: uint64
	global GroupSize
	<
	bz *for_0_end

	// examples/arc58/arc58.algo.ts:48
	// txn = this.txnGroup[i]
	frame_dig 1 // i: uint64
	frame_bury 2 // txn: txn

	// *if0_condition
	// examples/arc58/arc58.algo.ts:51
	// txn.sender === this.controlledAddress.value && txn.rekeyTo === this.controlledAddress.value
	frame_dig 2 // txn: txn
	gtxns Sender
	byte 0x63 // "c"
	app_global_get
	==
	dup
	bz *skip_and0
	frame_dig 2 // txn: txn
	gtxns RekeyTo
	byte 0x63 // "c"
	app_global_get
	==
	&&

*skip_and0:
	bz *if0_end

	// *if0_consequent
	// examples/arc58/arc58.algo.ts:52
	// rekeyedBack = true
	int 1
	frame_bury 0 // rekeyedBack: bool
	b *for_0_end

*if0_end:
	// *if1_condition
	// examples/arc58/arc58.algo.ts:58
	// txn.typeEnum === TransactionType.ApplicationCall &&
	//         txn.applicationID === this.app &&
	//         txn.numAppArgs === 1 &&
	//         txn.applicationArgs[0] === method('arc58_verifyAuthAddr()void')
	frame_dig 2 // txn: txn
	gtxns TypeEnum
	pushint 6 // appl
	==
	dup
	bz *skip_and1
	frame_dig 2 // txn: txn
	gtxns ApplicationID
	txna Applications 0
	==
	&&

*skip_and1:
	dup
	bz *skip_and2
	frame_dig 2 // txn: txn
	gtxns NumAppArgs
	int 1
	==
	&&

*skip_and2:
	dup
	bz *skip_and3
	frame_dig 2 // txn: txn
	gtxns ApplicationArgs 0
	byte 0x0f885493 // method "arc58_verifyAuthAddr()void"
	==
	&&

*skip_and3:
	bz *if1_end

	// *if1_consequent
	// examples/arc58/arc58.algo.ts:63
	// rekeyedBack = true
	int 1
	frame_bury 0 // rekeyedBack: bool
	b *for_0_end

*if1_end:

*for_0_continue:
	// examples/arc58/arc58.algo.ts:47
	// i += 1
	frame_dig 1 // i: uint64
	int 1
	+
	frame_bury 1 // i: uint64
	b *for_0

*for_0_end:
	// examples/arc58/arc58.algo.ts:68
	// assert(rekeyedBack)
	frame_dig 0 // rekeyedBack: bool
	assert
	retsub

// getAuthAddr(): Address
//
// What the value of this.address.value.authAddr should be when this.controlledAddress
// is able to be controlled by this app. It will either be this.app.address or zeroAddress
getAuthAddr:
	proto 0 1

	// examples/arc58/arc58.algo.ts:76
	// return this.controlledAddress.value === this.app.address ? Address.zeroAddress : this.app.address;
	byte 0x63 // "c"
	app_global_get
	global CurrentApplicationAddress
	==
	bz *ternary0_false
	global ZeroAddress
	b *ternary0_end

*ternary0_false:
	global CurrentApplicationAddress

*ternary0_end:
	retsub

// createApplication(address,address)void
*abi_route_createApplication:
	// admin: address
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (admin) for createApplication must be a address
	assert

	// controlledAddress: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (controlledAddress) for createApplication must be a address
	assert

	// execute createApplication(address,address)void
	callsub createApplication
	int 1
	return

// createApplication(controlledAddress: Address, admin: Address): void
//
// Create an abstracted account application.
// This is not part of ARC58 and implementation specific.
//
// @param controlledAddress The address of the abstracted account. If zeroAddress, then the address of the contract account will be used
// @param admin The admin for this app
createApplication:
	proto 2 0

	// examples/arc58/arc58.algo.ts:87
	// verifyAppCallTxn(this.txn, {
	//       sender: { includedIn: [controlledAddress, admin] },
	//     })
	// verify sender
	txn Sender
	frame_dig -1 // controlledAddress: Address
	==
	txn Sender
	frame_dig -2 // admin: Address
	==
	||

	// transaction verification failed: {"txn":{"txnText":"this.txn"},"field":"sender","condition":"includedIn","expected":"[controlledAddress, admin]"}
	assert

	// examples/arc58/arc58.algo.ts:91
	// assert(admin !== controlledAddress)
	frame_dig -2 // admin: Address
	frame_dig -1 // controlledAddress: Address
	!=
	assert

	// examples/arc58/arc58.algo.ts:93
	// this.admin.value = admin
	byte 0x61 // "a"
	frame_dig -2 // admin: Address
	app_global_put

	// examples/arc58/arc58.algo.ts:94
	// this.controlledAddress.value = controlledAddress === Address.zeroAddress ? this.app.address : controlledAddress
	byte 0x63 // "c"
	frame_dig -1 // controlledAddress: Address
	global ZeroAddress
	==
	bz *ternary1_false
	global CurrentApplicationAddress
	b *ternary1_end

*ternary1_false:
	frame_dig -1 // controlledAddress: Address

*ternary1_end:
	app_global_put
	retsub

// arc58_changeAdmin(address)void
*abi_route_arc58_changeAdmin:
	// newAdmin: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (newAdmin) for arc58_changeAdmin must be a address
	assert

	// execute arc58_changeAdmin(address)void
	callsub arc58_changeAdmin
	int 1
	return

// arc58_changeAdmin(newAdmin: Address): void
//
// Attempt to change the admin for this app. Some implementations MAY not support this.
//
// @param newAdmin The new admin
arc58_changeAdmin:
	proto 1 0

	// examples/arc58/arc58.algo.ts:103
	// verifyTxn(this.txn, { sender: this.admin.value })
	// verify sender
	txn Sender
	byte 0x61 // "a"
	app_global_get
	==

	// transaction verification failed: {"txn":"this.txn","field":"sender","expected":"this.admin.value"}
	assert

	// examples/arc58/arc58.algo.ts:104
	// this.admin.value = newAdmin
	byte 0x61 // "a"
	frame_dig -1 // newAdmin: Address
	app_global_put
	retsub

// arc58_pluginChangeAdmin(uint64,address,address)void
*abi_route_arc58_pluginChangeAdmin:
	// newAdmin: address
	txna ApplicationArgs 3
	dup
	len
	int 32
	==

	// argument 0 (newAdmin) for arc58_pluginChangeAdmin must be a address
	assert

	// allowedCaller: address
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 1 (allowedCaller) for arc58_pluginChangeAdmin must be a address
	assert

	// plugin: uint64
	txna ApplicationArgs 1
	btoi

	// execute arc58_pluginChangeAdmin(uint64,address,address)void
	callsub arc58_pluginChangeAdmin
	int 1
	return

// arc58_pluginChangeAdmin(plugin: AppID, allowedCaller: Address, newAdmin: Address): void
//
// Attempt to change the admin via plugin.
//
// @param plugin The app calling the plugin
// @param allowedCaller The address that triggered the plugin
// @param newAdmin The new admin
arc58_pluginChangeAdmin:
	proto 3 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/arc58/arc58.algo.ts:116
	// verifyTxn(this.txn, { sender: plugin.address })
	// verify sender
	txn Sender
	frame_dig -1 // plugin: AppID
	app_params_get AppAddress
	pop
	==

	// transaction verification failed: {"txn":"this.txn","field":"sender","expected":"plugin.address"}
	assert

	// examples/arc58/arc58.algo.ts:117
	// assert(this.controlledAddress.value.authAddr === plugin.address, 'This plugin is not in control of the account')
	byte 0x63 // "c"
	app_global_get
	acct_params_get AcctAuthAddr
	pop
	frame_dig -1 // plugin: AppID
	app_params_get AppAddress
	pop
	==

	// This plugin is not in control of the account
	assert

	// examples/arc58/arc58.algo.ts:119
	// key: PluginsKey = { application: plugin, allowedCaller: allowedCaller }
	frame_dig -1 // plugin: AppID
	itob
	frame_dig -2 // allowedCaller: Address
	concat
	frame_bury 0 // key: PluginsKey

	// examples/arc58/arc58.algo.ts:120
	// assert(
	//       this.plugins(key).exists && this.plugins(key).value.adminPrivileges,
	//       'This plugin does not have admin privileges'
	//     )
	byte 0x70 // "p"
	frame_dig 0 // key: PluginsKey
	concat
	box_len
	swap
	pop
	dup
	bz *skip_and4
	byte 0x70 // "p"
	frame_dig 0 // key: PluginsKey
	concat
	box_get

	// box value does not exist: this.plugins(key).value
	assert
	store 255 // full array
	load 255 // full array
	pushint 192
	getbit
	&&

*skip_and4:
	// This plugin does not have admin privileges
	assert

	// examples/arc58/arc58.algo.ts:125
	// this.admin.value = newAdmin
	byte 0x61 // "a"
	frame_dig -3 // newAdmin: Address
	app_global_put
	retsub

// arc58_getAdmin()address
*abi_route_arc58_getAdmin:
	// The ABI return prefix
	pushbytes 0x151f7c75

	// execute arc58_getAdmin()address
	callsub arc58_getAdmin
	concat
	log
	int 1
	return

// arc58_getAdmin(): Address
//
// Get the admin of this app. This method SHOULD always be used rather than reading directly from state
// because different implementations may have different ways of determining the admin.
arc58_getAdmin:
	proto 0 1

	// examples/arc58/arc58.algo.ts:133
	// return this.admin.value;
	byte 0x61 // "a"
	app_global_get
	retsub

// arc58_verifyAuthAddr()void
*abi_route_arc58_verifyAuthAddr:
	// execute arc58_verifyAuthAddr()void
	callsub arc58_verifyAuthAddr
	int 1
	return

// arc58_verifyAuthAddr(): void
//
// Verify the abstracted account is rekeyed to this app
arc58_verifyAuthAddr:
	proto 0 0

	// examples/arc58/arc58.algo.ts:140
	// assert(this.controlledAddress.value.authAddr === this.getAuthAddr())
	byte 0x63 // "c"
	app_global_get
	acct_params_get AcctAuthAddr
	pop
	callsub getAuthAddr
	==
	assert
	retsub

// arc58_rekeyTo(address,bool)void
*abi_route_arc58_rekeyTo:
	// flash: bool
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 0 (flash) for arc58_rekeyTo must be a bool
	assert
	int 0
	getbit

	// addr: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (addr) for arc58_rekeyTo must be a address
	assert

	// execute arc58_rekeyTo(address,bool)void
	callsub arc58_rekeyTo
	int 1
	return

// arc58_rekeyTo(addr: Address, flash: boolean): void
//
// Rekey the abstracted account to another address. Primarily useful for rekeying to an EOA.
//
// @param addr The address to rekey to
// @param flash Whether or not this should be a flash rekey. If true, the rekey back to the app address must done in the same txn group as this call
arc58_rekeyTo:
	proto 2 0

	// examples/arc58/arc58.algo.ts:150
	// verifyAppCallTxn(this.txn, { sender: this.admin.value })
	// verify sender
	txn Sender
	byte 0x61 // "a"
	app_global_get
	==

	// transaction verification failed: {"txn":"this.txn","field":"sender","expected":"this.admin.value"}
	assert

	// examples/arc58/arc58.algo.ts:152
	// sendPayment({
	//       sender: this.controlledAddress.value,
	//       receiver: addr,
	//       rekeyTo: addr,
	//       note: 'rekeying abstracted account',
	//     })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// examples/arc58/arc58.algo.ts:153
	// sender: this.controlledAddress.value
	byte 0x63 // "c"
	app_global_get
	itxn_field Sender

	// examples/arc58/arc58.algo.ts:154
	// receiver: addr
	frame_dig -1 // addr: Address
	itxn_field Receiver

	// examples/arc58/arc58.algo.ts:155
	// rekeyTo: addr
	frame_dig -1 // addr: Address
	itxn_field RekeyTo

	// examples/arc58/arc58.algo.ts:156
	// note: 'rekeying abstracted account'
	pushbytes 0x72656b6579696e672061627374726163746564206163636f756e74 // "rekeying abstracted account"
	itxn_field Note

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// *if2_condition
	// examples/arc58/arc58.algo.ts:159
	// flash
	frame_dig -2 // flash: boolean
	bz *if2_end

	// *if2_consequent
	// examples/arc58/arc58.algo.ts:159
	// this.verifyRekeyToAbstractedAccount()
	callsub verifyRekeyToAbstractedAccount

*if2_end:
	retsub

// pluginCallAllowed(app: AppID, caller: Address): boolean
pluginCallAllowed:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/arc58/arc58.algo.ts:163
	// key: PluginsKey = { application: app, allowedCaller: caller }
	frame_dig -1 // app: AppID
	itob
	frame_dig -2 // caller: Address
	concat
	frame_bury 0 // key: PluginsKey

	// examples/arc58/arc58.algo.ts:165
	// return (
	//       this.plugins(key).exists &&
	//       this.plugins(key).value.lastValidRound >= globals.round &&
	//       globals.round - this.plugins(key).value.lastCalled >= this.plugins(key).value.cooldown
	//     );
	byte 0x70 // "p"
	frame_dig 0 // key: PluginsKey
	concat
	box_len
	swap
	pop
	dup
	bz *skip_and5
	byte 0x70 // "p"
	frame_dig 0 // key: PluginsKey
	concat
	box_get

	// box value does not exist: this.plugins(key).value
	assert
	store 255 // full array
	load 255 // full array
	extract 0 8
	btoi
	global Round
	>=
	&&

*skip_and5:
	dup
	bz *skip_and6
	global Round
	byte 0x70 // "p"
	frame_dig 0 // key: PluginsKey
	concat
	box_get

	// box value does not exist: this.plugins(key).value
	assert
	store 255 // full array
	load 255 // full array
	extract 16 8
	btoi
	-
	byte 0x70 // "p"
	frame_dig 0 // key: PluginsKey
	concat
	box_get

	// box value does not exist: this.plugins(key).value
	assert
	store 255 // full array
	load 255 // full array
	extract 8 8
	btoi
	>=
	&&

*skip_and6:
	// set the subroutine return value
	frame_bury 0
	retsub

// arc58_rekeyToPlugin(uint64)void
*abi_route_arc58_rekeyToPlugin:
	// plugin: uint64
	txna ApplicationArgs 1
	btoi

	// execute arc58_rekeyToPlugin(uint64)void
	callsub arc58_rekeyToPlugin
	int 1
	return

// arc58_rekeyToPlugin(plugin: AppID): void
//
// Temporarily rekey to an approved plugin app address
//
// @param plugin The app to rekey to
arc58_rekeyToPlugin:
	proto 1 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/arc58/arc58.algo.ts:178
	// globalAllowed = this.pluginCallAllowed(plugin, Address.zeroAddress)
	global ZeroAddress
	frame_dig -1 // plugin: AppID
	callsub pluginCallAllowed
	frame_bury 0 // globalAllowed: bool

	// *if3_condition
	// examples/arc58/arc58.algo.ts:180
	// !globalAllowed
	frame_dig 0 // globalAllowed: bool
	!
	bz *if3_end

	// *if3_consequent
	// examples/arc58/arc58.algo.ts:181
	// assert(this.pluginCallAllowed(plugin, this.txn.sender), 'This sender is not allowed to trigger this plugin')
	txn Sender
	frame_dig -1 // plugin: AppID
	callsub pluginCallAllowed

	// This sender is not allowed to trigger this plugin
	assert

*if3_end:
	// examples/arc58/arc58.algo.ts:183
	// sendPayment({
	//       sender: this.controlledAddress.value,
	//       receiver: this.controlledAddress.value,
	//       rekeyTo: plugin.address,
	//       note: 'rekeying to plugin app',
	//     })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// examples/arc58/arc58.algo.ts:184
	// sender: this.controlledAddress.value
	byte 0x63 // "c"
	app_global_get
	itxn_field Sender

	// examples/arc58/arc58.algo.ts:185
	// receiver: this.controlledAddress.value
	byte 0x63 // "c"
	app_global_get
	itxn_field Receiver

	// examples/arc58/arc58.algo.ts:186
	// rekeyTo: plugin.address
	frame_dig -1 // plugin: AppID
	app_params_get AppAddress
	pop
	itxn_field RekeyTo

	// examples/arc58/arc58.algo.ts:187
	// note: 'rekeying to plugin app'
	pushbytes 0x72656b6579696e6720746f20706c7567696e20617070 // "rekeying to plugin app"
	itxn_field Note

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/arc58/arc58.algo.ts:190
	// this.plugins({
	//       application: plugin,
	//       allowedCaller: globalAllowed ? Address.zeroAddress : this.txn.sender,
	//     }).value.lastCalled = globals.round
	byte 0x70 // "p"
	frame_dig -1 // plugin: AppID
	itob
	frame_dig 0 // globalAllowed: bool
	bz *ternary3_false
	global ZeroAddress
	b *ternary3_end

*ternary3_false:
	txn Sender

*ternary3_end:
	concat
	concat
	box_get

	// box value does not exist: this.plugins({ application: plugin, allowedCaller: globalAllowed ? Address.zeroAddress : this.txn.sender, }).value
	assert
	store 255 // full array
	load 255 // full array
	pushint 16
	global Round
	itob
	byte 0x70 // "p"
	frame_dig -1 // plugin: AppID
	itob
	frame_dig 0 // globalAllowed: bool
	bz *ternary5_false
	global ZeroAddress
	b *ternary5_end

*ternary5_false:
	txn Sender

*ternary5_end:
	concat
	concat
	cover 2
	box_replace

	// examples/arc58/arc58.algo.ts:195
	// this.verifyRekeyToAbstractedAccount()
	callsub verifyRekeyToAbstractedAccount
	retsub

// arc58_rekeyToNamedPlugin(string)void
*abi_route_arc58_rekeyToNamedPlugin:
	// name: string
	txna ApplicationArgs 1
	extract 2 0

	// execute arc58_rekeyToNamedPlugin(string)void
	callsub arc58_rekeyToNamedPlugin
	int 1
	return

// arc58_rekeyToNamedPlugin(name: string): void
//
// Temporarily rekey to a named plugin app address
//
// @param name The name of the plugin to rekey to
arc58_rekeyToNamedPlugin:
	proto 1 0

	// examples/arc58/arc58.algo.ts:204
	// this.arc58_rekeyToPlugin(this.namedPlugins(name).value.application)
	int 0
	pushint 8
	byte 0x6e // "n"
	frame_dig -1 // name: string
	concat
	cover 2
	box_extract
	btoi
	callsub arc58_rekeyToPlugin
	retsub

// arc58_addPlugin(uint64,address,uint64,uint64,bool)void
*abi_route_arc58_addPlugin:
	// adminPrivileges: bool
	txna ApplicationArgs 5
	dup
	len
	int 1
	==

	// argument 0 (adminPrivileges) for arc58_addPlugin must be a bool
	assert
	int 0
	getbit

	// cooldown: uint64
	txna ApplicationArgs 4
	btoi

	// lastValidRound: uint64
	txna ApplicationArgs 3
	btoi

	// allowedCaller: address
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 3 (allowedCaller) for arc58_addPlugin must be a address
	assert

	// app: uint64
	txna ApplicationArgs 1
	btoi

	// execute arc58_addPlugin(uint64,address,uint64,uint64,bool)void
	callsub arc58_addPlugin
	int 1
	return

// arc58_addPlugin(app: AppID, allowedCaller: Address, lastValidRound: uint64, cooldown: uint64, adminPrivileges: boolean): void
//
// Add an app to the list of approved plugins
//
// @param app The app to add
// @param allowedCaller The address of that's allowed to call the app
// or the global zero address for all addresses
// @param lastValidRound The round when the permission expires
// @param cooldown  The number of rounds that must pass before the plugin can be called again
// @param adminPrivileges Whether the plugin has permissions to change the admin account
arc58_addPlugin:
	proto 5 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/arc58/arc58.algo.ts:224
	// verifyTxn(this.txn, { sender: this.admin.value })
	// verify sender
	txn Sender
	byte 0x61 // "a"
	app_global_get
	==

	// transaction verification failed: {"txn":"this.txn","field":"sender","expected":"this.admin.value"}
	assert

	// examples/arc58/arc58.algo.ts:225
	// key: PluginsKey = { application: app, allowedCaller: allowedCaller }
	frame_dig -1 // app: AppID
	itob
	frame_dig -2 // allowedCaller: Address
	concat
	frame_bury 0 // key: PluginsKey

	// examples/arc58/arc58.algo.ts:226
	// this.plugins(key).value = {
	//       lastValidRound: lastValidRound,
	//       cooldown: cooldown,
	//       lastCalled: 0,
	//       adminPrivileges: adminPrivileges,
	//     }
	byte 0x70 // "p"
	frame_dig 0 // key: PluginsKey
	concat
	frame_dig -3 // lastValidRound: uint64
	itob
	frame_dig -4 // cooldown: uint64
	itob
	concat
	byte 0x0000000000000000
	concat
	byte 0x00
	int 0
	frame_dig -5 // adminPrivileges: boolean
	setbit
	concat
	box_put
	retsub

// arc58_removePlugin(uint64,address)void
*abi_route_arc58_removePlugin:
	// allowedCaller: address
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (allowedCaller) for arc58_removePlugin must be a address
	assert

	// app: uint64
	txna ApplicationArgs 1
	btoi

	// execute arc58_removePlugin(uint64,address)void
	callsub arc58_removePlugin
	int 1
	return

// arc58_removePlugin(app: AppID, allowedCaller: Address): void
//
// Remove an app from the list of approved plugins
//
// @param app The app to remove
arc58_removePlugin:
	proto 2 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/arc58/arc58.algo.ts:240
	// verifyTxn(this.txn, { sender: this.admin.value })
	// verify sender
	txn Sender
	byte 0x61 // "a"
	app_global_get
	==

	// transaction verification failed: {"txn":"this.txn","field":"sender","expected":"this.admin.value"}
	assert

	// examples/arc58/arc58.algo.ts:242
	// key: PluginsKey = { application: app, allowedCaller: allowedCaller }
	frame_dig -1 // app: AppID
	itob
	frame_dig -2 // allowedCaller: Address
	concat
	frame_bury 0 // key: PluginsKey

	// examples/arc58/arc58.algo.ts:243
	// this.plugins(key).delete()
	byte 0x70 // "p"
	frame_dig 0 // key: PluginsKey
	concat
	box_del
	retsub

// arc58_addNamedPlugin(string,uint64,address,uint64,uint64,bool)void
*abi_route_arc58_addNamedPlugin:
	// adminPrivileges: bool
	txna ApplicationArgs 6
	dup
	len
	int 1
	==

	// argument 0 (adminPrivileges) for arc58_addNamedPlugin must be a bool
	assert
	int 0
	getbit

	// cooldown: uint64
	txna ApplicationArgs 5
	btoi

	// lastValidRound: uint64
	txna ApplicationArgs 4
	btoi

	// allowedCaller: address
	txna ApplicationArgs 3
	dup
	len
	int 32
	==

	// argument 3 (allowedCaller) for arc58_addNamedPlugin must be a address
	assert

	// app: uint64
	txna ApplicationArgs 2
	btoi

	// name: string
	txna ApplicationArgs 1
	extract 2 0

	// execute arc58_addNamedPlugin(string,uint64,address,uint64,uint64,bool)void
	callsub arc58_addNamedPlugin
	int 1
	return

// arc58_addNamedPlugin(name: string, app: AppID, allowedCaller: Address, lastValidRound: uint64, cooldown: uint64, adminPrivileges: boolean): void
//
// Add a named plugin
//
// @param app The plugin app
// @param name The plugin name
// @param allowedCaller The address of that's allowed to call the app
// or the global zero address for all addresses
// @param lastValidRound The round when the permission expires
// @param cooldown  The number of rounds that must pass before the plugin can be called again
// @param adminPrivileges Whether the plugin has permissions to change the admin account
arc58_addNamedPlugin:
	proto 6 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/arc58/arc58.algo.ts:265
	// verifyTxn(this.txn, { sender: this.admin.value })
	// verify sender
	txn Sender
	byte 0x61 // "a"
	app_global_get
	==

	// transaction verification failed: {"txn":"this.txn","field":"sender","expected":"this.admin.value"}
	assert

	// examples/arc58/arc58.algo.ts:266
	// assert(!this.namedPlugins(name).exists)
	byte 0x6e // "n"
	frame_dig -1 // name: string
	concat
	box_len
	swap
	pop
	!
	assert

	// examples/arc58/arc58.algo.ts:268
	// key: PluginsKey = { application: app, allowedCaller: allowedCaller }
	frame_dig -2 // app: AppID
	itob
	frame_dig -3 // allowedCaller: Address
	concat
	frame_bury 0 // key: PluginsKey

	// examples/arc58/arc58.algo.ts:269
	// this.namedPlugins(name).value = key
	byte 0x6e // "n"
	frame_dig -1 // name: string
	concat
	frame_dig 0 // key: PluginsKey
	box_put

	// examples/arc58/arc58.algo.ts:270
	// this.plugins(key).value = {
	//       lastValidRound: lastValidRound,
	//       cooldown: cooldown,
	//       lastCalled: 0,
	//       adminPrivileges: adminPrivileges,
	//     }
	byte 0x70 // "p"
	frame_dig 0 // key: PluginsKey
	concat
	frame_dig -4 // lastValidRound: uint64
	itob
	frame_dig -5 // cooldown: uint64
	itob
	concat
	byte 0x0000000000000000
	concat
	byte 0x00
	int 0
	frame_dig -6 // adminPrivileges: boolean
	setbit
	concat
	box_put
	retsub

// arc58_removeNamedPlugin(string)void
*abi_route_arc58_removeNamedPlugin:
	// name: string
	txna ApplicationArgs 1
	extract 2 0

	// execute arc58_removeNamedPlugin(string)void
	callsub arc58_removeNamedPlugin
	int 1
	return

// arc58_removeNamedPlugin(name: string): void
//
// Remove a named plugin
//
// @param name The plugin name
arc58_removeNamedPlugin:
	proto 1 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/arc58/arc58.algo.ts:284
	// verifyTxn(this.txn, { sender: this.admin.value })
	// verify sender
	txn Sender
	byte 0x61 // "a"
	app_global_get
	==

	// transaction verification failed: {"txn":"this.txn","field":"sender","expected":"this.admin.value"}
	assert

	// examples/arc58/arc58.algo.ts:286
	// app = this.namedPlugins(name).value
	byte 0x6e // "n"
	frame_dig -1 // name: string
	concat
	frame_bury 0 // storage key//app

	// examples/arc58/arc58.algo.ts:287
	// this.namedPlugins(name).delete()
	byte 0x6e // "n"
	frame_dig -1 // name: string
	concat
	box_del

	// examples/arc58/arc58.algo.ts:288
	// this.plugins(app).delete()
	byte 0x70 // "p"
	frame_dig 0 // storage key//app
	box_get

	// box value does not exist: this.namedPlugins(name).value
	assert
	concat
	box_del
	retsub

*create_NoOp:
	pushbytes 0xb4c77d71 // method "createApplication(address,address)void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0xd24b7556 // method "arc58_changeAdmin(address)void"
	pushbytes 0x5fa449c6 // method "arc58_pluginChangeAdmin(uint64,address,address)void"
	pushbytes 0x13bc44e4 // method "arc58_getAdmin()address"
	byte 0x0f885493 // method "arc58_verifyAuthAddr()void"
	pushbytes 0xc95a5d3d // method "arc58_rekeyTo(address,bool)void"
	pushbytes 0x7c766ddc // method "arc58_rekeyToPlugin(uint64)void"
	pushbytes 0x56f28b58 // method "arc58_rekeyToNamedPlugin(string)void"
	pushbytes 0xd12dcb61 // method "arc58_addPlugin(uint64,address,uint64,uint64,bool)void"
	pushbytes 0x4d372355 // method "arc58_removePlugin(uint64,address)void"
	pushbytes 0x8a72a750 // method "arc58_addNamedPlugin(string,uint64,address,uint64,uint64,bool)void"
	pushbytes 0xe350b9d4 // method "arc58_removeNamedPlugin(string)void"
	txna ApplicationArgs 0
	match *abi_route_arc58_changeAdmin *abi_route_arc58_pluginChangeAdmin *abi_route_arc58_getAdmin *abi_route_arc58_verifyAuthAddr *abi_route_arc58_rekeyTo *abi_route_arc58_rekeyToPlugin *abi_route_arc58_rekeyToNamedPlugin *abi_route_arc58_addPlugin *abi_route_arc58_removePlugin *abi_route_arc58_addNamedPlugin *abi_route_arc58_removeNamedPlugin

	// this contract does not implement the given ABI method for call NoOp
	err", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/examples/arc58/artifacts/AbstractedAccount.arc56_draft.json b/examples/arc58/artifacts/AbstractedAccount.arc56_draft.json index 93557b5cd..a5255caae 100644 --- a/examples/arc58/artifacts/AbstractedAccount.arc56_draft.json +++ b/examples/arc58/artifacts/AbstractedAccount.arc56_draft.json @@ -5309,7 +5309,7 @@ } }, "source": { - "approval": "#pragma version 10
intcblock 1 0 32
bytecblock 0x70 0x61 0x63 0x0000000000000000 0x 0x0f885493 0x6e 0x00

// This TEAL was generated by TEALScript v0.104.1
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// verifyRekeyToAbstractedAccount(): void
//
// Ensure that by the end of the group the abstracted account has control of its address
verifyRekeyToAbstractedAccount:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// examples/arc58/arc58.algo.ts:45
	// rekeyedBack = false
	int 0
	frame_bury 0 // rekeyedBack: bool

	// examples/arc58/arc58.algo.ts:47
	// for (let i = this.txn.groupIndex; i < this.txnGroup.length; i += 1)
	txn GroupIndex
	frame_bury 1 // i: uint64

*for_0:
	// examples/arc58/arc58.algo.ts:47
	// i < this.txnGroup.length
	frame_dig 1 // i: uint64
	global GroupSize
	<
	bz *for_0_end

	// examples/arc58/arc58.algo.ts:48
	// txn = this.txnGroup[i]
	frame_dig 1 // i: uint64
	frame_bury 2 // txn: txn

	// *if0_condition
	// examples/arc58/arc58.algo.ts:51
	// txn.sender === this.controlledAddress.value && txn.rekeyTo === this.controlledAddress.value
	frame_dig 2 // txn: txn
	gtxns Sender
	byte 0x63 // "c"
	app_global_get
	==
	dup
	bz *skip_and0
	frame_dig 2 // txn: txn
	gtxns RekeyTo
	byte 0x63 // "c"
	app_global_get
	==
	&&

*skip_and0:
	bz *if0_end

	// *if0_consequent
	// examples/arc58/arc58.algo.ts:52
	// rekeyedBack = true
	int 1
	frame_bury 0 // rekeyedBack: bool
	b *for_0_end

*if0_end:
	// *if1_condition
	// examples/arc58/arc58.algo.ts:58
	// txn.typeEnum === TransactionType.ApplicationCall &&
	//         txn.applicationID === this.app &&
	//         txn.numAppArgs === 1 &&
	//         txn.applicationArgs[0] === method('arc58_verifyAuthAddr()void')
	frame_dig 2 // txn: txn
	gtxns TypeEnum
	pushint 6 // appl
	==
	dup
	bz *skip_and1
	frame_dig 2 // txn: txn
	gtxns ApplicationID
	txna Applications 0
	==
	&&

*skip_and1:
	dup
	bz *skip_and2
	frame_dig 2 // txn: txn
	gtxns NumAppArgs
	int 1
	==
	&&

*skip_and2:
	dup
	bz *skip_and3
	frame_dig 2 // txn: txn
	gtxns ApplicationArgs 0
	byte 0x0f885493 // method "arc58_verifyAuthAddr()void"
	==
	&&

*skip_and3:
	bz *if1_end

	// *if1_consequent
	// examples/arc58/arc58.algo.ts:63
	// rekeyedBack = true
	int 1
	frame_bury 0 // rekeyedBack: bool
	b *for_0_end

*if1_end:

*for_0_continue:
	// examples/arc58/arc58.algo.ts:47
	// i += 1
	frame_dig 1 // i: uint64
	int 1
	+
	frame_bury 1 // i: uint64
	b *for_0

*for_0_end:
	// examples/arc58/arc58.algo.ts:68
	// assert(rekeyedBack)
	frame_dig 0 // rekeyedBack: bool
	assert
	retsub

// getAuthAddr(): Address
//
// What the value of this.address.value.authAddr should be when this.controlledAddress
// is able to be controlled by this app. It will either be this.app.address or zeroAddress
getAuthAddr:
	proto 0 1

	// examples/arc58/arc58.algo.ts:76
	// return this.controlledAddress.value === this.app.address ? Address.zeroAddress : this.app.address;
	byte 0x63 // "c"
	app_global_get
	global CurrentApplicationAddress
	==
	bz *ternary0_false
	global ZeroAddress
	b *ternary0_end

*ternary0_false:
	global CurrentApplicationAddress

*ternary0_end:
	retsub

// createApplication(address,address)void
*abi_route_createApplication:
	// admin: address
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (admin) for createApplication must be a address
	assert

	// controlledAddress: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (controlledAddress) for createApplication must be a address
	assert

	// execute createApplication(address,address)void
	callsub createApplication
	int 1
	return

// createApplication(controlledAddress: Address, admin: Address): void
//
// Create an abstracted account application.
// This is not part of ARC58 and implementation specific.
//
// @param controlledAddress The address of the abstracted account. If zeroAddress, then the address of the contract account will be used
// @param admin The admin for this app
createApplication:
	proto 2 0

	// examples/arc58/arc58.algo.ts:87
	// verifyAppCallTxn(this.txn, {
	//       sender: { includedIn: [controlledAddress, admin] },
	//     })
	// verify sender
	txn Sender
	frame_dig -1 // controlledAddress: Address
	==
	txn Sender
	frame_dig -2 // admin: Address
	==
	||

	// transaction verification failed: {"txn":{"txnText":"this.txn"},"field":"sender","condition":"includedIn","expected":"[controlledAddress, admin]"}
	assert

	// examples/arc58/arc58.algo.ts:91
	// assert(admin !== controlledAddress)
	frame_dig -2 // admin: Address
	frame_dig -1 // controlledAddress: Address
	!=
	assert

	// examples/arc58/arc58.algo.ts:93
	// this.admin.value = admin
	byte 0x61 // "a"
	frame_dig -2 // admin: Address
	app_global_put

	// examples/arc58/arc58.algo.ts:94
	// this.controlledAddress.value = controlledAddress === Address.zeroAddress ? this.app.address : controlledAddress
	byte 0x63 // "c"
	frame_dig -1 // controlledAddress: Address
	global ZeroAddress
	==
	bz *ternary1_false
	global CurrentApplicationAddress
	b *ternary1_end

*ternary1_false:
	frame_dig -1 // controlledAddress: Address

*ternary1_end:
	app_global_put
	retsub

// arc58_changeAdmin(address)void
*abi_route_arc58_changeAdmin:
	// newAdmin: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (newAdmin) for arc58_changeAdmin must be a address
	assert

	// execute arc58_changeAdmin(address)void
	callsub arc58_changeAdmin
	int 1
	return

// arc58_changeAdmin(newAdmin: Address): void
//
// Attempt to change the admin for this app. Some implementations MAY not support this.
//
// @param newAdmin The new admin
arc58_changeAdmin:
	proto 1 0

	// examples/arc58/arc58.algo.ts:103
	// verifyTxn(this.txn, { sender: this.admin.value })
	// verify sender
	txn Sender
	byte 0x61 // "a"
	app_global_get
	==

	// transaction verification failed: {"txn":"this.txn","field":"sender","expected":"this.admin.value"}
	assert

	// examples/arc58/arc58.algo.ts:104
	// this.admin.value = newAdmin
	byte 0x61 // "a"
	frame_dig -1 // newAdmin: Address
	app_global_put
	retsub

// arc58_pluginChangeAdmin(uint64,address,address)void
*abi_route_arc58_pluginChangeAdmin:
	// newAdmin: address
	txna ApplicationArgs 3
	dup
	len
	int 32
	==

	// argument 0 (newAdmin) for arc58_pluginChangeAdmin must be a address
	assert

	// allowedCaller: address
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 1 (allowedCaller) for arc58_pluginChangeAdmin must be a address
	assert

	// plugin: uint64
	txna ApplicationArgs 1
	btoi

	// execute arc58_pluginChangeAdmin(uint64,address,address)void
	callsub arc58_pluginChangeAdmin
	int 1
	return

// arc58_pluginChangeAdmin(plugin: AppID, allowedCaller: Address, newAdmin: Address): void
//
// Attempt to change the admin via plugin.
//
// @param plugin The app calling the plugin
// @param allowedCaller The address that triggered the plugin
// @param newAdmin The new admin
arc58_pluginChangeAdmin:
	proto 3 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/arc58/arc58.algo.ts:116
	// verifyTxn(this.txn, { sender: plugin.address })
	// verify sender
	txn Sender
	frame_dig -1 // plugin: AppID
	app_params_get AppAddress
	pop
	==

	// transaction verification failed: {"txn":"this.txn","field":"sender","expected":"plugin.address"}
	assert

	// examples/arc58/arc58.algo.ts:117
	// assert(this.controlledAddress.value.authAddr === plugin.address, 'This plugin is not in control of the account')
	byte 0x63 // "c"
	app_global_get
	acct_params_get AcctAuthAddr
	pop
	frame_dig -1 // plugin: AppID
	app_params_get AppAddress
	pop
	==

	// This plugin is not in control of the account
	assert

	// examples/arc58/arc58.algo.ts:119
	// key: PluginsKey = { application: plugin, allowedCaller: allowedCaller }
	frame_dig -1 // plugin: AppID
	itob
	frame_dig -2 // allowedCaller: Address
	concat
	frame_bury 0 // key: PluginsKey

	// examples/arc58/arc58.algo.ts:120
	// assert(
	//       this.plugins(key).exists && this.plugins(key).value.adminPrivileges,
	//       'This plugin does not have admin privileges'
	//     )
	byte 0x70 // "p"
	frame_dig 0 // key: PluginsKey
	concat
	box_len
	swap
	pop
	dup
	bz *skip_and4
	byte 0x70 // "p"
	frame_dig 0 // key: PluginsKey
	concat
	box_get

	// box value does not exist: this.plugins(key).value
	assert
	store 255 // full array
	load 255 // full array
	pushint 192
	getbit
	&&

*skip_and4:
	// This plugin does not have admin privileges
	assert

	// examples/arc58/arc58.algo.ts:125
	// this.admin.value = newAdmin
	byte 0x61 // "a"
	frame_dig -3 // newAdmin: Address
	app_global_put
	retsub

// arc58_getAdmin()address
*abi_route_arc58_getAdmin:
	// The ABI return prefix
	pushbytes 0x151f7c75

	// execute arc58_getAdmin()address
	callsub arc58_getAdmin
	concat
	log
	int 1
	return

// arc58_getAdmin(): Address
//
// Get the admin of this app. This method SHOULD always be used rather than reading directly from state
// because different implementations may have different ways of determining the admin.
arc58_getAdmin:
	proto 0 1

	// examples/arc58/arc58.algo.ts:133
	// return this.admin.value;
	byte 0x61 // "a"
	app_global_get
	retsub

// arc58_verifyAuthAddr()void
*abi_route_arc58_verifyAuthAddr:
	// execute arc58_verifyAuthAddr()void
	callsub arc58_verifyAuthAddr
	int 1
	return

// arc58_verifyAuthAddr(): void
//
// Verify the abstracted account is rekeyed to this app
arc58_verifyAuthAddr:
	proto 0 0

	// examples/arc58/arc58.algo.ts:140
	// assert(this.controlledAddress.value.authAddr === this.getAuthAddr())
	byte 0x63 // "c"
	app_global_get
	acct_params_get AcctAuthAddr
	pop
	callsub getAuthAddr
	==
	assert
	retsub

// arc58_rekeyTo(address,bool)void
*abi_route_arc58_rekeyTo:
	// flash: bool
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 0 (flash) for arc58_rekeyTo must be a bool
	assert
	int 0
	getbit

	// addr: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (addr) for arc58_rekeyTo must be a address
	assert

	// execute arc58_rekeyTo(address,bool)void
	callsub arc58_rekeyTo
	int 1
	return

// arc58_rekeyTo(addr: Address, flash: boolean): void
//
// Rekey the abstracted account to another address. Primarily useful for rekeying to an EOA.
//
// @param addr The address to rekey to
// @param flash Whether or not this should be a flash rekey. If true, the rekey back to the app address must done in the same txn group as this call
arc58_rekeyTo:
	proto 2 0

	// examples/arc58/arc58.algo.ts:150
	// verifyAppCallTxn(this.txn, { sender: this.admin.value })
	// verify sender
	txn Sender
	byte 0x61 // "a"
	app_global_get
	==

	// transaction verification failed: {"txn":"this.txn","field":"sender","expected":"this.admin.value"}
	assert

	// examples/arc58/arc58.algo.ts:152
	// sendPayment({
	//       sender: this.controlledAddress.value,
	//       receiver: addr,
	//       rekeyTo: addr,
	//       note: 'rekeying abstracted account',
	//     })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// examples/arc58/arc58.algo.ts:153
	// sender: this.controlledAddress.value
	byte 0x63 // "c"
	app_global_get
	itxn_field Sender

	// examples/arc58/arc58.algo.ts:154
	// receiver: addr
	frame_dig -1 // addr: Address
	itxn_field Receiver

	// examples/arc58/arc58.algo.ts:155
	// rekeyTo: addr
	frame_dig -1 // addr: Address
	itxn_field RekeyTo

	// examples/arc58/arc58.algo.ts:156
	// note: 'rekeying abstracted account'
	pushbytes 0x72656b6579696e672061627374726163746564206163636f756e74 // "rekeying abstracted account"
	itxn_field Note

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// *if2_condition
	// examples/arc58/arc58.algo.ts:159
	// flash
	frame_dig -2 // flash: boolean
	bz *if2_end

	// *if2_consequent
	// examples/arc58/arc58.algo.ts:159
	// this.verifyRekeyToAbstractedAccount()
	callsub verifyRekeyToAbstractedAccount

*if2_end:
	retsub

// pluginCallAllowed(app: AppID, caller: Address): boolean
pluginCallAllowed:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/arc58/arc58.algo.ts:163
	// key: PluginsKey = { application: app, allowedCaller: caller }
	frame_dig -1 // app: AppID
	itob
	frame_dig -2 // caller: Address
	concat
	frame_bury 0 // key: PluginsKey

	// examples/arc58/arc58.algo.ts:165
	// return (
	//       this.plugins(key).exists &&
	//       this.plugins(key).value.lastValidRound >= globals.round &&
	//       globals.round - this.plugins(key).value.lastCalled >= this.plugins(key).value.cooldown
	//     );
	byte 0x70 // "p"
	frame_dig 0 // key: PluginsKey
	concat
	box_len
	swap
	pop
	dup
	bz *skip_and5
	byte 0x70 // "p"
	frame_dig 0 // key: PluginsKey
	concat
	box_get

	// box value does not exist: this.plugins(key).value
	assert
	store 255 // full array
	load 255 // full array
	extract 0 8
	btoi
	global Round
	>=
	&&

*skip_and5:
	dup
	bz *skip_and6
	global Round
	byte 0x70 // "p"
	frame_dig 0 // key: PluginsKey
	concat
	box_get

	// box value does not exist: this.plugins(key).value
	assert
	store 255 // full array
	load 255 // full array
	extract 16 8
	btoi
	-
	byte 0x70 // "p"
	frame_dig 0 // key: PluginsKey
	concat
	box_get

	// box value does not exist: this.plugins(key).value
	assert
	store 255 // full array
	load 255 // full array
	extract 8 8
	btoi
	>=
	&&

*skip_and6:
	// set the subroutine return value
	frame_bury 0
	retsub

// arc58_rekeyToPlugin(uint64)void
*abi_route_arc58_rekeyToPlugin:
	// plugin: uint64
	txna ApplicationArgs 1
	btoi

	// execute arc58_rekeyToPlugin(uint64)void
	callsub arc58_rekeyToPlugin
	int 1
	return

// arc58_rekeyToPlugin(plugin: AppID): void
//
// Temporarily rekey to an approved plugin app address
//
// @param plugin The app to rekey to
arc58_rekeyToPlugin:
	proto 1 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/arc58/arc58.algo.ts:178
	// globalAllowed = this.pluginCallAllowed(plugin, Address.zeroAddress)
	global ZeroAddress
	frame_dig -1 // plugin: AppID
	callsub pluginCallAllowed
	frame_bury 0 // globalAllowed: bool

	// *if3_condition
	// examples/arc58/arc58.algo.ts:180
	// !globalAllowed
	frame_dig 0 // globalAllowed: bool
	!
	bz *if3_end

	// *if3_consequent
	// examples/arc58/arc58.algo.ts:181
	// assert(this.pluginCallAllowed(plugin, this.txn.sender), 'This sender is not allowed to trigger this plugin')
	txn Sender
	frame_dig -1 // plugin: AppID
	callsub pluginCallAllowed

	// This sender is not allowed to trigger this plugin
	assert

*if3_end:
	// examples/arc58/arc58.algo.ts:183
	// sendPayment({
	//       sender: this.controlledAddress.value,
	//       receiver: this.controlledAddress.value,
	//       rekeyTo: plugin.address,
	//       note: 'rekeying to plugin app',
	//     })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// examples/arc58/arc58.algo.ts:184
	// sender: this.controlledAddress.value
	byte 0x63 // "c"
	app_global_get
	itxn_field Sender

	// examples/arc58/arc58.algo.ts:185
	// receiver: this.controlledAddress.value
	byte 0x63 // "c"
	app_global_get
	itxn_field Receiver

	// examples/arc58/arc58.algo.ts:186
	// rekeyTo: plugin.address
	frame_dig -1 // plugin: AppID
	app_params_get AppAddress
	pop
	itxn_field RekeyTo

	// examples/arc58/arc58.algo.ts:187
	// note: 'rekeying to plugin app'
	pushbytes 0x72656b6579696e6720746f20706c7567696e20617070 // "rekeying to plugin app"
	itxn_field Note

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/arc58/arc58.algo.ts:190
	// this.plugins({
	//       application: plugin,
	//       allowedCaller: globalAllowed ? Address.zeroAddress : this.txn.sender,
	//     }).value.lastCalled = globals.round
	byte 0x70 // "p"
	frame_dig -1 // plugin: AppID
	itob
	frame_dig 0 // globalAllowed: bool
	bz *ternary3_false
	global ZeroAddress
	b *ternary3_end

*ternary3_false:
	txn Sender

*ternary3_end:
	concat
	concat
	box_get

	// box value does not exist: this.plugins({ application: plugin, allowedCaller: globalAllowed ? Address.zeroAddress : this.txn.sender, }).value
	assert
	store 255 // full array
	load 255 // full array
	pushint 16
	global Round
	itob
	byte 0x70 // "p"
	frame_dig -1 // plugin: AppID
	itob
	frame_dig 0 // globalAllowed: bool
	bz *ternary5_false
	global ZeroAddress
	b *ternary5_end

*ternary5_false:
	txn Sender

*ternary5_end:
	concat
	concat
	cover 2
	box_replace

	// examples/arc58/arc58.algo.ts:195
	// this.verifyRekeyToAbstractedAccount()
	callsub verifyRekeyToAbstractedAccount
	retsub

// arc58_rekeyToNamedPlugin(string)void
*abi_route_arc58_rekeyToNamedPlugin:
	// name: string
	txna ApplicationArgs 1
	extract 2 0

	// execute arc58_rekeyToNamedPlugin(string)void
	callsub arc58_rekeyToNamedPlugin
	int 1
	return

// arc58_rekeyToNamedPlugin(name: string): void
//
// Temporarily rekey to a named plugin app address
//
// @param name The name of the plugin to rekey to
arc58_rekeyToNamedPlugin:
	proto 1 0

	// examples/arc58/arc58.algo.ts:204
	// this.arc58_rekeyToPlugin(this.namedPlugins(name).value.application)
	int 0
	pushint 8
	byte 0x6e // "n"
	frame_dig -1 // name: string
	concat
	cover 2
	box_extract
	btoi
	callsub arc58_rekeyToPlugin
	retsub

// arc58_addPlugin(uint64,address,uint64,uint64,bool)void
*abi_route_arc58_addPlugin:
	// adminPrivileges: bool
	txna ApplicationArgs 5
	dup
	len
	int 1
	==

	// argument 0 (adminPrivileges) for arc58_addPlugin must be a bool
	assert
	int 0
	getbit

	// cooldown: uint64
	txna ApplicationArgs 4
	btoi

	// lastValidRound: uint64
	txna ApplicationArgs 3
	btoi

	// allowedCaller: address
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 3 (allowedCaller) for arc58_addPlugin must be a address
	assert

	// app: uint64
	txna ApplicationArgs 1
	btoi

	// execute arc58_addPlugin(uint64,address,uint64,uint64,bool)void
	callsub arc58_addPlugin
	int 1
	return

// arc58_addPlugin(app: AppID, allowedCaller: Address, lastValidRound: uint64, cooldown: uint64, adminPrivileges: boolean): void
//
// Add an app to the list of approved plugins
//
// @param app The app to add
// @param allowedCaller The address of that's allowed to call the app
// or the global zero address for all addresses
// @param lastValidRound The round when the permission expires
// @param cooldown  The number of rounds that must pass before the plugin can be called again
// @param adminPrivileges Whether the plugin has permissions to change the admin account
arc58_addPlugin:
	proto 5 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/arc58/arc58.algo.ts:224
	// verifyTxn(this.txn, { sender: this.admin.value })
	// verify sender
	txn Sender
	byte 0x61 // "a"
	app_global_get
	==

	// transaction verification failed: {"txn":"this.txn","field":"sender","expected":"this.admin.value"}
	assert

	// examples/arc58/arc58.algo.ts:225
	// key: PluginsKey = { application: app, allowedCaller: allowedCaller }
	frame_dig -1 // app: AppID
	itob
	frame_dig -2 // allowedCaller: Address
	concat
	frame_bury 0 // key: PluginsKey

	// examples/arc58/arc58.algo.ts:226
	// this.plugins(key).value = {
	//       lastValidRound: lastValidRound,
	//       cooldown: cooldown,
	//       lastCalled: 0,
	//       adminPrivileges: adminPrivileges,
	//     }
	byte 0x70 // "p"
	frame_dig 0 // key: PluginsKey
	concat
	frame_dig -3 // lastValidRound: uint64
	itob
	frame_dig -4 // cooldown: uint64
	itob
	concat
	byte 0x0000000000000000
	concat
	byte 0x00
	int 0
	frame_dig -5 // adminPrivileges: boolean
	setbit
	concat
	box_put
	retsub

// arc58_removePlugin(uint64,address)void
*abi_route_arc58_removePlugin:
	// allowedCaller: address
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (allowedCaller) for arc58_removePlugin must be a address
	assert

	// app: uint64
	txna ApplicationArgs 1
	btoi

	// execute arc58_removePlugin(uint64,address)void
	callsub arc58_removePlugin
	int 1
	return

// arc58_removePlugin(app: AppID, allowedCaller: Address): void
//
// Remove an app from the list of approved plugins
//
// @param app The app to remove
arc58_removePlugin:
	proto 2 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/arc58/arc58.algo.ts:240
	// verifyTxn(this.txn, { sender: this.admin.value })
	// verify sender
	txn Sender
	byte 0x61 // "a"
	app_global_get
	==

	// transaction verification failed: {"txn":"this.txn","field":"sender","expected":"this.admin.value"}
	assert

	// examples/arc58/arc58.algo.ts:242
	// key: PluginsKey = { application: app, allowedCaller: allowedCaller }
	frame_dig -1 // app: AppID
	itob
	frame_dig -2 // allowedCaller: Address
	concat
	frame_bury 0 // key: PluginsKey

	// examples/arc58/arc58.algo.ts:243
	// this.plugins(key).delete()
	byte 0x70 // "p"
	frame_dig 0 // key: PluginsKey
	concat
	box_del
	retsub

// arc58_addNamedPlugin(string,uint64,address,uint64,uint64,bool)void
*abi_route_arc58_addNamedPlugin:
	// adminPrivileges: bool
	txna ApplicationArgs 6
	dup
	len
	int 1
	==

	// argument 0 (adminPrivileges) for arc58_addNamedPlugin must be a bool
	assert
	int 0
	getbit

	// cooldown: uint64
	txna ApplicationArgs 5
	btoi

	// lastValidRound: uint64
	txna ApplicationArgs 4
	btoi

	// allowedCaller: address
	txna ApplicationArgs 3
	dup
	len
	int 32
	==

	// argument 3 (allowedCaller) for arc58_addNamedPlugin must be a address
	assert

	// app: uint64
	txna ApplicationArgs 2
	btoi

	// name: string
	txna ApplicationArgs 1
	extract 2 0

	// execute arc58_addNamedPlugin(string,uint64,address,uint64,uint64,bool)void
	callsub arc58_addNamedPlugin
	int 1
	return

// arc58_addNamedPlugin(name: string, app: AppID, allowedCaller: Address, lastValidRound: uint64, cooldown: uint64, adminPrivileges: boolean): void
//
// Add a named plugin
//
// @param app The plugin app
// @param name The plugin name
// @param allowedCaller The address of that's allowed to call the app
// or the global zero address for all addresses
// @param lastValidRound The round when the permission expires
// @param cooldown  The number of rounds that must pass before the plugin can be called again
// @param adminPrivileges Whether the plugin has permissions to change the admin account
arc58_addNamedPlugin:
	proto 6 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/arc58/arc58.algo.ts:265
	// verifyTxn(this.txn, { sender: this.admin.value })
	// verify sender
	txn Sender
	byte 0x61 // "a"
	app_global_get
	==

	// transaction verification failed: {"txn":"this.txn","field":"sender","expected":"this.admin.value"}
	assert

	// examples/arc58/arc58.algo.ts:266
	// assert(!this.namedPlugins(name).exists)
	byte 0x6e // "n"
	frame_dig -1 // name: string
	concat
	box_len
	swap
	pop
	!
	assert

	// examples/arc58/arc58.algo.ts:268
	// key: PluginsKey = { application: app, allowedCaller: allowedCaller }
	frame_dig -2 // app: AppID
	itob
	frame_dig -3 // allowedCaller: Address
	concat
	frame_bury 0 // key: PluginsKey

	// examples/arc58/arc58.algo.ts:269
	// this.namedPlugins(name).value = key
	byte 0x6e // "n"
	frame_dig -1 // name: string
	concat
	frame_dig 0 // key: PluginsKey
	box_put

	// examples/arc58/arc58.algo.ts:270
	// this.plugins(key).value = {
	//       lastValidRound: lastValidRound,
	//       cooldown: cooldown,
	//       lastCalled: 0,
	//       adminPrivileges: adminPrivileges,
	//     }
	byte 0x70 // "p"
	frame_dig 0 // key: PluginsKey
	concat
	frame_dig -4 // lastValidRound: uint64
	itob
	frame_dig -5 // cooldown: uint64
	itob
	concat
	byte 0x0000000000000000
	concat
	byte 0x00
	int 0
	frame_dig -6 // adminPrivileges: boolean
	setbit
	concat
	box_put
	retsub

// arc58_removeNamedPlugin(string)void
*abi_route_arc58_removeNamedPlugin:
	// name: string
	txna ApplicationArgs 1
	extract 2 0

	// execute arc58_removeNamedPlugin(string)void
	callsub arc58_removeNamedPlugin
	int 1
	return

// arc58_removeNamedPlugin(name: string): void
//
// Remove a named plugin
//
// @param name The plugin name
arc58_removeNamedPlugin:
	proto 1 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/arc58/arc58.algo.ts:284
	// verifyTxn(this.txn, { sender: this.admin.value })
	// verify sender
	txn Sender
	byte 0x61 // "a"
	app_global_get
	==

	// transaction verification failed: {"txn":"this.txn","field":"sender","expected":"this.admin.value"}
	assert

	// examples/arc58/arc58.algo.ts:286
	// app = this.namedPlugins(name).value
	byte 0x6e // "n"
	frame_dig -1 // name: string
	concat
	frame_bury 0 // storage key//app

	// examples/arc58/arc58.algo.ts:287
	// this.namedPlugins(name).delete()
	byte 0x6e // "n"
	frame_dig -1 // name: string
	concat
	box_del

	// examples/arc58/arc58.algo.ts:288
	// this.plugins(app).delete()
	byte 0x70 // "p"
	frame_dig 0 // storage key//app
	box_get

	// box value does not exist: this.namedPlugins(name).value
	assert
	concat
	box_del
	retsub

*create_NoOp:
	pushbytes 0xb4c77d71 // method "createApplication(address,address)void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0xd24b7556 // method "arc58_changeAdmin(address)void"
	pushbytes 0x5fa449c6 // method "arc58_pluginChangeAdmin(uint64,address,address)void"
	pushbytes 0x13bc44e4 // method "arc58_getAdmin()address"
	byte 0x0f885493 // method "arc58_verifyAuthAddr()void"
	pushbytes 0xc95a5d3d // method "arc58_rekeyTo(address,bool)void"
	pushbytes 0x7c766ddc // method "arc58_rekeyToPlugin(uint64)void"
	pushbytes 0x56f28b58 // method "arc58_rekeyToNamedPlugin(string)void"
	pushbytes 0xd12dcb61 // method "arc58_addPlugin(uint64,address,uint64,uint64,bool)void"
	pushbytes 0x4d372355 // method "arc58_removePlugin(uint64,address)void"
	pushbytes 0x8a72a750 // method "arc58_addNamedPlugin(string,uint64,address,uint64,uint64,bool)void"
	pushbytes 0xe350b9d4 // method "arc58_removeNamedPlugin(string)void"
	txna ApplicationArgs 0
	match *abi_route_arc58_changeAdmin *abi_route_arc58_pluginChangeAdmin *abi_route_arc58_getAdmin *abi_route_arc58_verifyAuthAddr *abi_route_arc58_rekeyTo *abi_route_arc58_rekeyToPlugin *abi_route_arc58_rekeyToNamedPlugin *abi_route_arc58_addPlugin *abi_route_arc58_removePlugin *abi_route_arc58_addNamedPlugin *abi_route_arc58_removeNamedPlugin

	// this contract does not implement the given ABI method for call NoOp
	err", + "approval": "#pragma version 10
intcblock 1 0 32
bytecblock 0x70 0x61 0x63 0x0000000000000000 0x 0x0f885493 0x6e 0x00

// This TEAL was generated by TEALScript v0.105.0
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// verifyRekeyToAbstractedAccount(): void
//
// Ensure that by the end of the group the abstracted account has control of its address
verifyRekeyToAbstractedAccount:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// examples/arc58/arc58.algo.ts:45
	// rekeyedBack = false
	int 0
	frame_bury 0 // rekeyedBack: bool

	// examples/arc58/arc58.algo.ts:47
	// for (let i = this.txn.groupIndex; i < this.txnGroup.length; i += 1)
	txn GroupIndex
	frame_bury 1 // i: uint64

*for_0:
	// examples/arc58/arc58.algo.ts:47
	// i < this.txnGroup.length
	frame_dig 1 // i: uint64
	global GroupSize
	<
	bz *for_0_end

	// examples/arc58/arc58.algo.ts:48
	// txn = this.txnGroup[i]
	frame_dig 1 // i: uint64
	frame_bury 2 // txn: txn

	// *if0_condition
	// examples/arc58/arc58.algo.ts:51
	// txn.sender === this.controlledAddress.value && txn.rekeyTo === this.controlledAddress.value
	frame_dig 2 // txn: txn
	gtxns Sender
	byte 0x63 // "c"
	app_global_get
	==
	dup
	bz *skip_and0
	frame_dig 2 // txn: txn
	gtxns RekeyTo
	byte 0x63 // "c"
	app_global_get
	==
	&&

*skip_and0:
	bz *if0_end

	// *if0_consequent
	// examples/arc58/arc58.algo.ts:52
	// rekeyedBack = true
	int 1
	frame_bury 0 // rekeyedBack: bool
	b *for_0_end

*if0_end:
	// *if1_condition
	// examples/arc58/arc58.algo.ts:58
	// txn.typeEnum === TransactionType.ApplicationCall &&
	//         txn.applicationID === this.app &&
	//         txn.numAppArgs === 1 &&
	//         txn.applicationArgs[0] === method('arc58_verifyAuthAddr()void')
	frame_dig 2 // txn: txn
	gtxns TypeEnum
	pushint 6 // appl
	==
	dup
	bz *skip_and1
	frame_dig 2 // txn: txn
	gtxns ApplicationID
	txna Applications 0
	==
	&&

*skip_and1:
	dup
	bz *skip_and2
	frame_dig 2 // txn: txn
	gtxns NumAppArgs
	int 1
	==
	&&

*skip_and2:
	dup
	bz *skip_and3
	frame_dig 2 // txn: txn
	gtxns ApplicationArgs 0
	byte 0x0f885493 // method "arc58_verifyAuthAddr()void"
	==
	&&

*skip_and3:
	bz *if1_end

	// *if1_consequent
	// examples/arc58/arc58.algo.ts:63
	// rekeyedBack = true
	int 1
	frame_bury 0 // rekeyedBack: bool
	b *for_0_end

*if1_end:

*for_0_continue:
	// examples/arc58/arc58.algo.ts:47
	// i += 1
	frame_dig 1 // i: uint64
	int 1
	+
	frame_bury 1 // i: uint64
	b *for_0

*for_0_end:
	// examples/arc58/arc58.algo.ts:68
	// assert(rekeyedBack)
	frame_dig 0 // rekeyedBack: bool
	assert
	retsub

// getAuthAddr(): Address
//
// What the value of this.address.value.authAddr should be when this.controlledAddress
// is able to be controlled by this app. It will either be this.app.address or zeroAddress
getAuthAddr:
	proto 0 1

	// examples/arc58/arc58.algo.ts:76
	// return this.controlledAddress.value === this.app.address ? Address.zeroAddress : this.app.address;
	byte 0x63 // "c"
	app_global_get
	global CurrentApplicationAddress
	==
	bz *ternary0_false
	global ZeroAddress
	b *ternary0_end

*ternary0_false:
	global CurrentApplicationAddress

*ternary0_end:
	retsub

// createApplication(address,address)void
*abi_route_createApplication:
	// admin: address
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (admin) for createApplication must be a address
	assert

	// controlledAddress: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (controlledAddress) for createApplication must be a address
	assert

	// execute createApplication(address,address)void
	callsub createApplication
	int 1
	return

// createApplication(controlledAddress: Address, admin: Address): void
//
// Create an abstracted account application.
// This is not part of ARC58 and implementation specific.
//
// @param controlledAddress The address of the abstracted account. If zeroAddress, then the address of the contract account will be used
// @param admin The admin for this app
createApplication:
	proto 2 0

	// examples/arc58/arc58.algo.ts:87
	// verifyAppCallTxn(this.txn, {
	//       sender: { includedIn: [controlledAddress, admin] },
	//     })
	// verify sender
	txn Sender
	frame_dig -1 // controlledAddress: Address
	==
	txn Sender
	frame_dig -2 // admin: Address
	==
	||

	// transaction verification failed: {"txn":{"txnText":"this.txn"},"field":"sender","condition":"includedIn","expected":"[controlledAddress, admin]"}
	assert

	// examples/arc58/arc58.algo.ts:91
	// assert(admin !== controlledAddress)
	frame_dig -2 // admin: Address
	frame_dig -1 // controlledAddress: Address
	!=
	assert

	// examples/arc58/arc58.algo.ts:93
	// this.admin.value = admin
	byte 0x61 // "a"
	frame_dig -2 // admin: Address
	app_global_put

	// examples/arc58/arc58.algo.ts:94
	// this.controlledAddress.value = controlledAddress === Address.zeroAddress ? this.app.address : controlledAddress
	byte 0x63 // "c"
	frame_dig -1 // controlledAddress: Address
	global ZeroAddress
	==
	bz *ternary1_false
	global CurrentApplicationAddress
	b *ternary1_end

*ternary1_false:
	frame_dig -1 // controlledAddress: Address

*ternary1_end:
	app_global_put
	retsub

// arc58_changeAdmin(address)void
*abi_route_arc58_changeAdmin:
	// newAdmin: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (newAdmin) for arc58_changeAdmin must be a address
	assert

	// execute arc58_changeAdmin(address)void
	callsub arc58_changeAdmin
	int 1
	return

// arc58_changeAdmin(newAdmin: Address): void
//
// Attempt to change the admin for this app. Some implementations MAY not support this.
//
// @param newAdmin The new admin
arc58_changeAdmin:
	proto 1 0

	// examples/arc58/arc58.algo.ts:103
	// verifyTxn(this.txn, { sender: this.admin.value })
	// verify sender
	txn Sender
	byte 0x61 // "a"
	app_global_get
	==

	// transaction verification failed: {"txn":"this.txn","field":"sender","expected":"this.admin.value"}
	assert

	// examples/arc58/arc58.algo.ts:104
	// this.admin.value = newAdmin
	byte 0x61 // "a"
	frame_dig -1 // newAdmin: Address
	app_global_put
	retsub

// arc58_pluginChangeAdmin(uint64,address,address)void
*abi_route_arc58_pluginChangeAdmin:
	// newAdmin: address
	txna ApplicationArgs 3
	dup
	len
	int 32
	==

	// argument 0 (newAdmin) for arc58_pluginChangeAdmin must be a address
	assert

	// allowedCaller: address
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 1 (allowedCaller) for arc58_pluginChangeAdmin must be a address
	assert

	// plugin: uint64
	txna ApplicationArgs 1
	btoi

	// execute arc58_pluginChangeAdmin(uint64,address,address)void
	callsub arc58_pluginChangeAdmin
	int 1
	return

// arc58_pluginChangeAdmin(plugin: AppID, allowedCaller: Address, newAdmin: Address): void
//
// Attempt to change the admin via plugin.
//
// @param plugin The app calling the plugin
// @param allowedCaller The address that triggered the plugin
// @param newAdmin The new admin
arc58_pluginChangeAdmin:
	proto 3 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/arc58/arc58.algo.ts:116
	// verifyTxn(this.txn, { sender: plugin.address })
	// verify sender
	txn Sender
	frame_dig -1 // plugin: AppID
	app_params_get AppAddress
	pop
	==

	// transaction verification failed: {"txn":"this.txn","field":"sender","expected":"plugin.address"}
	assert

	// examples/arc58/arc58.algo.ts:117
	// assert(this.controlledAddress.value.authAddr === plugin.address, 'This plugin is not in control of the account')
	byte 0x63 // "c"
	app_global_get
	acct_params_get AcctAuthAddr
	pop
	frame_dig -1 // plugin: AppID
	app_params_get AppAddress
	pop
	==

	// This plugin is not in control of the account
	assert

	// examples/arc58/arc58.algo.ts:119
	// key: PluginsKey = { application: plugin, allowedCaller: allowedCaller }
	frame_dig -1 // plugin: AppID
	itob
	frame_dig -2 // allowedCaller: Address
	concat
	frame_bury 0 // key: PluginsKey

	// examples/arc58/arc58.algo.ts:120
	// assert(
	//       this.plugins(key).exists && this.plugins(key).value.adminPrivileges,
	//       'This plugin does not have admin privileges'
	//     )
	byte 0x70 // "p"
	frame_dig 0 // key: PluginsKey
	concat
	box_len
	swap
	pop
	dup
	bz *skip_and4
	byte 0x70 // "p"
	frame_dig 0 // key: PluginsKey
	concat
	box_get

	// box value does not exist: this.plugins(key).value
	assert
	store 255 // full array
	load 255 // full array
	pushint 192
	getbit
	&&

*skip_and4:
	// This plugin does not have admin privileges
	assert

	// examples/arc58/arc58.algo.ts:125
	// this.admin.value = newAdmin
	byte 0x61 // "a"
	frame_dig -3 // newAdmin: Address
	app_global_put
	retsub

// arc58_getAdmin()address
*abi_route_arc58_getAdmin:
	// The ABI return prefix
	pushbytes 0x151f7c75

	// execute arc58_getAdmin()address
	callsub arc58_getAdmin
	concat
	log
	int 1
	return

// arc58_getAdmin(): Address
//
// Get the admin of this app. This method SHOULD always be used rather than reading directly from state
// because different implementations may have different ways of determining the admin.
arc58_getAdmin:
	proto 0 1

	// examples/arc58/arc58.algo.ts:133
	// return this.admin.value;
	byte 0x61 // "a"
	app_global_get
	retsub

// arc58_verifyAuthAddr()void
*abi_route_arc58_verifyAuthAddr:
	// execute arc58_verifyAuthAddr()void
	callsub arc58_verifyAuthAddr
	int 1
	return

// arc58_verifyAuthAddr(): void
//
// Verify the abstracted account is rekeyed to this app
arc58_verifyAuthAddr:
	proto 0 0

	// examples/arc58/arc58.algo.ts:140
	// assert(this.controlledAddress.value.authAddr === this.getAuthAddr())
	byte 0x63 // "c"
	app_global_get
	acct_params_get AcctAuthAddr
	pop
	callsub getAuthAddr
	==
	assert
	retsub

// arc58_rekeyTo(address,bool)void
*abi_route_arc58_rekeyTo:
	// flash: bool
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 0 (flash) for arc58_rekeyTo must be a bool
	assert
	int 0
	getbit

	// addr: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (addr) for arc58_rekeyTo must be a address
	assert

	// execute arc58_rekeyTo(address,bool)void
	callsub arc58_rekeyTo
	int 1
	return

// arc58_rekeyTo(addr: Address, flash: boolean): void
//
// Rekey the abstracted account to another address. Primarily useful for rekeying to an EOA.
//
// @param addr The address to rekey to
// @param flash Whether or not this should be a flash rekey. If true, the rekey back to the app address must done in the same txn group as this call
arc58_rekeyTo:
	proto 2 0

	// examples/arc58/arc58.algo.ts:150
	// verifyAppCallTxn(this.txn, { sender: this.admin.value })
	// verify sender
	txn Sender
	byte 0x61 // "a"
	app_global_get
	==

	// transaction verification failed: {"txn":"this.txn","field":"sender","expected":"this.admin.value"}
	assert

	// examples/arc58/arc58.algo.ts:152
	// sendPayment({
	//       sender: this.controlledAddress.value,
	//       receiver: addr,
	//       rekeyTo: addr,
	//       note: 'rekeying abstracted account',
	//     })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// examples/arc58/arc58.algo.ts:153
	// sender: this.controlledAddress.value
	byte 0x63 // "c"
	app_global_get
	itxn_field Sender

	// examples/arc58/arc58.algo.ts:154
	// receiver: addr
	frame_dig -1 // addr: Address
	itxn_field Receiver

	// examples/arc58/arc58.algo.ts:155
	// rekeyTo: addr
	frame_dig -1 // addr: Address
	itxn_field RekeyTo

	// examples/arc58/arc58.algo.ts:156
	// note: 'rekeying abstracted account'
	pushbytes 0x72656b6579696e672061627374726163746564206163636f756e74 // "rekeying abstracted account"
	itxn_field Note

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// *if2_condition
	// examples/arc58/arc58.algo.ts:159
	// flash
	frame_dig -2 // flash: boolean
	bz *if2_end

	// *if2_consequent
	// examples/arc58/arc58.algo.ts:159
	// this.verifyRekeyToAbstractedAccount()
	callsub verifyRekeyToAbstractedAccount

*if2_end:
	retsub

// pluginCallAllowed(app: AppID, caller: Address): boolean
pluginCallAllowed:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/arc58/arc58.algo.ts:163
	// key: PluginsKey = { application: app, allowedCaller: caller }
	frame_dig -1 // app: AppID
	itob
	frame_dig -2 // caller: Address
	concat
	frame_bury 0 // key: PluginsKey

	// examples/arc58/arc58.algo.ts:165
	// return (
	//       this.plugins(key).exists &&
	//       this.plugins(key).value.lastValidRound >= globals.round &&
	//       globals.round - this.plugins(key).value.lastCalled >= this.plugins(key).value.cooldown
	//     );
	byte 0x70 // "p"
	frame_dig 0 // key: PluginsKey
	concat
	box_len
	swap
	pop
	dup
	bz *skip_and5
	byte 0x70 // "p"
	frame_dig 0 // key: PluginsKey
	concat
	box_get

	// box value does not exist: this.plugins(key).value
	assert
	store 255 // full array
	load 255 // full array
	extract 0 8
	btoi
	global Round
	>=
	&&

*skip_and5:
	dup
	bz *skip_and6
	global Round
	byte 0x70 // "p"
	frame_dig 0 // key: PluginsKey
	concat
	box_get

	// box value does not exist: this.plugins(key).value
	assert
	store 255 // full array
	load 255 // full array
	extract 16 8
	btoi
	-
	byte 0x70 // "p"
	frame_dig 0 // key: PluginsKey
	concat
	box_get

	// box value does not exist: this.plugins(key).value
	assert
	store 255 // full array
	load 255 // full array
	extract 8 8
	btoi
	>=
	&&

*skip_and6:
	// set the subroutine return value
	frame_bury 0
	retsub

// arc58_rekeyToPlugin(uint64)void
*abi_route_arc58_rekeyToPlugin:
	// plugin: uint64
	txna ApplicationArgs 1
	btoi

	// execute arc58_rekeyToPlugin(uint64)void
	callsub arc58_rekeyToPlugin
	int 1
	return

// arc58_rekeyToPlugin(plugin: AppID): void
//
// Temporarily rekey to an approved plugin app address
//
// @param plugin The app to rekey to
arc58_rekeyToPlugin:
	proto 1 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/arc58/arc58.algo.ts:178
	// globalAllowed = this.pluginCallAllowed(plugin, Address.zeroAddress)
	global ZeroAddress
	frame_dig -1 // plugin: AppID
	callsub pluginCallAllowed
	frame_bury 0 // globalAllowed: bool

	// *if3_condition
	// examples/arc58/arc58.algo.ts:180
	// !globalAllowed
	frame_dig 0 // globalAllowed: bool
	!
	bz *if3_end

	// *if3_consequent
	// examples/arc58/arc58.algo.ts:181
	// assert(this.pluginCallAllowed(plugin, this.txn.sender), 'This sender is not allowed to trigger this plugin')
	txn Sender
	frame_dig -1 // plugin: AppID
	callsub pluginCallAllowed

	// This sender is not allowed to trigger this plugin
	assert

*if3_end:
	// examples/arc58/arc58.algo.ts:183
	// sendPayment({
	//       sender: this.controlledAddress.value,
	//       receiver: this.controlledAddress.value,
	//       rekeyTo: plugin.address,
	//       note: 'rekeying to plugin app',
	//     })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// examples/arc58/arc58.algo.ts:184
	// sender: this.controlledAddress.value
	byte 0x63 // "c"
	app_global_get
	itxn_field Sender

	// examples/arc58/arc58.algo.ts:185
	// receiver: this.controlledAddress.value
	byte 0x63 // "c"
	app_global_get
	itxn_field Receiver

	// examples/arc58/arc58.algo.ts:186
	// rekeyTo: plugin.address
	frame_dig -1 // plugin: AppID
	app_params_get AppAddress
	pop
	itxn_field RekeyTo

	// examples/arc58/arc58.algo.ts:187
	// note: 'rekeying to plugin app'
	pushbytes 0x72656b6579696e6720746f20706c7567696e20617070 // "rekeying to plugin app"
	itxn_field Note

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/arc58/arc58.algo.ts:190
	// this.plugins({
	//       application: plugin,
	//       allowedCaller: globalAllowed ? Address.zeroAddress : this.txn.sender,
	//     }).value.lastCalled = globals.round
	byte 0x70 // "p"
	frame_dig -1 // plugin: AppID
	itob
	frame_dig 0 // globalAllowed: bool
	bz *ternary3_false
	global ZeroAddress
	b *ternary3_end

*ternary3_false:
	txn Sender

*ternary3_end:
	concat
	concat
	box_get

	// box value does not exist: this.plugins({ application: plugin, allowedCaller: globalAllowed ? Address.zeroAddress : this.txn.sender, }).value
	assert
	store 255 // full array
	load 255 // full array
	pushint 16
	global Round
	itob
	byte 0x70 // "p"
	frame_dig -1 // plugin: AppID
	itob
	frame_dig 0 // globalAllowed: bool
	bz *ternary5_false
	global ZeroAddress
	b *ternary5_end

*ternary5_false:
	txn Sender

*ternary5_end:
	concat
	concat
	cover 2
	box_replace

	// examples/arc58/arc58.algo.ts:195
	// this.verifyRekeyToAbstractedAccount()
	callsub verifyRekeyToAbstractedAccount
	retsub

// arc58_rekeyToNamedPlugin(string)void
*abi_route_arc58_rekeyToNamedPlugin:
	// name: string
	txna ApplicationArgs 1
	extract 2 0

	// execute arc58_rekeyToNamedPlugin(string)void
	callsub arc58_rekeyToNamedPlugin
	int 1
	return

// arc58_rekeyToNamedPlugin(name: string): void
//
// Temporarily rekey to a named plugin app address
//
// @param name The name of the plugin to rekey to
arc58_rekeyToNamedPlugin:
	proto 1 0

	// examples/arc58/arc58.algo.ts:204
	// this.arc58_rekeyToPlugin(this.namedPlugins(name).value.application)
	int 0
	pushint 8
	byte 0x6e // "n"
	frame_dig -1 // name: string
	concat
	cover 2
	box_extract
	btoi
	callsub arc58_rekeyToPlugin
	retsub

// arc58_addPlugin(uint64,address,uint64,uint64,bool)void
*abi_route_arc58_addPlugin:
	// adminPrivileges: bool
	txna ApplicationArgs 5
	dup
	len
	int 1
	==

	// argument 0 (adminPrivileges) for arc58_addPlugin must be a bool
	assert
	int 0
	getbit

	// cooldown: uint64
	txna ApplicationArgs 4
	btoi

	// lastValidRound: uint64
	txna ApplicationArgs 3
	btoi

	// allowedCaller: address
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 3 (allowedCaller) for arc58_addPlugin must be a address
	assert

	// app: uint64
	txna ApplicationArgs 1
	btoi

	// execute arc58_addPlugin(uint64,address,uint64,uint64,bool)void
	callsub arc58_addPlugin
	int 1
	return

// arc58_addPlugin(app: AppID, allowedCaller: Address, lastValidRound: uint64, cooldown: uint64, adminPrivileges: boolean): void
//
// Add an app to the list of approved plugins
//
// @param app The app to add
// @param allowedCaller The address of that's allowed to call the app
// or the global zero address for all addresses
// @param lastValidRound The round when the permission expires
// @param cooldown  The number of rounds that must pass before the plugin can be called again
// @param adminPrivileges Whether the plugin has permissions to change the admin account
arc58_addPlugin:
	proto 5 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/arc58/arc58.algo.ts:224
	// verifyTxn(this.txn, { sender: this.admin.value })
	// verify sender
	txn Sender
	byte 0x61 // "a"
	app_global_get
	==

	// transaction verification failed: {"txn":"this.txn","field":"sender","expected":"this.admin.value"}
	assert

	// examples/arc58/arc58.algo.ts:225
	// key: PluginsKey = { application: app, allowedCaller: allowedCaller }
	frame_dig -1 // app: AppID
	itob
	frame_dig -2 // allowedCaller: Address
	concat
	frame_bury 0 // key: PluginsKey

	// examples/arc58/arc58.algo.ts:226
	// this.plugins(key).value = {
	//       lastValidRound: lastValidRound,
	//       cooldown: cooldown,
	//       lastCalled: 0,
	//       adminPrivileges: adminPrivileges,
	//     }
	byte 0x70 // "p"
	frame_dig 0 // key: PluginsKey
	concat
	frame_dig -3 // lastValidRound: uint64
	itob
	frame_dig -4 // cooldown: uint64
	itob
	concat
	byte 0x0000000000000000
	concat
	byte 0x00
	int 0
	frame_dig -5 // adminPrivileges: boolean
	setbit
	concat
	box_put
	retsub

// arc58_removePlugin(uint64,address)void
*abi_route_arc58_removePlugin:
	// allowedCaller: address
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (allowedCaller) for arc58_removePlugin must be a address
	assert

	// app: uint64
	txna ApplicationArgs 1
	btoi

	// execute arc58_removePlugin(uint64,address)void
	callsub arc58_removePlugin
	int 1
	return

// arc58_removePlugin(app: AppID, allowedCaller: Address): void
//
// Remove an app from the list of approved plugins
//
// @param app The app to remove
arc58_removePlugin:
	proto 2 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/arc58/arc58.algo.ts:240
	// verifyTxn(this.txn, { sender: this.admin.value })
	// verify sender
	txn Sender
	byte 0x61 // "a"
	app_global_get
	==

	// transaction verification failed: {"txn":"this.txn","field":"sender","expected":"this.admin.value"}
	assert

	// examples/arc58/arc58.algo.ts:242
	// key: PluginsKey = { application: app, allowedCaller: allowedCaller }
	frame_dig -1 // app: AppID
	itob
	frame_dig -2 // allowedCaller: Address
	concat
	frame_bury 0 // key: PluginsKey

	// examples/arc58/arc58.algo.ts:243
	// this.plugins(key).delete()
	byte 0x70 // "p"
	frame_dig 0 // key: PluginsKey
	concat
	box_del
	retsub

// arc58_addNamedPlugin(string,uint64,address,uint64,uint64,bool)void
*abi_route_arc58_addNamedPlugin:
	// adminPrivileges: bool
	txna ApplicationArgs 6
	dup
	len
	int 1
	==

	// argument 0 (adminPrivileges) for arc58_addNamedPlugin must be a bool
	assert
	int 0
	getbit

	// cooldown: uint64
	txna ApplicationArgs 5
	btoi

	// lastValidRound: uint64
	txna ApplicationArgs 4
	btoi

	// allowedCaller: address
	txna ApplicationArgs 3
	dup
	len
	int 32
	==

	// argument 3 (allowedCaller) for arc58_addNamedPlugin must be a address
	assert

	// app: uint64
	txna ApplicationArgs 2
	btoi

	// name: string
	txna ApplicationArgs 1
	extract 2 0

	// execute arc58_addNamedPlugin(string,uint64,address,uint64,uint64,bool)void
	callsub arc58_addNamedPlugin
	int 1
	return

// arc58_addNamedPlugin(name: string, app: AppID, allowedCaller: Address, lastValidRound: uint64, cooldown: uint64, adminPrivileges: boolean): void
//
// Add a named plugin
//
// @param app The plugin app
// @param name The plugin name
// @param allowedCaller The address of that's allowed to call the app
// or the global zero address for all addresses
// @param lastValidRound The round when the permission expires
// @param cooldown  The number of rounds that must pass before the plugin can be called again
// @param adminPrivileges Whether the plugin has permissions to change the admin account
arc58_addNamedPlugin:
	proto 6 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/arc58/arc58.algo.ts:265
	// verifyTxn(this.txn, { sender: this.admin.value })
	// verify sender
	txn Sender
	byte 0x61 // "a"
	app_global_get
	==

	// transaction verification failed: {"txn":"this.txn","field":"sender","expected":"this.admin.value"}
	assert

	// examples/arc58/arc58.algo.ts:266
	// assert(!this.namedPlugins(name).exists)
	byte 0x6e // "n"
	frame_dig -1 // name: string
	concat
	box_len
	swap
	pop
	!
	assert

	// examples/arc58/arc58.algo.ts:268
	// key: PluginsKey = { application: app, allowedCaller: allowedCaller }
	frame_dig -2 // app: AppID
	itob
	frame_dig -3 // allowedCaller: Address
	concat
	frame_bury 0 // key: PluginsKey

	// examples/arc58/arc58.algo.ts:269
	// this.namedPlugins(name).value = key
	byte 0x6e // "n"
	frame_dig -1 // name: string
	concat
	frame_dig 0 // key: PluginsKey
	box_put

	// examples/arc58/arc58.algo.ts:270
	// this.plugins(key).value = {
	//       lastValidRound: lastValidRound,
	//       cooldown: cooldown,
	//       lastCalled: 0,
	//       adminPrivileges: adminPrivileges,
	//     }
	byte 0x70 // "p"
	frame_dig 0 // key: PluginsKey
	concat
	frame_dig -4 // lastValidRound: uint64
	itob
	frame_dig -5 // cooldown: uint64
	itob
	concat
	byte 0x0000000000000000
	concat
	byte 0x00
	int 0
	frame_dig -6 // adminPrivileges: boolean
	setbit
	concat
	box_put
	retsub

// arc58_removeNamedPlugin(string)void
*abi_route_arc58_removeNamedPlugin:
	// name: string
	txna ApplicationArgs 1
	extract 2 0

	// execute arc58_removeNamedPlugin(string)void
	callsub arc58_removeNamedPlugin
	int 1
	return

// arc58_removeNamedPlugin(name: string): void
//
// Remove a named plugin
//
// @param name The plugin name
arc58_removeNamedPlugin:
	proto 1 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/arc58/arc58.algo.ts:284
	// verifyTxn(this.txn, { sender: this.admin.value })
	// verify sender
	txn Sender
	byte 0x61 // "a"
	app_global_get
	==

	// transaction verification failed: {"txn":"this.txn","field":"sender","expected":"this.admin.value"}
	assert

	// examples/arc58/arc58.algo.ts:286
	// app = this.namedPlugins(name).value
	byte 0x6e // "n"
	frame_dig -1 // name: string
	concat
	frame_bury 0 // storage key//app

	// examples/arc58/arc58.algo.ts:287
	// this.namedPlugins(name).delete()
	byte 0x6e // "n"
	frame_dig -1 // name: string
	concat
	box_del

	// examples/arc58/arc58.algo.ts:288
	// this.plugins(app).delete()
	byte 0x70 // "p"
	frame_dig 0 // storage key//app
	box_get

	// box value does not exist: this.namedPlugins(name).value
	assert
	concat
	box_del
	retsub

*create_NoOp:
	pushbytes 0xb4c77d71 // method "createApplication(address,address)void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0xd24b7556 // method "arc58_changeAdmin(address)void"
	pushbytes 0x5fa449c6 // method "arc58_pluginChangeAdmin(uint64,address,address)void"
	pushbytes 0x13bc44e4 // method "arc58_getAdmin()address"
	byte 0x0f885493 // method "arc58_verifyAuthAddr()void"
	pushbytes 0xc95a5d3d // method "arc58_rekeyTo(address,bool)void"
	pushbytes 0x7c766ddc // method "arc58_rekeyToPlugin(uint64)void"
	pushbytes 0x56f28b58 // method "arc58_rekeyToNamedPlugin(string)void"
	pushbytes 0xd12dcb61 // method "arc58_addPlugin(uint64,address,uint64,uint64,bool)void"
	pushbytes 0x4d372355 // method "arc58_removePlugin(uint64,address)void"
	pushbytes 0x8a72a750 // method "arc58_addNamedPlugin(string,uint64,address,uint64,uint64,bool)void"
	pushbytes 0xe350b9d4 // method "arc58_removeNamedPlugin(string)void"
	txna ApplicationArgs 0
	match *abi_route_arc58_changeAdmin *abi_route_arc58_pluginChangeAdmin *abi_route_arc58_getAdmin *abi_route_arc58_verifyAuthAddr *abi_route_arc58_rekeyTo *abi_route_arc58_rekeyToPlugin *abi_route_arc58_rekeyToNamedPlugin *abi_route_arc58_addPlugin *abi_route_arc58_removePlugin *abi_route_arc58_addNamedPlugin *abi_route_arc58_removeNamedPlugin

	// this contract does not implement the given ABI method for call NoOp
	err", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/examples/arc72/artifacts/ARC72.approval.teal b/examples/arc72/artifacts/ARC72.approval.teal index 10844f7fe..81202ca32 100644 --- a/examples/arc72/artifacts/ARC72.approval.teal +++ b/examples/arc72/artifacts/ARC72.approval.teal @@ -2,7 +2,7 @@ intcblock 32 1 256 bytecblock 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF 0x151f7c75 0x696e646578 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/examples/arc72/artifacts/ARC72.arc32.json b/examples/arc72/artifacts/ARC72.arc32.json index 030c076fb..25329869b 100644 --- a/examples/arc72/artifacts/ARC72.arc32.json +++ b/examples/arc72/artifacts/ARC72.arc32.json @@ -79,7 +79,7 @@ } }, "source": { - "approval": "#pragma version 10
intcblock 32 1 256
bytecblock 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF 0x151f7c75 0x696e646578 0x

// This TEAL was generated by TEALScript v0.104.1
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// arc72_ownerOf(uint256)address
*abi_route_arc72_ownerOf:
	// The ABI return prefix
	byte 0x151f7c75

	// tokenId: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (tokenId) for arc72_ownerOf must be a uint256
	assert

	// execute arc72_ownerOf(uint256)address
	callsub arc72_ownerOf
	concat
	log
	int 1
	return

// arc72_ownerOf(tokenId: uint256): Address
//
//
// Returns the address of the current owner of the NFT with the given tokenId
//
// @param tokenId The ID of the NFT
// @returns The current owner of the NFT
arc72_ownerOf:
	proto 1 1

	// examples/arc72/arc72.algo.ts:25
	// return this.tokenBox(tokenId).value.owner;
	frame_dig -1 // tokenId: uint256
	pushint 0
	int 32
	box_extract
	retsub

// arc72_tokenURI(uint256)byte[256]
*abi_route_arc72_tokenURI:
	// The ABI return prefix
	byte 0x151f7c75

	// tokenId: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (tokenId) for arc72_tokenURI must be a uint256
	assert

	// execute arc72_tokenURI(uint256)byte[256]
	callsub arc72_tokenURI
	concat
	log
	int 1
	return

// arc72_tokenURI(tokenId: uint256): Bytes256
//
//
// Returns a URI pointing to the NFT metadata
//
// @param tokenId The ID of the NFT
// @returns URI to token metadata
arc72_tokenURI:
	proto 1 1

	// examples/arc72/arc72.algo.ts:37
	// return this.tokenBox(tokenId).value.uri;
	frame_dig -1 // tokenId: uint256
	int 32 // headOffset
	int 256
	box_extract
	retsub

// transferTo(to: Address, tokenId: uint256): void
transferTo:
	proto 2 0

	// examples/arc72/arc72.algo.ts:41
	// this.tokenBox(tokenId).value.owner = to
	frame_dig -2 // tokenId: uint256
	pushint 0
	frame_dig -1 // to: Address
	box_replace
	retsub

// arc72_transferFrom(address,address,uint256)void
*abi_route_arc72_transferFrom:
	// tokenId: uint256
	txna ApplicationArgs 3
	dup
	len
	int 32
	==

	// argument 0 (tokenId) for arc72_transferFrom must be a uint256
	assert

	// to: address
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 1 (to) for arc72_transferFrom must be a address
	assert

	// _from: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 2 (_from) for arc72_transferFrom must be a address
	assert

	// execute arc72_transferFrom(address,address,uint256)void
	callsub arc72_transferFrom
	int 1
	return

// arc72_transferFrom(_from: Address, to: Address, tokenId: uint256): void
//
// Transfers ownership of an NFT
arc72_transferFrom:
	proto 3 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// examples/arc72/arc72.algo.ts:48
	// token = this.tokenBox(tokenId).value
	frame_dig -3 // tokenId: uint256
	frame_bury 0 // storage key//token

	// examples/arc72/arc72.algo.ts:50
	// key: Control = { owner: this.txn.sender, controller: _from }
	txn Sender
	frame_dig -1 // _from: Address
	concat
	frame_bury 1 // key: Control

	// *if0_condition
	// examples/arc72/arc72.algo.ts:52
	// this.txn.sender === _from || this.txn.sender === token.controller || this.controlBox(key).exists
	txn Sender
	frame_dig -1 // _from: Address
	==
	dup
	bnz *skip_or0
	txn Sender
	frame_dig -3 // tokenId: uint256
	pushint 288 // headOffset
	int 32
	box_extract
	==
	||

*skip_or0:
	dup
	bnz *skip_or1
	frame_dig 1 // key: Control
	box_len
	swap
	pop
	||

*skip_or1:
	bz *if0_else

	// *if0_consequent
	// examples/arc72/arc72.algo.ts:53
	// this.transferTo(to, tokenId)
	frame_dig -3 // tokenId: uint256
	frame_dig -2 // to: Address
	callsub transferTo
	b *if0_end

*if0_else:
	// Transfer not authorized
	err

*if0_end:
	retsub

// arc72_approve(address,uint256)void
*abi_route_arc72_approve:
	// tokenId: uint256
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (tokenId) for arc72_approve must be a uint256
	assert

	// approved: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (approved) for arc72_approve must be a address
	assert

	// execute arc72_approve(address,uint256)void
	callsub arc72_approve
	int 1
	return

// arc72_approve(approved: Address, tokenId: uint256): void
//
//
// Approve a controller for a single NFT
//
// @param approved Approved controller address
// @param tokenId The ID of the NFT
arc72_approve:
	proto 2 0

	// examples/arc72/arc72.algo.ts:65
	// this.tokenBox(tokenId).value.controller = approved
	frame_dig -2 // tokenId: uint256
	pushint 288 // headOffset
	frame_dig -1 // approved: Address
	box_replace
	retsub

// arc72_setApprovalForAll(address,bool)void
*abi_route_arc72_setApprovalForAll:
	// approved: bool
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 0 (approved) for arc72_setApprovalForAll must be a bool
	assert
	pushint 0
	getbit

	// operator: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (operator) for arc72_setApprovalForAll must be a address
	assert

	// execute arc72_setApprovalForAll(address,bool)void
	callsub arc72_setApprovalForAll
	int 1
	return

// arc72_setApprovalForAll(operator: Address, approved: boolean): void
//
//
// Approve an operator for all NFTs for a user
//
// @param operator Approved operator address
// @param approved true to give approval, false to revoke
// @returns
arc72_setApprovalForAll:
	proto 2 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/arc72/arc72.algo.ts:77
	// key: Control = { owner: this.txn.sender, controller: operator }
	txn Sender
	frame_dig -1 // operator: Address
	concat
	frame_bury 0 // key: Control

	// *if1_condition
	// examples/arc72/arc72.algo.ts:79
	// approved
	frame_dig -2 // approved: boolean
	bz *if1_elseif1_condition

	// *if1_consequent
	// examples/arc72/arc72.algo.ts:79
	// this.controlBox(key).value = ''
	frame_dig 0 // key: Control
	dup
	box_del
	pop
	byte 0x // ""
	box_put
	b *if1_end

*if1_elseif1_condition:
	// examples/arc72/arc72.algo.ts:80
	// this.controlBox(key).exists
	frame_dig 0 // key: Control
	box_len
	swap
	pop
	bz *if1_end

	// *if1_elseif1_consequent
	// examples/arc72/arc72.algo.ts:80
	// this.controlBox(key).delete()
	frame_dig 0 // key: Control
	box_del

*if1_end:
	retsub

// mint(address)void
*abi_route_mint:
	// to: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (to) for mint must be a address
	assert

	// execute mint(address)void
	callsub mint
	int 1
	return

// mint(to: Address): void
mint:
	proto 1 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// examples/arc72/arc72.algo.ts:84
	// index = this.index.value
	byte 0x696e646578 // "index"
	app_global_get
	frame_bury 0 // index: uint256

	// examples/arc72/arc72.algo.ts:86
	// token: Token = {
	//       owner: to,
	//       uri: 'https://github.com/algorandfoundation/ARCs' as Bytes256,
	//       controller: Address.zeroAddress,
	//     }
	frame_dig -1 // to: Address
	pushbytes 0x68747470733a2f2f6769746875622e636f6d2f616c676f72616e64666f756e646174696f6e2f4152437300000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 // "https://github.com/algorandfoundation/ARCs"
	concat
	global ZeroAddress
	concat
	frame_bury 1 // token: Token

	// examples/arc72/arc72.algo.ts:92
	// this.tokenBox(index).value = token
	frame_dig 0 // index: uint256
	frame_dig 1 // token: Token
	box_put

	// examples/arc72/arc72.algo.ts:93
	// this.transferTo(to, index)
	frame_dig 0 // index: uint256
	frame_dig -1 // to: Address
	callsub transferTo

	// examples/arc72/arc72.algo.ts:94
	// this.index.value = index + 1
	byte 0x696e646578 // "index"
	frame_dig 0 // index: uint256
	pushbytes 0x0000000000000000000000000000000000000000000000000000000000000001
	b+
	dup
	bitlen
	int 256
	<=

	// index + 1 overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	app_global_put
	retsub

// arc72_totalSupply()uint256
*abi_route_arc72_totalSupply:
	// The ABI return prefix
	byte 0x151f7c75

	// execute arc72_totalSupply()uint256
	callsub arc72_totalSupply
	dup
	bitlen
	int 256
	<=

	// arc72_totalSupply return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// arc72_totalSupply(): uint256
//
// Returns the number of NFTs currently defined by this contract
arc72_totalSupply:
	proto 0 1

	// examples/arc72/arc72.algo.ts:102
	// return this.index.value;
	byte 0x696e646578 // "index"
	app_global_get
	retsub

// arc72_tokenByIndex(uint256)uint256
*abi_route_arc72_tokenByIndex:
	// The ABI return prefix
	byte 0x151f7c75

	// index: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (index) for arc72_tokenByIndex must be a uint256
	assert

	// execute arc72_tokenByIndex(uint256)uint256
	callsub arc72_tokenByIndex
	dup
	bitlen
	int 256
	<=

	// arc72_tokenByIndex return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// arc72_tokenByIndex(index: uint256): uint256
//
// Returns the token ID of the token with the given index among all NFTs defined by the contract
arc72_tokenByIndex:
	proto 1 1

	// examples/arc72/arc72.algo.ts:110
	// return index;
	frame_dig -1 // index: uint256
	retsub

*abi_route_createApplication:
	int 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x79096a14 // method "arc72_ownerOf(uint256)address"
	pushbytes 0xc3c1fc00 // method "arc72_tokenURI(uint256)byte[256]"
	pushbytes 0xf2f194a0 // method "arc72_transferFrom(address,address,uint256)void"
	pushbytes 0xb4edba4e // method "arc72_approve(address,uint256)void"
	pushbytes 0x7134395f // method "arc72_setApprovalForAll(address,bool)void"
	pushbytes 0xac4cfadf // method "mint(address)void"
	pushbytes 0x64d72a7a // method "arc72_totalSupply()uint256"
	pushbytes 0x6d9bfd27 // method "arc72_tokenByIndex(uint256)uint256"
	txna ApplicationArgs 0
	match *abi_route_arc72_ownerOf *abi_route_arc72_tokenURI *abi_route_arc72_transferFrom *abi_route_arc72_approve *abi_route_arc72_setApprovalForAll *abi_route_mint *abi_route_arc72_totalSupply *abi_route_arc72_tokenByIndex

	// this contract does not implement the given ABI method for call NoOp
	err", + "approval": "#pragma version 10
intcblock 32 1 256
bytecblock 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF 0x151f7c75 0x696e646578 0x

// This TEAL was generated by TEALScript v0.105.0
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// arc72_ownerOf(uint256)address
*abi_route_arc72_ownerOf:
	// The ABI return prefix
	byte 0x151f7c75

	// tokenId: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (tokenId) for arc72_ownerOf must be a uint256
	assert

	// execute arc72_ownerOf(uint256)address
	callsub arc72_ownerOf
	concat
	log
	int 1
	return

// arc72_ownerOf(tokenId: uint256): Address
//
//
// Returns the address of the current owner of the NFT with the given tokenId
//
// @param tokenId The ID of the NFT
// @returns The current owner of the NFT
arc72_ownerOf:
	proto 1 1

	// examples/arc72/arc72.algo.ts:25
	// return this.tokenBox(tokenId).value.owner;
	frame_dig -1 // tokenId: uint256
	pushint 0
	int 32
	box_extract
	retsub

// arc72_tokenURI(uint256)byte[256]
*abi_route_arc72_tokenURI:
	// The ABI return prefix
	byte 0x151f7c75

	// tokenId: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (tokenId) for arc72_tokenURI must be a uint256
	assert

	// execute arc72_tokenURI(uint256)byte[256]
	callsub arc72_tokenURI
	concat
	log
	int 1
	return

// arc72_tokenURI(tokenId: uint256): Bytes256
//
//
// Returns a URI pointing to the NFT metadata
//
// @param tokenId The ID of the NFT
// @returns URI to token metadata
arc72_tokenURI:
	proto 1 1

	// examples/arc72/arc72.algo.ts:37
	// return this.tokenBox(tokenId).value.uri;
	frame_dig -1 // tokenId: uint256
	int 32 // headOffset
	int 256
	box_extract
	retsub

// transferTo(to: Address, tokenId: uint256): void
transferTo:
	proto 2 0

	// examples/arc72/arc72.algo.ts:41
	// this.tokenBox(tokenId).value.owner = to
	frame_dig -2 // tokenId: uint256
	pushint 0
	frame_dig -1 // to: Address
	box_replace
	retsub

// arc72_transferFrom(address,address,uint256)void
*abi_route_arc72_transferFrom:
	// tokenId: uint256
	txna ApplicationArgs 3
	dup
	len
	int 32
	==

	// argument 0 (tokenId) for arc72_transferFrom must be a uint256
	assert

	// to: address
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 1 (to) for arc72_transferFrom must be a address
	assert

	// _from: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 2 (_from) for arc72_transferFrom must be a address
	assert

	// execute arc72_transferFrom(address,address,uint256)void
	callsub arc72_transferFrom
	int 1
	return

// arc72_transferFrom(_from: Address, to: Address, tokenId: uint256): void
//
// Transfers ownership of an NFT
arc72_transferFrom:
	proto 3 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// examples/arc72/arc72.algo.ts:48
	// token = this.tokenBox(tokenId).value
	frame_dig -3 // tokenId: uint256
	frame_bury 0 // storage key//token

	// examples/arc72/arc72.algo.ts:50
	// key: Control = { owner: this.txn.sender, controller: _from }
	txn Sender
	frame_dig -1 // _from: Address
	concat
	frame_bury 1 // key: Control

	// *if0_condition
	// examples/arc72/arc72.algo.ts:52
	// this.txn.sender === _from || this.txn.sender === token.controller || this.controlBox(key).exists
	txn Sender
	frame_dig -1 // _from: Address
	==
	dup
	bnz *skip_or0
	txn Sender
	frame_dig -3 // tokenId: uint256
	pushint 288 // headOffset
	int 32
	box_extract
	==
	||

*skip_or0:
	dup
	bnz *skip_or1
	frame_dig 1 // key: Control
	box_len
	swap
	pop
	||

*skip_or1:
	bz *if0_else

	// *if0_consequent
	// examples/arc72/arc72.algo.ts:53
	// this.transferTo(to, tokenId)
	frame_dig -3 // tokenId: uint256
	frame_dig -2 // to: Address
	callsub transferTo
	b *if0_end

*if0_else:
	// Transfer not authorized
	err

*if0_end:
	retsub

// arc72_approve(address,uint256)void
*abi_route_arc72_approve:
	// tokenId: uint256
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (tokenId) for arc72_approve must be a uint256
	assert

	// approved: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (approved) for arc72_approve must be a address
	assert

	// execute arc72_approve(address,uint256)void
	callsub arc72_approve
	int 1
	return

// arc72_approve(approved: Address, tokenId: uint256): void
//
//
// Approve a controller for a single NFT
//
// @param approved Approved controller address
// @param tokenId The ID of the NFT
arc72_approve:
	proto 2 0

	// examples/arc72/arc72.algo.ts:65
	// this.tokenBox(tokenId).value.controller = approved
	frame_dig -2 // tokenId: uint256
	pushint 288 // headOffset
	frame_dig -1 // approved: Address
	box_replace
	retsub

// arc72_setApprovalForAll(address,bool)void
*abi_route_arc72_setApprovalForAll:
	// approved: bool
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 0 (approved) for arc72_setApprovalForAll must be a bool
	assert
	pushint 0
	getbit

	// operator: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (operator) for arc72_setApprovalForAll must be a address
	assert

	// execute arc72_setApprovalForAll(address,bool)void
	callsub arc72_setApprovalForAll
	int 1
	return

// arc72_setApprovalForAll(operator: Address, approved: boolean): void
//
//
// Approve an operator for all NFTs for a user
//
// @param operator Approved operator address
// @param approved true to give approval, false to revoke
// @returns
arc72_setApprovalForAll:
	proto 2 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/arc72/arc72.algo.ts:77
	// key: Control = { owner: this.txn.sender, controller: operator }
	txn Sender
	frame_dig -1 // operator: Address
	concat
	frame_bury 0 // key: Control

	// *if1_condition
	// examples/arc72/arc72.algo.ts:79
	// approved
	frame_dig -2 // approved: boolean
	bz *if1_elseif1_condition

	// *if1_consequent
	// examples/arc72/arc72.algo.ts:79
	// this.controlBox(key).value = ''
	frame_dig 0 // key: Control
	dup
	box_del
	pop
	byte 0x // ""
	box_put
	b *if1_end

*if1_elseif1_condition:
	// examples/arc72/arc72.algo.ts:80
	// this.controlBox(key).exists
	frame_dig 0 // key: Control
	box_len
	swap
	pop
	bz *if1_end

	// *if1_elseif1_consequent
	// examples/arc72/arc72.algo.ts:80
	// this.controlBox(key).delete()
	frame_dig 0 // key: Control
	box_del

*if1_end:
	retsub

// mint(address)void
*abi_route_mint:
	// to: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (to) for mint must be a address
	assert

	// execute mint(address)void
	callsub mint
	int 1
	return

// mint(to: Address): void
mint:
	proto 1 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// examples/arc72/arc72.algo.ts:84
	// index = this.index.value
	byte 0x696e646578 // "index"
	app_global_get
	frame_bury 0 // index: uint256

	// examples/arc72/arc72.algo.ts:86
	// token: Token = {
	//       owner: to,
	//       uri: 'https://github.com/algorandfoundation/ARCs' as Bytes256,
	//       controller: Address.zeroAddress,
	//     }
	frame_dig -1 // to: Address
	pushbytes 0x68747470733a2f2f6769746875622e636f6d2f616c676f72616e64666f756e646174696f6e2f4152437300000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 // "https://github.com/algorandfoundation/ARCs"
	concat
	global ZeroAddress
	concat
	frame_bury 1 // token: Token

	// examples/arc72/arc72.algo.ts:92
	// this.tokenBox(index).value = token
	frame_dig 0 // index: uint256
	frame_dig 1 // token: Token
	box_put

	// examples/arc72/arc72.algo.ts:93
	// this.transferTo(to, index)
	frame_dig 0 // index: uint256
	frame_dig -1 // to: Address
	callsub transferTo

	// examples/arc72/arc72.algo.ts:94
	// this.index.value = index + 1
	byte 0x696e646578 // "index"
	frame_dig 0 // index: uint256
	pushbytes 0x0000000000000000000000000000000000000000000000000000000000000001
	b+
	dup
	bitlen
	int 256
	<=

	// index + 1 overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	app_global_put
	retsub

// arc72_totalSupply()uint256
*abi_route_arc72_totalSupply:
	// The ABI return prefix
	byte 0x151f7c75

	// execute arc72_totalSupply()uint256
	callsub arc72_totalSupply
	dup
	bitlen
	int 256
	<=

	// arc72_totalSupply return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// arc72_totalSupply(): uint256
//
// Returns the number of NFTs currently defined by this contract
arc72_totalSupply:
	proto 0 1

	// examples/arc72/arc72.algo.ts:102
	// return this.index.value;
	byte 0x696e646578 // "index"
	app_global_get
	retsub

// arc72_tokenByIndex(uint256)uint256
*abi_route_arc72_tokenByIndex:
	// The ABI return prefix
	byte 0x151f7c75

	// index: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (index) for arc72_tokenByIndex must be a uint256
	assert

	// execute arc72_tokenByIndex(uint256)uint256
	callsub arc72_tokenByIndex
	dup
	bitlen
	int 256
	<=

	// arc72_tokenByIndex return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// arc72_tokenByIndex(index: uint256): uint256
//
// Returns the token ID of the token with the given index among all NFTs defined by the contract
arc72_tokenByIndex:
	proto 1 1

	// examples/arc72/arc72.algo.ts:110
	// return index;
	frame_dig -1 // index: uint256
	retsub

*abi_route_createApplication:
	int 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x79096a14 // method "arc72_ownerOf(uint256)address"
	pushbytes 0xc3c1fc00 // method "arc72_tokenURI(uint256)byte[256]"
	pushbytes 0xf2f194a0 // method "arc72_transferFrom(address,address,uint256)void"
	pushbytes 0xb4edba4e // method "arc72_approve(address,uint256)void"
	pushbytes 0x7134395f // method "arc72_setApprovalForAll(address,bool)void"
	pushbytes 0xac4cfadf // method "mint(address)void"
	pushbytes 0x64d72a7a // method "arc72_totalSupply()uint256"
	pushbytes 0x6d9bfd27 // method "arc72_tokenByIndex(uint256)uint256"
	txna ApplicationArgs 0
	match *abi_route_arc72_ownerOf *abi_route_arc72_tokenURI *abi_route_arc72_transferFrom *abi_route_arc72_approve *abi_route_arc72_setApprovalForAll *abi_route_mint *abi_route_arc72_totalSupply *abi_route_arc72_tokenByIndex

	// this contract does not implement the given ABI method for call NoOp
	err", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/examples/arc72/artifacts/ARC72.arc56_draft.json b/examples/arc72/artifacts/ARC72.arc56_draft.json index 0597ae530..78c8f1908 100644 --- a/examples/arc72/artifacts/ARC72.arc56_draft.json +++ b/examples/arc72/artifacts/ARC72.arc56_draft.json @@ -3030,7 +3030,7 @@ } }, "source": { - "approval": "#pragma version 10
intcblock 32 1 256
bytecblock 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF 0x151f7c75 0x696e646578 0x

// This TEAL was generated by TEALScript v0.104.1
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// arc72_ownerOf(uint256)address
*abi_route_arc72_ownerOf:
	// The ABI return prefix
	byte 0x151f7c75

	// tokenId: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (tokenId) for arc72_ownerOf must be a uint256
	assert

	// execute arc72_ownerOf(uint256)address
	callsub arc72_ownerOf
	concat
	log
	int 1
	return

// arc72_ownerOf(tokenId: uint256): Address
//
//
// Returns the address of the current owner of the NFT with the given tokenId
//
// @param tokenId The ID of the NFT
// @returns The current owner of the NFT
arc72_ownerOf:
	proto 1 1

	// examples/arc72/arc72.algo.ts:25
	// return this.tokenBox(tokenId).value.owner;
	frame_dig -1 // tokenId: uint256
	pushint 0
	int 32
	box_extract
	retsub

// arc72_tokenURI(uint256)byte[256]
*abi_route_arc72_tokenURI:
	// The ABI return prefix
	byte 0x151f7c75

	// tokenId: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (tokenId) for arc72_tokenURI must be a uint256
	assert

	// execute arc72_tokenURI(uint256)byte[256]
	callsub arc72_tokenURI
	concat
	log
	int 1
	return

// arc72_tokenURI(tokenId: uint256): Bytes256
//
//
// Returns a URI pointing to the NFT metadata
//
// @param tokenId The ID of the NFT
// @returns URI to token metadata
arc72_tokenURI:
	proto 1 1

	// examples/arc72/arc72.algo.ts:37
	// return this.tokenBox(tokenId).value.uri;
	frame_dig -1 // tokenId: uint256
	int 32 // headOffset
	int 256
	box_extract
	retsub

// transferTo(to: Address, tokenId: uint256): void
transferTo:
	proto 2 0

	// examples/arc72/arc72.algo.ts:41
	// this.tokenBox(tokenId).value.owner = to
	frame_dig -2 // tokenId: uint256
	pushint 0
	frame_dig -1 // to: Address
	box_replace
	retsub

// arc72_transferFrom(address,address,uint256)void
*abi_route_arc72_transferFrom:
	// tokenId: uint256
	txna ApplicationArgs 3
	dup
	len
	int 32
	==

	// argument 0 (tokenId) for arc72_transferFrom must be a uint256
	assert

	// to: address
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 1 (to) for arc72_transferFrom must be a address
	assert

	// _from: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 2 (_from) for arc72_transferFrom must be a address
	assert

	// execute arc72_transferFrom(address,address,uint256)void
	callsub arc72_transferFrom
	int 1
	return

// arc72_transferFrom(_from: Address, to: Address, tokenId: uint256): void
//
// Transfers ownership of an NFT
arc72_transferFrom:
	proto 3 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// examples/arc72/arc72.algo.ts:48
	// token = this.tokenBox(tokenId).value
	frame_dig -3 // tokenId: uint256
	frame_bury 0 // storage key//token

	// examples/arc72/arc72.algo.ts:50
	// key: Control = { owner: this.txn.sender, controller: _from }
	txn Sender
	frame_dig -1 // _from: Address
	concat
	frame_bury 1 // key: Control

	// *if0_condition
	// examples/arc72/arc72.algo.ts:52
	// this.txn.sender === _from || this.txn.sender === token.controller || this.controlBox(key).exists
	txn Sender
	frame_dig -1 // _from: Address
	==
	dup
	bnz *skip_or0
	txn Sender
	frame_dig -3 // tokenId: uint256
	pushint 288 // headOffset
	int 32
	box_extract
	==
	||

*skip_or0:
	dup
	bnz *skip_or1
	frame_dig 1 // key: Control
	box_len
	swap
	pop
	||

*skip_or1:
	bz *if0_else

	// *if0_consequent
	// examples/arc72/arc72.algo.ts:53
	// this.transferTo(to, tokenId)
	frame_dig -3 // tokenId: uint256
	frame_dig -2 // to: Address
	callsub transferTo
	b *if0_end

*if0_else:
	// Transfer not authorized
	err

*if0_end:
	retsub

// arc72_approve(address,uint256)void
*abi_route_arc72_approve:
	// tokenId: uint256
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (tokenId) for arc72_approve must be a uint256
	assert

	// approved: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (approved) for arc72_approve must be a address
	assert

	// execute arc72_approve(address,uint256)void
	callsub arc72_approve
	int 1
	return

// arc72_approve(approved: Address, tokenId: uint256): void
//
//
// Approve a controller for a single NFT
//
// @param approved Approved controller address
// @param tokenId The ID of the NFT
arc72_approve:
	proto 2 0

	// examples/arc72/arc72.algo.ts:65
	// this.tokenBox(tokenId).value.controller = approved
	frame_dig -2 // tokenId: uint256
	pushint 288 // headOffset
	frame_dig -1 // approved: Address
	box_replace
	retsub

// arc72_setApprovalForAll(address,bool)void
*abi_route_arc72_setApprovalForAll:
	// approved: bool
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 0 (approved) for arc72_setApprovalForAll must be a bool
	assert
	pushint 0
	getbit

	// operator: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (operator) for arc72_setApprovalForAll must be a address
	assert

	// execute arc72_setApprovalForAll(address,bool)void
	callsub arc72_setApprovalForAll
	int 1
	return

// arc72_setApprovalForAll(operator: Address, approved: boolean): void
//
//
// Approve an operator for all NFTs for a user
//
// @param operator Approved operator address
// @param approved true to give approval, false to revoke
// @returns
arc72_setApprovalForAll:
	proto 2 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/arc72/arc72.algo.ts:77
	// key: Control = { owner: this.txn.sender, controller: operator }
	txn Sender
	frame_dig -1 // operator: Address
	concat
	frame_bury 0 // key: Control

	// *if1_condition
	// examples/arc72/arc72.algo.ts:79
	// approved
	frame_dig -2 // approved: boolean
	bz *if1_elseif1_condition

	// *if1_consequent
	// examples/arc72/arc72.algo.ts:79
	// this.controlBox(key).value = ''
	frame_dig 0 // key: Control
	dup
	box_del
	pop
	byte 0x // ""
	box_put
	b *if1_end

*if1_elseif1_condition:
	// examples/arc72/arc72.algo.ts:80
	// this.controlBox(key).exists
	frame_dig 0 // key: Control
	box_len
	swap
	pop
	bz *if1_end

	// *if1_elseif1_consequent
	// examples/arc72/arc72.algo.ts:80
	// this.controlBox(key).delete()
	frame_dig 0 // key: Control
	box_del

*if1_end:
	retsub

// mint(address)void
*abi_route_mint:
	// to: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (to) for mint must be a address
	assert

	// execute mint(address)void
	callsub mint
	int 1
	return

// mint(to: Address): void
mint:
	proto 1 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// examples/arc72/arc72.algo.ts:84
	// index = this.index.value
	byte 0x696e646578 // "index"
	app_global_get
	frame_bury 0 // index: uint256

	// examples/arc72/arc72.algo.ts:86
	// token: Token = {
	//       owner: to,
	//       uri: 'https://github.com/algorandfoundation/ARCs' as Bytes256,
	//       controller: Address.zeroAddress,
	//     }
	frame_dig -1 // to: Address
	pushbytes 0x68747470733a2f2f6769746875622e636f6d2f616c676f72616e64666f756e646174696f6e2f4152437300000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 // "https://github.com/algorandfoundation/ARCs"
	concat
	global ZeroAddress
	concat
	frame_bury 1 // token: Token

	// examples/arc72/arc72.algo.ts:92
	// this.tokenBox(index).value = token
	frame_dig 0 // index: uint256
	frame_dig 1 // token: Token
	box_put

	// examples/arc72/arc72.algo.ts:93
	// this.transferTo(to, index)
	frame_dig 0 // index: uint256
	frame_dig -1 // to: Address
	callsub transferTo

	// examples/arc72/arc72.algo.ts:94
	// this.index.value = index + 1
	byte 0x696e646578 // "index"
	frame_dig 0 // index: uint256
	pushbytes 0x0000000000000000000000000000000000000000000000000000000000000001
	b+
	dup
	bitlen
	int 256
	<=

	// index + 1 overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	app_global_put
	retsub

// arc72_totalSupply()uint256
*abi_route_arc72_totalSupply:
	// The ABI return prefix
	byte 0x151f7c75

	// execute arc72_totalSupply()uint256
	callsub arc72_totalSupply
	dup
	bitlen
	int 256
	<=

	// arc72_totalSupply return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// arc72_totalSupply(): uint256
//
// Returns the number of NFTs currently defined by this contract
arc72_totalSupply:
	proto 0 1

	// examples/arc72/arc72.algo.ts:102
	// return this.index.value;
	byte 0x696e646578 // "index"
	app_global_get
	retsub

// arc72_tokenByIndex(uint256)uint256
*abi_route_arc72_tokenByIndex:
	// The ABI return prefix
	byte 0x151f7c75

	// index: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (index) for arc72_tokenByIndex must be a uint256
	assert

	// execute arc72_tokenByIndex(uint256)uint256
	callsub arc72_tokenByIndex
	dup
	bitlen
	int 256
	<=

	// arc72_tokenByIndex return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// arc72_tokenByIndex(index: uint256): uint256
//
// Returns the token ID of the token with the given index among all NFTs defined by the contract
arc72_tokenByIndex:
	proto 1 1

	// examples/arc72/arc72.algo.ts:110
	// return index;
	frame_dig -1 // index: uint256
	retsub

*abi_route_createApplication:
	int 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x79096a14 // method "arc72_ownerOf(uint256)address"
	pushbytes 0xc3c1fc00 // method "arc72_tokenURI(uint256)byte[256]"
	pushbytes 0xf2f194a0 // method "arc72_transferFrom(address,address,uint256)void"
	pushbytes 0xb4edba4e // method "arc72_approve(address,uint256)void"
	pushbytes 0x7134395f // method "arc72_setApprovalForAll(address,bool)void"
	pushbytes 0xac4cfadf // method "mint(address)void"
	pushbytes 0x64d72a7a // method "arc72_totalSupply()uint256"
	pushbytes 0x6d9bfd27 // method "arc72_tokenByIndex(uint256)uint256"
	txna ApplicationArgs 0
	match *abi_route_arc72_ownerOf *abi_route_arc72_tokenURI *abi_route_arc72_transferFrom *abi_route_arc72_approve *abi_route_arc72_setApprovalForAll *abi_route_mint *abi_route_arc72_totalSupply *abi_route_arc72_tokenByIndex

	// this contract does not implement the given ABI method for call NoOp
	err", + "approval": "#pragma version 10
intcblock 32 1 256
bytecblock 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF 0x151f7c75 0x696e646578 0x

// This TEAL was generated by TEALScript v0.105.0
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// arc72_ownerOf(uint256)address
*abi_route_arc72_ownerOf:
	// The ABI return prefix
	byte 0x151f7c75

	// tokenId: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (tokenId) for arc72_ownerOf must be a uint256
	assert

	// execute arc72_ownerOf(uint256)address
	callsub arc72_ownerOf
	concat
	log
	int 1
	return

// arc72_ownerOf(tokenId: uint256): Address
//
//
// Returns the address of the current owner of the NFT with the given tokenId
//
// @param tokenId The ID of the NFT
// @returns The current owner of the NFT
arc72_ownerOf:
	proto 1 1

	// examples/arc72/arc72.algo.ts:25
	// return this.tokenBox(tokenId).value.owner;
	frame_dig -1 // tokenId: uint256
	pushint 0
	int 32
	box_extract
	retsub

// arc72_tokenURI(uint256)byte[256]
*abi_route_arc72_tokenURI:
	// The ABI return prefix
	byte 0x151f7c75

	// tokenId: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (tokenId) for arc72_tokenURI must be a uint256
	assert

	// execute arc72_tokenURI(uint256)byte[256]
	callsub arc72_tokenURI
	concat
	log
	int 1
	return

// arc72_tokenURI(tokenId: uint256): Bytes256
//
//
// Returns a URI pointing to the NFT metadata
//
// @param tokenId The ID of the NFT
// @returns URI to token metadata
arc72_tokenURI:
	proto 1 1

	// examples/arc72/arc72.algo.ts:37
	// return this.tokenBox(tokenId).value.uri;
	frame_dig -1 // tokenId: uint256
	int 32 // headOffset
	int 256
	box_extract
	retsub

// transferTo(to: Address, tokenId: uint256): void
transferTo:
	proto 2 0

	// examples/arc72/arc72.algo.ts:41
	// this.tokenBox(tokenId).value.owner = to
	frame_dig -2 // tokenId: uint256
	pushint 0
	frame_dig -1 // to: Address
	box_replace
	retsub

// arc72_transferFrom(address,address,uint256)void
*abi_route_arc72_transferFrom:
	// tokenId: uint256
	txna ApplicationArgs 3
	dup
	len
	int 32
	==

	// argument 0 (tokenId) for arc72_transferFrom must be a uint256
	assert

	// to: address
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 1 (to) for arc72_transferFrom must be a address
	assert

	// _from: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 2 (_from) for arc72_transferFrom must be a address
	assert

	// execute arc72_transferFrom(address,address,uint256)void
	callsub arc72_transferFrom
	int 1
	return

// arc72_transferFrom(_from: Address, to: Address, tokenId: uint256): void
//
// Transfers ownership of an NFT
arc72_transferFrom:
	proto 3 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// examples/arc72/arc72.algo.ts:48
	// token = this.tokenBox(tokenId).value
	frame_dig -3 // tokenId: uint256
	frame_bury 0 // storage key//token

	// examples/arc72/arc72.algo.ts:50
	// key: Control = { owner: this.txn.sender, controller: _from }
	txn Sender
	frame_dig -1 // _from: Address
	concat
	frame_bury 1 // key: Control

	// *if0_condition
	// examples/arc72/arc72.algo.ts:52
	// this.txn.sender === _from || this.txn.sender === token.controller || this.controlBox(key).exists
	txn Sender
	frame_dig -1 // _from: Address
	==
	dup
	bnz *skip_or0
	txn Sender
	frame_dig -3 // tokenId: uint256
	pushint 288 // headOffset
	int 32
	box_extract
	==
	||

*skip_or0:
	dup
	bnz *skip_or1
	frame_dig 1 // key: Control
	box_len
	swap
	pop
	||

*skip_or1:
	bz *if0_else

	// *if0_consequent
	// examples/arc72/arc72.algo.ts:53
	// this.transferTo(to, tokenId)
	frame_dig -3 // tokenId: uint256
	frame_dig -2 // to: Address
	callsub transferTo
	b *if0_end

*if0_else:
	// Transfer not authorized
	err

*if0_end:
	retsub

// arc72_approve(address,uint256)void
*abi_route_arc72_approve:
	// tokenId: uint256
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (tokenId) for arc72_approve must be a uint256
	assert

	// approved: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (approved) for arc72_approve must be a address
	assert

	// execute arc72_approve(address,uint256)void
	callsub arc72_approve
	int 1
	return

// arc72_approve(approved: Address, tokenId: uint256): void
//
//
// Approve a controller for a single NFT
//
// @param approved Approved controller address
// @param tokenId The ID of the NFT
arc72_approve:
	proto 2 0

	// examples/arc72/arc72.algo.ts:65
	// this.tokenBox(tokenId).value.controller = approved
	frame_dig -2 // tokenId: uint256
	pushint 288 // headOffset
	frame_dig -1 // approved: Address
	box_replace
	retsub

// arc72_setApprovalForAll(address,bool)void
*abi_route_arc72_setApprovalForAll:
	// approved: bool
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 0 (approved) for arc72_setApprovalForAll must be a bool
	assert
	pushint 0
	getbit

	// operator: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (operator) for arc72_setApprovalForAll must be a address
	assert

	// execute arc72_setApprovalForAll(address,bool)void
	callsub arc72_setApprovalForAll
	int 1
	return

// arc72_setApprovalForAll(operator: Address, approved: boolean): void
//
//
// Approve an operator for all NFTs for a user
//
// @param operator Approved operator address
// @param approved true to give approval, false to revoke
// @returns
arc72_setApprovalForAll:
	proto 2 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/arc72/arc72.algo.ts:77
	// key: Control = { owner: this.txn.sender, controller: operator }
	txn Sender
	frame_dig -1 // operator: Address
	concat
	frame_bury 0 // key: Control

	// *if1_condition
	// examples/arc72/arc72.algo.ts:79
	// approved
	frame_dig -2 // approved: boolean
	bz *if1_elseif1_condition

	// *if1_consequent
	// examples/arc72/arc72.algo.ts:79
	// this.controlBox(key).value = ''
	frame_dig 0 // key: Control
	dup
	box_del
	pop
	byte 0x // ""
	box_put
	b *if1_end

*if1_elseif1_condition:
	// examples/arc72/arc72.algo.ts:80
	// this.controlBox(key).exists
	frame_dig 0 // key: Control
	box_len
	swap
	pop
	bz *if1_end

	// *if1_elseif1_consequent
	// examples/arc72/arc72.algo.ts:80
	// this.controlBox(key).delete()
	frame_dig 0 // key: Control
	box_del

*if1_end:
	retsub

// mint(address)void
*abi_route_mint:
	// to: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (to) for mint must be a address
	assert

	// execute mint(address)void
	callsub mint
	int 1
	return

// mint(to: Address): void
mint:
	proto 1 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// examples/arc72/arc72.algo.ts:84
	// index = this.index.value
	byte 0x696e646578 // "index"
	app_global_get
	frame_bury 0 // index: uint256

	// examples/arc72/arc72.algo.ts:86
	// token: Token = {
	//       owner: to,
	//       uri: 'https://github.com/algorandfoundation/ARCs' as Bytes256,
	//       controller: Address.zeroAddress,
	//     }
	frame_dig -1 // to: Address
	pushbytes 0x68747470733a2f2f6769746875622e636f6d2f616c676f72616e64666f756e646174696f6e2f4152437300000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 // "https://github.com/algorandfoundation/ARCs"
	concat
	global ZeroAddress
	concat
	frame_bury 1 // token: Token

	// examples/arc72/arc72.algo.ts:92
	// this.tokenBox(index).value = token
	frame_dig 0 // index: uint256
	frame_dig 1 // token: Token
	box_put

	// examples/arc72/arc72.algo.ts:93
	// this.transferTo(to, index)
	frame_dig 0 // index: uint256
	frame_dig -1 // to: Address
	callsub transferTo

	// examples/arc72/arc72.algo.ts:94
	// this.index.value = index + 1
	byte 0x696e646578 // "index"
	frame_dig 0 // index: uint256
	pushbytes 0x0000000000000000000000000000000000000000000000000000000000000001
	b+
	dup
	bitlen
	int 256
	<=

	// index + 1 overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	app_global_put
	retsub

// arc72_totalSupply()uint256
*abi_route_arc72_totalSupply:
	// The ABI return prefix
	byte 0x151f7c75

	// execute arc72_totalSupply()uint256
	callsub arc72_totalSupply
	dup
	bitlen
	int 256
	<=

	// arc72_totalSupply return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// arc72_totalSupply(): uint256
//
// Returns the number of NFTs currently defined by this contract
arc72_totalSupply:
	proto 0 1

	// examples/arc72/arc72.algo.ts:102
	// return this.index.value;
	byte 0x696e646578 // "index"
	app_global_get
	retsub

// arc72_tokenByIndex(uint256)uint256
*abi_route_arc72_tokenByIndex:
	// The ABI return prefix
	byte 0x151f7c75

	// index: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (index) for arc72_tokenByIndex must be a uint256
	assert

	// execute arc72_tokenByIndex(uint256)uint256
	callsub arc72_tokenByIndex
	dup
	bitlen
	int 256
	<=

	// arc72_tokenByIndex return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// arc72_tokenByIndex(index: uint256): uint256
//
// Returns the token ID of the token with the given index among all NFTs defined by the contract
arc72_tokenByIndex:
	proto 1 1

	// examples/arc72/arc72.algo.ts:110
	// return index;
	frame_dig -1 // index: uint256
	retsub

*abi_route_createApplication:
	int 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x79096a14 // method "arc72_ownerOf(uint256)address"
	pushbytes 0xc3c1fc00 // method "arc72_tokenURI(uint256)byte[256]"
	pushbytes 0xf2f194a0 // method "arc72_transferFrom(address,address,uint256)void"
	pushbytes 0xb4edba4e // method "arc72_approve(address,uint256)void"
	pushbytes 0x7134395f // method "arc72_setApprovalForAll(address,bool)void"
	pushbytes 0xac4cfadf // method "mint(address)void"
	pushbytes 0x64d72a7a // method "arc72_totalSupply()uint256"
	pushbytes 0x6d9bfd27 // method "arc72_tokenByIndex(uint256)uint256"
	txna ApplicationArgs 0
	match *abi_route_arc72_ownerOf *abi_route_arc72_tokenURI *abi_route_arc72_transferFrom *abi_route_arc72_approve *abi_route_arc72_setApprovalForAll *abi_route_mint *abi_route_arc72_totalSupply *abi_route_arc72_tokenByIndex

	// this contract does not implement the given ABI method for call NoOp
	err", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/examples/arc75/artifacts/ARC75.approval.teal b/examples/arc75/artifacts/ARC75.approval.teal index 7062323ee..83d55d8c7 100644 --- a/examples/arc75/artifacts/ARC75.approval.teal +++ b/examples/arc75/artifacts/ARC75.approval.teal @@ -2,7 +2,7 @@ intcblock 1 bytecblock 0x 0x0024 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/examples/arc75/artifacts/ARC75.arc32.json b/examples/arc75/artifacts/ARC75.arc32.json index b7b587150..7fb4187f4 100644 --- a/examples/arc75/artifacts/ARC75.arc32.json +++ b/examples/arc75/artifacts/ARC75.arc32.json @@ -54,7 +54,7 @@ } }, "source": { - "approval": "#pragma version 10
intcblock 1
bytecblock 0x 0x0024

// This TEAL was generated by TEALScript v0.104.1
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// verifyMBRPayment(payment: PayTxn, preMBR: uint64): void
verifyMBRPayment:
	proto 2 0

	// examples/arc75/arc75.algo.ts:10
	// verifyPayTxn(payment, {
	//       receiver: this.app.address,
	//       amount: this.app.address.minBalance - preMBR,
	//     })
	// verify receiver
	frame_dig -1 // payment: PayTxn
	gtxns Receiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"payment","field":"receiver","expected":"this.app.address"}
	assert

	// verify amount
	frame_dig -1 // payment: PayTxn
	gtxns Amount
	global CurrentApplicationAddress
	acct_params_get AcctMinBalance
	pop
	frame_dig -2 // preMBR: uint64
	-
	==

	// transaction verification failed: {"txn":"payment","field":"amount","expected":"this.app.address.minBalance - preMBR"}
	assert
	retsub

// sendMBRPayment(preMBR: uint64): void
sendMBRPayment:
	proto 1 0

	// examples/arc75/arc75.algo.ts:17
	// sendPayment({
	//       receiver: this.txn.sender,
	//       amount: preMBR - this.app.address.minBalance,
	//     })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// examples/arc75/arc75.algo.ts:18
	// receiver: this.txn.sender
	txn Sender
	itxn_field Receiver

	// examples/arc75/arc75.algo.ts:19
	// amount: preMBR - this.app.address.minBalance
	frame_dig -1 // preMBR: uint64
	global CurrentApplicationAddress
	acct_params_get AcctMinBalance
	pop
	-
	itxn_field Amount

	// Fee field not set, defaulting to 0
	pushint 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// addAppToWhiteList(string,uint16,uint64,pay)void
*abi_route_addAppToWhiteList:
	// payment: pay
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// argument 0 (payment) for addAppToWhiteList must be a pay transaction
	assert

	// appID: uint64
	txna ApplicationArgs 3
	btoi

	// boxIndex: uint16
	txna ApplicationArgs 2
	dup
	len
	pushint 2
	==

	// argument 2 (boxIndex) for addAppToWhiteList must be a uint16
	assert
	btoi

	// arc: string
	txna ApplicationArgs 1
	extract 2 0

	// execute addAppToWhiteList(string,uint16,uint64,pay)void
	callsub addAppToWhiteList
	int 1
	return

// addAppToWhiteList(arc: string, boxIndex: uint16, appID: uint64, payment: PayTxn): void
//
// Add app to whitelist box
//
// @param arc - The ARC the whitelist corresponds to
// @param boxIndex - The index of the whitelist box to add the app to
// @param appID - The app ID to add to the whitelist
// @param payment - The payment transaction to cover the MBR change
addAppToWhiteList:
	proto 4 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// examples/arc75/arc75.algo.ts:33
	// preMBR = this.app.address.minBalance
	global CurrentApplicationAddress
	acct_params_get AcctMinBalance
	pop
	frame_bury 0 // preMBR: uint64

	// examples/arc75/arc75.algo.ts:34
	// whitelist: Whitelist = { account: this.txn.sender, boxIndex: boxIndex, arc: arc }
	byte 0x // initial head
	byte 0x // initial tail
	byte 0x0024 // initial head offset
	txn Sender
	callsub *process_static_tuple_element
	frame_dig -2 // boxIndex: uint16
	itob
	extract 6 2
	callsub *process_static_tuple_element
	frame_dig -1 // arc: string
	dup
	len
	itob
	extract 6 2
	swap
	concat
	callsub *process_dynamic_tuple_element
	pop // pop head offset
	concat // concat head and tail
	frame_bury 1 // whitelist: Whitelist

	// *if0_condition
	// examples/arc75/arc75.algo.ts:36
	// this.whitelist(whitelist).exists
	frame_dig 1 // whitelist: Whitelist
	box_len
	swap
	pop
	bz *if0_else

	// *if0_consequent
	// examples/arc75/arc75.algo.ts:37
	// this.whitelist(whitelist).value.push(appID)
	frame_dig 1 // whitelist: Whitelist
	box_get

	// box value does not exist: this.whitelist(whitelist).value
	assert
	extract 2 0
	frame_dig -3 // appID: uint64
	itob
	concat
	frame_dig 1 // whitelist: Whitelist
	dup
	box_del
	pop
	swap
	dup
	len
	pushint 8
	/
	itob
	extract 6 2
	swap
	concat
	box_put
	b *if0_end

*if0_else:
	// examples/arc75/arc75.algo.ts:39
	// newWhitelist: uint64[] = [appID]
	frame_dig -3 // appID: uint64
	itob
	frame_bury 2 // newWhitelist: uint64[]

	// examples/arc75/arc75.algo.ts:40
	// this.whitelist(whitelist).value = newWhitelist
	frame_dig 1 // whitelist: Whitelist
	dup
	box_del
	pop
	frame_dig 2 // newWhitelist: uint64[]
	dup
	len
	pushint 8
	/
	itob
	extract 6 2
	swap
	concat
	box_put

*if0_end:
	// examples/arc75/arc75.algo.ts:43
	// this.verifyMBRPayment(payment, preMBR)
	frame_dig 0 // preMBR: uint64
	frame_dig -4 // payment: PayTxn
	callsub verifyMBRPayment
	retsub

// setAppWhitelist(string,uint16,uint64[])void
*abi_route_setAppWhitelist:
	// appIDs: uint64[]
	txna ApplicationArgs 3
	extract 2 0

	// boxIndex: uint16
	txna ApplicationArgs 2
	dup
	len
	pushint 2
	==

	// argument 1 (boxIndex) for setAppWhitelist must be a uint16
	assert
	btoi

	// arc: string
	txna ApplicationArgs 1
	extract 2 0

	// execute setAppWhitelist(string,uint16,uint64[])void
	callsub setAppWhitelist
	int 1
	return

// setAppWhitelist(arc: string, boxIndex: uint16, appIDs: uint64[]): void
//
// Sets a app whitelist for the sender. Should only be used when adding/removing
// more than one app
//
// @param boxIndex - The index of the whitelist box to put the app IDs in
// @param appIDs - Array of app IDs that signify the whitelisted apps
setAppWhitelist:
	proto 3 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// examples/arc75/arc75.algo.ts:55
	// preMBR = this.app.address.minBalance
	global CurrentApplicationAddress
	acct_params_get AcctMinBalance
	pop
	frame_bury 0 // preMBR: uint64

	// examples/arc75/arc75.algo.ts:56
	// whitelist: Whitelist = { account: this.txn.sender, boxIndex: boxIndex, arc: arc }
	byte 0x // initial head
	byte 0x // initial tail
	byte 0x0024 // initial head offset
	txn Sender
	callsub *process_static_tuple_element
	frame_dig -2 // boxIndex: uint16
	itob
	extract 6 2
	callsub *process_static_tuple_element
	frame_dig -1 // arc: string
	dup
	len
	itob
	extract 6 2
	swap
	concat
	callsub *process_dynamic_tuple_element
	pop // pop head offset
	concat // concat head and tail
	frame_bury 1 // whitelist: Whitelist

	// examples/arc75/arc75.algo.ts:58
	// this.whitelist(whitelist).delete()
	frame_dig 1 // whitelist: Whitelist
	box_del

	// examples/arc75/arc75.algo.ts:60
	// this.whitelist(whitelist).value = appIDs
	frame_dig 1 // whitelist: Whitelist
	dup
	box_del
	pop
	frame_dig -3 // appIDs: uint64[]
	dup
	len
	pushint 8
	/
	itob
	extract 6 2
	swap
	concat
	box_put

	// *if1_condition
	// examples/arc75/arc75.algo.ts:62
	// preMBR > this.app.address.minBalance
	frame_dig 0 // preMBR: uint64
	global CurrentApplicationAddress
	acct_params_get AcctMinBalance
	pop
	>
	bz *if1_else

	// *if1_consequent
	// examples/arc75/arc75.algo.ts:63
	// this.sendMBRPayment(preMBR)
	frame_dig 0 // preMBR: uint64
	callsub sendMBRPayment
	b *if1_end

*if1_else:
	// examples/arc75/arc75.algo.ts:65
	// this.verifyMBRPayment(this.txnGroup[this.txn.groupIndex - 1] as PayTxn, preMBR)
	frame_dig 0 // preMBR: uint64
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// failed to cast this.txnGroup[this.txn.groupIndex - 1] to pay
	assert
	callsub verifyMBRPayment

*if1_end:
	retsub

// deleteWhitelist(string,uint16)void
*abi_route_deleteWhitelist:
	// boxIndex: uint16
	txna ApplicationArgs 2
	dup
	len
	pushint 2
	==

	// argument 0 (boxIndex) for deleteWhitelist must be a uint16
	assert
	btoi

	// arc: string
	txna ApplicationArgs 1
	extract 2 0

	// execute deleteWhitelist(string,uint16)void
	callsub deleteWhitelist
	int 1
	return

// deleteWhitelist(arc: string, boxIndex: uint16): void
//
// Deletes a app whitelist for the sender
//
// @param arc - The ARC the whitelist corresponds to
// @param boxIndex - The index of the whitelist box to delete
deleteWhitelist:
	proto 2 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// examples/arc75/arc75.algo.ts:77
	// preMBR = this.app.address.minBalance
	global CurrentApplicationAddress
	acct_params_get AcctMinBalance
	pop
	frame_bury 0 // preMBR: uint64

	// examples/arc75/arc75.algo.ts:78
	// whitelist: Whitelist = { account: this.txn.sender, boxIndex: boxIndex, arc: arc }
	byte 0x // initial head
	byte 0x // initial tail
	byte 0x0024 // initial head offset
	txn Sender
	callsub *process_static_tuple_element
	frame_dig -2 // boxIndex: uint16
	itob
	extract 6 2
	callsub *process_static_tuple_element
	frame_dig -1 // arc: string
	dup
	len
	itob
	extract 6 2
	swap
	concat
	callsub *process_dynamic_tuple_element
	pop // pop head offset
	concat // concat head and tail
	frame_bury 1 // whitelist: Whitelist

	// examples/arc75/arc75.algo.ts:80
	// this.whitelist(whitelist).delete()
	frame_dig 1 // whitelist: Whitelist
	box_del

	// examples/arc75/arc75.algo.ts:82
	// this.sendMBRPayment(preMBR)
	frame_dig 0 // preMBR: uint64
	callsub sendMBRPayment
	retsub

// deleteAppFromWhitelist(string,uint16,uint64,uint64)void
*abi_route_deleteAppFromWhitelist:
	// index: uint64
	txna ApplicationArgs 4
	btoi

	// appID: uint64
	txna ApplicationArgs 3
	btoi

	// boxIndex: uint16
	txna ApplicationArgs 2
	dup
	len
	pushint 2
	==

	// argument 2 (boxIndex) for deleteAppFromWhitelist must be a uint16
	assert
	btoi

	// arc: string
	txna ApplicationArgs 1
	extract 2 0

	// execute deleteAppFromWhitelist(string,uint16,uint64,uint64)void
	callsub deleteAppFromWhitelist
	int 1
	return

// deleteAppFromWhitelist(arc: string, boxIndex: uint16, appID: uint64, index: uint64): void
//
// Deletes a app from a whitelist for the sender
//
// @param boxIndex - The index of the whitelist box to delete from
// @param appID - The app ID to delete from the whitelist
// @param index - The index of the app in the whitelist
deleteAppFromWhitelist:
	proto 4 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// examples/arc75/arc75.algo.ts:94
	// preMBR = this.app.address.minBalance
	global CurrentApplicationAddress
	acct_params_get AcctMinBalance
	pop
	frame_bury 0 // preMBR: uint64

	// examples/arc75/arc75.algo.ts:95
	// whitelist: Whitelist = { account: this.txn.sender, boxIndex: boxIndex, arc: arc }
	byte 0x // initial head
	byte 0x // initial tail
	byte 0x0024 // initial head offset
	txn Sender
	callsub *process_static_tuple_element
	frame_dig -2 // boxIndex: uint16
	itob
	extract 6 2
	callsub *process_static_tuple_element
	frame_dig -1 // arc: string
	dup
	len
	itob
	extract 6 2
	swap
	concat
	callsub *process_dynamic_tuple_element
	pop // pop head offset
	concat // concat head and tail
	frame_bury 1 // whitelist: Whitelist

	// examples/arc75/arc75.algo.ts:97
	// spliced = this.whitelist(whitelist).value.splice(index, 1)
	frame_dig 1 // whitelist: Whitelist
	box_get

	// box value does not exist: this.whitelist(whitelist).value
	assert
	extract 2 0
	int 1
	frame_dig -4 // index: uint64
	pushint 8
	*
	store 247 // splice start
	pushint 16
	store 246 // splice byte length
	frame_dig 1 // whitelist: Whitelist
	box_get

	// box value does not exist: this.whitelist(whitelist).value
	assert
	extract 2 0
	pushint 0
	load 247 // splice start
	substring3
	frame_dig 1 // whitelist: Whitelist
	box_get

	// box value does not exist: this.whitelist(whitelist).value
	assert
	extract 2 0
	dup
	len
	load 247 // splice start
	load 246 // splice byte length
	+
	pushint 8
	-
	swap
	substring3
	concat
	frame_dig 1 // whitelist: Whitelist
	box_get

	// box value does not exist: this.whitelist(whitelist).value
	assert
	extract 2 0
	load 247 // splice start
	load 246 // splice byte length
	pushint 8
	-
	extract3
	swap
	frame_dig 1 // whitelist: Whitelist
	dup
	box_del
	pop
	swap
	dup
	len
	pushint 8
	/
	itob
	extract 6 2
	swap
	concat
	box_put
	frame_bury 2 // spliced: uint64[]

	// examples/arc75/arc75.algo.ts:99
	// assert(spliced[0] === appID)
	frame_dig 2 // spliced: uint64[]
	store 255 // full array
	load 255 // full array
	extract 0 8
	btoi
	frame_dig -3 // appID: uint64
	==
	assert

	// examples/arc75/arc75.algo.ts:101
	// this.sendMBRPayment(preMBR)
	frame_dig 0 // preMBR: uint64
	callsub sendMBRPayment
	retsub

*abi_route_createApplication:
	int 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x467c7cbd // method "addAppToWhiteList(string,uint16,uint64,pay)void"
	pushbytes 0xd198fcb8 // method "setAppWhitelist(string,uint16,uint64[])void"
	pushbytes 0x7c33e832 // method "deleteWhitelist(string,uint16)void"
	pushbytes 0x7e1674ac // method "deleteAppFromWhitelist(string,uint16,uint64,uint64)void"
	txna ApplicationArgs 0
	match *abi_route_addAppToWhiteList *abi_route_setAppWhitelist *abi_route_deleteWhitelist *abi_route_deleteAppFromWhitelist

	// this contract does not implement the given ABI method for call NoOp
	err

*process_static_tuple_element:
	proto 4 3
	frame_dig -4 // tuple head
	frame_dig -1 // element
	concat
	frame_dig -3 // tuple tail
	frame_dig -2 // head offset
	retsub

*process_dynamic_tuple_element:
	proto 4 3
	frame_dig -4 // tuple head
	frame_dig -2 // head offset
	concat
	frame_bury -4 // tuple head
	frame_dig -1 // element
	dup
	len
	frame_dig -2 // head offset
	btoi
	+
	itob
	extract 6 2
	frame_bury -2 // head offset
	frame_dig -3 // tuple tail
	swap
	concat
	frame_bury -3 // tuple tail
	frame_dig -4 // tuple head
	frame_dig -3 // tuple tail
	frame_dig -2 // head offset
	retsub", + "approval": "#pragma version 10
intcblock 1
bytecblock 0x 0x0024

// This TEAL was generated by TEALScript v0.105.0
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// verifyMBRPayment(payment: PayTxn, preMBR: uint64): void
verifyMBRPayment:
	proto 2 0

	// examples/arc75/arc75.algo.ts:10
	// verifyPayTxn(payment, {
	//       receiver: this.app.address,
	//       amount: this.app.address.minBalance - preMBR,
	//     })
	// verify receiver
	frame_dig -1 // payment: PayTxn
	gtxns Receiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"payment","field":"receiver","expected":"this.app.address"}
	assert

	// verify amount
	frame_dig -1 // payment: PayTxn
	gtxns Amount
	global CurrentApplicationAddress
	acct_params_get AcctMinBalance
	pop
	frame_dig -2 // preMBR: uint64
	-
	==

	// transaction verification failed: {"txn":"payment","field":"amount","expected":"this.app.address.minBalance - preMBR"}
	assert
	retsub

// sendMBRPayment(preMBR: uint64): void
sendMBRPayment:
	proto 1 0

	// examples/arc75/arc75.algo.ts:17
	// sendPayment({
	//       receiver: this.txn.sender,
	//       amount: preMBR - this.app.address.minBalance,
	//     })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// examples/arc75/arc75.algo.ts:18
	// receiver: this.txn.sender
	txn Sender
	itxn_field Receiver

	// examples/arc75/arc75.algo.ts:19
	// amount: preMBR - this.app.address.minBalance
	frame_dig -1 // preMBR: uint64
	global CurrentApplicationAddress
	acct_params_get AcctMinBalance
	pop
	-
	itxn_field Amount

	// Fee field not set, defaulting to 0
	pushint 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// addAppToWhiteList(string,uint16,uint64,pay)void
*abi_route_addAppToWhiteList:
	// payment: pay
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// argument 0 (payment) for addAppToWhiteList must be a pay transaction
	assert

	// appID: uint64
	txna ApplicationArgs 3
	btoi

	// boxIndex: uint16
	txna ApplicationArgs 2
	dup
	len
	pushint 2
	==

	// argument 2 (boxIndex) for addAppToWhiteList must be a uint16
	assert
	btoi

	// arc: string
	txna ApplicationArgs 1
	extract 2 0

	// execute addAppToWhiteList(string,uint16,uint64,pay)void
	callsub addAppToWhiteList
	int 1
	return

// addAppToWhiteList(arc: string, boxIndex: uint16, appID: uint64, payment: PayTxn): void
//
// Add app to whitelist box
//
// @param arc - The ARC the whitelist corresponds to
// @param boxIndex - The index of the whitelist box to add the app to
// @param appID - The app ID to add to the whitelist
// @param payment - The payment transaction to cover the MBR change
addAppToWhiteList:
	proto 4 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// examples/arc75/arc75.algo.ts:33
	// preMBR = this.app.address.minBalance
	global CurrentApplicationAddress
	acct_params_get AcctMinBalance
	pop
	frame_bury 0 // preMBR: uint64

	// examples/arc75/arc75.algo.ts:34
	// whitelist: Whitelist = { account: this.txn.sender, boxIndex: boxIndex, arc: arc }
	byte 0x // initial head
	byte 0x // initial tail
	byte 0x0024 // initial head offset
	txn Sender
	callsub *process_static_tuple_element
	frame_dig -2 // boxIndex: uint16
	itob
	extract 6 2
	callsub *process_static_tuple_element
	frame_dig -1 // arc: string
	dup
	len
	itob
	extract 6 2
	swap
	concat
	callsub *process_dynamic_tuple_element
	pop // pop head offset
	concat // concat head and tail
	frame_bury 1 // whitelist: Whitelist

	// *if0_condition
	// examples/arc75/arc75.algo.ts:36
	// this.whitelist(whitelist).exists
	frame_dig 1 // whitelist: Whitelist
	box_len
	swap
	pop
	bz *if0_else

	// *if0_consequent
	// examples/arc75/arc75.algo.ts:37
	// this.whitelist(whitelist).value.push(appID)
	frame_dig 1 // whitelist: Whitelist
	box_get

	// box value does not exist: this.whitelist(whitelist).value
	assert
	extract 2 0
	frame_dig -3 // appID: uint64
	itob
	concat
	frame_dig 1 // whitelist: Whitelist
	dup
	box_del
	pop
	swap
	dup
	len
	pushint 8
	/
	itob
	extract 6 2
	swap
	concat
	box_put
	b *if0_end

*if0_else:
	// examples/arc75/arc75.algo.ts:39
	// newWhitelist: uint64[] = [appID]
	frame_dig -3 // appID: uint64
	itob
	frame_bury 2 // newWhitelist: uint64[]

	// examples/arc75/arc75.algo.ts:40
	// this.whitelist(whitelist).value = newWhitelist
	frame_dig 1 // whitelist: Whitelist
	dup
	box_del
	pop
	frame_dig 2 // newWhitelist: uint64[]
	dup
	len
	pushint 8
	/
	itob
	extract 6 2
	swap
	concat
	box_put

*if0_end:
	// examples/arc75/arc75.algo.ts:43
	// this.verifyMBRPayment(payment, preMBR)
	frame_dig 0 // preMBR: uint64
	frame_dig -4 // payment: PayTxn
	callsub verifyMBRPayment
	retsub

// setAppWhitelist(string,uint16,uint64[])void
*abi_route_setAppWhitelist:
	// appIDs: uint64[]
	txna ApplicationArgs 3
	extract 2 0

	// boxIndex: uint16
	txna ApplicationArgs 2
	dup
	len
	pushint 2
	==

	// argument 1 (boxIndex) for setAppWhitelist must be a uint16
	assert
	btoi

	// arc: string
	txna ApplicationArgs 1
	extract 2 0

	// execute setAppWhitelist(string,uint16,uint64[])void
	callsub setAppWhitelist
	int 1
	return

// setAppWhitelist(arc: string, boxIndex: uint16, appIDs: uint64[]): void
//
// Sets a app whitelist for the sender. Should only be used when adding/removing
// more than one app
//
// @param boxIndex - The index of the whitelist box to put the app IDs in
// @param appIDs - Array of app IDs that signify the whitelisted apps
setAppWhitelist:
	proto 3 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// examples/arc75/arc75.algo.ts:55
	// preMBR = this.app.address.minBalance
	global CurrentApplicationAddress
	acct_params_get AcctMinBalance
	pop
	frame_bury 0 // preMBR: uint64

	// examples/arc75/arc75.algo.ts:56
	// whitelist: Whitelist = { account: this.txn.sender, boxIndex: boxIndex, arc: arc }
	byte 0x // initial head
	byte 0x // initial tail
	byte 0x0024 // initial head offset
	txn Sender
	callsub *process_static_tuple_element
	frame_dig -2 // boxIndex: uint16
	itob
	extract 6 2
	callsub *process_static_tuple_element
	frame_dig -1 // arc: string
	dup
	len
	itob
	extract 6 2
	swap
	concat
	callsub *process_dynamic_tuple_element
	pop // pop head offset
	concat // concat head and tail
	frame_bury 1 // whitelist: Whitelist

	// examples/arc75/arc75.algo.ts:58
	// this.whitelist(whitelist).delete()
	frame_dig 1 // whitelist: Whitelist
	box_del

	// examples/arc75/arc75.algo.ts:60
	// this.whitelist(whitelist).value = appIDs
	frame_dig 1 // whitelist: Whitelist
	dup
	box_del
	pop
	frame_dig -3 // appIDs: uint64[]
	dup
	len
	pushint 8
	/
	itob
	extract 6 2
	swap
	concat
	box_put

	// *if1_condition
	// examples/arc75/arc75.algo.ts:62
	// preMBR > this.app.address.minBalance
	frame_dig 0 // preMBR: uint64
	global CurrentApplicationAddress
	acct_params_get AcctMinBalance
	pop
	>
	bz *if1_else

	// *if1_consequent
	// examples/arc75/arc75.algo.ts:63
	// this.sendMBRPayment(preMBR)
	frame_dig 0 // preMBR: uint64
	callsub sendMBRPayment
	b *if1_end

*if1_else:
	// examples/arc75/arc75.algo.ts:65
	// this.verifyMBRPayment(this.txnGroup[this.txn.groupIndex - 1] as PayTxn, preMBR)
	frame_dig 0 // preMBR: uint64
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// failed to cast this.txnGroup[this.txn.groupIndex - 1] to pay
	assert
	callsub verifyMBRPayment

*if1_end:
	retsub

// deleteWhitelist(string,uint16)void
*abi_route_deleteWhitelist:
	// boxIndex: uint16
	txna ApplicationArgs 2
	dup
	len
	pushint 2
	==

	// argument 0 (boxIndex) for deleteWhitelist must be a uint16
	assert
	btoi

	// arc: string
	txna ApplicationArgs 1
	extract 2 0

	// execute deleteWhitelist(string,uint16)void
	callsub deleteWhitelist
	int 1
	return

// deleteWhitelist(arc: string, boxIndex: uint16): void
//
// Deletes a app whitelist for the sender
//
// @param arc - The ARC the whitelist corresponds to
// @param boxIndex - The index of the whitelist box to delete
deleteWhitelist:
	proto 2 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// examples/arc75/arc75.algo.ts:77
	// preMBR = this.app.address.minBalance
	global CurrentApplicationAddress
	acct_params_get AcctMinBalance
	pop
	frame_bury 0 // preMBR: uint64

	// examples/arc75/arc75.algo.ts:78
	// whitelist: Whitelist = { account: this.txn.sender, boxIndex: boxIndex, arc: arc }
	byte 0x // initial head
	byte 0x // initial tail
	byte 0x0024 // initial head offset
	txn Sender
	callsub *process_static_tuple_element
	frame_dig -2 // boxIndex: uint16
	itob
	extract 6 2
	callsub *process_static_tuple_element
	frame_dig -1 // arc: string
	dup
	len
	itob
	extract 6 2
	swap
	concat
	callsub *process_dynamic_tuple_element
	pop // pop head offset
	concat // concat head and tail
	frame_bury 1 // whitelist: Whitelist

	// examples/arc75/arc75.algo.ts:80
	// this.whitelist(whitelist).delete()
	frame_dig 1 // whitelist: Whitelist
	box_del

	// examples/arc75/arc75.algo.ts:82
	// this.sendMBRPayment(preMBR)
	frame_dig 0 // preMBR: uint64
	callsub sendMBRPayment
	retsub

// deleteAppFromWhitelist(string,uint16,uint64,uint64)void
*abi_route_deleteAppFromWhitelist:
	// index: uint64
	txna ApplicationArgs 4
	btoi

	// appID: uint64
	txna ApplicationArgs 3
	btoi

	// boxIndex: uint16
	txna ApplicationArgs 2
	dup
	len
	pushint 2
	==

	// argument 2 (boxIndex) for deleteAppFromWhitelist must be a uint16
	assert
	btoi

	// arc: string
	txna ApplicationArgs 1
	extract 2 0

	// execute deleteAppFromWhitelist(string,uint16,uint64,uint64)void
	callsub deleteAppFromWhitelist
	int 1
	return

// deleteAppFromWhitelist(arc: string, boxIndex: uint16, appID: uint64, index: uint64): void
//
// Deletes a app from a whitelist for the sender
//
// @param boxIndex - The index of the whitelist box to delete from
// @param appID - The app ID to delete from the whitelist
// @param index - The index of the app in the whitelist
deleteAppFromWhitelist:
	proto 4 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// examples/arc75/arc75.algo.ts:94
	// preMBR = this.app.address.minBalance
	global CurrentApplicationAddress
	acct_params_get AcctMinBalance
	pop
	frame_bury 0 // preMBR: uint64

	// examples/arc75/arc75.algo.ts:95
	// whitelist: Whitelist = { account: this.txn.sender, boxIndex: boxIndex, arc: arc }
	byte 0x // initial head
	byte 0x // initial tail
	byte 0x0024 // initial head offset
	txn Sender
	callsub *process_static_tuple_element
	frame_dig -2 // boxIndex: uint16
	itob
	extract 6 2
	callsub *process_static_tuple_element
	frame_dig -1 // arc: string
	dup
	len
	itob
	extract 6 2
	swap
	concat
	callsub *process_dynamic_tuple_element
	pop // pop head offset
	concat // concat head and tail
	frame_bury 1 // whitelist: Whitelist

	// examples/arc75/arc75.algo.ts:97
	// spliced = this.whitelist(whitelist).value.splice(index, 1)
	frame_dig 1 // whitelist: Whitelist
	box_get

	// box value does not exist: this.whitelist(whitelist).value
	assert
	extract 2 0
	int 1
	frame_dig -4 // index: uint64
	pushint 8
	*
	store 247 // splice start
	pushint 16
	store 246 // splice byte length
	frame_dig 1 // whitelist: Whitelist
	box_get

	// box value does not exist: this.whitelist(whitelist).value
	assert
	extract 2 0
	pushint 0
	load 247 // splice start
	substring3
	frame_dig 1 // whitelist: Whitelist
	box_get

	// box value does not exist: this.whitelist(whitelist).value
	assert
	extract 2 0
	dup
	len
	load 247 // splice start
	load 246 // splice byte length
	+
	pushint 8
	-
	swap
	substring3
	concat
	frame_dig 1 // whitelist: Whitelist
	box_get

	// box value does not exist: this.whitelist(whitelist).value
	assert
	extract 2 0
	load 247 // splice start
	load 246 // splice byte length
	pushint 8
	-
	extract3
	swap
	frame_dig 1 // whitelist: Whitelist
	dup
	box_del
	pop
	swap
	dup
	len
	pushint 8
	/
	itob
	extract 6 2
	swap
	concat
	box_put
	frame_bury 2 // spliced: uint64[]

	// examples/arc75/arc75.algo.ts:99
	// assert(spliced[0] === appID)
	frame_dig 2 // spliced: uint64[]
	store 255 // full array
	load 255 // full array
	extract 0 8
	btoi
	frame_dig -3 // appID: uint64
	==
	assert

	// examples/arc75/arc75.algo.ts:101
	// this.sendMBRPayment(preMBR)
	frame_dig 0 // preMBR: uint64
	callsub sendMBRPayment
	retsub

*abi_route_createApplication:
	int 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x467c7cbd // method "addAppToWhiteList(string,uint16,uint64,pay)void"
	pushbytes 0xd198fcb8 // method "setAppWhitelist(string,uint16,uint64[])void"
	pushbytes 0x7c33e832 // method "deleteWhitelist(string,uint16)void"
	pushbytes 0x7e1674ac // method "deleteAppFromWhitelist(string,uint16,uint64,uint64)void"
	txna ApplicationArgs 0
	match *abi_route_addAppToWhiteList *abi_route_setAppWhitelist *abi_route_deleteWhitelist *abi_route_deleteAppFromWhitelist

	// this contract does not implement the given ABI method for call NoOp
	err

*process_static_tuple_element:
	proto 4 3
	frame_dig -4 // tuple head
	frame_dig -1 // element
	concat
	frame_dig -3 // tuple tail
	frame_dig -2 // head offset
	retsub

*process_dynamic_tuple_element:
	proto 4 3
	frame_dig -4 // tuple head
	frame_dig -2 // head offset
	concat
	frame_bury -4 // tuple head
	frame_dig -1 // element
	dup
	len
	frame_dig -2 // head offset
	btoi
	+
	itob
	extract 6 2
	frame_bury -2 // head offset
	frame_dig -3 // tuple tail
	swap
	concat
	frame_bury -3 // tuple tail
	frame_dig -4 // tuple head
	frame_dig -3 // tuple tail
	frame_dig -2 // head offset
	retsub", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/examples/arc75/artifacts/ARC75.arc56_draft.json b/examples/arc75/artifacts/ARC75.arc56_draft.json index c0429e1b6..da9e13264 100644 --- a/examples/arc75/artifacts/ARC75.arc56_draft.json +++ b/examples/arc75/artifacts/ARC75.arc56_draft.json @@ -3483,7 +3483,7 @@ } }, "source": { - "approval": "#pragma version 10
intcblock 1
bytecblock 0x 0x0024

// This TEAL was generated by TEALScript v0.104.1
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// verifyMBRPayment(payment: PayTxn, preMBR: uint64): void
verifyMBRPayment:
	proto 2 0

	// examples/arc75/arc75.algo.ts:10
	// verifyPayTxn(payment, {
	//       receiver: this.app.address,
	//       amount: this.app.address.minBalance - preMBR,
	//     })
	// verify receiver
	frame_dig -1 // payment: PayTxn
	gtxns Receiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"payment","field":"receiver","expected":"this.app.address"}
	assert

	// verify amount
	frame_dig -1 // payment: PayTxn
	gtxns Amount
	global CurrentApplicationAddress
	acct_params_get AcctMinBalance
	pop
	frame_dig -2 // preMBR: uint64
	-
	==

	// transaction verification failed: {"txn":"payment","field":"amount","expected":"this.app.address.minBalance - preMBR"}
	assert
	retsub

// sendMBRPayment(preMBR: uint64): void
sendMBRPayment:
	proto 1 0

	// examples/arc75/arc75.algo.ts:17
	// sendPayment({
	//       receiver: this.txn.sender,
	//       amount: preMBR - this.app.address.minBalance,
	//     })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// examples/arc75/arc75.algo.ts:18
	// receiver: this.txn.sender
	txn Sender
	itxn_field Receiver

	// examples/arc75/arc75.algo.ts:19
	// amount: preMBR - this.app.address.minBalance
	frame_dig -1 // preMBR: uint64
	global CurrentApplicationAddress
	acct_params_get AcctMinBalance
	pop
	-
	itxn_field Amount

	// Fee field not set, defaulting to 0
	pushint 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// addAppToWhiteList(string,uint16,uint64,pay)void
*abi_route_addAppToWhiteList:
	// payment: pay
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// argument 0 (payment) for addAppToWhiteList must be a pay transaction
	assert

	// appID: uint64
	txna ApplicationArgs 3
	btoi

	// boxIndex: uint16
	txna ApplicationArgs 2
	dup
	len
	pushint 2
	==

	// argument 2 (boxIndex) for addAppToWhiteList must be a uint16
	assert
	btoi

	// arc: string
	txna ApplicationArgs 1
	extract 2 0

	// execute addAppToWhiteList(string,uint16,uint64,pay)void
	callsub addAppToWhiteList
	int 1
	return

// addAppToWhiteList(arc: string, boxIndex: uint16, appID: uint64, payment: PayTxn): void
//
// Add app to whitelist box
//
// @param arc - The ARC the whitelist corresponds to
// @param boxIndex - The index of the whitelist box to add the app to
// @param appID - The app ID to add to the whitelist
// @param payment - The payment transaction to cover the MBR change
addAppToWhiteList:
	proto 4 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// examples/arc75/arc75.algo.ts:33
	// preMBR = this.app.address.minBalance
	global CurrentApplicationAddress
	acct_params_get AcctMinBalance
	pop
	frame_bury 0 // preMBR: uint64

	// examples/arc75/arc75.algo.ts:34
	// whitelist: Whitelist = { account: this.txn.sender, boxIndex: boxIndex, arc: arc }
	byte 0x // initial head
	byte 0x // initial tail
	byte 0x0024 // initial head offset
	txn Sender
	callsub *process_static_tuple_element
	frame_dig -2 // boxIndex: uint16
	itob
	extract 6 2
	callsub *process_static_tuple_element
	frame_dig -1 // arc: string
	dup
	len
	itob
	extract 6 2
	swap
	concat
	callsub *process_dynamic_tuple_element
	pop // pop head offset
	concat // concat head and tail
	frame_bury 1 // whitelist: Whitelist

	// *if0_condition
	// examples/arc75/arc75.algo.ts:36
	// this.whitelist(whitelist).exists
	frame_dig 1 // whitelist: Whitelist
	box_len
	swap
	pop
	bz *if0_else

	// *if0_consequent
	// examples/arc75/arc75.algo.ts:37
	// this.whitelist(whitelist).value.push(appID)
	frame_dig 1 // whitelist: Whitelist
	box_get

	// box value does not exist: this.whitelist(whitelist).value
	assert
	extract 2 0
	frame_dig -3 // appID: uint64
	itob
	concat
	frame_dig 1 // whitelist: Whitelist
	dup
	box_del
	pop
	swap
	dup
	len
	pushint 8
	/
	itob
	extract 6 2
	swap
	concat
	box_put
	b *if0_end

*if0_else:
	// examples/arc75/arc75.algo.ts:39
	// newWhitelist: uint64[] = [appID]
	frame_dig -3 // appID: uint64
	itob
	frame_bury 2 // newWhitelist: uint64[]

	// examples/arc75/arc75.algo.ts:40
	// this.whitelist(whitelist).value = newWhitelist
	frame_dig 1 // whitelist: Whitelist
	dup
	box_del
	pop
	frame_dig 2 // newWhitelist: uint64[]
	dup
	len
	pushint 8
	/
	itob
	extract 6 2
	swap
	concat
	box_put

*if0_end:
	// examples/arc75/arc75.algo.ts:43
	// this.verifyMBRPayment(payment, preMBR)
	frame_dig 0 // preMBR: uint64
	frame_dig -4 // payment: PayTxn
	callsub verifyMBRPayment
	retsub

// setAppWhitelist(string,uint16,uint64[])void
*abi_route_setAppWhitelist:
	// appIDs: uint64[]
	txna ApplicationArgs 3
	extract 2 0

	// boxIndex: uint16
	txna ApplicationArgs 2
	dup
	len
	pushint 2
	==

	// argument 1 (boxIndex) for setAppWhitelist must be a uint16
	assert
	btoi

	// arc: string
	txna ApplicationArgs 1
	extract 2 0

	// execute setAppWhitelist(string,uint16,uint64[])void
	callsub setAppWhitelist
	int 1
	return

// setAppWhitelist(arc: string, boxIndex: uint16, appIDs: uint64[]): void
//
// Sets a app whitelist for the sender. Should only be used when adding/removing
// more than one app
//
// @param boxIndex - The index of the whitelist box to put the app IDs in
// @param appIDs - Array of app IDs that signify the whitelisted apps
setAppWhitelist:
	proto 3 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// examples/arc75/arc75.algo.ts:55
	// preMBR = this.app.address.minBalance
	global CurrentApplicationAddress
	acct_params_get AcctMinBalance
	pop
	frame_bury 0 // preMBR: uint64

	// examples/arc75/arc75.algo.ts:56
	// whitelist: Whitelist = { account: this.txn.sender, boxIndex: boxIndex, arc: arc }
	byte 0x // initial head
	byte 0x // initial tail
	byte 0x0024 // initial head offset
	txn Sender
	callsub *process_static_tuple_element
	frame_dig -2 // boxIndex: uint16
	itob
	extract 6 2
	callsub *process_static_tuple_element
	frame_dig -1 // arc: string
	dup
	len
	itob
	extract 6 2
	swap
	concat
	callsub *process_dynamic_tuple_element
	pop // pop head offset
	concat // concat head and tail
	frame_bury 1 // whitelist: Whitelist

	// examples/arc75/arc75.algo.ts:58
	// this.whitelist(whitelist).delete()
	frame_dig 1 // whitelist: Whitelist
	box_del

	// examples/arc75/arc75.algo.ts:60
	// this.whitelist(whitelist).value = appIDs
	frame_dig 1 // whitelist: Whitelist
	dup
	box_del
	pop
	frame_dig -3 // appIDs: uint64[]
	dup
	len
	pushint 8
	/
	itob
	extract 6 2
	swap
	concat
	box_put

	// *if1_condition
	// examples/arc75/arc75.algo.ts:62
	// preMBR > this.app.address.minBalance
	frame_dig 0 // preMBR: uint64
	global CurrentApplicationAddress
	acct_params_get AcctMinBalance
	pop
	>
	bz *if1_else

	// *if1_consequent
	// examples/arc75/arc75.algo.ts:63
	// this.sendMBRPayment(preMBR)
	frame_dig 0 // preMBR: uint64
	callsub sendMBRPayment
	b *if1_end

*if1_else:
	// examples/arc75/arc75.algo.ts:65
	// this.verifyMBRPayment(this.txnGroup[this.txn.groupIndex - 1] as PayTxn, preMBR)
	frame_dig 0 // preMBR: uint64
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// failed to cast this.txnGroup[this.txn.groupIndex - 1] to pay
	assert
	callsub verifyMBRPayment

*if1_end:
	retsub

// deleteWhitelist(string,uint16)void
*abi_route_deleteWhitelist:
	// boxIndex: uint16
	txna ApplicationArgs 2
	dup
	len
	pushint 2
	==

	// argument 0 (boxIndex) for deleteWhitelist must be a uint16
	assert
	btoi

	// arc: string
	txna ApplicationArgs 1
	extract 2 0

	// execute deleteWhitelist(string,uint16)void
	callsub deleteWhitelist
	int 1
	return

// deleteWhitelist(arc: string, boxIndex: uint16): void
//
// Deletes a app whitelist for the sender
//
// @param arc - The ARC the whitelist corresponds to
// @param boxIndex - The index of the whitelist box to delete
deleteWhitelist:
	proto 2 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// examples/arc75/arc75.algo.ts:77
	// preMBR = this.app.address.minBalance
	global CurrentApplicationAddress
	acct_params_get AcctMinBalance
	pop
	frame_bury 0 // preMBR: uint64

	// examples/arc75/arc75.algo.ts:78
	// whitelist: Whitelist = { account: this.txn.sender, boxIndex: boxIndex, arc: arc }
	byte 0x // initial head
	byte 0x // initial tail
	byte 0x0024 // initial head offset
	txn Sender
	callsub *process_static_tuple_element
	frame_dig -2 // boxIndex: uint16
	itob
	extract 6 2
	callsub *process_static_tuple_element
	frame_dig -1 // arc: string
	dup
	len
	itob
	extract 6 2
	swap
	concat
	callsub *process_dynamic_tuple_element
	pop // pop head offset
	concat // concat head and tail
	frame_bury 1 // whitelist: Whitelist

	// examples/arc75/arc75.algo.ts:80
	// this.whitelist(whitelist).delete()
	frame_dig 1 // whitelist: Whitelist
	box_del

	// examples/arc75/arc75.algo.ts:82
	// this.sendMBRPayment(preMBR)
	frame_dig 0 // preMBR: uint64
	callsub sendMBRPayment
	retsub

// deleteAppFromWhitelist(string,uint16,uint64,uint64)void
*abi_route_deleteAppFromWhitelist:
	// index: uint64
	txna ApplicationArgs 4
	btoi

	// appID: uint64
	txna ApplicationArgs 3
	btoi

	// boxIndex: uint16
	txna ApplicationArgs 2
	dup
	len
	pushint 2
	==

	// argument 2 (boxIndex) for deleteAppFromWhitelist must be a uint16
	assert
	btoi

	// arc: string
	txna ApplicationArgs 1
	extract 2 0

	// execute deleteAppFromWhitelist(string,uint16,uint64,uint64)void
	callsub deleteAppFromWhitelist
	int 1
	return

// deleteAppFromWhitelist(arc: string, boxIndex: uint16, appID: uint64, index: uint64): void
//
// Deletes a app from a whitelist for the sender
//
// @param boxIndex - The index of the whitelist box to delete from
// @param appID - The app ID to delete from the whitelist
// @param index - The index of the app in the whitelist
deleteAppFromWhitelist:
	proto 4 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// examples/arc75/arc75.algo.ts:94
	// preMBR = this.app.address.minBalance
	global CurrentApplicationAddress
	acct_params_get AcctMinBalance
	pop
	frame_bury 0 // preMBR: uint64

	// examples/arc75/arc75.algo.ts:95
	// whitelist: Whitelist = { account: this.txn.sender, boxIndex: boxIndex, arc: arc }
	byte 0x // initial head
	byte 0x // initial tail
	byte 0x0024 // initial head offset
	txn Sender
	callsub *process_static_tuple_element
	frame_dig -2 // boxIndex: uint16
	itob
	extract 6 2
	callsub *process_static_tuple_element
	frame_dig -1 // arc: string
	dup
	len
	itob
	extract 6 2
	swap
	concat
	callsub *process_dynamic_tuple_element
	pop // pop head offset
	concat // concat head and tail
	frame_bury 1 // whitelist: Whitelist

	// examples/arc75/arc75.algo.ts:97
	// spliced = this.whitelist(whitelist).value.splice(index, 1)
	frame_dig 1 // whitelist: Whitelist
	box_get

	// box value does not exist: this.whitelist(whitelist).value
	assert
	extract 2 0
	int 1
	frame_dig -4 // index: uint64
	pushint 8
	*
	store 247 // splice start
	pushint 16
	store 246 // splice byte length
	frame_dig 1 // whitelist: Whitelist
	box_get

	// box value does not exist: this.whitelist(whitelist).value
	assert
	extract 2 0
	pushint 0
	load 247 // splice start
	substring3
	frame_dig 1 // whitelist: Whitelist
	box_get

	// box value does not exist: this.whitelist(whitelist).value
	assert
	extract 2 0
	dup
	len
	load 247 // splice start
	load 246 // splice byte length
	+
	pushint 8
	-
	swap
	substring3
	concat
	frame_dig 1 // whitelist: Whitelist
	box_get

	// box value does not exist: this.whitelist(whitelist).value
	assert
	extract 2 0
	load 247 // splice start
	load 246 // splice byte length
	pushint 8
	-
	extract3
	swap
	frame_dig 1 // whitelist: Whitelist
	dup
	box_del
	pop
	swap
	dup
	len
	pushint 8
	/
	itob
	extract 6 2
	swap
	concat
	box_put
	frame_bury 2 // spliced: uint64[]

	// examples/arc75/arc75.algo.ts:99
	// assert(spliced[0] === appID)
	frame_dig 2 // spliced: uint64[]
	store 255 // full array
	load 255 // full array
	extract 0 8
	btoi
	frame_dig -3 // appID: uint64
	==
	assert

	// examples/arc75/arc75.algo.ts:101
	// this.sendMBRPayment(preMBR)
	frame_dig 0 // preMBR: uint64
	callsub sendMBRPayment
	retsub

*abi_route_createApplication:
	int 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x467c7cbd // method "addAppToWhiteList(string,uint16,uint64,pay)void"
	pushbytes 0xd198fcb8 // method "setAppWhitelist(string,uint16,uint64[])void"
	pushbytes 0x7c33e832 // method "deleteWhitelist(string,uint16)void"
	pushbytes 0x7e1674ac // method "deleteAppFromWhitelist(string,uint16,uint64,uint64)void"
	txna ApplicationArgs 0
	match *abi_route_addAppToWhiteList *abi_route_setAppWhitelist *abi_route_deleteWhitelist *abi_route_deleteAppFromWhitelist

	// this contract does not implement the given ABI method for call NoOp
	err

*process_static_tuple_element:
	proto 4 3
	frame_dig -4 // tuple head
	frame_dig -1 // element
	concat
	frame_dig -3 // tuple tail
	frame_dig -2 // head offset
	retsub

*process_dynamic_tuple_element:
	proto 4 3
	frame_dig -4 // tuple head
	frame_dig -2 // head offset
	concat
	frame_bury -4 // tuple head
	frame_dig -1 // element
	dup
	len
	frame_dig -2 // head offset
	btoi
	+
	itob
	extract 6 2
	frame_bury -2 // head offset
	frame_dig -3 // tuple tail
	swap
	concat
	frame_bury -3 // tuple tail
	frame_dig -4 // tuple head
	frame_dig -3 // tuple tail
	frame_dig -2 // head offset
	retsub", + "approval": "#pragma version 10
intcblock 1
bytecblock 0x 0x0024

// This TEAL was generated by TEALScript v0.105.0
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// verifyMBRPayment(payment: PayTxn, preMBR: uint64): void
verifyMBRPayment:
	proto 2 0

	// examples/arc75/arc75.algo.ts:10
	// verifyPayTxn(payment, {
	//       receiver: this.app.address,
	//       amount: this.app.address.minBalance - preMBR,
	//     })
	// verify receiver
	frame_dig -1 // payment: PayTxn
	gtxns Receiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"payment","field":"receiver","expected":"this.app.address"}
	assert

	// verify amount
	frame_dig -1 // payment: PayTxn
	gtxns Amount
	global CurrentApplicationAddress
	acct_params_get AcctMinBalance
	pop
	frame_dig -2 // preMBR: uint64
	-
	==

	// transaction verification failed: {"txn":"payment","field":"amount","expected":"this.app.address.minBalance - preMBR"}
	assert
	retsub

// sendMBRPayment(preMBR: uint64): void
sendMBRPayment:
	proto 1 0

	// examples/arc75/arc75.algo.ts:17
	// sendPayment({
	//       receiver: this.txn.sender,
	//       amount: preMBR - this.app.address.minBalance,
	//     })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// examples/arc75/arc75.algo.ts:18
	// receiver: this.txn.sender
	txn Sender
	itxn_field Receiver

	// examples/arc75/arc75.algo.ts:19
	// amount: preMBR - this.app.address.minBalance
	frame_dig -1 // preMBR: uint64
	global CurrentApplicationAddress
	acct_params_get AcctMinBalance
	pop
	-
	itxn_field Amount

	// Fee field not set, defaulting to 0
	pushint 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// addAppToWhiteList(string,uint16,uint64,pay)void
*abi_route_addAppToWhiteList:
	// payment: pay
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// argument 0 (payment) for addAppToWhiteList must be a pay transaction
	assert

	// appID: uint64
	txna ApplicationArgs 3
	btoi

	// boxIndex: uint16
	txna ApplicationArgs 2
	dup
	len
	pushint 2
	==

	// argument 2 (boxIndex) for addAppToWhiteList must be a uint16
	assert
	btoi

	// arc: string
	txna ApplicationArgs 1
	extract 2 0

	// execute addAppToWhiteList(string,uint16,uint64,pay)void
	callsub addAppToWhiteList
	int 1
	return

// addAppToWhiteList(arc: string, boxIndex: uint16, appID: uint64, payment: PayTxn): void
//
// Add app to whitelist box
//
// @param arc - The ARC the whitelist corresponds to
// @param boxIndex - The index of the whitelist box to add the app to
// @param appID - The app ID to add to the whitelist
// @param payment - The payment transaction to cover the MBR change
addAppToWhiteList:
	proto 4 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// examples/arc75/arc75.algo.ts:33
	// preMBR = this.app.address.minBalance
	global CurrentApplicationAddress
	acct_params_get AcctMinBalance
	pop
	frame_bury 0 // preMBR: uint64

	// examples/arc75/arc75.algo.ts:34
	// whitelist: Whitelist = { account: this.txn.sender, boxIndex: boxIndex, arc: arc }
	byte 0x // initial head
	byte 0x // initial tail
	byte 0x0024 // initial head offset
	txn Sender
	callsub *process_static_tuple_element
	frame_dig -2 // boxIndex: uint16
	itob
	extract 6 2
	callsub *process_static_tuple_element
	frame_dig -1 // arc: string
	dup
	len
	itob
	extract 6 2
	swap
	concat
	callsub *process_dynamic_tuple_element
	pop // pop head offset
	concat // concat head and tail
	frame_bury 1 // whitelist: Whitelist

	// *if0_condition
	// examples/arc75/arc75.algo.ts:36
	// this.whitelist(whitelist).exists
	frame_dig 1 // whitelist: Whitelist
	box_len
	swap
	pop
	bz *if0_else

	// *if0_consequent
	// examples/arc75/arc75.algo.ts:37
	// this.whitelist(whitelist).value.push(appID)
	frame_dig 1 // whitelist: Whitelist
	box_get

	// box value does not exist: this.whitelist(whitelist).value
	assert
	extract 2 0
	frame_dig -3 // appID: uint64
	itob
	concat
	frame_dig 1 // whitelist: Whitelist
	dup
	box_del
	pop
	swap
	dup
	len
	pushint 8
	/
	itob
	extract 6 2
	swap
	concat
	box_put
	b *if0_end

*if0_else:
	// examples/arc75/arc75.algo.ts:39
	// newWhitelist: uint64[] = [appID]
	frame_dig -3 // appID: uint64
	itob
	frame_bury 2 // newWhitelist: uint64[]

	// examples/arc75/arc75.algo.ts:40
	// this.whitelist(whitelist).value = newWhitelist
	frame_dig 1 // whitelist: Whitelist
	dup
	box_del
	pop
	frame_dig 2 // newWhitelist: uint64[]
	dup
	len
	pushint 8
	/
	itob
	extract 6 2
	swap
	concat
	box_put

*if0_end:
	// examples/arc75/arc75.algo.ts:43
	// this.verifyMBRPayment(payment, preMBR)
	frame_dig 0 // preMBR: uint64
	frame_dig -4 // payment: PayTxn
	callsub verifyMBRPayment
	retsub

// setAppWhitelist(string,uint16,uint64[])void
*abi_route_setAppWhitelist:
	// appIDs: uint64[]
	txna ApplicationArgs 3
	extract 2 0

	// boxIndex: uint16
	txna ApplicationArgs 2
	dup
	len
	pushint 2
	==

	// argument 1 (boxIndex) for setAppWhitelist must be a uint16
	assert
	btoi

	// arc: string
	txna ApplicationArgs 1
	extract 2 0

	// execute setAppWhitelist(string,uint16,uint64[])void
	callsub setAppWhitelist
	int 1
	return

// setAppWhitelist(arc: string, boxIndex: uint16, appIDs: uint64[]): void
//
// Sets a app whitelist for the sender. Should only be used when adding/removing
// more than one app
//
// @param boxIndex - The index of the whitelist box to put the app IDs in
// @param appIDs - Array of app IDs that signify the whitelisted apps
setAppWhitelist:
	proto 3 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// examples/arc75/arc75.algo.ts:55
	// preMBR = this.app.address.minBalance
	global CurrentApplicationAddress
	acct_params_get AcctMinBalance
	pop
	frame_bury 0 // preMBR: uint64

	// examples/arc75/arc75.algo.ts:56
	// whitelist: Whitelist = { account: this.txn.sender, boxIndex: boxIndex, arc: arc }
	byte 0x // initial head
	byte 0x // initial tail
	byte 0x0024 // initial head offset
	txn Sender
	callsub *process_static_tuple_element
	frame_dig -2 // boxIndex: uint16
	itob
	extract 6 2
	callsub *process_static_tuple_element
	frame_dig -1 // arc: string
	dup
	len
	itob
	extract 6 2
	swap
	concat
	callsub *process_dynamic_tuple_element
	pop // pop head offset
	concat // concat head and tail
	frame_bury 1 // whitelist: Whitelist

	// examples/arc75/arc75.algo.ts:58
	// this.whitelist(whitelist).delete()
	frame_dig 1 // whitelist: Whitelist
	box_del

	// examples/arc75/arc75.algo.ts:60
	// this.whitelist(whitelist).value = appIDs
	frame_dig 1 // whitelist: Whitelist
	dup
	box_del
	pop
	frame_dig -3 // appIDs: uint64[]
	dup
	len
	pushint 8
	/
	itob
	extract 6 2
	swap
	concat
	box_put

	// *if1_condition
	// examples/arc75/arc75.algo.ts:62
	// preMBR > this.app.address.minBalance
	frame_dig 0 // preMBR: uint64
	global CurrentApplicationAddress
	acct_params_get AcctMinBalance
	pop
	>
	bz *if1_else

	// *if1_consequent
	// examples/arc75/arc75.algo.ts:63
	// this.sendMBRPayment(preMBR)
	frame_dig 0 // preMBR: uint64
	callsub sendMBRPayment
	b *if1_end

*if1_else:
	// examples/arc75/arc75.algo.ts:65
	// this.verifyMBRPayment(this.txnGroup[this.txn.groupIndex - 1] as PayTxn, preMBR)
	frame_dig 0 // preMBR: uint64
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// failed to cast this.txnGroup[this.txn.groupIndex - 1] to pay
	assert
	callsub verifyMBRPayment

*if1_end:
	retsub

// deleteWhitelist(string,uint16)void
*abi_route_deleteWhitelist:
	// boxIndex: uint16
	txna ApplicationArgs 2
	dup
	len
	pushint 2
	==

	// argument 0 (boxIndex) for deleteWhitelist must be a uint16
	assert
	btoi

	// arc: string
	txna ApplicationArgs 1
	extract 2 0

	// execute deleteWhitelist(string,uint16)void
	callsub deleteWhitelist
	int 1
	return

// deleteWhitelist(arc: string, boxIndex: uint16): void
//
// Deletes a app whitelist for the sender
//
// @param arc - The ARC the whitelist corresponds to
// @param boxIndex - The index of the whitelist box to delete
deleteWhitelist:
	proto 2 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// examples/arc75/arc75.algo.ts:77
	// preMBR = this.app.address.minBalance
	global CurrentApplicationAddress
	acct_params_get AcctMinBalance
	pop
	frame_bury 0 // preMBR: uint64

	// examples/arc75/arc75.algo.ts:78
	// whitelist: Whitelist = { account: this.txn.sender, boxIndex: boxIndex, arc: arc }
	byte 0x // initial head
	byte 0x // initial tail
	byte 0x0024 // initial head offset
	txn Sender
	callsub *process_static_tuple_element
	frame_dig -2 // boxIndex: uint16
	itob
	extract 6 2
	callsub *process_static_tuple_element
	frame_dig -1 // arc: string
	dup
	len
	itob
	extract 6 2
	swap
	concat
	callsub *process_dynamic_tuple_element
	pop // pop head offset
	concat // concat head and tail
	frame_bury 1 // whitelist: Whitelist

	// examples/arc75/arc75.algo.ts:80
	// this.whitelist(whitelist).delete()
	frame_dig 1 // whitelist: Whitelist
	box_del

	// examples/arc75/arc75.algo.ts:82
	// this.sendMBRPayment(preMBR)
	frame_dig 0 // preMBR: uint64
	callsub sendMBRPayment
	retsub

// deleteAppFromWhitelist(string,uint16,uint64,uint64)void
*abi_route_deleteAppFromWhitelist:
	// index: uint64
	txna ApplicationArgs 4
	btoi

	// appID: uint64
	txna ApplicationArgs 3
	btoi

	// boxIndex: uint16
	txna ApplicationArgs 2
	dup
	len
	pushint 2
	==

	// argument 2 (boxIndex) for deleteAppFromWhitelist must be a uint16
	assert
	btoi

	// arc: string
	txna ApplicationArgs 1
	extract 2 0

	// execute deleteAppFromWhitelist(string,uint16,uint64,uint64)void
	callsub deleteAppFromWhitelist
	int 1
	return

// deleteAppFromWhitelist(arc: string, boxIndex: uint16, appID: uint64, index: uint64): void
//
// Deletes a app from a whitelist for the sender
//
// @param boxIndex - The index of the whitelist box to delete from
// @param appID - The app ID to delete from the whitelist
// @param index - The index of the app in the whitelist
deleteAppFromWhitelist:
	proto 4 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// examples/arc75/arc75.algo.ts:94
	// preMBR = this.app.address.minBalance
	global CurrentApplicationAddress
	acct_params_get AcctMinBalance
	pop
	frame_bury 0 // preMBR: uint64

	// examples/arc75/arc75.algo.ts:95
	// whitelist: Whitelist = { account: this.txn.sender, boxIndex: boxIndex, arc: arc }
	byte 0x // initial head
	byte 0x // initial tail
	byte 0x0024 // initial head offset
	txn Sender
	callsub *process_static_tuple_element
	frame_dig -2 // boxIndex: uint16
	itob
	extract 6 2
	callsub *process_static_tuple_element
	frame_dig -1 // arc: string
	dup
	len
	itob
	extract 6 2
	swap
	concat
	callsub *process_dynamic_tuple_element
	pop // pop head offset
	concat // concat head and tail
	frame_bury 1 // whitelist: Whitelist

	// examples/arc75/arc75.algo.ts:97
	// spliced = this.whitelist(whitelist).value.splice(index, 1)
	frame_dig 1 // whitelist: Whitelist
	box_get

	// box value does not exist: this.whitelist(whitelist).value
	assert
	extract 2 0
	int 1
	frame_dig -4 // index: uint64
	pushint 8
	*
	store 247 // splice start
	pushint 16
	store 246 // splice byte length
	frame_dig 1 // whitelist: Whitelist
	box_get

	// box value does not exist: this.whitelist(whitelist).value
	assert
	extract 2 0
	pushint 0
	load 247 // splice start
	substring3
	frame_dig 1 // whitelist: Whitelist
	box_get

	// box value does not exist: this.whitelist(whitelist).value
	assert
	extract 2 0
	dup
	len
	load 247 // splice start
	load 246 // splice byte length
	+
	pushint 8
	-
	swap
	substring3
	concat
	frame_dig 1 // whitelist: Whitelist
	box_get

	// box value does not exist: this.whitelist(whitelist).value
	assert
	extract 2 0
	load 247 // splice start
	load 246 // splice byte length
	pushint 8
	-
	extract3
	swap
	frame_dig 1 // whitelist: Whitelist
	dup
	box_del
	pop
	swap
	dup
	len
	pushint 8
	/
	itob
	extract 6 2
	swap
	concat
	box_put
	frame_bury 2 // spliced: uint64[]

	// examples/arc75/arc75.algo.ts:99
	// assert(spliced[0] === appID)
	frame_dig 2 // spliced: uint64[]
	store 255 // full array
	load 255 // full array
	extract 0 8
	btoi
	frame_dig -3 // appID: uint64
	==
	assert

	// examples/arc75/arc75.algo.ts:101
	// this.sendMBRPayment(preMBR)
	frame_dig 0 // preMBR: uint64
	callsub sendMBRPayment
	retsub

*abi_route_createApplication:
	int 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x467c7cbd // method "addAppToWhiteList(string,uint16,uint64,pay)void"
	pushbytes 0xd198fcb8 // method "setAppWhitelist(string,uint16,uint64[])void"
	pushbytes 0x7c33e832 // method "deleteWhitelist(string,uint16)void"
	pushbytes 0x7e1674ac // method "deleteAppFromWhitelist(string,uint16,uint64,uint64)void"
	txna ApplicationArgs 0
	match *abi_route_addAppToWhiteList *abi_route_setAppWhitelist *abi_route_deleteWhitelist *abi_route_deleteAppFromWhitelist

	// this contract does not implement the given ABI method for call NoOp
	err

*process_static_tuple_element:
	proto 4 3
	frame_dig -4 // tuple head
	frame_dig -1 // element
	concat
	frame_dig -3 // tuple tail
	frame_dig -2 // head offset
	retsub

*process_dynamic_tuple_element:
	proto 4 3
	frame_dig -4 // tuple head
	frame_dig -2 // head offset
	concat
	frame_bury -4 // tuple head
	frame_dig -1 // element
	dup
	len
	frame_dig -2 // head offset
	btoi
	+
	itob
	extract 6 2
	frame_bury -2 // head offset
	frame_dig -3 // tuple tail
	swap
	concat
	frame_bury -3 // tuple tail
	frame_dig -4 // tuple head
	frame_dig -3 // tuple tail
	frame_dig -2 // head offset
	retsub", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/examples/auction/tealscript_artifacts/Auction.approval.teal b/examples/auction/tealscript_artifacts/Auction.approval.teal index 3e8632e9a..db49a3db3 100644 --- a/examples/auction/tealscript_artifacts/Auction.approval.teal +++ b/examples/auction/tealscript_artifacts/Auction.approval.teal @@ -2,7 +2,7 @@ intcblock 1 0 bytecblock 0x70726576696f7573426964646572 0x70726576696f7573426964 0x61756374696f6e456e64 0x636c61696d61626c65416d6f756e74 0x617361416d74 0x617361 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/examples/auction/tealscript_artifacts/Auction.arc32.json b/examples/auction/tealscript_artifacts/Auction.arc32.json index d5868428d..8f5f1e30f 100644 --- a/examples/auction/tealscript_artifacts/Auction.arc32.json +++ b/examples/auction/tealscript_artifacts/Auction.arc32.json @@ -95,7 +95,7 @@ } }, "source": { - "approval": "#pragma version 10
intcblock 1 0
bytecblock 0x70726576696f7573426964646572 0x70726576696f7573426964 0x61756374696f6e456e64 0x636c61696d61626c65416d6f756e74 0x617361416d74 0x617361 0x

// This TEAL was generated by TEALScript v0.104.1
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *call_OptIn *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *call_DeleteApplication *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// createApplication()void
*abi_route_createApplication:
	// execute createApplication()void
	callsub createApplication
	int 1
	return

// createApplication(): void
createApplication:
	proto 0 0

	// examples/auction/auction.algo.ts:18
	// this.auctionEnd.value = 0
	byte 0x61756374696f6e456e64 // "auctionEnd"
	int 0
	app_global_put

	// examples/auction/auction.algo.ts:19
	// this.previousBid.value = 0
	byte 0x70726576696f7573426964 // "previousBid"
	int 0
	app_global_put

	// examples/auction/auction.algo.ts:20
	// this.asaAmt.value = 0
	byte 0x617361416d74 // "asaAmt"
	int 0
	app_global_put

	// examples/auction/auction.algo.ts:21
	// this.asa.value = AssetID.zeroIndex
	byte 0x617361 // "asa"
	int 0
	app_global_put

	// examples/auction/auction.algo.ts:24
	// this.previousBidder.value = globals.zeroAddress
	byte 0x70726576696f7573426964646572 // "previousBidder"
	global ZeroAddress
	app_global_put
	retsub

// optIntoAsset(uint64)void
*abi_route_optIntoAsset:
	// asset: uint64
	txna ApplicationArgs 1
	btoi

	// execute optIntoAsset(uint64)void
	callsub optIntoAsset
	int 1
	return

// optIntoAsset(asset: AssetID): void
optIntoAsset:
	proto 1 0

	// Only allow app creator to opt the app account into a ASA
	// examples/auction/auction.algo.ts:29
	// verifyAppCallTxn(this.txn, { sender: globals.creatorAddress })
	// verify sender
	txn Sender
	global CreatorAddress
	==

	// transaction verification failed: {"txn":"this.txn","field":"sender","expected":"globals.creatorAddress"}
	assert

	// Verify a ASA hasn't already been opted into
	// examples/auction/auction.algo.ts:32
	// assert(this.asa.value === AssetID.zeroIndex)
	byte 0x617361 // "asa"
	app_global_get
	int 0
	==
	assert

	// Save ASA ID in global state
	// examples/auction/auction.algo.ts:35
	// this.asa.value = asset
	byte 0x617361 // "asa"
	frame_dig -1 // asset: AssetID
	app_global_put

	// Submit opt-in transaction: 0 asset transfer to self
	// examples/auction/auction.algo.ts:38
	// sendAssetTransfer({
	//       assetReceiver: this.app.address,
	//       xferAsset: asset,
	//       assetAmount: 0,
	//     })
	itxn_begin
	pushint 4 // axfer
	itxn_field TypeEnum

	// examples/auction/auction.algo.ts:39
	// assetReceiver: this.app.address
	global CurrentApplicationAddress
	itxn_field AssetReceiver

	// examples/auction/auction.algo.ts:40
	// xferAsset: asset
	frame_dig -1 // asset: AssetID
	itxn_field XferAsset

	// examples/auction/auction.algo.ts:41
	// assetAmount: 0
	int 0
	itxn_field AssetAmount

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// startAuction(uint64,uint64,axfer)void
*abi_route_startAuction:
	// axfer: axfer
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	pushint 4 // axfer
	==

	// argument 0 (axfer) for startAuction must be a axfer transaction
	assert

	// length: uint64
	txna ApplicationArgs 2
	btoi

	// startingPrice: uint64
	txna ApplicationArgs 1
	btoi

	// execute startAuction(uint64,uint64,axfer)void
	callsub startAuction
	int 1
	return

// startAuction(startingPrice: uint64, length: uint64, axfer: AssetTransferTxn): void
startAuction:
	proto 3 0

	// examples/auction/auction.algo.ts:46
	// verifyAppCallTxn(this.txn, { sender: globals.creatorAddress })
	// verify sender
	txn Sender
	global CreatorAddress
	==

	// transaction verification failed: {"txn":"this.txn","field":"sender","expected":"globals.creatorAddress"}
	assert

	// Ensure the auction hasn't already been started
	// examples/auction/auction.algo.ts:49
	// assert(this.auctionEnd.value === 0)
	byte 0x61756374696f6e456e64 // "auctionEnd"
	app_global_get
	int 0
	==
	assert

	// Verify axfer
	// examples/auction/auction.algo.ts:52
	// verifyAssetTransferTxn(axfer, { assetReceiver: this.app.address })
	// verify assetReceiver
	frame_dig -3 // axfer: AssetTransferTxn
	gtxns AssetReceiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"axfer","field":"assetReceiver","expected":"this.app.address"}
	assert

	// Set global state
	// examples/auction/auction.algo.ts:55
	// this.asaAmt.value = axfer.assetAmount
	byte 0x617361416d74 // "asaAmt"
	frame_dig -3 // axfer: AssetTransferTxn
	gtxns AssetAmount
	app_global_put

	// examples/auction/auction.algo.ts:56
	// this.auctionEnd.value = globals.latestTimestamp + length
	byte 0x61756374696f6e456e64 // "auctionEnd"
	global LatestTimestamp
	frame_dig -2 // length: uint64
	+
	app_global_put

	// examples/auction/auction.algo.ts:57
	// this.previousBid.value = startingPrice
	byte 0x70726576696f7573426964 // "previousBid"
	frame_dig -1 // startingPrice: uint64
	app_global_put
	retsub

// pay(receiver: Address, amount: uint64): void
pay:
	proto 2 0

	// examples/auction/auction.algo.ts:61
	// sendPayment({
	//       receiver: receiver,
	//       amount: amount,
	//     })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// examples/auction/auction.algo.ts:62
	// receiver: receiver
	frame_dig -1 // receiver: Address
	itxn_field Receiver

	// examples/auction/auction.algo.ts:63
	// amount: amount
	frame_dig -2 // amount: uint64
	itxn_field Amount

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// optInToApplication()void
*abi_route_optInToApplication:
	// execute optInToApplication()void
	callsub optInToApplication
	int 1
	return

// optInToApplication(): void
optInToApplication:
	proto 0 0
	retsub

// bid(pay)void
*abi_route_bid:
	// payment: pay
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// argument 0 (payment) for bid must be a pay transaction
	assert

	// execute bid(pay)void
	callsub bid
	int 1
	return

// bid(payment: PayTxn): void
bid:
	proto 1 0

	// Ensure auction hasn't ended
	// examples/auction/auction.algo.ts:72
	// assert(globals.latestTimestamp < this.auctionEnd.value)
	global LatestTimestamp
	byte 0x61756374696f6e456e64 // "auctionEnd"
	app_global_get
	<
	assert

	// Verify payment transaction
	// examples/auction/auction.algo.ts:75
	// verifyPayTxn(payment, {
	//       sender: this.txn.sender,
	//       amount: { greaterThan: this.previousBid.value },
	//     })
	// verify sender
	frame_dig -1 // payment: PayTxn
	gtxns Sender
	txn Sender
	==

	// transaction verification failed: {"txn":"payment","field":"sender","expected":"this.txn.sender"}
	assert

	// verify amount
	frame_dig -1 // payment: PayTxn
	gtxns Amount
	byte 0x70726576696f7573426964 // "previousBid"
	app_global_get
	>

	// transaction verification failed: {"txn":"payment","field":"amount","condition":"greaterThan","expected":">this.previousBid.value"}
	assert

	// Set global state
	// examples/auction/auction.algo.ts:81
	// this.previousBid.value = payment.amount
	byte 0x70726576696f7573426964 // "previousBid"
	frame_dig -1 // payment: PayTxn
	gtxns Amount
	app_global_put

	// examples/auction/auction.algo.ts:82
	// this.previousBidder.value = payment.sender
	byte 0x70726576696f7573426964646572 // "previousBidder"
	frame_dig -1 // payment: PayTxn
	gtxns Sender
	app_global_put

	// Update claimable amount
	// examples/auction/auction.algo.ts:85
	// this.claimableAmount(this.txn.sender).value = payment.amount
	txn Sender
	byte 0x636c61696d61626c65416d6f756e74 // "claimableAmount"
	frame_dig -1 // payment: PayTxn
	gtxns Amount
	app_local_put
	retsub

// claimBids()void
*abi_route_claimBids:
	// execute claimBids()void
	callsub claimBids
	int 1
	return

// claimBids(): void
claimBids:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// examples/auction/auction.algo.ts:89
	// originalAmount = this.claimableAmount(this.txn.sender).value
	txn Sender
	byte 0x636c61696d61626c65416d6f756e74 // "claimableAmount"
	app_local_get
	frame_bury 0 // originalAmount: uint64

	// examples/auction/auction.algo.ts:90
	// amount = originalAmount
	frame_dig 0 // originalAmount: uint64
	frame_bury 1 // amount: uint64

	// subtract previous bid if sender is previous bidder
	// *if0_condition
	// examples/auction/auction.algo.ts:93
	// this.txn.sender === this.previousBidder.value
	txn Sender
	byte 0x70726576696f7573426964646572 // "previousBidder"
	app_global_get
	==
	bz *if0_end

	// *if0_consequent
	// examples/auction/auction.algo.ts:93
	// amount = amount - this.previousBid.value
	frame_dig 1 // amount: uint64
	byte 0x70726576696f7573426964 // "previousBid"
	app_global_get
	-
	frame_bury 1 // amount: uint64

*if0_end:
	// examples/auction/auction.algo.ts:95
	// this.pay(this.txn.sender, amount)
	frame_dig 1 // amount: uint64
	txn Sender
	callsub pay

	// examples/auction/auction.algo.ts:96
	// this.claimableAmount(this.txn.sender).value = originalAmount - amount
	txn Sender
	byte 0x636c61696d61626c65416d6f756e74 // "claimableAmount"
	frame_dig 0 // originalAmount: uint64
	frame_dig 1 // amount: uint64
	-
	app_local_put
	retsub

// claim_asset(uint64)void
*abi_route_claim_asset:
	// asset: uint64
	txna ApplicationArgs 1
	btoi

	// execute claim_asset(uint64)void
	callsub claim_asset
	int 1
	return

// claim_asset(asset: AssetID): void
claim_asset:
	proto 1 0

	// examples/auction/auction.algo.ts:100
	// assert(globals.latestTimestamp > this.auctionEnd.value)
	global LatestTimestamp
	byte 0x61756374696f6e456e64 // "auctionEnd"
	app_global_get
	>
	assert

	// Send ASA to previous bidder
	// examples/auction/auction.algo.ts:103
	// sendAssetTransfer({
	//       assetReceiver: this.previousBidder.value,
	//       xferAsset: asset,
	//       assetAmount: this.asaAmt.value,
	//       assetCloseTo: this.previousBidder.value,
	//     })
	itxn_begin
	pushint 4 // axfer
	itxn_field TypeEnum

	// examples/auction/auction.algo.ts:104
	// assetReceiver: this.previousBidder.value
	byte 0x70726576696f7573426964646572 // "previousBidder"
	app_global_get
	itxn_field AssetReceiver

	// examples/auction/auction.algo.ts:105
	// xferAsset: asset
	frame_dig -1 // asset: AssetID
	itxn_field XferAsset

	// examples/auction/auction.algo.ts:106
	// assetAmount: this.asaAmt.value
	byte 0x617361416d74 // "asaAmt"
	app_global_get
	itxn_field AssetAmount

	// examples/auction/auction.algo.ts:107
	// assetCloseTo: this.previousBidder.value
	byte 0x70726576696f7573426964646572 // "previousBidder"
	app_global_get
	itxn_field AssetCloseTo

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// deleteApplication()void
*abi_route_deleteApplication:
	// execute deleteApplication()void
	callsub deleteApplication
	int 1
	return

// deleteApplication(): void
deleteApplication:
	proto 0 0

	// examples/auction/auction.algo.ts:112
	// sendPayment({
	//       receiver: globals.creatorAddress,
	//       closeRemainderTo: globals.creatorAddress,
	//       amount: 0,
	//     })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// examples/auction/auction.algo.ts:113
	// receiver: globals.creatorAddress
	global CreatorAddress
	itxn_field Receiver

	// examples/auction/auction.algo.ts:114
	// closeRemainderTo: globals.creatorAddress
	global CreatorAddress
	itxn_field CloseRemainderTo

	// examples/auction/auction.algo.ts:115
	// amount: 0
	int 0
	itxn_field Amount

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x3987f0c1 // method "optIntoAsset(uint64)void"
	pushbytes 0xc2725922 // method "startAuction(uint64,uint64,axfer)void"
	pushbytes 0xdb7fe843 // method "bid(pay)void"
	pushbytes 0x032f650d // method "claimBids()void"
	pushbytes 0x59b2ab26 // method "claim_asset(uint64)void"
	txna ApplicationArgs 0
	match *abi_route_optIntoAsset *abi_route_startAuction *abi_route_bid *abi_route_claimBids *abi_route_claim_asset

	// this contract does not implement the given ABI method for call NoOp
	err

*call_OptIn:
	pushbytes 0x01a3a3ff // method "optInToApplication()void"
	txna ApplicationArgs 0
	match *abi_route_optInToApplication

	// this contract does not implement the given ABI method for call OptIn
	err

*call_DeleteApplication:
	pushbytes 0x2487c32c // method "deleteApplication()void"
	txna ApplicationArgs 0
	match *abi_route_deleteApplication

	// this contract does not implement the given ABI method for call DeleteApplication
	err", + "approval": "#pragma version 10
intcblock 1 0
bytecblock 0x70726576696f7573426964646572 0x70726576696f7573426964 0x61756374696f6e456e64 0x636c61696d61626c65416d6f756e74 0x617361416d74 0x617361 0x

// This TEAL was generated by TEALScript v0.105.0
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *call_OptIn *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *call_DeleteApplication *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// createApplication()void
*abi_route_createApplication:
	// execute createApplication()void
	callsub createApplication
	int 1
	return

// createApplication(): void
createApplication:
	proto 0 0

	// examples/auction/auction.algo.ts:18
	// this.auctionEnd.value = 0
	byte 0x61756374696f6e456e64 // "auctionEnd"
	int 0
	app_global_put

	// examples/auction/auction.algo.ts:19
	// this.previousBid.value = 0
	byte 0x70726576696f7573426964 // "previousBid"
	int 0
	app_global_put

	// examples/auction/auction.algo.ts:20
	// this.asaAmt.value = 0
	byte 0x617361416d74 // "asaAmt"
	int 0
	app_global_put

	// examples/auction/auction.algo.ts:21
	// this.asa.value = AssetID.zeroIndex
	byte 0x617361 // "asa"
	int 0
	app_global_put

	// examples/auction/auction.algo.ts:24
	// this.previousBidder.value = globals.zeroAddress
	byte 0x70726576696f7573426964646572 // "previousBidder"
	global ZeroAddress
	app_global_put
	retsub

// optIntoAsset(uint64)void
*abi_route_optIntoAsset:
	// asset: uint64
	txna ApplicationArgs 1
	btoi

	// execute optIntoAsset(uint64)void
	callsub optIntoAsset
	int 1
	return

// optIntoAsset(asset: AssetID): void
optIntoAsset:
	proto 1 0

	// Only allow app creator to opt the app account into a ASA
	// examples/auction/auction.algo.ts:29
	// verifyAppCallTxn(this.txn, { sender: globals.creatorAddress })
	// verify sender
	txn Sender
	global CreatorAddress
	==

	// transaction verification failed: {"txn":"this.txn","field":"sender","expected":"globals.creatorAddress"}
	assert

	// Verify a ASA hasn't already been opted into
	// examples/auction/auction.algo.ts:32
	// assert(this.asa.value === AssetID.zeroIndex)
	byte 0x617361 // "asa"
	app_global_get
	int 0
	==
	assert

	// Save ASA ID in global state
	// examples/auction/auction.algo.ts:35
	// this.asa.value = asset
	byte 0x617361 // "asa"
	frame_dig -1 // asset: AssetID
	app_global_put

	// Submit opt-in transaction: 0 asset transfer to self
	// examples/auction/auction.algo.ts:38
	// sendAssetTransfer({
	//       assetReceiver: this.app.address,
	//       xferAsset: asset,
	//       assetAmount: 0,
	//     })
	itxn_begin
	pushint 4 // axfer
	itxn_field TypeEnum

	// examples/auction/auction.algo.ts:39
	// assetReceiver: this.app.address
	global CurrentApplicationAddress
	itxn_field AssetReceiver

	// examples/auction/auction.algo.ts:40
	// xferAsset: asset
	frame_dig -1 // asset: AssetID
	itxn_field XferAsset

	// examples/auction/auction.algo.ts:41
	// assetAmount: 0
	int 0
	itxn_field AssetAmount

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// startAuction(uint64,uint64,axfer)void
*abi_route_startAuction:
	// axfer: axfer
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	pushint 4 // axfer
	==

	// argument 0 (axfer) for startAuction must be a axfer transaction
	assert

	// length: uint64
	txna ApplicationArgs 2
	btoi

	// startingPrice: uint64
	txna ApplicationArgs 1
	btoi

	// execute startAuction(uint64,uint64,axfer)void
	callsub startAuction
	int 1
	return

// startAuction(startingPrice: uint64, length: uint64, axfer: AssetTransferTxn): void
startAuction:
	proto 3 0

	// examples/auction/auction.algo.ts:46
	// verifyAppCallTxn(this.txn, { sender: globals.creatorAddress })
	// verify sender
	txn Sender
	global CreatorAddress
	==

	// transaction verification failed: {"txn":"this.txn","field":"sender","expected":"globals.creatorAddress"}
	assert

	// Ensure the auction hasn't already been started
	// examples/auction/auction.algo.ts:49
	// assert(this.auctionEnd.value === 0)
	byte 0x61756374696f6e456e64 // "auctionEnd"
	app_global_get
	int 0
	==
	assert

	// Verify axfer
	// examples/auction/auction.algo.ts:52
	// verifyAssetTransferTxn(axfer, { assetReceiver: this.app.address })
	// verify assetReceiver
	frame_dig -3 // axfer: AssetTransferTxn
	gtxns AssetReceiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"axfer","field":"assetReceiver","expected":"this.app.address"}
	assert

	// Set global state
	// examples/auction/auction.algo.ts:55
	// this.asaAmt.value = axfer.assetAmount
	byte 0x617361416d74 // "asaAmt"
	frame_dig -3 // axfer: AssetTransferTxn
	gtxns AssetAmount
	app_global_put

	// examples/auction/auction.algo.ts:56
	// this.auctionEnd.value = globals.latestTimestamp + length
	byte 0x61756374696f6e456e64 // "auctionEnd"
	global LatestTimestamp
	frame_dig -2 // length: uint64
	+
	app_global_put

	// examples/auction/auction.algo.ts:57
	// this.previousBid.value = startingPrice
	byte 0x70726576696f7573426964 // "previousBid"
	frame_dig -1 // startingPrice: uint64
	app_global_put
	retsub

// pay(receiver: Address, amount: uint64): void
pay:
	proto 2 0

	// examples/auction/auction.algo.ts:61
	// sendPayment({
	//       receiver: receiver,
	//       amount: amount,
	//     })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// examples/auction/auction.algo.ts:62
	// receiver: receiver
	frame_dig -1 // receiver: Address
	itxn_field Receiver

	// examples/auction/auction.algo.ts:63
	// amount: amount
	frame_dig -2 // amount: uint64
	itxn_field Amount

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// optInToApplication()void
*abi_route_optInToApplication:
	// execute optInToApplication()void
	callsub optInToApplication
	int 1
	return

// optInToApplication(): void
optInToApplication:
	proto 0 0
	retsub

// bid(pay)void
*abi_route_bid:
	// payment: pay
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// argument 0 (payment) for bid must be a pay transaction
	assert

	// execute bid(pay)void
	callsub bid
	int 1
	return

// bid(payment: PayTxn): void
bid:
	proto 1 0

	// Ensure auction hasn't ended
	// examples/auction/auction.algo.ts:72
	// assert(globals.latestTimestamp < this.auctionEnd.value)
	global LatestTimestamp
	byte 0x61756374696f6e456e64 // "auctionEnd"
	app_global_get
	<
	assert

	// Verify payment transaction
	// examples/auction/auction.algo.ts:75
	// verifyPayTxn(payment, {
	//       sender: this.txn.sender,
	//       amount: { greaterThan: this.previousBid.value },
	//     })
	// verify sender
	frame_dig -1 // payment: PayTxn
	gtxns Sender
	txn Sender
	==

	// transaction verification failed: {"txn":"payment","field":"sender","expected":"this.txn.sender"}
	assert

	// verify amount
	frame_dig -1 // payment: PayTxn
	gtxns Amount
	byte 0x70726576696f7573426964 // "previousBid"
	app_global_get
	>

	// transaction verification failed: {"txn":"payment","field":"amount","condition":"greaterThan","expected":">this.previousBid.value"}
	assert

	// Set global state
	// examples/auction/auction.algo.ts:81
	// this.previousBid.value = payment.amount
	byte 0x70726576696f7573426964 // "previousBid"
	frame_dig -1 // payment: PayTxn
	gtxns Amount
	app_global_put

	// examples/auction/auction.algo.ts:82
	// this.previousBidder.value = payment.sender
	byte 0x70726576696f7573426964646572 // "previousBidder"
	frame_dig -1 // payment: PayTxn
	gtxns Sender
	app_global_put

	// Update claimable amount
	// examples/auction/auction.algo.ts:85
	// this.claimableAmount(this.txn.sender).value = payment.amount
	txn Sender
	byte 0x636c61696d61626c65416d6f756e74 // "claimableAmount"
	frame_dig -1 // payment: PayTxn
	gtxns Amount
	app_local_put
	retsub

// claimBids()void
*abi_route_claimBids:
	// execute claimBids()void
	callsub claimBids
	int 1
	return

// claimBids(): void
claimBids:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// examples/auction/auction.algo.ts:89
	// originalAmount = this.claimableAmount(this.txn.sender).value
	txn Sender
	byte 0x636c61696d61626c65416d6f756e74 // "claimableAmount"
	app_local_get
	frame_bury 0 // originalAmount: uint64

	// examples/auction/auction.algo.ts:90
	// amount = originalAmount
	frame_dig 0 // originalAmount: uint64
	frame_bury 1 // amount: uint64

	// subtract previous bid if sender is previous bidder
	// *if0_condition
	// examples/auction/auction.algo.ts:93
	// this.txn.sender === this.previousBidder.value
	txn Sender
	byte 0x70726576696f7573426964646572 // "previousBidder"
	app_global_get
	==
	bz *if0_end

	// *if0_consequent
	// examples/auction/auction.algo.ts:93
	// amount = amount - this.previousBid.value
	frame_dig 1 // amount: uint64
	byte 0x70726576696f7573426964 // "previousBid"
	app_global_get
	-
	frame_bury 1 // amount: uint64

*if0_end:
	// examples/auction/auction.algo.ts:95
	// this.pay(this.txn.sender, amount)
	frame_dig 1 // amount: uint64
	txn Sender
	callsub pay

	// examples/auction/auction.algo.ts:96
	// this.claimableAmount(this.txn.sender).value = originalAmount - amount
	txn Sender
	byte 0x636c61696d61626c65416d6f756e74 // "claimableAmount"
	frame_dig 0 // originalAmount: uint64
	frame_dig 1 // amount: uint64
	-
	app_local_put
	retsub

// claim_asset(uint64)void
*abi_route_claim_asset:
	// asset: uint64
	txna ApplicationArgs 1
	btoi

	// execute claim_asset(uint64)void
	callsub claim_asset
	int 1
	return

// claim_asset(asset: AssetID): void
claim_asset:
	proto 1 0

	// examples/auction/auction.algo.ts:100
	// assert(globals.latestTimestamp > this.auctionEnd.value)
	global LatestTimestamp
	byte 0x61756374696f6e456e64 // "auctionEnd"
	app_global_get
	>
	assert

	// Send ASA to previous bidder
	// examples/auction/auction.algo.ts:103
	// sendAssetTransfer({
	//       assetReceiver: this.previousBidder.value,
	//       xferAsset: asset,
	//       assetAmount: this.asaAmt.value,
	//       assetCloseTo: this.previousBidder.value,
	//     })
	itxn_begin
	pushint 4 // axfer
	itxn_field TypeEnum

	// examples/auction/auction.algo.ts:104
	// assetReceiver: this.previousBidder.value
	byte 0x70726576696f7573426964646572 // "previousBidder"
	app_global_get
	itxn_field AssetReceiver

	// examples/auction/auction.algo.ts:105
	// xferAsset: asset
	frame_dig -1 // asset: AssetID
	itxn_field XferAsset

	// examples/auction/auction.algo.ts:106
	// assetAmount: this.asaAmt.value
	byte 0x617361416d74 // "asaAmt"
	app_global_get
	itxn_field AssetAmount

	// examples/auction/auction.algo.ts:107
	// assetCloseTo: this.previousBidder.value
	byte 0x70726576696f7573426964646572 // "previousBidder"
	app_global_get
	itxn_field AssetCloseTo

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// deleteApplication()void
*abi_route_deleteApplication:
	// execute deleteApplication()void
	callsub deleteApplication
	int 1
	return

// deleteApplication(): void
deleteApplication:
	proto 0 0

	// examples/auction/auction.algo.ts:112
	// sendPayment({
	//       receiver: globals.creatorAddress,
	//       closeRemainderTo: globals.creatorAddress,
	//       amount: 0,
	//     })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// examples/auction/auction.algo.ts:113
	// receiver: globals.creatorAddress
	global CreatorAddress
	itxn_field Receiver

	// examples/auction/auction.algo.ts:114
	// closeRemainderTo: globals.creatorAddress
	global CreatorAddress
	itxn_field CloseRemainderTo

	// examples/auction/auction.algo.ts:115
	// amount: 0
	int 0
	itxn_field Amount

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x3987f0c1 // method "optIntoAsset(uint64)void"
	pushbytes 0xc2725922 // method "startAuction(uint64,uint64,axfer)void"
	pushbytes 0xdb7fe843 // method "bid(pay)void"
	pushbytes 0x032f650d // method "claimBids()void"
	pushbytes 0x59b2ab26 // method "claim_asset(uint64)void"
	txna ApplicationArgs 0
	match *abi_route_optIntoAsset *abi_route_startAuction *abi_route_bid *abi_route_claimBids *abi_route_claim_asset

	// this contract does not implement the given ABI method for call NoOp
	err

*call_OptIn:
	pushbytes 0x01a3a3ff // method "optInToApplication()void"
	txna ApplicationArgs 0
	match *abi_route_optInToApplication

	// this contract does not implement the given ABI method for call OptIn
	err

*call_DeleteApplication:
	pushbytes 0x2487c32c // method "deleteApplication()void"
	txna ApplicationArgs 0
	match *abi_route_deleteApplication

	// this contract does not implement the given ABI method for call DeleteApplication
	err", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/examples/auction/tealscript_artifacts/Auction.arc56_draft.json b/examples/auction/tealscript_artifacts/Auction.arc56_draft.json index 2f0dd94b7..cdfd9e49c 100644 --- a/examples/auction/tealscript_artifacts/Auction.arc56_draft.json +++ b/examples/auction/tealscript_artifacts/Auction.arc56_draft.json @@ -2639,7 +2639,7 @@ } }, "source": { - "approval": "#pragma version 10
intcblock 1 0
bytecblock 0x70726576696f7573426964646572 0x70726576696f7573426964 0x61756374696f6e456e64 0x636c61696d61626c65416d6f756e74 0x617361416d74 0x617361 0x

// This TEAL was generated by TEALScript v0.104.1
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *call_OptIn *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *call_DeleteApplication *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// createApplication()void
*abi_route_createApplication:
	// execute createApplication()void
	callsub createApplication
	int 1
	return

// createApplication(): void
createApplication:
	proto 0 0

	// examples/auction/auction.algo.ts:18
	// this.auctionEnd.value = 0
	byte 0x61756374696f6e456e64 // "auctionEnd"
	int 0
	app_global_put

	// examples/auction/auction.algo.ts:19
	// this.previousBid.value = 0
	byte 0x70726576696f7573426964 // "previousBid"
	int 0
	app_global_put

	// examples/auction/auction.algo.ts:20
	// this.asaAmt.value = 0
	byte 0x617361416d74 // "asaAmt"
	int 0
	app_global_put

	// examples/auction/auction.algo.ts:21
	// this.asa.value = AssetID.zeroIndex
	byte 0x617361 // "asa"
	int 0
	app_global_put

	// examples/auction/auction.algo.ts:24
	// this.previousBidder.value = globals.zeroAddress
	byte 0x70726576696f7573426964646572 // "previousBidder"
	global ZeroAddress
	app_global_put
	retsub

// optIntoAsset(uint64)void
*abi_route_optIntoAsset:
	// asset: uint64
	txna ApplicationArgs 1
	btoi

	// execute optIntoAsset(uint64)void
	callsub optIntoAsset
	int 1
	return

// optIntoAsset(asset: AssetID): void
optIntoAsset:
	proto 1 0

	// Only allow app creator to opt the app account into a ASA
	// examples/auction/auction.algo.ts:29
	// verifyAppCallTxn(this.txn, { sender: globals.creatorAddress })
	// verify sender
	txn Sender
	global CreatorAddress
	==

	// transaction verification failed: {"txn":"this.txn","field":"sender","expected":"globals.creatorAddress"}
	assert

	// Verify a ASA hasn't already been opted into
	// examples/auction/auction.algo.ts:32
	// assert(this.asa.value === AssetID.zeroIndex)
	byte 0x617361 // "asa"
	app_global_get
	int 0
	==
	assert

	// Save ASA ID in global state
	// examples/auction/auction.algo.ts:35
	// this.asa.value = asset
	byte 0x617361 // "asa"
	frame_dig -1 // asset: AssetID
	app_global_put

	// Submit opt-in transaction: 0 asset transfer to self
	// examples/auction/auction.algo.ts:38
	// sendAssetTransfer({
	//       assetReceiver: this.app.address,
	//       xferAsset: asset,
	//       assetAmount: 0,
	//     })
	itxn_begin
	pushint 4 // axfer
	itxn_field TypeEnum

	// examples/auction/auction.algo.ts:39
	// assetReceiver: this.app.address
	global CurrentApplicationAddress
	itxn_field AssetReceiver

	// examples/auction/auction.algo.ts:40
	// xferAsset: asset
	frame_dig -1 // asset: AssetID
	itxn_field XferAsset

	// examples/auction/auction.algo.ts:41
	// assetAmount: 0
	int 0
	itxn_field AssetAmount

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// startAuction(uint64,uint64,axfer)void
*abi_route_startAuction:
	// axfer: axfer
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	pushint 4 // axfer
	==

	// argument 0 (axfer) for startAuction must be a axfer transaction
	assert

	// length: uint64
	txna ApplicationArgs 2
	btoi

	// startingPrice: uint64
	txna ApplicationArgs 1
	btoi

	// execute startAuction(uint64,uint64,axfer)void
	callsub startAuction
	int 1
	return

// startAuction(startingPrice: uint64, length: uint64, axfer: AssetTransferTxn): void
startAuction:
	proto 3 0

	// examples/auction/auction.algo.ts:46
	// verifyAppCallTxn(this.txn, { sender: globals.creatorAddress })
	// verify sender
	txn Sender
	global CreatorAddress
	==

	// transaction verification failed: {"txn":"this.txn","field":"sender","expected":"globals.creatorAddress"}
	assert

	// Ensure the auction hasn't already been started
	// examples/auction/auction.algo.ts:49
	// assert(this.auctionEnd.value === 0)
	byte 0x61756374696f6e456e64 // "auctionEnd"
	app_global_get
	int 0
	==
	assert

	// Verify axfer
	// examples/auction/auction.algo.ts:52
	// verifyAssetTransferTxn(axfer, { assetReceiver: this.app.address })
	// verify assetReceiver
	frame_dig -3 // axfer: AssetTransferTxn
	gtxns AssetReceiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"axfer","field":"assetReceiver","expected":"this.app.address"}
	assert

	// Set global state
	// examples/auction/auction.algo.ts:55
	// this.asaAmt.value = axfer.assetAmount
	byte 0x617361416d74 // "asaAmt"
	frame_dig -3 // axfer: AssetTransferTxn
	gtxns AssetAmount
	app_global_put

	// examples/auction/auction.algo.ts:56
	// this.auctionEnd.value = globals.latestTimestamp + length
	byte 0x61756374696f6e456e64 // "auctionEnd"
	global LatestTimestamp
	frame_dig -2 // length: uint64
	+
	app_global_put

	// examples/auction/auction.algo.ts:57
	// this.previousBid.value = startingPrice
	byte 0x70726576696f7573426964 // "previousBid"
	frame_dig -1 // startingPrice: uint64
	app_global_put
	retsub

// pay(receiver: Address, amount: uint64): void
pay:
	proto 2 0

	// examples/auction/auction.algo.ts:61
	// sendPayment({
	//       receiver: receiver,
	//       amount: amount,
	//     })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// examples/auction/auction.algo.ts:62
	// receiver: receiver
	frame_dig -1 // receiver: Address
	itxn_field Receiver

	// examples/auction/auction.algo.ts:63
	// amount: amount
	frame_dig -2 // amount: uint64
	itxn_field Amount

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// optInToApplication()void
*abi_route_optInToApplication:
	// execute optInToApplication()void
	callsub optInToApplication
	int 1
	return

// optInToApplication(): void
optInToApplication:
	proto 0 0
	retsub

// bid(pay)void
*abi_route_bid:
	// payment: pay
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// argument 0 (payment) for bid must be a pay transaction
	assert

	// execute bid(pay)void
	callsub bid
	int 1
	return

// bid(payment: PayTxn): void
bid:
	proto 1 0

	// Ensure auction hasn't ended
	// examples/auction/auction.algo.ts:72
	// assert(globals.latestTimestamp < this.auctionEnd.value)
	global LatestTimestamp
	byte 0x61756374696f6e456e64 // "auctionEnd"
	app_global_get
	<
	assert

	// Verify payment transaction
	// examples/auction/auction.algo.ts:75
	// verifyPayTxn(payment, {
	//       sender: this.txn.sender,
	//       amount: { greaterThan: this.previousBid.value },
	//     })
	// verify sender
	frame_dig -1 // payment: PayTxn
	gtxns Sender
	txn Sender
	==

	// transaction verification failed: {"txn":"payment","field":"sender","expected":"this.txn.sender"}
	assert

	// verify amount
	frame_dig -1 // payment: PayTxn
	gtxns Amount
	byte 0x70726576696f7573426964 // "previousBid"
	app_global_get
	>

	// transaction verification failed: {"txn":"payment","field":"amount","condition":"greaterThan","expected":">this.previousBid.value"}
	assert

	// Set global state
	// examples/auction/auction.algo.ts:81
	// this.previousBid.value = payment.amount
	byte 0x70726576696f7573426964 // "previousBid"
	frame_dig -1 // payment: PayTxn
	gtxns Amount
	app_global_put

	// examples/auction/auction.algo.ts:82
	// this.previousBidder.value = payment.sender
	byte 0x70726576696f7573426964646572 // "previousBidder"
	frame_dig -1 // payment: PayTxn
	gtxns Sender
	app_global_put

	// Update claimable amount
	// examples/auction/auction.algo.ts:85
	// this.claimableAmount(this.txn.sender).value = payment.amount
	txn Sender
	byte 0x636c61696d61626c65416d6f756e74 // "claimableAmount"
	frame_dig -1 // payment: PayTxn
	gtxns Amount
	app_local_put
	retsub

// claimBids()void
*abi_route_claimBids:
	// execute claimBids()void
	callsub claimBids
	int 1
	return

// claimBids(): void
claimBids:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// examples/auction/auction.algo.ts:89
	// originalAmount = this.claimableAmount(this.txn.sender).value
	txn Sender
	byte 0x636c61696d61626c65416d6f756e74 // "claimableAmount"
	app_local_get
	frame_bury 0 // originalAmount: uint64

	// examples/auction/auction.algo.ts:90
	// amount = originalAmount
	frame_dig 0 // originalAmount: uint64
	frame_bury 1 // amount: uint64

	// subtract previous bid if sender is previous bidder
	// *if0_condition
	// examples/auction/auction.algo.ts:93
	// this.txn.sender === this.previousBidder.value
	txn Sender
	byte 0x70726576696f7573426964646572 // "previousBidder"
	app_global_get
	==
	bz *if0_end

	// *if0_consequent
	// examples/auction/auction.algo.ts:93
	// amount = amount - this.previousBid.value
	frame_dig 1 // amount: uint64
	byte 0x70726576696f7573426964 // "previousBid"
	app_global_get
	-
	frame_bury 1 // amount: uint64

*if0_end:
	// examples/auction/auction.algo.ts:95
	// this.pay(this.txn.sender, amount)
	frame_dig 1 // amount: uint64
	txn Sender
	callsub pay

	// examples/auction/auction.algo.ts:96
	// this.claimableAmount(this.txn.sender).value = originalAmount - amount
	txn Sender
	byte 0x636c61696d61626c65416d6f756e74 // "claimableAmount"
	frame_dig 0 // originalAmount: uint64
	frame_dig 1 // amount: uint64
	-
	app_local_put
	retsub

// claim_asset(uint64)void
*abi_route_claim_asset:
	// asset: uint64
	txna ApplicationArgs 1
	btoi

	// execute claim_asset(uint64)void
	callsub claim_asset
	int 1
	return

// claim_asset(asset: AssetID): void
claim_asset:
	proto 1 0

	// examples/auction/auction.algo.ts:100
	// assert(globals.latestTimestamp > this.auctionEnd.value)
	global LatestTimestamp
	byte 0x61756374696f6e456e64 // "auctionEnd"
	app_global_get
	>
	assert

	// Send ASA to previous bidder
	// examples/auction/auction.algo.ts:103
	// sendAssetTransfer({
	//       assetReceiver: this.previousBidder.value,
	//       xferAsset: asset,
	//       assetAmount: this.asaAmt.value,
	//       assetCloseTo: this.previousBidder.value,
	//     })
	itxn_begin
	pushint 4 // axfer
	itxn_field TypeEnum

	// examples/auction/auction.algo.ts:104
	// assetReceiver: this.previousBidder.value
	byte 0x70726576696f7573426964646572 // "previousBidder"
	app_global_get
	itxn_field AssetReceiver

	// examples/auction/auction.algo.ts:105
	// xferAsset: asset
	frame_dig -1 // asset: AssetID
	itxn_field XferAsset

	// examples/auction/auction.algo.ts:106
	// assetAmount: this.asaAmt.value
	byte 0x617361416d74 // "asaAmt"
	app_global_get
	itxn_field AssetAmount

	// examples/auction/auction.algo.ts:107
	// assetCloseTo: this.previousBidder.value
	byte 0x70726576696f7573426964646572 // "previousBidder"
	app_global_get
	itxn_field AssetCloseTo

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// deleteApplication()void
*abi_route_deleteApplication:
	// execute deleteApplication()void
	callsub deleteApplication
	int 1
	return

// deleteApplication(): void
deleteApplication:
	proto 0 0

	// examples/auction/auction.algo.ts:112
	// sendPayment({
	//       receiver: globals.creatorAddress,
	//       closeRemainderTo: globals.creatorAddress,
	//       amount: 0,
	//     })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// examples/auction/auction.algo.ts:113
	// receiver: globals.creatorAddress
	global CreatorAddress
	itxn_field Receiver

	// examples/auction/auction.algo.ts:114
	// closeRemainderTo: globals.creatorAddress
	global CreatorAddress
	itxn_field CloseRemainderTo

	// examples/auction/auction.algo.ts:115
	// amount: 0
	int 0
	itxn_field Amount

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x3987f0c1 // method "optIntoAsset(uint64)void"
	pushbytes 0xc2725922 // method "startAuction(uint64,uint64,axfer)void"
	pushbytes 0xdb7fe843 // method "bid(pay)void"
	pushbytes 0x032f650d // method "claimBids()void"
	pushbytes 0x59b2ab26 // method "claim_asset(uint64)void"
	txna ApplicationArgs 0
	match *abi_route_optIntoAsset *abi_route_startAuction *abi_route_bid *abi_route_claimBids *abi_route_claim_asset

	// this contract does not implement the given ABI method for call NoOp
	err

*call_OptIn:
	pushbytes 0x01a3a3ff // method "optInToApplication()void"
	txna ApplicationArgs 0
	match *abi_route_optInToApplication

	// this contract does not implement the given ABI method for call OptIn
	err

*call_DeleteApplication:
	pushbytes 0x2487c32c // method "deleteApplication()void"
	txna ApplicationArgs 0
	match *abi_route_deleteApplication

	// this contract does not implement the given ABI method for call DeleteApplication
	err", + "approval": "#pragma version 10
intcblock 1 0
bytecblock 0x70726576696f7573426964646572 0x70726576696f7573426964 0x61756374696f6e456e64 0x636c61696d61626c65416d6f756e74 0x617361416d74 0x617361 0x

// This TEAL was generated by TEALScript v0.105.0
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *call_OptIn *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *call_DeleteApplication *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// createApplication()void
*abi_route_createApplication:
	// execute createApplication()void
	callsub createApplication
	int 1
	return

// createApplication(): void
createApplication:
	proto 0 0

	// examples/auction/auction.algo.ts:18
	// this.auctionEnd.value = 0
	byte 0x61756374696f6e456e64 // "auctionEnd"
	int 0
	app_global_put

	// examples/auction/auction.algo.ts:19
	// this.previousBid.value = 0
	byte 0x70726576696f7573426964 // "previousBid"
	int 0
	app_global_put

	// examples/auction/auction.algo.ts:20
	// this.asaAmt.value = 0
	byte 0x617361416d74 // "asaAmt"
	int 0
	app_global_put

	// examples/auction/auction.algo.ts:21
	// this.asa.value = AssetID.zeroIndex
	byte 0x617361 // "asa"
	int 0
	app_global_put

	// examples/auction/auction.algo.ts:24
	// this.previousBidder.value = globals.zeroAddress
	byte 0x70726576696f7573426964646572 // "previousBidder"
	global ZeroAddress
	app_global_put
	retsub

// optIntoAsset(uint64)void
*abi_route_optIntoAsset:
	// asset: uint64
	txna ApplicationArgs 1
	btoi

	// execute optIntoAsset(uint64)void
	callsub optIntoAsset
	int 1
	return

// optIntoAsset(asset: AssetID): void
optIntoAsset:
	proto 1 0

	// Only allow app creator to opt the app account into a ASA
	// examples/auction/auction.algo.ts:29
	// verifyAppCallTxn(this.txn, { sender: globals.creatorAddress })
	// verify sender
	txn Sender
	global CreatorAddress
	==

	// transaction verification failed: {"txn":"this.txn","field":"sender","expected":"globals.creatorAddress"}
	assert

	// Verify a ASA hasn't already been opted into
	// examples/auction/auction.algo.ts:32
	// assert(this.asa.value === AssetID.zeroIndex)
	byte 0x617361 // "asa"
	app_global_get
	int 0
	==
	assert

	// Save ASA ID in global state
	// examples/auction/auction.algo.ts:35
	// this.asa.value = asset
	byte 0x617361 // "asa"
	frame_dig -1 // asset: AssetID
	app_global_put

	// Submit opt-in transaction: 0 asset transfer to self
	// examples/auction/auction.algo.ts:38
	// sendAssetTransfer({
	//       assetReceiver: this.app.address,
	//       xferAsset: asset,
	//       assetAmount: 0,
	//     })
	itxn_begin
	pushint 4 // axfer
	itxn_field TypeEnum

	// examples/auction/auction.algo.ts:39
	// assetReceiver: this.app.address
	global CurrentApplicationAddress
	itxn_field AssetReceiver

	// examples/auction/auction.algo.ts:40
	// xferAsset: asset
	frame_dig -1 // asset: AssetID
	itxn_field XferAsset

	// examples/auction/auction.algo.ts:41
	// assetAmount: 0
	int 0
	itxn_field AssetAmount

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// startAuction(uint64,uint64,axfer)void
*abi_route_startAuction:
	// axfer: axfer
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	pushint 4 // axfer
	==

	// argument 0 (axfer) for startAuction must be a axfer transaction
	assert

	// length: uint64
	txna ApplicationArgs 2
	btoi

	// startingPrice: uint64
	txna ApplicationArgs 1
	btoi

	// execute startAuction(uint64,uint64,axfer)void
	callsub startAuction
	int 1
	return

// startAuction(startingPrice: uint64, length: uint64, axfer: AssetTransferTxn): void
startAuction:
	proto 3 0

	// examples/auction/auction.algo.ts:46
	// verifyAppCallTxn(this.txn, { sender: globals.creatorAddress })
	// verify sender
	txn Sender
	global CreatorAddress
	==

	// transaction verification failed: {"txn":"this.txn","field":"sender","expected":"globals.creatorAddress"}
	assert

	// Ensure the auction hasn't already been started
	// examples/auction/auction.algo.ts:49
	// assert(this.auctionEnd.value === 0)
	byte 0x61756374696f6e456e64 // "auctionEnd"
	app_global_get
	int 0
	==
	assert

	// Verify axfer
	// examples/auction/auction.algo.ts:52
	// verifyAssetTransferTxn(axfer, { assetReceiver: this.app.address })
	// verify assetReceiver
	frame_dig -3 // axfer: AssetTransferTxn
	gtxns AssetReceiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"axfer","field":"assetReceiver","expected":"this.app.address"}
	assert

	// Set global state
	// examples/auction/auction.algo.ts:55
	// this.asaAmt.value = axfer.assetAmount
	byte 0x617361416d74 // "asaAmt"
	frame_dig -3 // axfer: AssetTransferTxn
	gtxns AssetAmount
	app_global_put

	// examples/auction/auction.algo.ts:56
	// this.auctionEnd.value = globals.latestTimestamp + length
	byte 0x61756374696f6e456e64 // "auctionEnd"
	global LatestTimestamp
	frame_dig -2 // length: uint64
	+
	app_global_put

	// examples/auction/auction.algo.ts:57
	// this.previousBid.value = startingPrice
	byte 0x70726576696f7573426964 // "previousBid"
	frame_dig -1 // startingPrice: uint64
	app_global_put
	retsub

// pay(receiver: Address, amount: uint64): void
pay:
	proto 2 0

	// examples/auction/auction.algo.ts:61
	// sendPayment({
	//       receiver: receiver,
	//       amount: amount,
	//     })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// examples/auction/auction.algo.ts:62
	// receiver: receiver
	frame_dig -1 // receiver: Address
	itxn_field Receiver

	// examples/auction/auction.algo.ts:63
	// amount: amount
	frame_dig -2 // amount: uint64
	itxn_field Amount

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// optInToApplication()void
*abi_route_optInToApplication:
	// execute optInToApplication()void
	callsub optInToApplication
	int 1
	return

// optInToApplication(): void
optInToApplication:
	proto 0 0
	retsub

// bid(pay)void
*abi_route_bid:
	// payment: pay
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// argument 0 (payment) for bid must be a pay transaction
	assert

	// execute bid(pay)void
	callsub bid
	int 1
	return

// bid(payment: PayTxn): void
bid:
	proto 1 0

	// Ensure auction hasn't ended
	// examples/auction/auction.algo.ts:72
	// assert(globals.latestTimestamp < this.auctionEnd.value)
	global LatestTimestamp
	byte 0x61756374696f6e456e64 // "auctionEnd"
	app_global_get
	<
	assert

	// Verify payment transaction
	// examples/auction/auction.algo.ts:75
	// verifyPayTxn(payment, {
	//       sender: this.txn.sender,
	//       amount: { greaterThan: this.previousBid.value },
	//     })
	// verify sender
	frame_dig -1 // payment: PayTxn
	gtxns Sender
	txn Sender
	==

	// transaction verification failed: {"txn":"payment","field":"sender","expected":"this.txn.sender"}
	assert

	// verify amount
	frame_dig -1 // payment: PayTxn
	gtxns Amount
	byte 0x70726576696f7573426964 // "previousBid"
	app_global_get
	>

	// transaction verification failed: {"txn":"payment","field":"amount","condition":"greaterThan","expected":">this.previousBid.value"}
	assert

	// Set global state
	// examples/auction/auction.algo.ts:81
	// this.previousBid.value = payment.amount
	byte 0x70726576696f7573426964 // "previousBid"
	frame_dig -1 // payment: PayTxn
	gtxns Amount
	app_global_put

	// examples/auction/auction.algo.ts:82
	// this.previousBidder.value = payment.sender
	byte 0x70726576696f7573426964646572 // "previousBidder"
	frame_dig -1 // payment: PayTxn
	gtxns Sender
	app_global_put

	// Update claimable amount
	// examples/auction/auction.algo.ts:85
	// this.claimableAmount(this.txn.sender).value = payment.amount
	txn Sender
	byte 0x636c61696d61626c65416d6f756e74 // "claimableAmount"
	frame_dig -1 // payment: PayTxn
	gtxns Amount
	app_local_put
	retsub

// claimBids()void
*abi_route_claimBids:
	// execute claimBids()void
	callsub claimBids
	int 1
	return

// claimBids(): void
claimBids:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// examples/auction/auction.algo.ts:89
	// originalAmount = this.claimableAmount(this.txn.sender).value
	txn Sender
	byte 0x636c61696d61626c65416d6f756e74 // "claimableAmount"
	app_local_get
	frame_bury 0 // originalAmount: uint64

	// examples/auction/auction.algo.ts:90
	// amount = originalAmount
	frame_dig 0 // originalAmount: uint64
	frame_bury 1 // amount: uint64

	// subtract previous bid if sender is previous bidder
	// *if0_condition
	// examples/auction/auction.algo.ts:93
	// this.txn.sender === this.previousBidder.value
	txn Sender
	byte 0x70726576696f7573426964646572 // "previousBidder"
	app_global_get
	==
	bz *if0_end

	// *if0_consequent
	// examples/auction/auction.algo.ts:93
	// amount = amount - this.previousBid.value
	frame_dig 1 // amount: uint64
	byte 0x70726576696f7573426964 // "previousBid"
	app_global_get
	-
	frame_bury 1 // amount: uint64

*if0_end:
	// examples/auction/auction.algo.ts:95
	// this.pay(this.txn.sender, amount)
	frame_dig 1 // amount: uint64
	txn Sender
	callsub pay

	// examples/auction/auction.algo.ts:96
	// this.claimableAmount(this.txn.sender).value = originalAmount - amount
	txn Sender
	byte 0x636c61696d61626c65416d6f756e74 // "claimableAmount"
	frame_dig 0 // originalAmount: uint64
	frame_dig 1 // amount: uint64
	-
	app_local_put
	retsub

// claim_asset(uint64)void
*abi_route_claim_asset:
	// asset: uint64
	txna ApplicationArgs 1
	btoi

	// execute claim_asset(uint64)void
	callsub claim_asset
	int 1
	return

// claim_asset(asset: AssetID): void
claim_asset:
	proto 1 0

	// examples/auction/auction.algo.ts:100
	// assert(globals.latestTimestamp > this.auctionEnd.value)
	global LatestTimestamp
	byte 0x61756374696f6e456e64 // "auctionEnd"
	app_global_get
	>
	assert

	// Send ASA to previous bidder
	// examples/auction/auction.algo.ts:103
	// sendAssetTransfer({
	//       assetReceiver: this.previousBidder.value,
	//       xferAsset: asset,
	//       assetAmount: this.asaAmt.value,
	//       assetCloseTo: this.previousBidder.value,
	//     })
	itxn_begin
	pushint 4 // axfer
	itxn_field TypeEnum

	// examples/auction/auction.algo.ts:104
	// assetReceiver: this.previousBidder.value
	byte 0x70726576696f7573426964646572 // "previousBidder"
	app_global_get
	itxn_field AssetReceiver

	// examples/auction/auction.algo.ts:105
	// xferAsset: asset
	frame_dig -1 // asset: AssetID
	itxn_field XferAsset

	// examples/auction/auction.algo.ts:106
	// assetAmount: this.asaAmt.value
	byte 0x617361416d74 // "asaAmt"
	app_global_get
	itxn_field AssetAmount

	// examples/auction/auction.algo.ts:107
	// assetCloseTo: this.previousBidder.value
	byte 0x70726576696f7573426964646572 // "previousBidder"
	app_global_get
	itxn_field AssetCloseTo

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// deleteApplication()void
*abi_route_deleteApplication:
	// execute deleteApplication()void
	callsub deleteApplication
	int 1
	return

// deleteApplication(): void
deleteApplication:
	proto 0 0

	// examples/auction/auction.algo.ts:112
	// sendPayment({
	//       receiver: globals.creatorAddress,
	//       closeRemainderTo: globals.creatorAddress,
	//       amount: 0,
	//     })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// examples/auction/auction.algo.ts:113
	// receiver: globals.creatorAddress
	global CreatorAddress
	itxn_field Receiver

	// examples/auction/auction.algo.ts:114
	// closeRemainderTo: globals.creatorAddress
	global CreatorAddress
	itxn_field CloseRemainderTo

	// examples/auction/auction.algo.ts:115
	// amount: 0
	int 0
	itxn_field Amount

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x3987f0c1 // method "optIntoAsset(uint64)void"
	pushbytes 0xc2725922 // method "startAuction(uint64,uint64,axfer)void"
	pushbytes 0xdb7fe843 // method "bid(pay)void"
	pushbytes 0x032f650d // method "claimBids()void"
	pushbytes 0x59b2ab26 // method "claim_asset(uint64)void"
	txna ApplicationArgs 0
	match *abi_route_optIntoAsset *abi_route_startAuction *abi_route_bid *abi_route_claimBids *abi_route_claim_asset

	// this contract does not implement the given ABI method for call NoOp
	err

*call_OptIn:
	pushbytes 0x01a3a3ff // method "optInToApplication()void"
	txna ApplicationArgs 0
	match *abi_route_optInToApplication

	// this contract does not implement the given ABI method for call OptIn
	err

*call_DeleteApplication:
	pushbytes 0x2487c32c // method "deleteApplication()void"
	txna ApplicationArgs 0
	match *abi_route_deleteApplication

	// this contract does not implement the given ABI method for call DeleteApplication
	err", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/examples/big_box/artifacts/BigBox.approval.teal b/examples/big_box/artifacts/BigBox.approval.teal index d94cb668c..6127b4f6b 100644 --- a/examples/big_box/artifacts/BigBox.approval.teal +++ b/examples/big_box/artifacts/BigBox.approval.teal @@ -2,7 +2,7 @@ intcblock 1 bytecblock 0x63757272656e74496e646578 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/examples/big_box/artifacts/BigBox.arc32.json b/examples/big_box/artifacts/BigBox.arc32.json index 4b2a48fcb..b5244150d 100644 --- a/examples/big_box/artifacts/BigBox.arc32.json +++ b/examples/big_box/artifacts/BigBox.arc32.json @@ -54,7 +54,7 @@ } }, "source": { - "approval": "#pragma version 10
intcblock 1
bytecblock 0x63757272656e74496e646578 0x

// This TEAL was generated by TEALScript v0.104.1
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// startUpload(string,uint64,uint64,pay)void
*abi_route_startUpload:
	// mbrPayment: pay
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// argument 0 (mbrPayment) for startUpload must be a pay transaction
	assert

	// endBoxSize: uint64
	txna ApplicationArgs 3
	btoi

	// numBoxes: uint64
	txna ApplicationArgs 2
	btoi

	// dataIdentifier: string
	txna ApplicationArgs 1
	extract 2 0

	// execute startUpload(string,uint64,uint64,pay)void
	callsub startUpload
	int 1
	return

// startUpload(dataIdentifier: string, numBoxes: uint64, endBoxSize: uint64, mbrPayment: PayTxn): void
//
//
// Allocate boxes to begin data upload process
//
// @param dataIdentifier The unique identifier for the data
// @param numBoxes The number of boxes that the data will take up
// @param endBoxSize The size of the last box
// @param mbrPayment Payment from the uploader to cover the box MBR
startUpload:
	proto 4 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 3

	// examples/big_box/big_box.algo.ts:41
	// startBox = this.currentIndex.value
	byte 0x63757272656e74496e646578 // "currentIndex"
	app_global_get
	frame_bury 0 // startBox: uint64

	// examples/big_box/big_box.algo.ts:42
	// endBox = startBox + numBoxes - 1
	frame_dig 0 // startBox: uint64
	frame_dig -2 // numBoxes: uint64
	+
	int 1
	-
	frame_bury 1 // endBox: uint64

	// examples/big_box/big_box.algo.ts:44
	// metadata: Metadata = {
	//       start: startBox,
	//       end: endBox,
	//       status: IN_PROGRESS,
	//       endSize: endBoxSize,
	//     }
	frame_dig 0 // startBox: uint64
	itob
	frame_dig 1 // endBox: uint64
	itob
	concat
	pushbytes 0x00
	concat
	frame_dig -3 // endBoxSize: uint64
	itob
	concat
	frame_bury 2 // metadata: Metadata

	// examples/big_box/big_box.algo.ts:51
	// assert(!this.metadata(dataIdentifier).exists)
	frame_dig -1 // dataIdentifier: string
	box_len
	swap
	pop
	!
	assert

	// examples/big_box/big_box.algo.ts:53
	// this.metadata(dataIdentifier).value = metadata
	frame_dig -1 // dataIdentifier: string
	frame_dig 2 // metadata: Metadata
	box_put

	// examples/big_box/big_box.algo.ts:55
	// this.currentIndex.value = endBox + 1
	byte 0x63757272656e74496e646578 // "currentIndex"
	frame_dig 1 // endBox: uint64
	int 1
	+
	app_global_put

	// examples/big_box/big_box.algo.ts:57
	// totalCost =
	//       numBoxes * COST_PER_BOX + // cost of boxes
	//       (numBoxes - 1) * MAX_BOX_SIZE * COST_PER_BYTE + // cost of data
	//       numBoxes * 64 * COST_PER_BYTE + // cost of keys
	//       endBoxSize * COST_PER_BYTE
	frame_dig -2 // numBoxes: uint64
	pushint 2500
	*
	frame_dig -2 // numBoxes: uint64
	int 1
	-
	pushint 32768
	*
	pushint 400
	*
	+
	frame_dig -2 // numBoxes: uint64
	pushint 64
	*
	pushint 400
	*
	+
	frame_dig -3 // endBoxSize: uint64
	pushint 400
	*
	+
	frame_bury 3 // totalCost: uint64

	// examples/big_box/big_box.algo.ts:63
	// verifyPayTxn(mbrPayment, { receiver: this.app.address, amount: totalCost })
	// verify receiver
	frame_dig -4 // mbrPayment: PayTxn
	gtxns Receiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"mbrPayment","field":"receiver","expected":"this.app.address"}
	assert

	// verify amount
	frame_dig -4 // mbrPayment: PayTxn
	gtxns Amount
	frame_dig 3 // totalCost: uint64
	==

	// transaction verification failed: {"txn":"mbrPayment","field":"amount","expected":"totalCost"}
	assert
	retsub

// upload(string,uint64,uint64,byte[])void
*abi_route_upload:
	// data: byte[]
	txna ApplicationArgs 4
	extract 2 0

	// offset: uint64
	txna ApplicationArgs 3
	btoi

	// boxIndex: uint64
	txna ApplicationArgs 2
	btoi

	// dataIdentifier: string
	txna ApplicationArgs 1
	extract 2 0

	// execute upload(string,uint64,uint64,byte[])void
	callsub upload
	int 1
	return

// upload(dataIdentifier: string, boxIndex: uint64, offset: uint64, data: bytes): void
//
//
// Upload data to a specific offset in a box
//
// @param dataIdentifier The unique identifier for the data
// @param boxIndex The index of the box to upload the given chunk of data to
// @param offset The offset within the box to start writing the data
// @param data The data to write
upload:
	proto 4 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/big_box/big_box.algo.ts:76
	// metadata = this.metadata(dataIdentifier).value
	frame_dig -1 // dataIdentifier: string
	frame_bury 0 // storage key//metadata

	// examples/big_box/big_box.algo.ts:77
	// assert(metadata.status === IN_PROGRESS)
	frame_dig -1 // dataIdentifier: string
	pushint 16 // headOffset
	int 1
	box_extract
	btoi
	pushint 0
	==
	assert

	// examples/big_box/big_box.algo.ts:78
	// assert(metadata.start <= boxIndex && boxIndex <= metadata.end)
	frame_dig -1 // dataIdentifier: string
	pushint 0
	pushint 8
	box_extract
	btoi
	frame_dig -2 // boxIndex: uint64
	<=
	dup
	bz *skip_and0
	frame_dig -2 // boxIndex: uint64
	frame_dig -1 // dataIdentifier: string
	pushint 8 // headOffset
	pushint 8
	box_extract
	btoi
	<=
	&&

*skip_and0:
	assert

	// *if0_condition
	// examples/big_box/big_box.algo.ts:80
	// offset === 0
	frame_dig -3 // offset: uint64
	pushint 0
	==
	bz *if0_end

	// *if0_consequent
	// examples/big_box/big_box.algo.ts:81
	// this.dataBoxes(boxIndex).create(boxIndex === metadata.end ? metadata.endSize : MAX_BOX_SIZE)
	frame_dig -2 // boxIndex: uint64
	itob
	frame_dig -2 // boxIndex: uint64
	frame_dig -1 // dataIdentifier: string
	pushint 8 // headOffset
	pushint 8
	box_extract
	btoi
	==
	bz *ternary0_false
	frame_dig -1 // dataIdentifier: string
	pushint 17 // headOffset
	pushint 8
	box_extract
	btoi
	b *ternary0_end

*ternary0_false:
	pushint 32768

*ternary0_end:
	box_create
	pop

*if0_end:
	// examples/big_box/big_box.algo.ts:84
	// this.dataBoxes(boxIndex).replace(offset, data)
	frame_dig -2 // boxIndex: uint64
	itob
	frame_dig -3 // offset: uint64
	frame_dig -4 // data: bytes
	box_replace
	retsub

// setStatus(string,uint8)void
*abi_route_setStatus:
	// status: uint8
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 0 (status) for setStatus must be a uint8
	assert
	btoi

	// dataIdentifier: string
	txna ApplicationArgs 1
	extract 2 0

	// execute setStatus(string,uint8)void
	callsub setStatus
	int 1
	return

// setStatus(dataIdentifier: string, status: uint<8>): void
//
//
// Set the status of the data
//
// @param dataIdentifier The unique identifier for the data
// @param status The new status for the data
setStatus:
	proto 2 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/big_box/big_box.algo.ts:95
	// currentStatus = this.metadata(dataIdentifier).value.status
	frame_dig -1 // dataIdentifier: string
	pushint 16 // headOffset
	int 1
	box_extract
	btoi
	frame_bury 0 // currentStatus: uint8

	// examples/big_box/big_box.algo.ts:97
	// assert(status === READY || status === IMMUTABLE || status === IN_PROGRESS)
	frame_dig -2 // status: uint<8>
	int 1
	==
	dup
	bnz *skip_or0
	frame_dig -2 // status: uint<8>
	pushint 2
	==
	||

*skip_or0:
	dup
	bnz *skip_or1
	frame_dig -2 // status: uint<8>
	pushint 0
	==
	||

*skip_or1:
	assert

	// examples/big_box/big_box.algo.ts:98
	// assert(currentStatus !== IMMUTABLE)
	frame_dig 0 // currentStatus: uint8
	pushint 2
	!=
	assert

	// examples/big_box/big_box.algo.ts:100
	// this.metadata(dataIdentifier).value.status = status
	pushint 16 // headOffset
	frame_dig -2 // status: uint<8>
	itob
	extract 7 1
	frame_dig -1 // dataIdentifier: string
	cover 2
	box_replace
	retsub

*abi_route_createApplication:
	int 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0xa05b5669 // method "startUpload(string,uint64,uint64,pay)void"
	pushbytes 0x1b7dfa35 // method "upload(string,uint64,uint64,byte[])void"
	pushbytes 0xbf3856f8 // method "setStatus(string,uint8)void"
	txna ApplicationArgs 0
	match *abi_route_startUpload *abi_route_upload *abi_route_setStatus

	// this contract does not implement the given ABI method for call NoOp
	err", + "approval": "#pragma version 10
intcblock 1
bytecblock 0x63757272656e74496e646578 0x

// This TEAL was generated by TEALScript v0.105.0
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// startUpload(string,uint64,uint64,pay)void
*abi_route_startUpload:
	// mbrPayment: pay
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// argument 0 (mbrPayment) for startUpload must be a pay transaction
	assert

	// endBoxSize: uint64
	txna ApplicationArgs 3
	btoi

	// numBoxes: uint64
	txna ApplicationArgs 2
	btoi

	// dataIdentifier: string
	txna ApplicationArgs 1
	extract 2 0

	// execute startUpload(string,uint64,uint64,pay)void
	callsub startUpload
	int 1
	return

// startUpload(dataIdentifier: string, numBoxes: uint64, endBoxSize: uint64, mbrPayment: PayTxn): void
//
//
// Allocate boxes to begin data upload process
//
// @param dataIdentifier The unique identifier for the data
// @param numBoxes The number of boxes that the data will take up
// @param endBoxSize The size of the last box
// @param mbrPayment Payment from the uploader to cover the box MBR
startUpload:
	proto 4 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 3

	// examples/big_box/big_box.algo.ts:41
	// startBox = this.currentIndex.value
	byte 0x63757272656e74496e646578 // "currentIndex"
	app_global_get
	frame_bury 0 // startBox: uint64

	// examples/big_box/big_box.algo.ts:42
	// endBox = startBox + numBoxes - 1
	frame_dig 0 // startBox: uint64
	frame_dig -2 // numBoxes: uint64
	+
	int 1
	-
	frame_bury 1 // endBox: uint64

	// examples/big_box/big_box.algo.ts:44
	// metadata: Metadata = {
	//       start: startBox,
	//       end: endBox,
	//       status: IN_PROGRESS,
	//       endSize: endBoxSize,
	//     }
	frame_dig 0 // startBox: uint64
	itob
	frame_dig 1 // endBox: uint64
	itob
	concat
	pushbytes 0x00
	concat
	frame_dig -3 // endBoxSize: uint64
	itob
	concat
	frame_bury 2 // metadata: Metadata

	// examples/big_box/big_box.algo.ts:51
	// assert(!this.metadata(dataIdentifier).exists)
	frame_dig -1 // dataIdentifier: string
	box_len
	swap
	pop
	!
	assert

	// examples/big_box/big_box.algo.ts:53
	// this.metadata(dataIdentifier).value = metadata
	frame_dig -1 // dataIdentifier: string
	frame_dig 2 // metadata: Metadata
	box_put

	// examples/big_box/big_box.algo.ts:55
	// this.currentIndex.value = endBox + 1
	byte 0x63757272656e74496e646578 // "currentIndex"
	frame_dig 1 // endBox: uint64
	int 1
	+
	app_global_put

	// examples/big_box/big_box.algo.ts:57
	// totalCost =
	//       numBoxes * COST_PER_BOX + // cost of boxes
	//       (numBoxes - 1) * MAX_BOX_SIZE * COST_PER_BYTE + // cost of data
	//       numBoxes * 64 * COST_PER_BYTE + // cost of keys
	//       endBoxSize * COST_PER_BYTE
	frame_dig -2 // numBoxes: uint64
	pushint 2500
	*
	frame_dig -2 // numBoxes: uint64
	int 1
	-
	pushint 32768
	*
	pushint 400
	*
	+
	frame_dig -2 // numBoxes: uint64
	pushint 64
	*
	pushint 400
	*
	+
	frame_dig -3 // endBoxSize: uint64
	pushint 400
	*
	+
	frame_bury 3 // totalCost: uint64

	// examples/big_box/big_box.algo.ts:63
	// verifyPayTxn(mbrPayment, { receiver: this.app.address, amount: totalCost })
	// verify receiver
	frame_dig -4 // mbrPayment: PayTxn
	gtxns Receiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"mbrPayment","field":"receiver","expected":"this.app.address"}
	assert

	// verify amount
	frame_dig -4 // mbrPayment: PayTxn
	gtxns Amount
	frame_dig 3 // totalCost: uint64
	==

	// transaction verification failed: {"txn":"mbrPayment","field":"amount","expected":"totalCost"}
	assert
	retsub

// upload(string,uint64,uint64,byte[])void
*abi_route_upload:
	// data: byte[]
	txna ApplicationArgs 4
	extract 2 0

	// offset: uint64
	txna ApplicationArgs 3
	btoi

	// boxIndex: uint64
	txna ApplicationArgs 2
	btoi

	// dataIdentifier: string
	txna ApplicationArgs 1
	extract 2 0

	// execute upload(string,uint64,uint64,byte[])void
	callsub upload
	int 1
	return

// upload(dataIdentifier: string, boxIndex: uint64, offset: uint64, data: bytes): void
//
//
// Upload data to a specific offset in a box
//
// @param dataIdentifier The unique identifier for the data
// @param boxIndex The index of the box to upload the given chunk of data to
// @param offset The offset within the box to start writing the data
// @param data The data to write
upload:
	proto 4 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/big_box/big_box.algo.ts:76
	// metadata = this.metadata(dataIdentifier).value
	frame_dig -1 // dataIdentifier: string
	frame_bury 0 // storage key//metadata

	// examples/big_box/big_box.algo.ts:77
	// assert(metadata.status === IN_PROGRESS)
	frame_dig -1 // dataIdentifier: string
	pushint 16 // headOffset
	int 1
	box_extract
	btoi
	pushint 0
	==
	assert

	// examples/big_box/big_box.algo.ts:78
	// assert(metadata.start <= boxIndex && boxIndex <= metadata.end)
	frame_dig -1 // dataIdentifier: string
	pushint 0
	pushint 8
	box_extract
	btoi
	frame_dig -2 // boxIndex: uint64
	<=
	dup
	bz *skip_and0
	frame_dig -2 // boxIndex: uint64
	frame_dig -1 // dataIdentifier: string
	pushint 8 // headOffset
	pushint 8
	box_extract
	btoi
	<=
	&&

*skip_and0:
	assert

	// *if0_condition
	// examples/big_box/big_box.algo.ts:80
	// offset === 0
	frame_dig -3 // offset: uint64
	pushint 0
	==
	bz *if0_end

	// *if0_consequent
	// examples/big_box/big_box.algo.ts:81
	// this.dataBoxes(boxIndex).create(boxIndex === metadata.end ? metadata.endSize : MAX_BOX_SIZE)
	frame_dig -2 // boxIndex: uint64
	itob
	frame_dig -2 // boxIndex: uint64
	frame_dig -1 // dataIdentifier: string
	pushint 8 // headOffset
	pushint 8
	box_extract
	btoi
	==
	bz *ternary0_false
	frame_dig -1 // dataIdentifier: string
	pushint 17 // headOffset
	pushint 8
	box_extract
	btoi
	b *ternary0_end

*ternary0_false:
	pushint 32768

*ternary0_end:
	box_create
	pop

*if0_end:
	// examples/big_box/big_box.algo.ts:84
	// this.dataBoxes(boxIndex).replace(offset, data)
	frame_dig -2 // boxIndex: uint64
	itob
	frame_dig -3 // offset: uint64
	frame_dig -4 // data: bytes
	box_replace
	retsub

// setStatus(string,uint8)void
*abi_route_setStatus:
	// status: uint8
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 0 (status) for setStatus must be a uint8
	assert
	btoi

	// dataIdentifier: string
	txna ApplicationArgs 1
	extract 2 0

	// execute setStatus(string,uint8)void
	callsub setStatus
	int 1
	return

// setStatus(dataIdentifier: string, status: uint<8>): void
//
//
// Set the status of the data
//
// @param dataIdentifier The unique identifier for the data
// @param status The new status for the data
setStatus:
	proto 2 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/big_box/big_box.algo.ts:95
	// currentStatus = this.metadata(dataIdentifier).value.status
	frame_dig -1 // dataIdentifier: string
	pushint 16 // headOffset
	int 1
	box_extract
	btoi
	frame_bury 0 // currentStatus: uint8

	// examples/big_box/big_box.algo.ts:97
	// assert(status === READY || status === IMMUTABLE || status === IN_PROGRESS)
	frame_dig -2 // status: uint<8>
	int 1
	==
	dup
	bnz *skip_or0
	frame_dig -2 // status: uint<8>
	pushint 2
	==
	||

*skip_or0:
	dup
	bnz *skip_or1
	frame_dig -2 // status: uint<8>
	pushint 0
	==
	||

*skip_or1:
	assert

	// examples/big_box/big_box.algo.ts:98
	// assert(currentStatus !== IMMUTABLE)
	frame_dig 0 // currentStatus: uint8
	pushint 2
	!=
	assert

	// examples/big_box/big_box.algo.ts:100
	// this.metadata(dataIdentifier).value.status = status
	pushint 16 // headOffset
	frame_dig -2 // status: uint<8>
	itob
	extract 7 1
	frame_dig -1 // dataIdentifier: string
	cover 2
	box_replace
	retsub

*abi_route_createApplication:
	int 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0xa05b5669 // method "startUpload(string,uint64,uint64,pay)void"
	pushbytes 0x1b7dfa35 // method "upload(string,uint64,uint64,byte[])void"
	pushbytes 0xbf3856f8 // method "setStatus(string,uint8)void"
	txna ApplicationArgs 0
	match *abi_route_startUpload *abi_route_upload *abi_route_setStatus

	// this contract does not implement the given ABI method for call NoOp
	err", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/examples/big_box/artifacts/BigBox.arc56_draft.json b/examples/big_box/artifacts/BigBox.arc56_draft.json index 8cff8b7de..9fc3f4e21 100644 --- a/examples/big_box/artifacts/BigBox.arc56_draft.json +++ b/examples/big_box/artifacts/BigBox.arc56_draft.json @@ -2047,7 +2047,7 @@ } }, "source": { - "approval": "#pragma version 10
intcblock 1
bytecblock 0x63757272656e74496e646578 0x

// This TEAL was generated by TEALScript v0.104.1
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// startUpload(string,uint64,uint64,pay)void
*abi_route_startUpload:
	// mbrPayment: pay
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// argument 0 (mbrPayment) for startUpload must be a pay transaction
	assert

	// endBoxSize: uint64
	txna ApplicationArgs 3
	btoi

	// numBoxes: uint64
	txna ApplicationArgs 2
	btoi

	// dataIdentifier: string
	txna ApplicationArgs 1
	extract 2 0

	// execute startUpload(string,uint64,uint64,pay)void
	callsub startUpload
	int 1
	return

// startUpload(dataIdentifier: string, numBoxes: uint64, endBoxSize: uint64, mbrPayment: PayTxn): void
//
//
// Allocate boxes to begin data upload process
//
// @param dataIdentifier The unique identifier for the data
// @param numBoxes The number of boxes that the data will take up
// @param endBoxSize The size of the last box
// @param mbrPayment Payment from the uploader to cover the box MBR
startUpload:
	proto 4 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 3

	// examples/big_box/big_box.algo.ts:41
	// startBox = this.currentIndex.value
	byte 0x63757272656e74496e646578 // "currentIndex"
	app_global_get
	frame_bury 0 // startBox: uint64

	// examples/big_box/big_box.algo.ts:42
	// endBox = startBox + numBoxes - 1
	frame_dig 0 // startBox: uint64
	frame_dig -2 // numBoxes: uint64
	+
	int 1
	-
	frame_bury 1 // endBox: uint64

	// examples/big_box/big_box.algo.ts:44
	// metadata: Metadata = {
	//       start: startBox,
	//       end: endBox,
	//       status: IN_PROGRESS,
	//       endSize: endBoxSize,
	//     }
	frame_dig 0 // startBox: uint64
	itob
	frame_dig 1 // endBox: uint64
	itob
	concat
	pushbytes 0x00
	concat
	frame_dig -3 // endBoxSize: uint64
	itob
	concat
	frame_bury 2 // metadata: Metadata

	// examples/big_box/big_box.algo.ts:51
	// assert(!this.metadata(dataIdentifier).exists)
	frame_dig -1 // dataIdentifier: string
	box_len
	swap
	pop
	!
	assert

	// examples/big_box/big_box.algo.ts:53
	// this.metadata(dataIdentifier).value = metadata
	frame_dig -1 // dataIdentifier: string
	frame_dig 2 // metadata: Metadata
	box_put

	// examples/big_box/big_box.algo.ts:55
	// this.currentIndex.value = endBox + 1
	byte 0x63757272656e74496e646578 // "currentIndex"
	frame_dig 1 // endBox: uint64
	int 1
	+
	app_global_put

	// examples/big_box/big_box.algo.ts:57
	// totalCost =
	//       numBoxes * COST_PER_BOX + // cost of boxes
	//       (numBoxes - 1) * MAX_BOX_SIZE * COST_PER_BYTE + // cost of data
	//       numBoxes * 64 * COST_PER_BYTE + // cost of keys
	//       endBoxSize * COST_PER_BYTE
	frame_dig -2 // numBoxes: uint64
	pushint 2500
	*
	frame_dig -2 // numBoxes: uint64
	int 1
	-
	pushint 32768
	*
	pushint 400
	*
	+
	frame_dig -2 // numBoxes: uint64
	pushint 64
	*
	pushint 400
	*
	+
	frame_dig -3 // endBoxSize: uint64
	pushint 400
	*
	+
	frame_bury 3 // totalCost: uint64

	// examples/big_box/big_box.algo.ts:63
	// verifyPayTxn(mbrPayment, { receiver: this.app.address, amount: totalCost })
	// verify receiver
	frame_dig -4 // mbrPayment: PayTxn
	gtxns Receiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"mbrPayment","field":"receiver","expected":"this.app.address"}
	assert

	// verify amount
	frame_dig -4 // mbrPayment: PayTxn
	gtxns Amount
	frame_dig 3 // totalCost: uint64
	==

	// transaction verification failed: {"txn":"mbrPayment","field":"amount","expected":"totalCost"}
	assert
	retsub

// upload(string,uint64,uint64,byte[])void
*abi_route_upload:
	// data: byte[]
	txna ApplicationArgs 4
	extract 2 0

	// offset: uint64
	txna ApplicationArgs 3
	btoi

	// boxIndex: uint64
	txna ApplicationArgs 2
	btoi

	// dataIdentifier: string
	txna ApplicationArgs 1
	extract 2 0

	// execute upload(string,uint64,uint64,byte[])void
	callsub upload
	int 1
	return

// upload(dataIdentifier: string, boxIndex: uint64, offset: uint64, data: bytes): void
//
//
// Upload data to a specific offset in a box
//
// @param dataIdentifier The unique identifier for the data
// @param boxIndex The index of the box to upload the given chunk of data to
// @param offset The offset within the box to start writing the data
// @param data The data to write
upload:
	proto 4 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/big_box/big_box.algo.ts:76
	// metadata = this.metadata(dataIdentifier).value
	frame_dig -1 // dataIdentifier: string
	frame_bury 0 // storage key//metadata

	// examples/big_box/big_box.algo.ts:77
	// assert(metadata.status === IN_PROGRESS)
	frame_dig -1 // dataIdentifier: string
	pushint 16 // headOffset
	int 1
	box_extract
	btoi
	pushint 0
	==
	assert

	// examples/big_box/big_box.algo.ts:78
	// assert(metadata.start <= boxIndex && boxIndex <= metadata.end)
	frame_dig -1 // dataIdentifier: string
	pushint 0
	pushint 8
	box_extract
	btoi
	frame_dig -2 // boxIndex: uint64
	<=
	dup
	bz *skip_and0
	frame_dig -2 // boxIndex: uint64
	frame_dig -1 // dataIdentifier: string
	pushint 8 // headOffset
	pushint 8
	box_extract
	btoi
	<=
	&&

*skip_and0:
	assert

	// *if0_condition
	// examples/big_box/big_box.algo.ts:80
	// offset === 0
	frame_dig -3 // offset: uint64
	pushint 0
	==
	bz *if0_end

	// *if0_consequent
	// examples/big_box/big_box.algo.ts:81
	// this.dataBoxes(boxIndex).create(boxIndex === metadata.end ? metadata.endSize : MAX_BOX_SIZE)
	frame_dig -2 // boxIndex: uint64
	itob
	frame_dig -2 // boxIndex: uint64
	frame_dig -1 // dataIdentifier: string
	pushint 8 // headOffset
	pushint 8
	box_extract
	btoi
	==
	bz *ternary0_false
	frame_dig -1 // dataIdentifier: string
	pushint 17 // headOffset
	pushint 8
	box_extract
	btoi
	b *ternary0_end

*ternary0_false:
	pushint 32768

*ternary0_end:
	box_create
	pop

*if0_end:
	// examples/big_box/big_box.algo.ts:84
	// this.dataBoxes(boxIndex).replace(offset, data)
	frame_dig -2 // boxIndex: uint64
	itob
	frame_dig -3 // offset: uint64
	frame_dig -4 // data: bytes
	box_replace
	retsub

// setStatus(string,uint8)void
*abi_route_setStatus:
	// status: uint8
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 0 (status) for setStatus must be a uint8
	assert
	btoi

	// dataIdentifier: string
	txna ApplicationArgs 1
	extract 2 0

	// execute setStatus(string,uint8)void
	callsub setStatus
	int 1
	return

// setStatus(dataIdentifier: string, status: uint<8>): void
//
//
// Set the status of the data
//
// @param dataIdentifier The unique identifier for the data
// @param status The new status for the data
setStatus:
	proto 2 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/big_box/big_box.algo.ts:95
	// currentStatus = this.metadata(dataIdentifier).value.status
	frame_dig -1 // dataIdentifier: string
	pushint 16 // headOffset
	int 1
	box_extract
	btoi
	frame_bury 0 // currentStatus: uint8

	// examples/big_box/big_box.algo.ts:97
	// assert(status === READY || status === IMMUTABLE || status === IN_PROGRESS)
	frame_dig -2 // status: uint<8>
	int 1
	==
	dup
	bnz *skip_or0
	frame_dig -2 // status: uint<8>
	pushint 2
	==
	||

*skip_or0:
	dup
	bnz *skip_or1
	frame_dig -2 // status: uint<8>
	pushint 0
	==
	||

*skip_or1:
	assert

	// examples/big_box/big_box.algo.ts:98
	// assert(currentStatus !== IMMUTABLE)
	frame_dig 0 // currentStatus: uint8
	pushint 2
	!=
	assert

	// examples/big_box/big_box.algo.ts:100
	// this.metadata(dataIdentifier).value.status = status
	pushint 16 // headOffset
	frame_dig -2 // status: uint<8>
	itob
	extract 7 1
	frame_dig -1 // dataIdentifier: string
	cover 2
	box_replace
	retsub

*abi_route_createApplication:
	int 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0xa05b5669 // method "startUpload(string,uint64,uint64,pay)void"
	pushbytes 0x1b7dfa35 // method "upload(string,uint64,uint64,byte[])void"
	pushbytes 0xbf3856f8 // method "setStatus(string,uint8)void"
	txna ApplicationArgs 0
	match *abi_route_startUpload *abi_route_upload *abi_route_setStatus

	// this contract does not implement the given ABI method for call NoOp
	err", + "approval": "#pragma version 10
intcblock 1
bytecblock 0x63757272656e74496e646578 0x

// This TEAL was generated by TEALScript v0.105.0
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// startUpload(string,uint64,uint64,pay)void
*abi_route_startUpload:
	// mbrPayment: pay
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// argument 0 (mbrPayment) for startUpload must be a pay transaction
	assert

	// endBoxSize: uint64
	txna ApplicationArgs 3
	btoi

	// numBoxes: uint64
	txna ApplicationArgs 2
	btoi

	// dataIdentifier: string
	txna ApplicationArgs 1
	extract 2 0

	// execute startUpload(string,uint64,uint64,pay)void
	callsub startUpload
	int 1
	return

// startUpload(dataIdentifier: string, numBoxes: uint64, endBoxSize: uint64, mbrPayment: PayTxn): void
//
//
// Allocate boxes to begin data upload process
//
// @param dataIdentifier The unique identifier for the data
// @param numBoxes The number of boxes that the data will take up
// @param endBoxSize The size of the last box
// @param mbrPayment Payment from the uploader to cover the box MBR
startUpload:
	proto 4 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 3

	// examples/big_box/big_box.algo.ts:41
	// startBox = this.currentIndex.value
	byte 0x63757272656e74496e646578 // "currentIndex"
	app_global_get
	frame_bury 0 // startBox: uint64

	// examples/big_box/big_box.algo.ts:42
	// endBox = startBox + numBoxes - 1
	frame_dig 0 // startBox: uint64
	frame_dig -2 // numBoxes: uint64
	+
	int 1
	-
	frame_bury 1 // endBox: uint64

	// examples/big_box/big_box.algo.ts:44
	// metadata: Metadata = {
	//       start: startBox,
	//       end: endBox,
	//       status: IN_PROGRESS,
	//       endSize: endBoxSize,
	//     }
	frame_dig 0 // startBox: uint64
	itob
	frame_dig 1 // endBox: uint64
	itob
	concat
	pushbytes 0x00
	concat
	frame_dig -3 // endBoxSize: uint64
	itob
	concat
	frame_bury 2 // metadata: Metadata

	// examples/big_box/big_box.algo.ts:51
	// assert(!this.metadata(dataIdentifier).exists)
	frame_dig -1 // dataIdentifier: string
	box_len
	swap
	pop
	!
	assert

	// examples/big_box/big_box.algo.ts:53
	// this.metadata(dataIdentifier).value = metadata
	frame_dig -1 // dataIdentifier: string
	frame_dig 2 // metadata: Metadata
	box_put

	// examples/big_box/big_box.algo.ts:55
	// this.currentIndex.value = endBox + 1
	byte 0x63757272656e74496e646578 // "currentIndex"
	frame_dig 1 // endBox: uint64
	int 1
	+
	app_global_put

	// examples/big_box/big_box.algo.ts:57
	// totalCost =
	//       numBoxes * COST_PER_BOX + // cost of boxes
	//       (numBoxes - 1) * MAX_BOX_SIZE * COST_PER_BYTE + // cost of data
	//       numBoxes * 64 * COST_PER_BYTE + // cost of keys
	//       endBoxSize * COST_PER_BYTE
	frame_dig -2 // numBoxes: uint64
	pushint 2500
	*
	frame_dig -2 // numBoxes: uint64
	int 1
	-
	pushint 32768
	*
	pushint 400
	*
	+
	frame_dig -2 // numBoxes: uint64
	pushint 64
	*
	pushint 400
	*
	+
	frame_dig -3 // endBoxSize: uint64
	pushint 400
	*
	+
	frame_bury 3 // totalCost: uint64

	// examples/big_box/big_box.algo.ts:63
	// verifyPayTxn(mbrPayment, { receiver: this.app.address, amount: totalCost })
	// verify receiver
	frame_dig -4 // mbrPayment: PayTxn
	gtxns Receiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"mbrPayment","field":"receiver","expected":"this.app.address"}
	assert

	// verify amount
	frame_dig -4 // mbrPayment: PayTxn
	gtxns Amount
	frame_dig 3 // totalCost: uint64
	==

	// transaction verification failed: {"txn":"mbrPayment","field":"amount","expected":"totalCost"}
	assert
	retsub

// upload(string,uint64,uint64,byte[])void
*abi_route_upload:
	// data: byte[]
	txna ApplicationArgs 4
	extract 2 0

	// offset: uint64
	txna ApplicationArgs 3
	btoi

	// boxIndex: uint64
	txna ApplicationArgs 2
	btoi

	// dataIdentifier: string
	txna ApplicationArgs 1
	extract 2 0

	// execute upload(string,uint64,uint64,byte[])void
	callsub upload
	int 1
	return

// upload(dataIdentifier: string, boxIndex: uint64, offset: uint64, data: bytes): void
//
//
// Upload data to a specific offset in a box
//
// @param dataIdentifier The unique identifier for the data
// @param boxIndex The index of the box to upload the given chunk of data to
// @param offset The offset within the box to start writing the data
// @param data The data to write
upload:
	proto 4 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/big_box/big_box.algo.ts:76
	// metadata = this.metadata(dataIdentifier).value
	frame_dig -1 // dataIdentifier: string
	frame_bury 0 // storage key//metadata

	// examples/big_box/big_box.algo.ts:77
	// assert(metadata.status === IN_PROGRESS)
	frame_dig -1 // dataIdentifier: string
	pushint 16 // headOffset
	int 1
	box_extract
	btoi
	pushint 0
	==
	assert

	// examples/big_box/big_box.algo.ts:78
	// assert(metadata.start <= boxIndex && boxIndex <= metadata.end)
	frame_dig -1 // dataIdentifier: string
	pushint 0
	pushint 8
	box_extract
	btoi
	frame_dig -2 // boxIndex: uint64
	<=
	dup
	bz *skip_and0
	frame_dig -2 // boxIndex: uint64
	frame_dig -1 // dataIdentifier: string
	pushint 8 // headOffset
	pushint 8
	box_extract
	btoi
	<=
	&&

*skip_and0:
	assert

	// *if0_condition
	// examples/big_box/big_box.algo.ts:80
	// offset === 0
	frame_dig -3 // offset: uint64
	pushint 0
	==
	bz *if0_end

	// *if0_consequent
	// examples/big_box/big_box.algo.ts:81
	// this.dataBoxes(boxIndex).create(boxIndex === metadata.end ? metadata.endSize : MAX_BOX_SIZE)
	frame_dig -2 // boxIndex: uint64
	itob
	frame_dig -2 // boxIndex: uint64
	frame_dig -1 // dataIdentifier: string
	pushint 8 // headOffset
	pushint 8
	box_extract
	btoi
	==
	bz *ternary0_false
	frame_dig -1 // dataIdentifier: string
	pushint 17 // headOffset
	pushint 8
	box_extract
	btoi
	b *ternary0_end

*ternary0_false:
	pushint 32768

*ternary0_end:
	box_create
	pop

*if0_end:
	// examples/big_box/big_box.algo.ts:84
	// this.dataBoxes(boxIndex).replace(offset, data)
	frame_dig -2 // boxIndex: uint64
	itob
	frame_dig -3 // offset: uint64
	frame_dig -4 // data: bytes
	box_replace
	retsub

// setStatus(string,uint8)void
*abi_route_setStatus:
	// status: uint8
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 0 (status) for setStatus must be a uint8
	assert
	btoi

	// dataIdentifier: string
	txna ApplicationArgs 1
	extract 2 0

	// execute setStatus(string,uint8)void
	callsub setStatus
	int 1
	return

// setStatus(dataIdentifier: string, status: uint<8>): void
//
//
// Set the status of the data
//
// @param dataIdentifier The unique identifier for the data
// @param status The new status for the data
setStatus:
	proto 2 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/big_box/big_box.algo.ts:95
	// currentStatus = this.metadata(dataIdentifier).value.status
	frame_dig -1 // dataIdentifier: string
	pushint 16 // headOffset
	int 1
	box_extract
	btoi
	frame_bury 0 // currentStatus: uint8

	// examples/big_box/big_box.algo.ts:97
	// assert(status === READY || status === IMMUTABLE || status === IN_PROGRESS)
	frame_dig -2 // status: uint<8>
	int 1
	==
	dup
	bnz *skip_or0
	frame_dig -2 // status: uint<8>
	pushint 2
	==
	||

*skip_or0:
	dup
	bnz *skip_or1
	frame_dig -2 // status: uint<8>
	pushint 0
	==
	||

*skip_or1:
	assert

	// examples/big_box/big_box.algo.ts:98
	// assert(currentStatus !== IMMUTABLE)
	frame_dig 0 // currentStatus: uint8
	pushint 2
	!=
	assert

	// examples/big_box/big_box.algo.ts:100
	// this.metadata(dataIdentifier).value.status = status
	pushint 16 // headOffset
	frame_dig -2 // status: uint<8>
	itob
	extract 7 1
	frame_dig -1 // dataIdentifier: string
	cover 2
	box_replace
	retsub

*abi_route_createApplication:
	int 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0xa05b5669 // method "startUpload(string,uint64,uint64,pay)void"
	pushbytes 0x1b7dfa35 // method "upload(string,uint64,uint64,byte[])void"
	pushbytes 0xbf3856f8 // method "setStatus(string,uint8)void"
	txna ApplicationArgs 0
	match *abi_route_startUpload *abi_route_upload *abi_route_setStatus

	// this contract does not implement the given ABI method for call NoOp
	err", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/examples/calculator/artifacts/Calculator.approval.teal b/examples/calculator/artifacts/Calculator.approval.teal index 3e3ae233e..16ef192b0 100644 --- a/examples/calculator/artifacts/Calculator.approval.teal +++ b/examples/calculator/artifacts/Calculator.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/examples/calculator/artifacts/Calculator.arc32.json b/examples/calculator/artifacts/Calculator.arc32.json index 790665468..8eade5af5 100644 --- a/examples/calculator/artifacts/Calculator.arc32.json +++ b/examples/calculator/artifacts/Calculator.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZ2V0U3VtKGE6IHVpbnQ2NCwgYjogdWludDY0KTogdWludDY0Ci8vCi8vIENhbGN1bGF0ZXMgdGhlIHN1bSBvZiB0d28gbnVtYmVycwovLwovLyBAcGFyYW0gYQovLyBAcGFyYW0gYgovLyBAcmV0dXJucyBUaGUgc3VtIG9mIGEgYW5kIGIKZ2V0U3VtOgoJcHJvdG8gMiAxCgoJLy8gZXhhbXBsZXMvY2FsY3VsYXRvci9jYWxjdWxhdG9yLmFsZ28udHM6MTMKCS8vIHJldHVybiBhICsgYjsKCWZyYW1lX2RpZyAtMSAvLyBhOiB1aW50NjQKCWZyYW1lX2RpZyAtMiAvLyBiOiB1aW50NjQKCSsKCXJldHN1YgoKLy8gZ2V0RGlmZmVyZW5jZShhOiB1aW50NjQsIGI6IHVpbnQ2NCk6IHVpbnQ2NAovLwovLyBDYWxjdWxhdGVzIHRoZSBkaWZmZXJlbmNlIGJldHdlZW4gdHdvIG51bWJlcnMKLy8KLy8gQHBhcmFtIGEKLy8gQHBhcmFtIGIKLy8gQHJldHVybnMgVGhlIGRpZmZlcmVuY2UgYmV0d2VlbiBhIGFuZCBiLgpnZXREaWZmZXJlbmNlOgoJcHJvdG8gMiAxCgoJLy8gZXhhbXBsZXMvY2FsY3VsYXRvci9jYWxjdWxhdG9yLmFsZ28udHM6MjQKCS8vIHJldHVybiBhID49IGIgPyBhIC0gYiA6IGIgLSBhOwoJZnJhbWVfZGlnIC0xIC8vIGE6IHVpbnQ2NAoJZnJhbWVfZGlnIC0yIC8vIGI6IHVpbnQ2NAoJPj0KCWJ6ICp0ZXJuYXJ5MF9mYWxzZQoJZnJhbWVfZGlnIC0xIC8vIGE6IHVpbnQ2NAoJZnJhbWVfZGlnIC0yIC8vIGI6IHVpbnQ2NAoJLQoJYiAqdGVybmFyeTBfZW5kCgoqdGVybmFyeTBfZmFsc2U6CglmcmFtZV9kaWcgLTIgLy8gYjogdWludDY0CglmcmFtZV9kaWcgLTEgLy8gYTogdWludDY0CgktCgoqdGVybmFyeTBfZW5kOgoJcmV0c3ViCgovLyBkb01hdGgodWludDY0LHVpbnQ2NCxzdHJpbmcpdWludDY0CiphYmlfcm91dGVfZG9NYXRoOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIG9wZXJhdGlvbjogc3RyaW5nCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAzCglleHRyYWN0IDIgMAoKCS8vIGI6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMgoJYnRvaQoKCS8vIGE6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJYnRvaQoKCS8vIGV4ZWN1dGUgZG9NYXRoKHVpbnQ2NCx1aW50NjQsc3RyaW5nKXVpbnQ2NAoJY2FsbHN1YiBkb01hdGgKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gZG9NYXRoKGE6IHVpbnQ2NCwgYjogdWludDY0LCBvcGVyYXRpb246IHN0cmluZyk6IHVpbnQ2NAovLwovLyBBIG1ldGhvZCB0aGF0IHRha2VzIHR3byBudW1iZXJzIGFuZCBkb2VzIGVpdGhlciBhZGRpdGlvbiBvciBzdWJ0cmFjdGlvbgovLwovLyBAcGFyYW0gYSBUaGUgZmlyc3QgbnVtYmVyCi8vIEBwYXJhbSBiIFRoZSBzZWNvbmQgbnVtYmVyCi8vIEBwYXJhbSBvcGVyYXRpb24gVGhlIG9wZXJhdGlvbiB0byBwZXJmb3JtLiBDYW4gYmUgZWl0aGVyICdzdW0nIG9yICdkaWZmZXJlbmNlJwovLwovLyBAcmV0dXJucyBUaGUgcmVzdWx0IG9mIHRoZSBvcGVyYXRpb24KZG9NYXRoOgoJcHJvdG8gMyAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vICppZjBfY29uZGl0aW9uCgkvLyBleGFtcGxlcy9jYWxjdWxhdG9yL2NhbGN1bGF0b3IuYWxnby50czozOQoJLy8gb3BlcmF0aW9uID09PSAnc3VtJwoJZnJhbWVfZGlnIC0zIC8vIG9wZXJhdGlvbjogc3RyaW5nCglwdXNoYnl0ZXMgMHg3Mzc1NmQgLy8gInN1bSIKCT09CglieiAqaWYwX2Vsc2VpZjFfY29uZGl0aW9uCgoJLy8gKmlmMF9jb25zZXF1ZW50CgkvLyBleGFtcGxlcy9jYWxjdWxhdG9yL2NhbGN1bGF0b3IuYWxnby50czo0MAoJLy8gcmVzdWx0ID0gdGhpcy5nZXRTdW0oYSwgYikKCWZyYW1lX2RpZyAtMiAvLyBiOiB1aW50NjQKCWZyYW1lX2RpZyAtMSAvLyBhOiB1aW50NjQKCWNhbGxzdWIgZ2V0U3VtCglmcmFtZV9idXJ5IDAgLy8gcmVzdWx0OiB1aW50NjQKCWIgKmlmMF9lbmQKCippZjBfZWxzZWlmMV9jb25kaXRpb246CgkvLyBleGFtcGxlcy9jYWxjdWxhdG9yL2NhbGN1bGF0b3IuYWxnby50czo0MQoJLy8gb3BlcmF0aW9uID09PSAnZGlmZmVyZW5jZScKCWZyYW1lX2RpZyAtMyAvLyBvcGVyYXRpb246IHN0cmluZwoJcHVzaGJ5dGVzIDB4NjQ2OTY2NjY2NTcyNjU2ZTYzNjUgLy8gImRpZmZlcmVuY2UiCgk9PQoJYnogKmlmMF9lbHNlCgoJLy8gKmlmMF9lbHNlaWYxX2NvbnNlcXVlbnQKCS8vIGV4YW1wbGVzL2NhbGN1bGF0b3IvY2FsY3VsYXRvci5hbGdvLnRzOjQyCgkvLyByZXN1bHQgPSB0aGlzLmdldERpZmZlcmVuY2UoYSwgYikKCWZyYW1lX2RpZyAtMiAvLyBiOiB1aW50NjQKCWZyYW1lX2RpZyAtMSAvLyBhOiB1aW50NjQKCWNhbGxzdWIgZ2V0RGlmZmVyZW5jZQoJZnJhbWVfYnVyeSAwIC8vIHJlc3VsdDogdWludDY0CgliICppZjBfZW5kCgoqaWYwX2Vsc2U6CgkvLyBJbnZhbGlkIG9wZXJhdGlvbgoJZXJyCgoqaWYwX2VuZDoKCS8vIGV4YW1wbGVzL2NhbGN1bGF0b3IvY2FsY3VsYXRvci5hbGdvLnRzOjQ1CgkvLyByZXR1cm4gcmVzdWx0OwoJZnJhbWVfZGlnIDAgLy8gcmVzdWx0OiB1aW50NjQKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4NzZhN2VmMzMgLy8gbWV0aG9kICJkb01hdGgodWludDY0LHVpbnQ2NCxzdHJpbmcpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9kb01hdGgKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZ2V0U3VtKGE6IHVpbnQ2NCwgYjogdWludDY0KTogdWludDY0Ci8vCi8vIENhbGN1bGF0ZXMgdGhlIHN1bSBvZiB0d28gbnVtYmVycwovLwovLyBAcGFyYW0gYQovLyBAcGFyYW0gYgovLyBAcmV0dXJucyBUaGUgc3VtIG9mIGEgYW5kIGIKZ2V0U3VtOgoJcHJvdG8gMiAxCgoJLy8gZXhhbXBsZXMvY2FsY3VsYXRvci9jYWxjdWxhdG9yLmFsZ28udHM6MTMKCS8vIHJldHVybiBhICsgYjsKCWZyYW1lX2RpZyAtMSAvLyBhOiB1aW50NjQKCWZyYW1lX2RpZyAtMiAvLyBiOiB1aW50NjQKCSsKCXJldHN1YgoKLy8gZ2V0RGlmZmVyZW5jZShhOiB1aW50NjQsIGI6IHVpbnQ2NCk6IHVpbnQ2NAovLwovLyBDYWxjdWxhdGVzIHRoZSBkaWZmZXJlbmNlIGJldHdlZW4gdHdvIG51bWJlcnMKLy8KLy8gQHBhcmFtIGEKLy8gQHBhcmFtIGIKLy8gQHJldHVybnMgVGhlIGRpZmZlcmVuY2UgYmV0d2VlbiBhIGFuZCBiLgpnZXREaWZmZXJlbmNlOgoJcHJvdG8gMiAxCgoJLy8gZXhhbXBsZXMvY2FsY3VsYXRvci9jYWxjdWxhdG9yLmFsZ28udHM6MjQKCS8vIHJldHVybiBhID49IGIgPyBhIC0gYiA6IGIgLSBhOwoJZnJhbWVfZGlnIC0xIC8vIGE6IHVpbnQ2NAoJZnJhbWVfZGlnIC0yIC8vIGI6IHVpbnQ2NAoJPj0KCWJ6ICp0ZXJuYXJ5MF9mYWxzZQoJZnJhbWVfZGlnIC0xIC8vIGE6IHVpbnQ2NAoJZnJhbWVfZGlnIC0yIC8vIGI6IHVpbnQ2NAoJLQoJYiAqdGVybmFyeTBfZW5kCgoqdGVybmFyeTBfZmFsc2U6CglmcmFtZV9kaWcgLTIgLy8gYjogdWludDY0CglmcmFtZV9kaWcgLTEgLy8gYTogdWludDY0CgktCgoqdGVybmFyeTBfZW5kOgoJcmV0c3ViCgovLyBkb01hdGgodWludDY0LHVpbnQ2NCxzdHJpbmcpdWludDY0CiphYmlfcm91dGVfZG9NYXRoOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIG9wZXJhdGlvbjogc3RyaW5nCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAzCglleHRyYWN0IDIgMAoKCS8vIGI6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMgoJYnRvaQoKCS8vIGE6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJYnRvaQoKCS8vIGV4ZWN1dGUgZG9NYXRoKHVpbnQ2NCx1aW50NjQsc3RyaW5nKXVpbnQ2NAoJY2FsbHN1YiBkb01hdGgKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gZG9NYXRoKGE6IHVpbnQ2NCwgYjogdWludDY0LCBvcGVyYXRpb246IHN0cmluZyk6IHVpbnQ2NAovLwovLyBBIG1ldGhvZCB0aGF0IHRha2VzIHR3byBudW1iZXJzIGFuZCBkb2VzIGVpdGhlciBhZGRpdGlvbiBvciBzdWJ0cmFjdGlvbgovLwovLyBAcGFyYW0gYSBUaGUgZmlyc3QgbnVtYmVyCi8vIEBwYXJhbSBiIFRoZSBzZWNvbmQgbnVtYmVyCi8vIEBwYXJhbSBvcGVyYXRpb24gVGhlIG9wZXJhdGlvbiB0byBwZXJmb3JtLiBDYW4gYmUgZWl0aGVyICdzdW0nIG9yICdkaWZmZXJlbmNlJwovLwovLyBAcmV0dXJucyBUaGUgcmVzdWx0IG9mIHRoZSBvcGVyYXRpb24KZG9NYXRoOgoJcHJvdG8gMyAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vICppZjBfY29uZGl0aW9uCgkvLyBleGFtcGxlcy9jYWxjdWxhdG9yL2NhbGN1bGF0b3IuYWxnby50czozOQoJLy8gb3BlcmF0aW9uID09PSAnc3VtJwoJZnJhbWVfZGlnIC0zIC8vIG9wZXJhdGlvbjogc3RyaW5nCglwdXNoYnl0ZXMgMHg3Mzc1NmQgLy8gInN1bSIKCT09CglieiAqaWYwX2Vsc2VpZjFfY29uZGl0aW9uCgoJLy8gKmlmMF9jb25zZXF1ZW50CgkvLyBleGFtcGxlcy9jYWxjdWxhdG9yL2NhbGN1bGF0b3IuYWxnby50czo0MAoJLy8gcmVzdWx0ID0gdGhpcy5nZXRTdW0oYSwgYikKCWZyYW1lX2RpZyAtMiAvLyBiOiB1aW50NjQKCWZyYW1lX2RpZyAtMSAvLyBhOiB1aW50NjQKCWNhbGxzdWIgZ2V0U3VtCglmcmFtZV9idXJ5IDAgLy8gcmVzdWx0OiB1aW50NjQKCWIgKmlmMF9lbmQKCippZjBfZWxzZWlmMV9jb25kaXRpb246CgkvLyBleGFtcGxlcy9jYWxjdWxhdG9yL2NhbGN1bGF0b3IuYWxnby50czo0MQoJLy8gb3BlcmF0aW9uID09PSAnZGlmZmVyZW5jZScKCWZyYW1lX2RpZyAtMyAvLyBvcGVyYXRpb246IHN0cmluZwoJcHVzaGJ5dGVzIDB4NjQ2OTY2NjY2NTcyNjU2ZTYzNjUgLy8gImRpZmZlcmVuY2UiCgk9PQoJYnogKmlmMF9lbHNlCgoJLy8gKmlmMF9lbHNlaWYxX2NvbnNlcXVlbnQKCS8vIGV4YW1wbGVzL2NhbGN1bGF0b3IvY2FsY3VsYXRvci5hbGdvLnRzOjQyCgkvLyByZXN1bHQgPSB0aGlzLmdldERpZmZlcmVuY2UoYSwgYikKCWZyYW1lX2RpZyAtMiAvLyBiOiB1aW50NjQKCWZyYW1lX2RpZyAtMSAvLyBhOiB1aW50NjQKCWNhbGxzdWIgZ2V0RGlmZmVyZW5jZQoJZnJhbWVfYnVyeSAwIC8vIHJlc3VsdDogdWludDY0CgliICppZjBfZW5kCgoqaWYwX2Vsc2U6CgkvLyBJbnZhbGlkIG9wZXJhdGlvbgoJZXJyCgoqaWYwX2VuZDoKCS8vIGV4YW1wbGVzL2NhbGN1bGF0b3IvY2FsY3VsYXRvci5hbGdvLnRzOjQ1CgkvLyByZXR1cm4gcmVzdWx0OwoJZnJhbWVfZGlnIDAgLy8gcmVzdWx0OiB1aW50NjQKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4NzZhN2VmMzMgLy8gbWV0aG9kICJkb01hdGgodWludDY0LHVpbnQ2NCxzdHJpbmcpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9kb01hdGgKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/examples/calculator/artifacts/Calculator.arc56_draft.json b/examples/calculator/artifacts/Calculator.arc56_draft.json index 3989b529a..829e7006d 100644 --- a/examples/calculator/artifacts/Calculator.arc56_draft.json +++ b/examples/calculator/artifacts/Calculator.arc56_draft.json @@ -733,7 +733,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZ2V0U3VtKGE6IHVpbnQ2NCwgYjogdWludDY0KTogdWludDY0Ci8vCi8vIENhbGN1bGF0ZXMgdGhlIHN1bSBvZiB0d28gbnVtYmVycwovLwovLyBAcGFyYW0gYQovLyBAcGFyYW0gYgovLyBAcmV0dXJucyBUaGUgc3VtIG9mIGEgYW5kIGIKZ2V0U3VtOgoJcHJvdG8gMiAxCgoJLy8gZXhhbXBsZXMvY2FsY3VsYXRvci9jYWxjdWxhdG9yLmFsZ28udHM6MTMKCS8vIHJldHVybiBhICsgYjsKCWZyYW1lX2RpZyAtMSAvLyBhOiB1aW50NjQKCWZyYW1lX2RpZyAtMiAvLyBiOiB1aW50NjQKCSsKCXJldHN1YgoKLy8gZ2V0RGlmZmVyZW5jZShhOiB1aW50NjQsIGI6IHVpbnQ2NCk6IHVpbnQ2NAovLwovLyBDYWxjdWxhdGVzIHRoZSBkaWZmZXJlbmNlIGJldHdlZW4gdHdvIG51bWJlcnMKLy8KLy8gQHBhcmFtIGEKLy8gQHBhcmFtIGIKLy8gQHJldHVybnMgVGhlIGRpZmZlcmVuY2UgYmV0d2VlbiBhIGFuZCBiLgpnZXREaWZmZXJlbmNlOgoJcHJvdG8gMiAxCgoJLy8gZXhhbXBsZXMvY2FsY3VsYXRvci9jYWxjdWxhdG9yLmFsZ28udHM6MjQKCS8vIHJldHVybiBhID49IGIgPyBhIC0gYiA6IGIgLSBhOwoJZnJhbWVfZGlnIC0xIC8vIGE6IHVpbnQ2NAoJZnJhbWVfZGlnIC0yIC8vIGI6IHVpbnQ2NAoJPj0KCWJ6ICp0ZXJuYXJ5MF9mYWxzZQoJZnJhbWVfZGlnIC0xIC8vIGE6IHVpbnQ2NAoJZnJhbWVfZGlnIC0yIC8vIGI6IHVpbnQ2NAoJLQoJYiAqdGVybmFyeTBfZW5kCgoqdGVybmFyeTBfZmFsc2U6CglmcmFtZV9kaWcgLTIgLy8gYjogdWludDY0CglmcmFtZV9kaWcgLTEgLy8gYTogdWludDY0CgktCgoqdGVybmFyeTBfZW5kOgoJcmV0c3ViCgovLyBkb01hdGgodWludDY0LHVpbnQ2NCxzdHJpbmcpdWludDY0CiphYmlfcm91dGVfZG9NYXRoOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIG9wZXJhdGlvbjogc3RyaW5nCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAzCglleHRyYWN0IDIgMAoKCS8vIGI6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMgoJYnRvaQoKCS8vIGE6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJYnRvaQoKCS8vIGV4ZWN1dGUgZG9NYXRoKHVpbnQ2NCx1aW50NjQsc3RyaW5nKXVpbnQ2NAoJY2FsbHN1YiBkb01hdGgKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gZG9NYXRoKGE6IHVpbnQ2NCwgYjogdWludDY0LCBvcGVyYXRpb246IHN0cmluZyk6IHVpbnQ2NAovLwovLyBBIG1ldGhvZCB0aGF0IHRha2VzIHR3byBudW1iZXJzIGFuZCBkb2VzIGVpdGhlciBhZGRpdGlvbiBvciBzdWJ0cmFjdGlvbgovLwovLyBAcGFyYW0gYSBUaGUgZmlyc3QgbnVtYmVyCi8vIEBwYXJhbSBiIFRoZSBzZWNvbmQgbnVtYmVyCi8vIEBwYXJhbSBvcGVyYXRpb24gVGhlIG9wZXJhdGlvbiB0byBwZXJmb3JtLiBDYW4gYmUgZWl0aGVyICdzdW0nIG9yICdkaWZmZXJlbmNlJwovLwovLyBAcmV0dXJucyBUaGUgcmVzdWx0IG9mIHRoZSBvcGVyYXRpb24KZG9NYXRoOgoJcHJvdG8gMyAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vICppZjBfY29uZGl0aW9uCgkvLyBleGFtcGxlcy9jYWxjdWxhdG9yL2NhbGN1bGF0b3IuYWxnby50czozOQoJLy8gb3BlcmF0aW9uID09PSAnc3VtJwoJZnJhbWVfZGlnIC0zIC8vIG9wZXJhdGlvbjogc3RyaW5nCglwdXNoYnl0ZXMgMHg3Mzc1NmQgLy8gInN1bSIKCT09CglieiAqaWYwX2Vsc2VpZjFfY29uZGl0aW9uCgoJLy8gKmlmMF9jb25zZXF1ZW50CgkvLyBleGFtcGxlcy9jYWxjdWxhdG9yL2NhbGN1bGF0b3IuYWxnby50czo0MAoJLy8gcmVzdWx0ID0gdGhpcy5nZXRTdW0oYSwgYikKCWZyYW1lX2RpZyAtMiAvLyBiOiB1aW50NjQKCWZyYW1lX2RpZyAtMSAvLyBhOiB1aW50NjQKCWNhbGxzdWIgZ2V0U3VtCglmcmFtZV9idXJ5IDAgLy8gcmVzdWx0OiB1aW50NjQKCWIgKmlmMF9lbmQKCippZjBfZWxzZWlmMV9jb25kaXRpb246CgkvLyBleGFtcGxlcy9jYWxjdWxhdG9yL2NhbGN1bGF0b3IuYWxnby50czo0MQoJLy8gb3BlcmF0aW9uID09PSAnZGlmZmVyZW5jZScKCWZyYW1lX2RpZyAtMyAvLyBvcGVyYXRpb246IHN0cmluZwoJcHVzaGJ5dGVzIDB4NjQ2OTY2NjY2NTcyNjU2ZTYzNjUgLy8gImRpZmZlcmVuY2UiCgk9PQoJYnogKmlmMF9lbHNlCgoJLy8gKmlmMF9lbHNlaWYxX2NvbnNlcXVlbnQKCS8vIGV4YW1wbGVzL2NhbGN1bGF0b3IvY2FsY3VsYXRvci5hbGdvLnRzOjQyCgkvLyByZXN1bHQgPSB0aGlzLmdldERpZmZlcmVuY2UoYSwgYikKCWZyYW1lX2RpZyAtMiAvLyBiOiB1aW50NjQKCWZyYW1lX2RpZyAtMSAvLyBhOiB1aW50NjQKCWNhbGxzdWIgZ2V0RGlmZmVyZW5jZQoJZnJhbWVfYnVyeSAwIC8vIHJlc3VsdDogdWludDY0CgliICppZjBfZW5kCgoqaWYwX2Vsc2U6CgkvLyBJbnZhbGlkIG9wZXJhdGlvbgoJZXJyCgoqaWYwX2VuZDoKCS8vIGV4YW1wbGVzL2NhbGN1bGF0b3IvY2FsY3VsYXRvci5hbGdvLnRzOjQ1CgkvLyByZXR1cm4gcmVzdWx0OwoJZnJhbWVfZGlnIDAgLy8gcmVzdWx0OiB1aW50NjQKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4NzZhN2VmMzMgLy8gbWV0aG9kICJkb01hdGgodWludDY0LHVpbnQ2NCxzdHJpbmcpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9kb01hdGgKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZ2V0U3VtKGE6IHVpbnQ2NCwgYjogdWludDY0KTogdWludDY0Ci8vCi8vIENhbGN1bGF0ZXMgdGhlIHN1bSBvZiB0d28gbnVtYmVycwovLwovLyBAcGFyYW0gYQovLyBAcGFyYW0gYgovLyBAcmV0dXJucyBUaGUgc3VtIG9mIGEgYW5kIGIKZ2V0U3VtOgoJcHJvdG8gMiAxCgoJLy8gZXhhbXBsZXMvY2FsY3VsYXRvci9jYWxjdWxhdG9yLmFsZ28udHM6MTMKCS8vIHJldHVybiBhICsgYjsKCWZyYW1lX2RpZyAtMSAvLyBhOiB1aW50NjQKCWZyYW1lX2RpZyAtMiAvLyBiOiB1aW50NjQKCSsKCXJldHN1YgoKLy8gZ2V0RGlmZmVyZW5jZShhOiB1aW50NjQsIGI6IHVpbnQ2NCk6IHVpbnQ2NAovLwovLyBDYWxjdWxhdGVzIHRoZSBkaWZmZXJlbmNlIGJldHdlZW4gdHdvIG51bWJlcnMKLy8KLy8gQHBhcmFtIGEKLy8gQHBhcmFtIGIKLy8gQHJldHVybnMgVGhlIGRpZmZlcmVuY2UgYmV0d2VlbiBhIGFuZCBiLgpnZXREaWZmZXJlbmNlOgoJcHJvdG8gMiAxCgoJLy8gZXhhbXBsZXMvY2FsY3VsYXRvci9jYWxjdWxhdG9yLmFsZ28udHM6MjQKCS8vIHJldHVybiBhID49IGIgPyBhIC0gYiA6IGIgLSBhOwoJZnJhbWVfZGlnIC0xIC8vIGE6IHVpbnQ2NAoJZnJhbWVfZGlnIC0yIC8vIGI6IHVpbnQ2NAoJPj0KCWJ6ICp0ZXJuYXJ5MF9mYWxzZQoJZnJhbWVfZGlnIC0xIC8vIGE6IHVpbnQ2NAoJZnJhbWVfZGlnIC0yIC8vIGI6IHVpbnQ2NAoJLQoJYiAqdGVybmFyeTBfZW5kCgoqdGVybmFyeTBfZmFsc2U6CglmcmFtZV9kaWcgLTIgLy8gYjogdWludDY0CglmcmFtZV9kaWcgLTEgLy8gYTogdWludDY0CgktCgoqdGVybmFyeTBfZW5kOgoJcmV0c3ViCgovLyBkb01hdGgodWludDY0LHVpbnQ2NCxzdHJpbmcpdWludDY0CiphYmlfcm91dGVfZG9NYXRoOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIG9wZXJhdGlvbjogc3RyaW5nCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAzCglleHRyYWN0IDIgMAoKCS8vIGI6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMgoJYnRvaQoKCS8vIGE6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJYnRvaQoKCS8vIGV4ZWN1dGUgZG9NYXRoKHVpbnQ2NCx1aW50NjQsc3RyaW5nKXVpbnQ2NAoJY2FsbHN1YiBkb01hdGgKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gZG9NYXRoKGE6IHVpbnQ2NCwgYjogdWludDY0LCBvcGVyYXRpb246IHN0cmluZyk6IHVpbnQ2NAovLwovLyBBIG1ldGhvZCB0aGF0IHRha2VzIHR3byBudW1iZXJzIGFuZCBkb2VzIGVpdGhlciBhZGRpdGlvbiBvciBzdWJ0cmFjdGlvbgovLwovLyBAcGFyYW0gYSBUaGUgZmlyc3QgbnVtYmVyCi8vIEBwYXJhbSBiIFRoZSBzZWNvbmQgbnVtYmVyCi8vIEBwYXJhbSBvcGVyYXRpb24gVGhlIG9wZXJhdGlvbiB0byBwZXJmb3JtLiBDYW4gYmUgZWl0aGVyICdzdW0nIG9yICdkaWZmZXJlbmNlJwovLwovLyBAcmV0dXJucyBUaGUgcmVzdWx0IG9mIHRoZSBvcGVyYXRpb24KZG9NYXRoOgoJcHJvdG8gMyAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vICppZjBfY29uZGl0aW9uCgkvLyBleGFtcGxlcy9jYWxjdWxhdG9yL2NhbGN1bGF0b3IuYWxnby50czozOQoJLy8gb3BlcmF0aW9uID09PSAnc3VtJwoJZnJhbWVfZGlnIC0zIC8vIG9wZXJhdGlvbjogc3RyaW5nCglwdXNoYnl0ZXMgMHg3Mzc1NmQgLy8gInN1bSIKCT09CglieiAqaWYwX2Vsc2VpZjFfY29uZGl0aW9uCgoJLy8gKmlmMF9jb25zZXF1ZW50CgkvLyBleGFtcGxlcy9jYWxjdWxhdG9yL2NhbGN1bGF0b3IuYWxnby50czo0MAoJLy8gcmVzdWx0ID0gdGhpcy5nZXRTdW0oYSwgYikKCWZyYW1lX2RpZyAtMiAvLyBiOiB1aW50NjQKCWZyYW1lX2RpZyAtMSAvLyBhOiB1aW50NjQKCWNhbGxzdWIgZ2V0U3VtCglmcmFtZV9idXJ5IDAgLy8gcmVzdWx0OiB1aW50NjQKCWIgKmlmMF9lbmQKCippZjBfZWxzZWlmMV9jb25kaXRpb246CgkvLyBleGFtcGxlcy9jYWxjdWxhdG9yL2NhbGN1bGF0b3IuYWxnby50czo0MQoJLy8gb3BlcmF0aW9uID09PSAnZGlmZmVyZW5jZScKCWZyYW1lX2RpZyAtMyAvLyBvcGVyYXRpb246IHN0cmluZwoJcHVzaGJ5dGVzIDB4NjQ2OTY2NjY2NTcyNjU2ZTYzNjUgLy8gImRpZmZlcmVuY2UiCgk9PQoJYnogKmlmMF9lbHNlCgoJLy8gKmlmMF9lbHNlaWYxX2NvbnNlcXVlbnQKCS8vIGV4YW1wbGVzL2NhbGN1bGF0b3IvY2FsY3VsYXRvci5hbGdvLnRzOjQyCgkvLyByZXN1bHQgPSB0aGlzLmdldERpZmZlcmVuY2UoYSwgYikKCWZyYW1lX2RpZyAtMiAvLyBiOiB1aW50NjQKCWZyYW1lX2RpZyAtMSAvLyBhOiB1aW50NjQKCWNhbGxzdWIgZ2V0RGlmZmVyZW5jZQoJZnJhbWVfYnVyeSAwIC8vIHJlc3VsdDogdWludDY0CgliICppZjBfZW5kCgoqaWYwX2Vsc2U6CgkvLyBJbnZhbGlkIG9wZXJhdGlvbgoJZXJyCgoqaWYwX2VuZDoKCS8vIGV4YW1wbGVzL2NhbGN1bGF0b3IvY2FsY3VsYXRvci5hbGdvLnRzOjQ1CgkvLyByZXR1cm4gcmVzdWx0OwoJZnJhbWVfZGlnIDAgLy8gcmVzdWx0OiB1aW50NjQKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4NzZhN2VmMzMgLy8gbWV0aG9kICJkb01hdGgodWludDY0LHVpbnQ2NCxzdHJpbmcpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9kb01hdGgKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/examples/itxns/artifacts/FactoryCaller.approval.teal b/examples/itxns/artifacts/FactoryCaller.approval.teal index c2a5239ff..1a4e40035 100644 --- a/examples/itxns/artifacts/FactoryCaller.approval.teal +++ b/examples/itxns/artifacts/FactoryCaller.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0xb8447b36 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/examples/itxns/artifacts/FactoryCaller.arc32.json b/examples/itxns/artifacts/FactoryCaller.arc32.json index f956d4952..87f7d5f1f 100644 --- a/examples/itxns/artifacts/FactoryCaller.arc32.json +++ b/examples/itxns/artifacts/FactoryCaller.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "#pragma version 10
bytecblock 0xb8447b36 0x

// This TEAL was generated by TEALScript v0.104.1
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// mintAndGetAsset()uint64
*abi_route_mintAndGetAsset:
	// The ABI return prefix
	pushbytes 0x151f7c75

	// execute mintAndGetAsset()uint64
	callsub mintAndGetAsset
	itob
	concat
	log
	pushint 1
	return

// mintAndGetAsset(): AssetID
mintAndGetAsset:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// examples/itxns/itxns.algo.ts:25
	// sendMethodCall<typeof NFTFactory.prototype.createApplication>({
	//       clearStateProgram: NFTFactory.clearProgram(),
	//       approvalProgram: NFTFactory.approvalProgram(),
	//     })
	itxn_begin
	pushint 6 // appl
	itxn_field TypeEnum
	byte 0xb8447b36 // method "createApplication()void"
	itxn_field ApplicationArgs

	// examples/itxns/itxns.algo.ts:26
	// clearStateProgram: NFTFactory.clearProgram()
	pushbytes 0x0a
	itxn_field ClearStateProgram

	// examples/itxns/itxns.algo.ts:27
	// approvalProgram: NFTFactory.approvalProgram()
	pushbytes 0x0a31181481060b3119088d0c007600000000000000000000006800000000000000000000008004151f7c75361a02570200361a015702008800061650b08101438a0201b18103b2108bffb2268bfeb2258101b2228100b201b3b43c89361a02491581201244361a01178800038101438a0200b18104b2108bfeb2148101b2128bffb2118100b201b3898101438004b8447b36361a008e01fff0008004d2024c738004c7e260af361a008e02ff76ffad00
	itxn_field ApprovalProgram

	// Fee field not set, defaulting to 0
	pushint 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/itxns/itxns.algo.ts:30
	// factoryApp = this.itxn.createdApplicationID
	itxn CreatedApplicationID
	frame_bury 0 // factoryApp: uint64

	// examples/itxns/itxns.algo.ts:32
	// sendPayment({
	//       amount: 200_000,
	//       receiver: factoryApp.address,
	//     })
	itxn_begin
	pushint 1 // pay
	itxn_field TypeEnum

	// examples/itxns/itxns.algo.ts:33
	// amount: 200_000
	pushint 200_000
	itxn_field Amount

	// examples/itxns/itxns.algo.ts:34
	// receiver: factoryApp.address
	frame_dig 0 // factoryApp: uint64
	app_params_get AppAddress
	pop
	itxn_field Receiver

	// Fee field not set, defaulting to 0
	pushint 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/itxns/itxns.algo.ts:37
	// createdAsset = sendMethodCall<typeof NFTFactory.prototype.createNFT>({
	//       applicationID: factoryApp,
	//       methodArgs: ['My NFT', 'MNFT'],
	//     })
	itxn_begin
	pushint 6 // appl
	itxn_field TypeEnum
	pushbytes 0xd2024c73 // method "createNFT(string,string)uint64"
	itxn_field ApplicationArgs

	// examples/itxns/itxns.algo.ts:38
	// applicationID: factoryApp
	frame_dig 0 // factoryApp: uint64
	itxn_field ApplicationID

	// examples/itxns/itxns.algo.ts:39
	// methodArgs: ['My NFT', 'MNFT']
	pushbytes 0x00064d79204e4654
	itxn_field ApplicationArgs
	pushbytes 0x00044d4e4654
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	pushint 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	pushint 1
	-
	itxnas Logs
	extract 4 0
	btoi
	frame_bury 1 // createdAsset: uint64

	// examples/itxns/itxns.algo.ts:42
	// sendAssetTransfer({
	//       assetReceiver: this.app.address,
	//       assetAmount: 0,
	//       xferAsset: createdAsset,
	//     })
	itxn_begin
	pushint 4 // axfer
	itxn_field TypeEnum

	// examples/itxns/itxns.algo.ts:43
	// assetReceiver: this.app.address
	global CurrentApplicationAddress
	itxn_field AssetReceiver

	// examples/itxns/itxns.algo.ts:44
	// assetAmount: 0
	pushint 0
	itxn_field AssetAmount

	// examples/itxns/itxns.algo.ts:45
	// xferAsset: createdAsset
	frame_dig 1 // createdAsset: uint64
	itxn_field XferAsset

	// Fee field not set, defaulting to 0
	pushint 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/itxns/itxns.algo.ts:48
	// sendMethodCall<typeof NFTFactory.prototype.transferNFT>({
	//       applicationID: factoryApp,
	//       methodArgs: [createdAsset, this.app.address],
	//     })
	itxn_begin
	pushint 6 // appl
	itxn_field TypeEnum
	pushbytes 0xc7e260af // method "transferNFT(uint64,address)void"
	itxn_field ApplicationArgs

	// examples/itxns/itxns.algo.ts:49
	// applicationID: factoryApp
	frame_dig 0 // factoryApp: uint64
	itxn_field ApplicationID

	// examples/itxns/itxns.algo.ts:50
	// methodArgs: [createdAsset, this.app.address]
	frame_dig 1 // createdAsset: uint64
	itob
	itxn_field ApplicationArgs
	global CurrentApplicationAddress
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	pushint 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/itxns/itxns.algo.ts:53
	// return createdAsset;
	frame_dig 1 // createdAsset: uint64

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 1
	retsub

*abi_route_createApplication:
	pushint 1
	return

*create_NoOp:
	byte 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x45ded8e0 // method "mintAndGetAsset()uint64"
	txna ApplicationArgs 0
	match *abi_route_mintAndGetAsset

	// this contract does not implement the given ABI method for call NoOp
	err", + "approval": "#pragma version 10
bytecblock 0xb8447b36 0x

// This TEAL was generated by TEALScript v0.105.0
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// mintAndGetAsset()uint64
*abi_route_mintAndGetAsset:
	// The ABI return prefix
	pushbytes 0x151f7c75

	// execute mintAndGetAsset()uint64
	callsub mintAndGetAsset
	itob
	concat
	log
	pushint 1
	return

// mintAndGetAsset(): AssetID
mintAndGetAsset:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// examples/itxns/itxns.algo.ts:25
	// sendMethodCall<typeof NFTFactory.prototype.createApplication>({
	//       clearStateProgram: NFTFactory.clearProgram(),
	//       approvalProgram: NFTFactory.approvalProgram(),
	//     })
	itxn_begin
	pushint 6 // appl
	itxn_field TypeEnum
	byte 0xb8447b36 // method "createApplication()void"
	itxn_field ApplicationArgs

	// examples/itxns/itxns.algo.ts:26
	// clearStateProgram: NFTFactory.clearProgram()
	pushbytes 0x0a
	itxn_field ClearStateProgram

	// examples/itxns/itxns.algo.ts:27
	// approvalProgram: NFTFactory.approvalProgram()
	pushbytes 0x0a31181481060b3119088d0c007600000000000000000000006800000000000000000000008004151f7c75361a02570200361a015702008800061650b08101438a0201b18103b2108bffb2268bfeb2258101b2228100b201b3b43c89361a02491581201244361a01178800038101438a0200b18104b2108bfeb2148101b2128bffb2118100b201b3898101438004b8447b36361a008e01fff0008004d2024c738004c7e260af361a008e02ff76ffad00
	itxn_field ApprovalProgram

	// Fee field not set, defaulting to 0
	pushint 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/itxns/itxns.algo.ts:30
	// factoryApp = this.itxn.createdApplicationID
	itxn CreatedApplicationID
	frame_bury 0 // factoryApp: uint64

	// examples/itxns/itxns.algo.ts:32
	// sendPayment({
	//       amount: 200_000,
	//       receiver: factoryApp.address,
	//     })
	itxn_begin
	pushint 1 // pay
	itxn_field TypeEnum

	// examples/itxns/itxns.algo.ts:33
	// amount: 200_000
	pushint 200_000
	itxn_field Amount

	// examples/itxns/itxns.algo.ts:34
	// receiver: factoryApp.address
	frame_dig 0 // factoryApp: uint64
	app_params_get AppAddress
	pop
	itxn_field Receiver

	// Fee field not set, defaulting to 0
	pushint 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/itxns/itxns.algo.ts:37
	// createdAsset = sendMethodCall<typeof NFTFactory.prototype.createNFT>({
	//       applicationID: factoryApp,
	//       methodArgs: ['My NFT', 'MNFT'],
	//     })
	itxn_begin
	pushint 6 // appl
	itxn_field TypeEnum
	pushbytes 0xd2024c73 // method "createNFT(string,string)uint64"
	itxn_field ApplicationArgs

	// examples/itxns/itxns.algo.ts:38
	// applicationID: factoryApp
	frame_dig 0 // factoryApp: uint64
	itxn_field ApplicationID

	// examples/itxns/itxns.algo.ts:39
	// methodArgs: ['My NFT', 'MNFT']
	pushbytes 0x00064d79204e4654
	itxn_field ApplicationArgs
	pushbytes 0x00044d4e4654
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	pushint 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	pushint 1
	-
	itxnas Logs
	extract 4 0
	btoi
	frame_bury 1 // createdAsset: uint64

	// examples/itxns/itxns.algo.ts:42
	// sendAssetTransfer({
	//       assetReceiver: this.app.address,
	//       assetAmount: 0,
	//       xferAsset: createdAsset,
	//     })
	itxn_begin
	pushint 4 // axfer
	itxn_field TypeEnum

	// examples/itxns/itxns.algo.ts:43
	// assetReceiver: this.app.address
	global CurrentApplicationAddress
	itxn_field AssetReceiver

	// examples/itxns/itxns.algo.ts:44
	// assetAmount: 0
	pushint 0
	itxn_field AssetAmount

	// examples/itxns/itxns.algo.ts:45
	// xferAsset: createdAsset
	frame_dig 1 // createdAsset: uint64
	itxn_field XferAsset

	// Fee field not set, defaulting to 0
	pushint 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/itxns/itxns.algo.ts:48
	// sendMethodCall<typeof NFTFactory.prototype.transferNFT>({
	//       applicationID: factoryApp,
	//       methodArgs: [createdAsset, this.app.address],
	//     })
	itxn_begin
	pushint 6 // appl
	itxn_field TypeEnum
	pushbytes 0xc7e260af // method "transferNFT(uint64,address)void"
	itxn_field ApplicationArgs

	// examples/itxns/itxns.algo.ts:49
	// applicationID: factoryApp
	frame_dig 0 // factoryApp: uint64
	itxn_field ApplicationID

	// examples/itxns/itxns.algo.ts:50
	// methodArgs: [createdAsset, this.app.address]
	frame_dig 1 // createdAsset: uint64
	itob
	itxn_field ApplicationArgs
	global CurrentApplicationAddress
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	pushint 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/itxns/itxns.algo.ts:53
	// return createdAsset;
	frame_dig 1 // createdAsset: uint64

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 1
	retsub

*abi_route_createApplication:
	pushint 1
	return

*create_NoOp:
	byte 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x45ded8e0 // method "mintAndGetAsset()uint64"
	txna ApplicationArgs 0
	match *abi_route_mintAndGetAsset

	// this contract does not implement the given ABI method for call NoOp
	err", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/examples/itxns/artifacts/FactoryCaller.arc56_draft.json b/examples/itxns/artifacts/FactoryCaller.arc56_draft.json index 1b6e7bf9b..a032bce18 100644 --- a/examples/itxns/artifacts/FactoryCaller.arc56_draft.json +++ b/examples/itxns/artifacts/FactoryCaller.arc56_draft.json @@ -1168,7 +1168,7 @@ } }, "source": { - "approval": "#pragma version 10
bytecblock 0xb8447b36 0x

// This TEAL was generated by TEALScript v0.104.1
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// mintAndGetAsset()uint64
*abi_route_mintAndGetAsset:
	// The ABI return prefix
	pushbytes 0x151f7c75

	// execute mintAndGetAsset()uint64
	callsub mintAndGetAsset
	itob
	concat
	log
	pushint 1
	return

// mintAndGetAsset(): AssetID
mintAndGetAsset:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// examples/itxns/itxns.algo.ts:25
	// sendMethodCall<typeof NFTFactory.prototype.createApplication>({
	//       clearStateProgram: NFTFactory.clearProgram(),
	//       approvalProgram: NFTFactory.approvalProgram(),
	//     })
	itxn_begin
	pushint 6 // appl
	itxn_field TypeEnum
	byte 0xb8447b36 // method "createApplication()void"
	itxn_field ApplicationArgs

	// examples/itxns/itxns.algo.ts:26
	// clearStateProgram: NFTFactory.clearProgram()
	pushbytes 0x0a
	itxn_field ClearStateProgram

	// examples/itxns/itxns.algo.ts:27
	// approvalProgram: NFTFactory.approvalProgram()
	pushbytes 0x0a31181481060b3119088d0c007600000000000000000000006800000000000000000000008004151f7c75361a02570200361a015702008800061650b08101438a0201b18103b2108bffb2268bfeb2258101b2228100b201b3b43c89361a02491581201244361a01178800038101438a0200b18104b2108bfeb2148101b2128bffb2118100b201b3898101438004b8447b36361a008e01fff0008004d2024c738004c7e260af361a008e02ff76ffad00
	itxn_field ApprovalProgram

	// Fee field not set, defaulting to 0
	pushint 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/itxns/itxns.algo.ts:30
	// factoryApp = this.itxn.createdApplicationID
	itxn CreatedApplicationID
	frame_bury 0 // factoryApp: uint64

	// examples/itxns/itxns.algo.ts:32
	// sendPayment({
	//       amount: 200_000,
	//       receiver: factoryApp.address,
	//     })
	itxn_begin
	pushint 1 // pay
	itxn_field TypeEnum

	// examples/itxns/itxns.algo.ts:33
	// amount: 200_000
	pushint 200_000
	itxn_field Amount

	// examples/itxns/itxns.algo.ts:34
	// receiver: factoryApp.address
	frame_dig 0 // factoryApp: uint64
	app_params_get AppAddress
	pop
	itxn_field Receiver

	// Fee field not set, defaulting to 0
	pushint 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/itxns/itxns.algo.ts:37
	// createdAsset = sendMethodCall<typeof NFTFactory.prototype.createNFT>({
	//       applicationID: factoryApp,
	//       methodArgs: ['My NFT', 'MNFT'],
	//     })
	itxn_begin
	pushint 6 // appl
	itxn_field TypeEnum
	pushbytes 0xd2024c73 // method "createNFT(string,string)uint64"
	itxn_field ApplicationArgs

	// examples/itxns/itxns.algo.ts:38
	// applicationID: factoryApp
	frame_dig 0 // factoryApp: uint64
	itxn_field ApplicationID

	// examples/itxns/itxns.algo.ts:39
	// methodArgs: ['My NFT', 'MNFT']
	pushbytes 0x00064d79204e4654
	itxn_field ApplicationArgs
	pushbytes 0x00044d4e4654
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	pushint 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	pushint 1
	-
	itxnas Logs
	extract 4 0
	btoi
	frame_bury 1 // createdAsset: uint64

	// examples/itxns/itxns.algo.ts:42
	// sendAssetTransfer({
	//       assetReceiver: this.app.address,
	//       assetAmount: 0,
	//       xferAsset: createdAsset,
	//     })
	itxn_begin
	pushint 4 // axfer
	itxn_field TypeEnum

	// examples/itxns/itxns.algo.ts:43
	// assetReceiver: this.app.address
	global CurrentApplicationAddress
	itxn_field AssetReceiver

	// examples/itxns/itxns.algo.ts:44
	// assetAmount: 0
	pushint 0
	itxn_field AssetAmount

	// examples/itxns/itxns.algo.ts:45
	// xferAsset: createdAsset
	frame_dig 1 // createdAsset: uint64
	itxn_field XferAsset

	// Fee field not set, defaulting to 0
	pushint 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/itxns/itxns.algo.ts:48
	// sendMethodCall<typeof NFTFactory.prototype.transferNFT>({
	//       applicationID: factoryApp,
	//       methodArgs: [createdAsset, this.app.address],
	//     })
	itxn_begin
	pushint 6 // appl
	itxn_field TypeEnum
	pushbytes 0xc7e260af // method "transferNFT(uint64,address)void"
	itxn_field ApplicationArgs

	// examples/itxns/itxns.algo.ts:49
	// applicationID: factoryApp
	frame_dig 0 // factoryApp: uint64
	itxn_field ApplicationID

	// examples/itxns/itxns.algo.ts:50
	// methodArgs: [createdAsset, this.app.address]
	frame_dig 1 // createdAsset: uint64
	itob
	itxn_field ApplicationArgs
	global CurrentApplicationAddress
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	pushint 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/itxns/itxns.algo.ts:53
	// return createdAsset;
	frame_dig 1 // createdAsset: uint64

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 1
	retsub

*abi_route_createApplication:
	pushint 1
	return

*create_NoOp:
	byte 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x45ded8e0 // method "mintAndGetAsset()uint64"
	txna ApplicationArgs 0
	match *abi_route_mintAndGetAsset

	// this contract does not implement the given ABI method for call NoOp
	err", + "approval": "#pragma version 10
bytecblock 0xb8447b36 0x

// This TEAL was generated by TEALScript v0.105.0
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// mintAndGetAsset()uint64
*abi_route_mintAndGetAsset:
	// The ABI return prefix
	pushbytes 0x151f7c75

	// execute mintAndGetAsset()uint64
	callsub mintAndGetAsset
	itob
	concat
	log
	pushint 1
	return

// mintAndGetAsset(): AssetID
mintAndGetAsset:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// examples/itxns/itxns.algo.ts:25
	// sendMethodCall<typeof NFTFactory.prototype.createApplication>({
	//       clearStateProgram: NFTFactory.clearProgram(),
	//       approvalProgram: NFTFactory.approvalProgram(),
	//     })
	itxn_begin
	pushint 6 // appl
	itxn_field TypeEnum
	byte 0xb8447b36 // method "createApplication()void"
	itxn_field ApplicationArgs

	// examples/itxns/itxns.algo.ts:26
	// clearStateProgram: NFTFactory.clearProgram()
	pushbytes 0x0a
	itxn_field ClearStateProgram

	// examples/itxns/itxns.algo.ts:27
	// approvalProgram: NFTFactory.approvalProgram()
	pushbytes 0x0a31181481060b3119088d0c007600000000000000000000006800000000000000000000008004151f7c75361a02570200361a015702008800061650b08101438a0201b18103b2108bffb2268bfeb2258101b2228100b201b3b43c89361a02491581201244361a01178800038101438a0200b18104b2108bfeb2148101b2128bffb2118100b201b3898101438004b8447b36361a008e01fff0008004d2024c738004c7e260af361a008e02ff76ffad00
	itxn_field ApprovalProgram

	// Fee field not set, defaulting to 0
	pushint 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/itxns/itxns.algo.ts:30
	// factoryApp = this.itxn.createdApplicationID
	itxn CreatedApplicationID
	frame_bury 0 // factoryApp: uint64

	// examples/itxns/itxns.algo.ts:32
	// sendPayment({
	//       amount: 200_000,
	//       receiver: factoryApp.address,
	//     })
	itxn_begin
	pushint 1 // pay
	itxn_field TypeEnum

	// examples/itxns/itxns.algo.ts:33
	// amount: 200_000
	pushint 200_000
	itxn_field Amount

	// examples/itxns/itxns.algo.ts:34
	// receiver: factoryApp.address
	frame_dig 0 // factoryApp: uint64
	app_params_get AppAddress
	pop
	itxn_field Receiver

	// Fee field not set, defaulting to 0
	pushint 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/itxns/itxns.algo.ts:37
	// createdAsset = sendMethodCall<typeof NFTFactory.prototype.createNFT>({
	//       applicationID: factoryApp,
	//       methodArgs: ['My NFT', 'MNFT'],
	//     })
	itxn_begin
	pushint 6 // appl
	itxn_field TypeEnum
	pushbytes 0xd2024c73 // method "createNFT(string,string)uint64"
	itxn_field ApplicationArgs

	// examples/itxns/itxns.algo.ts:38
	// applicationID: factoryApp
	frame_dig 0 // factoryApp: uint64
	itxn_field ApplicationID

	// examples/itxns/itxns.algo.ts:39
	// methodArgs: ['My NFT', 'MNFT']
	pushbytes 0x00064d79204e4654
	itxn_field ApplicationArgs
	pushbytes 0x00044d4e4654
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	pushint 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	pushint 1
	-
	itxnas Logs
	extract 4 0
	btoi
	frame_bury 1 // createdAsset: uint64

	// examples/itxns/itxns.algo.ts:42
	// sendAssetTransfer({
	//       assetReceiver: this.app.address,
	//       assetAmount: 0,
	//       xferAsset: createdAsset,
	//     })
	itxn_begin
	pushint 4 // axfer
	itxn_field TypeEnum

	// examples/itxns/itxns.algo.ts:43
	// assetReceiver: this.app.address
	global CurrentApplicationAddress
	itxn_field AssetReceiver

	// examples/itxns/itxns.algo.ts:44
	// assetAmount: 0
	pushint 0
	itxn_field AssetAmount

	// examples/itxns/itxns.algo.ts:45
	// xferAsset: createdAsset
	frame_dig 1 // createdAsset: uint64
	itxn_field XferAsset

	// Fee field not set, defaulting to 0
	pushint 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/itxns/itxns.algo.ts:48
	// sendMethodCall<typeof NFTFactory.prototype.transferNFT>({
	//       applicationID: factoryApp,
	//       methodArgs: [createdAsset, this.app.address],
	//     })
	itxn_begin
	pushint 6 // appl
	itxn_field TypeEnum
	pushbytes 0xc7e260af // method "transferNFT(uint64,address)void"
	itxn_field ApplicationArgs

	// examples/itxns/itxns.algo.ts:49
	// applicationID: factoryApp
	frame_dig 0 // factoryApp: uint64
	itxn_field ApplicationID

	// examples/itxns/itxns.algo.ts:50
	// methodArgs: [createdAsset, this.app.address]
	frame_dig 1 // createdAsset: uint64
	itob
	itxn_field ApplicationArgs
	global CurrentApplicationAddress
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	pushint 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/itxns/itxns.algo.ts:53
	// return createdAsset;
	frame_dig 1 // createdAsset: uint64

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 1
	retsub

*abi_route_createApplication:
	pushint 1
	return

*create_NoOp:
	byte 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x45ded8e0 // method "mintAndGetAsset()uint64"
	txna ApplicationArgs 0
	match *abi_route_mintAndGetAsset

	// this contract does not implement the given ABI method for call NoOp
	err", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/examples/itxns/artifacts/NFTFactory.approval.teal b/examples/itxns/artifacts/NFTFactory.approval.teal index fa1ac9d44..a220bedd2 100644 --- a/examples/itxns/artifacts/NFTFactory.approval.teal +++ b/examples/itxns/artifacts/NFTFactory.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/examples/itxns/artifacts/NFTFactory.arc32.json b/examples/itxns/artifacts/NFTFactory.arc32.json index 45cba73a2..490948819 100644 --- a/examples/itxns/artifacts/NFTFactory.arc32.json +++ b/examples/itxns/artifacts/NFTFactory.arc32.json @@ -44,7 +44,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gY3JlYXRlTkZUKHN0cmluZyxzdHJpbmcpdWludDY0CiphYmlfcm91dGVfY3JlYXRlTkZUOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIHVuaXROYW1lOiBzdHJpbmcKCXR4bmEgQXBwbGljYXRpb25BcmdzIDIKCWV4dHJhY3QgMiAwCgoJLy8gbmFtZTogc3RyaW5nCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglleHRyYWN0IDIgMAoKCS8vIGV4ZWN1dGUgY3JlYXRlTkZUKHN0cmluZyxzdHJpbmcpdWludDY0CgljYWxsc3ViIGNyZWF0ZU5GVAoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBjcmVhdGVORlQobmFtZTogc3RyaW5nLCB1bml0TmFtZTogc3RyaW5nKTogQXNzZXRJRApjcmVhdGVORlQ6Cglwcm90byAyIDEKCgkvLyBleGFtcGxlcy9pdHhucy9pdHhucy5hbGdvLnRzOjYKCS8vIHJldHVybiBzZW5kQXNzZXRDcmVhdGlvbih7CgkvLyAgICAgICBjb25maWdBc3NldE5hbWU6IG5hbWUsCgkvLyAgICAgICBjb25maWdBc3NldFVuaXROYW1lOiB1bml0TmFtZSwKCS8vICAgICAgIGNvbmZpZ0Fzc2V0VG90YWw6IDEsCgkvLyAgICAgfSk7CglpdHhuX2JlZ2luCglwdXNoaW50IDMgLy8gYWNmZwoJaXR4bl9maWVsZCBUeXBlRW51bQoKCS8vIGV4YW1wbGVzL2l0eG5zL2l0eG5zLmFsZ28udHM6NwoJLy8gY29uZmlnQXNzZXROYW1lOiBuYW1lCglmcmFtZV9kaWcgLTEgLy8gbmFtZTogc3RyaW5nCglpdHhuX2ZpZWxkIENvbmZpZ0Fzc2V0TmFtZQoKCS8vIGV4YW1wbGVzL2l0eG5zL2l0eG5zLmFsZ28udHM6OAoJLy8gY29uZmlnQXNzZXRVbml0TmFtZTogdW5pdE5hbWUKCWZyYW1lX2RpZyAtMiAvLyB1bml0TmFtZTogc3RyaW5nCglpdHhuX2ZpZWxkIENvbmZpZ0Fzc2V0VW5pdE5hbWUKCgkvLyBleGFtcGxlcy9pdHhucy9pdHhucy5hbGdvLnRzOjkKCS8vIGNvbmZpZ0Fzc2V0VG90YWw6IDEKCXB1c2hpbnQgMQoJaXR4bl9maWVsZCBDb25maWdBc3NldFRvdGFsCgoJLy8gRmVlIGZpZWxkIG5vdCBzZXQsIGRlZmF1bHRpbmcgdG8gMAoJcHVzaGludCAwCglpdHhuX2ZpZWxkIEZlZQoKCS8vIFN1Ym1pdCBpbm5lciB0cmFuc2FjdGlvbgoJaXR4bl9zdWJtaXQKCWl0eG4gQ3JlYXRlZEFzc2V0SUQKCXJldHN1YgoKLy8gdHJhbnNmZXJORlQodWludDY0LGFkZHJlc3Mpdm9pZAoqYWJpX3JvdXRlX3RyYW5zZmVyTkZUOgoJLy8gcmVjZWl2ZXI6IGFkZHJlc3MKCXR4bmEgQXBwbGljYXRpb25BcmdzIDIKCWR1cAoJbGVuCglwdXNoaW50IDMyCgk9PQoKCS8vIGFyZ3VtZW50IDAgKHJlY2VpdmVyKSBmb3IgdHJhbnNmZXJORlQgbXVzdCBiZSBhIGFkZHJlc3MKCWFzc2VydAoKCS8vIGFzc2V0OiB1aW50NjQKCXR4bmEgQXBwbGljYXRpb25BcmdzIDEKCWJ0b2kKCgkvLyBleGVjdXRlIHRyYW5zZmVyTkZUKHVpbnQ2NCxhZGRyZXNzKXZvaWQKCWNhbGxzdWIgdHJhbnNmZXJORlQKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyB0cmFuc2Zlck5GVChhc3NldDogQXNzZXRJRCwgcmVjZWl2ZXI6IEFkZHJlc3MpOiB2b2lkCnRyYW5zZmVyTkZUOgoJcHJvdG8gMiAwCgoJLy8gZXhhbXBsZXMvaXR4bnMvaXR4bnMuYWxnby50czoxNAoJLy8gc2VuZEFzc2V0VHJhbnNmZXIoewoJLy8gICAgICAgYXNzZXRSZWNlaXZlcjogcmVjZWl2ZXIsCgkvLyAgICAgICBhc3NldEFtb3VudDogMSwKCS8vICAgICAgIHhmZXJBc3NldDogYXNzZXQsCgkvLyAgICAgfSkKCWl0eG5fYmVnaW4KCXB1c2hpbnQgNCAvLyBheGZlcgoJaXR4bl9maWVsZCBUeXBlRW51bQoKCS8vIGV4YW1wbGVzL2l0eG5zL2l0eG5zLmFsZ28udHM6MTUKCS8vIGFzc2V0UmVjZWl2ZXI6IHJlY2VpdmVyCglmcmFtZV9kaWcgLTIgLy8gcmVjZWl2ZXI6IEFkZHJlc3MKCWl0eG5fZmllbGQgQXNzZXRSZWNlaXZlcgoKCS8vIGV4YW1wbGVzL2l0eG5zL2l0eG5zLmFsZ28udHM6MTYKCS8vIGFzc2V0QW1vdW50OiAxCglwdXNoaW50IDEKCWl0eG5fZmllbGQgQXNzZXRBbW91bnQKCgkvLyBleGFtcGxlcy9pdHhucy9pdHhucy5hbGdvLnRzOjE3CgkvLyB4ZmVyQXNzZXQ6IGFzc2V0CglmcmFtZV9kaWcgLTEgLy8gYXNzZXQ6IEFzc2V0SUQKCWl0eG5fZmllbGQgWGZlckFzc2V0CgoJLy8gRmVlIGZpZWxkIG5vdCBzZXQsIGRlZmF1bHRpbmcgdG8gMAoJcHVzaGludCAwCglpdHhuX2ZpZWxkIEZlZQoKCS8vIFN1Ym1pdCBpbm5lciB0cmFuc2FjdGlvbgoJaXR4bl9zdWJtaXQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZDIwMjRjNzMgLy8gbWV0aG9kICJjcmVhdGVORlQoc3RyaW5nLHN0cmluZyl1aW50NjQiCglwdXNoYnl0ZXMgMHhjN2UyNjBhZiAvLyBtZXRob2QgInRyYW5zZmVyTkZUKHVpbnQ2NCxhZGRyZXNzKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZU5GVCAqYWJpX3JvdXRlX3RyYW5zZmVyTkZUCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gY3JlYXRlTkZUKHN0cmluZyxzdHJpbmcpdWludDY0CiphYmlfcm91dGVfY3JlYXRlTkZUOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIHVuaXROYW1lOiBzdHJpbmcKCXR4bmEgQXBwbGljYXRpb25BcmdzIDIKCWV4dHJhY3QgMiAwCgoJLy8gbmFtZTogc3RyaW5nCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglleHRyYWN0IDIgMAoKCS8vIGV4ZWN1dGUgY3JlYXRlTkZUKHN0cmluZyxzdHJpbmcpdWludDY0CgljYWxsc3ViIGNyZWF0ZU5GVAoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBjcmVhdGVORlQobmFtZTogc3RyaW5nLCB1bml0TmFtZTogc3RyaW5nKTogQXNzZXRJRApjcmVhdGVORlQ6Cglwcm90byAyIDEKCgkvLyBleGFtcGxlcy9pdHhucy9pdHhucy5hbGdvLnRzOjYKCS8vIHJldHVybiBzZW5kQXNzZXRDcmVhdGlvbih7CgkvLyAgICAgICBjb25maWdBc3NldE5hbWU6IG5hbWUsCgkvLyAgICAgICBjb25maWdBc3NldFVuaXROYW1lOiB1bml0TmFtZSwKCS8vICAgICAgIGNvbmZpZ0Fzc2V0VG90YWw6IDEsCgkvLyAgICAgfSk7CglpdHhuX2JlZ2luCglwdXNoaW50IDMgLy8gYWNmZwoJaXR4bl9maWVsZCBUeXBlRW51bQoKCS8vIGV4YW1wbGVzL2l0eG5zL2l0eG5zLmFsZ28udHM6NwoJLy8gY29uZmlnQXNzZXROYW1lOiBuYW1lCglmcmFtZV9kaWcgLTEgLy8gbmFtZTogc3RyaW5nCglpdHhuX2ZpZWxkIENvbmZpZ0Fzc2V0TmFtZQoKCS8vIGV4YW1wbGVzL2l0eG5zL2l0eG5zLmFsZ28udHM6OAoJLy8gY29uZmlnQXNzZXRVbml0TmFtZTogdW5pdE5hbWUKCWZyYW1lX2RpZyAtMiAvLyB1bml0TmFtZTogc3RyaW5nCglpdHhuX2ZpZWxkIENvbmZpZ0Fzc2V0VW5pdE5hbWUKCgkvLyBleGFtcGxlcy9pdHhucy9pdHhucy5hbGdvLnRzOjkKCS8vIGNvbmZpZ0Fzc2V0VG90YWw6IDEKCXB1c2hpbnQgMQoJaXR4bl9maWVsZCBDb25maWdBc3NldFRvdGFsCgoJLy8gRmVlIGZpZWxkIG5vdCBzZXQsIGRlZmF1bHRpbmcgdG8gMAoJcHVzaGludCAwCglpdHhuX2ZpZWxkIEZlZQoKCS8vIFN1Ym1pdCBpbm5lciB0cmFuc2FjdGlvbgoJaXR4bl9zdWJtaXQKCWl0eG4gQ3JlYXRlZEFzc2V0SUQKCXJldHN1YgoKLy8gdHJhbnNmZXJORlQodWludDY0LGFkZHJlc3Mpdm9pZAoqYWJpX3JvdXRlX3RyYW5zZmVyTkZUOgoJLy8gcmVjZWl2ZXI6IGFkZHJlc3MKCXR4bmEgQXBwbGljYXRpb25BcmdzIDIKCWR1cAoJbGVuCglwdXNoaW50IDMyCgk9PQoKCS8vIGFyZ3VtZW50IDAgKHJlY2VpdmVyKSBmb3IgdHJhbnNmZXJORlQgbXVzdCBiZSBhIGFkZHJlc3MKCWFzc2VydAoKCS8vIGFzc2V0OiB1aW50NjQKCXR4bmEgQXBwbGljYXRpb25BcmdzIDEKCWJ0b2kKCgkvLyBleGVjdXRlIHRyYW5zZmVyTkZUKHVpbnQ2NCxhZGRyZXNzKXZvaWQKCWNhbGxzdWIgdHJhbnNmZXJORlQKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyB0cmFuc2Zlck5GVChhc3NldDogQXNzZXRJRCwgcmVjZWl2ZXI6IEFkZHJlc3MpOiB2b2lkCnRyYW5zZmVyTkZUOgoJcHJvdG8gMiAwCgoJLy8gZXhhbXBsZXMvaXR4bnMvaXR4bnMuYWxnby50czoxNAoJLy8gc2VuZEFzc2V0VHJhbnNmZXIoewoJLy8gICAgICAgYXNzZXRSZWNlaXZlcjogcmVjZWl2ZXIsCgkvLyAgICAgICBhc3NldEFtb3VudDogMSwKCS8vICAgICAgIHhmZXJBc3NldDogYXNzZXQsCgkvLyAgICAgfSkKCWl0eG5fYmVnaW4KCXB1c2hpbnQgNCAvLyBheGZlcgoJaXR4bl9maWVsZCBUeXBlRW51bQoKCS8vIGV4YW1wbGVzL2l0eG5zL2l0eG5zLmFsZ28udHM6MTUKCS8vIGFzc2V0UmVjZWl2ZXI6IHJlY2VpdmVyCglmcmFtZV9kaWcgLTIgLy8gcmVjZWl2ZXI6IEFkZHJlc3MKCWl0eG5fZmllbGQgQXNzZXRSZWNlaXZlcgoKCS8vIGV4YW1wbGVzL2l0eG5zL2l0eG5zLmFsZ28udHM6MTYKCS8vIGFzc2V0QW1vdW50OiAxCglwdXNoaW50IDEKCWl0eG5fZmllbGQgQXNzZXRBbW91bnQKCgkvLyBleGFtcGxlcy9pdHhucy9pdHhucy5hbGdvLnRzOjE3CgkvLyB4ZmVyQXNzZXQ6IGFzc2V0CglmcmFtZV9kaWcgLTEgLy8gYXNzZXQ6IEFzc2V0SUQKCWl0eG5fZmllbGQgWGZlckFzc2V0CgoJLy8gRmVlIGZpZWxkIG5vdCBzZXQsIGRlZmF1bHRpbmcgdG8gMAoJcHVzaGludCAwCglpdHhuX2ZpZWxkIEZlZQoKCS8vIFN1Ym1pdCBpbm5lciB0cmFuc2FjdGlvbgoJaXR4bl9zdWJtaXQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZDIwMjRjNzMgLy8gbWV0aG9kICJjcmVhdGVORlQoc3RyaW5nLHN0cmluZyl1aW50NjQiCglwdXNoYnl0ZXMgMHhjN2UyNjBhZiAvLyBtZXRob2QgInRyYW5zZmVyTkZUKHVpbnQ2NCxhZGRyZXNzKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZU5GVCAqYWJpX3JvdXRlX3RyYW5zZmVyTkZUCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/examples/itxns/artifacts/NFTFactory.arc56_draft.json b/examples/itxns/artifacts/NFTFactory.arc56_draft.json index 134e9ae2c..171c9a0d6 100644 --- a/examples/itxns/artifacts/NFTFactory.arc56_draft.json +++ b/examples/itxns/artifacts/NFTFactory.arc56_draft.json @@ -709,7 +709,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gY3JlYXRlTkZUKHN0cmluZyxzdHJpbmcpdWludDY0CiphYmlfcm91dGVfY3JlYXRlTkZUOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIHVuaXROYW1lOiBzdHJpbmcKCXR4bmEgQXBwbGljYXRpb25BcmdzIDIKCWV4dHJhY3QgMiAwCgoJLy8gbmFtZTogc3RyaW5nCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglleHRyYWN0IDIgMAoKCS8vIGV4ZWN1dGUgY3JlYXRlTkZUKHN0cmluZyxzdHJpbmcpdWludDY0CgljYWxsc3ViIGNyZWF0ZU5GVAoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBjcmVhdGVORlQobmFtZTogc3RyaW5nLCB1bml0TmFtZTogc3RyaW5nKTogQXNzZXRJRApjcmVhdGVORlQ6Cglwcm90byAyIDEKCgkvLyBleGFtcGxlcy9pdHhucy9pdHhucy5hbGdvLnRzOjYKCS8vIHJldHVybiBzZW5kQXNzZXRDcmVhdGlvbih7CgkvLyAgICAgICBjb25maWdBc3NldE5hbWU6IG5hbWUsCgkvLyAgICAgICBjb25maWdBc3NldFVuaXROYW1lOiB1bml0TmFtZSwKCS8vICAgICAgIGNvbmZpZ0Fzc2V0VG90YWw6IDEsCgkvLyAgICAgfSk7CglpdHhuX2JlZ2luCglwdXNoaW50IDMgLy8gYWNmZwoJaXR4bl9maWVsZCBUeXBlRW51bQoKCS8vIGV4YW1wbGVzL2l0eG5zL2l0eG5zLmFsZ28udHM6NwoJLy8gY29uZmlnQXNzZXROYW1lOiBuYW1lCglmcmFtZV9kaWcgLTEgLy8gbmFtZTogc3RyaW5nCglpdHhuX2ZpZWxkIENvbmZpZ0Fzc2V0TmFtZQoKCS8vIGV4YW1wbGVzL2l0eG5zL2l0eG5zLmFsZ28udHM6OAoJLy8gY29uZmlnQXNzZXRVbml0TmFtZTogdW5pdE5hbWUKCWZyYW1lX2RpZyAtMiAvLyB1bml0TmFtZTogc3RyaW5nCglpdHhuX2ZpZWxkIENvbmZpZ0Fzc2V0VW5pdE5hbWUKCgkvLyBleGFtcGxlcy9pdHhucy9pdHhucy5hbGdvLnRzOjkKCS8vIGNvbmZpZ0Fzc2V0VG90YWw6IDEKCXB1c2hpbnQgMQoJaXR4bl9maWVsZCBDb25maWdBc3NldFRvdGFsCgoJLy8gRmVlIGZpZWxkIG5vdCBzZXQsIGRlZmF1bHRpbmcgdG8gMAoJcHVzaGludCAwCglpdHhuX2ZpZWxkIEZlZQoKCS8vIFN1Ym1pdCBpbm5lciB0cmFuc2FjdGlvbgoJaXR4bl9zdWJtaXQKCWl0eG4gQ3JlYXRlZEFzc2V0SUQKCXJldHN1YgoKLy8gdHJhbnNmZXJORlQodWludDY0LGFkZHJlc3Mpdm9pZAoqYWJpX3JvdXRlX3RyYW5zZmVyTkZUOgoJLy8gcmVjZWl2ZXI6IGFkZHJlc3MKCXR4bmEgQXBwbGljYXRpb25BcmdzIDIKCWR1cAoJbGVuCglwdXNoaW50IDMyCgk9PQoKCS8vIGFyZ3VtZW50IDAgKHJlY2VpdmVyKSBmb3IgdHJhbnNmZXJORlQgbXVzdCBiZSBhIGFkZHJlc3MKCWFzc2VydAoKCS8vIGFzc2V0OiB1aW50NjQKCXR4bmEgQXBwbGljYXRpb25BcmdzIDEKCWJ0b2kKCgkvLyBleGVjdXRlIHRyYW5zZmVyTkZUKHVpbnQ2NCxhZGRyZXNzKXZvaWQKCWNhbGxzdWIgdHJhbnNmZXJORlQKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyB0cmFuc2Zlck5GVChhc3NldDogQXNzZXRJRCwgcmVjZWl2ZXI6IEFkZHJlc3MpOiB2b2lkCnRyYW5zZmVyTkZUOgoJcHJvdG8gMiAwCgoJLy8gZXhhbXBsZXMvaXR4bnMvaXR4bnMuYWxnby50czoxNAoJLy8gc2VuZEFzc2V0VHJhbnNmZXIoewoJLy8gICAgICAgYXNzZXRSZWNlaXZlcjogcmVjZWl2ZXIsCgkvLyAgICAgICBhc3NldEFtb3VudDogMSwKCS8vICAgICAgIHhmZXJBc3NldDogYXNzZXQsCgkvLyAgICAgfSkKCWl0eG5fYmVnaW4KCXB1c2hpbnQgNCAvLyBheGZlcgoJaXR4bl9maWVsZCBUeXBlRW51bQoKCS8vIGV4YW1wbGVzL2l0eG5zL2l0eG5zLmFsZ28udHM6MTUKCS8vIGFzc2V0UmVjZWl2ZXI6IHJlY2VpdmVyCglmcmFtZV9kaWcgLTIgLy8gcmVjZWl2ZXI6IEFkZHJlc3MKCWl0eG5fZmllbGQgQXNzZXRSZWNlaXZlcgoKCS8vIGV4YW1wbGVzL2l0eG5zL2l0eG5zLmFsZ28udHM6MTYKCS8vIGFzc2V0QW1vdW50OiAxCglwdXNoaW50IDEKCWl0eG5fZmllbGQgQXNzZXRBbW91bnQKCgkvLyBleGFtcGxlcy9pdHhucy9pdHhucy5hbGdvLnRzOjE3CgkvLyB4ZmVyQXNzZXQ6IGFzc2V0CglmcmFtZV9kaWcgLTEgLy8gYXNzZXQ6IEFzc2V0SUQKCWl0eG5fZmllbGQgWGZlckFzc2V0CgoJLy8gRmVlIGZpZWxkIG5vdCBzZXQsIGRlZmF1bHRpbmcgdG8gMAoJcHVzaGludCAwCglpdHhuX2ZpZWxkIEZlZQoKCS8vIFN1Ym1pdCBpbm5lciB0cmFuc2FjdGlvbgoJaXR4bl9zdWJtaXQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZDIwMjRjNzMgLy8gbWV0aG9kICJjcmVhdGVORlQoc3RyaW5nLHN0cmluZyl1aW50NjQiCglwdXNoYnl0ZXMgMHhjN2UyNjBhZiAvLyBtZXRob2QgInRyYW5zZmVyTkZUKHVpbnQ2NCxhZGRyZXNzKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZU5GVCAqYWJpX3JvdXRlX3RyYW5zZmVyTkZUCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gY3JlYXRlTkZUKHN0cmluZyxzdHJpbmcpdWludDY0CiphYmlfcm91dGVfY3JlYXRlTkZUOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIHVuaXROYW1lOiBzdHJpbmcKCXR4bmEgQXBwbGljYXRpb25BcmdzIDIKCWV4dHJhY3QgMiAwCgoJLy8gbmFtZTogc3RyaW5nCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglleHRyYWN0IDIgMAoKCS8vIGV4ZWN1dGUgY3JlYXRlTkZUKHN0cmluZyxzdHJpbmcpdWludDY0CgljYWxsc3ViIGNyZWF0ZU5GVAoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBjcmVhdGVORlQobmFtZTogc3RyaW5nLCB1bml0TmFtZTogc3RyaW5nKTogQXNzZXRJRApjcmVhdGVORlQ6Cglwcm90byAyIDEKCgkvLyBleGFtcGxlcy9pdHhucy9pdHhucy5hbGdvLnRzOjYKCS8vIHJldHVybiBzZW5kQXNzZXRDcmVhdGlvbih7CgkvLyAgICAgICBjb25maWdBc3NldE5hbWU6IG5hbWUsCgkvLyAgICAgICBjb25maWdBc3NldFVuaXROYW1lOiB1bml0TmFtZSwKCS8vICAgICAgIGNvbmZpZ0Fzc2V0VG90YWw6IDEsCgkvLyAgICAgfSk7CglpdHhuX2JlZ2luCglwdXNoaW50IDMgLy8gYWNmZwoJaXR4bl9maWVsZCBUeXBlRW51bQoKCS8vIGV4YW1wbGVzL2l0eG5zL2l0eG5zLmFsZ28udHM6NwoJLy8gY29uZmlnQXNzZXROYW1lOiBuYW1lCglmcmFtZV9kaWcgLTEgLy8gbmFtZTogc3RyaW5nCglpdHhuX2ZpZWxkIENvbmZpZ0Fzc2V0TmFtZQoKCS8vIGV4YW1wbGVzL2l0eG5zL2l0eG5zLmFsZ28udHM6OAoJLy8gY29uZmlnQXNzZXRVbml0TmFtZTogdW5pdE5hbWUKCWZyYW1lX2RpZyAtMiAvLyB1bml0TmFtZTogc3RyaW5nCglpdHhuX2ZpZWxkIENvbmZpZ0Fzc2V0VW5pdE5hbWUKCgkvLyBleGFtcGxlcy9pdHhucy9pdHhucy5hbGdvLnRzOjkKCS8vIGNvbmZpZ0Fzc2V0VG90YWw6IDEKCXB1c2hpbnQgMQoJaXR4bl9maWVsZCBDb25maWdBc3NldFRvdGFsCgoJLy8gRmVlIGZpZWxkIG5vdCBzZXQsIGRlZmF1bHRpbmcgdG8gMAoJcHVzaGludCAwCglpdHhuX2ZpZWxkIEZlZQoKCS8vIFN1Ym1pdCBpbm5lciB0cmFuc2FjdGlvbgoJaXR4bl9zdWJtaXQKCWl0eG4gQ3JlYXRlZEFzc2V0SUQKCXJldHN1YgoKLy8gdHJhbnNmZXJORlQodWludDY0LGFkZHJlc3Mpdm9pZAoqYWJpX3JvdXRlX3RyYW5zZmVyTkZUOgoJLy8gcmVjZWl2ZXI6IGFkZHJlc3MKCXR4bmEgQXBwbGljYXRpb25BcmdzIDIKCWR1cAoJbGVuCglwdXNoaW50IDMyCgk9PQoKCS8vIGFyZ3VtZW50IDAgKHJlY2VpdmVyKSBmb3IgdHJhbnNmZXJORlQgbXVzdCBiZSBhIGFkZHJlc3MKCWFzc2VydAoKCS8vIGFzc2V0OiB1aW50NjQKCXR4bmEgQXBwbGljYXRpb25BcmdzIDEKCWJ0b2kKCgkvLyBleGVjdXRlIHRyYW5zZmVyTkZUKHVpbnQ2NCxhZGRyZXNzKXZvaWQKCWNhbGxzdWIgdHJhbnNmZXJORlQKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyB0cmFuc2Zlck5GVChhc3NldDogQXNzZXRJRCwgcmVjZWl2ZXI6IEFkZHJlc3MpOiB2b2lkCnRyYW5zZmVyTkZUOgoJcHJvdG8gMiAwCgoJLy8gZXhhbXBsZXMvaXR4bnMvaXR4bnMuYWxnby50czoxNAoJLy8gc2VuZEFzc2V0VHJhbnNmZXIoewoJLy8gICAgICAgYXNzZXRSZWNlaXZlcjogcmVjZWl2ZXIsCgkvLyAgICAgICBhc3NldEFtb3VudDogMSwKCS8vICAgICAgIHhmZXJBc3NldDogYXNzZXQsCgkvLyAgICAgfSkKCWl0eG5fYmVnaW4KCXB1c2hpbnQgNCAvLyBheGZlcgoJaXR4bl9maWVsZCBUeXBlRW51bQoKCS8vIGV4YW1wbGVzL2l0eG5zL2l0eG5zLmFsZ28udHM6MTUKCS8vIGFzc2V0UmVjZWl2ZXI6IHJlY2VpdmVyCglmcmFtZV9kaWcgLTIgLy8gcmVjZWl2ZXI6IEFkZHJlc3MKCWl0eG5fZmllbGQgQXNzZXRSZWNlaXZlcgoKCS8vIGV4YW1wbGVzL2l0eG5zL2l0eG5zLmFsZ28udHM6MTYKCS8vIGFzc2V0QW1vdW50OiAxCglwdXNoaW50IDEKCWl0eG5fZmllbGQgQXNzZXRBbW91bnQKCgkvLyBleGFtcGxlcy9pdHhucy9pdHhucy5hbGdvLnRzOjE3CgkvLyB4ZmVyQXNzZXQ6IGFzc2V0CglmcmFtZV9kaWcgLTEgLy8gYXNzZXQ6IEFzc2V0SUQKCWl0eG5fZmllbGQgWGZlckFzc2V0CgoJLy8gRmVlIGZpZWxkIG5vdCBzZXQsIGRlZmF1bHRpbmcgdG8gMAoJcHVzaGludCAwCglpdHhuX2ZpZWxkIEZlZQoKCS8vIFN1Ym1pdCBpbm5lciB0cmFuc2FjdGlvbgoJaXR4bl9zdWJtaXQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZDIwMjRjNzMgLy8gbWV0aG9kICJjcmVhdGVORlQoc3RyaW5nLHN0cmluZyl1aW50NjQiCglwdXNoYnl0ZXMgMHhjN2UyNjBhZiAvLyBtZXRob2QgInRyYW5zZmVyTkZUKHVpbnQ2NCxhZGRyZXNzKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZU5GVCAqYWJpX3JvdXRlX3RyYW5zZmVyTkZUCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/examples/lsig_with_app/artifacts/CreatorVerifier.approval.teal b/examples/lsig_with_app/artifacts/CreatorVerifier.approval.teal index 601428c22..03e7d0b57 100644 --- a/examples/lsig_with_app/artifacts/CreatorVerifier.approval.teal +++ b/examples/lsig_with_app/artifacts/CreatorVerifier.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x00 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/examples/lsig_with_app/artifacts/CreatorVerifier.arc32.json b/examples/lsig_with_app/artifacts/CreatorVerifier.arc32.json index 8d2971868..c977d9f47 100644 --- a/examples/lsig_with_app/artifacts/CreatorVerifier.arc32.json +++ b/examples/lsig_with_app/artifacts/CreatorVerifier.arc32.json @@ -49,7 +49,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgwMAoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDQuMQovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIGFsbG93T3B0SW5zRnJvbShhZGRyZXNzKXZvaWQKKmFiaV9yb3V0ZV9hbGxvd09wdEluc0Zyb206CgkvLyBjcmVhdG9yOiBhZGRyZXNzCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglkdXAKCWxlbgoJcHVzaGludCAzMgoJPT0KCgkvLyBhcmd1bWVudCAwIChjcmVhdG9yKSBmb3IgYWxsb3dPcHRJbnNGcm9tIG11c3QgYmUgYSBhZGRyZXNzCglhc3NlcnQKCgkvLyBleGVjdXRlIGFsbG93T3B0SW5zRnJvbShhZGRyZXNzKXZvaWQKCWNhbGxzdWIgYWxsb3dPcHRJbnNGcm9tCglwdXNoaW50IDEKCXJldHVybgoKLy8gYWxsb3dPcHRJbnNGcm9tKGNyZWF0b3I6IEFkZHJlc3MpOiB2b2lkCi8vCi8vIEFsbG93IGFueW9uZSB0byB1c2UgdGhlIGxzaWcgdG8gb3B0IGluIHRoZSB0eG4gc2VuZGVyIGludG8gYW4gYXNzZXQgY3JlYXRlZCBieSB0aGUgY3JlYXRvcgphbGxvd09wdEluc0Zyb206Cglwcm90byAxIDAKCgkvLyBleGFtcGxlcy9sc2lnX3dpdGhfYXBwL2xzaWdfd2l0aF9hcHAuYWxnby50czo0MQoJLy8gdGhpcy5hbGxvd2VkQ3JlYXRvcnMoW3RoaXMudHhuLnNlbmRlciwgY3JlYXRvcl0pLnZhbHVlID0gdHJ1ZQoJdHhuIFNlbmRlcgoJZnJhbWVfZGlnIC0xIC8vIGNyZWF0b3I6IEFkZHJlc3MKCWNvbmNhdAoJcHVzaGludCAxCglieXRlIDB4MDAKCXB1c2hpbnQgMAoJdW5jb3ZlciAyCglzZXRiaXQKCWJveF9wdXQKCXJldHN1YgoKLy8gZGlzYWJsZU9wdEluc0Zyb20oYWRkcmVzcyl2b2lkCiphYmlfcm91dGVfZGlzYWJsZU9wdEluc0Zyb206CgkvLyBjcmVhdG9yOiBhZGRyZXNzCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglkdXAKCWxlbgoJcHVzaGludCAzMgoJPT0KCgkvLyBhcmd1bWVudCAwIChjcmVhdG9yKSBmb3IgZGlzYWJsZU9wdEluc0Zyb20gbXVzdCBiZSBhIGFkZHJlc3MKCWFzc2VydAoKCS8vIGV4ZWN1dGUgZGlzYWJsZU9wdEluc0Zyb20oYWRkcmVzcyl2b2lkCgljYWxsc3ViIGRpc2FibGVPcHRJbnNGcm9tCglwdXNoaW50IDEKCXJldHVybgoKLy8gZGlzYWJsZU9wdEluc0Zyb20oY3JlYXRvcjogQWRkcmVzcyk6IHZvaWQKLy8KLy8gRGlzYWJsZSBvcHQtaW5zIGZvciBBU0FzIGZyb20gdGhlIGdpdmVuIGNyZWF0b3IKZGlzYWJsZU9wdEluc0Zyb206Cglwcm90byAxIDAKCgkvLyBleGFtcGxlcy9sc2lnX3dpdGhfYXBwL2xzaWdfd2l0aF9hcHAuYWxnby50czo0NgoJLy8gdGhpcy5hbGxvd2VkQ3JlYXRvcnMoW3RoaXMudHhuLnNlbmRlciwgY3JlYXRvcl0pLnZhbHVlID0gZmFsc2UKCXR4biBTZW5kZXIKCWZyYW1lX2RpZyAtMSAvLyBjcmVhdG9yOiBBZGRyZXNzCgljb25jYXQKCXB1c2hpbnQgMAoJYnl0ZSAweDAwCglwdXNoaW50IDAKCXVuY292ZXIgMgoJc2V0Yml0Cglib3hfcHV0CglyZXRzdWIKCi8vIHZlcmlmeUNyZWF0b3IoYXhmZXIpdm9pZAoqYWJpX3JvdXRlX3ZlcmlmeUNyZWF0b3I6CgkvLyBvcHRJbjogYXhmZXIKCXR4biBHcm91cEluZGV4CglwdXNoaW50IDEKCS0KCWR1cAoJZ3R4bnMgVHlwZUVudW0KCXB1c2hpbnQgNCAvLyBheGZlcgoJPT0KCgkvLyBhcmd1bWVudCAwIChvcHRJbikgZm9yIHZlcmlmeUNyZWF0b3IgbXVzdCBiZSBhIGF4ZmVyIHRyYW5zYWN0aW9uCglhc3NlcnQKCgkvLyBleGVjdXRlIHZlcmlmeUNyZWF0b3IoYXhmZXIpdm9pZAoJY2FsbHN1YiB2ZXJpZnlDcmVhdG9yCglwdXNoaW50IDEKCXJldHVybgoKLy8gdmVyaWZ5Q3JlYXRvcihvcHRJbjogQXNzZXRUcmFuc2ZlclR4bik6IHZvaWQKdmVyaWZ5Q3JlYXRvcjoKCXByb3RvIDEgMAoKCS8vIGV4YW1wbGVzL2xzaWdfd2l0aF9hcHAvbHNpZ193aXRoX2FwcC5hbGdvLnRzOjUyCgkvLyBhc3NlcnQodGhpcy5hbGxvd2VkQ3JlYXRvcnMoW29wdEluLnNlbmRlciwgb3B0SW4ueGZlckFzc2V0LmNyZWF0b3JdKS52YWx1ZSkKCWZyYW1lX2RpZyAtMSAvLyBvcHRJbjogQXNzZXRUcmFuc2ZlclR4bgoJZ3R4bnMgU2VuZGVyCglmcmFtZV9kaWcgLTEgLy8gb3B0SW46IEFzc2V0VHJhbnNmZXJUeG4KCWd0eG5zIFhmZXJBc3NldAoJYXNzZXRfcGFyYW1zX2dldCBBc3NldENyZWF0b3IKCXBvcAoJY29uY2F0Cglib3hfZ2V0CgoJLy8gYm94IHZhbHVlIGRvZXMgbm90IGV4aXN0OiB0aGlzLmFsbG93ZWRDcmVhdG9ycyhbb3B0SW4uc2VuZGVyLCBvcHRJbi54ZmVyQXNzZXQuY3JlYXRvcl0pLnZhbHVlCglhc3NlcnQKCXB1c2hpbnQgMAoJZ2V0Yml0Cglhc3NlcnQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZjFiZjJjYTggLy8gbWV0aG9kICJhbGxvd09wdEluc0Zyb20oYWRkcmVzcyl2b2lkIgoJcHVzaGJ5dGVzIDB4YmMyOGFjMmIgLy8gbWV0aG9kICJkaXNhYmxlT3B0SW5zRnJvbShhZGRyZXNzKXZvaWQiCglwdXNoYnl0ZXMgMHg4ZDVhYTcyNyAvLyBtZXRob2QgInZlcmlmeUNyZWF0b3IoYXhmZXIpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfYWxsb3dPcHRJbnNGcm9tICphYmlfcm91dGVfZGlzYWJsZU9wdEluc0Zyb20gKmFiaV9yb3V0ZV92ZXJpZnlDcmVhdG9yCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgwMAoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDUuMAovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIGFsbG93T3B0SW5zRnJvbShhZGRyZXNzKXZvaWQKKmFiaV9yb3V0ZV9hbGxvd09wdEluc0Zyb206CgkvLyBjcmVhdG9yOiBhZGRyZXNzCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglkdXAKCWxlbgoJcHVzaGludCAzMgoJPT0KCgkvLyBhcmd1bWVudCAwIChjcmVhdG9yKSBmb3IgYWxsb3dPcHRJbnNGcm9tIG11c3QgYmUgYSBhZGRyZXNzCglhc3NlcnQKCgkvLyBleGVjdXRlIGFsbG93T3B0SW5zRnJvbShhZGRyZXNzKXZvaWQKCWNhbGxzdWIgYWxsb3dPcHRJbnNGcm9tCglwdXNoaW50IDEKCXJldHVybgoKLy8gYWxsb3dPcHRJbnNGcm9tKGNyZWF0b3I6IEFkZHJlc3MpOiB2b2lkCi8vCi8vIEFsbG93IGFueW9uZSB0byB1c2UgdGhlIGxzaWcgdG8gb3B0IGluIHRoZSB0eG4gc2VuZGVyIGludG8gYW4gYXNzZXQgY3JlYXRlZCBieSB0aGUgY3JlYXRvcgphbGxvd09wdEluc0Zyb206Cglwcm90byAxIDAKCgkvLyBleGFtcGxlcy9sc2lnX3dpdGhfYXBwL2xzaWdfd2l0aF9hcHAuYWxnby50czo0MQoJLy8gdGhpcy5hbGxvd2VkQ3JlYXRvcnMoW3RoaXMudHhuLnNlbmRlciwgY3JlYXRvcl0pLnZhbHVlID0gdHJ1ZQoJdHhuIFNlbmRlcgoJZnJhbWVfZGlnIC0xIC8vIGNyZWF0b3I6IEFkZHJlc3MKCWNvbmNhdAoJcHVzaGludCAxCglieXRlIDB4MDAKCXB1c2hpbnQgMAoJdW5jb3ZlciAyCglzZXRiaXQKCWJveF9wdXQKCXJldHN1YgoKLy8gZGlzYWJsZU9wdEluc0Zyb20oYWRkcmVzcyl2b2lkCiphYmlfcm91dGVfZGlzYWJsZU9wdEluc0Zyb206CgkvLyBjcmVhdG9yOiBhZGRyZXNzCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglkdXAKCWxlbgoJcHVzaGludCAzMgoJPT0KCgkvLyBhcmd1bWVudCAwIChjcmVhdG9yKSBmb3IgZGlzYWJsZU9wdEluc0Zyb20gbXVzdCBiZSBhIGFkZHJlc3MKCWFzc2VydAoKCS8vIGV4ZWN1dGUgZGlzYWJsZU9wdEluc0Zyb20oYWRkcmVzcyl2b2lkCgljYWxsc3ViIGRpc2FibGVPcHRJbnNGcm9tCglwdXNoaW50IDEKCXJldHVybgoKLy8gZGlzYWJsZU9wdEluc0Zyb20oY3JlYXRvcjogQWRkcmVzcyk6IHZvaWQKLy8KLy8gRGlzYWJsZSBvcHQtaW5zIGZvciBBU0FzIGZyb20gdGhlIGdpdmVuIGNyZWF0b3IKZGlzYWJsZU9wdEluc0Zyb206Cglwcm90byAxIDAKCgkvLyBleGFtcGxlcy9sc2lnX3dpdGhfYXBwL2xzaWdfd2l0aF9hcHAuYWxnby50czo0NgoJLy8gdGhpcy5hbGxvd2VkQ3JlYXRvcnMoW3RoaXMudHhuLnNlbmRlciwgY3JlYXRvcl0pLnZhbHVlID0gZmFsc2UKCXR4biBTZW5kZXIKCWZyYW1lX2RpZyAtMSAvLyBjcmVhdG9yOiBBZGRyZXNzCgljb25jYXQKCXB1c2hpbnQgMAoJYnl0ZSAweDAwCglwdXNoaW50IDAKCXVuY292ZXIgMgoJc2V0Yml0Cglib3hfcHV0CglyZXRzdWIKCi8vIHZlcmlmeUNyZWF0b3IoYXhmZXIpdm9pZAoqYWJpX3JvdXRlX3ZlcmlmeUNyZWF0b3I6CgkvLyBvcHRJbjogYXhmZXIKCXR4biBHcm91cEluZGV4CglwdXNoaW50IDEKCS0KCWR1cAoJZ3R4bnMgVHlwZUVudW0KCXB1c2hpbnQgNCAvLyBheGZlcgoJPT0KCgkvLyBhcmd1bWVudCAwIChvcHRJbikgZm9yIHZlcmlmeUNyZWF0b3IgbXVzdCBiZSBhIGF4ZmVyIHRyYW5zYWN0aW9uCglhc3NlcnQKCgkvLyBleGVjdXRlIHZlcmlmeUNyZWF0b3IoYXhmZXIpdm9pZAoJY2FsbHN1YiB2ZXJpZnlDcmVhdG9yCglwdXNoaW50IDEKCXJldHVybgoKLy8gdmVyaWZ5Q3JlYXRvcihvcHRJbjogQXNzZXRUcmFuc2ZlclR4bik6IHZvaWQKdmVyaWZ5Q3JlYXRvcjoKCXByb3RvIDEgMAoKCS8vIGV4YW1wbGVzL2xzaWdfd2l0aF9hcHAvbHNpZ193aXRoX2FwcC5hbGdvLnRzOjUyCgkvLyBhc3NlcnQodGhpcy5hbGxvd2VkQ3JlYXRvcnMoW29wdEluLnNlbmRlciwgb3B0SW4ueGZlckFzc2V0LmNyZWF0b3JdKS52YWx1ZSkKCWZyYW1lX2RpZyAtMSAvLyBvcHRJbjogQXNzZXRUcmFuc2ZlclR4bgoJZ3R4bnMgU2VuZGVyCglmcmFtZV9kaWcgLTEgLy8gb3B0SW46IEFzc2V0VHJhbnNmZXJUeG4KCWd0eG5zIFhmZXJBc3NldAoJYXNzZXRfcGFyYW1zX2dldCBBc3NldENyZWF0b3IKCXBvcAoJY29uY2F0Cglib3hfZ2V0CgoJLy8gYm94IHZhbHVlIGRvZXMgbm90IGV4aXN0OiB0aGlzLmFsbG93ZWRDcmVhdG9ycyhbb3B0SW4uc2VuZGVyLCBvcHRJbi54ZmVyQXNzZXQuY3JlYXRvcl0pLnZhbHVlCglhc3NlcnQKCXB1c2hpbnQgMAoJZ2V0Yml0Cglhc3NlcnQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZjFiZjJjYTggLy8gbWV0aG9kICJhbGxvd09wdEluc0Zyb20oYWRkcmVzcyl2b2lkIgoJcHVzaGJ5dGVzIDB4YmMyOGFjMmIgLy8gbWV0aG9kICJkaXNhYmxlT3B0SW5zRnJvbShhZGRyZXNzKXZvaWQiCglwdXNoYnl0ZXMgMHg4ZDVhYTcyNyAvLyBtZXRob2QgInZlcmlmeUNyZWF0b3IoYXhmZXIpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfYWxsb3dPcHRJbnNGcm9tICphYmlfcm91dGVfZGlzYWJsZU9wdEluc0Zyb20gKmFiaV9yb3V0ZV92ZXJpZnlDcmVhdG9yCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/examples/lsig_with_app/artifacts/CreatorVerifier.arc56_draft.json b/examples/lsig_with_app/artifacts/CreatorVerifier.arc56_draft.json index eb4c3f00f..64143d01d 100644 --- a/examples/lsig_with_app/artifacts/CreatorVerifier.arc56_draft.json +++ b/examples/lsig_with_app/artifacts/CreatorVerifier.arc56_draft.json @@ -847,7 +847,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgwMAoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDQuMQovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIGFsbG93T3B0SW5zRnJvbShhZGRyZXNzKXZvaWQKKmFiaV9yb3V0ZV9hbGxvd09wdEluc0Zyb206CgkvLyBjcmVhdG9yOiBhZGRyZXNzCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglkdXAKCWxlbgoJcHVzaGludCAzMgoJPT0KCgkvLyBhcmd1bWVudCAwIChjcmVhdG9yKSBmb3IgYWxsb3dPcHRJbnNGcm9tIG11c3QgYmUgYSBhZGRyZXNzCglhc3NlcnQKCgkvLyBleGVjdXRlIGFsbG93T3B0SW5zRnJvbShhZGRyZXNzKXZvaWQKCWNhbGxzdWIgYWxsb3dPcHRJbnNGcm9tCglwdXNoaW50IDEKCXJldHVybgoKLy8gYWxsb3dPcHRJbnNGcm9tKGNyZWF0b3I6IEFkZHJlc3MpOiB2b2lkCi8vCi8vIEFsbG93IGFueW9uZSB0byB1c2UgdGhlIGxzaWcgdG8gb3B0IGluIHRoZSB0eG4gc2VuZGVyIGludG8gYW4gYXNzZXQgY3JlYXRlZCBieSB0aGUgY3JlYXRvcgphbGxvd09wdEluc0Zyb206Cglwcm90byAxIDAKCgkvLyBleGFtcGxlcy9sc2lnX3dpdGhfYXBwL2xzaWdfd2l0aF9hcHAuYWxnby50czo0MQoJLy8gdGhpcy5hbGxvd2VkQ3JlYXRvcnMoW3RoaXMudHhuLnNlbmRlciwgY3JlYXRvcl0pLnZhbHVlID0gdHJ1ZQoJdHhuIFNlbmRlcgoJZnJhbWVfZGlnIC0xIC8vIGNyZWF0b3I6IEFkZHJlc3MKCWNvbmNhdAoJcHVzaGludCAxCglieXRlIDB4MDAKCXB1c2hpbnQgMAoJdW5jb3ZlciAyCglzZXRiaXQKCWJveF9wdXQKCXJldHN1YgoKLy8gZGlzYWJsZU9wdEluc0Zyb20oYWRkcmVzcyl2b2lkCiphYmlfcm91dGVfZGlzYWJsZU9wdEluc0Zyb206CgkvLyBjcmVhdG9yOiBhZGRyZXNzCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglkdXAKCWxlbgoJcHVzaGludCAzMgoJPT0KCgkvLyBhcmd1bWVudCAwIChjcmVhdG9yKSBmb3IgZGlzYWJsZU9wdEluc0Zyb20gbXVzdCBiZSBhIGFkZHJlc3MKCWFzc2VydAoKCS8vIGV4ZWN1dGUgZGlzYWJsZU9wdEluc0Zyb20oYWRkcmVzcyl2b2lkCgljYWxsc3ViIGRpc2FibGVPcHRJbnNGcm9tCglwdXNoaW50IDEKCXJldHVybgoKLy8gZGlzYWJsZU9wdEluc0Zyb20oY3JlYXRvcjogQWRkcmVzcyk6IHZvaWQKLy8KLy8gRGlzYWJsZSBvcHQtaW5zIGZvciBBU0FzIGZyb20gdGhlIGdpdmVuIGNyZWF0b3IKZGlzYWJsZU9wdEluc0Zyb206Cglwcm90byAxIDAKCgkvLyBleGFtcGxlcy9sc2lnX3dpdGhfYXBwL2xzaWdfd2l0aF9hcHAuYWxnby50czo0NgoJLy8gdGhpcy5hbGxvd2VkQ3JlYXRvcnMoW3RoaXMudHhuLnNlbmRlciwgY3JlYXRvcl0pLnZhbHVlID0gZmFsc2UKCXR4biBTZW5kZXIKCWZyYW1lX2RpZyAtMSAvLyBjcmVhdG9yOiBBZGRyZXNzCgljb25jYXQKCXB1c2hpbnQgMAoJYnl0ZSAweDAwCglwdXNoaW50IDAKCXVuY292ZXIgMgoJc2V0Yml0Cglib3hfcHV0CglyZXRzdWIKCi8vIHZlcmlmeUNyZWF0b3IoYXhmZXIpdm9pZAoqYWJpX3JvdXRlX3ZlcmlmeUNyZWF0b3I6CgkvLyBvcHRJbjogYXhmZXIKCXR4biBHcm91cEluZGV4CglwdXNoaW50IDEKCS0KCWR1cAoJZ3R4bnMgVHlwZUVudW0KCXB1c2hpbnQgNCAvLyBheGZlcgoJPT0KCgkvLyBhcmd1bWVudCAwIChvcHRJbikgZm9yIHZlcmlmeUNyZWF0b3IgbXVzdCBiZSBhIGF4ZmVyIHRyYW5zYWN0aW9uCglhc3NlcnQKCgkvLyBleGVjdXRlIHZlcmlmeUNyZWF0b3IoYXhmZXIpdm9pZAoJY2FsbHN1YiB2ZXJpZnlDcmVhdG9yCglwdXNoaW50IDEKCXJldHVybgoKLy8gdmVyaWZ5Q3JlYXRvcihvcHRJbjogQXNzZXRUcmFuc2ZlclR4bik6IHZvaWQKdmVyaWZ5Q3JlYXRvcjoKCXByb3RvIDEgMAoKCS8vIGV4YW1wbGVzL2xzaWdfd2l0aF9hcHAvbHNpZ193aXRoX2FwcC5hbGdvLnRzOjUyCgkvLyBhc3NlcnQodGhpcy5hbGxvd2VkQ3JlYXRvcnMoW29wdEluLnNlbmRlciwgb3B0SW4ueGZlckFzc2V0LmNyZWF0b3JdKS52YWx1ZSkKCWZyYW1lX2RpZyAtMSAvLyBvcHRJbjogQXNzZXRUcmFuc2ZlclR4bgoJZ3R4bnMgU2VuZGVyCglmcmFtZV9kaWcgLTEgLy8gb3B0SW46IEFzc2V0VHJhbnNmZXJUeG4KCWd0eG5zIFhmZXJBc3NldAoJYXNzZXRfcGFyYW1zX2dldCBBc3NldENyZWF0b3IKCXBvcAoJY29uY2F0Cglib3hfZ2V0CgoJLy8gYm94IHZhbHVlIGRvZXMgbm90IGV4aXN0OiB0aGlzLmFsbG93ZWRDcmVhdG9ycyhbb3B0SW4uc2VuZGVyLCBvcHRJbi54ZmVyQXNzZXQuY3JlYXRvcl0pLnZhbHVlCglhc3NlcnQKCXB1c2hpbnQgMAoJZ2V0Yml0Cglhc3NlcnQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZjFiZjJjYTggLy8gbWV0aG9kICJhbGxvd09wdEluc0Zyb20oYWRkcmVzcyl2b2lkIgoJcHVzaGJ5dGVzIDB4YmMyOGFjMmIgLy8gbWV0aG9kICJkaXNhYmxlT3B0SW5zRnJvbShhZGRyZXNzKXZvaWQiCglwdXNoYnl0ZXMgMHg4ZDVhYTcyNyAvLyBtZXRob2QgInZlcmlmeUNyZWF0b3IoYXhmZXIpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfYWxsb3dPcHRJbnNGcm9tICphYmlfcm91dGVfZGlzYWJsZU9wdEluc0Zyb20gKmFiaV9yb3V0ZV92ZXJpZnlDcmVhdG9yCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgwMAoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDUuMAovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIGFsbG93T3B0SW5zRnJvbShhZGRyZXNzKXZvaWQKKmFiaV9yb3V0ZV9hbGxvd09wdEluc0Zyb206CgkvLyBjcmVhdG9yOiBhZGRyZXNzCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglkdXAKCWxlbgoJcHVzaGludCAzMgoJPT0KCgkvLyBhcmd1bWVudCAwIChjcmVhdG9yKSBmb3IgYWxsb3dPcHRJbnNGcm9tIG11c3QgYmUgYSBhZGRyZXNzCglhc3NlcnQKCgkvLyBleGVjdXRlIGFsbG93T3B0SW5zRnJvbShhZGRyZXNzKXZvaWQKCWNhbGxzdWIgYWxsb3dPcHRJbnNGcm9tCglwdXNoaW50IDEKCXJldHVybgoKLy8gYWxsb3dPcHRJbnNGcm9tKGNyZWF0b3I6IEFkZHJlc3MpOiB2b2lkCi8vCi8vIEFsbG93IGFueW9uZSB0byB1c2UgdGhlIGxzaWcgdG8gb3B0IGluIHRoZSB0eG4gc2VuZGVyIGludG8gYW4gYXNzZXQgY3JlYXRlZCBieSB0aGUgY3JlYXRvcgphbGxvd09wdEluc0Zyb206Cglwcm90byAxIDAKCgkvLyBleGFtcGxlcy9sc2lnX3dpdGhfYXBwL2xzaWdfd2l0aF9hcHAuYWxnby50czo0MQoJLy8gdGhpcy5hbGxvd2VkQ3JlYXRvcnMoW3RoaXMudHhuLnNlbmRlciwgY3JlYXRvcl0pLnZhbHVlID0gdHJ1ZQoJdHhuIFNlbmRlcgoJZnJhbWVfZGlnIC0xIC8vIGNyZWF0b3I6IEFkZHJlc3MKCWNvbmNhdAoJcHVzaGludCAxCglieXRlIDB4MDAKCXB1c2hpbnQgMAoJdW5jb3ZlciAyCglzZXRiaXQKCWJveF9wdXQKCXJldHN1YgoKLy8gZGlzYWJsZU9wdEluc0Zyb20oYWRkcmVzcyl2b2lkCiphYmlfcm91dGVfZGlzYWJsZU9wdEluc0Zyb206CgkvLyBjcmVhdG9yOiBhZGRyZXNzCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglkdXAKCWxlbgoJcHVzaGludCAzMgoJPT0KCgkvLyBhcmd1bWVudCAwIChjcmVhdG9yKSBmb3IgZGlzYWJsZU9wdEluc0Zyb20gbXVzdCBiZSBhIGFkZHJlc3MKCWFzc2VydAoKCS8vIGV4ZWN1dGUgZGlzYWJsZU9wdEluc0Zyb20oYWRkcmVzcyl2b2lkCgljYWxsc3ViIGRpc2FibGVPcHRJbnNGcm9tCglwdXNoaW50IDEKCXJldHVybgoKLy8gZGlzYWJsZU9wdEluc0Zyb20oY3JlYXRvcjogQWRkcmVzcyk6IHZvaWQKLy8KLy8gRGlzYWJsZSBvcHQtaW5zIGZvciBBU0FzIGZyb20gdGhlIGdpdmVuIGNyZWF0b3IKZGlzYWJsZU9wdEluc0Zyb206Cglwcm90byAxIDAKCgkvLyBleGFtcGxlcy9sc2lnX3dpdGhfYXBwL2xzaWdfd2l0aF9hcHAuYWxnby50czo0NgoJLy8gdGhpcy5hbGxvd2VkQ3JlYXRvcnMoW3RoaXMudHhuLnNlbmRlciwgY3JlYXRvcl0pLnZhbHVlID0gZmFsc2UKCXR4biBTZW5kZXIKCWZyYW1lX2RpZyAtMSAvLyBjcmVhdG9yOiBBZGRyZXNzCgljb25jYXQKCXB1c2hpbnQgMAoJYnl0ZSAweDAwCglwdXNoaW50IDAKCXVuY292ZXIgMgoJc2V0Yml0Cglib3hfcHV0CglyZXRzdWIKCi8vIHZlcmlmeUNyZWF0b3IoYXhmZXIpdm9pZAoqYWJpX3JvdXRlX3ZlcmlmeUNyZWF0b3I6CgkvLyBvcHRJbjogYXhmZXIKCXR4biBHcm91cEluZGV4CglwdXNoaW50IDEKCS0KCWR1cAoJZ3R4bnMgVHlwZUVudW0KCXB1c2hpbnQgNCAvLyBheGZlcgoJPT0KCgkvLyBhcmd1bWVudCAwIChvcHRJbikgZm9yIHZlcmlmeUNyZWF0b3IgbXVzdCBiZSBhIGF4ZmVyIHRyYW5zYWN0aW9uCglhc3NlcnQKCgkvLyBleGVjdXRlIHZlcmlmeUNyZWF0b3IoYXhmZXIpdm9pZAoJY2FsbHN1YiB2ZXJpZnlDcmVhdG9yCglwdXNoaW50IDEKCXJldHVybgoKLy8gdmVyaWZ5Q3JlYXRvcihvcHRJbjogQXNzZXRUcmFuc2ZlclR4bik6IHZvaWQKdmVyaWZ5Q3JlYXRvcjoKCXByb3RvIDEgMAoKCS8vIGV4YW1wbGVzL2xzaWdfd2l0aF9hcHAvbHNpZ193aXRoX2FwcC5hbGdvLnRzOjUyCgkvLyBhc3NlcnQodGhpcy5hbGxvd2VkQ3JlYXRvcnMoW29wdEluLnNlbmRlciwgb3B0SW4ueGZlckFzc2V0LmNyZWF0b3JdKS52YWx1ZSkKCWZyYW1lX2RpZyAtMSAvLyBvcHRJbjogQXNzZXRUcmFuc2ZlclR4bgoJZ3R4bnMgU2VuZGVyCglmcmFtZV9kaWcgLTEgLy8gb3B0SW46IEFzc2V0VHJhbnNmZXJUeG4KCWd0eG5zIFhmZXJBc3NldAoJYXNzZXRfcGFyYW1zX2dldCBBc3NldENyZWF0b3IKCXBvcAoJY29uY2F0Cglib3hfZ2V0CgoJLy8gYm94IHZhbHVlIGRvZXMgbm90IGV4aXN0OiB0aGlzLmFsbG93ZWRDcmVhdG9ycyhbb3B0SW4uc2VuZGVyLCBvcHRJbi54ZmVyQXNzZXQuY3JlYXRvcl0pLnZhbHVlCglhc3NlcnQKCXB1c2hpbnQgMAoJZ2V0Yml0Cglhc3NlcnQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZjFiZjJjYTggLy8gbWV0aG9kICJhbGxvd09wdEluc0Zyb20oYWRkcmVzcyl2b2lkIgoJcHVzaGJ5dGVzIDB4YmMyOGFjMmIgLy8gbWV0aG9kICJkaXNhYmxlT3B0SW5zRnJvbShhZGRyZXNzKXZvaWQiCglwdXNoYnl0ZXMgMHg4ZDVhYTcyNyAvLyBtZXRob2QgInZlcmlmeUNyZWF0b3IoYXhmZXIpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfYWxsb3dPcHRJbnNGcm9tICphYmlfcm91dGVfZGlzYWJsZU9wdEluc0Zyb20gKmFiaV9yb3V0ZV92ZXJpZnlDcmVhdG9yCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/examples/lsig_with_app/artifacts/OptInLsig.lsig.teal b/examples/lsig_with_app/artifacts/OptInLsig.lsig.teal index eed1e6318..61f568d30 100644 --- a/examples/lsig_with_app/artifacts/OptInLsig.lsig.teal +++ b/examples/lsig_with_app/artifacts/OptInLsig.lsig.teal @@ -2,7 +2,7 @@ //#pragma mode logicsig intcblock TMPL_APP_ID -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript diff --git a/examples/merkle/artifacts/MerkleTree.approval.teal b/examples/merkle/artifacts/MerkleTree.approval.teal index bc4909bcf..0bc6fa08a 100644 --- a/examples/merkle/artifacts/MerkleTree.approval.teal +++ b/examples/merkle/artifacts/MerkleTree.approval.teal @@ -2,7 +2,7 @@ intcblock 1 bytecblock 0xe3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b8550000000000000000000000000000000000000000000000000000000000000000 0x0000000000000000000000000000000000000000000000000000000000000000 0x726f6f74 0x 0x73697a65 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/examples/merkle/artifacts/MerkleTree.arc32.json b/examples/merkle/artifacts/MerkleTree.arc32.json index b00816b35..9d1c73f50 100644 --- a/examples/merkle/artifacts/MerkleTree.arc32.json +++ b/examples/merkle/artifacts/MerkleTree.arc32.json @@ -63,7 +63,7 @@ } }, "source": { - "approval": "#pragma version 10
intcblock 1
bytecblock 0xe3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b8550000000000000000000000000000000000000000000000000000000000000000 0x0000000000000000000000000000000000000000000000000000000000000000 0x726f6f74 0x 0x73697a65

// This TEAL was generated by TEALScript v0.104.1
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *call_DeleteApplication *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// calcInitRoot(): bytes32
calcInitRoot:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// examples/merkle/merkle.algo.ts:17
	// result = hex(EMPTY_HASH) as bytes32
	byte 0xe3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b8550000000000000000000000000000000000000000000000000000000000000000
	byte 0x
	dup
	b==
	assert
	extract 0 32
	frame_bury 0 // result: byte[32]

	// examples/merkle/merkle.algo.ts:19
	// for (let i = 0; i < TREE_DEPTH; i = i + 1)
	pushint 0
	frame_bury 1 // i: uint64

*for_0:
	// examples/merkle/merkle.algo.ts:19
	// i < TREE_DEPTH
	frame_dig 1 // i: uint64
	pushint 3
	<
	bz *for_0_end

	// examples/merkle/merkle.algo.ts:20
	// result = sha256(result + result)
	frame_dig 0 // result: byte[32]
	frame_dig 0 // result: byte[32]
	concat
	sha256
	frame_bury 0 // result: byte[32]

*for_0_continue:
	// examples/merkle/merkle.algo.ts:19
	// i = i + 1
	frame_dig 1 // i: uint64
	int 1
	+
	frame_bury 1 // i: uint64
	b *for_0

*for_0_end:
	// examples/merkle/merkle.algo.ts:23
	// return result;
	frame_dig 0 // result: byte[32]

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 1
	retsub

// hashConcat(left: bytes32, right: bytes32): bytes32
hashConcat:
	proto 2 1

	// examples/merkle/merkle.algo.ts:27
	// return sha256(left + right);
	frame_dig -1 // left: bytes32
	frame_dig -2 // right: bytes32
	concat
	sha256
	retsub

// isRightSibling(elem: Branch): boolean
isRightSibling:
	proto 1 1

	// examples/merkle/merkle.algo.ts:31
	// return getbyte(elem, 0) === RIGHT_SIBLING_PREFIX;
	frame_dig -1 // elem: Branch
	pushint 0
	getbyte
	pushint 170
	==
	retsub

// calcRoot(leaf: bytes32, path: Path): bytes32
calcRoot:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// examples/merkle/merkle.algo.ts:37
	// for (let i = 0; i < TREE_DEPTH; i = i + 1)
	pushint 0
	frame_bury 0 // i: uint64

*for_1:
	// examples/merkle/merkle.algo.ts:37
	// i < TREE_DEPTH
	frame_dig 0 // i: uint64
	pushint 3
	<
	bz *for_1_end
	frame_dig 0 // i: uint64
	frame_bury 1 // accessor: accessor//0//elem

	// *if0_condition
	// examples/merkle/merkle.algo.ts:40
	// this.isRightSibling(elem)
	frame_dig -2 // path: Path
	frame_dig 1 // saved accessor: accessor//0//elem
	pushint 33
	* // acc * typeLength
	pushint 33
	extract3
	callsub isRightSibling
	bz *if0_else

	// *if0_consequent
	// examples/merkle/merkle.algo.ts:41
	// result = this.hashConcat(result, extract3(elem, 1, 32) as bytes32)
	frame_dig -2 // path: Path
	frame_dig 1 // saved accessor: accessor//0//elem
	pushint 33
	* // acc * typeLength
	pushint 33
	extract3
	extract 1 32
	byte 0x0000000000000000000000000000000000000000000000000000000000000000
	concat
	dup
	extract 32 0
	byte 0x
	b==
	assert
	extract 0 32
	frame_dig -1 // leaf: bytes32
	callsub hashConcat
	frame_bury -1 // result: bytes32
	b *if0_end

*if0_else:
	// examples/merkle/merkle.algo.ts:43
	// result = this.hashConcat(extract3(elem, 1, 32) as bytes32, result)
	frame_dig -1 // leaf: bytes32
	frame_dig -2 // path: Path
	frame_dig 1 // saved accessor: accessor//0//elem
	pushint 33
	* // acc * typeLength
	pushint 33
	extract3
	extract 1 32
	byte 0x0000000000000000000000000000000000000000000000000000000000000000
	concat
	dup
	extract 32 0
	byte 0x
	b==
	assert
	extract 0 32
	callsub hashConcat
	frame_bury -1 // result: bytes32

*if0_end:

*for_1_continue:
	// examples/merkle/merkle.algo.ts:37
	// i = i + 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64
	b *for_1

*for_1_end:
	// examples/merkle/merkle.algo.ts:47
	// return result;
	frame_dig -1 // leaf: bytes32

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 1
	retsub

// deleteApplication()void
*abi_route_deleteApplication:
	// execute deleteApplication()void
	callsub deleteApplication
	int 1
	return

// deleteApplication(): void
deleteApplication:
	proto 0 0

	// examples/merkle/merkle.algo.ts:51
	// verifyAppCallTxn(this.txn, { sender: this.app.creator })
	// verify sender
	txn Sender
	txna Applications 0
	app_params_get AppCreator
	pop
	==

	// transaction verification failed: {"txn":"this.txn","field":"sender","expected":"this.app.creator"}
	assert
	retsub

// createApplication()void
*abi_route_createApplication:
	// execute createApplication()void
	callsub createApplication
	int 1
	return

// createApplication(): void
createApplication:
	proto 0 0

	// examples/merkle/merkle.algo.ts:55
	// this.root.value = this.calcInitRoot()
	byte 0x726f6f74 // "root"
	callsub calcInitRoot
	app_global_put
	retsub

// verify(byte[],byte[33][3])void
*abi_route_verify:
	// path: byte[33][3]
	txna ApplicationArgs 2
	dup
	len
	pushint 99
	==

	// argument 0 (path) for verify must be a byte[33][3]
	assert

	// data: byte[]
	txna ApplicationArgs 1
	extract 2 0

	// execute verify(byte[],byte[33][3])void
	callsub verify
	int 1
	return

// verify(data: bytes, path: Path): void
verify:
	proto 2 0

	// examples/merkle/merkle.algo.ts:59
	// assert(this.root.value === this.calcRoot(sha256(data), path))
	byte 0x726f6f74 // "root"
	app_global_get
	frame_dig -2 // path: Path
	frame_dig -1 // data: bytes
	sha256
	callsub calcRoot
	==
	assert
	retsub

// appendLeaf(byte[],byte[33][3])void
*abi_route_appendLeaf:
	// path: byte[33][3]
	txna ApplicationArgs 2
	dup
	len
	pushint 99
	==

	// argument 0 (path) for appendLeaf must be a byte[33][3]
	assert

	// data: byte[]
	txna ApplicationArgs 1
	extract 2 0

	// execute appendLeaf(byte[],byte[33][3])void
	callsub appendLeaf
	int 1
	return

// appendLeaf(data: bytes, path: Path): void
appendLeaf:
	proto 2 0

	// examples/merkle/merkle.algo.ts:63
	// assert(data !== '')
	frame_dig -1 // data: bytes
	byte 0x // ""
	!=
	assert

	// examples/merkle/merkle.algo.ts:64
	// assert(this.root.value === this.calcRoot(hex(EMPTY_HASH) as bytes32, path))
	byte 0x726f6f74 // "root"
	app_global_get
	frame_dig -2 // path: Path
	byte 0xe3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b8550000000000000000000000000000000000000000000000000000000000000000
	byte 0x
	dup
	b==
	assert
	extract 0 32
	callsub calcRoot
	==
	assert

	// examples/merkle/merkle.algo.ts:66
	// this.root.value = this.calcRoot(sha256(data), path)
	byte 0x726f6f74 // "root"
	frame_dig -2 // path: Path
	frame_dig -1 // data: bytes
	sha256
	callsub calcRoot
	app_global_put

	// examples/merkle/merkle.algo.ts:68
	// this.size.value = this.size.value + 1
	byte 0x73697a65 // "size"
	dup
	app_global_get
	int 1
	+
	app_global_put
	retsub

// updateLeaf(byte[],byte[],byte[33][3])void
*abi_route_updateLeaf:
	// path: byte[33][3]
	txna ApplicationArgs 3
	dup
	len
	pushint 99
	==

	// argument 0 (path) for updateLeaf must be a byte[33][3]
	assert

	// newData: byte[]
	txna ApplicationArgs 2
	extract 2 0

	// oldData: byte[]
	txna ApplicationArgs 1
	extract 2 0

	// execute updateLeaf(byte[],byte[],byte[33][3])void
	callsub updateLeaf
	int 1
	return

// updateLeaf(oldData: bytes, newData: bytes, path: Path): void
updateLeaf:
	proto 3 0

	// examples/merkle/merkle.algo.ts:72
	// assert(newData !== '')
	frame_dig -2 // newData: bytes
	byte 0x // ""
	!=
	assert

	// examples/merkle/merkle.algo.ts:73
	// assert(this.root.value === this.calcRoot(sha256(oldData), path))
	byte 0x726f6f74 // "root"
	app_global_get
	frame_dig -3 // path: Path
	frame_dig -1 // oldData: bytes
	sha256
	callsub calcRoot
	==
	assert

	// examples/merkle/merkle.algo.ts:75
	// this.root.value = this.calcRoot(sha256(newData), path)
	byte 0x726f6f74 // "root"
	frame_dig -3 // path: Path
	frame_dig -2 // newData: bytes
	sha256
	callsub calcRoot
	app_global_put
	retsub

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x506cb8d8 // method "verify(byte[],byte[33][3])void"
	pushbytes 0x04f63238 // method "appendLeaf(byte[],byte[33][3])void"
	pushbytes 0x255d93e3 // method "updateLeaf(byte[],byte[],byte[33][3])void"
	txna ApplicationArgs 0
	match *abi_route_verify *abi_route_appendLeaf *abi_route_updateLeaf

	// this contract does not implement the given ABI method for call NoOp
	err

*call_DeleteApplication:
	pushbytes 0x2487c32c // method "deleteApplication()void"
	txna ApplicationArgs 0
	match *abi_route_deleteApplication

	// this contract does not implement the given ABI method for call DeleteApplication
	err", + "approval": "#pragma version 10
intcblock 1
bytecblock 0xe3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b8550000000000000000000000000000000000000000000000000000000000000000 0x0000000000000000000000000000000000000000000000000000000000000000 0x726f6f74 0x 0x73697a65

// This TEAL was generated by TEALScript v0.105.0
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *call_DeleteApplication *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// calcInitRoot(): bytes32
calcInitRoot:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// examples/merkle/merkle.algo.ts:17
	// result = hex(EMPTY_HASH) as bytes32
	byte 0xe3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b8550000000000000000000000000000000000000000000000000000000000000000
	byte 0x
	dup
	b==
	assert
	extract 0 32
	frame_bury 0 // result: byte[32]

	// examples/merkle/merkle.algo.ts:19
	// for (let i = 0; i < TREE_DEPTH; i = i + 1)
	pushint 0
	frame_bury 1 // i: uint64

*for_0:
	// examples/merkle/merkle.algo.ts:19
	// i < TREE_DEPTH
	frame_dig 1 // i: uint64
	pushint 3
	<
	bz *for_0_end

	// examples/merkle/merkle.algo.ts:20
	// result = sha256(result + result)
	frame_dig 0 // result: byte[32]
	frame_dig 0 // result: byte[32]
	concat
	sha256
	frame_bury 0 // result: byte[32]

*for_0_continue:
	// examples/merkle/merkle.algo.ts:19
	// i = i + 1
	frame_dig 1 // i: uint64
	int 1
	+
	frame_bury 1 // i: uint64
	b *for_0

*for_0_end:
	// examples/merkle/merkle.algo.ts:23
	// return result;
	frame_dig 0 // result: byte[32]

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 1
	retsub

// hashConcat(left: bytes32, right: bytes32): bytes32
hashConcat:
	proto 2 1

	// examples/merkle/merkle.algo.ts:27
	// return sha256(left + right);
	frame_dig -1 // left: bytes32
	frame_dig -2 // right: bytes32
	concat
	sha256
	retsub

// isRightSibling(elem: Branch): boolean
isRightSibling:
	proto 1 1

	// examples/merkle/merkle.algo.ts:31
	// return getbyte(elem, 0) === RIGHT_SIBLING_PREFIX;
	frame_dig -1 // elem: Branch
	pushint 0
	getbyte
	pushint 170
	==
	retsub

// calcRoot(leaf: bytes32, path: Path): bytes32
calcRoot:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// examples/merkle/merkle.algo.ts:37
	// for (let i = 0; i < TREE_DEPTH; i = i + 1)
	pushint 0
	frame_bury 0 // i: uint64

*for_1:
	// examples/merkle/merkle.algo.ts:37
	// i < TREE_DEPTH
	frame_dig 0 // i: uint64
	pushint 3
	<
	bz *for_1_end
	frame_dig 0 // i: uint64
	frame_bury 1 // accessor: accessor//0//elem

	// *if0_condition
	// examples/merkle/merkle.algo.ts:40
	// this.isRightSibling(elem)
	frame_dig -2 // path: Path
	frame_dig 1 // saved accessor: accessor//0//elem
	pushint 33
	* // acc * typeLength
	pushint 33
	extract3
	callsub isRightSibling
	bz *if0_else

	// *if0_consequent
	// examples/merkle/merkle.algo.ts:41
	// result = this.hashConcat(result, extract3(elem, 1, 32) as bytes32)
	frame_dig -2 // path: Path
	frame_dig 1 // saved accessor: accessor//0//elem
	pushint 33
	* // acc * typeLength
	pushint 33
	extract3
	extract 1 32
	byte 0x0000000000000000000000000000000000000000000000000000000000000000
	concat
	dup
	extract 32 0
	byte 0x
	b==
	assert
	extract 0 32
	frame_dig -1 // leaf: bytes32
	callsub hashConcat
	frame_bury -1 // result: bytes32
	b *if0_end

*if0_else:
	// examples/merkle/merkle.algo.ts:43
	// result = this.hashConcat(extract3(elem, 1, 32) as bytes32, result)
	frame_dig -1 // leaf: bytes32
	frame_dig -2 // path: Path
	frame_dig 1 // saved accessor: accessor//0//elem
	pushint 33
	* // acc * typeLength
	pushint 33
	extract3
	extract 1 32
	byte 0x0000000000000000000000000000000000000000000000000000000000000000
	concat
	dup
	extract 32 0
	byte 0x
	b==
	assert
	extract 0 32
	callsub hashConcat
	frame_bury -1 // result: bytes32

*if0_end:

*for_1_continue:
	// examples/merkle/merkle.algo.ts:37
	// i = i + 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64
	b *for_1

*for_1_end:
	// examples/merkle/merkle.algo.ts:47
	// return result;
	frame_dig -1 // leaf: bytes32

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 1
	retsub

// deleteApplication()void
*abi_route_deleteApplication:
	// execute deleteApplication()void
	callsub deleteApplication
	int 1
	return

// deleteApplication(): void
deleteApplication:
	proto 0 0

	// examples/merkle/merkle.algo.ts:51
	// verifyAppCallTxn(this.txn, { sender: this.app.creator })
	// verify sender
	txn Sender
	txna Applications 0
	app_params_get AppCreator
	pop
	==

	// transaction verification failed: {"txn":"this.txn","field":"sender","expected":"this.app.creator"}
	assert
	retsub

// createApplication()void
*abi_route_createApplication:
	// execute createApplication()void
	callsub createApplication
	int 1
	return

// createApplication(): void
createApplication:
	proto 0 0

	// examples/merkle/merkle.algo.ts:55
	// this.root.value = this.calcInitRoot()
	byte 0x726f6f74 // "root"
	callsub calcInitRoot
	app_global_put
	retsub

// verify(byte[],byte[33][3])void
*abi_route_verify:
	// path: byte[33][3]
	txna ApplicationArgs 2
	dup
	len
	pushint 99
	==

	// argument 0 (path) for verify must be a byte[33][3]
	assert

	// data: byte[]
	txna ApplicationArgs 1
	extract 2 0

	// execute verify(byte[],byte[33][3])void
	callsub verify
	int 1
	return

// verify(data: bytes, path: Path): void
verify:
	proto 2 0

	// examples/merkle/merkle.algo.ts:59
	// assert(this.root.value === this.calcRoot(sha256(data), path))
	byte 0x726f6f74 // "root"
	app_global_get
	frame_dig -2 // path: Path
	frame_dig -1 // data: bytes
	sha256
	callsub calcRoot
	==
	assert
	retsub

// appendLeaf(byte[],byte[33][3])void
*abi_route_appendLeaf:
	// path: byte[33][3]
	txna ApplicationArgs 2
	dup
	len
	pushint 99
	==

	// argument 0 (path) for appendLeaf must be a byte[33][3]
	assert

	// data: byte[]
	txna ApplicationArgs 1
	extract 2 0

	// execute appendLeaf(byte[],byte[33][3])void
	callsub appendLeaf
	int 1
	return

// appendLeaf(data: bytes, path: Path): void
appendLeaf:
	proto 2 0

	// examples/merkle/merkle.algo.ts:63
	// assert(data !== '')
	frame_dig -1 // data: bytes
	byte 0x // ""
	!=
	assert

	// examples/merkle/merkle.algo.ts:64
	// assert(this.root.value === this.calcRoot(hex(EMPTY_HASH) as bytes32, path))
	byte 0x726f6f74 // "root"
	app_global_get
	frame_dig -2 // path: Path
	byte 0xe3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b8550000000000000000000000000000000000000000000000000000000000000000
	byte 0x
	dup
	b==
	assert
	extract 0 32
	callsub calcRoot
	==
	assert

	// examples/merkle/merkle.algo.ts:66
	// this.root.value = this.calcRoot(sha256(data), path)
	byte 0x726f6f74 // "root"
	frame_dig -2 // path: Path
	frame_dig -1 // data: bytes
	sha256
	callsub calcRoot
	app_global_put

	// examples/merkle/merkle.algo.ts:68
	// this.size.value = this.size.value + 1
	byte 0x73697a65 // "size"
	dup
	app_global_get
	int 1
	+
	app_global_put
	retsub

// updateLeaf(byte[],byte[],byte[33][3])void
*abi_route_updateLeaf:
	// path: byte[33][3]
	txna ApplicationArgs 3
	dup
	len
	pushint 99
	==

	// argument 0 (path) for updateLeaf must be a byte[33][3]
	assert

	// newData: byte[]
	txna ApplicationArgs 2
	extract 2 0

	// oldData: byte[]
	txna ApplicationArgs 1
	extract 2 0

	// execute updateLeaf(byte[],byte[],byte[33][3])void
	callsub updateLeaf
	int 1
	return

// updateLeaf(oldData: bytes, newData: bytes, path: Path): void
updateLeaf:
	proto 3 0

	// examples/merkle/merkle.algo.ts:72
	// assert(newData !== '')
	frame_dig -2 // newData: bytes
	byte 0x // ""
	!=
	assert

	// examples/merkle/merkle.algo.ts:73
	// assert(this.root.value === this.calcRoot(sha256(oldData), path))
	byte 0x726f6f74 // "root"
	app_global_get
	frame_dig -3 // path: Path
	frame_dig -1 // oldData: bytes
	sha256
	callsub calcRoot
	==
	assert

	// examples/merkle/merkle.algo.ts:75
	// this.root.value = this.calcRoot(sha256(newData), path)
	byte 0x726f6f74 // "root"
	frame_dig -3 // path: Path
	frame_dig -2 // newData: bytes
	sha256
	callsub calcRoot
	app_global_put
	retsub

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x506cb8d8 // method "verify(byte[],byte[33][3])void"
	pushbytes 0x04f63238 // method "appendLeaf(byte[],byte[33][3])void"
	pushbytes 0x255d93e3 // method "updateLeaf(byte[],byte[],byte[33][3])void"
	txna ApplicationArgs 0
	match *abi_route_verify *abi_route_appendLeaf *abi_route_updateLeaf

	// this contract does not implement the given ABI method for call NoOp
	err

*call_DeleteApplication:
	pushbytes 0x2487c32c // method "deleteApplication()void"
	txna ApplicationArgs 0
	match *abi_route_deleteApplication

	// this contract does not implement the given ABI method for call DeleteApplication
	err", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/examples/merkle/artifacts/MerkleTree.arc56_draft.json b/examples/merkle/artifacts/MerkleTree.arc56_draft.json index 952eec777..8619d9ca4 100644 --- a/examples/merkle/artifacts/MerkleTree.arc56_draft.json +++ b/examples/merkle/artifacts/MerkleTree.arc56_draft.json @@ -2481,7 +2481,7 @@ } }, "source": { - "approval": "#pragma version 10
intcblock 1
bytecblock 0xe3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b8550000000000000000000000000000000000000000000000000000000000000000 0x0000000000000000000000000000000000000000000000000000000000000000 0x726f6f74 0x 0x73697a65

// This TEAL was generated by TEALScript v0.104.1
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *call_DeleteApplication *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// calcInitRoot(): bytes32
calcInitRoot:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// examples/merkle/merkle.algo.ts:17
	// result = hex(EMPTY_HASH) as bytes32
	byte 0xe3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b8550000000000000000000000000000000000000000000000000000000000000000
	byte 0x
	dup
	b==
	assert
	extract 0 32
	frame_bury 0 // result: byte[32]

	// examples/merkle/merkle.algo.ts:19
	// for (let i = 0; i < TREE_DEPTH; i = i + 1)
	pushint 0
	frame_bury 1 // i: uint64

*for_0:
	// examples/merkle/merkle.algo.ts:19
	// i < TREE_DEPTH
	frame_dig 1 // i: uint64
	pushint 3
	<
	bz *for_0_end

	// examples/merkle/merkle.algo.ts:20
	// result = sha256(result + result)
	frame_dig 0 // result: byte[32]
	frame_dig 0 // result: byte[32]
	concat
	sha256
	frame_bury 0 // result: byte[32]

*for_0_continue:
	// examples/merkle/merkle.algo.ts:19
	// i = i + 1
	frame_dig 1 // i: uint64
	int 1
	+
	frame_bury 1 // i: uint64
	b *for_0

*for_0_end:
	// examples/merkle/merkle.algo.ts:23
	// return result;
	frame_dig 0 // result: byte[32]

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 1
	retsub

// hashConcat(left: bytes32, right: bytes32): bytes32
hashConcat:
	proto 2 1

	// examples/merkle/merkle.algo.ts:27
	// return sha256(left + right);
	frame_dig -1 // left: bytes32
	frame_dig -2 // right: bytes32
	concat
	sha256
	retsub

// isRightSibling(elem: Branch): boolean
isRightSibling:
	proto 1 1

	// examples/merkle/merkle.algo.ts:31
	// return getbyte(elem, 0) === RIGHT_SIBLING_PREFIX;
	frame_dig -1 // elem: Branch
	pushint 0
	getbyte
	pushint 170
	==
	retsub

// calcRoot(leaf: bytes32, path: Path): bytes32
calcRoot:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// examples/merkle/merkle.algo.ts:37
	// for (let i = 0; i < TREE_DEPTH; i = i + 1)
	pushint 0
	frame_bury 0 // i: uint64

*for_1:
	// examples/merkle/merkle.algo.ts:37
	// i < TREE_DEPTH
	frame_dig 0 // i: uint64
	pushint 3
	<
	bz *for_1_end
	frame_dig 0 // i: uint64
	frame_bury 1 // accessor: accessor//0//elem

	// *if0_condition
	// examples/merkle/merkle.algo.ts:40
	// this.isRightSibling(elem)
	frame_dig -2 // path: Path
	frame_dig 1 // saved accessor: accessor//0//elem
	pushint 33
	* // acc * typeLength
	pushint 33
	extract3
	callsub isRightSibling
	bz *if0_else

	// *if0_consequent
	// examples/merkle/merkle.algo.ts:41
	// result = this.hashConcat(result, extract3(elem, 1, 32) as bytes32)
	frame_dig -2 // path: Path
	frame_dig 1 // saved accessor: accessor//0//elem
	pushint 33
	* // acc * typeLength
	pushint 33
	extract3
	extract 1 32
	byte 0x0000000000000000000000000000000000000000000000000000000000000000
	concat
	dup
	extract 32 0
	byte 0x
	b==
	assert
	extract 0 32
	frame_dig -1 // leaf: bytes32
	callsub hashConcat
	frame_bury -1 // result: bytes32
	b *if0_end

*if0_else:
	// examples/merkle/merkle.algo.ts:43
	// result = this.hashConcat(extract3(elem, 1, 32) as bytes32, result)
	frame_dig -1 // leaf: bytes32
	frame_dig -2 // path: Path
	frame_dig 1 // saved accessor: accessor//0//elem
	pushint 33
	* // acc * typeLength
	pushint 33
	extract3
	extract 1 32
	byte 0x0000000000000000000000000000000000000000000000000000000000000000
	concat
	dup
	extract 32 0
	byte 0x
	b==
	assert
	extract 0 32
	callsub hashConcat
	frame_bury -1 // result: bytes32

*if0_end:

*for_1_continue:
	// examples/merkle/merkle.algo.ts:37
	// i = i + 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64
	b *for_1

*for_1_end:
	// examples/merkle/merkle.algo.ts:47
	// return result;
	frame_dig -1 // leaf: bytes32

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 1
	retsub

// deleteApplication()void
*abi_route_deleteApplication:
	// execute deleteApplication()void
	callsub deleteApplication
	int 1
	return

// deleteApplication(): void
deleteApplication:
	proto 0 0

	// examples/merkle/merkle.algo.ts:51
	// verifyAppCallTxn(this.txn, { sender: this.app.creator })
	// verify sender
	txn Sender
	txna Applications 0
	app_params_get AppCreator
	pop
	==

	// transaction verification failed: {"txn":"this.txn","field":"sender","expected":"this.app.creator"}
	assert
	retsub

// createApplication()void
*abi_route_createApplication:
	// execute createApplication()void
	callsub createApplication
	int 1
	return

// createApplication(): void
createApplication:
	proto 0 0

	// examples/merkle/merkle.algo.ts:55
	// this.root.value = this.calcInitRoot()
	byte 0x726f6f74 // "root"
	callsub calcInitRoot
	app_global_put
	retsub

// verify(byte[],byte[33][3])void
*abi_route_verify:
	// path: byte[33][3]
	txna ApplicationArgs 2
	dup
	len
	pushint 99
	==

	// argument 0 (path) for verify must be a byte[33][3]
	assert

	// data: byte[]
	txna ApplicationArgs 1
	extract 2 0

	// execute verify(byte[],byte[33][3])void
	callsub verify
	int 1
	return

// verify(data: bytes, path: Path): void
verify:
	proto 2 0

	// examples/merkle/merkle.algo.ts:59
	// assert(this.root.value === this.calcRoot(sha256(data), path))
	byte 0x726f6f74 // "root"
	app_global_get
	frame_dig -2 // path: Path
	frame_dig -1 // data: bytes
	sha256
	callsub calcRoot
	==
	assert
	retsub

// appendLeaf(byte[],byte[33][3])void
*abi_route_appendLeaf:
	// path: byte[33][3]
	txna ApplicationArgs 2
	dup
	len
	pushint 99
	==

	// argument 0 (path) for appendLeaf must be a byte[33][3]
	assert

	// data: byte[]
	txna ApplicationArgs 1
	extract 2 0

	// execute appendLeaf(byte[],byte[33][3])void
	callsub appendLeaf
	int 1
	return

// appendLeaf(data: bytes, path: Path): void
appendLeaf:
	proto 2 0

	// examples/merkle/merkle.algo.ts:63
	// assert(data !== '')
	frame_dig -1 // data: bytes
	byte 0x // ""
	!=
	assert

	// examples/merkle/merkle.algo.ts:64
	// assert(this.root.value === this.calcRoot(hex(EMPTY_HASH) as bytes32, path))
	byte 0x726f6f74 // "root"
	app_global_get
	frame_dig -2 // path: Path
	byte 0xe3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b8550000000000000000000000000000000000000000000000000000000000000000
	byte 0x
	dup
	b==
	assert
	extract 0 32
	callsub calcRoot
	==
	assert

	// examples/merkle/merkle.algo.ts:66
	// this.root.value = this.calcRoot(sha256(data), path)
	byte 0x726f6f74 // "root"
	frame_dig -2 // path: Path
	frame_dig -1 // data: bytes
	sha256
	callsub calcRoot
	app_global_put

	// examples/merkle/merkle.algo.ts:68
	// this.size.value = this.size.value + 1
	byte 0x73697a65 // "size"
	dup
	app_global_get
	int 1
	+
	app_global_put
	retsub

// updateLeaf(byte[],byte[],byte[33][3])void
*abi_route_updateLeaf:
	// path: byte[33][3]
	txna ApplicationArgs 3
	dup
	len
	pushint 99
	==

	// argument 0 (path) for updateLeaf must be a byte[33][3]
	assert

	// newData: byte[]
	txna ApplicationArgs 2
	extract 2 0

	// oldData: byte[]
	txna ApplicationArgs 1
	extract 2 0

	// execute updateLeaf(byte[],byte[],byte[33][3])void
	callsub updateLeaf
	int 1
	return

// updateLeaf(oldData: bytes, newData: bytes, path: Path): void
updateLeaf:
	proto 3 0

	// examples/merkle/merkle.algo.ts:72
	// assert(newData !== '')
	frame_dig -2 // newData: bytes
	byte 0x // ""
	!=
	assert

	// examples/merkle/merkle.algo.ts:73
	// assert(this.root.value === this.calcRoot(sha256(oldData), path))
	byte 0x726f6f74 // "root"
	app_global_get
	frame_dig -3 // path: Path
	frame_dig -1 // oldData: bytes
	sha256
	callsub calcRoot
	==
	assert

	// examples/merkle/merkle.algo.ts:75
	// this.root.value = this.calcRoot(sha256(newData), path)
	byte 0x726f6f74 // "root"
	frame_dig -3 // path: Path
	frame_dig -2 // newData: bytes
	sha256
	callsub calcRoot
	app_global_put
	retsub

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x506cb8d8 // method "verify(byte[],byte[33][3])void"
	pushbytes 0x04f63238 // method "appendLeaf(byte[],byte[33][3])void"
	pushbytes 0x255d93e3 // method "updateLeaf(byte[],byte[],byte[33][3])void"
	txna ApplicationArgs 0
	match *abi_route_verify *abi_route_appendLeaf *abi_route_updateLeaf

	// this contract does not implement the given ABI method for call NoOp
	err

*call_DeleteApplication:
	pushbytes 0x2487c32c // method "deleteApplication()void"
	txna ApplicationArgs 0
	match *abi_route_deleteApplication

	// this contract does not implement the given ABI method for call DeleteApplication
	err", + "approval": "#pragma version 10
intcblock 1
bytecblock 0xe3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b8550000000000000000000000000000000000000000000000000000000000000000 0x0000000000000000000000000000000000000000000000000000000000000000 0x726f6f74 0x 0x73697a65

// This TEAL was generated by TEALScript v0.105.0
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *call_DeleteApplication *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// calcInitRoot(): bytes32
calcInitRoot:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// examples/merkle/merkle.algo.ts:17
	// result = hex(EMPTY_HASH) as bytes32
	byte 0xe3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b8550000000000000000000000000000000000000000000000000000000000000000
	byte 0x
	dup
	b==
	assert
	extract 0 32
	frame_bury 0 // result: byte[32]

	// examples/merkle/merkle.algo.ts:19
	// for (let i = 0; i < TREE_DEPTH; i = i + 1)
	pushint 0
	frame_bury 1 // i: uint64

*for_0:
	// examples/merkle/merkle.algo.ts:19
	// i < TREE_DEPTH
	frame_dig 1 // i: uint64
	pushint 3
	<
	bz *for_0_end

	// examples/merkle/merkle.algo.ts:20
	// result = sha256(result + result)
	frame_dig 0 // result: byte[32]
	frame_dig 0 // result: byte[32]
	concat
	sha256
	frame_bury 0 // result: byte[32]

*for_0_continue:
	// examples/merkle/merkle.algo.ts:19
	// i = i + 1
	frame_dig 1 // i: uint64
	int 1
	+
	frame_bury 1 // i: uint64
	b *for_0

*for_0_end:
	// examples/merkle/merkle.algo.ts:23
	// return result;
	frame_dig 0 // result: byte[32]

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 1
	retsub

// hashConcat(left: bytes32, right: bytes32): bytes32
hashConcat:
	proto 2 1

	// examples/merkle/merkle.algo.ts:27
	// return sha256(left + right);
	frame_dig -1 // left: bytes32
	frame_dig -2 // right: bytes32
	concat
	sha256
	retsub

// isRightSibling(elem: Branch): boolean
isRightSibling:
	proto 1 1

	// examples/merkle/merkle.algo.ts:31
	// return getbyte(elem, 0) === RIGHT_SIBLING_PREFIX;
	frame_dig -1 // elem: Branch
	pushint 0
	getbyte
	pushint 170
	==
	retsub

// calcRoot(leaf: bytes32, path: Path): bytes32
calcRoot:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// examples/merkle/merkle.algo.ts:37
	// for (let i = 0; i < TREE_DEPTH; i = i + 1)
	pushint 0
	frame_bury 0 // i: uint64

*for_1:
	// examples/merkle/merkle.algo.ts:37
	// i < TREE_DEPTH
	frame_dig 0 // i: uint64
	pushint 3
	<
	bz *for_1_end
	frame_dig 0 // i: uint64
	frame_bury 1 // accessor: accessor//0//elem

	// *if0_condition
	// examples/merkle/merkle.algo.ts:40
	// this.isRightSibling(elem)
	frame_dig -2 // path: Path
	frame_dig 1 // saved accessor: accessor//0//elem
	pushint 33
	* // acc * typeLength
	pushint 33
	extract3
	callsub isRightSibling
	bz *if0_else

	// *if0_consequent
	// examples/merkle/merkle.algo.ts:41
	// result = this.hashConcat(result, extract3(elem, 1, 32) as bytes32)
	frame_dig -2 // path: Path
	frame_dig 1 // saved accessor: accessor//0//elem
	pushint 33
	* // acc * typeLength
	pushint 33
	extract3
	extract 1 32
	byte 0x0000000000000000000000000000000000000000000000000000000000000000
	concat
	dup
	extract 32 0
	byte 0x
	b==
	assert
	extract 0 32
	frame_dig -1 // leaf: bytes32
	callsub hashConcat
	frame_bury -1 // result: bytes32
	b *if0_end

*if0_else:
	// examples/merkle/merkle.algo.ts:43
	// result = this.hashConcat(extract3(elem, 1, 32) as bytes32, result)
	frame_dig -1 // leaf: bytes32
	frame_dig -2 // path: Path
	frame_dig 1 // saved accessor: accessor//0//elem
	pushint 33
	* // acc * typeLength
	pushint 33
	extract3
	extract 1 32
	byte 0x0000000000000000000000000000000000000000000000000000000000000000
	concat
	dup
	extract 32 0
	byte 0x
	b==
	assert
	extract 0 32
	callsub hashConcat
	frame_bury -1 // result: bytes32

*if0_end:

*for_1_continue:
	// examples/merkle/merkle.algo.ts:37
	// i = i + 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64
	b *for_1

*for_1_end:
	// examples/merkle/merkle.algo.ts:47
	// return result;
	frame_dig -1 // leaf: bytes32

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 1
	retsub

// deleteApplication()void
*abi_route_deleteApplication:
	// execute deleteApplication()void
	callsub deleteApplication
	int 1
	return

// deleteApplication(): void
deleteApplication:
	proto 0 0

	// examples/merkle/merkle.algo.ts:51
	// verifyAppCallTxn(this.txn, { sender: this.app.creator })
	// verify sender
	txn Sender
	txna Applications 0
	app_params_get AppCreator
	pop
	==

	// transaction verification failed: {"txn":"this.txn","field":"sender","expected":"this.app.creator"}
	assert
	retsub

// createApplication()void
*abi_route_createApplication:
	// execute createApplication()void
	callsub createApplication
	int 1
	return

// createApplication(): void
createApplication:
	proto 0 0

	// examples/merkle/merkle.algo.ts:55
	// this.root.value = this.calcInitRoot()
	byte 0x726f6f74 // "root"
	callsub calcInitRoot
	app_global_put
	retsub

// verify(byte[],byte[33][3])void
*abi_route_verify:
	// path: byte[33][3]
	txna ApplicationArgs 2
	dup
	len
	pushint 99
	==

	// argument 0 (path) for verify must be a byte[33][3]
	assert

	// data: byte[]
	txna ApplicationArgs 1
	extract 2 0

	// execute verify(byte[],byte[33][3])void
	callsub verify
	int 1
	return

// verify(data: bytes, path: Path): void
verify:
	proto 2 0

	// examples/merkle/merkle.algo.ts:59
	// assert(this.root.value === this.calcRoot(sha256(data), path))
	byte 0x726f6f74 // "root"
	app_global_get
	frame_dig -2 // path: Path
	frame_dig -1 // data: bytes
	sha256
	callsub calcRoot
	==
	assert
	retsub

// appendLeaf(byte[],byte[33][3])void
*abi_route_appendLeaf:
	// path: byte[33][3]
	txna ApplicationArgs 2
	dup
	len
	pushint 99
	==

	// argument 0 (path) for appendLeaf must be a byte[33][3]
	assert

	// data: byte[]
	txna ApplicationArgs 1
	extract 2 0

	// execute appendLeaf(byte[],byte[33][3])void
	callsub appendLeaf
	int 1
	return

// appendLeaf(data: bytes, path: Path): void
appendLeaf:
	proto 2 0

	// examples/merkle/merkle.algo.ts:63
	// assert(data !== '')
	frame_dig -1 // data: bytes
	byte 0x // ""
	!=
	assert

	// examples/merkle/merkle.algo.ts:64
	// assert(this.root.value === this.calcRoot(hex(EMPTY_HASH) as bytes32, path))
	byte 0x726f6f74 // "root"
	app_global_get
	frame_dig -2 // path: Path
	byte 0xe3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b8550000000000000000000000000000000000000000000000000000000000000000
	byte 0x
	dup
	b==
	assert
	extract 0 32
	callsub calcRoot
	==
	assert

	// examples/merkle/merkle.algo.ts:66
	// this.root.value = this.calcRoot(sha256(data), path)
	byte 0x726f6f74 // "root"
	frame_dig -2 // path: Path
	frame_dig -1 // data: bytes
	sha256
	callsub calcRoot
	app_global_put

	// examples/merkle/merkle.algo.ts:68
	// this.size.value = this.size.value + 1
	byte 0x73697a65 // "size"
	dup
	app_global_get
	int 1
	+
	app_global_put
	retsub

// updateLeaf(byte[],byte[],byte[33][3])void
*abi_route_updateLeaf:
	// path: byte[33][3]
	txna ApplicationArgs 3
	dup
	len
	pushint 99
	==

	// argument 0 (path) for updateLeaf must be a byte[33][3]
	assert

	// newData: byte[]
	txna ApplicationArgs 2
	extract 2 0

	// oldData: byte[]
	txna ApplicationArgs 1
	extract 2 0

	// execute updateLeaf(byte[],byte[],byte[33][3])void
	callsub updateLeaf
	int 1
	return

// updateLeaf(oldData: bytes, newData: bytes, path: Path): void
updateLeaf:
	proto 3 0

	// examples/merkle/merkle.algo.ts:72
	// assert(newData !== '')
	frame_dig -2 // newData: bytes
	byte 0x // ""
	!=
	assert

	// examples/merkle/merkle.algo.ts:73
	// assert(this.root.value === this.calcRoot(sha256(oldData), path))
	byte 0x726f6f74 // "root"
	app_global_get
	frame_dig -3 // path: Path
	frame_dig -1 // oldData: bytes
	sha256
	callsub calcRoot
	==
	assert

	// examples/merkle/merkle.algo.ts:75
	// this.root.value = this.calcRoot(sha256(newData), path)
	byte 0x726f6f74 // "root"
	frame_dig -3 // path: Path
	frame_dig -2 // newData: bytes
	sha256
	callsub calcRoot
	app_global_put
	retsub

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x506cb8d8 // method "verify(byte[],byte[33][3])void"
	pushbytes 0x04f63238 // method "appendLeaf(byte[],byte[33][3])void"
	pushbytes 0x255d93e3 // method "updateLeaf(byte[],byte[],byte[33][3])void"
	txna ApplicationArgs 0
	match *abi_route_verify *abi_route_appendLeaf *abi_route_updateLeaf

	// this contract does not implement the given ABI method for call NoOp
	err

*call_DeleteApplication:
	pushbytes 0x2487c32c // method "deleteApplication()void"
	txna ApplicationArgs 0
	match *abi_route_deleteApplication

	// this contract does not implement the given ABI method for call DeleteApplication
	err", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/examples/non_abi/artifacts/NonABIExample.approval.teal b/examples/non_abi/artifacts/NonABIExample.approval.teal index 20fe8f612..878b09eea 100644 --- a/examples/non_abi/artifacts/NonABIExample.approval.teal +++ b/examples/non_abi/artifacts/NonABIExample.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // !!!! WARNING: This contract is *NOT* ARC4 compliant. It may contain ABI methods, but it also allows app calls where the first argument does NOT match an ABI selector diff --git a/examples/non_abi/artifacts/NonABIExample.arc32.json b/examples/non_abi/artifacts/NonABIExample.arc32.json index edffce9bf..e952f25b3 100644 --- a/examples/non_abi/artifacts/NonABIExample.arc32.json +++ b/examples/non_abi/artifacts/NonABIExample.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyAhISEhIFdBUk5JTkc6IFRoaXMgY29udHJhY3QgaXMgKk5PVCogQVJDNCBjb21wbGlhbnQuIEl0IG1heSBjb250YWluIEFCSSBtZXRob2RzLCBidXQgaXQgYWxzbyBhbGxvd3MgYXBwIGNhbGxzIHdoZXJlIHRoZSBmaXJzdCBhcmd1bWVudCBkb2VzIE5PVCBtYXRjaCBhbiBBQkkgc2VsZWN0b3IKCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY2FsbF9VcGRhdGVBcHBsaWNhdGlvbiAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYWRkKHg6IHVpbnQ2NCwgeTogdWludDY0KTogdWludDY0CmFkZDoKCXByb3RvIDIgMQoKCS8vIGV4YW1wbGVzL25vbl9hYmkvbm9uX2FiaS5hbGdvLnRzOjYKCS8vIHJldHVybiB4ICsgeTsKCWZyYW1lX2RpZyAtMSAvLyB4OiB1aW50NjQKCWZyYW1lX2RpZyAtMiAvLyB5OiB1aW50NjQKCSsKCXJldHN1YgoKLy8gYWJpQWRkKHVpbnQ2NCx1aW50NjQpdWludDY0CiphYmlfcm91dGVfYWJpQWRkOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIHk6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMgoJYnRvaQoKCS8vIHg6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJYnRvaQoKCS8vIGV4ZWN1dGUgYWJpQWRkKHVpbnQ2NCx1aW50NjQpdWludDY0CgljYWxsc3ViIGFiaUFkZAoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBhYmlBZGQoeDogdWludDY0LCB5OiB1aW50NjQpOiB1aW50NjQKYWJpQWRkOgoJcHJvdG8gMiAxCgoJLy8gZXhhbXBsZXMvbm9uX2FiaS9ub25fYWJpLmFsZ28udHM6MTAKCS8vIHJldHVybiB0aGlzLmFkZCh4LCB5KTsKCWZyYW1lX2RpZyAtMiAvLyB5OiB1aW50NjQKCWZyYW1lX2RpZyAtMSAvLyB4OiB1aW50NjQKCWNhbGxzdWIgYWRkCglyZXRzdWIKCi8vIG5vbkFiaUFkZCgpOiB2b2lkCm5vbkFiaUFkZDoKCXByb3RvIDAgMAoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXAKCgkvLyBleGFtcGxlcy9ub25fYWJpL25vbl9hYmkuYWxnby50czoxNQoJLy8geCA9IGJ0b2kodGhpcy50eG4uYXBwbGljYXRpb25BcmdzIVswXSkKCXR4biBBcHBsaWNhdGlvbkFyZ3MgMAoJYnRvaQoJZnJhbWVfYnVyeSAwIC8vIHg6IHVpbnQ2NAoKCS8vIGV4YW1wbGVzL25vbl9hYmkvbm9uX2FiaS5hbGdvLnRzOjE2CgkvLyB5ID0gYnRvaSh0aGlzLnR4bi5hcHBsaWNhdGlvbkFyZ3MhWzFdKQoJdHhuIEFwcGxpY2F0aW9uQXJncyAxCglidG9pCglmcmFtZV9idXJ5IDEgLy8geTogdWludDY0CgoJLy8gZXhhbXBsZXMvbm9uX2FiaS9ub25fYWJpLmFsZ28udHM6MTcKCS8vIGxvZyhpdG9iKHRoaXMuYWRkKHgsIHkpKSkKCWZyYW1lX2RpZyAxIC8vIHk6IHVpbnQ2NAoJZnJhbWVfZGlnIDAgLy8geDogdWludDY0CgljYWxsc3ViIGFkZAoJaXRvYgoJbG9nCglyZXRzdWIKCi8vIG5vbkFiaVVwZGF0ZSgpOiB2b2lkCm5vbkFiaVVwZGF0ZToKCXByb3RvIDAgMAoKCS8vIGV4YW1wbGVzL25vbl9hYmkvbm9uX2FiaS5hbGdvLnRzOjIyCgkvLyBsb2coJ1VwZGF0ZWQhJykKCXB1c2hieXRlcyAweDU1NzA2NDYxNzQ2NTY0MjEgLy8gIlVwZGF0ZWQhIgoJbG9nCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGI4Yjg0NDg0IC8vIG1ldGhvZCAiYWJpQWRkKHVpbnQ2NCx1aW50NjQpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9hYmlBZGQKCgkvLyAhISEhIFdBUk5JTkc6IG5vbi1BQkkgcm91dGluZwoJY2FsbHN1YiBub25BYmlBZGQKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY2FsbF9VcGRhdGVBcHBsaWNhdGlvbjoKCS8vICEhISEgV0FSTklORzogbm9uLUFCSSByb3V0aW5nCgljYWxsc3ViIG5vbkFiaVVwZGF0ZQoJcHVzaGludCAxCglyZXR1cm4=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyAhISEhIFdBUk5JTkc6IFRoaXMgY29udHJhY3QgaXMgKk5PVCogQVJDNCBjb21wbGlhbnQuIEl0IG1heSBjb250YWluIEFCSSBtZXRob2RzLCBidXQgaXQgYWxzbyBhbGxvd3MgYXBwIGNhbGxzIHdoZXJlIHRoZSBmaXJzdCBhcmd1bWVudCBkb2VzIE5PVCBtYXRjaCBhbiBBQkkgc2VsZWN0b3IKCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY2FsbF9VcGRhdGVBcHBsaWNhdGlvbiAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYWRkKHg6IHVpbnQ2NCwgeTogdWludDY0KTogdWludDY0CmFkZDoKCXByb3RvIDIgMQoKCS8vIGV4YW1wbGVzL25vbl9hYmkvbm9uX2FiaS5hbGdvLnRzOjYKCS8vIHJldHVybiB4ICsgeTsKCWZyYW1lX2RpZyAtMSAvLyB4OiB1aW50NjQKCWZyYW1lX2RpZyAtMiAvLyB5OiB1aW50NjQKCSsKCXJldHN1YgoKLy8gYWJpQWRkKHVpbnQ2NCx1aW50NjQpdWludDY0CiphYmlfcm91dGVfYWJpQWRkOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIHk6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMgoJYnRvaQoKCS8vIHg6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJYnRvaQoKCS8vIGV4ZWN1dGUgYWJpQWRkKHVpbnQ2NCx1aW50NjQpdWludDY0CgljYWxsc3ViIGFiaUFkZAoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBhYmlBZGQoeDogdWludDY0LCB5OiB1aW50NjQpOiB1aW50NjQKYWJpQWRkOgoJcHJvdG8gMiAxCgoJLy8gZXhhbXBsZXMvbm9uX2FiaS9ub25fYWJpLmFsZ28udHM6MTAKCS8vIHJldHVybiB0aGlzLmFkZCh4LCB5KTsKCWZyYW1lX2RpZyAtMiAvLyB5OiB1aW50NjQKCWZyYW1lX2RpZyAtMSAvLyB4OiB1aW50NjQKCWNhbGxzdWIgYWRkCglyZXRzdWIKCi8vIG5vbkFiaUFkZCgpOiB2b2lkCm5vbkFiaUFkZDoKCXByb3RvIDAgMAoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXAKCgkvLyBleGFtcGxlcy9ub25fYWJpL25vbl9hYmkuYWxnby50czoxNQoJLy8geCA9IGJ0b2kodGhpcy50eG4uYXBwbGljYXRpb25BcmdzIVswXSkKCXR4biBBcHBsaWNhdGlvbkFyZ3MgMAoJYnRvaQoJZnJhbWVfYnVyeSAwIC8vIHg6IHVpbnQ2NAoKCS8vIGV4YW1wbGVzL25vbl9hYmkvbm9uX2FiaS5hbGdvLnRzOjE2CgkvLyB5ID0gYnRvaSh0aGlzLnR4bi5hcHBsaWNhdGlvbkFyZ3MhWzFdKQoJdHhuIEFwcGxpY2F0aW9uQXJncyAxCglidG9pCglmcmFtZV9idXJ5IDEgLy8geTogdWludDY0CgoJLy8gZXhhbXBsZXMvbm9uX2FiaS9ub25fYWJpLmFsZ28udHM6MTcKCS8vIGxvZyhpdG9iKHRoaXMuYWRkKHgsIHkpKSkKCWZyYW1lX2RpZyAxIC8vIHk6IHVpbnQ2NAoJZnJhbWVfZGlnIDAgLy8geDogdWludDY0CgljYWxsc3ViIGFkZAoJaXRvYgoJbG9nCglyZXRzdWIKCi8vIG5vbkFiaVVwZGF0ZSgpOiB2b2lkCm5vbkFiaVVwZGF0ZToKCXByb3RvIDAgMAoKCS8vIGV4YW1wbGVzL25vbl9hYmkvbm9uX2FiaS5hbGdvLnRzOjIyCgkvLyBsb2coJ1VwZGF0ZWQhJykKCXB1c2hieXRlcyAweDU1NzA2NDYxNzQ2NTY0MjEgLy8gIlVwZGF0ZWQhIgoJbG9nCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGI4Yjg0NDg0IC8vIG1ldGhvZCAiYWJpQWRkKHVpbnQ2NCx1aW50NjQpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9hYmlBZGQKCgkvLyAhISEhIFdBUk5JTkc6IG5vbi1BQkkgcm91dGluZwoJY2FsbHN1YiBub25BYmlBZGQKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY2FsbF9VcGRhdGVBcHBsaWNhdGlvbjoKCS8vICEhISEgV0FSTklORzogbm9uLUFCSSByb3V0aW5nCgljYWxsc3ViIG5vbkFiaVVwZGF0ZQoJcHVzaGludCAxCglyZXR1cm4=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/examples/non_abi/artifacts/NonABIExample.arc56_draft.json b/examples/non_abi/artifacts/NonABIExample.arc56_draft.json index c07c208a9..63133d45b 100644 --- a/examples/non_abi/artifacts/NonABIExample.arc56_draft.json +++ b/examples/non_abi/artifacts/NonABIExample.arc56_draft.json @@ -641,7 +641,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyAhISEhIFdBUk5JTkc6IFRoaXMgY29udHJhY3QgaXMgKk5PVCogQVJDNCBjb21wbGlhbnQuIEl0IG1heSBjb250YWluIEFCSSBtZXRob2RzLCBidXQgaXQgYWxzbyBhbGxvd3MgYXBwIGNhbGxzIHdoZXJlIHRoZSBmaXJzdCBhcmd1bWVudCBkb2VzIE5PVCBtYXRjaCBhbiBBQkkgc2VsZWN0b3IKCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY2FsbF9VcGRhdGVBcHBsaWNhdGlvbiAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYWRkKHg6IHVpbnQ2NCwgeTogdWludDY0KTogdWludDY0CmFkZDoKCXByb3RvIDIgMQoKCS8vIGV4YW1wbGVzL25vbl9hYmkvbm9uX2FiaS5hbGdvLnRzOjYKCS8vIHJldHVybiB4ICsgeTsKCWZyYW1lX2RpZyAtMSAvLyB4OiB1aW50NjQKCWZyYW1lX2RpZyAtMiAvLyB5OiB1aW50NjQKCSsKCXJldHN1YgoKLy8gYWJpQWRkKHVpbnQ2NCx1aW50NjQpdWludDY0CiphYmlfcm91dGVfYWJpQWRkOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIHk6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMgoJYnRvaQoKCS8vIHg6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJYnRvaQoKCS8vIGV4ZWN1dGUgYWJpQWRkKHVpbnQ2NCx1aW50NjQpdWludDY0CgljYWxsc3ViIGFiaUFkZAoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBhYmlBZGQoeDogdWludDY0LCB5OiB1aW50NjQpOiB1aW50NjQKYWJpQWRkOgoJcHJvdG8gMiAxCgoJLy8gZXhhbXBsZXMvbm9uX2FiaS9ub25fYWJpLmFsZ28udHM6MTAKCS8vIHJldHVybiB0aGlzLmFkZCh4LCB5KTsKCWZyYW1lX2RpZyAtMiAvLyB5OiB1aW50NjQKCWZyYW1lX2RpZyAtMSAvLyB4OiB1aW50NjQKCWNhbGxzdWIgYWRkCglyZXRzdWIKCi8vIG5vbkFiaUFkZCgpOiB2b2lkCm5vbkFiaUFkZDoKCXByb3RvIDAgMAoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXAKCgkvLyBleGFtcGxlcy9ub25fYWJpL25vbl9hYmkuYWxnby50czoxNQoJLy8geCA9IGJ0b2kodGhpcy50eG4uYXBwbGljYXRpb25BcmdzIVswXSkKCXR4biBBcHBsaWNhdGlvbkFyZ3MgMAoJYnRvaQoJZnJhbWVfYnVyeSAwIC8vIHg6IHVpbnQ2NAoKCS8vIGV4YW1wbGVzL25vbl9hYmkvbm9uX2FiaS5hbGdvLnRzOjE2CgkvLyB5ID0gYnRvaSh0aGlzLnR4bi5hcHBsaWNhdGlvbkFyZ3MhWzFdKQoJdHhuIEFwcGxpY2F0aW9uQXJncyAxCglidG9pCglmcmFtZV9idXJ5IDEgLy8geTogdWludDY0CgoJLy8gZXhhbXBsZXMvbm9uX2FiaS9ub25fYWJpLmFsZ28udHM6MTcKCS8vIGxvZyhpdG9iKHRoaXMuYWRkKHgsIHkpKSkKCWZyYW1lX2RpZyAxIC8vIHk6IHVpbnQ2NAoJZnJhbWVfZGlnIDAgLy8geDogdWludDY0CgljYWxsc3ViIGFkZAoJaXRvYgoJbG9nCglyZXRzdWIKCi8vIG5vbkFiaVVwZGF0ZSgpOiB2b2lkCm5vbkFiaVVwZGF0ZToKCXByb3RvIDAgMAoKCS8vIGV4YW1wbGVzL25vbl9hYmkvbm9uX2FiaS5hbGdvLnRzOjIyCgkvLyBsb2coJ1VwZGF0ZWQhJykKCXB1c2hieXRlcyAweDU1NzA2NDYxNzQ2NTY0MjEgLy8gIlVwZGF0ZWQhIgoJbG9nCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGI4Yjg0NDg0IC8vIG1ldGhvZCAiYWJpQWRkKHVpbnQ2NCx1aW50NjQpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9hYmlBZGQKCgkvLyAhISEhIFdBUk5JTkc6IG5vbi1BQkkgcm91dGluZwoJY2FsbHN1YiBub25BYmlBZGQKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY2FsbF9VcGRhdGVBcHBsaWNhdGlvbjoKCS8vICEhISEgV0FSTklORzogbm9uLUFCSSByb3V0aW5nCgljYWxsc3ViIG5vbkFiaVVwZGF0ZQoJcHVzaGludCAxCglyZXR1cm4=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyAhISEhIFdBUk5JTkc6IFRoaXMgY29udHJhY3QgaXMgKk5PVCogQVJDNCBjb21wbGlhbnQuIEl0IG1heSBjb250YWluIEFCSSBtZXRob2RzLCBidXQgaXQgYWxzbyBhbGxvd3MgYXBwIGNhbGxzIHdoZXJlIHRoZSBmaXJzdCBhcmd1bWVudCBkb2VzIE5PVCBtYXRjaCBhbiBBQkkgc2VsZWN0b3IKCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY2FsbF9VcGRhdGVBcHBsaWNhdGlvbiAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYWRkKHg6IHVpbnQ2NCwgeTogdWludDY0KTogdWludDY0CmFkZDoKCXByb3RvIDIgMQoKCS8vIGV4YW1wbGVzL25vbl9hYmkvbm9uX2FiaS5hbGdvLnRzOjYKCS8vIHJldHVybiB4ICsgeTsKCWZyYW1lX2RpZyAtMSAvLyB4OiB1aW50NjQKCWZyYW1lX2RpZyAtMiAvLyB5OiB1aW50NjQKCSsKCXJldHN1YgoKLy8gYWJpQWRkKHVpbnQ2NCx1aW50NjQpdWludDY0CiphYmlfcm91dGVfYWJpQWRkOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIHk6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMgoJYnRvaQoKCS8vIHg6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJYnRvaQoKCS8vIGV4ZWN1dGUgYWJpQWRkKHVpbnQ2NCx1aW50NjQpdWludDY0CgljYWxsc3ViIGFiaUFkZAoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBhYmlBZGQoeDogdWludDY0LCB5OiB1aW50NjQpOiB1aW50NjQKYWJpQWRkOgoJcHJvdG8gMiAxCgoJLy8gZXhhbXBsZXMvbm9uX2FiaS9ub25fYWJpLmFsZ28udHM6MTAKCS8vIHJldHVybiB0aGlzLmFkZCh4LCB5KTsKCWZyYW1lX2RpZyAtMiAvLyB5OiB1aW50NjQKCWZyYW1lX2RpZyAtMSAvLyB4OiB1aW50NjQKCWNhbGxzdWIgYWRkCglyZXRzdWIKCi8vIG5vbkFiaUFkZCgpOiB2b2lkCm5vbkFiaUFkZDoKCXByb3RvIDAgMAoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXAKCgkvLyBleGFtcGxlcy9ub25fYWJpL25vbl9hYmkuYWxnby50czoxNQoJLy8geCA9IGJ0b2kodGhpcy50eG4uYXBwbGljYXRpb25BcmdzIVswXSkKCXR4biBBcHBsaWNhdGlvbkFyZ3MgMAoJYnRvaQoJZnJhbWVfYnVyeSAwIC8vIHg6IHVpbnQ2NAoKCS8vIGV4YW1wbGVzL25vbl9hYmkvbm9uX2FiaS5hbGdvLnRzOjE2CgkvLyB5ID0gYnRvaSh0aGlzLnR4bi5hcHBsaWNhdGlvbkFyZ3MhWzFdKQoJdHhuIEFwcGxpY2F0aW9uQXJncyAxCglidG9pCglmcmFtZV9idXJ5IDEgLy8geTogdWludDY0CgoJLy8gZXhhbXBsZXMvbm9uX2FiaS9ub25fYWJpLmFsZ28udHM6MTcKCS8vIGxvZyhpdG9iKHRoaXMuYWRkKHgsIHkpKSkKCWZyYW1lX2RpZyAxIC8vIHk6IHVpbnQ2NAoJZnJhbWVfZGlnIDAgLy8geDogdWludDY0CgljYWxsc3ViIGFkZAoJaXRvYgoJbG9nCglyZXRzdWIKCi8vIG5vbkFiaVVwZGF0ZSgpOiB2b2lkCm5vbkFiaVVwZGF0ZToKCXByb3RvIDAgMAoKCS8vIGV4YW1wbGVzL25vbl9hYmkvbm9uX2FiaS5hbGdvLnRzOjIyCgkvLyBsb2coJ1VwZGF0ZWQhJykKCXB1c2hieXRlcyAweDU1NzA2NDYxNzQ2NTY0MjEgLy8gIlVwZGF0ZWQhIgoJbG9nCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGI4Yjg0NDg0IC8vIG1ldGhvZCAiYWJpQWRkKHVpbnQ2NCx1aW50NjQpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9hYmlBZGQKCgkvLyAhISEhIFdBUk5JTkc6IG5vbi1BQkkgcm91dGluZwoJY2FsbHN1YiBub25BYmlBZGQKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY2FsbF9VcGRhdGVBcHBsaWNhdGlvbjoKCS8vICEhISEgV0FSTklORzogbm9uLUFCSSByb3V0aW5nCgljYWxsc3ViIG5vbkFiaVVwZGF0ZQoJcHVzaGludCAxCglyZXR1cm4=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/examples/optin-lsig/artifacts/LsigExample.lsig.teal b/examples/optin-lsig/artifacts/LsigExample.lsig.teal index c4343442f..cb2a02ba1 100644 --- a/examples/optin-lsig/artifacts/LsigExample.lsig.teal +++ b/examples/optin-lsig/artifacts/LsigExample.lsig.teal @@ -1,7 +1,7 @@ #pragma version 10 //#pragma mode logicsig -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // The address of this logic signature is 2557Q4YBTDGG3M6XJO2BWFD37TWICBDDDF5IGNJLDJH3HUZXICNVCD6ZBI diff --git a/examples/reti/artifacts/StakingPool.approval.teal b/examples/reti/artifacts/StakingPool.approval.teal index 16152d5f7..548c3de0e 100644 --- a/examples/reti/artifacts/StakingPool.approval.teal +++ b/examples/reti/artifacts/StakingPool.approval.teal @@ -2,7 +2,7 @@ intcblock TMPL_nfdRegistryAppId 0 1 6 64 32 16 128 1_000_000 2_100_000 200 300 1000 bytecblock TMPL_feeSinkAddr 0x63726561746f72417070 0x76616c696461746f724964 0x7374616b65416363756d756c61746f72 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF 0x7374616b657273 0x726f756e6473506572446179 0x706f6f6c4964 0x726577617264416363756d756c61746f72 0x7374616b6564 0x62696e526f756e645374617274 0x0000000000000000 0x 0x0a8101 0x6e756d5374616b657273 0x6c6173745061796f7574 0x00000000000000000000000000000000 0x00000000000000000000000000000064 0x6d696e456e7472795374616b65 0x65706f63684e756d626572 0x75aff61d 0x65776d61 0x151f7c75 0xa2dc51b5 0x572767d1 0x4df8d86e 0x0c2245e1 0x00 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/examples/reti/artifacts/StakingPool.arc32.json b/examples/reti/artifacts/StakingPool.arc32.json index bab396c8f..dd3acbb34 100644 --- a/examples/reti/artifacts/StakingPool.arc32.json +++ b/examples/reti/artifacts/StakingPool.arc32.json @@ -161,7 +161,7 @@ } }, "source": { - "approval": "#pragma version 10
intcblock TMPL_nfdRegistryAppId 0 1 6 64 32 16 128 1_000_000 2_100_000 200 300 1000
bytecblock TMPL_feeSinkAddr 0x63726561746f72417070 0x76616c696461746f724964 0x7374616b65416363756d756c61746f72 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF 0x7374616b657273 0x726f756e6473506572446179 0x706f6f6c4964 0x726577617264416363756d756c61746f72 0x7374616b6564 0x62696e526f756e645374617274 0x0000000000000000 0x 0x0a8101 0x6e756d5374616b657273 0x6c6173745061796f7574 0x00000000000000000000000000000000 0x00000000000000000000000000000064 0x6d696e456e7472795374616b65 0x65706f63684e756d626572 0x75aff61d 0x65776d61 0x151f7c75 0xa2dc51b5 0x572767d1 0x4df8d86e 0x0c2245e1 0x00

// This TEAL was generated by TEALScript v0.104.1
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following lines of TEAL are used to initialize template variables in scratch slots
bytec 0 // TMPL_feeSinkAddr
intc 0 // TMPL_nfdRegistryAppId

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
int 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *call_UpdateApplication *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// updateApplication()void
*abi_route_updateApplication:
	// execute updateApplication()void
	callsub updateApplication
	int 1
	return

// updateApplication(): void
updateApplication:
	proto 0 0

	// examples/reti/stakingPool.algo.ts:94
	// assert(
	//       this.txn.sender === Address.fromAddress('LZ4V2IRVLCXFJK4REJV4TAGEKEYTA2GMR6TC2344OB3L3AF3MWXZ6ZAFIQ'),
	//       'Temporary: contract is upgradeable but only during testing and only from a development account'
	//     )
	txn Sender
	pushbytes 0x5e795d223558ae54ab91226bc980c451313068cc8fa62d6f9c7076bd80bb65af // addr "LZ4V2IRVLCXFJK4REJV4TAGEKEYTA2GMR6TC2344OB3L3AF3MWXZ6ZAFIQ"
	==

	// Temporary: contract is upgradeable but only during testing and only from a development account
	assert
	retsub

// createApplication(uint64,uint64,uint64,uint64)void
*abi_route_createApplication:
	// minEntryStake: uint64
	txna ApplicationArgs 4
	btoi

	// poolId: uint64
	txna ApplicationArgs 3
	btoi

	// validatorId: uint64
	txna ApplicationArgs 2
	btoi

	// creatingContractId: uint64
	txna ApplicationArgs 1
	btoi

	// execute createApplication(uint64,uint64,uint64,uint64)void
	callsub createApplication
	int 1
	return

// createApplication(creatingContractId: uint64, validatorId: uint64, poolId: uint64, minEntryStake: uint64): void
//
// Initialize the staking pool w/ owner and manager, but can only be created by the validator contract.
// @param {uint64} creatingContractId - id of contract that constructed us - the validator application (single global instance)
// @param {uint64} validatorId - id of validator we're a staking pool of
// @param {uint64} poolId - which pool id are we
// @param {uint64} minEntryStake - minimum amount to be in pool, but also minimum amount balance can't go below (without removing all!)
createApplication:
	proto 4 0

	// *if0_condition
	// examples/reti/stakingPool.algo.ts:108
	// creatingContractId === 0
	frame_dig -1 // creatingContractId: uint64
	int 0
	==
	bz *if0_else

	// *if0_consequent
	// examples/reti/stakingPool.algo.ts:110
	// assert(validatorId === 0)
	frame_dig -2 // validatorId: uint64
	int 0
	==
	assert

	// examples/reti/stakingPool.algo.ts:111
	// assert(poolId === 0)
	frame_dig -3 // poolId: uint64
	int 0
	==
	assert
	b *if0_end

*if0_else:
	// examples/reti/stakingPool.algo.ts:113
	// assert(validatorId !== 0)
	frame_dig -2 // validatorId: uint64
	int 0
	!=
	assert

	// examples/reti/stakingPool.algo.ts:114
	// assert(poolId !== 0)
	frame_dig -3 // poolId: uint64
	int 0
	!=
	assert

*if0_end:
	// examples/reti/stakingPool.algo.ts:116
	// assert(minEntryStake >= MIN_ALGO_STAKE_PER_POOL, 'staking pool must have minimum entry of 1 algo')
	frame_dig -4 // minEntryStake: uint64
	pushint 1000000
	>=

	// staking pool must have minimum entry of 1 algo
	assert

	// examples/reti/stakingPool.algo.ts:117
	// this.creatingValidatorContractAppId.value = creatingContractId
	byte 0x63726561746f72417070 // "creatorApp"
	frame_dig -1 // creatingContractId: uint64
	app_global_put

	// examples/reti/stakingPool.algo.ts:118
	// this.validatorId.value = validatorId
	byte 0x76616c696461746f724964 // "validatorId"
	frame_dig -2 // validatorId: uint64
	app_global_put

	// examples/reti/stakingPool.algo.ts:119
	// this.poolId.value = poolId
	byte 0x706f6f6c4964 // "poolId"
	frame_dig -3 // poolId: uint64
	app_global_put

	// examples/reti/stakingPool.algo.ts:120
	// this.numStakers.value = 0
	byte 0x6e756d5374616b657273 // "numStakers"
	int 0
	app_global_put

	// examples/reti/stakingPool.algo.ts:121
	// this.totalAlgoStaked.value = 0
	byte 0x7374616b6564 // "staked"
	int 0
	app_global_put

	// examples/reti/stakingPool.algo.ts:122
	// this.minEntryStake.value = minEntryStake
	byte 0x6d696e456e7472795374616b65 // "minEntryStake"
	frame_dig -4 // minEntryStake: uint64
	app_global_put

	// examples/reti/stakingPool.algo.ts:123
	// this.lastPayout.value = globals.round
	byte 0x6c6173745061796f7574 // "lastPayout"
	global Round
	app_global_put

	// examples/reti/stakingPool.algo.ts:124
	// this.epochNumber.value = 0
	byte 0x65706f63684e756d626572 // "epochNumber"
	int 0
	app_global_put

	// examples/reti/stakingPool.algo.ts:126
	// this.setRoundsPerDay()
	callsub setRoundsPerDay

	// examples/reti/stakingPool.algo.ts:127
	// this.binRoundStart.value = globals.round - (globals.round % this.roundsPerDay.value)
	byte 0x62696e526f756e645374617274 // "binRoundStart"
	global Round
	global Round
	byte 0x726f756e6473506572446179 // "roundsPerDay"
	app_global_get
	%
	-
	app_global_put

	// examples/reti/stakingPool.algo.ts:128
	// this.stakeAccumulator.value = 0 as uint128
	byte 0x7374616b65416363756d756c61746f72 // "stakeAccumulator"
	byte 0x00000000000000000000000000000000
	app_global_put

	// examples/reti/stakingPool.algo.ts:129
	// this.rewardAccumulator.value = 0
	byte 0x726577617264416363756d756c61746f72 // "rewardAccumulator"
	int 0
	app_global_put

	// examples/reti/stakingPool.algo.ts:130
	// this.weightedMovingAverage.value = 0 as uint128
	byte 0x65776d61 // "ewma"
	byte 0x00000000000000000000000000000000
	app_global_put
	retsub

// gas()void
*abi_route_gas:
	// execute gas()void
	callsub gas
	int 1
	return

// gas(): void
//
// gas is a dummy no-op call that can be used to pool-up resource references and opcode cost
gas:
	proto 0 0
	retsub

// costForBoxStorage(totalNumBytes: uint64): uint64
costForBoxStorage:
	proto 1 1

	// examples/reti/stakingPool.algo.ts:142
	// return SCBOX_PERBOX + totalNumBytes * SCBOX_PERBYTE;
	pushint 2500
	frame_dig -1 // totalNumBytes: uint64
	pushint 400
	*
	+
	retsub

// initStorage(pay)void
*abi_route_initStorage:
	// mbrPayment: pay
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// argument 0 (mbrPayment) for initStorage must be a pay transaction
	assert

	// execute initStorage(pay)void
	callsub initStorage
	int 1
	return

// initStorage(mbrPayment: PayTxn): void
//
// Called after we're created and then funded, so we can create our large stakers ledger storage
// Caller has to get MBR amounts from ValidatorRegistry to know how much to fund us to cover the box storage cost
// If this is pool 1 AND the validator has specified a reward token, opt-in to that token
// so that the validator can seed the pool with future rewards of that token.
// @param mbrPayment payment from caller which covers mbr increase of new staking pools' storage
initStorage:
	proto 1 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 3

	// examples/reti/stakingPool.algo.ts:153
	// assert(!this.stakers.exists, 'staking pool already initialized')
	byte 0x7374616b657273 // "stakers"
	box_len
	swap
	pop
	!

	// staking pool already initialized
	assert

	// examples/reti/stakingPool.algo.ts:156
	// validatorConfig = sendMethodCall<typeof ValidatorRegistry.prototype.getValidatorConfig>({
	//       applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//       methodArgs: [this.validatorId.value],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0x75aff61d // method "getValidatorConfig(uint64)(uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:157
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:158
	// methodArgs: [this.validatorId.value]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0
	frame_bury 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:160
	// isTokenEligible = validatorConfig.rewardTokenId !== 0
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 153 8
	btoi
	int 0
	!=
	frame_bury 1 // isTokenEligible: bool

	// examples/reti/stakingPool.algo.ts:161
	// extraMBR = isTokenEligible && this.poolId.value === 1 ? ASSET_HOLDING_FEE : 0
	frame_dig 1 // isTokenEligible: bool
	dup
	bz *skip_and0
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	int 1
	==
	&&

*skip_and0:
	bz *ternary0_false
	pushint 100000
	b *ternary0_end

*ternary0_false:
	int 0

*ternary0_end:
	frame_bury 2 // extraMBR: uint64

	// examples/reti/stakingPool.algo.ts:162
	// PoolInitMbr =
	//       ALGORAND_ACCOUNT_MIN_BALANCE +
	//       extraMBR +
	//       this.costForBoxStorage(7 /* 'stakers' name */ + len<StakedInfo>() * MAX_STAKERS_PER_POOL)
	pushint 100000
	frame_dig 2 // extraMBR: uint64
	+
	pushint 12807
	callsub costForBoxStorage
	+
	frame_bury 3 // PoolInitMbr: uint64

	// examples/reti/stakingPool.algo.ts:168
	// verifyPayTxn(mbrPayment, { receiver: this.app.address, amount: PoolInitMbr })
	// verify receiver
	frame_dig -1 // mbrPayment: PayTxn
	gtxns Receiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"mbrPayment","field":"receiver","expected":"this.app.address"}
	assert

	// verify amount
	frame_dig -1 // mbrPayment: PayTxn
	gtxns Amount
	frame_dig 3 // PoolInitMbr: uint64
	==

	// transaction verification failed: {"txn":"mbrPayment","field":"amount","expected":"PoolInitMbr"}
	assert

	// examples/reti/stakingPool.algo.ts:169
	// this.stakers.create()
	byte 0x7374616b657273 // "stakers"
	pushint 12800
	box_create
	pop

	// *if1_condition
	// examples/reti/stakingPool.algo.ts:171
	// isTokenEligible && this.poolId.value === 1
	frame_dig 1 // isTokenEligible: bool
	dup
	bz *skip_and1
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	int 1
	==
	&&

*skip_and1:
	bz *if1_end

	// *if1_consequent
	// examples/reti/stakingPool.algo.ts:173
	// sendAssetTransfer({
	//         xferAsset: AssetID.fromUint64(validatorConfig.rewardTokenId),
	//         assetReceiver: this.app.address,
	//         assetAmount: 0,
	//       })
	itxn_begin
	pushint 4 // axfer
	itxn_field TypeEnum

	// examples/reti/stakingPool.algo.ts:174
	// xferAsset: AssetID.fromUint64(validatorConfig.rewardTokenId)
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 153 8
	btoi
	itxn_field XferAsset

	// examples/reti/stakingPool.algo.ts:175
	// assetReceiver: this.app.address
	global CurrentApplicationAddress
	itxn_field AssetReceiver

	// examples/reti/stakingPool.algo.ts:176
	// assetAmount: 0
	int 0
	itxn_field AssetAmount

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

*if1_end:
	retsub

// addStake(pay,address)uint64
*abi_route_addStake:
	// The ABI return prefix
	byte 0x151f7c75

	// staker: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (staker) for addStake must be a address
	assert

	// stakedAmountPayment: pay
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// argument 1 (stakedAmountPayment) for addStake must be a pay transaction
	assert

	// execute addStake(pay,address)uint64
	callsub addStake
	itob
	concat
	log
	int 1
	return

// addStake(stakedAmountPayment: PayTxn, staker: Address): uint64
//
// Adds stake to the given account.
// Can ONLY be called by the validator contract that created us
// Must receive payment from the validator contract for amount being staked.
//
// @param {PayTxn} stakedAmountPayment prior payment coming from validator contract to us on behalf of staker.
// @param {Address} staker - The account adding new stake
// @throws {Error} - Throws an error if the staking pool is full.
// @returns {uint64} new 'entry round' round number of stake add
addStake:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 4

	// examples/reti/stakingPool.algo.ts:192
	// assert(this.stakers.exists, 'staking pool must be initialized first')
	byte 0x7374616b657273 // "stakers"
	box_len
	swap
	pop

	// staking pool must be initialized first
	assert

	// examples/reti/stakingPool.algo.ts:195
	// assert(
	//       this.txn.sender === AppID.fromUint64(this.creatingValidatorContractAppId.value).address,
	//       'stake can only be added via the validator contract'
	//     )
	txn Sender
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	app_params_get AppAddress
	pop
	==

	// stake can only be added via the validator contract
	assert

	// examples/reti/stakingPool.algo.ts:199
	// assert(staker !== globals.zeroAddress)
	frame_dig -2 // staker: Address
	global ZeroAddress
	!=
	assert

	// examples/reti/stakingPool.algo.ts:202
	// this.checkIfBinClosed()
	callsub checkIfBinClosed

	// examples/reti/stakingPool.algo.ts:206
	// verifyPayTxn(stakedAmountPayment, {
	//       sender: AppID.fromUint64(this.creatingValidatorContractAppId.value).address,
	//       receiver: this.app.address,
	//       amount: stakedAmountPayment.amount,
	//     })
	// verify sender
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Sender
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	app_params_get AppAddress
	pop
	==

	// transaction verification failed: {"txn":"stakedAmountPayment","field":"sender","expected":"AppID.fromUint64(this.creatingValidatorContractAppId.value).address"}
	assert

	// verify receiver
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Receiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"stakedAmountPayment","field":"receiver","expected":"this.app.address"}
	assert

	// verify amount
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Amount
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Amount
	==

	// transaction verification failed: {"txn":"stakedAmountPayment","field":"amount","expected":"stakedAmountPayment.amount"}
	assert

	// examples/reti/stakingPool.algo.ts:215
	// entryRound = globals.round + ALGORAND_STAKING_BLOCK_DELAY
	global Round
	pushint 320
	+
	frame_bury 0 // entryRound: uint64

	// examples/reti/stakingPool.algo.ts:216
	// firstEmpty = 0
	int 0
	frame_bury 1 // firstEmpty: uint64

	// examples/reti/stakingPool.algo.ts:218
	// this.totalAlgoStaked.value += stakedAmountPayment.amount
	byte 0x7374616b6564 // "staked"
	app_global_get
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Amount
	+
	byte 0x7374616b6564 // "staked"
	swap
	app_global_put

	// examples/reti/stakingPool.algo.ts:220
	// roundsLeftInBin = this.binRoundStart.value + this.roundsPerDay.value - globals.round
	byte 0x62696e526f756e645374617274 // "binRoundStart"
	app_global_get
	byte 0x726f756e6473506572446179 // "roundsPerDay"
	app_global_get
	+
	global Round
	-
	frame_bury 2 // roundsLeftInBin: uint64

	// examples/reti/stakingPool.algo.ts:221
	// this.stakeAccumulator.value =
	//       this.stakeAccumulator.value + (stakedAmountPayment.amount as uint128) * (roundsLeftInBin as uint128)
	byte 0x7374616b65416363756d756c61746f72 // "stakeAccumulator"
	dup
	app_global_get
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Amount
	itob
	frame_dig 2 // roundsLeftInBin: uint64
	itob
	b*
	b+
	dup
	bitlen
	int 128
	<=

	// this.stakeAccumulator.value + (stakedAmountPayment.amount as uint128) * (roundsLeftInBin as uint128) overflowed 128 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 16
	-
	swap
	substring3
	app_global_put

	// examples/reti/stakingPool.algo.ts:225
	// for (let i = 0; i < this.stakers.value.length; i += 1)
	int 0
	frame_bury 3 // i: uint64

*for_0:
	// examples/reti/stakingPool.algo.ts:225
	// i < this.stakers.value.length
	frame_dig 3 // i: uint64
	int 200
	<
	bz *for_0_end

	// *if2_condition
	// examples/reti/stakingPool.algo.ts:226
	// globals.opcodeBudget < 300
	global OpcodeBudget
	int 300
	<
	bz *if2_end

	// *if2_consequent
	// examples/reti/stakingPool.algo.ts:227
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	pushint 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

*if2_end:
	// examples/reti/stakingPool.algo.ts:229
	// cmpStaker = clone(this.stakers.value[i])
	frame_dig 3 // i: uint64
	int 64
	* // acc * typeLength
	int 64
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_extract
	frame_bury 4 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// *if3_condition
	// examples/reti/stakingPool.algo.ts:230
	// cmpStaker.account === staker
	frame_dig 4 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 0 32
	frame_dig -2 // staker: Address
	==
	bz *if3_end

	// *if3_consequent
	// examples/reti/stakingPool.algo.ts:232
	// cmpStaker.balance += stakedAmountPayment.amount
	frame_dig 4 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	int 32 // headOffset
	frame_dig 4 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Amount
	+
	itob
	replace3
	frame_bury 4 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:233
	// cmpStaker.entryRound = entryRound
	frame_dig 4 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	pushint 56 // headOffset
	frame_dig 0 // entryRound: uint64
	itob
	replace3
	frame_bury 4 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:236
	// this.stakers.value[i] = cmpStaker
	frame_dig 3 // i: uint64
	int 64
	* // acc * typeLength
	frame_dig 4 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_replace

	// examples/reti/stakingPool.algo.ts:238
	// return entryRound;
	frame_dig 0 // entryRound: uint64
	b *addStake*return

*if3_end:
	// *if4_condition
	// examples/reti/stakingPool.algo.ts:240
	// firstEmpty === 0 && cmpStaker.account === globals.zeroAddress
	frame_dig 1 // firstEmpty: uint64
	int 0
	==
	dup
	bz *skip_and2
	frame_dig 4 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 0 32
	global ZeroAddress
	==
	&&

*skip_and2:
	bz *if4_end

	// *if4_consequent
	// examples/reti/stakingPool.algo.ts:241
	// firstEmpty = i + 1
	frame_dig 3 // i: uint64
	int 1
	+
	frame_bury 1 // firstEmpty: uint64

*if4_end:

*for_0_continue:
	// examples/reti/stakingPool.algo.ts:225
	// i += 1
	frame_dig 3 // i: uint64
	int 1
	+
	frame_bury 3 // i: uint64
	b *for_0

*for_0_end:
	// *if5_condition
	// examples/reti/stakingPool.algo.ts:245
	// firstEmpty === 0
	frame_dig 1 // firstEmpty: uint64
	int 0
	==
	bz *if5_end

	// *if5_consequent
	// Staking pool full
	err

*if5_end:
	// examples/reti/stakingPool.algo.ts:252
	// assert(stakedAmountPayment.amount >= this.minEntryStake.value, 'must stake at least the minimum for this pool')
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Amount
	byte 0x6d696e456e7472795374616b65 // "minEntryStake"
	app_global_get
	>=

	// must stake at least the minimum for this pool
	assert

	// examples/reti/stakingPool.algo.ts:254
	// assert(this.stakers.value[firstEmpty - 1].account === globals.zeroAddress)
	frame_dig 1 // firstEmpty: uint64
	int 1
	-
	int 64
	* // acc * typeLength
	int 0
	+
	int 32
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_extract
	global ZeroAddress
	==
	assert

	// examples/reti/stakingPool.algo.ts:255
	// this.stakers.value[firstEmpty - 1] = {
	//       account: staker,
	//       balance: stakedAmountPayment.amount,
	//       totalRewarded: 0,
	//       rewardTokenBalance: 0,
	//       entryRound: entryRound,
	//     }
	frame_dig 1 // firstEmpty: uint64
	int 1
	-
	int 64
	* // acc * typeLength
	frame_dig -2 // staker: Address
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Amount
	itob
	concat
	byte 0x0000000000000000
	concat
	byte 0x0000000000000000
	concat
	frame_dig 0 // entryRound: uint64
	itob
	concat
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_replace

	// examples/reti/stakingPool.algo.ts:262
	// this.numStakers.value += 1
	byte 0x6e756d5374616b657273 // "numStakers"
	app_global_get
	int 1
	+
	byte 0x6e756d5374616b657273 // "numStakers"
	swap
	app_global_put

	// examples/reti/stakingPool.algo.ts:263
	// return entryRound;
	frame_dig 0 // entryRound: uint64

*addStake*return:
	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 4
	retsub

// removeStake(address,uint64)void
*abi_route_removeStake:
	// amountToUnstake: uint64
	txna ApplicationArgs 2
	btoi

	// staker: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (staker) for removeStake must be a address
	assert

	// execute removeStake(address,uint64)void
	callsub removeStake
	int 1
	return

// removeStake(staker: Address, amountToUnstake: uint64): void
//
// Removes stake on behalf of caller (removing own stake).  If any token rewards exist, those are always sent in
// full. Also notifies the validator contract for this pools validator of the staker / balance changes.
//
// @param {Address} staker - account to remove.  normally same as sender, but the validator owner or manager can also call
// this to remove the specified staker explicitly. The removed stake MUST only go to the staker of course.  This is
// so a validator can shut down a poool and refund the stakers.  It can also be used to kick out stakers who no longer
// meet the gating requirements (determined by the node daemon).
// @param {uint64} amountToUnstake - The amount of stake to be removed.  Specify 0 to remove all stake.
// @throws {Error} If the account has insufficient balance or if the account is not found.
removeStake:
	proto 2 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 6

	// *if6_condition
	// examples/reti/stakingPool.algo.ts:280
	// staker !== this.txn.sender
	frame_dig -1 // staker: Address
	txn Sender
	!=
	bz *if6_end

	// *if6_consequent
	// examples/reti/stakingPool.algo.ts:281
	// assert(
	//         this.isOwnerOrManagerCaller(),
	//         'If staker is not sender in removeStake call, then sender MUST be owner or manager of validator'
	//       )
	callsub isOwnerOrManagerCaller

	// If staker is not sender in removeStake call, then sender MUST be owner or manager of validator
	assert

*if6_end:
	// examples/reti/stakingPool.algo.ts:287
	// this.checkIfBinClosed()
	callsub checkIfBinClosed

	// examples/reti/stakingPool.algo.ts:289
	// for (let i = 0; i < this.stakers.value.length; i += 1)
	int 0
	frame_bury 0 // i: uint64

*for_1:
	// examples/reti/stakingPool.algo.ts:289
	// i < this.stakers.value.length
	frame_dig 0 // i: uint64
	int 200
	<
	bz *for_1_end

	// *if7_condition
	// examples/reti/stakingPool.algo.ts:290
	// globals.opcodeBudget < 300
	global OpcodeBudget
	int 300
	<
	bz *if7_end

	// *if7_consequent
	// examples/reti/stakingPool.algo.ts:291
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	pushint 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

*if7_end:
	// examples/reti/stakingPool.algo.ts:293
	// cmpStaker = clone(this.stakers.value[i])
	frame_dig 0 // i: uint64
	int 64
	* // acc * typeLength
	int 64
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_extract
	frame_bury 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// *if8_condition
	// examples/reti/stakingPool.algo.ts:294
	// cmpStaker.account === staker
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 0 32
	frame_dig -1 // staker: Address
	==
	bz *if8_end

	// *if8_consequent
	// *if9_condition
	// examples/reti/stakingPool.algo.ts:295
	// amountToUnstake === 0
	frame_dig -2 // amountToUnstake: uint64
	int 0
	==
	bz *if9_end

	// *if9_consequent
	// examples/reti/stakingPool.algo.ts:297
	// amountToUnstake = cmpStaker.balance
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	frame_bury -2 // amountToUnstake: uint64

*if9_end:
	// *if10_condition
	// examples/reti/stakingPool.algo.ts:299
	// cmpStaker.balance < amountToUnstake
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	frame_dig -2 // amountToUnstake: uint64
	<
	bz *if10_end

	// *if10_consequent
	// Insufficient balance
	err

*if10_end:
	// examples/reti/stakingPool.algo.ts:302
	// cmpStaker.balance -= amountToUnstake
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	int 32 // headOffset
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	frame_dig -2 // amountToUnstake: uint64
	-
	itob
	replace3
	frame_bury 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:303
	// this.totalAlgoStaked.value -= amountToUnstake
	byte 0x7374616b6564 // "staked"
	app_global_get
	frame_dig -2 // amountToUnstake: uint64
	-
	byte 0x7374616b6564 // "staked"
	swap
	app_global_put

	// examples/reti/stakingPool.algo.ts:305
	// amountRewardTokenRemoved = 0
	int 0
	frame_bury 2 // amountRewardTokenRemoved: uint64

	// *if11_condition
	// examples/reti/stakingPool.algo.ts:306
	// cmpStaker.rewardTokenBalance > 0
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 48 8
	btoi
	int 0
	>
	bz *if11_end

	// *if11_consequent
	// *if12_condition
	// examples/reti/stakingPool.algo.ts:308
	// this.poolId.value === 1
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	int 1
	==
	bz *if12_else

	// *if12_consequent
	// examples/reti/stakingPool.algo.ts:309
	// validatorConfig = sendMethodCall<typeof ValidatorRegistry.prototype.getValidatorConfig>({
	//               applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//               methodArgs: [this.validatorId.value],
	//             })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0x75aff61d // method "getValidatorConfig(uint64)(uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:310
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:311
	// methodArgs: [this.validatorId.value]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0
	frame_bury 3 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:317
	// sendAssetTransfer({
	//               xferAsset: AssetID.fromUint64(validatorConfig.rewardTokenId),
	//               assetReceiver: staker,
	//               assetAmount: cmpStaker.rewardTokenBalance,
	//             })
	itxn_begin
	pushint 4 // axfer
	itxn_field TypeEnum

	// examples/reti/stakingPool.algo.ts:318
	// xferAsset: AssetID.fromUint64(validatorConfig.rewardTokenId)
	frame_dig 3 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 153 8
	btoi
	itxn_field XferAsset

	// examples/reti/stakingPool.algo.ts:319
	// assetReceiver: staker
	frame_dig -1 // staker: Address
	itxn_field AssetReceiver

	// examples/reti/stakingPool.algo.ts:320
	// assetAmount: cmpStaker.rewardTokenBalance
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 48 8
	btoi
	itxn_field AssetAmount

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/stakingPool.algo.ts:322
	// amountRewardTokenRemoved = cmpStaker.rewardTokenBalance
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 48 8
	btoi
	frame_bury 2 // amountRewardTokenRemoved: uint64

	// examples/reti/stakingPool.algo.ts:323
	// cmpStaker.rewardTokenBalance = 0
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	byte 0x0000000000000000
	replace2 48
	frame_bury 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	b *if12_end

*if12_else:
	// examples/reti/stakingPool.algo.ts:328
	// amountRewardTokenRemoved = cmpStaker.rewardTokenBalance
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 48 8
	btoi
	frame_bury 2 // amountRewardTokenRemoved: uint64

	// examples/reti/stakingPool.algo.ts:329
	// cmpStaker.rewardTokenBalance = 0
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	byte 0x0000000000000000
	replace2 48
	frame_bury 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)

*if12_end:

*if11_end:
	// examples/reti/stakingPool.algo.ts:334
	// assert(
	//           cmpStaker.balance === 0 || cmpStaker.balance >= this.minEntryStake.value,
	//           'cannot reduce balance below minimum allowed stake unless all is removed'
	//         )
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	int 0
	==
	dup
	bnz *skip_or0
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	byte 0x6d696e456e7472795374616b65 // "minEntryStake"
	app_global_get
	>=
	||

*skip_or0:
	// cannot reduce balance below minimum allowed stake unless all is removed
	assert

	// examples/reti/stakingPool.algo.ts:342
	// sendPayment({
	//           amount: amountToUnstake,
	//           receiver: staker,
	//           note: 'unstaked',
	//         })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// examples/reti/stakingPool.algo.ts:343
	// amount: amountToUnstake
	frame_dig -2 // amountToUnstake: uint64
	itxn_field Amount

	// examples/reti/stakingPool.algo.ts:344
	// receiver: staker
	frame_dig -1 // staker: Address
	itxn_field Receiver

	// examples/reti/stakingPool.algo.ts:345
	// note: 'unstaked'
	pushbytes 0x756e7374616b6564 // "unstaked"
	itxn_field Note

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/stakingPool.algo.ts:347
	// stakerRemoved = false
	int 0
	frame_bury 4 // stakerRemoved: bool

	// *if13_condition
	// examples/reti/stakingPool.algo.ts:348
	// cmpStaker.balance === 0
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	int 0
	==
	bz *if13_end

	// *if13_consequent
	// examples/reti/stakingPool.algo.ts:350
	// this.numStakers.value -= 1
	byte 0x6e756d5374616b657273 // "numStakers"
	app_global_get
	int 1
	-
	byte 0x6e756d5374616b657273 // "numStakers"
	swap
	app_global_put

	// examples/reti/stakingPool.algo.ts:351
	// cmpStaker.account = globals.zeroAddress
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	int 0
	global ZeroAddress
	replace3
	frame_bury 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:352
	// cmpStaker.totalRewarded = 0
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	byte 0x0000000000000000
	replace2 40
	frame_bury 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:353
	// cmpStaker.rewardTokenBalance = 0
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	byte 0x0000000000000000
	replace2 48
	frame_bury 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:354
	// stakerRemoved = true
	int 1
	frame_bury 4 // stakerRemoved: bool

*if13_end:
	// examples/reti/stakingPool.algo.ts:357
	// this.stakers.value[i] = cmpStaker
	frame_dig 0 // i: uint64
	int 64
	* // acc * typeLength
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_replace

	// examples/reti/stakingPool.algo.ts:359
	// roundsLeftInBin = this.binRoundStart.value + this.roundsPerDay.value - globals.round
	byte 0x62696e526f756e645374617274 // "binRoundStart"
	app_global_get
	byte 0x726f756e6473506572446179 // "roundsPerDay"
	app_global_get
	+
	global Round
	-
	frame_bury 5 // roundsLeftInBin: uint64

	// examples/reti/stakingPool.algo.ts:360
	// subtractAmount: uint128 = (amountToUnstake as uint128) * (roundsLeftInBin as uint128)
	frame_dig -2 // amountToUnstake: uint64
	itob
	frame_dig 5 // roundsLeftInBin: uint64
	itob
	b*
	dup
	bitlen
	int 128
	<=

	// (amountToUnstake as uint128) * (roundsLeftInBin as uint128) overflowed 128 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 16
	-
	swap
	substring3
	frame_bury 6 // subtractAmount: uint128

	// examples/reti/stakingPool.algo.ts:361
	// this.stakeAccumulator.value = this.stakeAccumulator.value - subtractAmount
	byte 0x7374616b65416363756d756c61746f72 // "stakeAccumulator"
	dup
	app_global_get
	frame_dig 6 // subtractAmount: uint128
	b-
	dup
	bitlen
	int 128
	<=

	// this.stakeAccumulator.value - subtractAmount overflowed 128 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 16
	-
	swap
	substring3
	app_global_put

	// examples/reti/stakingPool.algo.ts:366
	// sendMethodCall<typeof ValidatorRegistry.prototype.stakeRemoved>({
	//           applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//           methodArgs: [
	//             { id: this.validatorId.value, poolId: this.poolId.value, poolAppId: this.app.id },
	//             staker,
	//             amountToUnstake,
	//             amountRewardTokenRemoved,
	//             stakerRemoved,
	//           ],
	//         })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0xa2dc51b5 // method "stakeRemoved((uint64,uint64,uint64),address,uint64,uint64,bool)void"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:367
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:368
	// methodArgs: [
	//             { id: this.validatorId.value, poolId: this.poolId.value, poolAppId: this.app.id },
	//             staker,
	//             amountToUnstake,
	//             amountRewardTokenRemoved,
	//             stakerRemoved,
	//           ]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	itob
	concat
	txna Applications 0
	itob
	concat
	itxn_field ApplicationArgs
	frame_dig -1 // staker: Address
	itxn_field ApplicationArgs
	frame_dig -2 // amountToUnstake: uint64
	itob
	itxn_field ApplicationArgs
	frame_dig 2 // amountRewardTokenRemoved: uint64
	itob
	itxn_field ApplicationArgs
	frame_dig 4 // stakerRemoved: bool
	byte 0x00
	int 0
	uncover 2
	setbit
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/stakingPool.algo.ts:376
	// return;
	retsub

*if8_end:

*for_1_continue:
	// examples/reti/stakingPool.algo.ts:289
	// i += 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64
	b *for_1

*for_1_end:
	// account not found
	err
	retsub

// claimTokens()void
*abi_route_claimTokens:
	// execute claimTokens()void
	callsub claimTokens
	int 1
	return

// claimTokens(): void
//
// Claims all the available reward tokens a staker has available, sending their entire balance to the staker from
// pool 1 (either directly, or via validator->pool1 to pay it out)
// Also notifies the validator contract for this pools validator of the staker / balance changes.
claimTokens:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 4

	// examples/reti/stakingPool.algo.ts:391
	// staker = this.txn.sender
	txn Sender
	frame_bury 0 // staker: address

	// examples/reti/stakingPool.algo.ts:393
	// for (let i = 0; i < this.stakers.value.length; i += 1)
	int 0
	frame_bury 1 // i: uint64

*for_2:
	// examples/reti/stakingPool.algo.ts:393
	// i < this.stakers.value.length
	frame_dig 1 // i: uint64
	int 200
	<
	bz *for_2_end

	// *if14_condition
	// examples/reti/stakingPool.algo.ts:394
	// globals.opcodeBudget < 300
	global OpcodeBudget
	int 300
	<
	bz *if14_end

	// *if14_consequent
	// examples/reti/stakingPool.algo.ts:395
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	pushint 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

*if14_end:
	// examples/reti/stakingPool.algo.ts:397
	// cmpStaker = clone(this.stakers.value[i])
	frame_dig 1 // i: uint64
	int 64
	* // acc * typeLength
	int 64
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_extract
	frame_bury 2 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// *if15_condition
	// examples/reti/stakingPool.algo.ts:398
	// cmpStaker.account === staker
	frame_dig 2 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 0 32
	frame_dig 0 // staker: address
	==
	bz *if15_end

	// *if15_consequent
	// *if16_condition
	// examples/reti/stakingPool.algo.ts:399
	// cmpStaker.rewardTokenBalance === 0
	frame_dig 2 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 48 8
	btoi
	int 0
	==
	bz *if16_end

	// *if16_consequent
	// examples/reti/stakingPool.algo.ts:400
	// return;
	retsub

*if16_end:
	// examples/reti/stakingPool.algo.ts:402
	// amountRewardTokenRemoved = 0
	int 0
	frame_bury 3 // amountRewardTokenRemoved: uint64

	// *if17_condition
	// examples/reti/stakingPool.algo.ts:404
	// this.poolId.value === 1
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	int 1
	==
	bz *if17_else

	// *if17_consequent
	// examples/reti/stakingPool.algo.ts:405
	// validatorConfig = sendMethodCall<typeof ValidatorRegistry.prototype.getValidatorConfig>({
	//             applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//             methodArgs: [this.validatorId.value],
	//           })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0x75aff61d // method "getValidatorConfig(uint64)(uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:406
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:407
	// methodArgs: [this.validatorId.value]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0
	frame_bury 4 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:412
	// sendAssetTransfer({
	//             xferAsset: AssetID.fromUint64(validatorConfig.rewardTokenId),
	//             assetReceiver: staker,
	//             assetAmount: cmpStaker.rewardTokenBalance,
	//           })
	itxn_begin
	pushint 4 // axfer
	itxn_field TypeEnum

	// examples/reti/stakingPool.algo.ts:413
	// xferAsset: AssetID.fromUint64(validatorConfig.rewardTokenId)
	frame_dig 4 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 153 8
	btoi
	itxn_field XferAsset

	// examples/reti/stakingPool.algo.ts:414
	// assetReceiver: staker
	frame_dig 0 // staker: address
	itxn_field AssetReceiver

	// examples/reti/stakingPool.algo.ts:415
	// assetAmount: cmpStaker.rewardTokenBalance
	frame_dig 2 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 48 8
	btoi
	itxn_field AssetAmount

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/stakingPool.algo.ts:417
	// amountRewardTokenRemoved = cmpStaker.rewardTokenBalance
	frame_dig 2 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 48 8
	btoi
	frame_bury 3 // amountRewardTokenRemoved: uint64

	// examples/reti/stakingPool.algo.ts:418
	// cmpStaker.rewardTokenBalance = 0
	frame_dig 2 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	byte 0x0000000000000000
	replace2 48
	frame_bury 2 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	b *if17_end

*if17_else:
	// examples/reti/stakingPool.algo.ts:423
	// amountRewardTokenRemoved = cmpStaker.rewardTokenBalance
	frame_dig 2 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 48 8
	btoi
	frame_bury 3 // amountRewardTokenRemoved: uint64

	// examples/reti/stakingPool.algo.ts:424
	// cmpStaker.rewardTokenBalance = 0
	frame_dig 2 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	byte 0x0000000000000000
	replace2 48
	frame_bury 2 // cmpStaker: (address,uint64,uint64,uint64,uint64)

*if17_end:
	// examples/reti/stakingPool.algo.ts:428
	// this.stakers.value[i] = cmpStaker
	frame_dig 1 // i: uint64
	int 64
	* // acc * typeLength
	frame_dig 2 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_replace

	// examples/reti/stakingPool.algo.ts:433
	// sendMethodCall<typeof ValidatorRegistry.prototype.stakeRemoved>({
	//           applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//           methodArgs: [
	//             { id: this.validatorId.value, poolId: this.poolId.value, poolAppId: this.app.id },
	//             staker,
	//             0, // no algo removed
	//             amountRewardTokenRemoved,
	//             false, // staker isn't being removed.
	//           ],
	//         })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0xa2dc51b5 // method "stakeRemoved((uint64,uint64,uint64),address,uint64,uint64,bool)void"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:434
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:435
	// methodArgs: [
	//             { id: this.validatorId.value, poolId: this.poolId.value, poolAppId: this.app.id },
	//             staker,
	//             0, // no algo removed
	//             amountRewardTokenRemoved,
	//             false, // staker isn't being removed.
	//           ]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	itob
	concat
	txna Applications 0
	itob
	concat
	itxn_field ApplicationArgs
	frame_dig 0 // staker: address
	itxn_field ApplicationArgs
	byte 0x0000000000000000
	itxn_field ApplicationArgs
	frame_dig 3 // amountRewardTokenRemoved: uint64
	itob
	itxn_field ApplicationArgs
	int 0
	byte 0x00
	int 0
	uncover 2
	setbit
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/stakingPool.algo.ts:443
	// return;
	retsub

*if15_end:

*for_2_continue:
	// examples/reti/stakingPool.algo.ts:393
	// i += 1
	frame_dig 1 // i: uint64
	int 1
	+
	frame_bury 1 // i: uint64
	b *for_2

*for_2_end:
	// account not found
	err
	retsub

// getStakerInfo(address)(address,uint64,uint64,uint64,uint64)
*abi_route_getStakerInfo:
	// The ABI return prefix
	byte 0x151f7c75

	// staker: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (staker) for getStakerInfo must be a address
	assert

	// execute getStakerInfo(address)(address,uint64,uint64,uint64,uint64)
	callsub getStakerInfo
	concat
	log
	int 1
	return

// getStakerInfo(staker: Address): StakedInfo
//
// Retrieves the staked information for a given staker.
//
// @param {Address} staker - The address of the staker.
// @returns {StakedInfo} - The staked information for the given staker.
// @throws {Error} - If the staker's account is not found.
getStakerInfo:
	proto 1 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/reti/stakingPool.algo.ts:458
	// for (let i = 0; i < this.stakers.value.length; i += 1)
	int 0
	frame_bury 0 // i: uint64

*for_3:
	// examples/reti/stakingPool.algo.ts:458
	// i < this.stakers.value.length
	frame_dig 0 // i: uint64
	int 200
	<
	bz *for_3_end

	// *if18_condition
	// examples/reti/stakingPool.algo.ts:459
	// globals.opcodeBudget < 200
	global OpcodeBudget
	int 200
	<
	bz *if18_end

	// *if18_consequent
	// examples/reti/stakingPool.algo.ts:460
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	pushint 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

*if18_end:
	// *if19_condition
	// examples/reti/stakingPool.algo.ts:462
	// this.stakers.value[i].account === staker
	frame_dig 0 // i: uint64
	int 64
	* // acc * typeLength
	int 0
	+
	int 32
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_extract
	frame_dig -1 // staker: Address
	==
	bz *if19_end

	// *if19_consequent
	// examples/reti/stakingPool.algo.ts:463
	// return this.stakers.value[i];
	frame_dig 0 // i: uint64
	int 64
	* // acc * typeLength
	int 64
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_extract
	b *getStakerInfo*return

*if19_end:

*for_3_continue:
	// examples/reti/stakingPool.algo.ts:458
	// i += 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64
	b *for_3

*for_3_end:
	// account not found
	err

*getStakerInfo*return:
	// set the subroutine return value
	frame_bury 0
	retsub

// payTokenReward(address,uint64,uint64)void
*abi_route_payTokenReward:
	// amountToSend: uint64
	txna ApplicationArgs 3
	btoi

	// rewardToken: uint64
	txna ApplicationArgs 2
	btoi

	// staker: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 2 (staker) for payTokenReward must be a address
	assert

	// execute payTokenReward(address,uint64,uint64)void
	callsub payTokenReward
	int 1
	return

// payTokenReward(staker: Address, rewardToken: uint64, amountToSend: uint64): void
//
// [Internal protocol method] Remove a specified amount of 'community token' rewards for a staker.
// This can ONLY be called by our validator and only if we're pool 1 - with the token.
// Note: this can also be called by validator as part of OWNER wanting to send the reward tokens
// somewhere else (ie if they're sunsetting their validator and need the reward tokens back).
// It's up to the validator to ensure that the balance in rewardTokenHeldBack is honored.
// @param staker - the staker account to send rewards to
// @param rewardToken - id of reward token (to avoid re-entrancy in calling validator back to get id)
// @param amountToSend - amount to send the staker (there is significant trust here(!) - also why only validator can call us
payTokenReward:
	proto 3 0

	// examples/reti/stakingPool.algo.ts:481
	// assert(
	//       this.txn.sender === AppID.fromUint64(this.creatingValidatorContractAppId.value).address,
	//       'this can only be called via the validator contract'
	//     )
	txn Sender
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	app_params_get AppAddress
	pop
	==

	// this can only be called via the validator contract
	assert

	// examples/reti/stakingPool.algo.ts:485
	// assert(this.poolId.value === 1, 'must be pool 1 in order to be called to pay out token rewards')
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	int 1
	==

	// must be pool 1 in order to be called to pay out token rewards
	assert

	// examples/reti/stakingPool.algo.ts:486
	// assert(rewardToken !== 0, 'can only claim token rewards from validator that has them')
	frame_dig -2 // rewardToken: uint64
	int 0
	!=

	// can only claim token rewards from validator that has them
	assert

	// examples/reti/stakingPool.algo.ts:489
	// sendAssetTransfer({
	//       xferAsset: AssetID.fromUint64(rewardToken),
	//       assetReceiver: staker,
	//       assetAmount: amountToSend,
	//     })
	itxn_begin
	pushint 4 // axfer
	itxn_field TypeEnum

	// examples/reti/stakingPool.algo.ts:490
	// xferAsset: AssetID.fromUint64(rewardToken)
	frame_dig -2 // rewardToken: uint64
	itxn_field XferAsset

	// examples/reti/stakingPool.algo.ts:491
	// assetReceiver: staker
	frame_dig -1 // staker: Address
	itxn_field AssetReceiver

	// examples/reti/stakingPool.algo.ts:492
	// assetAmount: amountToSend
	frame_dig -3 // amountToSend: uint64
	itxn_field AssetAmount

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// updateAlgodVer(string)void
*abi_route_updateAlgodVer:
	// algodVer: string
	txna ApplicationArgs 1
	extract 2 0

	// execute updateAlgodVer(string)void
	callsub updateAlgodVer
	int 1
	return

// updateAlgodVer(algodVer: string): void
//
// Update the (honor system) algod version for the node associated to this pool.  The node management daemon
// should compare its current nodes version to the version stored in global state, updating when different.
// The reti node daemon composes its own version string using format:
// {major}.{minor}.{build} {branch} [{commit hash}],
// ie: 3.22.0 rel/stable [6b508975]
// [ ONLY OWNER OR MANAGER CAN CALL ]
// @param {string} algodVer - string representing the algorand node daemon version (reti node daemon composes its own meta version)
updateAlgodVer:
	proto 1 0

	// examples/reti/stakingPool.algo.ts:506
	// assert(this.isOwnerOrManagerCaller(), 'can only be called by owner or manager of validator')
	callsub isOwnerOrManagerCaller

	// can only be called by owner or manager of validator
	assert

	// examples/reti/stakingPool.algo.ts:507
	// this.algodVer.value = algodVer
	pushbytes 0x616c676f64566572 // "algodVer"
	frame_dig -1 // algodVer: string
	app_global_put
	retsub

// epochBalanceUpdate()void
*abi_route_epochBalanceUpdate:
	// execute epochBalanceUpdate()void
	callsub epochBalanceUpdate
	int 1
	return

// epochBalanceUpdate(): void
//
// Updates the balance of stakers in the pool based on the received 'rewards' (current balance vs known staked balance)
// stakers outstanding balance is adjusted based on their % of stake and time in the current epoch - so that balance
// compounds over time and staker can remove that amount at will.
// The validator is paid their percentage each epoch payout.
//
// Note: ANYONE can call this.
epochBalanceUpdate:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 36

	// examples/reti/stakingPool.algo.ts:520
	// validatorConfig = sendMethodCall<typeof ValidatorRegistry.prototype.getValidatorConfig>({
	//       applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//       methodArgs: [this.validatorId.value],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0x75aff61d // method "getValidatorConfig(uint64)(uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:521
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:522
	// methodArgs: [this.validatorId.value]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0
	frame_bury 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:529
	// epochRoundLength = validatorConfig.epochRoundLength as uint64
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 169 4
	btoi
	frame_bury 1 // epochRoundLength: uint64

	// examples/reti/stakingPool.algo.ts:530
	// curRound = globals.round
	global Round
	frame_bury 2 // curRound: uint64

	// examples/reti/stakingPool.algo.ts:531
	// thisEpochBegin = curRound - (curRound % epochRoundLength)
	frame_dig 2 // curRound: uint64
	frame_dig 2 // curRound: uint64
	frame_dig 1 // epochRoundLength: uint64
	%
	-
	frame_bury 3 // thisEpochBegin: uint64

	// *if20_condition
	// examples/reti/stakingPool.algo.ts:534
	// this.lastPayout.exists
	txna Applications 0
	byte 0x6c6173745061796f7574 // "lastPayout"
	app_global_get_ex
	swap
	pop
	bz *if20_end

	// *if20_consequent
	// examples/reti/stakingPool.algo.ts:535
	// lastPayoutEpoch = this.lastPayout.value - (this.lastPayout.value % epochRoundLength)
	byte 0x6c6173745061796f7574 // "lastPayout"
	app_global_get
	byte 0x6c6173745061796f7574 // "lastPayout"
	app_global_get
	frame_dig 1 // epochRoundLength: uint64
	%
	-
	frame_bury 4 // lastPayoutEpoch: uint64

	// examples/reti/stakingPool.algo.ts:539
	// assert(lastPayoutEpoch !== thisEpochBegin, "can't call epochBalanceUpdate in same epoch as prior call")
	frame_dig 4 // lastPayoutEpoch: uint64
	frame_dig 3 // thisEpochBegin: uint64
	!=

	// can't call epochBalanceUpdate in same epoch as prior call
	assert

*if20_end:
	// examples/reti/stakingPool.algo.ts:542
	// this.checkIfBinClosed()
	callsub checkIfBinClosed

	// examples/reti/stakingPool.algo.ts:545
	// this.lastPayout.value = curRound
	byte 0x6c6173745061796f7574 // "lastPayout"
	frame_dig 2 // curRound: uint64
	app_global_put

	// examples/reti/stakingPool.algo.ts:546
	// this.epochNumber.value += 1
	byte 0x65706f63684e756d626572 // "epochNumber"
	app_global_get
	int 1
	+
	byte 0x65706f63684e756d626572 // "epochNumber"
	swap
	app_global_put

	// examples/reti/stakingPool.algo.ts:551
	// isTokenEligible = validatorConfig.rewardTokenId !== 0
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 153 8
	btoi
	int 0
	!=
	frame_bury 5 // isTokenEligible: bool

	// examples/reti/stakingPool.algo.ts:552
	// poolOneAppID = this.app.id
	txna Applications 0
	frame_bury 6 // poolOneAppID: uint64

	// examples/reti/stakingPool.algo.ts:553
	// poolOneAddress = this.app.address
	global CurrentApplicationAddress
	frame_bury 7 // poolOneAddress: address

	// *if21_condition
	// examples/reti/stakingPool.algo.ts:558
	// isTokenEligible
	frame_dig 5 // isTokenEligible: bool
	bz *if21_end

	// *if21_consequent
	// *if22_condition
	// examples/reti/stakingPool.algo.ts:559
	// this.poolId.value !== 1
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	int 1
	!=
	bz *if22_end

	// *if22_consequent
	// examples/reti/stakingPool.algo.ts:561
	// poolOneAppID = sendMethodCall<typeof ValidatorRegistry.prototype.getPoolAppId>({
	//           applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//           methodArgs: [this.validatorId.value, 1],
	//         })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0x572767d1 // method "getPoolAppId(uint64,uint64)uint64"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:562
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:563
	// methodArgs: [this.validatorId.value, 1]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	itxn_field ApplicationArgs
	pushbytes 0x0000000000000001
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0
	btoi
	frame_bury 6 // poolOneAppID: uint64

	// examples/reti/stakingPool.algo.ts:565
	// poolOneAddress = AppID.fromUint64(poolOneAppID).address
	frame_dig 6 // poolOneAppID: uint64
	app_params_get AppAddress
	pop
	frame_bury 7 // poolOneAddress: address

*if22_end:
	// *if23_condition
	// examples/reti/stakingPool.algo.ts:570
	// this.poolId.value === 1
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	int 1
	==
	bz *if23_else

	// *if23_consequent
	// examples/reti/stakingPool.algo.ts:571
	// tokenPayoutRatio = sendMethodCall<typeof ValidatorRegistry.prototype.setTokenPayoutRatio>({
	//           applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//           methodArgs: [this.validatorId.value],
	//         })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0x4df8d86e // method "setTokenPayoutRatio(uint64)(uint64[24],uint64)"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:572
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:573
	// methodArgs: [this.validatorId.value]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0
	frame_bury 8 // tokenPayoutRatio: PoolTokenPayoutRatio
	b *if23_end

*if23_else:
	// examples/reti/stakingPool.algo.ts:577
	// tokenPayoutRatio = sendMethodCall<typeof StakingPool.prototype.proxiedSetTokenPayoutRatio>({
	//           applicationID: AppID.fromUint64(poolOneAppID),
	//           methodArgs: [{ id: this.validatorId.value, poolId: this.poolId.value, poolAppId: this.app.id }],
	//         })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0x0c2245e1 // method "proxiedSetTokenPayoutRatio((uint64,uint64,uint64))(uint64[24],uint64)"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:578
	// applicationID: AppID.fromUint64(poolOneAppID)
	frame_dig 6 // poolOneAppID: uint64
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:579
	// methodArgs: [{ id: this.validatorId.value, poolId: this.poolId.value, poolAppId: this.app.id }]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	itob
	concat
	txna Applications 0
	itob
	concat
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0
	frame_bury 8 // tokenPayoutRatio: PoolTokenPayoutRatio

*if23_end:

*if21_end:
	// examples/reti/stakingPool.algo.ts:586
	// validatorState = sendMethodCall<typeof ValidatorRegistry.prototype.getValidatorState>({
	//       applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//       methodArgs: [this.validatorId.value],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	pushbytes 0x1f2f0109 // method "getValidatorState(uint64)(uint16,uint64,uint64,uint64)"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:587
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:588
	// methodArgs: [this.validatorId.value]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0
	frame_bury 9 // validatorState: (uint16,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:590
	// rewardTokenHeldBack = validatorState.rewardTokenHeldBack
	frame_dig 9 // validatorState: (uint16,uint64,uint64,uint64)
	extract 18 8
	btoi
	frame_bury 10 // rewardTokenHeldBack: uint64

	// examples/reti/stakingPool.algo.ts:596
	// algoRewardAvail = this.app.address.balance - this.totalAlgoStaked.value - this.app.address.minBalance
	global CurrentApplicationAddress
	acct_params_get AcctBalance
	pop
	byte 0x7374616b6564 // "staked"
	app_global_get
	-
	global CurrentApplicationAddress
	acct_params_get AcctMinBalance
	pop
	-
	frame_bury 11 // algoRewardAvail: uint64

	// examples/reti/stakingPool.algo.ts:597
	// isPoolSaturated = false
	int 0
	frame_bury 12 // isPoolSaturated: bool

	// examples/reti/stakingPool.algo.ts:598
	// algoSaturationAmt = this.algoSaturationLevel()
	callsub algoSaturationLevel
	frame_bury 13 // algoSaturationAmt: uint64

	// *if24_condition
	// examples/reti/stakingPool.algo.ts:606
	// validatorState.totalAlgoStaked > algoSaturationAmt
	frame_dig 9 // validatorState: (uint16,uint64,uint64,uint64)
	extract 10 8
	btoi
	frame_dig 13 // algoSaturationAmt: uint64
	>
	bz *if24_end

	// *if24_consequent
	// examples/reti/stakingPool.algo.ts:607
	// isPoolSaturated = true
	int 1
	frame_bury 12 // isPoolSaturated: bool

*if24_end:
	// examples/reti/stakingPool.algo.ts:613
	// tokenRewardAvail = 0
	int 0
	frame_bury 14 // tokenRewardAvail: uint64

	// examples/reti/stakingPool.algo.ts:614
	// tokenRewardPaidOut = 0
	int 0
	frame_bury 15 // tokenRewardPaidOut: uint64

	// examples/reti/stakingPool.algo.ts:615
	// validatorCommissionPaidOut = 0
	int 0
	frame_bury 16 // validatorCommissionPaidOut: uint64

	// examples/reti/stakingPool.algo.ts:616
	// excessToFeeSink = 0
	int 0
	frame_bury 17 // excessToFeeSink: uint64

	// *if25_condition
	// examples/reti/stakingPool.algo.ts:617
	// isTokenEligible
	frame_dig 5 // isTokenEligible: bool
	bz *if25_end

	// *if25_consequent
	// examples/reti/stakingPool.algo.ts:618
	// tokenRewardBal =
	//         poolOneAddress.assetBalance(AssetID.fromUint64(validatorConfig.rewardTokenId)) - rewardTokenHeldBack
	frame_dig 7 // poolOneAddress: address
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 153 8
	btoi
	asset_holding_get AssetBalance
	pop
	frame_dig 10 // rewardTokenHeldBack: uint64
	-
	frame_bury 18 // tokenRewardBal: uint64

	// *if26_condition
	// examples/reti/stakingPool.algo.ts:623
	// tokenRewardBal >= validatorConfig.rewardPerPayout
	frame_dig 18 // tokenRewardBal: uint64
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 161 8
	btoi
	>=
	bz *if26_end

	// *if26_consequent
	// examples/reti/stakingPool.algo.ts:629
	// ourPoolPctOfWhole = tokenPayoutRatio.poolPctOfWhole[this.poolId.value - 1]
	frame_dig 8 // tokenPayoutRatio: PoolTokenPayoutRatio
	int 0
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	int 1
	-
	pushint 8
	* // acc * typeLength
	+
	pushint 8
	extract3
	btoi
	frame_bury 19 // ourPoolPctOfWhole: uint64

	// examples/reti/stakingPool.algo.ts:632
	// tokenRewardAvail = wideRatio([validatorConfig.rewardPerPayout, ourPoolPctOfWhole], [1_000_000])
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 161 8
	btoi
	frame_dig 19 // ourPoolPctOfWhole: uint64
	mulw
	int 0
	int 1_000_000
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	frame_bury 14 // tokenRewardAvail: uint64

*if26_end:

*if25_end:
	// *if27_condition
	// examples/reti/stakingPool.algo.ts:635
	// tokenRewardAvail === 0
	frame_dig 14 // tokenRewardAvail: uint64
	int 0
	==
	bz *if27_end

	// *if27_consequent
	// *if28_condition
	// examples/reti/stakingPool.algo.ts:640
	// algoRewardAvail < 1_000_000
	frame_dig 11 // algoRewardAvail: uint64
	int 1_000_000
	<
	bz *if28_end

	// *if28_consequent
	// examples/reti/stakingPool.algo.ts:641
	// log('!token&&!noalgo to pay')
	pushbytes 0x21746f6b656e2626216e6f616c676f20746f20706179 // "!token&&!noalgo to pay"
	log

	// examples/reti/stakingPool.algo.ts:642
	// return;
	retsub

*if28_end:

*if27_end:
	// *if29_condition
	// examples/reti/stakingPool.algo.ts:646
	// isPoolSaturated
	frame_dig 12 // isPoolSaturated: bool
	bz *if29_elseif1_condition

	// *if29_consequent
	// examples/reti/stakingPool.algo.ts:649
	// diminishedReward = wideRatio([algoRewardAvail, algoSaturationAmt], [validatorState.totalAlgoStaked])
	frame_dig 11 // algoRewardAvail: uint64
	frame_dig 13 // algoSaturationAmt: uint64
	mulw
	int 0
	frame_dig 9 // validatorState: (uint16,uint64,uint64,uint64)
	extract 10 8
	btoi
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	frame_bury 20 // diminishedReward: uint64

	// examples/reti/stakingPool.algo.ts:651
	// excessToFeeSink = algoRewardAvail - diminishedReward
	frame_dig 11 // algoRewardAvail: uint64
	frame_dig 20 // diminishedReward: uint64
	-
	frame_bury 17 // excessToFeeSink: uint64

	// examples/reti/stakingPool.algo.ts:652
	// sendPayment({
	//         amount: excessToFeeSink,
	//         receiver: this.getFeeSink(),
	//         note: 'pool saturated, excess to fee sink',
	//       })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// examples/reti/stakingPool.algo.ts:653
	// amount: excessToFeeSink
	frame_dig 17 // excessToFeeSink: uint64
	itxn_field Amount

	// examples/reti/stakingPool.algo.ts:654
	// receiver: this.getFeeSink()
	callsub getFeeSink
	itxn_field Receiver

	// examples/reti/stakingPool.algo.ts:655
	// note: 'pool saturated, excess to fee sink'
	pushbytes 0x706f6f6c207361747572617465642c2065786365737320746f206665652073696e6b // "pool saturated, excess to fee sink"
	itxn_field Note

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/stakingPool.algo.ts:658
	// algoRewardAvail = diminishedReward
	frame_dig 20 // diminishedReward: uint64
	frame_bury 11 // algoRewardAvail: uint64
	b *if29_end

*if29_elseif1_condition:
	// examples/reti/stakingPool.algo.ts:659
	// validatorConfig.percentToValidator !== 0
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 173 4
	btoi
	int 0
	!=
	bz *if29_end

	// *if29_elseif1_consequent
	// examples/reti/stakingPool.algo.ts:662
	// validatorCommissionPaidOut = wideRatio(
	//         [algoRewardAvail, validatorConfig.percentToValidator as uint64],
	//         [1_000_000]
	//       )
	frame_dig 11 // algoRewardAvail: uint64
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 173 4
	btoi
	mulw
	int 0
	int 1_000_000
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	frame_bury 16 // validatorCommissionPaidOut: uint64

	// examples/reti/stakingPool.algo.ts:668
	// algoRewardAvail -= validatorCommissionPaidOut
	frame_dig 11 // algoRewardAvail: uint64
	frame_dig 16 // validatorCommissionPaidOut: uint64
	-
	frame_bury 11 // algoRewardAvail: uint64

	// *if30_condition
	// examples/reti/stakingPool.algo.ts:675
	// validatorCommissionPaidOut > 0
	frame_dig 16 // validatorCommissionPaidOut: uint64
	int 0
	>
	bz *if30_end

	// *if30_consequent
	// examples/reti/stakingPool.algo.ts:678
	// managerTopOff = 0
	int 0
	frame_bury 21 // managerTopOff: uint64

	// *if31_condition
	// examples/reti/stakingPool.algo.ts:680
	// validatorConfig.manager !== validatorConfig.validatorCommissionAddress &&
	//           validatorConfig.manager.balance - validatorConfig.manager.minBalance < 2_100_000
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 40 32
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 177 32
	!=
	dup
	bz *skip_and3
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 40 32
	acct_params_get AcctBalance
	pop
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 40 32
	acct_params_get AcctMinBalance
	pop
	-
	int 2_100_000
	<
	&&

*skip_and3:
	bz *if31_end

	// *if31_consequent
	// examples/reti/stakingPool.algo.ts:683
	// managerTopOff = validatorCommissionPaidOut < 2_100_000 ? validatorCommissionPaidOut : 2_100_000
	frame_dig 16 // validatorCommissionPaidOut: uint64
	int 2_100_000
	<
	bz *ternary1_false
	frame_dig 16 // validatorCommissionPaidOut: uint64
	b *ternary1_end

*ternary1_false:
	int 2_100_000

*ternary1_end:
	frame_bury 21 // managerTopOff: uint64

	// examples/reti/stakingPool.algo.ts:684
	// sendPayment({
	//             amount: managerTopOff,
	//             receiver: validatorConfig.manager,
	//             note: 'validator reward to manager for funding epoch updates',
	//           })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// examples/reti/stakingPool.algo.ts:685
	// amount: managerTopOff
	frame_dig 21 // managerTopOff: uint64
	itxn_field Amount

	// examples/reti/stakingPool.algo.ts:686
	// receiver: validatorConfig.manager
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 40 32
	itxn_field Receiver

	// examples/reti/stakingPool.algo.ts:687
	// note: 'validator reward to manager for funding epoch updates'
	pushbytes 0x76616c696461746f722072657761726420746f206d616e6167657220666f722066756e64696e672065706f63682075706461746573 // "validator reward to manager for funding epoch updates"
	itxn_field Note

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

*if31_end:
	// *if32_condition
	// examples/reti/stakingPool.algo.ts:690
	// validatorCommissionPaidOut - managerTopOff > 0
	frame_dig 16 // validatorCommissionPaidOut: uint64
	frame_dig 21 // managerTopOff: uint64
	-
	int 0
	>
	bz *if32_end

	// *if32_consequent
	// examples/reti/stakingPool.algo.ts:691
	// sendPayment({
	//             amount: validatorCommissionPaidOut - managerTopOff,
	//             receiver: validatorConfig.validatorCommissionAddress,
	//             note: 'validator reward',
	//           })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// examples/reti/stakingPool.algo.ts:692
	// amount: validatorCommissionPaidOut - managerTopOff
	frame_dig 16 // validatorCommissionPaidOut: uint64
	frame_dig 21 // managerTopOff: uint64
	-
	itxn_field Amount

	// examples/reti/stakingPool.algo.ts:693
	// receiver: validatorConfig.validatorCommissionAddress
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 177 32
	itxn_field Receiver

	// examples/reti/stakingPool.algo.ts:694
	// note: 'validator reward'
	pushbytes 0x76616c696461746f7220726577617264 // "validator reward"
	itxn_field Note

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

*if32_end:

*if30_end:

*if29_end:
	// examples/reti/stakingPool.algo.ts:706
	// increasedStake = 0
	int 0
	frame_bury 22 // increasedStake: uint64

	// *if33_condition
	// examples/reti/stakingPool.algo.ts:730
	// algoRewardAvail !== 0 || tokenRewardAvail !== 0
	frame_dig 11 // algoRewardAvail: uint64
	int 0
	!=
	dup
	bnz *skip_or1
	frame_dig 14 // tokenRewardAvail: uint64
	int 0
	!=
	||

*skip_or1:
	bz *if33_end

	// *if33_consequent
	// examples/reti/stakingPool.algo.ts:731
	// partialStakersTotalStake: uint64 = 0
	int 0
	frame_bury 23 // partialStakersTotalStake: uint64

	// examples/reti/stakingPool.algo.ts:732
	// for (let i = 0; i < this.stakers.value.length; i += 1)
	int 0
	frame_bury 24 // i: uint64

*for_4:
	// examples/reti/stakingPool.algo.ts:732
	// i < this.stakers.value.length
	frame_dig 24 // i: uint64
	int 200
	<
	bz *for_4_end

	// *if34_condition
	// examples/reti/stakingPool.algo.ts:733
	// globals.opcodeBudget < 400
	global OpcodeBudget
	pushint 400
	<
	bz *if34_end

	// *if34_consequent
	// examples/reti/stakingPool.algo.ts:734
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	pushint 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

*if34_end:
	// examples/reti/stakingPool.algo.ts:736
	// cmpStaker = clone(this.stakers.value[i])
	frame_dig 24 // i: uint64
	int 64
	* // acc * typeLength
	int 64
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_extract
	frame_bury 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// *if35_condition
	// examples/reti/stakingPool.algo.ts:737
	// cmpStaker.account !== globals.zeroAddress
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 0 32
	global ZeroAddress
	!=
	bz *if35_end

	// *if35_consequent
	// *if36_condition
	// examples/reti/stakingPool.algo.ts:738
	// cmpStaker.entryRound >= thisEpochBegin
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 56 8
	btoi
	frame_dig 3 // thisEpochBegin: uint64
	>=
	bz *if36_else

	// *if36_consequent
	// examples/reti/stakingPool.algo.ts:741
	// partialStakersTotalStake += cmpStaker.balance
	frame_dig 23 // partialStakersTotalStake: uint64
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	+
	frame_bury 23 // partialStakersTotalStake: uint64
	b *if36_end

*if36_else:
	// examples/reti/stakingPool.algo.ts:745
	// timeInPool = thisEpochBegin - cmpStaker.entryRound
	frame_dig 3 // thisEpochBegin: uint64
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 56 8
	btoi
	-
	frame_bury 26 // timeInPool: uint64

	// *if37_condition
	// examples/reti/stakingPool.algo.ts:749
	// timeInPool < epochRoundLength
	frame_dig 26 // timeInPool: uint64
	frame_dig 1 // epochRoundLength: uint64
	<
	bz *if37_end

	// *if37_consequent
	// examples/reti/stakingPool.algo.ts:750
	// partialStakersTotalStake += cmpStaker.balance
	frame_dig 23 // partialStakersTotalStake: uint64
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	+
	frame_bury 23 // partialStakersTotalStake: uint64

	// examples/reti/stakingPool.algo.ts:751
	// timePercentage = (timeInPool * 1000) / epochRoundLength
	frame_dig 26 // timeInPool: uint64
	int 1000
	*
	frame_dig 1 // epochRoundLength: uint64
	/
	frame_bury 27 // timePercentage: uint64

	// *if38_condition
	// examples/reti/stakingPool.algo.ts:753
	// tokenRewardAvail > 0
	frame_dig 14 // tokenRewardAvail: uint64
	int 0
	>
	bz *if38_end

	// *if38_consequent
	// examples/reti/stakingPool.algo.ts:755
	// stakerTokenReward = wideRatio(
	//                   [cmpStaker.balance, tokenRewardAvail, timePercentage],
	//                   [this.totalAlgoStaked.value, 1000]
	//                 )
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	frame_dig 14 // tokenRewardAvail: uint64
	mulw
	frame_dig 27 // timePercentage: uint64
	uncover 2
	dig 1
	*
	cover 2
	mulw
	cover 2
	+
	swap
	byte 0x7374616b6564 // "staked"
	app_global_get
	int 1000
	mulw
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	frame_bury 28 // stakerTokenReward: uint64

	// examples/reti/stakingPool.algo.ts:762
	// tokenRewardAvail -= stakerTokenReward
	frame_dig 14 // tokenRewardAvail: uint64
	frame_dig 28 // stakerTokenReward: uint64
	-
	frame_bury 14 // tokenRewardAvail: uint64

	// examples/reti/stakingPool.algo.ts:763
	// cmpStaker.rewardTokenBalance += stakerTokenReward
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	pushint 48 // headOffset
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 48 8
	btoi
	frame_dig 28 // stakerTokenReward: uint64
	+
	itob
	replace3
	frame_bury 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:764
	// tokenRewardPaidOut += stakerTokenReward
	frame_dig 15 // tokenRewardPaidOut: uint64
	frame_dig 28 // stakerTokenReward: uint64
	+
	frame_bury 15 // tokenRewardPaidOut: uint64

*if38_end:
	// *if39_condition
	// examples/reti/stakingPool.algo.ts:766
	// algoRewardAvail > 0
	frame_dig 11 // algoRewardAvail: uint64
	int 0
	>
	bz *if39_end

	// *if39_consequent
	// examples/reti/stakingPool.algo.ts:768
	// stakerReward = wideRatio(
	//                   [cmpStaker.balance, algoRewardAvail, timePercentage],
	//                   [this.totalAlgoStaked.value, 1000]
	//                 )
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	frame_dig 11 // algoRewardAvail: uint64
	mulw
	frame_dig 27 // timePercentage: uint64
	uncover 2
	dig 1
	*
	cover 2
	mulw
	cover 2
	+
	swap
	byte 0x7374616b6564 // "staked"
	app_global_get
	int 1000
	mulw
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	frame_bury 29 // stakerReward: uint64

	// examples/reti/stakingPool.algo.ts:775
	// algoRewardAvail -= stakerReward
	frame_dig 11 // algoRewardAvail: uint64
	frame_dig 29 // stakerReward: uint64
	-
	frame_bury 11 // algoRewardAvail: uint64

	// examples/reti/stakingPool.algo.ts:778
	// cmpStaker.balance += stakerReward
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	int 32 // headOffset
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	frame_dig 29 // stakerReward: uint64
	+
	itob
	replace3
	frame_bury 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:779
	// cmpStaker.totalRewarded += stakerReward
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	pushint 40 // headOffset
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 40 8
	btoi
	frame_dig 29 // stakerReward: uint64
	+
	itob
	replace3
	frame_bury 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:780
	// increasedStake += stakerReward
	frame_dig 22 // increasedStake: uint64
	frame_dig 29 // stakerReward: uint64
	+
	frame_bury 22 // increasedStake: uint64

*if39_end:
	// examples/reti/stakingPool.algo.ts:783
	// this.stakers.value[i] = cmpStaker
	frame_dig 24 // i: uint64
	int 64
	* // acc * typeLength
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_replace

*if37_end:

*if36_end:

*if35_end:

*for_4_continue:
	// examples/reti/stakingPool.algo.ts:732
	// i += 1
	frame_dig 24 // i: uint64
	int 1
	+
	frame_bury 24 // i: uint64
	b *for_4

*for_4_end:
	// examples/reti/stakingPool.algo.ts:791
	// newPoolTotalStake = this.totalAlgoStaked.value - partialStakersTotalStake
	byte 0x7374616b6564 // "staked"
	app_global_get
	frame_dig 23 // partialStakersTotalStake: uint64
	-
	frame_bury 30 // newPoolTotalStake: uint64

	// *if40_condition
	// examples/reti/stakingPool.algo.ts:795
	// newPoolTotalStake > 0
	frame_dig 30 // newPoolTotalStake: uint64
	int 0
	>
	bz *if40_end

	// *if40_consequent
	// examples/reti/stakingPool.algo.ts:797
	// for (let i = 0; i < this.stakers.value.length; i += 1)
	int 0
	frame_bury 31 // i: uint64

*for_5:
	// examples/reti/stakingPool.algo.ts:797
	// i < this.stakers.value.length
	frame_dig 31 // i: uint64
	int 200
	<
	bz *for_5_end

	// *if41_condition
	// examples/reti/stakingPool.algo.ts:798
	// globals.opcodeBudget < 200
	global OpcodeBudget
	int 200
	<
	bz *if41_end

	// *if41_consequent
	// examples/reti/stakingPool.algo.ts:799
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	pushint 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

*if41_end:
	// examples/reti/stakingPool.algo.ts:801
	// cmpStaker = clone(this.stakers.value[i])
	frame_dig 31 // i: uint64
	int 64
	* // acc * typeLength
	int 64
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_extract
	frame_bury 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// *if42_condition
	// examples/reti/stakingPool.algo.ts:802
	// cmpStaker.account !== globals.zeroAddress && cmpStaker.entryRound < thisEpochBegin
	frame_dig 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 0 32
	global ZeroAddress
	!=
	dup
	bz *skip_and4
	frame_dig 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 56 8
	btoi
	frame_dig 3 // thisEpochBegin: uint64
	<
	&&

*skip_and4:
	bz *if42_end

	// *if42_consequent
	// examples/reti/stakingPool.algo.ts:803
	// timeInPool = thisEpochBegin - cmpStaker.entryRound
	frame_dig 3 // thisEpochBegin: uint64
	frame_dig 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 56 8
	btoi
	-
	frame_bury 33 // timeInPool: uint64

	// *if43_condition
	// examples/reti/stakingPool.algo.ts:805
	// timeInPool >= epochRoundLength
	frame_dig 33 // timeInPool: uint64
	frame_dig 1 // epochRoundLength: uint64
	>=
	bz *if43_end

	// *if43_consequent
	// *if44_condition
	// examples/reti/stakingPool.algo.ts:810
	// tokenRewardAvail > 0
	frame_dig 14 // tokenRewardAvail: uint64
	int 0
	>
	bz *if44_end

	// *if44_consequent
	// examples/reti/stakingPool.algo.ts:811
	// stakerTokenReward = wideRatio([cmpStaker.balance, tokenRewardAvail], [newPoolTotalStake])
	frame_dig 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	frame_dig 14 // tokenRewardAvail: uint64
	mulw
	int 0
	frame_dig 30 // newPoolTotalStake: uint64
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	frame_bury 34 // stakerTokenReward: uint64

	// examples/reti/stakingPool.algo.ts:814
	// cmpStaker.rewardTokenBalance += stakerTokenReward
	frame_dig 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	pushint 48 // headOffset
	frame_dig 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 48 8
	btoi
	frame_dig 34 // stakerTokenReward: uint64
	+
	itob
	replace3
	frame_bury 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:815
	// tokenRewardPaidOut += stakerTokenReward
	frame_dig 15 // tokenRewardPaidOut: uint64
	frame_dig 34 // stakerTokenReward: uint64
	+
	frame_bury 15 // tokenRewardPaidOut: uint64

*if44_end:
	// *if45_condition
	// examples/reti/stakingPool.algo.ts:817
	// algoRewardAvail > 0
	frame_dig 11 // algoRewardAvail: uint64
	int 0
	>
	bz *if45_end

	// *if45_consequent
	// examples/reti/stakingPool.algo.ts:818
	// stakerReward = wideRatio([cmpStaker.balance, algoRewardAvail], [newPoolTotalStake])
	frame_dig 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	frame_dig 11 // algoRewardAvail: uint64
	mulw
	int 0
	frame_dig 30 // newPoolTotalStake: uint64
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	frame_bury 35 // stakerReward: uint64

	// examples/reti/stakingPool.algo.ts:821
	// cmpStaker.balance += stakerReward
	frame_dig 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	int 32 // headOffset
	frame_dig 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	frame_dig 35 // stakerReward: uint64
	+
	itob
	replace3
	frame_bury 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:822
	// cmpStaker.totalRewarded += stakerReward
	frame_dig 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	pushint 40 // headOffset
	frame_dig 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 40 8
	btoi
	frame_dig 35 // stakerReward: uint64
	+
	itob
	replace3
	frame_bury 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:823
	// increasedStake += stakerReward
	frame_dig 22 // increasedStake: uint64
	frame_dig 35 // stakerReward: uint64
	+
	frame_bury 22 // increasedStake: uint64

*if45_end:
	// examples/reti/stakingPool.algo.ts:827
	// this.stakers.value[i] = cmpStaker
	frame_dig 31 // i: uint64
	int 64
	* // acc * typeLength
	frame_dig 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_replace

*if43_end:

*if42_end:

*for_5_continue:
	// examples/reti/stakingPool.algo.ts:797
	// i += 1
	frame_dig 31 // i: uint64
	int 1
	+
	frame_bury 31 // i: uint64
	b *for_5

*for_5_end:

*if40_end:

*if33_end:
	// examples/reti/stakingPool.algo.ts:837
	// roundsLeftInBin = this.binRoundStart.value + this.roundsPerDay.value - globals.round
	byte 0x62696e526f756e645374617274 // "binRoundStart"
	app_global_get
	byte 0x726f756e6473506572446179 // "roundsPerDay"
	app_global_get
	+
	global Round
	-
	frame_bury 36 // roundsLeftInBin: uint64

	// examples/reti/stakingPool.algo.ts:838
	// this.totalAlgoStaked.value += increasedStake
	byte 0x7374616b6564 // "staked"
	app_global_get
	frame_dig 22 // increasedStake: uint64
	+
	byte 0x7374616b6564 // "staked"
	swap
	app_global_put

	// examples/reti/stakingPool.algo.ts:839
	// this.stakeAccumulator.value =
	//       this.stakeAccumulator.value + (increasedStake as uint128) * (roundsLeftInBin as uint128)
	byte 0x7374616b65416363756d756c61746f72 // "stakeAccumulator"
	dup
	app_global_get
	frame_dig 22 // increasedStake: uint64
	itob
	frame_dig 36 // roundsLeftInBin: uint64
	itob
	b*
	b+
	dup
	bitlen
	int 128
	<=

	// this.stakeAccumulator.value + (increasedStake as uint128) * (roundsLeftInBin as uint128) overflowed 128 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 16
	-
	swap
	substring3
	app_global_put

	// examples/reti/stakingPool.algo.ts:841
	// this.rewardAccumulator.value = this.rewardAccumulator.value + increasedStake
	byte 0x726577617264416363756d756c61746f72 // "rewardAccumulator"
	dup
	app_global_get
	frame_dig 22 // increasedStake: uint64
	+
	app_global_put

	// examples/reti/stakingPool.algo.ts:847
	// sendMethodCall<typeof ValidatorRegistry.prototype.stakeUpdatedViaRewards>({
	//       applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//       methodArgs: [
	//         { id: this.validatorId.value, poolId: this.poolId.value, poolAppId: this.app.id },
	//         increasedStake,
	//         tokenRewardPaidOut,
	//         validatorCommissionPaidOut,
	//         excessToFeeSink,
	//       ],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	pushbytes 0x418fcefc // method "stakeUpdatedViaRewards((uint64,uint64,uint64),uint64,uint64,uint64,uint64)void"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:848
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:849
	// methodArgs: [
	//         { id: this.validatorId.value, poolId: this.poolId.value, poolAppId: this.app.id },
	//         increasedStake,
	//         tokenRewardPaidOut,
	//         validatorCommissionPaidOut,
	//         excessToFeeSink,
	//       ]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	itob
	concat
	txna Applications 0
	itob
	concat
	itxn_field ApplicationArgs
	frame_dig 22 // increasedStake: uint64
	itob
	itxn_field ApplicationArgs
	frame_dig 15 // tokenRewardPaidOut: uint64
	itob
	itxn_field ApplicationArgs
	frame_dig 16 // validatorCommissionPaidOut: uint64
	itob
	itxn_field ApplicationArgs
	frame_dig 17 // excessToFeeSink: uint64
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// goOnline(pay,byte[],byte[],byte[],uint64,uint64,uint64)void
*abi_route_goOnline:
	// voteKeyDilution: uint64
	txna ApplicationArgs 6
	btoi

	// voteLast: uint64
	txna ApplicationArgs 5
	btoi

	// voteFirst: uint64
	txna ApplicationArgs 4
	btoi

	// stateProofPK: byte[]
	txna ApplicationArgs 3
	extract 2 0

	// selectionPK: byte[]
	txna ApplicationArgs 2
	extract 2 0

	// votePK: byte[]
	txna ApplicationArgs 1
	extract 2 0

	// feePayment: pay
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// argument 6 (feePayment) for goOnline must be a pay transaction
	assert

	// execute goOnline(pay,byte[],byte[],byte[],uint64,uint64,uint64)void
	callsub goOnline
	int 1
	return

// goOnline(feePayment: PayTxn, votePK: bytes, selectionPK: bytes, stateProofPK: bytes, voteFirst: uint64, voteLast: uint64, voteKeyDilution: uint64): void
//
// Registers a staking pool key online against a participation key.
// [ ONLY OWNER OR MANAGER CAN CALL ]
//
// @param {PayTxn} feePayment - payment to cover extra fee of going online if offline - or 0 if not renewal
// @param {bytes} votePK - The vote public key.
// @param {bytes} selectionPK - The selection public key.
// @param {bytes} stateProofPK - The state proof public key.
// @param {uint64} voteFirst - The first vote index.
// @param {uint64} voteLast - The last vote index.
// @param {uint64} voteKeyDilution - The vote key dilution value.
// @throws {Error} Will throw an error if the caller is not the owner or a manager.
goOnline:
	proto 7 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/reti/stakingPool.algo.ts:881
	// assert(this.isOwnerOrManagerCaller(), 'can only be called by owner or manager of validator')
	callsub isOwnerOrManagerCaller

	// can only be called by owner or manager of validator
	assert

	// examples/reti/stakingPool.algo.ts:882
	// extraFee = this.getGoOnlineFee()
	callsub getGoOnlineFee
	frame_bury 0 // extraFee: uint64

	// examples/reti/stakingPool.algo.ts:883
	// verifyPayTxn(feePayment, { receiver: this.app.address, amount: extraFee })
	// verify receiver
	frame_dig -1 // feePayment: PayTxn
	gtxns Receiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"feePayment","field":"receiver","expected":"this.app.address"}
	assert

	// verify amount
	frame_dig -1 // feePayment: PayTxn
	gtxns Amount
	frame_dig 0 // extraFee: uint64
	==

	// transaction verification failed: {"txn":"feePayment","field":"amount","expected":"extraFee"}
	assert

	// examples/reti/stakingPool.algo.ts:884
	// sendOnlineKeyRegistration({
	//       votePK: votePK,
	//       selectionPK: selectionPK,
	//       stateProofPK: stateProofPK,
	//       voteFirst: voteFirst,
	//       voteLast: voteLast,
	//       voteKeyDilution: voteKeyDilution,
	//       fee: this.getGoOnlineFee(),
	//     })
	itxn_begin
	pushint 2 // keyreg
	itxn_field TypeEnum

	// examples/reti/stakingPool.algo.ts:885
	// votePK: votePK
	frame_dig -2 // votePK: bytes
	itxn_field VotePK

	// examples/reti/stakingPool.algo.ts:886
	// selectionPK: selectionPK
	frame_dig -3 // selectionPK: bytes
	itxn_field SelectionPK

	// examples/reti/stakingPool.algo.ts:887
	// stateProofPK: stateProofPK
	frame_dig -4 // stateProofPK: bytes
	itxn_field StateProofPK

	// examples/reti/stakingPool.algo.ts:888
	// voteFirst: voteFirst
	frame_dig -5 // voteFirst: uint64
	itxn_field VoteFirst

	// examples/reti/stakingPool.algo.ts:889
	// voteLast: voteLast
	frame_dig -6 // voteLast: uint64
	itxn_field VoteLast

	// examples/reti/stakingPool.algo.ts:890
	// voteKeyDilution: voteKeyDilution
	frame_dig -7 // voteKeyDilution: uint64
	itxn_field VoteKeyDilution

	// examples/reti/stakingPool.algo.ts:891
	// fee: this.getGoOnlineFee()
	callsub getGoOnlineFee
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// goOffline()void
*abi_route_goOffline:
	// execute goOffline()void
	callsub goOffline
	int 1
	return

// goOffline(): void
//
// Marks a staking pool key OFFLINE.
// [ ONLY OWNER OR MANAGER CAN CALL ]
goOffline:
	proto 0 0

	// *if46_condition
	// examples/reti/stakingPool.algo.ts:903
	// this.txn.sender !== AppID.fromUint64(this.creatingValidatorContractAppId.value).address
	txn Sender
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	app_params_get AppAddress
	pop
	!=
	bz *if46_end

	// *if46_consequent
	// examples/reti/stakingPool.algo.ts:904
	// assert(this.isOwnerOrManagerCaller(), 'can only be called by owner or manager of validator')
	callsub isOwnerOrManagerCaller

	// can only be called by owner or manager of validator
	assert

*if46_end:
	// examples/reti/stakingPool.algo.ts:907
	// sendOfflineKeyRegistration({})
	itxn_begin
	pushint 2 // keyreg
	itxn_field TypeEnum

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// linkToNFD(uint64,string)void
*abi_route_linkToNFD:
	// nfdName: string
	txna ApplicationArgs 2
	extract 2 0

	// nfdAppId: uint64
	txna ApplicationArgs 1
	btoi

	// execute linkToNFD(uint64,string)void
	callsub linkToNFD
	int 1
	return

// linkToNFD(nfdAppId: uint64, nfdName: string): void
linkToNFD:
	proto 2 0

	// examples/reti/stakingPool.algo.ts:914
	// assert(this.isOwnerOrManagerCaller(), 'can only be called by owner or manager of validator')
	callsub isOwnerOrManagerCaller

	// can only be called by owner or manager of validator
	assert

	// examples/reti/stakingPool.algo.ts:916
	// sendAppCall({
	//       applicationID: AppID.fromUint64(this.nfdRegistryAppId),
	//       applicationArgs: ['verify_nfd_addr', nfdName, itob(nfdAppId), rawBytes(this.app.address)],
	//       applications: [AppID.fromUint64(nfdAppId)],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum

	// examples/reti/stakingPool.algo.ts:917
	// applicationID: AppID.fromUint64(this.nfdRegistryAppId)
	intc 0 // TMPL_nfdRegistryAppId
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:918
	// applicationArgs: ['verify_nfd_addr', nfdName, itob(nfdAppId), rawBytes(this.app.address)]
	pushbytes 0x7665726966795f6e66645f61646472 // "verify_nfd_addr"
	itxn_field ApplicationArgs
	frame_dig -2 // nfdName: string
	itxn_field ApplicationArgs
	frame_dig -1 // nfdAppId: uint64
	itob
	itxn_field ApplicationArgs
	global CurrentApplicationAddress
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:919
	// applications: [AppID.fromUint64(nfdAppId)]
	frame_dig -1 // nfdAppId: uint64
	itxn_field Applications

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// proxiedSetTokenPayoutRatio((uint64,uint64,uint64))(uint64[24],uint64)
*abi_route_proxiedSetTokenPayoutRatio:
	// The ABI return prefix
	byte 0x151f7c75

	// poolKey: (uint64,uint64,uint64)
	txna ApplicationArgs 1
	dup
	len
	pushint 24
	==

	// argument 0 (poolKey) for proxiedSetTokenPayoutRatio must be a (uint64,uint64,uint64)
	assert

	// execute proxiedSetTokenPayoutRatio((uint64,uint64,uint64))(uint64[24],uint64)
	callsub proxiedSetTokenPayoutRatio
	concat
	log
	int 1
	return

// proxiedSetTokenPayoutRatio(poolKey: ValidatorPoolKey): PoolTokenPayoutRatio
//
// proxiedSetTokenPayoutRatio is meant to be called by pools != 1 - calling US, pool #1
// We need to verify that we are in fact being called by another of OUR pools (not us)
// and then we'll call the validator on their behalf to update the token payouts
// @param poolKey - ValidatorPoolKey tuple
proxiedSetTokenPayoutRatio:
	proto 1 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/reti/stakingPool.algo.ts:930
	// assert(this.validatorId.value === poolKey.id, 'caller must be part of same validator set!')
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	==

	// caller must be part of same validator set!
	assert

	// examples/reti/stakingPool.algo.ts:931
	// assert(this.poolId.value === 1, 'callee must be pool 1')
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	int 1
	==

	// callee must be pool 1
	assert

	// examples/reti/stakingPool.algo.ts:932
	// assert(poolKey.poolId !== 1, 'caller must NOT be pool 1')
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	!=

	// caller must NOT be pool 1
	assert

	// examples/reti/stakingPool.algo.ts:934
	// callerPoolAppID = sendMethodCall<typeof ValidatorRegistry.prototype.getPoolAppId>({
	//       applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//       methodArgs: [poolKey.id, poolKey.poolId],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0x572767d1 // method "getPoolAppId(uint64,uint64)uint64"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:935
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:936
	// methodArgs: [poolKey.id, poolKey.poolId]
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	itxn_field ApplicationArgs
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0
	btoi
	frame_bury 0 // callerPoolAppID: uint64

	// examples/reti/stakingPool.algo.ts:938
	// assert(callerPoolAppID === poolKey.poolAppId)
	frame_dig 0 // callerPoolAppID: uint64
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 16 8
	btoi
	==
	assert

	// examples/reti/stakingPool.algo.ts:939
	// assert(this.txn.sender === AppID.fromUint64(poolKey.poolAppId).address)
	txn Sender
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 16 8
	btoi
	app_params_get AppAddress
	pop
	==
	assert

	// examples/reti/stakingPool.algo.ts:941
	// return sendMethodCall<typeof ValidatorRegistry.prototype.setTokenPayoutRatio>({
	//       applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//       methodArgs: [this.validatorId.value],
	//     });
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0x4df8d86e // method "setTokenPayoutRatio(uint64)(uint64[24],uint64)"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:942
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:943
	// methodArgs: [this.validatorId.value]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0

	// set the subroutine return value
	frame_bury 0
	retsub

// isOwnerOrManagerCaller(): boolean
isOwnerOrManagerCaller:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/reti/stakingPool.algo.ts:948
	// OwnerAndManager = sendMethodCall<typeof ValidatorRegistry.prototype.getValidatorOwnerAndManager>({
	//       applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//       methodArgs: [this.validatorId.value],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	pushbytes 0x2fa22c4b // method "getValidatorOwnerAndManager(uint64)(address,address)"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:949
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:950
	// methodArgs: [this.validatorId.value]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0
	frame_bury 0 // OwnerAndManager: (address,address)

	// examples/reti/stakingPool.algo.ts:952
	// return this.txn.sender === OwnerAndManager[0] || this.txn.sender === OwnerAndManager[1];
	txn Sender
	frame_dig 0 // OwnerAndManager: (address,address)
	extract 0 32
	==
	dup
	bnz *skip_or2
	txn Sender
	frame_dig 0 // OwnerAndManager: (address,address)
	extract 32 32
	==
	||

*skip_or2:
	// set the subroutine return value
	frame_bury 0
	retsub

// getFeeSink(): Address
getFeeSink:
	proto 0 1

	// examples/reti/stakingPool.algo.ts:956
	// return this.feeSinkAddr;
	bytec 0 // TMPL_feeSinkAddr
	retsub

// algoSaturationLevel(): uint64
//
// Returns the maximum allowed stake per validator based on a percentage of all current online stake before
// the validator is considered saturated - where rewards are diminished.
algoSaturationLevel:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/reti/stakingPool.algo.ts:966
	// online = this.getCurrentOnlineStake()
	callsub getCurrentOnlineStake
	frame_bury 0 // online: uint64

	// examples/reti/stakingPool.algo.ts:968
	// return wideRatio([online, MAX_VALIDATOR_SOFT_PCT_OF_ONLINE_1DECIMAL], [1000]);
	frame_dig 0 // online: uint64
	pushint 100
	mulw
	int 0
	int 1000
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert

	// set the subroutine return value
	frame_bury 0
	retsub

// getGoOnlineFee(): uint64
getGoOnlineFee:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/reti/stakingPool.algo.ts:975
	// isOnline = false
	int 0
	frame_bury 0 // isOnline: bool

	// *if47_condition
	// examples/reti/stakingPool.algo.ts:976
	// !isOnline
	frame_dig 0 // isOnline: bool
	!
	bz *if47_end

	// *if47_consequent
	// examples/reti/stakingPool.algo.ts:978
	// return 2_000_000;
	pushint 2_000_000
	b *getGoOnlineFee*return

*if47_end:
	// examples/reti/stakingPool.algo.ts:980
	// return 0;
	int 0

*getGoOnlineFee*return:
	// set the subroutine return value
	frame_bury 0
	retsub

// getCurrentOnlineStake(): uint64
getCurrentOnlineStake:
	proto 0 1

	// examples/reti/stakingPool.algo.ts:985
	// return 2_000_000_000_000_000;
	pushint 2_000_000_000_000_000
	retsub

// checkIfBinClosed(): void
//
// Checks if the current round is in a 'new calculation bin' (approximately daily)
checkIfBinClosed:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 4

	// examples/reti/stakingPool.algo.ts:992
	// currentBinSize = this.roundsPerDay.value as uint128
	byte 0x726f756e6473506572446179 // "roundsPerDay"
	app_global_get
	itob
	frame_bury 0 // currentBinSize: unsafe uint128

	// *if48_condition
	// examples/reti/stakingPool.algo.ts:993
	// globals.round >= this.binRoundStart.value + (currentBinSize as uint64)
	global Round
	byte 0x62696e526f756e645374617274 // "binRoundStart"
	app_global_get
	frame_dig 0 // currentBinSize: unsafe uint128
	dup
	bitlen
	int 64
	<=

	// currentBinSize as uint64 overflowed 64 bits
	assert
	pushbytes 0xFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	pushint 8
	-
	swap
	substring3
	btoi
	+
	>=
	bz *if48_end

	// *if48_consequent
	// *if49_condition
	// examples/reti/stakingPool.algo.ts:994
	// globals.opcodeBudget < 300
	global OpcodeBudget
	int 300
	<
	bz *if49_end

	// *if49_consequent
	// examples/reti/stakingPool.algo.ts:995
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	pushint 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

*if49_end:
	// examples/reti/stakingPool.algo.ts:997
	// approxRoundsPerYear: uint128 = currentBinSize * (365 as uint128)
	frame_dig 0 // currentBinSize: unsafe uint128
	pushbytes 0x0000000000000000000000000000016d
	b*
	dup
	bitlen
	int 128
	<=

	// currentBinSize * (365 as uint128) overflowed 128 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 16
	-
	swap
	substring3
	frame_bury 1 // approxRoundsPerYear: uint128

	// examples/reti/stakingPool.algo.ts:998
	// avgStake: uint128 = this.stakeAccumulator.value / currentBinSize
	byte 0x7374616b65416363756d756c61746f72 // "stakeAccumulator"
	app_global_get
	frame_dig 0 // currentBinSize: unsafe uint128
	b/
	dup
	bitlen
	int 128
	<=

	// this.stakeAccumulator.value / currentBinSize overflowed 128 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 16
	-
	swap
	substring3
	frame_bury 2 // avgStake: uint128

	// *if50_condition
	// examples/reti/stakingPool.algo.ts:999
	// avgStake !== 0
	frame_dig 2 // avgStake: uint128
	byte 0x00000000000000000000000000000000
	b!=
	bz *if50_end

	// *if50_consequent
	// examples/reti/stakingPool.algo.ts:1003
	// apr: uint128 =
	//           (((this.rewardAccumulator.value as uint128) * (10000 as uint128)) / avgStake) *
	//           (approxRoundsPerYear / currentBinSize)
	byte 0x726577617264416363756d756c61746f72 // "rewardAccumulator"
	app_global_get
	itob
	pushbytes 0x00000000000000000000000000002710
	b*
	frame_dig 2 // avgStake: uint128
	b/
	frame_dig 1 // approxRoundsPerYear: uint128
	frame_dig 0 // currentBinSize: unsafe uint128
	b/
	b*
	dup
	bitlen
	int 128
	<=

	// (((this.rewardAccumulator.value as uint128) * (10000 as uint128)) / avgStake) *\n          (approxRoundsPerYear / currentBinSize) overflowed 128 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 16
	-
	swap
	substring3
	frame_bury 3 // apr: uint128

	// examples/reti/stakingPool.algo.ts:1007
	// alpha: uint128 = 10 as uint128
	pushbytes 0x0000000000000000000000000000000a
	frame_bury 4 // alpha: unsafe uint128

	// *if51_condition
	// examples/reti/stakingPool.algo.ts:1009
	// avgStake > 300000000000
	frame_dig 2 // avgStake: uint128
	pushbytes 0x000000000000000000000045d964b800
	b>
	bz *if51_end

	// *if51_consequent
	// examples/reti/stakingPool.algo.ts:1010
	// alpha = 90 as uint128
	pushbytes 0x0000000000000000000000000000005a
	frame_bury 4 // alpha: unsafe uint128

*if51_end:
	// examples/reti/stakingPool.algo.ts:1012
	// this.weightedMovingAverage.value =
	//           (this.weightedMovingAverage.value * ((100 as uint128) - alpha)) / (100 as uint128) +
	//           (apr * alpha) / (100 as uint128)
	byte 0x65776d61 // "ewma"
	dup
	app_global_get
	byte 0x00000000000000000000000000000064
	frame_dig 4 // alpha: unsafe uint128
	b-
	b*
	byte 0x00000000000000000000000000000064
	b/
	frame_dig 3 // apr: uint128
	frame_dig 4 // alpha: unsafe uint128
	b*
	byte 0x00000000000000000000000000000064
	b/
	b+
	dup
	bitlen
	int 128
	<=

	// (this.weightedMovingAverage.value * ((100 as uint128) - alpha)) / (100 as uint128) +\n          (apr * alpha) / (100 as uint128) overflowed 128 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 16
	-
	swap
	substring3
	app_global_put

*if50_end:
	// examples/reti/stakingPool.algo.ts:1018
	// this.setRoundsPerDay()
	callsub setRoundsPerDay

	// examples/reti/stakingPool.algo.ts:1019
	// this.stakeAccumulator.value = (this.totalAlgoStaked.value as uint128) * (this.roundsPerDay.value as uint128)
	byte 0x7374616b65416363756d756c61746f72 // "stakeAccumulator"
	byte 0x7374616b6564 // "staked"
	app_global_get
	itob
	byte 0x726f756e6473506572446179 // "roundsPerDay"
	app_global_get
	itob
	b*
	dup
	bitlen
	int 128
	<=

	// (this.totalAlgoStaked.value as uint128) * (this.roundsPerDay.value as uint128) overflowed 128 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 16
	-
	swap
	substring3
	app_global_put

	// examples/reti/stakingPool.algo.ts:1020
	// this.rewardAccumulator.value = 0
	byte 0x726577617264416363756d756c61746f72 // "rewardAccumulator"
	int 0
	app_global_put

	// examples/reti/stakingPool.algo.ts:1021
	// this.binRoundStart.value = globals.round - (globals.round % this.roundsPerDay.value)
	byte 0x62696e526f756e645374617274 // "binRoundStart"
	global Round
	global Round
	byte 0x726f756e6473506572446179 // "roundsPerDay"
	app_global_get
	%
	-
	app_global_put

*if48_end:
	retsub

// setRoundsPerDay(): void
setRoundsPerDay:
	proto 0 0

	// examples/reti/stakingPool.algo.ts:1026
	// this.roundsPerDay.value = AVG_ROUNDS_PER_DAY
	byte 0x726f756e6473506572446179 // "roundsPerDay"
	pushint 30857
	app_global_put
	retsub

*create_NoOp:
	pushbytes 0x59e90aa6 // method "createApplication(uint64,uint64,uint64,uint64)void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x3172ca9d // method "gas()void"
	pushbytes 0x47cfcc04 // method "initStorage(pay)void"
	pushbytes 0xf9c70cbd // method "addStake(pay,address)uint64"
	pushbytes 0x421b5abe // method "removeStake(address,uint64)void"
	pushbytes 0xf5892d56 // method "claimTokens()void"
	pushbytes 0x5cfbb057 // method "getStakerInfo(address)(address,uint64,uint64,uint64,uint64)"
	pushbytes 0x63f3f28b // method "payTokenReward(address,uint64,uint64)void"
	pushbytes 0x86a3725c // method "updateAlgodVer(string)void"
	pushbytes 0xefc2608d // method "epochBalanceUpdate()void"
	pushbytes 0x400e14fb // method "goOnline(pay,byte[],byte[],byte[],uint64,uint64,uint64)void"
	pushbytes 0x51ef3b21 // method "goOffline()void"
	pushbytes 0xa24e2717 // method "linkToNFD(uint64,string)void"
	byte 0x0c2245e1 // method "proxiedSetTokenPayoutRatio((uint64,uint64,uint64))(uint64[24],uint64)"
	txna ApplicationArgs 0
	match *abi_route_gas *abi_route_initStorage *abi_route_addStake *abi_route_removeStake *abi_route_claimTokens *abi_route_getStakerInfo *abi_route_payTokenReward *abi_route_updateAlgodVer *abi_route_epochBalanceUpdate *abi_route_goOnline *abi_route_goOffline *abi_route_linkToNFD *abi_route_proxiedSetTokenPayoutRatio

	// this contract does not implement the given ABI method for call NoOp
	err

*call_UpdateApplication:
	pushbytes 0x46f76533 // method "updateApplication()void"
	txna ApplicationArgs 0
	match *abi_route_updateApplication

	// this contract does not implement the given ABI method for call UpdateApplication
	err", + "approval": "#pragma version 10
intcblock TMPL_nfdRegistryAppId 0 1 6 64 32 16 128 1_000_000 2_100_000 200 300 1000
bytecblock TMPL_feeSinkAddr 0x63726561746f72417070 0x76616c696461746f724964 0x7374616b65416363756d756c61746f72 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF 0x7374616b657273 0x726f756e6473506572446179 0x706f6f6c4964 0x726577617264416363756d756c61746f72 0x7374616b6564 0x62696e526f756e645374617274 0x0000000000000000 0x 0x0a8101 0x6e756d5374616b657273 0x6c6173745061796f7574 0x00000000000000000000000000000000 0x00000000000000000000000000000064 0x6d696e456e7472795374616b65 0x65706f63684e756d626572 0x75aff61d 0x65776d61 0x151f7c75 0xa2dc51b5 0x572767d1 0x4df8d86e 0x0c2245e1 0x00

// This TEAL was generated by TEALScript v0.105.0
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following lines of TEAL are used to initialize template variables in scratch slots
bytec 0 // TMPL_feeSinkAddr
intc 0 // TMPL_nfdRegistryAppId

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
int 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *call_UpdateApplication *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// updateApplication()void
*abi_route_updateApplication:
	// execute updateApplication()void
	callsub updateApplication
	int 1
	return

// updateApplication(): void
updateApplication:
	proto 0 0

	// examples/reti/stakingPool.algo.ts:94
	// assert(
	//       this.txn.sender === Address.fromAddress('LZ4V2IRVLCXFJK4REJV4TAGEKEYTA2GMR6TC2344OB3L3AF3MWXZ6ZAFIQ'),
	//       'Temporary: contract is upgradeable but only during testing and only from a development account'
	//     )
	txn Sender
	pushbytes 0x5e795d223558ae54ab91226bc980c451313068cc8fa62d6f9c7076bd80bb65af // addr "LZ4V2IRVLCXFJK4REJV4TAGEKEYTA2GMR6TC2344OB3L3AF3MWXZ6ZAFIQ"
	==

	// Temporary: contract is upgradeable but only during testing and only from a development account
	assert
	retsub

// createApplication(uint64,uint64,uint64,uint64)void
*abi_route_createApplication:
	// minEntryStake: uint64
	txna ApplicationArgs 4
	btoi

	// poolId: uint64
	txna ApplicationArgs 3
	btoi

	// validatorId: uint64
	txna ApplicationArgs 2
	btoi

	// creatingContractId: uint64
	txna ApplicationArgs 1
	btoi

	// execute createApplication(uint64,uint64,uint64,uint64)void
	callsub createApplication
	int 1
	return

// createApplication(creatingContractId: uint64, validatorId: uint64, poolId: uint64, minEntryStake: uint64): void
//
// Initialize the staking pool w/ owner and manager, but can only be created by the validator contract.
// @param {uint64} creatingContractId - id of contract that constructed us - the validator application (single global instance)
// @param {uint64} validatorId - id of validator we're a staking pool of
// @param {uint64} poolId - which pool id are we
// @param {uint64} minEntryStake - minimum amount to be in pool, but also minimum amount balance can't go below (without removing all!)
createApplication:
	proto 4 0

	// *if0_condition
	// examples/reti/stakingPool.algo.ts:108
	// creatingContractId === 0
	frame_dig -1 // creatingContractId: uint64
	int 0
	==
	bz *if0_else

	// *if0_consequent
	// examples/reti/stakingPool.algo.ts:110
	// assert(validatorId === 0)
	frame_dig -2 // validatorId: uint64
	int 0
	==
	assert

	// examples/reti/stakingPool.algo.ts:111
	// assert(poolId === 0)
	frame_dig -3 // poolId: uint64
	int 0
	==
	assert
	b *if0_end

*if0_else:
	// examples/reti/stakingPool.algo.ts:113
	// assert(validatorId !== 0)
	frame_dig -2 // validatorId: uint64
	int 0
	!=
	assert

	// examples/reti/stakingPool.algo.ts:114
	// assert(poolId !== 0)
	frame_dig -3 // poolId: uint64
	int 0
	!=
	assert

*if0_end:
	// examples/reti/stakingPool.algo.ts:116
	// assert(minEntryStake >= MIN_ALGO_STAKE_PER_POOL, 'staking pool must have minimum entry of 1 algo')
	frame_dig -4 // minEntryStake: uint64
	pushint 1000000
	>=

	// staking pool must have minimum entry of 1 algo
	assert

	// examples/reti/stakingPool.algo.ts:117
	// this.creatingValidatorContractAppId.value = creatingContractId
	byte 0x63726561746f72417070 // "creatorApp"
	frame_dig -1 // creatingContractId: uint64
	app_global_put

	// examples/reti/stakingPool.algo.ts:118
	// this.validatorId.value = validatorId
	byte 0x76616c696461746f724964 // "validatorId"
	frame_dig -2 // validatorId: uint64
	app_global_put

	// examples/reti/stakingPool.algo.ts:119
	// this.poolId.value = poolId
	byte 0x706f6f6c4964 // "poolId"
	frame_dig -3 // poolId: uint64
	app_global_put

	// examples/reti/stakingPool.algo.ts:120
	// this.numStakers.value = 0
	byte 0x6e756d5374616b657273 // "numStakers"
	int 0
	app_global_put

	// examples/reti/stakingPool.algo.ts:121
	// this.totalAlgoStaked.value = 0
	byte 0x7374616b6564 // "staked"
	int 0
	app_global_put

	// examples/reti/stakingPool.algo.ts:122
	// this.minEntryStake.value = minEntryStake
	byte 0x6d696e456e7472795374616b65 // "minEntryStake"
	frame_dig -4 // minEntryStake: uint64
	app_global_put

	// examples/reti/stakingPool.algo.ts:123
	// this.lastPayout.value = globals.round
	byte 0x6c6173745061796f7574 // "lastPayout"
	global Round
	app_global_put

	// examples/reti/stakingPool.algo.ts:124
	// this.epochNumber.value = 0
	byte 0x65706f63684e756d626572 // "epochNumber"
	int 0
	app_global_put

	// examples/reti/stakingPool.algo.ts:126
	// this.setRoundsPerDay()
	callsub setRoundsPerDay

	// examples/reti/stakingPool.algo.ts:127
	// this.binRoundStart.value = globals.round - (globals.round % this.roundsPerDay.value)
	byte 0x62696e526f756e645374617274 // "binRoundStart"
	global Round
	global Round
	byte 0x726f756e6473506572446179 // "roundsPerDay"
	app_global_get
	%
	-
	app_global_put

	// examples/reti/stakingPool.algo.ts:128
	// this.stakeAccumulator.value = 0 as uint128
	byte 0x7374616b65416363756d756c61746f72 // "stakeAccumulator"
	byte 0x00000000000000000000000000000000
	app_global_put

	// examples/reti/stakingPool.algo.ts:129
	// this.rewardAccumulator.value = 0
	byte 0x726577617264416363756d756c61746f72 // "rewardAccumulator"
	int 0
	app_global_put

	// examples/reti/stakingPool.algo.ts:130
	// this.weightedMovingAverage.value = 0 as uint128
	byte 0x65776d61 // "ewma"
	byte 0x00000000000000000000000000000000
	app_global_put
	retsub

// gas()void
*abi_route_gas:
	// execute gas()void
	callsub gas
	int 1
	return

// gas(): void
//
// gas is a dummy no-op call that can be used to pool-up resource references and opcode cost
gas:
	proto 0 0
	retsub

// costForBoxStorage(totalNumBytes: uint64): uint64
costForBoxStorage:
	proto 1 1

	// examples/reti/stakingPool.algo.ts:142
	// return SCBOX_PERBOX + totalNumBytes * SCBOX_PERBYTE;
	pushint 2500
	frame_dig -1 // totalNumBytes: uint64
	pushint 400
	*
	+
	retsub

// initStorage(pay)void
*abi_route_initStorage:
	// mbrPayment: pay
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// argument 0 (mbrPayment) for initStorage must be a pay transaction
	assert

	// execute initStorage(pay)void
	callsub initStorage
	int 1
	return

// initStorage(mbrPayment: PayTxn): void
//
// Called after we're created and then funded, so we can create our large stakers ledger storage
// Caller has to get MBR amounts from ValidatorRegistry to know how much to fund us to cover the box storage cost
// If this is pool 1 AND the validator has specified a reward token, opt-in to that token
// so that the validator can seed the pool with future rewards of that token.
// @param mbrPayment payment from caller which covers mbr increase of new staking pools' storage
initStorage:
	proto 1 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 3

	// examples/reti/stakingPool.algo.ts:153
	// assert(!this.stakers.exists, 'staking pool already initialized')
	byte 0x7374616b657273 // "stakers"
	box_len
	swap
	pop
	!

	// staking pool already initialized
	assert

	// examples/reti/stakingPool.algo.ts:156
	// validatorConfig = sendMethodCall<typeof ValidatorRegistry.prototype.getValidatorConfig>({
	//       applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//       methodArgs: [this.validatorId.value],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0x75aff61d // method "getValidatorConfig(uint64)(uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:157
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:158
	// methodArgs: [this.validatorId.value]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0
	frame_bury 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:160
	// isTokenEligible = validatorConfig.rewardTokenId !== 0
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 153 8
	btoi
	int 0
	!=
	frame_bury 1 // isTokenEligible: bool

	// examples/reti/stakingPool.algo.ts:161
	// extraMBR = isTokenEligible && this.poolId.value === 1 ? ASSET_HOLDING_FEE : 0
	frame_dig 1 // isTokenEligible: bool
	dup
	bz *skip_and0
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	int 1
	==
	&&

*skip_and0:
	bz *ternary0_false
	pushint 100000
	b *ternary0_end

*ternary0_false:
	int 0

*ternary0_end:
	frame_bury 2 // extraMBR: uint64

	// examples/reti/stakingPool.algo.ts:162
	// PoolInitMbr =
	//       ALGORAND_ACCOUNT_MIN_BALANCE +
	//       extraMBR +
	//       this.costForBoxStorage(7 /* 'stakers' name */ + len<StakedInfo>() * MAX_STAKERS_PER_POOL)
	pushint 100000
	frame_dig 2 // extraMBR: uint64
	+
	pushint 12807
	callsub costForBoxStorage
	+
	frame_bury 3 // PoolInitMbr: uint64

	// examples/reti/stakingPool.algo.ts:168
	// verifyPayTxn(mbrPayment, { receiver: this.app.address, amount: PoolInitMbr })
	// verify receiver
	frame_dig -1 // mbrPayment: PayTxn
	gtxns Receiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"mbrPayment","field":"receiver","expected":"this.app.address"}
	assert

	// verify amount
	frame_dig -1 // mbrPayment: PayTxn
	gtxns Amount
	frame_dig 3 // PoolInitMbr: uint64
	==

	// transaction verification failed: {"txn":"mbrPayment","field":"amount","expected":"PoolInitMbr"}
	assert

	// examples/reti/stakingPool.algo.ts:169
	// this.stakers.create()
	byte 0x7374616b657273 // "stakers"
	pushint 12800
	box_create
	pop

	// *if1_condition
	// examples/reti/stakingPool.algo.ts:171
	// isTokenEligible && this.poolId.value === 1
	frame_dig 1 // isTokenEligible: bool
	dup
	bz *skip_and1
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	int 1
	==
	&&

*skip_and1:
	bz *if1_end

	// *if1_consequent
	// examples/reti/stakingPool.algo.ts:173
	// sendAssetTransfer({
	//         xferAsset: AssetID.fromUint64(validatorConfig.rewardTokenId),
	//         assetReceiver: this.app.address,
	//         assetAmount: 0,
	//       })
	itxn_begin
	pushint 4 // axfer
	itxn_field TypeEnum

	// examples/reti/stakingPool.algo.ts:174
	// xferAsset: AssetID.fromUint64(validatorConfig.rewardTokenId)
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 153 8
	btoi
	itxn_field XferAsset

	// examples/reti/stakingPool.algo.ts:175
	// assetReceiver: this.app.address
	global CurrentApplicationAddress
	itxn_field AssetReceiver

	// examples/reti/stakingPool.algo.ts:176
	// assetAmount: 0
	int 0
	itxn_field AssetAmount

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

*if1_end:
	retsub

// addStake(pay,address)uint64
*abi_route_addStake:
	// The ABI return prefix
	byte 0x151f7c75

	// staker: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (staker) for addStake must be a address
	assert

	// stakedAmountPayment: pay
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// argument 1 (stakedAmountPayment) for addStake must be a pay transaction
	assert

	// execute addStake(pay,address)uint64
	callsub addStake
	itob
	concat
	log
	int 1
	return

// addStake(stakedAmountPayment: PayTxn, staker: Address): uint64
//
// Adds stake to the given account.
// Can ONLY be called by the validator contract that created us
// Must receive payment from the validator contract for amount being staked.
//
// @param {PayTxn} stakedAmountPayment prior payment coming from validator contract to us on behalf of staker.
// @param {Address} staker - The account adding new stake
// @throws {Error} - Throws an error if the staking pool is full.
// @returns {uint64} new 'entry round' round number of stake add
addStake:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 4

	// examples/reti/stakingPool.algo.ts:192
	// assert(this.stakers.exists, 'staking pool must be initialized first')
	byte 0x7374616b657273 // "stakers"
	box_len
	swap
	pop

	// staking pool must be initialized first
	assert

	// examples/reti/stakingPool.algo.ts:195
	// assert(
	//       this.txn.sender === AppID.fromUint64(this.creatingValidatorContractAppId.value).address,
	//       'stake can only be added via the validator contract'
	//     )
	txn Sender
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	app_params_get AppAddress
	pop
	==

	// stake can only be added via the validator contract
	assert

	// examples/reti/stakingPool.algo.ts:199
	// assert(staker !== globals.zeroAddress)
	frame_dig -2 // staker: Address
	global ZeroAddress
	!=
	assert

	// examples/reti/stakingPool.algo.ts:202
	// this.checkIfBinClosed()
	callsub checkIfBinClosed

	// examples/reti/stakingPool.algo.ts:206
	// verifyPayTxn(stakedAmountPayment, {
	//       sender: AppID.fromUint64(this.creatingValidatorContractAppId.value).address,
	//       receiver: this.app.address,
	//       amount: stakedAmountPayment.amount,
	//     })
	// verify sender
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Sender
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	app_params_get AppAddress
	pop
	==

	// transaction verification failed: {"txn":"stakedAmountPayment","field":"sender","expected":"AppID.fromUint64(this.creatingValidatorContractAppId.value).address"}
	assert

	// verify receiver
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Receiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"stakedAmountPayment","field":"receiver","expected":"this.app.address"}
	assert

	// verify amount
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Amount
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Amount
	==

	// transaction verification failed: {"txn":"stakedAmountPayment","field":"amount","expected":"stakedAmountPayment.amount"}
	assert

	// examples/reti/stakingPool.algo.ts:215
	// entryRound = globals.round + ALGORAND_STAKING_BLOCK_DELAY
	global Round
	pushint 320
	+
	frame_bury 0 // entryRound: uint64

	// examples/reti/stakingPool.algo.ts:216
	// firstEmpty = 0
	int 0
	frame_bury 1 // firstEmpty: uint64

	// examples/reti/stakingPool.algo.ts:218
	// this.totalAlgoStaked.value += stakedAmountPayment.amount
	byte 0x7374616b6564 // "staked"
	app_global_get
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Amount
	+
	byte 0x7374616b6564 // "staked"
	swap
	app_global_put

	// examples/reti/stakingPool.algo.ts:220
	// roundsLeftInBin = this.binRoundStart.value + this.roundsPerDay.value - globals.round
	byte 0x62696e526f756e645374617274 // "binRoundStart"
	app_global_get
	byte 0x726f756e6473506572446179 // "roundsPerDay"
	app_global_get
	+
	global Round
	-
	frame_bury 2 // roundsLeftInBin: uint64

	// examples/reti/stakingPool.algo.ts:221
	// this.stakeAccumulator.value =
	//       this.stakeAccumulator.value + (stakedAmountPayment.amount as uint128) * (roundsLeftInBin as uint128)
	byte 0x7374616b65416363756d756c61746f72 // "stakeAccumulator"
	dup
	app_global_get
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Amount
	itob
	frame_dig 2 // roundsLeftInBin: uint64
	itob
	b*
	b+
	dup
	bitlen
	int 128
	<=

	// this.stakeAccumulator.value + (stakedAmountPayment.amount as uint128) * (roundsLeftInBin as uint128) overflowed 128 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 16
	-
	swap
	substring3
	app_global_put

	// examples/reti/stakingPool.algo.ts:225
	// for (let i = 0; i < this.stakers.value.length; i += 1)
	int 0
	frame_bury 3 // i: uint64

*for_0:
	// examples/reti/stakingPool.algo.ts:225
	// i < this.stakers.value.length
	frame_dig 3 // i: uint64
	int 200
	<
	bz *for_0_end

	// *if2_condition
	// examples/reti/stakingPool.algo.ts:226
	// globals.opcodeBudget < 300
	global OpcodeBudget
	int 300
	<
	bz *if2_end

	// *if2_consequent
	// examples/reti/stakingPool.algo.ts:227
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	pushint 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

*if2_end:
	// examples/reti/stakingPool.algo.ts:229
	// cmpStaker = clone(this.stakers.value[i])
	frame_dig 3 // i: uint64
	int 64
	* // acc * typeLength
	int 64
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_extract
	frame_bury 4 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// *if3_condition
	// examples/reti/stakingPool.algo.ts:230
	// cmpStaker.account === staker
	frame_dig 4 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 0 32
	frame_dig -2 // staker: Address
	==
	bz *if3_end

	// *if3_consequent
	// examples/reti/stakingPool.algo.ts:232
	// cmpStaker.balance += stakedAmountPayment.amount
	frame_dig 4 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	int 32 // headOffset
	frame_dig 4 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Amount
	+
	itob
	replace3
	frame_bury 4 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:233
	// cmpStaker.entryRound = entryRound
	frame_dig 4 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	pushint 56 // headOffset
	frame_dig 0 // entryRound: uint64
	itob
	replace3
	frame_bury 4 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:236
	// this.stakers.value[i] = cmpStaker
	frame_dig 3 // i: uint64
	int 64
	* // acc * typeLength
	frame_dig 4 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_replace

	// examples/reti/stakingPool.algo.ts:238
	// return entryRound;
	frame_dig 0 // entryRound: uint64
	b *addStake*return

*if3_end:
	// *if4_condition
	// examples/reti/stakingPool.algo.ts:240
	// firstEmpty === 0 && cmpStaker.account === globals.zeroAddress
	frame_dig 1 // firstEmpty: uint64
	int 0
	==
	dup
	bz *skip_and2
	frame_dig 4 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 0 32
	global ZeroAddress
	==
	&&

*skip_and2:
	bz *if4_end

	// *if4_consequent
	// examples/reti/stakingPool.algo.ts:241
	// firstEmpty = i + 1
	frame_dig 3 // i: uint64
	int 1
	+
	frame_bury 1 // firstEmpty: uint64

*if4_end:

*for_0_continue:
	// examples/reti/stakingPool.algo.ts:225
	// i += 1
	frame_dig 3 // i: uint64
	int 1
	+
	frame_bury 3 // i: uint64
	b *for_0

*for_0_end:
	// *if5_condition
	// examples/reti/stakingPool.algo.ts:245
	// firstEmpty === 0
	frame_dig 1 // firstEmpty: uint64
	int 0
	==
	bz *if5_end

	// *if5_consequent
	// Staking pool full
	err

*if5_end:
	// examples/reti/stakingPool.algo.ts:252
	// assert(stakedAmountPayment.amount >= this.minEntryStake.value, 'must stake at least the minimum for this pool')
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Amount
	byte 0x6d696e456e7472795374616b65 // "minEntryStake"
	app_global_get
	>=

	// must stake at least the minimum for this pool
	assert

	// examples/reti/stakingPool.algo.ts:254
	// assert(this.stakers.value[firstEmpty - 1].account === globals.zeroAddress)
	frame_dig 1 // firstEmpty: uint64
	int 1
	-
	int 64
	* // acc * typeLength
	int 0
	+
	int 32
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_extract
	global ZeroAddress
	==
	assert

	// examples/reti/stakingPool.algo.ts:255
	// this.stakers.value[firstEmpty - 1] = {
	//       account: staker,
	//       balance: stakedAmountPayment.amount,
	//       totalRewarded: 0,
	//       rewardTokenBalance: 0,
	//       entryRound: entryRound,
	//     }
	frame_dig 1 // firstEmpty: uint64
	int 1
	-
	int 64
	* // acc * typeLength
	frame_dig -2 // staker: Address
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Amount
	itob
	concat
	byte 0x0000000000000000
	concat
	byte 0x0000000000000000
	concat
	frame_dig 0 // entryRound: uint64
	itob
	concat
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_replace

	// examples/reti/stakingPool.algo.ts:262
	// this.numStakers.value += 1
	byte 0x6e756d5374616b657273 // "numStakers"
	app_global_get
	int 1
	+
	byte 0x6e756d5374616b657273 // "numStakers"
	swap
	app_global_put

	// examples/reti/stakingPool.algo.ts:263
	// return entryRound;
	frame_dig 0 // entryRound: uint64

*addStake*return:
	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 4
	retsub

// removeStake(address,uint64)void
*abi_route_removeStake:
	// amountToUnstake: uint64
	txna ApplicationArgs 2
	btoi

	// staker: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (staker) for removeStake must be a address
	assert

	// execute removeStake(address,uint64)void
	callsub removeStake
	int 1
	return

// removeStake(staker: Address, amountToUnstake: uint64): void
//
// Removes stake on behalf of caller (removing own stake).  If any token rewards exist, those are always sent in
// full. Also notifies the validator contract for this pools validator of the staker / balance changes.
//
// @param {Address} staker - account to remove.  normally same as sender, but the validator owner or manager can also call
// this to remove the specified staker explicitly. The removed stake MUST only go to the staker of course.  This is
// so a validator can shut down a poool and refund the stakers.  It can also be used to kick out stakers who no longer
// meet the gating requirements (determined by the node daemon).
// @param {uint64} amountToUnstake - The amount of stake to be removed.  Specify 0 to remove all stake.
// @throws {Error} If the account has insufficient balance or if the account is not found.
removeStake:
	proto 2 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 6

	// *if6_condition
	// examples/reti/stakingPool.algo.ts:280
	// staker !== this.txn.sender
	frame_dig -1 // staker: Address
	txn Sender
	!=
	bz *if6_end

	// *if6_consequent
	// examples/reti/stakingPool.algo.ts:281
	// assert(
	//         this.isOwnerOrManagerCaller(),
	//         'If staker is not sender in removeStake call, then sender MUST be owner or manager of validator'
	//       )
	callsub isOwnerOrManagerCaller

	// If staker is not sender in removeStake call, then sender MUST be owner or manager of validator
	assert

*if6_end:
	// examples/reti/stakingPool.algo.ts:287
	// this.checkIfBinClosed()
	callsub checkIfBinClosed

	// examples/reti/stakingPool.algo.ts:289
	// for (let i = 0; i < this.stakers.value.length; i += 1)
	int 0
	frame_bury 0 // i: uint64

*for_1:
	// examples/reti/stakingPool.algo.ts:289
	// i < this.stakers.value.length
	frame_dig 0 // i: uint64
	int 200
	<
	bz *for_1_end

	// *if7_condition
	// examples/reti/stakingPool.algo.ts:290
	// globals.opcodeBudget < 300
	global OpcodeBudget
	int 300
	<
	bz *if7_end

	// *if7_consequent
	// examples/reti/stakingPool.algo.ts:291
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	pushint 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

*if7_end:
	// examples/reti/stakingPool.algo.ts:293
	// cmpStaker = clone(this.stakers.value[i])
	frame_dig 0 // i: uint64
	int 64
	* // acc * typeLength
	int 64
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_extract
	frame_bury 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// *if8_condition
	// examples/reti/stakingPool.algo.ts:294
	// cmpStaker.account === staker
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 0 32
	frame_dig -1 // staker: Address
	==
	bz *if8_end

	// *if8_consequent
	// *if9_condition
	// examples/reti/stakingPool.algo.ts:295
	// amountToUnstake === 0
	frame_dig -2 // amountToUnstake: uint64
	int 0
	==
	bz *if9_end

	// *if9_consequent
	// examples/reti/stakingPool.algo.ts:297
	// amountToUnstake = cmpStaker.balance
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	frame_bury -2 // amountToUnstake: uint64

*if9_end:
	// *if10_condition
	// examples/reti/stakingPool.algo.ts:299
	// cmpStaker.balance < amountToUnstake
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	frame_dig -2 // amountToUnstake: uint64
	<
	bz *if10_end

	// *if10_consequent
	// Insufficient balance
	err

*if10_end:
	// examples/reti/stakingPool.algo.ts:302
	// cmpStaker.balance -= amountToUnstake
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	int 32 // headOffset
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	frame_dig -2 // amountToUnstake: uint64
	-
	itob
	replace3
	frame_bury 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:303
	// this.totalAlgoStaked.value -= amountToUnstake
	byte 0x7374616b6564 // "staked"
	app_global_get
	frame_dig -2 // amountToUnstake: uint64
	-
	byte 0x7374616b6564 // "staked"
	swap
	app_global_put

	// examples/reti/stakingPool.algo.ts:305
	// amountRewardTokenRemoved = 0
	int 0
	frame_bury 2 // amountRewardTokenRemoved: uint64

	// *if11_condition
	// examples/reti/stakingPool.algo.ts:306
	// cmpStaker.rewardTokenBalance > 0
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 48 8
	btoi
	int 0
	>
	bz *if11_end

	// *if11_consequent
	// *if12_condition
	// examples/reti/stakingPool.algo.ts:308
	// this.poolId.value === 1
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	int 1
	==
	bz *if12_else

	// *if12_consequent
	// examples/reti/stakingPool.algo.ts:309
	// validatorConfig = sendMethodCall<typeof ValidatorRegistry.prototype.getValidatorConfig>({
	//               applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//               methodArgs: [this.validatorId.value],
	//             })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0x75aff61d // method "getValidatorConfig(uint64)(uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:310
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:311
	// methodArgs: [this.validatorId.value]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0
	frame_bury 3 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:317
	// sendAssetTransfer({
	//               xferAsset: AssetID.fromUint64(validatorConfig.rewardTokenId),
	//               assetReceiver: staker,
	//               assetAmount: cmpStaker.rewardTokenBalance,
	//             })
	itxn_begin
	pushint 4 // axfer
	itxn_field TypeEnum

	// examples/reti/stakingPool.algo.ts:318
	// xferAsset: AssetID.fromUint64(validatorConfig.rewardTokenId)
	frame_dig 3 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 153 8
	btoi
	itxn_field XferAsset

	// examples/reti/stakingPool.algo.ts:319
	// assetReceiver: staker
	frame_dig -1 // staker: Address
	itxn_field AssetReceiver

	// examples/reti/stakingPool.algo.ts:320
	// assetAmount: cmpStaker.rewardTokenBalance
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 48 8
	btoi
	itxn_field AssetAmount

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/stakingPool.algo.ts:322
	// amountRewardTokenRemoved = cmpStaker.rewardTokenBalance
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 48 8
	btoi
	frame_bury 2 // amountRewardTokenRemoved: uint64

	// examples/reti/stakingPool.algo.ts:323
	// cmpStaker.rewardTokenBalance = 0
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	byte 0x0000000000000000
	replace2 48
	frame_bury 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	b *if12_end

*if12_else:
	// examples/reti/stakingPool.algo.ts:328
	// amountRewardTokenRemoved = cmpStaker.rewardTokenBalance
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 48 8
	btoi
	frame_bury 2 // amountRewardTokenRemoved: uint64

	// examples/reti/stakingPool.algo.ts:329
	// cmpStaker.rewardTokenBalance = 0
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	byte 0x0000000000000000
	replace2 48
	frame_bury 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)

*if12_end:

*if11_end:
	// examples/reti/stakingPool.algo.ts:334
	// assert(
	//           cmpStaker.balance === 0 || cmpStaker.balance >= this.minEntryStake.value,
	//           'cannot reduce balance below minimum allowed stake unless all is removed'
	//         )
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	int 0
	==
	dup
	bnz *skip_or0
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	byte 0x6d696e456e7472795374616b65 // "minEntryStake"
	app_global_get
	>=
	||

*skip_or0:
	// cannot reduce balance below minimum allowed stake unless all is removed
	assert

	// examples/reti/stakingPool.algo.ts:342
	// sendPayment({
	//           amount: amountToUnstake,
	//           receiver: staker,
	//           note: 'unstaked',
	//         })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// examples/reti/stakingPool.algo.ts:343
	// amount: amountToUnstake
	frame_dig -2 // amountToUnstake: uint64
	itxn_field Amount

	// examples/reti/stakingPool.algo.ts:344
	// receiver: staker
	frame_dig -1 // staker: Address
	itxn_field Receiver

	// examples/reti/stakingPool.algo.ts:345
	// note: 'unstaked'
	pushbytes 0x756e7374616b6564 // "unstaked"
	itxn_field Note

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/stakingPool.algo.ts:347
	// stakerRemoved = false
	int 0
	frame_bury 4 // stakerRemoved: bool

	// *if13_condition
	// examples/reti/stakingPool.algo.ts:348
	// cmpStaker.balance === 0
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	int 0
	==
	bz *if13_end

	// *if13_consequent
	// examples/reti/stakingPool.algo.ts:350
	// this.numStakers.value -= 1
	byte 0x6e756d5374616b657273 // "numStakers"
	app_global_get
	int 1
	-
	byte 0x6e756d5374616b657273 // "numStakers"
	swap
	app_global_put

	// examples/reti/stakingPool.algo.ts:351
	// cmpStaker.account = globals.zeroAddress
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	int 0
	global ZeroAddress
	replace3
	frame_bury 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:352
	// cmpStaker.totalRewarded = 0
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	byte 0x0000000000000000
	replace2 40
	frame_bury 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:353
	// cmpStaker.rewardTokenBalance = 0
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	byte 0x0000000000000000
	replace2 48
	frame_bury 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:354
	// stakerRemoved = true
	int 1
	frame_bury 4 // stakerRemoved: bool

*if13_end:
	// examples/reti/stakingPool.algo.ts:357
	// this.stakers.value[i] = cmpStaker
	frame_dig 0 // i: uint64
	int 64
	* // acc * typeLength
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_replace

	// examples/reti/stakingPool.algo.ts:359
	// roundsLeftInBin = this.binRoundStart.value + this.roundsPerDay.value - globals.round
	byte 0x62696e526f756e645374617274 // "binRoundStart"
	app_global_get
	byte 0x726f756e6473506572446179 // "roundsPerDay"
	app_global_get
	+
	global Round
	-
	frame_bury 5 // roundsLeftInBin: uint64

	// examples/reti/stakingPool.algo.ts:360
	// subtractAmount: uint128 = (amountToUnstake as uint128) * (roundsLeftInBin as uint128)
	frame_dig -2 // amountToUnstake: uint64
	itob
	frame_dig 5 // roundsLeftInBin: uint64
	itob
	b*
	dup
	bitlen
	int 128
	<=

	// (amountToUnstake as uint128) * (roundsLeftInBin as uint128) overflowed 128 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 16
	-
	swap
	substring3
	frame_bury 6 // subtractAmount: uint128

	// examples/reti/stakingPool.algo.ts:361
	// this.stakeAccumulator.value = this.stakeAccumulator.value - subtractAmount
	byte 0x7374616b65416363756d756c61746f72 // "stakeAccumulator"
	dup
	app_global_get
	frame_dig 6 // subtractAmount: uint128
	b-
	dup
	bitlen
	int 128
	<=

	// this.stakeAccumulator.value - subtractAmount overflowed 128 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 16
	-
	swap
	substring3
	app_global_put

	// examples/reti/stakingPool.algo.ts:366
	// sendMethodCall<typeof ValidatorRegistry.prototype.stakeRemoved>({
	//           applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//           methodArgs: [
	//             { id: this.validatorId.value, poolId: this.poolId.value, poolAppId: this.app.id },
	//             staker,
	//             amountToUnstake,
	//             amountRewardTokenRemoved,
	//             stakerRemoved,
	//           ],
	//         })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0xa2dc51b5 // method "stakeRemoved((uint64,uint64,uint64),address,uint64,uint64,bool)void"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:367
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:368
	// methodArgs: [
	//             { id: this.validatorId.value, poolId: this.poolId.value, poolAppId: this.app.id },
	//             staker,
	//             amountToUnstake,
	//             amountRewardTokenRemoved,
	//             stakerRemoved,
	//           ]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	itob
	concat
	txna Applications 0
	itob
	concat
	itxn_field ApplicationArgs
	frame_dig -1 // staker: Address
	itxn_field ApplicationArgs
	frame_dig -2 // amountToUnstake: uint64
	itob
	itxn_field ApplicationArgs
	frame_dig 2 // amountRewardTokenRemoved: uint64
	itob
	itxn_field ApplicationArgs
	frame_dig 4 // stakerRemoved: bool
	byte 0x00
	int 0
	uncover 2
	setbit
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/stakingPool.algo.ts:376
	// return;
	retsub

*if8_end:

*for_1_continue:
	// examples/reti/stakingPool.algo.ts:289
	// i += 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64
	b *for_1

*for_1_end:
	// account not found
	err
	retsub

// claimTokens()void
*abi_route_claimTokens:
	// execute claimTokens()void
	callsub claimTokens
	int 1
	return

// claimTokens(): void
//
// Claims all the available reward tokens a staker has available, sending their entire balance to the staker from
// pool 1 (either directly, or via validator->pool1 to pay it out)
// Also notifies the validator contract for this pools validator of the staker / balance changes.
claimTokens:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 4

	// examples/reti/stakingPool.algo.ts:391
	// staker = this.txn.sender
	txn Sender
	frame_bury 0 // staker: address

	// examples/reti/stakingPool.algo.ts:393
	// for (let i = 0; i < this.stakers.value.length; i += 1)
	int 0
	frame_bury 1 // i: uint64

*for_2:
	// examples/reti/stakingPool.algo.ts:393
	// i < this.stakers.value.length
	frame_dig 1 // i: uint64
	int 200
	<
	bz *for_2_end

	// *if14_condition
	// examples/reti/stakingPool.algo.ts:394
	// globals.opcodeBudget < 300
	global OpcodeBudget
	int 300
	<
	bz *if14_end

	// *if14_consequent
	// examples/reti/stakingPool.algo.ts:395
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	pushint 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

*if14_end:
	// examples/reti/stakingPool.algo.ts:397
	// cmpStaker = clone(this.stakers.value[i])
	frame_dig 1 // i: uint64
	int 64
	* // acc * typeLength
	int 64
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_extract
	frame_bury 2 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// *if15_condition
	// examples/reti/stakingPool.algo.ts:398
	// cmpStaker.account === staker
	frame_dig 2 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 0 32
	frame_dig 0 // staker: address
	==
	bz *if15_end

	// *if15_consequent
	// *if16_condition
	// examples/reti/stakingPool.algo.ts:399
	// cmpStaker.rewardTokenBalance === 0
	frame_dig 2 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 48 8
	btoi
	int 0
	==
	bz *if16_end

	// *if16_consequent
	// examples/reti/stakingPool.algo.ts:400
	// return;
	retsub

*if16_end:
	// examples/reti/stakingPool.algo.ts:402
	// amountRewardTokenRemoved = 0
	int 0
	frame_bury 3 // amountRewardTokenRemoved: uint64

	// *if17_condition
	// examples/reti/stakingPool.algo.ts:404
	// this.poolId.value === 1
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	int 1
	==
	bz *if17_else

	// *if17_consequent
	// examples/reti/stakingPool.algo.ts:405
	// validatorConfig = sendMethodCall<typeof ValidatorRegistry.prototype.getValidatorConfig>({
	//             applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//             methodArgs: [this.validatorId.value],
	//           })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0x75aff61d // method "getValidatorConfig(uint64)(uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:406
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:407
	// methodArgs: [this.validatorId.value]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0
	frame_bury 4 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:412
	// sendAssetTransfer({
	//             xferAsset: AssetID.fromUint64(validatorConfig.rewardTokenId),
	//             assetReceiver: staker,
	//             assetAmount: cmpStaker.rewardTokenBalance,
	//           })
	itxn_begin
	pushint 4 // axfer
	itxn_field TypeEnum

	// examples/reti/stakingPool.algo.ts:413
	// xferAsset: AssetID.fromUint64(validatorConfig.rewardTokenId)
	frame_dig 4 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 153 8
	btoi
	itxn_field XferAsset

	// examples/reti/stakingPool.algo.ts:414
	// assetReceiver: staker
	frame_dig 0 // staker: address
	itxn_field AssetReceiver

	// examples/reti/stakingPool.algo.ts:415
	// assetAmount: cmpStaker.rewardTokenBalance
	frame_dig 2 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 48 8
	btoi
	itxn_field AssetAmount

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/stakingPool.algo.ts:417
	// amountRewardTokenRemoved = cmpStaker.rewardTokenBalance
	frame_dig 2 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 48 8
	btoi
	frame_bury 3 // amountRewardTokenRemoved: uint64

	// examples/reti/stakingPool.algo.ts:418
	// cmpStaker.rewardTokenBalance = 0
	frame_dig 2 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	byte 0x0000000000000000
	replace2 48
	frame_bury 2 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	b *if17_end

*if17_else:
	// examples/reti/stakingPool.algo.ts:423
	// amountRewardTokenRemoved = cmpStaker.rewardTokenBalance
	frame_dig 2 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 48 8
	btoi
	frame_bury 3 // amountRewardTokenRemoved: uint64

	// examples/reti/stakingPool.algo.ts:424
	// cmpStaker.rewardTokenBalance = 0
	frame_dig 2 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	byte 0x0000000000000000
	replace2 48
	frame_bury 2 // cmpStaker: (address,uint64,uint64,uint64,uint64)

*if17_end:
	// examples/reti/stakingPool.algo.ts:428
	// this.stakers.value[i] = cmpStaker
	frame_dig 1 // i: uint64
	int 64
	* // acc * typeLength
	frame_dig 2 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_replace

	// examples/reti/stakingPool.algo.ts:433
	// sendMethodCall<typeof ValidatorRegistry.prototype.stakeRemoved>({
	//           applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//           methodArgs: [
	//             { id: this.validatorId.value, poolId: this.poolId.value, poolAppId: this.app.id },
	//             staker,
	//             0, // no algo removed
	//             amountRewardTokenRemoved,
	//             false, // staker isn't being removed.
	//           ],
	//         })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0xa2dc51b5 // method "stakeRemoved((uint64,uint64,uint64),address,uint64,uint64,bool)void"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:434
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:435
	// methodArgs: [
	//             { id: this.validatorId.value, poolId: this.poolId.value, poolAppId: this.app.id },
	//             staker,
	//             0, // no algo removed
	//             amountRewardTokenRemoved,
	//             false, // staker isn't being removed.
	//           ]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	itob
	concat
	txna Applications 0
	itob
	concat
	itxn_field ApplicationArgs
	frame_dig 0 // staker: address
	itxn_field ApplicationArgs
	byte 0x0000000000000000
	itxn_field ApplicationArgs
	frame_dig 3 // amountRewardTokenRemoved: uint64
	itob
	itxn_field ApplicationArgs
	int 0
	byte 0x00
	int 0
	uncover 2
	setbit
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/stakingPool.algo.ts:443
	// return;
	retsub

*if15_end:

*for_2_continue:
	// examples/reti/stakingPool.algo.ts:393
	// i += 1
	frame_dig 1 // i: uint64
	int 1
	+
	frame_bury 1 // i: uint64
	b *for_2

*for_2_end:
	// account not found
	err
	retsub

// getStakerInfo(address)(address,uint64,uint64,uint64,uint64)
*abi_route_getStakerInfo:
	// The ABI return prefix
	byte 0x151f7c75

	// staker: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (staker) for getStakerInfo must be a address
	assert

	// execute getStakerInfo(address)(address,uint64,uint64,uint64,uint64)
	callsub getStakerInfo
	concat
	log
	int 1
	return

// getStakerInfo(staker: Address): StakedInfo
//
// Retrieves the staked information for a given staker.
//
// @param {Address} staker - The address of the staker.
// @returns {StakedInfo} - The staked information for the given staker.
// @throws {Error} - If the staker's account is not found.
getStakerInfo:
	proto 1 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/reti/stakingPool.algo.ts:458
	// for (let i = 0; i < this.stakers.value.length; i += 1)
	int 0
	frame_bury 0 // i: uint64

*for_3:
	// examples/reti/stakingPool.algo.ts:458
	// i < this.stakers.value.length
	frame_dig 0 // i: uint64
	int 200
	<
	bz *for_3_end

	// *if18_condition
	// examples/reti/stakingPool.algo.ts:459
	// globals.opcodeBudget < 200
	global OpcodeBudget
	int 200
	<
	bz *if18_end

	// *if18_consequent
	// examples/reti/stakingPool.algo.ts:460
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	pushint 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

*if18_end:
	// *if19_condition
	// examples/reti/stakingPool.algo.ts:462
	// this.stakers.value[i].account === staker
	frame_dig 0 // i: uint64
	int 64
	* // acc * typeLength
	int 0
	+
	int 32
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_extract
	frame_dig -1 // staker: Address
	==
	bz *if19_end

	// *if19_consequent
	// examples/reti/stakingPool.algo.ts:463
	// return this.stakers.value[i];
	frame_dig 0 // i: uint64
	int 64
	* // acc * typeLength
	int 64
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_extract
	b *getStakerInfo*return

*if19_end:

*for_3_continue:
	// examples/reti/stakingPool.algo.ts:458
	// i += 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64
	b *for_3

*for_3_end:
	// account not found
	err

*getStakerInfo*return:
	// set the subroutine return value
	frame_bury 0
	retsub

// payTokenReward(address,uint64,uint64)void
*abi_route_payTokenReward:
	// amountToSend: uint64
	txna ApplicationArgs 3
	btoi

	// rewardToken: uint64
	txna ApplicationArgs 2
	btoi

	// staker: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 2 (staker) for payTokenReward must be a address
	assert

	// execute payTokenReward(address,uint64,uint64)void
	callsub payTokenReward
	int 1
	return

// payTokenReward(staker: Address, rewardToken: uint64, amountToSend: uint64): void
//
// [Internal protocol method] Remove a specified amount of 'community token' rewards for a staker.
// This can ONLY be called by our validator and only if we're pool 1 - with the token.
// Note: this can also be called by validator as part of OWNER wanting to send the reward tokens
// somewhere else (ie if they're sunsetting their validator and need the reward tokens back).
// It's up to the validator to ensure that the balance in rewardTokenHeldBack is honored.
// @param staker - the staker account to send rewards to
// @param rewardToken - id of reward token (to avoid re-entrancy in calling validator back to get id)
// @param amountToSend - amount to send the staker (there is significant trust here(!) - also why only validator can call us
payTokenReward:
	proto 3 0

	// examples/reti/stakingPool.algo.ts:481
	// assert(
	//       this.txn.sender === AppID.fromUint64(this.creatingValidatorContractAppId.value).address,
	//       'this can only be called via the validator contract'
	//     )
	txn Sender
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	app_params_get AppAddress
	pop
	==

	// this can only be called via the validator contract
	assert

	// examples/reti/stakingPool.algo.ts:485
	// assert(this.poolId.value === 1, 'must be pool 1 in order to be called to pay out token rewards')
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	int 1
	==

	// must be pool 1 in order to be called to pay out token rewards
	assert

	// examples/reti/stakingPool.algo.ts:486
	// assert(rewardToken !== 0, 'can only claim token rewards from validator that has them')
	frame_dig -2 // rewardToken: uint64
	int 0
	!=

	// can only claim token rewards from validator that has them
	assert

	// examples/reti/stakingPool.algo.ts:489
	// sendAssetTransfer({
	//       xferAsset: AssetID.fromUint64(rewardToken),
	//       assetReceiver: staker,
	//       assetAmount: amountToSend,
	//     })
	itxn_begin
	pushint 4 // axfer
	itxn_field TypeEnum

	// examples/reti/stakingPool.algo.ts:490
	// xferAsset: AssetID.fromUint64(rewardToken)
	frame_dig -2 // rewardToken: uint64
	itxn_field XferAsset

	// examples/reti/stakingPool.algo.ts:491
	// assetReceiver: staker
	frame_dig -1 // staker: Address
	itxn_field AssetReceiver

	// examples/reti/stakingPool.algo.ts:492
	// assetAmount: amountToSend
	frame_dig -3 // amountToSend: uint64
	itxn_field AssetAmount

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// updateAlgodVer(string)void
*abi_route_updateAlgodVer:
	// algodVer: string
	txna ApplicationArgs 1
	extract 2 0

	// execute updateAlgodVer(string)void
	callsub updateAlgodVer
	int 1
	return

// updateAlgodVer(algodVer: string): void
//
// Update the (honor system) algod version for the node associated to this pool.  The node management daemon
// should compare its current nodes version to the version stored in global state, updating when different.
// The reti node daemon composes its own version string using format:
// {major}.{minor}.{build} {branch} [{commit hash}],
// ie: 3.22.0 rel/stable [6b508975]
// [ ONLY OWNER OR MANAGER CAN CALL ]
// @param {string} algodVer - string representing the algorand node daemon version (reti node daemon composes its own meta version)
updateAlgodVer:
	proto 1 0

	// examples/reti/stakingPool.algo.ts:506
	// assert(this.isOwnerOrManagerCaller(), 'can only be called by owner or manager of validator')
	callsub isOwnerOrManagerCaller

	// can only be called by owner or manager of validator
	assert

	// examples/reti/stakingPool.algo.ts:507
	// this.algodVer.value = algodVer
	pushbytes 0x616c676f64566572 // "algodVer"
	frame_dig -1 // algodVer: string
	app_global_put
	retsub

// epochBalanceUpdate()void
*abi_route_epochBalanceUpdate:
	// execute epochBalanceUpdate()void
	callsub epochBalanceUpdate
	int 1
	return

// epochBalanceUpdate(): void
//
// Updates the balance of stakers in the pool based on the received 'rewards' (current balance vs known staked balance)
// stakers outstanding balance is adjusted based on their % of stake and time in the current epoch - so that balance
// compounds over time and staker can remove that amount at will.
// The validator is paid their percentage each epoch payout.
//
// Note: ANYONE can call this.
epochBalanceUpdate:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 36

	// examples/reti/stakingPool.algo.ts:520
	// validatorConfig = sendMethodCall<typeof ValidatorRegistry.prototype.getValidatorConfig>({
	//       applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//       methodArgs: [this.validatorId.value],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0x75aff61d // method "getValidatorConfig(uint64)(uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:521
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:522
	// methodArgs: [this.validatorId.value]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0
	frame_bury 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:529
	// epochRoundLength = validatorConfig.epochRoundLength as uint64
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 169 4
	btoi
	frame_bury 1 // epochRoundLength: uint64

	// examples/reti/stakingPool.algo.ts:530
	// curRound = globals.round
	global Round
	frame_bury 2 // curRound: uint64

	// examples/reti/stakingPool.algo.ts:531
	// thisEpochBegin = curRound - (curRound % epochRoundLength)
	frame_dig 2 // curRound: uint64
	frame_dig 2 // curRound: uint64
	frame_dig 1 // epochRoundLength: uint64
	%
	-
	frame_bury 3 // thisEpochBegin: uint64

	// *if20_condition
	// examples/reti/stakingPool.algo.ts:534
	// this.lastPayout.exists
	txna Applications 0
	byte 0x6c6173745061796f7574 // "lastPayout"
	app_global_get_ex
	swap
	pop
	bz *if20_end

	// *if20_consequent
	// examples/reti/stakingPool.algo.ts:535
	// lastPayoutEpoch = this.lastPayout.value - (this.lastPayout.value % epochRoundLength)
	byte 0x6c6173745061796f7574 // "lastPayout"
	app_global_get
	byte 0x6c6173745061796f7574 // "lastPayout"
	app_global_get
	frame_dig 1 // epochRoundLength: uint64
	%
	-
	frame_bury 4 // lastPayoutEpoch: uint64

	// examples/reti/stakingPool.algo.ts:539
	// assert(lastPayoutEpoch !== thisEpochBegin, "can't call epochBalanceUpdate in same epoch as prior call")
	frame_dig 4 // lastPayoutEpoch: uint64
	frame_dig 3 // thisEpochBegin: uint64
	!=

	// can't call epochBalanceUpdate in same epoch as prior call
	assert

*if20_end:
	// examples/reti/stakingPool.algo.ts:542
	// this.checkIfBinClosed()
	callsub checkIfBinClosed

	// examples/reti/stakingPool.algo.ts:545
	// this.lastPayout.value = curRound
	byte 0x6c6173745061796f7574 // "lastPayout"
	frame_dig 2 // curRound: uint64
	app_global_put

	// examples/reti/stakingPool.algo.ts:546
	// this.epochNumber.value += 1
	byte 0x65706f63684e756d626572 // "epochNumber"
	app_global_get
	int 1
	+
	byte 0x65706f63684e756d626572 // "epochNumber"
	swap
	app_global_put

	// examples/reti/stakingPool.algo.ts:551
	// isTokenEligible = validatorConfig.rewardTokenId !== 0
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 153 8
	btoi
	int 0
	!=
	frame_bury 5 // isTokenEligible: bool

	// examples/reti/stakingPool.algo.ts:552
	// poolOneAppID = this.app.id
	txna Applications 0
	frame_bury 6 // poolOneAppID: uint64

	// examples/reti/stakingPool.algo.ts:553
	// poolOneAddress = this.app.address
	global CurrentApplicationAddress
	frame_bury 7 // poolOneAddress: address

	// *if21_condition
	// examples/reti/stakingPool.algo.ts:558
	// isTokenEligible
	frame_dig 5 // isTokenEligible: bool
	bz *if21_end

	// *if21_consequent
	// *if22_condition
	// examples/reti/stakingPool.algo.ts:559
	// this.poolId.value !== 1
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	int 1
	!=
	bz *if22_end

	// *if22_consequent
	// examples/reti/stakingPool.algo.ts:561
	// poolOneAppID = sendMethodCall<typeof ValidatorRegistry.prototype.getPoolAppId>({
	//           applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//           methodArgs: [this.validatorId.value, 1],
	//         })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0x572767d1 // method "getPoolAppId(uint64,uint64)uint64"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:562
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:563
	// methodArgs: [this.validatorId.value, 1]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	itxn_field ApplicationArgs
	pushbytes 0x0000000000000001
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0
	btoi
	frame_bury 6 // poolOneAppID: uint64

	// examples/reti/stakingPool.algo.ts:565
	// poolOneAddress = AppID.fromUint64(poolOneAppID).address
	frame_dig 6 // poolOneAppID: uint64
	app_params_get AppAddress
	pop
	frame_bury 7 // poolOneAddress: address

*if22_end:
	// *if23_condition
	// examples/reti/stakingPool.algo.ts:570
	// this.poolId.value === 1
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	int 1
	==
	bz *if23_else

	// *if23_consequent
	// examples/reti/stakingPool.algo.ts:571
	// tokenPayoutRatio = sendMethodCall<typeof ValidatorRegistry.prototype.setTokenPayoutRatio>({
	//           applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//           methodArgs: [this.validatorId.value],
	//         })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0x4df8d86e // method "setTokenPayoutRatio(uint64)(uint64[24],uint64)"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:572
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:573
	// methodArgs: [this.validatorId.value]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0
	frame_bury 8 // tokenPayoutRatio: PoolTokenPayoutRatio
	b *if23_end

*if23_else:
	// examples/reti/stakingPool.algo.ts:577
	// tokenPayoutRatio = sendMethodCall<typeof StakingPool.prototype.proxiedSetTokenPayoutRatio>({
	//           applicationID: AppID.fromUint64(poolOneAppID),
	//           methodArgs: [{ id: this.validatorId.value, poolId: this.poolId.value, poolAppId: this.app.id }],
	//         })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0x0c2245e1 // method "proxiedSetTokenPayoutRatio((uint64,uint64,uint64))(uint64[24],uint64)"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:578
	// applicationID: AppID.fromUint64(poolOneAppID)
	frame_dig 6 // poolOneAppID: uint64
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:579
	// methodArgs: [{ id: this.validatorId.value, poolId: this.poolId.value, poolAppId: this.app.id }]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	itob
	concat
	txna Applications 0
	itob
	concat
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0
	frame_bury 8 // tokenPayoutRatio: PoolTokenPayoutRatio

*if23_end:

*if21_end:
	// examples/reti/stakingPool.algo.ts:586
	// validatorState = sendMethodCall<typeof ValidatorRegistry.prototype.getValidatorState>({
	//       applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//       methodArgs: [this.validatorId.value],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	pushbytes 0x1f2f0109 // method "getValidatorState(uint64)(uint16,uint64,uint64,uint64)"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:587
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:588
	// methodArgs: [this.validatorId.value]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0
	frame_bury 9 // validatorState: (uint16,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:590
	// rewardTokenHeldBack = validatorState.rewardTokenHeldBack
	frame_dig 9 // validatorState: (uint16,uint64,uint64,uint64)
	extract 18 8
	btoi
	frame_bury 10 // rewardTokenHeldBack: uint64

	// examples/reti/stakingPool.algo.ts:596
	// algoRewardAvail = this.app.address.balance - this.totalAlgoStaked.value - this.app.address.minBalance
	global CurrentApplicationAddress
	acct_params_get AcctBalance
	pop
	byte 0x7374616b6564 // "staked"
	app_global_get
	-
	global CurrentApplicationAddress
	acct_params_get AcctMinBalance
	pop
	-
	frame_bury 11 // algoRewardAvail: uint64

	// examples/reti/stakingPool.algo.ts:597
	// isPoolSaturated = false
	int 0
	frame_bury 12 // isPoolSaturated: bool

	// examples/reti/stakingPool.algo.ts:598
	// algoSaturationAmt = this.algoSaturationLevel()
	callsub algoSaturationLevel
	frame_bury 13 // algoSaturationAmt: uint64

	// *if24_condition
	// examples/reti/stakingPool.algo.ts:606
	// validatorState.totalAlgoStaked > algoSaturationAmt
	frame_dig 9 // validatorState: (uint16,uint64,uint64,uint64)
	extract 10 8
	btoi
	frame_dig 13 // algoSaturationAmt: uint64
	>
	bz *if24_end

	// *if24_consequent
	// examples/reti/stakingPool.algo.ts:607
	// isPoolSaturated = true
	int 1
	frame_bury 12 // isPoolSaturated: bool

*if24_end:
	// examples/reti/stakingPool.algo.ts:613
	// tokenRewardAvail = 0
	int 0
	frame_bury 14 // tokenRewardAvail: uint64

	// examples/reti/stakingPool.algo.ts:614
	// tokenRewardPaidOut = 0
	int 0
	frame_bury 15 // tokenRewardPaidOut: uint64

	// examples/reti/stakingPool.algo.ts:615
	// validatorCommissionPaidOut = 0
	int 0
	frame_bury 16 // validatorCommissionPaidOut: uint64

	// examples/reti/stakingPool.algo.ts:616
	// excessToFeeSink = 0
	int 0
	frame_bury 17 // excessToFeeSink: uint64

	// *if25_condition
	// examples/reti/stakingPool.algo.ts:617
	// isTokenEligible
	frame_dig 5 // isTokenEligible: bool
	bz *if25_end

	// *if25_consequent
	// examples/reti/stakingPool.algo.ts:618
	// tokenRewardBal =
	//         poolOneAddress.assetBalance(AssetID.fromUint64(validatorConfig.rewardTokenId)) - rewardTokenHeldBack
	frame_dig 7 // poolOneAddress: address
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 153 8
	btoi
	asset_holding_get AssetBalance
	pop
	frame_dig 10 // rewardTokenHeldBack: uint64
	-
	frame_bury 18 // tokenRewardBal: uint64

	// *if26_condition
	// examples/reti/stakingPool.algo.ts:623
	// tokenRewardBal >= validatorConfig.rewardPerPayout
	frame_dig 18 // tokenRewardBal: uint64
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 161 8
	btoi
	>=
	bz *if26_end

	// *if26_consequent
	// examples/reti/stakingPool.algo.ts:629
	// ourPoolPctOfWhole = tokenPayoutRatio.poolPctOfWhole[this.poolId.value - 1]
	frame_dig 8 // tokenPayoutRatio: PoolTokenPayoutRatio
	int 0
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	int 1
	-
	pushint 8
	* // acc * typeLength
	+
	pushint 8
	extract3
	btoi
	frame_bury 19 // ourPoolPctOfWhole: uint64

	// examples/reti/stakingPool.algo.ts:632
	// tokenRewardAvail = wideRatio([validatorConfig.rewardPerPayout, ourPoolPctOfWhole], [1_000_000])
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 161 8
	btoi
	frame_dig 19 // ourPoolPctOfWhole: uint64
	mulw
	int 0
	int 1_000_000
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	frame_bury 14 // tokenRewardAvail: uint64

*if26_end:

*if25_end:
	// *if27_condition
	// examples/reti/stakingPool.algo.ts:635
	// tokenRewardAvail === 0
	frame_dig 14 // tokenRewardAvail: uint64
	int 0
	==
	bz *if27_end

	// *if27_consequent
	// *if28_condition
	// examples/reti/stakingPool.algo.ts:640
	// algoRewardAvail < 1_000_000
	frame_dig 11 // algoRewardAvail: uint64
	int 1_000_000
	<
	bz *if28_end

	// *if28_consequent
	// examples/reti/stakingPool.algo.ts:641
	// log('!token&&!noalgo to pay')
	pushbytes 0x21746f6b656e2626216e6f616c676f20746f20706179 // "!token&&!noalgo to pay"
	log

	// examples/reti/stakingPool.algo.ts:642
	// return;
	retsub

*if28_end:

*if27_end:
	// *if29_condition
	// examples/reti/stakingPool.algo.ts:646
	// isPoolSaturated
	frame_dig 12 // isPoolSaturated: bool
	bz *if29_elseif1_condition

	// *if29_consequent
	// examples/reti/stakingPool.algo.ts:649
	// diminishedReward = wideRatio([algoRewardAvail, algoSaturationAmt], [validatorState.totalAlgoStaked])
	frame_dig 11 // algoRewardAvail: uint64
	frame_dig 13 // algoSaturationAmt: uint64
	mulw
	int 0
	frame_dig 9 // validatorState: (uint16,uint64,uint64,uint64)
	extract 10 8
	btoi
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	frame_bury 20 // diminishedReward: uint64

	// examples/reti/stakingPool.algo.ts:651
	// excessToFeeSink = algoRewardAvail - diminishedReward
	frame_dig 11 // algoRewardAvail: uint64
	frame_dig 20 // diminishedReward: uint64
	-
	frame_bury 17 // excessToFeeSink: uint64

	// examples/reti/stakingPool.algo.ts:652
	// sendPayment({
	//         amount: excessToFeeSink,
	//         receiver: this.getFeeSink(),
	//         note: 'pool saturated, excess to fee sink',
	//       })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// examples/reti/stakingPool.algo.ts:653
	// amount: excessToFeeSink
	frame_dig 17 // excessToFeeSink: uint64
	itxn_field Amount

	// examples/reti/stakingPool.algo.ts:654
	// receiver: this.getFeeSink()
	callsub getFeeSink
	itxn_field Receiver

	// examples/reti/stakingPool.algo.ts:655
	// note: 'pool saturated, excess to fee sink'
	pushbytes 0x706f6f6c207361747572617465642c2065786365737320746f206665652073696e6b // "pool saturated, excess to fee sink"
	itxn_field Note

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/stakingPool.algo.ts:658
	// algoRewardAvail = diminishedReward
	frame_dig 20 // diminishedReward: uint64
	frame_bury 11 // algoRewardAvail: uint64
	b *if29_end

*if29_elseif1_condition:
	// examples/reti/stakingPool.algo.ts:659
	// validatorConfig.percentToValidator !== 0
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 173 4
	btoi
	int 0
	!=
	bz *if29_end

	// *if29_elseif1_consequent
	// examples/reti/stakingPool.algo.ts:662
	// validatorCommissionPaidOut = wideRatio(
	//         [algoRewardAvail, validatorConfig.percentToValidator as uint64],
	//         [1_000_000]
	//       )
	frame_dig 11 // algoRewardAvail: uint64
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 173 4
	btoi
	mulw
	int 0
	int 1_000_000
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	frame_bury 16 // validatorCommissionPaidOut: uint64

	// examples/reti/stakingPool.algo.ts:668
	// algoRewardAvail -= validatorCommissionPaidOut
	frame_dig 11 // algoRewardAvail: uint64
	frame_dig 16 // validatorCommissionPaidOut: uint64
	-
	frame_bury 11 // algoRewardAvail: uint64

	// *if30_condition
	// examples/reti/stakingPool.algo.ts:675
	// validatorCommissionPaidOut > 0
	frame_dig 16 // validatorCommissionPaidOut: uint64
	int 0
	>
	bz *if30_end

	// *if30_consequent
	// examples/reti/stakingPool.algo.ts:678
	// managerTopOff = 0
	int 0
	frame_bury 21 // managerTopOff: uint64

	// *if31_condition
	// examples/reti/stakingPool.algo.ts:680
	// validatorConfig.manager !== validatorConfig.validatorCommissionAddress &&
	//           validatorConfig.manager.balance - validatorConfig.manager.minBalance < 2_100_000
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 40 32
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 177 32
	!=
	dup
	bz *skip_and3
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 40 32
	acct_params_get AcctBalance
	pop
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 40 32
	acct_params_get AcctMinBalance
	pop
	-
	int 2_100_000
	<
	&&

*skip_and3:
	bz *if31_end

	// *if31_consequent
	// examples/reti/stakingPool.algo.ts:683
	// managerTopOff = validatorCommissionPaidOut < 2_100_000 ? validatorCommissionPaidOut : 2_100_000
	frame_dig 16 // validatorCommissionPaidOut: uint64
	int 2_100_000
	<
	bz *ternary1_false
	frame_dig 16 // validatorCommissionPaidOut: uint64
	b *ternary1_end

*ternary1_false:
	int 2_100_000

*ternary1_end:
	frame_bury 21 // managerTopOff: uint64

	// examples/reti/stakingPool.algo.ts:684
	// sendPayment({
	//             amount: managerTopOff,
	//             receiver: validatorConfig.manager,
	//             note: 'validator reward to manager for funding epoch updates',
	//           })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// examples/reti/stakingPool.algo.ts:685
	// amount: managerTopOff
	frame_dig 21 // managerTopOff: uint64
	itxn_field Amount

	// examples/reti/stakingPool.algo.ts:686
	// receiver: validatorConfig.manager
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 40 32
	itxn_field Receiver

	// examples/reti/stakingPool.algo.ts:687
	// note: 'validator reward to manager for funding epoch updates'
	pushbytes 0x76616c696461746f722072657761726420746f206d616e6167657220666f722066756e64696e672065706f63682075706461746573 // "validator reward to manager for funding epoch updates"
	itxn_field Note

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

*if31_end:
	// *if32_condition
	// examples/reti/stakingPool.algo.ts:690
	// validatorCommissionPaidOut - managerTopOff > 0
	frame_dig 16 // validatorCommissionPaidOut: uint64
	frame_dig 21 // managerTopOff: uint64
	-
	int 0
	>
	bz *if32_end

	// *if32_consequent
	// examples/reti/stakingPool.algo.ts:691
	// sendPayment({
	//             amount: validatorCommissionPaidOut - managerTopOff,
	//             receiver: validatorConfig.validatorCommissionAddress,
	//             note: 'validator reward',
	//           })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// examples/reti/stakingPool.algo.ts:692
	// amount: validatorCommissionPaidOut - managerTopOff
	frame_dig 16 // validatorCommissionPaidOut: uint64
	frame_dig 21 // managerTopOff: uint64
	-
	itxn_field Amount

	// examples/reti/stakingPool.algo.ts:693
	// receiver: validatorConfig.validatorCommissionAddress
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 177 32
	itxn_field Receiver

	// examples/reti/stakingPool.algo.ts:694
	// note: 'validator reward'
	pushbytes 0x76616c696461746f7220726577617264 // "validator reward"
	itxn_field Note

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

*if32_end:

*if30_end:

*if29_end:
	// examples/reti/stakingPool.algo.ts:706
	// increasedStake = 0
	int 0
	frame_bury 22 // increasedStake: uint64

	// *if33_condition
	// examples/reti/stakingPool.algo.ts:730
	// algoRewardAvail !== 0 || tokenRewardAvail !== 0
	frame_dig 11 // algoRewardAvail: uint64
	int 0
	!=
	dup
	bnz *skip_or1
	frame_dig 14 // tokenRewardAvail: uint64
	int 0
	!=
	||

*skip_or1:
	bz *if33_end

	// *if33_consequent
	// examples/reti/stakingPool.algo.ts:731
	// partialStakersTotalStake: uint64 = 0
	int 0
	frame_bury 23 // partialStakersTotalStake: uint64

	// examples/reti/stakingPool.algo.ts:732
	// for (let i = 0; i < this.stakers.value.length; i += 1)
	int 0
	frame_bury 24 // i: uint64

*for_4:
	// examples/reti/stakingPool.algo.ts:732
	// i < this.stakers.value.length
	frame_dig 24 // i: uint64
	int 200
	<
	bz *for_4_end

	// *if34_condition
	// examples/reti/stakingPool.algo.ts:733
	// globals.opcodeBudget < 400
	global OpcodeBudget
	pushint 400
	<
	bz *if34_end

	// *if34_consequent
	// examples/reti/stakingPool.algo.ts:734
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	pushint 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

*if34_end:
	// examples/reti/stakingPool.algo.ts:736
	// cmpStaker = clone(this.stakers.value[i])
	frame_dig 24 // i: uint64
	int 64
	* // acc * typeLength
	int 64
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_extract
	frame_bury 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// *if35_condition
	// examples/reti/stakingPool.algo.ts:737
	// cmpStaker.account !== globals.zeroAddress
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 0 32
	global ZeroAddress
	!=
	bz *if35_end

	// *if35_consequent
	// *if36_condition
	// examples/reti/stakingPool.algo.ts:738
	// cmpStaker.entryRound >= thisEpochBegin
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 56 8
	btoi
	frame_dig 3 // thisEpochBegin: uint64
	>=
	bz *if36_else

	// *if36_consequent
	// examples/reti/stakingPool.algo.ts:741
	// partialStakersTotalStake += cmpStaker.balance
	frame_dig 23 // partialStakersTotalStake: uint64
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	+
	frame_bury 23 // partialStakersTotalStake: uint64
	b *if36_end

*if36_else:
	// examples/reti/stakingPool.algo.ts:745
	// timeInPool = thisEpochBegin - cmpStaker.entryRound
	frame_dig 3 // thisEpochBegin: uint64
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 56 8
	btoi
	-
	frame_bury 26 // timeInPool: uint64

	// *if37_condition
	// examples/reti/stakingPool.algo.ts:749
	// timeInPool < epochRoundLength
	frame_dig 26 // timeInPool: uint64
	frame_dig 1 // epochRoundLength: uint64
	<
	bz *if37_end

	// *if37_consequent
	// examples/reti/stakingPool.algo.ts:750
	// partialStakersTotalStake += cmpStaker.balance
	frame_dig 23 // partialStakersTotalStake: uint64
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	+
	frame_bury 23 // partialStakersTotalStake: uint64

	// examples/reti/stakingPool.algo.ts:751
	// timePercentage = (timeInPool * 1000) / epochRoundLength
	frame_dig 26 // timeInPool: uint64
	int 1000
	*
	frame_dig 1 // epochRoundLength: uint64
	/
	frame_bury 27 // timePercentage: uint64

	// *if38_condition
	// examples/reti/stakingPool.algo.ts:753
	// tokenRewardAvail > 0
	frame_dig 14 // tokenRewardAvail: uint64
	int 0
	>
	bz *if38_end

	// *if38_consequent
	// examples/reti/stakingPool.algo.ts:755
	// stakerTokenReward = wideRatio(
	//                   [cmpStaker.balance, tokenRewardAvail, timePercentage],
	//                   [this.totalAlgoStaked.value, 1000]
	//                 )
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	frame_dig 14 // tokenRewardAvail: uint64
	mulw
	frame_dig 27 // timePercentage: uint64
	uncover 2
	dig 1
	*
	cover 2
	mulw
	cover 2
	+
	swap
	byte 0x7374616b6564 // "staked"
	app_global_get
	int 1000
	mulw
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	frame_bury 28 // stakerTokenReward: uint64

	// examples/reti/stakingPool.algo.ts:762
	// tokenRewardAvail -= stakerTokenReward
	frame_dig 14 // tokenRewardAvail: uint64
	frame_dig 28 // stakerTokenReward: uint64
	-
	frame_bury 14 // tokenRewardAvail: uint64

	// examples/reti/stakingPool.algo.ts:763
	// cmpStaker.rewardTokenBalance += stakerTokenReward
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	pushint 48 // headOffset
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 48 8
	btoi
	frame_dig 28 // stakerTokenReward: uint64
	+
	itob
	replace3
	frame_bury 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:764
	// tokenRewardPaidOut += stakerTokenReward
	frame_dig 15 // tokenRewardPaidOut: uint64
	frame_dig 28 // stakerTokenReward: uint64
	+
	frame_bury 15 // tokenRewardPaidOut: uint64

*if38_end:
	// *if39_condition
	// examples/reti/stakingPool.algo.ts:766
	// algoRewardAvail > 0
	frame_dig 11 // algoRewardAvail: uint64
	int 0
	>
	bz *if39_end

	// *if39_consequent
	// examples/reti/stakingPool.algo.ts:768
	// stakerReward = wideRatio(
	//                   [cmpStaker.balance, algoRewardAvail, timePercentage],
	//                   [this.totalAlgoStaked.value, 1000]
	//                 )
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	frame_dig 11 // algoRewardAvail: uint64
	mulw
	frame_dig 27 // timePercentage: uint64
	uncover 2
	dig 1
	*
	cover 2
	mulw
	cover 2
	+
	swap
	byte 0x7374616b6564 // "staked"
	app_global_get
	int 1000
	mulw
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	frame_bury 29 // stakerReward: uint64

	// examples/reti/stakingPool.algo.ts:775
	// algoRewardAvail -= stakerReward
	frame_dig 11 // algoRewardAvail: uint64
	frame_dig 29 // stakerReward: uint64
	-
	frame_bury 11 // algoRewardAvail: uint64

	// examples/reti/stakingPool.algo.ts:778
	// cmpStaker.balance += stakerReward
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	int 32 // headOffset
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	frame_dig 29 // stakerReward: uint64
	+
	itob
	replace3
	frame_bury 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:779
	// cmpStaker.totalRewarded += stakerReward
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	pushint 40 // headOffset
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 40 8
	btoi
	frame_dig 29 // stakerReward: uint64
	+
	itob
	replace3
	frame_bury 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:780
	// increasedStake += stakerReward
	frame_dig 22 // increasedStake: uint64
	frame_dig 29 // stakerReward: uint64
	+
	frame_bury 22 // increasedStake: uint64

*if39_end:
	// examples/reti/stakingPool.algo.ts:783
	// this.stakers.value[i] = cmpStaker
	frame_dig 24 // i: uint64
	int 64
	* // acc * typeLength
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_replace

*if37_end:

*if36_end:

*if35_end:

*for_4_continue:
	// examples/reti/stakingPool.algo.ts:732
	// i += 1
	frame_dig 24 // i: uint64
	int 1
	+
	frame_bury 24 // i: uint64
	b *for_4

*for_4_end:
	// examples/reti/stakingPool.algo.ts:791
	// newPoolTotalStake = this.totalAlgoStaked.value - partialStakersTotalStake
	byte 0x7374616b6564 // "staked"
	app_global_get
	frame_dig 23 // partialStakersTotalStake: uint64
	-
	frame_bury 30 // newPoolTotalStake: uint64

	// *if40_condition
	// examples/reti/stakingPool.algo.ts:795
	// newPoolTotalStake > 0
	frame_dig 30 // newPoolTotalStake: uint64
	int 0
	>
	bz *if40_end

	// *if40_consequent
	// examples/reti/stakingPool.algo.ts:797
	// for (let i = 0; i < this.stakers.value.length; i += 1)
	int 0
	frame_bury 31 // i: uint64

*for_5:
	// examples/reti/stakingPool.algo.ts:797
	// i < this.stakers.value.length
	frame_dig 31 // i: uint64
	int 200
	<
	bz *for_5_end

	// *if41_condition
	// examples/reti/stakingPool.algo.ts:798
	// globals.opcodeBudget < 200
	global OpcodeBudget
	int 200
	<
	bz *if41_end

	// *if41_consequent
	// examples/reti/stakingPool.algo.ts:799
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	pushint 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

*if41_end:
	// examples/reti/stakingPool.algo.ts:801
	// cmpStaker = clone(this.stakers.value[i])
	frame_dig 31 // i: uint64
	int 64
	* // acc * typeLength
	int 64
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_extract
	frame_bury 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// *if42_condition
	// examples/reti/stakingPool.algo.ts:802
	// cmpStaker.account !== globals.zeroAddress && cmpStaker.entryRound < thisEpochBegin
	frame_dig 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 0 32
	global ZeroAddress
	!=
	dup
	bz *skip_and4
	frame_dig 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 56 8
	btoi
	frame_dig 3 // thisEpochBegin: uint64
	<
	&&

*skip_and4:
	bz *if42_end

	// *if42_consequent
	// examples/reti/stakingPool.algo.ts:803
	// timeInPool = thisEpochBegin - cmpStaker.entryRound
	frame_dig 3 // thisEpochBegin: uint64
	frame_dig 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 56 8
	btoi
	-
	frame_bury 33 // timeInPool: uint64

	// *if43_condition
	// examples/reti/stakingPool.algo.ts:805
	// timeInPool >= epochRoundLength
	frame_dig 33 // timeInPool: uint64
	frame_dig 1 // epochRoundLength: uint64
	>=
	bz *if43_end

	// *if43_consequent
	// *if44_condition
	// examples/reti/stakingPool.algo.ts:810
	// tokenRewardAvail > 0
	frame_dig 14 // tokenRewardAvail: uint64
	int 0
	>
	bz *if44_end

	// *if44_consequent
	// examples/reti/stakingPool.algo.ts:811
	// stakerTokenReward = wideRatio([cmpStaker.balance, tokenRewardAvail], [newPoolTotalStake])
	frame_dig 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	frame_dig 14 // tokenRewardAvail: uint64
	mulw
	int 0
	frame_dig 30 // newPoolTotalStake: uint64
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	frame_bury 34 // stakerTokenReward: uint64

	// examples/reti/stakingPool.algo.ts:814
	// cmpStaker.rewardTokenBalance += stakerTokenReward
	frame_dig 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	pushint 48 // headOffset
	frame_dig 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 48 8
	btoi
	frame_dig 34 // stakerTokenReward: uint64
	+
	itob
	replace3
	frame_bury 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:815
	// tokenRewardPaidOut += stakerTokenReward
	frame_dig 15 // tokenRewardPaidOut: uint64
	frame_dig 34 // stakerTokenReward: uint64
	+
	frame_bury 15 // tokenRewardPaidOut: uint64

*if44_end:
	// *if45_condition
	// examples/reti/stakingPool.algo.ts:817
	// algoRewardAvail > 0
	frame_dig 11 // algoRewardAvail: uint64
	int 0
	>
	bz *if45_end

	// *if45_consequent
	// examples/reti/stakingPool.algo.ts:818
	// stakerReward = wideRatio([cmpStaker.balance, algoRewardAvail], [newPoolTotalStake])
	frame_dig 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	frame_dig 11 // algoRewardAvail: uint64
	mulw
	int 0
	frame_dig 30 // newPoolTotalStake: uint64
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	frame_bury 35 // stakerReward: uint64

	// examples/reti/stakingPool.algo.ts:821
	// cmpStaker.balance += stakerReward
	frame_dig 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	int 32 // headOffset
	frame_dig 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	frame_dig 35 // stakerReward: uint64
	+
	itob
	replace3
	frame_bury 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:822
	// cmpStaker.totalRewarded += stakerReward
	frame_dig 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	pushint 40 // headOffset
	frame_dig 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 40 8
	btoi
	frame_dig 35 // stakerReward: uint64
	+
	itob
	replace3
	frame_bury 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:823
	// increasedStake += stakerReward
	frame_dig 22 // increasedStake: uint64
	frame_dig 35 // stakerReward: uint64
	+
	frame_bury 22 // increasedStake: uint64

*if45_end:
	// examples/reti/stakingPool.algo.ts:827
	// this.stakers.value[i] = cmpStaker
	frame_dig 31 // i: uint64
	int 64
	* // acc * typeLength
	frame_dig 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_replace

*if43_end:

*if42_end:

*for_5_continue:
	// examples/reti/stakingPool.algo.ts:797
	// i += 1
	frame_dig 31 // i: uint64
	int 1
	+
	frame_bury 31 // i: uint64
	b *for_5

*for_5_end:

*if40_end:

*if33_end:
	// examples/reti/stakingPool.algo.ts:837
	// roundsLeftInBin = this.binRoundStart.value + this.roundsPerDay.value - globals.round
	byte 0x62696e526f756e645374617274 // "binRoundStart"
	app_global_get
	byte 0x726f756e6473506572446179 // "roundsPerDay"
	app_global_get
	+
	global Round
	-
	frame_bury 36 // roundsLeftInBin: uint64

	// examples/reti/stakingPool.algo.ts:838
	// this.totalAlgoStaked.value += increasedStake
	byte 0x7374616b6564 // "staked"
	app_global_get
	frame_dig 22 // increasedStake: uint64
	+
	byte 0x7374616b6564 // "staked"
	swap
	app_global_put

	// examples/reti/stakingPool.algo.ts:839
	// this.stakeAccumulator.value =
	//       this.stakeAccumulator.value + (increasedStake as uint128) * (roundsLeftInBin as uint128)
	byte 0x7374616b65416363756d756c61746f72 // "stakeAccumulator"
	dup
	app_global_get
	frame_dig 22 // increasedStake: uint64
	itob
	frame_dig 36 // roundsLeftInBin: uint64
	itob
	b*
	b+
	dup
	bitlen
	int 128
	<=

	// this.stakeAccumulator.value + (increasedStake as uint128) * (roundsLeftInBin as uint128) overflowed 128 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 16
	-
	swap
	substring3
	app_global_put

	// examples/reti/stakingPool.algo.ts:841
	// this.rewardAccumulator.value = this.rewardAccumulator.value + increasedStake
	byte 0x726577617264416363756d756c61746f72 // "rewardAccumulator"
	dup
	app_global_get
	frame_dig 22 // increasedStake: uint64
	+
	app_global_put

	// examples/reti/stakingPool.algo.ts:847
	// sendMethodCall<typeof ValidatorRegistry.prototype.stakeUpdatedViaRewards>({
	//       applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//       methodArgs: [
	//         { id: this.validatorId.value, poolId: this.poolId.value, poolAppId: this.app.id },
	//         increasedStake,
	//         tokenRewardPaidOut,
	//         validatorCommissionPaidOut,
	//         excessToFeeSink,
	//       ],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	pushbytes 0x418fcefc // method "stakeUpdatedViaRewards((uint64,uint64,uint64),uint64,uint64,uint64,uint64)void"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:848
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:849
	// methodArgs: [
	//         { id: this.validatorId.value, poolId: this.poolId.value, poolAppId: this.app.id },
	//         increasedStake,
	//         tokenRewardPaidOut,
	//         validatorCommissionPaidOut,
	//         excessToFeeSink,
	//       ]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	itob
	concat
	txna Applications 0
	itob
	concat
	itxn_field ApplicationArgs
	frame_dig 22 // increasedStake: uint64
	itob
	itxn_field ApplicationArgs
	frame_dig 15 // tokenRewardPaidOut: uint64
	itob
	itxn_field ApplicationArgs
	frame_dig 16 // validatorCommissionPaidOut: uint64
	itob
	itxn_field ApplicationArgs
	frame_dig 17 // excessToFeeSink: uint64
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// goOnline(pay,byte[],byte[],byte[],uint64,uint64,uint64)void
*abi_route_goOnline:
	// voteKeyDilution: uint64
	txna ApplicationArgs 6
	btoi

	// voteLast: uint64
	txna ApplicationArgs 5
	btoi

	// voteFirst: uint64
	txna ApplicationArgs 4
	btoi

	// stateProofPK: byte[]
	txna ApplicationArgs 3
	extract 2 0

	// selectionPK: byte[]
	txna ApplicationArgs 2
	extract 2 0

	// votePK: byte[]
	txna ApplicationArgs 1
	extract 2 0

	// feePayment: pay
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// argument 6 (feePayment) for goOnline must be a pay transaction
	assert

	// execute goOnline(pay,byte[],byte[],byte[],uint64,uint64,uint64)void
	callsub goOnline
	int 1
	return

// goOnline(feePayment: PayTxn, votePK: bytes, selectionPK: bytes, stateProofPK: bytes, voteFirst: uint64, voteLast: uint64, voteKeyDilution: uint64): void
//
// Registers a staking pool key online against a participation key.
// [ ONLY OWNER OR MANAGER CAN CALL ]
//
// @param {PayTxn} feePayment - payment to cover extra fee of going online if offline - or 0 if not renewal
// @param {bytes} votePK - The vote public key.
// @param {bytes} selectionPK - The selection public key.
// @param {bytes} stateProofPK - The state proof public key.
// @param {uint64} voteFirst - The first vote index.
// @param {uint64} voteLast - The last vote index.
// @param {uint64} voteKeyDilution - The vote key dilution value.
// @throws {Error} Will throw an error if the caller is not the owner or a manager.
goOnline:
	proto 7 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/reti/stakingPool.algo.ts:881
	// assert(this.isOwnerOrManagerCaller(), 'can only be called by owner or manager of validator')
	callsub isOwnerOrManagerCaller

	// can only be called by owner or manager of validator
	assert

	// examples/reti/stakingPool.algo.ts:882
	// extraFee = this.getGoOnlineFee()
	callsub getGoOnlineFee
	frame_bury 0 // extraFee: uint64

	// examples/reti/stakingPool.algo.ts:883
	// verifyPayTxn(feePayment, { receiver: this.app.address, amount: extraFee })
	// verify receiver
	frame_dig -1 // feePayment: PayTxn
	gtxns Receiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"feePayment","field":"receiver","expected":"this.app.address"}
	assert

	// verify amount
	frame_dig -1 // feePayment: PayTxn
	gtxns Amount
	frame_dig 0 // extraFee: uint64
	==

	// transaction verification failed: {"txn":"feePayment","field":"amount","expected":"extraFee"}
	assert

	// examples/reti/stakingPool.algo.ts:884
	// sendOnlineKeyRegistration({
	//       votePK: votePK,
	//       selectionPK: selectionPK,
	//       stateProofPK: stateProofPK,
	//       voteFirst: voteFirst,
	//       voteLast: voteLast,
	//       voteKeyDilution: voteKeyDilution,
	//       fee: this.getGoOnlineFee(),
	//     })
	itxn_begin
	pushint 2 // keyreg
	itxn_field TypeEnum

	// examples/reti/stakingPool.algo.ts:885
	// votePK: votePK
	frame_dig -2 // votePK: bytes
	itxn_field VotePK

	// examples/reti/stakingPool.algo.ts:886
	// selectionPK: selectionPK
	frame_dig -3 // selectionPK: bytes
	itxn_field SelectionPK

	// examples/reti/stakingPool.algo.ts:887
	// stateProofPK: stateProofPK
	frame_dig -4 // stateProofPK: bytes
	itxn_field StateProofPK

	// examples/reti/stakingPool.algo.ts:888
	// voteFirst: voteFirst
	frame_dig -5 // voteFirst: uint64
	itxn_field VoteFirst

	// examples/reti/stakingPool.algo.ts:889
	// voteLast: voteLast
	frame_dig -6 // voteLast: uint64
	itxn_field VoteLast

	// examples/reti/stakingPool.algo.ts:890
	// voteKeyDilution: voteKeyDilution
	frame_dig -7 // voteKeyDilution: uint64
	itxn_field VoteKeyDilution

	// examples/reti/stakingPool.algo.ts:891
	// fee: this.getGoOnlineFee()
	callsub getGoOnlineFee
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// goOffline()void
*abi_route_goOffline:
	// execute goOffline()void
	callsub goOffline
	int 1
	return

// goOffline(): void
//
// Marks a staking pool key OFFLINE.
// [ ONLY OWNER OR MANAGER CAN CALL ]
goOffline:
	proto 0 0

	// *if46_condition
	// examples/reti/stakingPool.algo.ts:903
	// this.txn.sender !== AppID.fromUint64(this.creatingValidatorContractAppId.value).address
	txn Sender
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	app_params_get AppAddress
	pop
	!=
	bz *if46_end

	// *if46_consequent
	// examples/reti/stakingPool.algo.ts:904
	// assert(this.isOwnerOrManagerCaller(), 'can only be called by owner or manager of validator')
	callsub isOwnerOrManagerCaller

	// can only be called by owner or manager of validator
	assert

*if46_end:
	// examples/reti/stakingPool.algo.ts:907
	// sendOfflineKeyRegistration({})
	itxn_begin
	pushint 2 // keyreg
	itxn_field TypeEnum

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// linkToNFD(uint64,string)void
*abi_route_linkToNFD:
	// nfdName: string
	txna ApplicationArgs 2
	extract 2 0

	// nfdAppId: uint64
	txna ApplicationArgs 1
	btoi

	// execute linkToNFD(uint64,string)void
	callsub linkToNFD
	int 1
	return

// linkToNFD(nfdAppId: uint64, nfdName: string): void
linkToNFD:
	proto 2 0

	// examples/reti/stakingPool.algo.ts:914
	// assert(this.isOwnerOrManagerCaller(), 'can only be called by owner or manager of validator')
	callsub isOwnerOrManagerCaller

	// can only be called by owner or manager of validator
	assert

	// examples/reti/stakingPool.algo.ts:916
	// sendAppCall({
	//       applicationID: AppID.fromUint64(this.nfdRegistryAppId),
	//       applicationArgs: ['verify_nfd_addr', nfdName, itob(nfdAppId), rawBytes(this.app.address)],
	//       applications: [AppID.fromUint64(nfdAppId)],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum

	// examples/reti/stakingPool.algo.ts:917
	// applicationID: AppID.fromUint64(this.nfdRegistryAppId)
	intc 0 // TMPL_nfdRegistryAppId
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:918
	// applicationArgs: ['verify_nfd_addr', nfdName, itob(nfdAppId), rawBytes(this.app.address)]
	pushbytes 0x7665726966795f6e66645f61646472 // "verify_nfd_addr"
	itxn_field ApplicationArgs
	frame_dig -2 // nfdName: string
	itxn_field ApplicationArgs
	frame_dig -1 // nfdAppId: uint64
	itob
	itxn_field ApplicationArgs
	global CurrentApplicationAddress
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:919
	// applications: [AppID.fromUint64(nfdAppId)]
	frame_dig -1 // nfdAppId: uint64
	itxn_field Applications

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// proxiedSetTokenPayoutRatio((uint64,uint64,uint64))(uint64[24],uint64)
*abi_route_proxiedSetTokenPayoutRatio:
	// The ABI return prefix
	byte 0x151f7c75

	// poolKey: (uint64,uint64,uint64)
	txna ApplicationArgs 1
	dup
	len
	pushint 24
	==

	// argument 0 (poolKey) for proxiedSetTokenPayoutRatio must be a (uint64,uint64,uint64)
	assert

	// execute proxiedSetTokenPayoutRatio((uint64,uint64,uint64))(uint64[24],uint64)
	callsub proxiedSetTokenPayoutRatio
	concat
	log
	int 1
	return

// proxiedSetTokenPayoutRatio(poolKey: ValidatorPoolKey): PoolTokenPayoutRatio
//
// proxiedSetTokenPayoutRatio is meant to be called by pools != 1 - calling US, pool #1
// We need to verify that we are in fact being called by another of OUR pools (not us)
// and then we'll call the validator on their behalf to update the token payouts
// @param poolKey - ValidatorPoolKey tuple
proxiedSetTokenPayoutRatio:
	proto 1 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/reti/stakingPool.algo.ts:930
	// assert(this.validatorId.value === poolKey.id, 'caller must be part of same validator set!')
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	==

	// caller must be part of same validator set!
	assert

	// examples/reti/stakingPool.algo.ts:931
	// assert(this.poolId.value === 1, 'callee must be pool 1')
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	int 1
	==

	// callee must be pool 1
	assert

	// examples/reti/stakingPool.algo.ts:932
	// assert(poolKey.poolId !== 1, 'caller must NOT be pool 1')
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	!=

	// caller must NOT be pool 1
	assert

	// examples/reti/stakingPool.algo.ts:934
	// callerPoolAppID = sendMethodCall<typeof ValidatorRegistry.prototype.getPoolAppId>({
	//       applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//       methodArgs: [poolKey.id, poolKey.poolId],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0x572767d1 // method "getPoolAppId(uint64,uint64)uint64"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:935
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:936
	// methodArgs: [poolKey.id, poolKey.poolId]
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	itxn_field ApplicationArgs
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0
	btoi
	frame_bury 0 // callerPoolAppID: uint64

	// examples/reti/stakingPool.algo.ts:938
	// assert(callerPoolAppID === poolKey.poolAppId)
	frame_dig 0 // callerPoolAppID: uint64
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 16 8
	btoi
	==
	assert

	// examples/reti/stakingPool.algo.ts:939
	// assert(this.txn.sender === AppID.fromUint64(poolKey.poolAppId).address)
	txn Sender
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 16 8
	btoi
	app_params_get AppAddress
	pop
	==
	assert

	// examples/reti/stakingPool.algo.ts:941
	// return sendMethodCall<typeof ValidatorRegistry.prototype.setTokenPayoutRatio>({
	//       applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//       methodArgs: [this.validatorId.value],
	//     });
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0x4df8d86e // method "setTokenPayoutRatio(uint64)(uint64[24],uint64)"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:942
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:943
	// methodArgs: [this.validatorId.value]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0

	// set the subroutine return value
	frame_bury 0
	retsub

// isOwnerOrManagerCaller(): boolean
isOwnerOrManagerCaller:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/reti/stakingPool.algo.ts:948
	// OwnerAndManager = sendMethodCall<typeof ValidatorRegistry.prototype.getValidatorOwnerAndManager>({
	//       applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//       methodArgs: [this.validatorId.value],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	pushbytes 0x2fa22c4b // method "getValidatorOwnerAndManager(uint64)(address,address)"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:949
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:950
	// methodArgs: [this.validatorId.value]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0
	frame_bury 0 // OwnerAndManager: (address,address)

	// examples/reti/stakingPool.algo.ts:952
	// return this.txn.sender === OwnerAndManager[0] || this.txn.sender === OwnerAndManager[1];
	txn Sender
	frame_dig 0 // OwnerAndManager: (address,address)
	extract 0 32
	==
	dup
	bnz *skip_or2
	txn Sender
	frame_dig 0 // OwnerAndManager: (address,address)
	extract 32 32
	==
	||

*skip_or2:
	// set the subroutine return value
	frame_bury 0
	retsub

// getFeeSink(): Address
getFeeSink:
	proto 0 1

	// examples/reti/stakingPool.algo.ts:956
	// return this.feeSinkAddr;
	bytec 0 // TMPL_feeSinkAddr
	retsub

// algoSaturationLevel(): uint64
//
// Returns the maximum allowed stake per validator based on a percentage of all current online stake before
// the validator is considered saturated - where rewards are diminished.
algoSaturationLevel:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/reti/stakingPool.algo.ts:966
	// online = this.getCurrentOnlineStake()
	callsub getCurrentOnlineStake
	frame_bury 0 // online: uint64

	// examples/reti/stakingPool.algo.ts:968
	// return wideRatio([online, MAX_VALIDATOR_SOFT_PCT_OF_ONLINE_1DECIMAL], [1000]);
	frame_dig 0 // online: uint64
	pushint 100
	mulw
	int 0
	int 1000
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert

	// set the subroutine return value
	frame_bury 0
	retsub

// getGoOnlineFee(): uint64
getGoOnlineFee:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/reti/stakingPool.algo.ts:975
	// isOnline = false
	int 0
	frame_bury 0 // isOnline: bool

	// *if47_condition
	// examples/reti/stakingPool.algo.ts:976
	// !isOnline
	frame_dig 0 // isOnline: bool
	!
	bz *if47_end

	// *if47_consequent
	// examples/reti/stakingPool.algo.ts:978
	// return 2_000_000;
	pushint 2_000_000
	b *getGoOnlineFee*return

*if47_end:
	// examples/reti/stakingPool.algo.ts:980
	// return 0;
	int 0

*getGoOnlineFee*return:
	// set the subroutine return value
	frame_bury 0
	retsub

// getCurrentOnlineStake(): uint64
getCurrentOnlineStake:
	proto 0 1

	// examples/reti/stakingPool.algo.ts:985
	// return 2_000_000_000_000_000;
	pushint 2_000_000_000_000_000
	retsub

// checkIfBinClosed(): void
//
// Checks if the current round is in a 'new calculation bin' (approximately daily)
checkIfBinClosed:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 4

	// examples/reti/stakingPool.algo.ts:992
	// currentBinSize = this.roundsPerDay.value as uint128
	byte 0x726f756e6473506572446179 // "roundsPerDay"
	app_global_get
	itob
	frame_bury 0 // currentBinSize: unsafe uint128

	// *if48_condition
	// examples/reti/stakingPool.algo.ts:993
	// globals.round >= this.binRoundStart.value + (currentBinSize as uint64)
	global Round
	byte 0x62696e526f756e645374617274 // "binRoundStart"
	app_global_get
	frame_dig 0 // currentBinSize: unsafe uint128
	dup
	bitlen
	int 64
	<=

	// currentBinSize as uint64 overflowed 64 bits
	assert
	pushbytes 0xFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	pushint 8
	-
	swap
	substring3
	btoi
	+
	>=
	bz *if48_end

	// *if48_consequent
	// *if49_condition
	// examples/reti/stakingPool.algo.ts:994
	// globals.opcodeBudget < 300
	global OpcodeBudget
	int 300
	<
	bz *if49_end

	// *if49_consequent
	// examples/reti/stakingPool.algo.ts:995
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	pushint 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

*if49_end:
	// examples/reti/stakingPool.algo.ts:997
	// approxRoundsPerYear: uint128 = currentBinSize * (365 as uint128)
	frame_dig 0 // currentBinSize: unsafe uint128
	pushbytes 0x0000000000000000000000000000016d
	b*
	dup
	bitlen
	int 128
	<=

	// currentBinSize * (365 as uint128) overflowed 128 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 16
	-
	swap
	substring3
	frame_bury 1 // approxRoundsPerYear: uint128

	// examples/reti/stakingPool.algo.ts:998
	// avgStake: uint128 = this.stakeAccumulator.value / currentBinSize
	byte 0x7374616b65416363756d756c61746f72 // "stakeAccumulator"
	app_global_get
	frame_dig 0 // currentBinSize: unsafe uint128
	b/
	dup
	bitlen
	int 128
	<=

	// this.stakeAccumulator.value / currentBinSize overflowed 128 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 16
	-
	swap
	substring3
	frame_bury 2 // avgStake: uint128

	// *if50_condition
	// examples/reti/stakingPool.algo.ts:999
	// avgStake !== 0
	frame_dig 2 // avgStake: uint128
	byte 0x00000000000000000000000000000000
	b!=
	bz *if50_end

	// *if50_consequent
	// examples/reti/stakingPool.algo.ts:1003
	// apr: uint128 =
	//           (((this.rewardAccumulator.value as uint128) * (10000 as uint128)) / avgStake) *
	//           (approxRoundsPerYear / currentBinSize)
	byte 0x726577617264416363756d756c61746f72 // "rewardAccumulator"
	app_global_get
	itob
	pushbytes 0x00000000000000000000000000002710
	b*
	frame_dig 2 // avgStake: uint128
	b/
	frame_dig 1 // approxRoundsPerYear: uint128
	frame_dig 0 // currentBinSize: unsafe uint128
	b/
	b*
	dup
	bitlen
	int 128
	<=

	// (((this.rewardAccumulator.value as uint128) * (10000 as uint128)) / avgStake) *\n          (approxRoundsPerYear / currentBinSize) overflowed 128 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 16
	-
	swap
	substring3
	frame_bury 3 // apr: uint128

	// examples/reti/stakingPool.algo.ts:1007
	// alpha: uint128 = 10 as uint128
	pushbytes 0x0000000000000000000000000000000a
	frame_bury 4 // alpha: unsafe uint128

	// *if51_condition
	// examples/reti/stakingPool.algo.ts:1009
	// avgStake > 300000000000
	frame_dig 2 // avgStake: uint128
	pushbytes 0x000000000000000000000045d964b800
	b>
	bz *if51_end

	// *if51_consequent
	// examples/reti/stakingPool.algo.ts:1010
	// alpha = 90 as uint128
	pushbytes 0x0000000000000000000000000000005a
	frame_bury 4 // alpha: unsafe uint128

*if51_end:
	// examples/reti/stakingPool.algo.ts:1012
	// this.weightedMovingAverage.value =
	//           (this.weightedMovingAverage.value * ((100 as uint128) - alpha)) / (100 as uint128) +
	//           (apr * alpha) / (100 as uint128)
	byte 0x65776d61 // "ewma"
	dup
	app_global_get
	byte 0x00000000000000000000000000000064
	frame_dig 4 // alpha: unsafe uint128
	b-
	b*
	byte 0x00000000000000000000000000000064
	b/
	frame_dig 3 // apr: uint128
	frame_dig 4 // alpha: unsafe uint128
	b*
	byte 0x00000000000000000000000000000064
	b/
	b+
	dup
	bitlen
	int 128
	<=

	// (this.weightedMovingAverage.value * ((100 as uint128) - alpha)) / (100 as uint128) +\n          (apr * alpha) / (100 as uint128) overflowed 128 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 16
	-
	swap
	substring3
	app_global_put

*if50_end:
	// examples/reti/stakingPool.algo.ts:1018
	// this.setRoundsPerDay()
	callsub setRoundsPerDay

	// examples/reti/stakingPool.algo.ts:1019
	// this.stakeAccumulator.value = (this.totalAlgoStaked.value as uint128) * (this.roundsPerDay.value as uint128)
	byte 0x7374616b65416363756d756c61746f72 // "stakeAccumulator"
	byte 0x7374616b6564 // "staked"
	app_global_get
	itob
	byte 0x726f756e6473506572446179 // "roundsPerDay"
	app_global_get
	itob
	b*
	dup
	bitlen
	int 128
	<=

	// (this.totalAlgoStaked.value as uint128) * (this.roundsPerDay.value as uint128) overflowed 128 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 16
	-
	swap
	substring3
	app_global_put

	// examples/reti/stakingPool.algo.ts:1020
	// this.rewardAccumulator.value = 0
	byte 0x726577617264416363756d756c61746f72 // "rewardAccumulator"
	int 0
	app_global_put

	// examples/reti/stakingPool.algo.ts:1021
	// this.binRoundStart.value = globals.round - (globals.round % this.roundsPerDay.value)
	byte 0x62696e526f756e645374617274 // "binRoundStart"
	global Round
	global Round
	byte 0x726f756e6473506572446179 // "roundsPerDay"
	app_global_get
	%
	-
	app_global_put

*if48_end:
	retsub

// setRoundsPerDay(): void
setRoundsPerDay:
	proto 0 0

	// examples/reti/stakingPool.algo.ts:1026
	// this.roundsPerDay.value = AVG_ROUNDS_PER_DAY
	byte 0x726f756e6473506572446179 // "roundsPerDay"
	pushint 30857
	app_global_put
	retsub

*create_NoOp:
	pushbytes 0x59e90aa6 // method "createApplication(uint64,uint64,uint64,uint64)void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x3172ca9d // method "gas()void"
	pushbytes 0x47cfcc04 // method "initStorage(pay)void"
	pushbytes 0xf9c70cbd // method "addStake(pay,address)uint64"
	pushbytes 0x421b5abe // method "removeStake(address,uint64)void"
	pushbytes 0xf5892d56 // method "claimTokens()void"
	pushbytes 0x5cfbb057 // method "getStakerInfo(address)(address,uint64,uint64,uint64,uint64)"
	pushbytes 0x63f3f28b // method "payTokenReward(address,uint64,uint64)void"
	pushbytes 0x86a3725c // method "updateAlgodVer(string)void"
	pushbytes 0xefc2608d // method "epochBalanceUpdate()void"
	pushbytes 0x400e14fb // method "goOnline(pay,byte[],byte[],byte[],uint64,uint64,uint64)void"
	pushbytes 0x51ef3b21 // method "goOffline()void"
	pushbytes 0xa24e2717 // method "linkToNFD(uint64,string)void"
	byte 0x0c2245e1 // method "proxiedSetTokenPayoutRatio((uint64,uint64,uint64))(uint64[24],uint64)"
	txna ApplicationArgs 0
	match *abi_route_gas *abi_route_initStorage *abi_route_addStake *abi_route_removeStake *abi_route_claimTokens *abi_route_getStakerInfo *abi_route_payTokenReward *abi_route_updateAlgodVer *abi_route_epochBalanceUpdate *abi_route_goOnline *abi_route_goOffline *abi_route_linkToNFD *abi_route_proxiedSetTokenPayoutRatio

	// this contract does not implement the given ABI method for call NoOp
	err

*call_UpdateApplication:
	pushbytes 0x46f76533 // method "updateApplication()void"
	txna ApplicationArgs 0
	match *abi_route_updateApplication

	// this contract does not implement the given ABI method for call UpdateApplication
	err", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/examples/reti/artifacts/StakingPool.arc56_draft.json b/examples/reti/artifacts/StakingPool.arc56_draft.json index 6f4ee23b1..dc7c2b826 100644 --- a/examples/reti/artifacts/StakingPool.arc56_draft.json +++ b/examples/reti/artifacts/StakingPool.arc56_draft.json @@ -20918,7 +20918,7 @@ } }, "source": { - "approval": "#pragma version 10
intcblock TMPL_nfdRegistryAppId 0 1 6 64 32 16 128 1_000_000 2_100_000 200 300 1000
bytecblock TMPL_feeSinkAddr 0x63726561746f72417070 0x76616c696461746f724964 0x7374616b65416363756d756c61746f72 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF 0x7374616b657273 0x726f756e6473506572446179 0x706f6f6c4964 0x726577617264416363756d756c61746f72 0x7374616b6564 0x62696e526f756e645374617274 0x0000000000000000 0x 0x0a8101 0x6e756d5374616b657273 0x6c6173745061796f7574 0x00000000000000000000000000000000 0x00000000000000000000000000000064 0x6d696e456e7472795374616b65 0x65706f63684e756d626572 0x75aff61d 0x65776d61 0x151f7c75 0xa2dc51b5 0x572767d1 0x4df8d86e 0x0c2245e1 0x00

// This TEAL was generated by TEALScript v0.104.1
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following lines of TEAL are used to initialize template variables in scratch slots
bytec 0 // TMPL_feeSinkAddr
intc 0 // TMPL_nfdRegistryAppId

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
int 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *call_UpdateApplication *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// updateApplication()void
*abi_route_updateApplication:
	// execute updateApplication()void
	callsub updateApplication
	int 1
	return

// updateApplication(): void
updateApplication:
	proto 0 0

	// examples/reti/stakingPool.algo.ts:94
	// assert(
	//       this.txn.sender === Address.fromAddress('LZ4V2IRVLCXFJK4REJV4TAGEKEYTA2GMR6TC2344OB3L3AF3MWXZ6ZAFIQ'),
	//       'Temporary: contract is upgradeable but only during testing and only from a development account'
	//     )
	txn Sender
	pushbytes 0x5e795d223558ae54ab91226bc980c451313068cc8fa62d6f9c7076bd80bb65af // addr "LZ4V2IRVLCXFJK4REJV4TAGEKEYTA2GMR6TC2344OB3L3AF3MWXZ6ZAFIQ"
	==

	// Temporary: contract is upgradeable but only during testing and only from a development account
	assert
	retsub

// createApplication(uint64,uint64,uint64,uint64)void
*abi_route_createApplication:
	// minEntryStake: uint64
	txna ApplicationArgs 4
	btoi

	// poolId: uint64
	txna ApplicationArgs 3
	btoi

	// validatorId: uint64
	txna ApplicationArgs 2
	btoi

	// creatingContractId: uint64
	txna ApplicationArgs 1
	btoi

	// execute createApplication(uint64,uint64,uint64,uint64)void
	callsub createApplication
	int 1
	return

// createApplication(creatingContractId: uint64, validatorId: uint64, poolId: uint64, minEntryStake: uint64): void
//
// Initialize the staking pool w/ owner and manager, but can only be created by the validator contract.
// @param {uint64} creatingContractId - id of contract that constructed us - the validator application (single global instance)
// @param {uint64} validatorId - id of validator we're a staking pool of
// @param {uint64} poolId - which pool id are we
// @param {uint64} minEntryStake - minimum amount to be in pool, but also minimum amount balance can't go below (without removing all!)
createApplication:
	proto 4 0

	// *if0_condition
	// examples/reti/stakingPool.algo.ts:108
	// creatingContractId === 0
	frame_dig -1 // creatingContractId: uint64
	int 0
	==
	bz *if0_else

	// *if0_consequent
	// examples/reti/stakingPool.algo.ts:110
	// assert(validatorId === 0)
	frame_dig -2 // validatorId: uint64
	int 0
	==
	assert

	// examples/reti/stakingPool.algo.ts:111
	// assert(poolId === 0)
	frame_dig -3 // poolId: uint64
	int 0
	==
	assert
	b *if0_end

*if0_else:
	// examples/reti/stakingPool.algo.ts:113
	// assert(validatorId !== 0)
	frame_dig -2 // validatorId: uint64
	int 0
	!=
	assert

	// examples/reti/stakingPool.algo.ts:114
	// assert(poolId !== 0)
	frame_dig -3 // poolId: uint64
	int 0
	!=
	assert

*if0_end:
	// examples/reti/stakingPool.algo.ts:116
	// assert(minEntryStake >= MIN_ALGO_STAKE_PER_POOL, 'staking pool must have minimum entry of 1 algo')
	frame_dig -4 // minEntryStake: uint64
	pushint 1000000
	>=

	// staking pool must have minimum entry of 1 algo
	assert

	// examples/reti/stakingPool.algo.ts:117
	// this.creatingValidatorContractAppId.value = creatingContractId
	byte 0x63726561746f72417070 // "creatorApp"
	frame_dig -1 // creatingContractId: uint64
	app_global_put

	// examples/reti/stakingPool.algo.ts:118
	// this.validatorId.value = validatorId
	byte 0x76616c696461746f724964 // "validatorId"
	frame_dig -2 // validatorId: uint64
	app_global_put

	// examples/reti/stakingPool.algo.ts:119
	// this.poolId.value = poolId
	byte 0x706f6f6c4964 // "poolId"
	frame_dig -3 // poolId: uint64
	app_global_put

	// examples/reti/stakingPool.algo.ts:120
	// this.numStakers.value = 0
	byte 0x6e756d5374616b657273 // "numStakers"
	int 0
	app_global_put

	// examples/reti/stakingPool.algo.ts:121
	// this.totalAlgoStaked.value = 0
	byte 0x7374616b6564 // "staked"
	int 0
	app_global_put

	// examples/reti/stakingPool.algo.ts:122
	// this.minEntryStake.value = minEntryStake
	byte 0x6d696e456e7472795374616b65 // "minEntryStake"
	frame_dig -4 // minEntryStake: uint64
	app_global_put

	// examples/reti/stakingPool.algo.ts:123
	// this.lastPayout.value = globals.round
	byte 0x6c6173745061796f7574 // "lastPayout"
	global Round
	app_global_put

	// examples/reti/stakingPool.algo.ts:124
	// this.epochNumber.value = 0
	byte 0x65706f63684e756d626572 // "epochNumber"
	int 0
	app_global_put

	// examples/reti/stakingPool.algo.ts:126
	// this.setRoundsPerDay()
	callsub setRoundsPerDay

	// examples/reti/stakingPool.algo.ts:127
	// this.binRoundStart.value = globals.round - (globals.round % this.roundsPerDay.value)
	byte 0x62696e526f756e645374617274 // "binRoundStart"
	global Round
	global Round
	byte 0x726f756e6473506572446179 // "roundsPerDay"
	app_global_get
	%
	-
	app_global_put

	// examples/reti/stakingPool.algo.ts:128
	// this.stakeAccumulator.value = 0 as uint128
	byte 0x7374616b65416363756d756c61746f72 // "stakeAccumulator"
	byte 0x00000000000000000000000000000000
	app_global_put

	// examples/reti/stakingPool.algo.ts:129
	// this.rewardAccumulator.value = 0
	byte 0x726577617264416363756d756c61746f72 // "rewardAccumulator"
	int 0
	app_global_put

	// examples/reti/stakingPool.algo.ts:130
	// this.weightedMovingAverage.value = 0 as uint128
	byte 0x65776d61 // "ewma"
	byte 0x00000000000000000000000000000000
	app_global_put
	retsub

// gas()void
*abi_route_gas:
	// execute gas()void
	callsub gas
	int 1
	return

// gas(): void
//
// gas is a dummy no-op call that can be used to pool-up resource references and opcode cost
gas:
	proto 0 0
	retsub

// costForBoxStorage(totalNumBytes: uint64): uint64
costForBoxStorage:
	proto 1 1

	// examples/reti/stakingPool.algo.ts:142
	// return SCBOX_PERBOX + totalNumBytes * SCBOX_PERBYTE;
	pushint 2500
	frame_dig -1 // totalNumBytes: uint64
	pushint 400
	*
	+
	retsub

// initStorage(pay)void
*abi_route_initStorage:
	// mbrPayment: pay
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// argument 0 (mbrPayment) for initStorage must be a pay transaction
	assert

	// execute initStorage(pay)void
	callsub initStorage
	int 1
	return

// initStorage(mbrPayment: PayTxn): void
//
// Called after we're created and then funded, so we can create our large stakers ledger storage
// Caller has to get MBR amounts from ValidatorRegistry to know how much to fund us to cover the box storage cost
// If this is pool 1 AND the validator has specified a reward token, opt-in to that token
// so that the validator can seed the pool with future rewards of that token.
// @param mbrPayment payment from caller which covers mbr increase of new staking pools' storage
initStorage:
	proto 1 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 3

	// examples/reti/stakingPool.algo.ts:153
	// assert(!this.stakers.exists, 'staking pool already initialized')
	byte 0x7374616b657273 // "stakers"
	box_len
	swap
	pop
	!

	// staking pool already initialized
	assert

	// examples/reti/stakingPool.algo.ts:156
	// validatorConfig = sendMethodCall<typeof ValidatorRegistry.prototype.getValidatorConfig>({
	//       applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//       methodArgs: [this.validatorId.value],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0x75aff61d // method "getValidatorConfig(uint64)(uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:157
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:158
	// methodArgs: [this.validatorId.value]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0
	frame_bury 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:160
	// isTokenEligible = validatorConfig.rewardTokenId !== 0
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 153 8
	btoi
	int 0
	!=
	frame_bury 1 // isTokenEligible: bool

	// examples/reti/stakingPool.algo.ts:161
	// extraMBR = isTokenEligible && this.poolId.value === 1 ? ASSET_HOLDING_FEE : 0
	frame_dig 1 // isTokenEligible: bool
	dup
	bz *skip_and0
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	int 1
	==
	&&

*skip_and0:
	bz *ternary0_false
	pushint 100000
	b *ternary0_end

*ternary0_false:
	int 0

*ternary0_end:
	frame_bury 2 // extraMBR: uint64

	// examples/reti/stakingPool.algo.ts:162
	// PoolInitMbr =
	//       ALGORAND_ACCOUNT_MIN_BALANCE +
	//       extraMBR +
	//       this.costForBoxStorage(7 /* 'stakers' name */ + len<StakedInfo>() * MAX_STAKERS_PER_POOL)
	pushint 100000
	frame_dig 2 // extraMBR: uint64
	+
	pushint 12807
	callsub costForBoxStorage
	+
	frame_bury 3 // PoolInitMbr: uint64

	// examples/reti/stakingPool.algo.ts:168
	// verifyPayTxn(mbrPayment, { receiver: this.app.address, amount: PoolInitMbr })
	// verify receiver
	frame_dig -1 // mbrPayment: PayTxn
	gtxns Receiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"mbrPayment","field":"receiver","expected":"this.app.address"}
	assert

	// verify amount
	frame_dig -1 // mbrPayment: PayTxn
	gtxns Amount
	frame_dig 3 // PoolInitMbr: uint64
	==

	// transaction verification failed: {"txn":"mbrPayment","field":"amount","expected":"PoolInitMbr"}
	assert

	// examples/reti/stakingPool.algo.ts:169
	// this.stakers.create()
	byte 0x7374616b657273 // "stakers"
	pushint 12800
	box_create
	pop

	// *if1_condition
	// examples/reti/stakingPool.algo.ts:171
	// isTokenEligible && this.poolId.value === 1
	frame_dig 1 // isTokenEligible: bool
	dup
	bz *skip_and1
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	int 1
	==
	&&

*skip_and1:
	bz *if1_end

	// *if1_consequent
	// examples/reti/stakingPool.algo.ts:173
	// sendAssetTransfer({
	//         xferAsset: AssetID.fromUint64(validatorConfig.rewardTokenId),
	//         assetReceiver: this.app.address,
	//         assetAmount: 0,
	//       })
	itxn_begin
	pushint 4 // axfer
	itxn_field TypeEnum

	// examples/reti/stakingPool.algo.ts:174
	// xferAsset: AssetID.fromUint64(validatorConfig.rewardTokenId)
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 153 8
	btoi
	itxn_field XferAsset

	// examples/reti/stakingPool.algo.ts:175
	// assetReceiver: this.app.address
	global CurrentApplicationAddress
	itxn_field AssetReceiver

	// examples/reti/stakingPool.algo.ts:176
	// assetAmount: 0
	int 0
	itxn_field AssetAmount

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

*if1_end:
	retsub

// addStake(pay,address)uint64
*abi_route_addStake:
	// The ABI return prefix
	byte 0x151f7c75

	// staker: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (staker) for addStake must be a address
	assert

	// stakedAmountPayment: pay
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// argument 1 (stakedAmountPayment) for addStake must be a pay transaction
	assert

	// execute addStake(pay,address)uint64
	callsub addStake
	itob
	concat
	log
	int 1
	return

// addStake(stakedAmountPayment: PayTxn, staker: Address): uint64
//
// Adds stake to the given account.
// Can ONLY be called by the validator contract that created us
// Must receive payment from the validator contract for amount being staked.
//
// @param {PayTxn} stakedAmountPayment prior payment coming from validator contract to us on behalf of staker.
// @param {Address} staker - The account adding new stake
// @throws {Error} - Throws an error if the staking pool is full.
// @returns {uint64} new 'entry round' round number of stake add
addStake:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 4

	// examples/reti/stakingPool.algo.ts:192
	// assert(this.stakers.exists, 'staking pool must be initialized first')
	byte 0x7374616b657273 // "stakers"
	box_len
	swap
	pop

	// staking pool must be initialized first
	assert

	// examples/reti/stakingPool.algo.ts:195
	// assert(
	//       this.txn.sender === AppID.fromUint64(this.creatingValidatorContractAppId.value).address,
	//       'stake can only be added via the validator contract'
	//     )
	txn Sender
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	app_params_get AppAddress
	pop
	==

	// stake can only be added via the validator contract
	assert

	// examples/reti/stakingPool.algo.ts:199
	// assert(staker !== globals.zeroAddress)
	frame_dig -2 // staker: Address
	global ZeroAddress
	!=
	assert

	// examples/reti/stakingPool.algo.ts:202
	// this.checkIfBinClosed()
	callsub checkIfBinClosed

	// examples/reti/stakingPool.algo.ts:206
	// verifyPayTxn(stakedAmountPayment, {
	//       sender: AppID.fromUint64(this.creatingValidatorContractAppId.value).address,
	//       receiver: this.app.address,
	//       amount: stakedAmountPayment.amount,
	//     })
	// verify sender
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Sender
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	app_params_get AppAddress
	pop
	==

	// transaction verification failed: {"txn":"stakedAmountPayment","field":"sender","expected":"AppID.fromUint64(this.creatingValidatorContractAppId.value).address"}
	assert

	// verify receiver
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Receiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"stakedAmountPayment","field":"receiver","expected":"this.app.address"}
	assert

	// verify amount
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Amount
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Amount
	==

	// transaction verification failed: {"txn":"stakedAmountPayment","field":"amount","expected":"stakedAmountPayment.amount"}
	assert

	// examples/reti/stakingPool.algo.ts:215
	// entryRound = globals.round + ALGORAND_STAKING_BLOCK_DELAY
	global Round
	pushint 320
	+
	frame_bury 0 // entryRound: uint64

	// examples/reti/stakingPool.algo.ts:216
	// firstEmpty = 0
	int 0
	frame_bury 1 // firstEmpty: uint64

	// examples/reti/stakingPool.algo.ts:218
	// this.totalAlgoStaked.value += stakedAmountPayment.amount
	byte 0x7374616b6564 // "staked"
	app_global_get
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Amount
	+
	byte 0x7374616b6564 // "staked"
	swap
	app_global_put

	// examples/reti/stakingPool.algo.ts:220
	// roundsLeftInBin = this.binRoundStart.value + this.roundsPerDay.value - globals.round
	byte 0x62696e526f756e645374617274 // "binRoundStart"
	app_global_get
	byte 0x726f756e6473506572446179 // "roundsPerDay"
	app_global_get
	+
	global Round
	-
	frame_bury 2 // roundsLeftInBin: uint64

	// examples/reti/stakingPool.algo.ts:221
	// this.stakeAccumulator.value =
	//       this.stakeAccumulator.value + (stakedAmountPayment.amount as uint128) * (roundsLeftInBin as uint128)
	byte 0x7374616b65416363756d756c61746f72 // "stakeAccumulator"
	dup
	app_global_get
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Amount
	itob
	frame_dig 2 // roundsLeftInBin: uint64
	itob
	b*
	b+
	dup
	bitlen
	int 128
	<=

	// this.stakeAccumulator.value + (stakedAmountPayment.amount as uint128) * (roundsLeftInBin as uint128) overflowed 128 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 16
	-
	swap
	substring3
	app_global_put

	// examples/reti/stakingPool.algo.ts:225
	// for (let i = 0; i < this.stakers.value.length; i += 1)
	int 0
	frame_bury 3 // i: uint64

*for_0:
	// examples/reti/stakingPool.algo.ts:225
	// i < this.stakers.value.length
	frame_dig 3 // i: uint64
	int 200
	<
	bz *for_0_end

	// *if2_condition
	// examples/reti/stakingPool.algo.ts:226
	// globals.opcodeBudget < 300
	global OpcodeBudget
	int 300
	<
	bz *if2_end

	// *if2_consequent
	// examples/reti/stakingPool.algo.ts:227
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	pushint 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

*if2_end:
	// examples/reti/stakingPool.algo.ts:229
	// cmpStaker = clone(this.stakers.value[i])
	frame_dig 3 // i: uint64
	int 64
	* // acc * typeLength
	int 64
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_extract
	frame_bury 4 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// *if3_condition
	// examples/reti/stakingPool.algo.ts:230
	// cmpStaker.account === staker
	frame_dig 4 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 0 32
	frame_dig -2 // staker: Address
	==
	bz *if3_end

	// *if3_consequent
	// examples/reti/stakingPool.algo.ts:232
	// cmpStaker.balance += stakedAmountPayment.amount
	frame_dig 4 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	int 32 // headOffset
	frame_dig 4 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Amount
	+
	itob
	replace3
	frame_bury 4 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:233
	// cmpStaker.entryRound = entryRound
	frame_dig 4 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	pushint 56 // headOffset
	frame_dig 0 // entryRound: uint64
	itob
	replace3
	frame_bury 4 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:236
	// this.stakers.value[i] = cmpStaker
	frame_dig 3 // i: uint64
	int 64
	* // acc * typeLength
	frame_dig 4 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_replace

	// examples/reti/stakingPool.algo.ts:238
	// return entryRound;
	frame_dig 0 // entryRound: uint64
	b *addStake*return

*if3_end:
	// *if4_condition
	// examples/reti/stakingPool.algo.ts:240
	// firstEmpty === 0 && cmpStaker.account === globals.zeroAddress
	frame_dig 1 // firstEmpty: uint64
	int 0
	==
	dup
	bz *skip_and2
	frame_dig 4 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 0 32
	global ZeroAddress
	==
	&&

*skip_and2:
	bz *if4_end

	// *if4_consequent
	// examples/reti/stakingPool.algo.ts:241
	// firstEmpty = i + 1
	frame_dig 3 // i: uint64
	int 1
	+
	frame_bury 1 // firstEmpty: uint64

*if4_end:

*for_0_continue:
	// examples/reti/stakingPool.algo.ts:225
	// i += 1
	frame_dig 3 // i: uint64
	int 1
	+
	frame_bury 3 // i: uint64
	b *for_0

*for_0_end:
	// *if5_condition
	// examples/reti/stakingPool.algo.ts:245
	// firstEmpty === 0
	frame_dig 1 // firstEmpty: uint64
	int 0
	==
	bz *if5_end

	// *if5_consequent
	// Staking pool full
	err

*if5_end:
	// examples/reti/stakingPool.algo.ts:252
	// assert(stakedAmountPayment.amount >= this.minEntryStake.value, 'must stake at least the minimum for this pool')
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Amount
	byte 0x6d696e456e7472795374616b65 // "minEntryStake"
	app_global_get
	>=

	// must stake at least the minimum for this pool
	assert

	// examples/reti/stakingPool.algo.ts:254
	// assert(this.stakers.value[firstEmpty - 1].account === globals.zeroAddress)
	frame_dig 1 // firstEmpty: uint64
	int 1
	-
	int 64
	* // acc * typeLength
	int 0
	+
	int 32
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_extract
	global ZeroAddress
	==
	assert

	// examples/reti/stakingPool.algo.ts:255
	// this.stakers.value[firstEmpty - 1] = {
	//       account: staker,
	//       balance: stakedAmountPayment.amount,
	//       totalRewarded: 0,
	//       rewardTokenBalance: 0,
	//       entryRound: entryRound,
	//     }
	frame_dig 1 // firstEmpty: uint64
	int 1
	-
	int 64
	* // acc * typeLength
	frame_dig -2 // staker: Address
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Amount
	itob
	concat
	byte 0x0000000000000000
	concat
	byte 0x0000000000000000
	concat
	frame_dig 0 // entryRound: uint64
	itob
	concat
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_replace

	// examples/reti/stakingPool.algo.ts:262
	// this.numStakers.value += 1
	byte 0x6e756d5374616b657273 // "numStakers"
	app_global_get
	int 1
	+
	byte 0x6e756d5374616b657273 // "numStakers"
	swap
	app_global_put

	// examples/reti/stakingPool.algo.ts:263
	// return entryRound;
	frame_dig 0 // entryRound: uint64

*addStake*return:
	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 4
	retsub

// removeStake(address,uint64)void
*abi_route_removeStake:
	// amountToUnstake: uint64
	txna ApplicationArgs 2
	btoi

	// staker: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (staker) for removeStake must be a address
	assert

	// execute removeStake(address,uint64)void
	callsub removeStake
	int 1
	return

// removeStake(staker: Address, amountToUnstake: uint64): void
//
// Removes stake on behalf of caller (removing own stake).  If any token rewards exist, those are always sent in
// full. Also notifies the validator contract for this pools validator of the staker / balance changes.
//
// @param {Address} staker - account to remove.  normally same as sender, but the validator owner or manager can also call
// this to remove the specified staker explicitly. The removed stake MUST only go to the staker of course.  This is
// so a validator can shut down a poool and refund the stakers.  It can also be used to kick out stakers who no longer
// meet the gating requirements (determined by the node daemon).
// @param {uint64} amountToUnstake - The amount of stake to be removed.  Specify 0 to remove all stake.
// @throws {Error} If the account has insufficient balance or if the account is not found.
removeStake:
	proto 2 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 6

	// *if6_condition
	// examples/reti/stakingPool.algo.ts:280
	// staker !== this.txn.sender
	frame_dig -1 // staker: Address
	txn Sender
	!=
	bz *if6_end

	// *if6_consequent
	// examples/reti/stakingPool.algo.ts:281
	// assert(
	//         this.isOwnerOrManagerCaller(),
	//         'If staker is not sender in removeStake call, then sender MUST be owner or manager of validator'
	//       )
	callsub isOwnerOrManagerCaller

	// If staker is not sender in removeStake call, then sender MUST be owner or manager of validator
	assert

*if6_end:
	// examples/reti/stakingPool.algo.ts:287
	// this.checkIfBinClosed()
	callsub checkIfBinClosed

	// examples/reti/stakingPool.algo.ts:289
	// for (let i = 0; i < this.stakers.value.length; i += 1)
	int 0
	frame_bury 0 // i: uint64

*for_1:
	// examples/reti/stakingPool.algo.ts:289
	// i < this.stakers.value.length
	frame_dig 0 // i: uint64
	int 200
	<
	bz *for_1_end

	// *if7_condition
	// examples/reti/stakingPool.algo.ts:290
	// globals.opcodeBudget < 300
	global OpcodeBudget
	int 300
	<
	bz *if7_end

	// *if7_consequent
	// examples/reti/stakingPool.algo.ts:291
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	pushint 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

*if7_end:
	// examples/reti/stakingPool.algo.ts:293
	// cmpStaker = clone(this.stakers.value[i])
	frame_dig 0 // i: uint64
	int 64
	* // acc * typeLength
	int 64
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_extract
	frame_bury 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// *if8_condition
	// examples/reti/stakingPool.algo.ts:294
	// cmpStaker.account === staker
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 0 32
	frame_dig -1 // staker: Address
	==
	bz *if8_end

	// *if8_consequent
	// *if9_condition
	// examples/reti/stakingPool.algo.ts:295
	// amountToUnstake === 0
	frame_dig -2 // amountToUnstake: uint64
	int 0
	==
	bz *if9_end

	// *if9_consequent
	// examples/reti/stakingPool.algo.ts:297
	// amountToUnstake = cmpStaker.balance
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	frame_bury -2 // amountToUnstake: uint64

*if9_end:
	// *if10_condition
	// examples/reti/stakingPool.algo.ts:299
	// cmpStaker.balance < amountToUnstake
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	frame_dig -2 // amountToUnstake: uint64
	<
	bz *if10_end

	// *if10_consequent
	// Insufficient balance
	err

*if10_end:
	// examples/reti/stakingPool.algo.ts:302
	// cmpStaker.balance -= amountToUnstake
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	int 32 // headOffset
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	frame_dig -2 // amountToUnstake: uint64
	-
	itob
	replace3
	frame_bury 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:303
	// this.totalAlgoStaked.value -= amountToUnstake
	byte 0x7374616b6564 // "staked"
	app_global_get
	frame_dig -2 // amountToUnstake: uint64
	-
	byte 0x7374616b6564 // "staked"
	swap
	app_global_put

	// examples/reti/stakingPool.algo.ts:305
	// amountRewardTokenRemoved = 0
	int 0
	frame_bury 2 // amountRewardTokenRemoved: uint64

	// *if11_condition
	// examples/reti/stakingPool.algo.ts:306
	// cmpStaker.rewardTokenBalance > 0
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 48 8
	btoi
	int 0
	>
	bz *if11_end

	// *if11_consequent
	// *if12_condition
	// examples/reti/stakingPool.algo.ts:308
	// this.poolId.value === 1
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	int 1
	==
	bz *if12_else

	// *if12_consequent
	// examples/reti/stakingPool.algo.ts:309
	// validatorConfig = sendMethodCall<typeof ValidatorRegistry.prototype.getValidatorConfig>({
	//               applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//               methodArgs: [this.validatorId.value],
	//             })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0x75aff61d // method "getValidatorConfig(uint64)(uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:310
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:311
	// methodArgs: [this.validatorId.value]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0
	frame_bury 3 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:317
	// sendAssetTransfer({
	//               xferAsset: AssetID.fromUint64(validatorConfig.rewardTokenId),
	//               assetReceiver: staker,
	//               assetAmount: cmpStaker.rewardTokenBalance,
	//             })
	itxn_begin
	pushint 4 // axfer
	itxn_field TypeEnum

	// examples/reti/stakingPool.algo.ts:318
	// xferAsset: AssetID.fromUint64(validatorConfig.rewardTokenId)
	frame_dig 3 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 153 8
	btoi
	itxn_field XferAsset

	// examples/reti/stakingPool.algo.ts:319
	// assetReceiver: staker
	frame_dig -1 // staker: Address
	itxn_field AssetReceiver

	// examples/reti/stakingPool.algo.ts:320
	// assetAmount: cmpStaker.rewardTokenBalance
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 48 8
	btoi
	itxn_field AssetAmount

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/stakingPool.algo.ts:322
	// amountRewardTokenRemoved = cmpStaker.rewardTokenBalance
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 48 8
	btoi
	frame_bury 2 // amountRewardTokenRemoved: uint64

	// examples/reti/stakingPool.algo.ts:323
	// cmpStaker.rewardTokenBalance = 0
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	byte 0x0000000000000000
	replace2 48
	frame_bury 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	b *if12_end

*if12_else:
	// examples/reti/stakingPool.algo.ts:328
	// amountRewardTokenRemoved = cmpStaker.rewardTokenBalance
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 48 8
	btoi
	frame_bury 2 // amountRewardTokenRemoved: uint64

	// examples/reti/stakingPool.algo.ts:329
	// cmpStaker.rewardTokenBalance = 0
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	byte 0x0000000000000000
	replace2 48
	frame_bury 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)

*if12_end:

*if11_end:
	// examples/reti/stakingPool.algo.ts:334
	// assert(
	//           cmpStaker.balance === 0 || cmpStaker.balance >= this.minEntryStake.value,
	//           'cannot reduce balance below minimum allowed stake unless all is removed'
	//         )
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	int 0
	==
	dup
	bnz *skip_or0
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	byte 0x6d696e456e7472795374616b65 // "minEntryStake"
	app_global_get
	>=
	||

*skip_or0:
	// cannot reduce balance below minimum allowed stake unless all is removed
	assert

	// examples/reti/stakingPool.algo.ts:342
	// sendPayment({
	//           amount: amountToUnstake,
	//           receiver: staker,
	//           note: 'unstaked',
	//         })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// examples/reti/stakingPool.algo.ts:343
	// amount: amountToUnstake
	frame_dig -2 // amountToUnstake: uint64
	itxn_field Amount

	// examples/reti/stakingPool.algo.ts:344
	// receiver: staker
	frame_dig -1 // staker: Address
	itxn_field Receiver

	// examples/reti/stakingPool.algo.ts:345
	// note: 'unstaked'
	pushbytes 0x756e7374616b6564 // "unstaked"
	itxn_field Note

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/stakingPool.algo.ts:347
	// stakerRemoved = false
	int 0
	frame_bury 4 // stakerRemoved: bool

	// *if13_condition
	// examples/reti/stakingPool.algo.ts:348
	// cmpStaker.balance === 0
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	int 0
	==
	bz *if13_end

	// *if13_consequent
	// examples/reti/stakingPool.algo.ts:350
	// this.numStakers.value -= 1
	byte 0x6e756d5374616b657273 // "numStakers"
	app_global_get
	int 1
	-
	byte 0x6e756d5374616b657273 // "numStakers"
	swap
	app_global_put

	// examples/reti/stakingPool.algo.ts:351
	// cmpStaker.account = globals.zeroAddress
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	int 0
	global ZeroAddress
	replace3
	frame_bury 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:352
	// cmpStaker.totalRewarded = 0
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	byte 0x0000000000000000
	replace2 40
	frame_bury 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:353
	// cmpStaker.rewardTokenBalance = 0
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	byte 0x0000000000000000
	replace2 48
	frame_bury 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:354
	// stakerRemoved = true
	int 1
	frame_bury 4 // stakerRemoved: bool

*if13_end:
	// examples/reti/stakingPool.algo.ts:357
	// this.stakers.value[i] = cmpStaker
	frame_dig 0 // i: uint64
	int 64
	* // acc * typeLength
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_replace

	// examples/reti/stakingPool.algo.ts:359
	// roundsLeftInBin = this.binRoundStart.value + this.roundsPerDay.value - globals.round
	byte 0x62696e526f756e645374617274 // "binRoundStart"
	app_global_get
	byte 0x726f756e6473506572446179 // "roundsPerDay"
	app_global_get
	+
	global Round
	-
	frame_bury 5 // roundsLeftInBin: uint64

	// examples/reti/stakingPool.algo.ts:360
	// subtractAmount: uint128 = (amountToUnstake as uint128) * (roundsLeftInBin as uint128)
	frame_dig -2 // amountToUnstake: uint64
	itob
	frame_dig 5 // roundsLeftInBin: uint64
	itob
	b*
	dup
	bitlen
	int 128
	<=

	// (amountToUnstake as uint128) * (roundsLeftInBin as uint128) overflowed 128 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 16
	-
	swap
	substring3
	frame_bury 6 // subtractAmount: uint128

	// examples/reti/stakingPool.algo.ts:361
	// this.stakeAccumulator.value = this.stakeAccumulator.value - subtractAmount
	byte 0x7374616b65416363756d756c61746f72 // "stakeAccumulator"
	dup
	app_global_get
	frame_dig 6 // subtractAmount: uint128
	b-
	dup
	bitlen
	int 128
	<=

	// this.stakeAccumulator.value - subtractAmount overflowed 128 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 16
	-
	swap
	substring3
	app_global_put

	// examples/reti/stakingPool.algo.ts:366
	// sendMethodCall<typeof ValidatorRegistry.prototype.stakeRemoved>({
	//           applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//           methodArgs: [
	//             { id: this.validatorId.value, poolId: this.poolId.value, poolAppId: this.app.id },
	//             staker,
	//             amountToUnstake,
	//             amountRewardTokenRemoved,
	//             stakerRemoved,
	//           ],
	//         })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0xa2dc51b5 // method "stakeRemoved((uint64,uint64,uint64),address,uint64,uint64,bool)void"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:367
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:368
	// methodArgs: [
	//             { id: this.validatorId.value, poolId: this.poolId.value, poolAppId: this.app.id },
	//             staker,
	//             amountToUnstake,
	//             amountRewardTokenRemoved,
	//             stakerRemoved,
	//           ]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	itob
	concat
	txna Applications 0
	itob
	concat
	itxn_field ApplicationArgs
	frame_dig -1 // staker: Address
	itxn_field ApplicationArgs
	frame_dig -2 // amountToUnstake: uint64
	itob
	itxn_field ApplicationArgs
	frame_dig 2 // amountRewardTokenRemoved: uint64
	itob
	itxn_field ApplicationArgs
	frame_dig 4 // stakerRemoved: bool
	byte 0x00
	int 0
	uncover 2
	setbit
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/stakingPool.algo.ts:376
	// return;
	retsub

*if8_end:

*for_1_continue:
	// examples/reti/stakingPool.algo.ts:289
	// i += 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64
	b *for_1

*for_1_end:
	// account not found
	err
	retsub

// claimTokens()void
*abi_route_claimTokens:
	// execute claimTokens()void
	callsub claimTokens
	int 1
	return

// claimTokens(): void
//
// Claims all the available reward tokens a staker has available, sending their entire balance to the staker from
// pool 1 (either directly, or via validator->pool1 to pay it out)
// Also notifies the validator contract for this pools validator of the staker / balance changes.
claimTokens:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 4

	// examples/reti/stakingPool.algo.ts:391
	// staker = this.txn.sender
	txn Sender
	frame_bury 0 // staker: address

	// examples/reti/stakingPool.algo.ts:393
	// for (let i = 0; i < this.stakers.value.length; i += 1)
	int 0
	frame_bury 1 // i: uint64

*for_2:
	// examples/reti/stakingPool.algo.ts:393
	// i < this.stakers.value.length
	frame_dig 1 // i: uint64
	int 200
	<
	bz *for_2_end

	// *if14_condition
	// examples/reti/stakingPool.algo.ts:394
	// globals.opcodeBudget < 300
	global OpcodeBudget
	int 300
	<
	bz *if14_end

	// *if14_consequent
	// examples/reti/stakingPool.algo.ts:395
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	pushint 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

*if14_end:
	// examples/reti/stakingPool.algo.ts:397
	// cmpStaker = clone(this.stakers.value[i])
	frame_dig 1 // i: uint64
	int 64
	* // acc * typeLength
	int 64
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_extract
	frame_bury 2 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// *if15_condition
	// examples/reti/stakingPool.algo.ts:398
	// cmpStaker.account === staker
	frame_dig 2 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 0 32
	frame_dig 0 // staker: address
	==
	bz *if15_end

	// *if15_consequent
	// *if16_condition
	// examples/reti/stakingPool.algo.ts:399
	// cmpStaker.rewardTokenBalance === 0
	frame_dig 2 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 48 8
	btoi
	int 0
	==
	bz *if16_end

	// *if16_consequent
	// examples/reti/stakingPool.algo.ts:400
	// return;
	retsub

*if16_end:
	// examples/reti/stakingPool.algo.ts:402
	// amountRewardTokenRemoved = 0
	int 0
	frame_bury 3 // amountRewardTokenRemoved: uint64

	// *if17_condition
	// examples/reti/stakingPool.algo.ts:404
	// this.poolId.value === 1
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	int 1
	==
	bz *if17_else

	// *if17_consequent
	// examples/reti/stakingPool.algo.ts:405
	// validatorConfig = sendMethodCall<typeof ValidatorRegistry.prototype.getValidatorConfig>({
	//             applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//             methodArgs: [this.validatorId.value],
	//           })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0x75aff61d // method "getValidatorConfig(uint64)(uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:406
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:407
	// methodArgs: [this.validatorId.value]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0
	frame_bury 4 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:412
	// sendAssetTransfer({
	//             xferAsset: AssetID.fromUint64(validatorConfig.rewardTokenId),
	//             assetReceiver: staker,
	//             assetAmount: cmpStaker.rewardTokenBalance,
	//           })
	itxn_begin
	pushint 4 // axfer
	itxn_field TypeEnum

	// examples/reti/stakingPool.algo.ts:413
	// xferAsset: AssetID.fromUint64(validatorConfig.rewardTokenId)
	frame_dig 4 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 153 8
	btoi
	itxn_field XferAsset

	// examples/reti/stakingPool.algo.ts:414
	// assetReceiver: staker
	frame_dig 0 // staker: address
	itxn_field AssetReceiver

	// examples/reti/stakingPool.algo.ts:415
	// assetAmount: cmpStaker.rewardTokenBalance
	frame_dig 2 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 48 8
	btoi
	itxn_field AssetAmount

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/stakingPool.algo.ts:417
	// amountRewardTokenRemoved = cmpStaker.rewardTokenBalance
	frame_dig 2 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 48 8
	btoi
	frame_bury 3 // amountRewardTokenRemoved: uint64

	// examples/reti/stakingPool.algo.ts:418
	// cmpStaker.rewardTokenBalance = 0
	frame_dig 2 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	byte 0x0000000000000000
	replace2 48
	frame_bury 2 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	b *if17_end

*if17_else:
	// examples/reti/stakingPool.algo.ts:423
	// amountRewardTokenRemoved = cmpStaker.rewardTokenBalance
	frame_dig 2 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 48 8
	btoi
	frame_bury 3 // amountRewardTokenRemoved: uint64

	// examples/reti/stakingPool.algo.ts:424
	// cmpStaker.rewardTokenBalance = 0
	frame_dig 2 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	byte 0x0000000000000000
	replace2 48
	frame_bury 2 // cmpStaker: (address,uint64,uint64,uint64,uint64)

*if17_end:
	// examples/reti/stakingPool.algo.ts:428
	// this.stakers.value[i] = cmpStaker
	frame_dig 1 // i: uint64
	int 64
	* // acc * typeLength
	frame_dig 2 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_replace

	// examples/reti/stakingPool.algo.ts:433
	// sendMethodCall<typeof ValidatorRegistry.prototype.stakeRemoved>({
	//           applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//           methodArgs: [
	//             { id: this.validatorId.value, poolId: this.poolId.value, poolAppId: this.app.id },
	//             staker,
	//             0, // no algo removed
	//             amountRewardTokenRemoved,
	//             false, // staker isn't being removed.
	//           ],
	//         })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0xa2dc51b5 // method "stakeRemoved((uint64,uint64,uint64),address,uint64,uint64,bool)void"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:434
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:435
	// methodArgs: [
	//             { id: this.validatorId.value, poolId: this.poolId.value, poolAppId: this.app.id },
	//             staker,
	//             0, // no algo removed
	//             amountRewardTokenRemoved,
	//             false, // staker isn't being removed.
	//           ]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	itob
	concat
	txna Applications 0
	itob
	concat
	itxn_field ApplicationArgs
	frame_dig 0 // staker: address
	itxn_field ApplicationArgs
	byte 0x0000000000000000
	itxn_field ApplicationArgs
	frame_dig 3 // amountRewardTokenRemoved: uint64
	itob
	itxn_field ApplicationArgs
	int 0
	byte 0x00
	int 0
	uncover 2
	setbit
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/stakingPool.algo.ts:443
	// return;
	retsub

*if15_end:

*for_2_continue:
	// examples/reti/stakingPool.algo.ts:393
	// i += 1
	frame_dig 1 // i: uint64
	int 1
	+
	frame_bury 1 // i: uint64
	b *for_2

*for_2_end:
	// account not found
	err
	retsub

// getStakerInfo(address)(address,uint64,uint64,uint64,uint64)
*abi_route_getStakerInfo:
	// The ABI return prefix
	byte 0x151f7c75

	// staker: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (staker) for getStakerInfo must be a address
	assert

	// execute getStakerInfo(address)(address,uint64,uint64,uint64,uint64)
	callsub getStakerInfo
	concat
	log
	int 1
	return

// getStakerInfo(staker: Address): StakedInfo
//
// Retrieves the staked information for a given staker.
//
// @param {Address} staker - The address of the staker.
// @returns {StakedInfo} - The staked information for the given staker.
// @throws {Error} - If the staker's account is not found.
getStakerInfo:
	proto 1 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/reti/stakingPool.algo.ts:458
	// for (let i = 0; i < this.stakers.value.length; i += 1)
	int 0
	frame_bury 0 // i: uint64

*for_3:
	// examples/reti/stakingPool.algo.ts:458
	// i < this.stakers.value.length
	frame_dig 0 // i: uint64
	int 200
	<
	bz *for_3_end

	// *if18_condition
	// examples/reti/stakingPool.algo.ts:459
	// globals.opcodeBudget < 200
	global OpcodeBudget
	int 200
	<
	bz *if18_end

	// *if18_consequent
	// examples/reti/stakingPool.algo.ts:460
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	pushint 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

*if18_end:
	// *if19_condition
	// examples/reti/stakingPool.algo.ts:462
	// this.stakers.value[i].account === staker
	frame_dig 0 // i: uint64
	int 64
	* // acc * typeLength
	int 0
	+
	int 32
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_extract
	frame_dig -1 // staker: Address
	==
	bz *if19_end

	// *if19_consequent
	// examples/reti/stakingPool.algo.ts:463
	// return this.stakers.value[i];
	frame_dig 0 // i: uint64
	int 64
	* // acc * typeLength
	int 64
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_extract
	b *getStakerInfo*return

*if19_end:

*for_3_continue:
	// examples/reti/stakingPool.algo.ts:458
	// i += 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64
	b *for_3

*for_3_end:
	// account not found
	err

*getStakerInfo*return:
	// set the subroutine return value
	frame_bury 0
	retsub

// payTokenReward(address,uint64,uint64)void
*abi_route_payTokenReward:
	// amountToSend: uint64
	txna ApplicationArgs 3
	btoi

	// rewardToken: uint64
	txna ApplicationArgs 2
	btoi

	// staker: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 2 (staker) for payTokenReward must be a address
	assert

	// execute payTokenReward(address,uint64,uint64)void
	callsub payTokenReward
	int 1
	return

// payTokenReward(staker: Address, rewardToken: uint64, amountToSend: uint64): void
//
// [Internal protocol method] Remove a specified amount of 'community token' rewards for a staker.
// This can ONLY be called by our validator and only if we're pool 1 - with the token.
// Note: this can also be called by validator as part of OWNER wanting to send the reward tokens
// somewhere else (ie if they're sunsetting their validator and need the reward tokens back).
// It's up to the validator to ensure that the balance in rewardTokenHeldBack is honored.
// @param staker - the staker account to send rewards to
// @param rewardToken - id of reward token (to avoid re-entrancy in calling validator back to get id)
// @param amountToSend - amount to send the staker (there is significant trust here(!) - also why only validator can call us
payTokenReward:
	proto 3 0

	// examples/reti/stakingPool.algo.ts:481
	// assert(
	//       this.txn.sender === AppID.fromUint64(this.creatingValidatorContractAppId.value).address,
	//       'this can only be called via the validator contract'
	//     )
	txn Sender
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	app_params_get AppAddress
	pop
	==

	// this can only be called via the validator contract
	assert

	// examples/reti/stakingPool.algo.ts:485
	// assert(this.poolId.value === 1, 'must be pool 1 in order to be called to pay out token rewards')
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	int 1
	==

	// must be pool 1 in order to be called to pay out token rewards
	assert

	// examples/reti/stakingPool.algo.ts:486
	// assert(rewardToken !== 0, 'can only claim token rewards from validator that has them')
	frame_dig -2 // rewardToken: uint64
	int 0
	!=

	// can only claim token rewards from validator that has them
	assert

	// examples/reti/stakingPool.algo.ts:489
	// sendAssetTransfer({
	//       xferAsset: AssetID.fromUint64(rewardToken),
	//       assetReceiver: staker,
	//       assetAmount: amountToSend,
	//     })
	itxn_begin
	pushint 4 // axfer
	itxn_field TypeEnum

	// examples/reti/stakingPool.algo.ts:490
	// xferAsset: AssetID.fromUint64(rewardToken)
	frame_dig -2 // rewardToken: uint64
	itxn_field XferAsset

	// examples/reti/stakingPool.algo.ts:491
	// assetReceiver: staker
	frame_dig -1 // staker: Address
	itxn_field AssetReceiver

	// examples/reti/stakingPool.algo.ts:492
	// assetAmount: amountToSend
	frame_dig -3 // amountToSend: uint64
	itxn_field AssetAmount

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// updateAlgodVer(string)void
*abi_route_updateAlgodVer:
	// algodVer: string
	txna ApplicationArgs 1
	extract 2 0

	// execute updateAlgodVer(string)void
	callsub updateAlgodVer
	int 1
	return

// updateAlgodVer(algodVer: string): void
//
// Update the (honor system) algod version for the node associated to this pool.  The node management daemon
// should compare its current nodes version to the version stored in global state, updating when different.
// The reti node daemon composes its own version string using format:
// {major}.{minor}.{build} {branch} [{commit hash}],
// ie: 3.22.0 rel/stable [6b508975]
// [ ONLY OWNER OR MANAGER CAN CALL ]
// @param {string} algodVer - string representing the algorand node daemon version (reti node daemon composes its own meta version)
updateAlgodVer:
	proto 1 0

	// examples/reti/stakingPool.algo.ts:506
	// assert(this.isOwnerOrManagerCaller(), 'can only be called by owner or manager of validator')
	callsub isOwnerOrManagerCaller

	// can only be called by owner or manager of validator
	assert

	// examples/reti/stakingPool.algo.ts:507
	// this.algodVer.value = algodVer
	pushbytes 0x616c676f64566572 // "algodVer"
	frame_dig -1 // algodVer: string
	app_global_put
	retsub

// epochBalanceUpdate()void
*abi_route_epochBalanceUpdate:
	// execute epochBalanceUpdate()void
	callsub epochBalanceUpdate
	int 1
	return

// epochBalanceUpdate(): void
//
// Updates the balance of stakers in the pool based on the received 'rewards' (current balance vs known staked balance)
// stakers outstanding balance is adjusted based on their % of stake and time in the current epoch - so that balance
// compounds over time and staker can remove that amount at will.
// The validator is paid their percentage each epoch payout.
//
// Note: ANYONE can call this.
epochBalanceUpdate:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 36

	// examples/reti/stakingPool.algo.ts:520
	// validatorConfig = sendMethodCall<typeof ValidatorRegistry.prototype.getValidatorConfig>({
	//       applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//       methodArgs: [this.validatorId.value],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0x75aff61d // method "getValidatorConfig(uint64)(uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:521
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:522
	// methodArgs: [this.validatorId.value]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0
	frame_bury 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:529
	// epochRoundLength = validatorConfig.epochRoundLength as uint64
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 169 4
	btoi
	frame_bury 1 // epochRoundLength: uint64

	// examples/reti/stakingPool.algo.ts:530
	// curRound = globals.round
	global Round
	frame_bury 2 // curRound: uint64

	// examples/reti/stakingPool.algo.ts:531
	// thisEpochBegin = curRound - (curRound % epochRoundLength)
	frame_dig 2 // curRound: uint64
	frame_dig 2 // curRound: uint64
	frame_dig 1 // epochRoundLength: uint64
	%
	-
	frame_bury 3 // thisEpochBegin: uint64

	// *if20_condition
	// examples/reti/stakingPool.algo.ts:534
	// this.lastPayout.exists
	txna Applications 0
	byte 0x6c6173745061796f7574 // "lastPayout"
	app_global_get_ex
	swap
	pop
	bz *if20_end

	// *if20_consequent
	// examples/reti/stakingPool.algo.ts:535
	// lastPayoutEpoch = this.lastPayout.value - (this.lastPayout.value % epochRoundLength)
	byte 0x6c6173745061796f7574 // "lastPayout"
	app_global_get
	byte 0x6c6173745061796f7574 // "lastPayout"
	app_global_get
	frame_dig 1 // epochRoundLength: uint64
	%
	-
	frame_bury 4 // lastPayoutEpoch: uint64

	// examples/reti/stakingPool.algo.ts:539
	// assert(lastPayoutEpoch !== thisEpochBegin, "can't call epochBalanceUpdate in same epoch as prior call")
	frame_dig 4 // lastPayoutEpoch: uint64
	frame_dig 3 // thisEpochBegin: uint64
	!=

	// can't call epochBalanceUpdate in same epoch as prior call
	assert

*if20_end:
	// examples/reti/stakingPool.algo.ts:542
	// this.checkIfBinClosed()
	callsub checkIfBinClosed

	// examples/reti/stakingPool.algo.ts:545
	// this.lastPayout.value = curRound
	byte 0x6c6173745061796f7574 // "lastPayout"
	frame_dig 2 // curRound: uint64
	app_global_put

	// examples/reti/stakingPool.algo.ts:546
	// this.epochNumber.value += 1
	byte 0x65706f63684e756d626572 // "epochNumber"
	app_global_get
	int 1
	+
	byte 0x65706f63684e756d626572 // "epochNumber"
	swap
	app_global_put

	// examples/reti/stakingPool.algo.ts:551
	// isTokenEligible = validatorConfig.rewardTokenId !== 0
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 153 8
	btoi
	int 0
	!=
	frame_bury 5 // isTokenEligible: bool

	// examples/reti/stakingPool.algo.ts:552
	// poolOneAppID = this.app.id
	txna Applications 0
	frame_bury 6 // poolOneAppID: uint64

	// examples/reti/stakingPool.algo.ts:553
	// poolOneAddress = this.app.address
	global CurrentApplicationAddress
	frame_bury 7 // poolOneAddress: address

	// *if21_condition
	// examples/reti/stakingPool.algo.ts:558
	// isTokenEligible
	frame_dig 5 // isTokenEligible: bool
	bz *if21_end

	// *if21_consequent
	// *if22_condition
	// examples/reti/stakingPool.algo.ts:559
	// this.poolId.value !== 1
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	int 1
	!=
	bz *if22_end

	// *if22_consequent
	// examples/reti/stakingPool.algo.ts:561
	// poolOneAppID = sendMethodCall<typeof ValidatorRegistry.prototype.getPoolAppId>({
	//           applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//           methodArgs: [this.validatorId.value, 1],
	//         })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0x572767d1 // method "getPoolAppId(uint64,uint64)uint64"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:562
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:563
	// methodArgs: [this.validatorId.value, 1]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	itxn_field ApplicationArgs
	pushbytes 0x0000000000000001
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0
	btoi
	frame_bury 6 // poolOneAppID: uint64

	// examples/reti/stakingPool.algo.ts:565
	// poolOneAddress = AppID.fromUint64(poolOneAppID).address
	frame_dig 6 // poolOneAppID: uint64
	app_params_get AppAddress
	pop
	frame_bury 7 // poolOneAddress: address

*if22_end:
	// *if23_condition
	// examples/reti/stakingPool.algo.ts:570
	// this.poolId.value === 1
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	int 1
	==
	bz *if23_else

	// *if23_consequent
	// examples/reti/stakingPool.algo.ts:571
	// tokenPayoutRatio = sendMethodCall<typeof ValidatorRegistry.prototype.setTokenPayoutRatio>({
	//           applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//           methodArgs: [this.validatorId.value],
	//         })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0x4df8d86e // method "setTokenPayoutRatio(uint64)(uint64[24],uint64)"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:572
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:573
	// methodArgs: [this.validatorId.value]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0
	frame_bury 8 // tokenPayoutRatio: PoolTokenPayoutRatio
	b *if23_end

*if23_else:
	// examples/reti/stakingPool.algo.ts:577
	// tokenPayoutRatio = sendMethodCall<typeof StakingPool.prototype.proxiedSetTokenPayoutRatio>({
	//           applicationID: AppID.fromUint64(poolOneAppID),
	//           methodArgs: [{ id: this.validatorId.value, poolId: this.poolId.value, poolAppId: this.app.id }],
	//         })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0x0c2245e1 // method "proxiedSetTokenPayoutRatio((uint64,uint64,uint64))(uint64[24],uint64)"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:578
	// applicationID: AppID.fromUint64(poolOneAppID)
	frame_dig 6 // poolOneAppID: uint64
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:579
	// methodArgs: [{ id: this.validatorId.value, poolId: this.poolId.value, poolAppId: this.app.id }]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	itob
	concat
	txna Applications 0
	itob
	concat
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0
	frame_bury 8 // tokenPayoutRatio: PoolTokenPayoutRatio

*if23_end:

*if21_end:
	// examples/reti/stakingPool.algo.ts:586
	// validatorState = sendMethodCall<typeof ValidatorRegistry.prototype.getValidatorState>({
	//       applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//       methodArgs: [this.validatorId.value],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	pushbytes 0x1f2f0109 // method "getValidatorState(uint64)(uint16,uint64,uint64,uint64)"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:587
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:588
	// methodArgs: [this.validatorId.value]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0
	frame_bury 9 // validatorState: (uint16,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:590
	// rewardTokenHeldBack = validatorState.rewardTokenHeldBack
	frame_dig 9 // validatorState: (uint16,uint64,uint64,uint64)
	extract 18 8
	btoi
	frame_bury 10 // rewardTokenHeldBack: uint64

	// examples/reti/stakingPool.algo.ts:596
	// algoRewardAvail = this.app.address.balance - this.totalAlgoStaked.value - this.app.address.minBalance
	global CurrentApplicationAddress
	acct_params_get AcctBalance
	pop
	byte 0x7374616b6564 // "staked"
	app_global_get
	-
	global CurrentApplicationAddress
	acct_params_get AcctMinBalance
	pop
	-
	frame_bury 11 // algoRewardAvail: uint64

	// examples/reti/stakingPool.algo.ts:597
	// isPoolSaturated = false
	int 0
	frame_bury 12 // isPoolSaturated: bool

	// examples/reti/stakingPool.algo.ts:598
	// algoSaturationAmt = this.algoSaturationLevel()
	callsub algoSaturationLevel
	frame_bury 13 // algoSaturationAmt: uint64

	// *if24_condition
	// examples/reti/stakingPool.algo.ts:606
	// validatorState.totalAlgoStaked > algoSaturationAmt
	frame_dig 9 // validatorState: (uint16,uint64,uint64,uint64)
	extract 10 8
	btoi
	frame_dig 13 // algoSaturationAmt: uint64
	>
	bz *if24_end

	// *if24_consequent
	// examples/reti/stakingPool.algo.ts:607
	// isPoolSaturated = true
	int 1
	frame_bury 12 // isPoolSaturated: bool

*if24_end:
	// examples/reti/stakingPool.algo.ts:613
	// tokenRewardAvail = 0
	int 0
	frame_bury 14 // tokenRewardAvail: uint64

	// examples/reti/stakingPool.algo.ts:614
	// tokenRewardPaidOut = 0
	int 0
	frame_bury 15 // tokenRewardPaidOut: uint64

	// examples/reti/stakingPool.algo.ts:615
	// validatorCommissionPaidOut = 0
	int 0
	frame_bury 16 // validatorCommissionPaidOut: uint64

	// examples/reti/stakingPool.algo.ts:616
	// excessToFeeSink = 0
	int 0
	frame_bury 17 // excessToFeeSink: uint64

	// *if25_condition
	// examples/reti/stakingPool.algo.ts:617
	// isTokenEligible
	frame_dig 5 // isTokenEligible: bool
	bz *if25_end

	// *if25_consequent
	// examples/reti/stakingPool.algo.ts:618
	// tokenRewardBal =
	//         poolOneAddress.assetBalance(AssetID.fromUint64(validatorConfig.rewardTokenId)) - rewardTokenHeldBack
	frame_dig 7 // poolOneAddress: address
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 153 8
	btoi
	asset_holding_get AssetBalance
	pop
	frame_dig 10 // rewardTokenHeldBack: uint64
	-
	frame_bury 18 // tokenRewardBal: uint64

	// *if26_condition
	// examples/reti/stakingPool.algo.ts:623
	// tokenRewardBal >= validatorConfig.rewardPerPayout
	frame_dig 18 // tokenRewardBal: uint64
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 161 8
	btoi
	>=
	bz *if26_end

	// *if26_consequent
	// examples/reti/stakingPool.algo.ts:629
	// ourPoolPctOfWhole = tokenPayoutRatio.poolPctOfWhole[this.poolId.value - 1]
	frame_dig 8 // tokenPayoutRatio: PoolTokenPayoutRatio
	int 0
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	int 1
	-
	pushint 8
	* // acc * typeLength
	+
	pushint 8
	extract3
	btoi
	frame_bury 19 // ourPoolPctOfWhole: uint64

	// examples/reti/stakingPool.algo.ts:632
	// tokenRewardAvail = wideRatio([validatorConfig.rewardPerPayout, ourPoolPctOfWhole], [1_000_000])
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 161 8
	btoi
	frame_dig 19 // ourPoolPctOfWhole: uint64
	mulw
	int 0
	int 1_000_000
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	frame_bury 14 // tokenRewardAvail: uint64

*if26_end:

*if25_end:
	// *if27_condition
	// examples/reti/stakingPool.algo.ts:635
	// tokenRewardAvail === 0
	frame_dig 14 // tokenRewardAvail: uint64
	int 0
	==
	bz *if27_end

	// *if27_consequent
	// *if28_condition
	// examples/reti/stakingPool.algo.ts:640
	// algoRewardAvail < 1_000_000
	frame_dig 11 // algoRewardAvail: uint64
	int 1_000_000
	<
	bz *if28_end

	// *if28_consequent
	// examples/reti/stakingPool.algo.ts:641
	// log('!token&&!noalgo to pay')
	pushbytes 0x21746f6b656e2626216e6f616c676f20746f20706179 // "!token&&!noalgo to pay"
	log

	// examples/reti/stakingPool.algo.ts:642
	// return;
	retsub

*if28_end:

*if27_end:
	// *if29_condition
	// examples/reti/stakingPool.algo.ts:646
	// isPoolSaturated
	frame_dig 12 // isPoolSaturated: bool
	bz *if29_elseif1_condition

	// *if29_consequent
	// examples/reti/stakingPool.algo.ts:649
	// diminishedReward = wideRatio([algoRewardAvail, algoSaturationAmt], [validatorState.totalAlgoStaked])
	frame_dig 11 // algoRewardAvail: uint64
	frame_dig 13 // algoSaturationAmt: uint64
	mulw
	int 0
	frame_dig 9 // validatorState: (uint16,uint64,uint64,uint64)
	extract 10 8
	btoi
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	frame_bury 20 // diminishedReward: uint64

	// examples/reti/stakingPool.algo.ts:651
	// excessToFeeSink = algoRewardAvail - diminishedReward
	frame_dig 11 // algoRewardAvail: uint64
	frame_dig 20 // diminishedReward: uint64
	-
	frame_bury 17 // excessToFeeSink: uint64

	// examples/reti/stakingPool.algo.ts:652
	// sendPayment({
	//         amount: excessToFeeSink,
	//         receiver: this.getFeeSink(),
	//         note: 'pool saturated, excess to fee sink',
	//       })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// examples/reti/stakingPool.algo.ts:653
	// amount: excessToFeeSink
	frame_dig 17 // excessToFeeSink: uint64
	itxn_field Amount

	// examples/reti/stakingPool.algo.ts:654
	// receiver: this.getFeeSink()
	callsub getFeeSink
	itxn_field Receiver

	// examples/reti/stakingPool.algo.ts:655
	// note: 'pool saturated, excess to fee sink'
	pushbytes 0x706f6f6c207361747572617465642c2065786365737320746f206665652073696e6b // "pool saturated, excess to fee sink"
	itxn_field Note

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/stakingPool.algo.ts:658
	// algoRewardAvail = diminishedReward
	frame_dig 20 // diminishedReward: uint64
	frame_bury 11 // algoRewardAvail: uint64
	b *if29_end

*if29_elseif1_condition:
	// examples/reti/stakingPool.algo.ts:659
	// validatorConfig.percentToValidator !== 0
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 173 4
	btoi
	int 0
	!=
	bz *if29_end

	// *if29_elseif1_consequent
	// examples/reti/stakingPool.algo.ts:662
	// validatorCommissionPaidOut = wideRatio(
	//         [algoRewardAvail, validatorConfig.percentToValidator as uint64],
	//         [1_000_000]
	//       )
	frame_dig 11 // algoRewardAvail: uint64
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 173 4
	btoi
	mulw
	int 0
	int 1_000_000
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	frame_bury 16 // validatorCommissionPaidOut: uint64

	// examples/reti/stakingPool.algo.ts:668
	// algoRewardAvail -= validatorCommissionPaidOut
	frame_dig 11 // algoRewardAvail: uint64
	frame_dig 16 // validatorCommissionPaidOut: uint64
	-
	frame_bury 11 // algoRewardAvail: uint64

	// *if30_condition
	// examples/reti/stakingPool.algo.ts:675
	// validatorCommissionPaidOut > 0
	frame_dig 16 // validatorCommissionPaidOut: uint64
	int 0
	>
	bz *if30_end

	// *if30_consequent
	// examples/reti/stakingPool.algo.ts:678
	// managerTopOff = 0
	int 0
	frame_bury 21 // managerTopOff: uint64

	// *if31_condition
	// examples/reti/stakingPool.algo.ts:680
	// validatorConfig.manager !== validatorConfig.validatorCommissionAddress &&
	//           validatorConfig.manager.balance - validatorConfig.manager.minBalance < 2_100_000
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 40 32
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 177 32
	!=
	dup
	bz *skip_and3
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 40 32
	acct_params_get AcctBalance
	pop
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 40 32
	acct_params_get AcctMinBalance
	pop
	-
	int 2_100_000
	<
	&&

*skip_and3:
	bz *if31_end

	// *if31_consequent
	// examples/reti/stakingPool.algo.ts:683
	// managerTopOff = validatorCommissionPaidOut < 2_100_000 ? validatorCommissionPaidOut : 2_100_000
	frame_dig 16 // validatorCommissionPaidOut: uint64
	int 2_100_000
	<
	bz *ternary1_false
	frame_dig 16 // validatorCommissionPaidOut: uint64
	b *ternary1_end

*ternary1_false:
	int 2_100_000

*ternary1_end:
	frame_bury 21 // managerTopOff: uint64

	// examples/reti/stakingPool.algo.ts:684
	// sendPayment({
	//             amount: managerTopOff,
	//             receiver: validatorConfig.manager,
	//             note: 'validator reward to manager for funding epoch updates',
	//           })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// examples/reti/stakingPool.algo.ts:685
	// amount: managerTopOff
	frame_dig 21 // managerTopOff: uint64
	itxn_field Amount

	// examples/reti/stakingPool.algo.ts:686
	// receiver: validatorConfig.manager
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 40 32
	itxn_field Receiver

	// examples/reti/stakingPool.algo.ts:687
	// note: 'validator reward to manager for funding epoch updates'
	pushbytes 0x76616c696461746f722072657761726420746f206d616e6167657220666f722066756e64696e672065706f63682075706461746573 // "validator reward to manager for funding epoch updates"
	itxn_field Note

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

*if31_end:
	// *if32_condition
	// examples/reti/stakingPool.algo.ts:690
	// validatorCommissionPaidOut - managerTopOff > 0
	frame_dig 16 // validatorCommissionPaidOut: uint64
	frame_dig 21 // managerTopOff: uint64
	-
	int 0
	>
	bz *if32_end

	// *if32_consequent
	// examples/reti/stakingPool.algo.ts:691
	// sendPayment({
	//             amount: validatorCommissionPaidOut - managerTopOff,
	//             receiver: validatorConfig.validatorCommissionAddress,
	//             note: 'validator reward',
	//           })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// examples/reti/stakingPool.algo.ts:692
	// amount: validatorCommissionPaidOut - managerTopOff
	frame_dig 16 // validatorCommissionPaidOut: uint64
	frame_dig 21 // managerTopOff: uint64
	-
	itxn_field Amount

	// examples/reti/stakingPool.algo.ts:693
	// receiver: validatorConfig.validatorCommissionAddress
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 177 32
	itxn_field Receiver

	// examples/reti/stakingPool.algo.ts:694
	// note: 'validator reward'
	pushbytes 0x76616c696461746f7220726577617264 // "validator reward"
	itxn_field Note

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

*if32_end:

*if30_end:

*if29_end:
	// examples/reti/stakingPool.algo.ts:706
	// increasedStake = 0
	int 0
	frame_bury 22 // increasedStake: uint64

	// *if33_condition
	// examples/reti/stakingPool.algo.ts:730
	// algoRewardAvail !== 0 || tokenRewardAvail !== 0
	frame_dig 11 // algoRewardAvail: uint64
	int 0
	!=
	dup
	bnz *skip_or1
	frame_dig 14 // tokenRewardAvail: uint64
	int 0
	!=
	||

*skip_or1:
	bz *if33_end

	// *if33_consequent
	// examples/reti/stakingPool.algo.ts:731
	// partialStakersTotalStake: uint64 = 0
	int 0
	frame_bury 23 // partialStakersTotalStake: uint64

	// examples/reti/stakingPool.algo.ts:732
	// for (let i = 0; i < this.stakers.value.length; i += 1)
	int 0
	frame_bury 24 // i: uint64

*for_4:
	// examples/reti/stakingPool.algo.ts:732
	// i < this.stakers.value.length
	frame_dig 24 // i: uint64
	int 200
	<
	bz *for_4_end

	// *if34_condition
	// examples/reti/stakingPool.algo.ts:733
	// globals.opcodeBudget < 400
	global OpcodeBudget
	pushint 400
	<
	bz *if34_end

	// *if34_consequent
	// examples/reti/stakingPool.algo.ts:734
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	pushint 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

*if34_end:
	// examples/reti/stakingPool.algo.ts:736
	// cmpStaker = clone(this.stakers.value[i])
	frame_dig 24 // i: uint64
	int 64
	* // acc * typeLength
	int 64
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_extract
	frame_bury 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// *if35_condition
	// examples/reti/stakingPool.algo.ts:737
	// cmpStaker.account !== globals.zeroAddress
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 0 32
	global ZeroAddress
	!=
	bz *if35_end

	// *if35_consequent
	// *if36_condition
	// examples/reti/stakingPool.algo.ts:738
	// cmpStaker.entryRound >= thisEpochBegin
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 56 8
	btoi
	frame_dig 3 // thisEpochBegin: uint64
	>=
	bz *if36_else

	// *if36_consequent
	// examples/reti/stakingPool.algo.ts:741
	// partialStakersTotalStake += cmpStaker.balance
	frame_dig 23 // partialStakersTotalStake: uint64
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	+
	frame_bury 23 // partialStakersTotalStake: uint64
	b *if36_end

*if36_else:
	// examples/reti/stakingPool.algo.ts:745
	// timeInPool = thisEpochBegin - cmpStaker.entryRound
	frame_dig 3 // thisEpochBegin: uint64
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 56 8
	btoi
	-
	frame_bury 26 // timeInPool: uint64

	// *if37_condition
	// examples/reti/stakingPool.algo.ts:749
	// timeInPool < epochRoundLength
	frame_dig 26 // timeInPool: uint64
	frame_dig 1 // epochRoundLength: uint64
	<
	bz *if37_end

	// *if37_consequent
	// examples/reti/stakingPool.algo.ts:750
	// partialStakersTotalStake += cmpStaker.balance
	frame_dig 23 // partialStakersTotalStake: uint64
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	+
	frame_bury 23 // partialStakersTotalStake: uint64

	// examples/reti/stakingPool.algo.ts:751
	// timePercentage = (timeInPool * 1000) / epochRoundLength
	frame_dig 26 // timeInPool: uint64
	int 1000
	*
	frame_dig 1 // epochRoundLength: uint64
	/
	frame_bury 27 // timePercentage: uint64

	// *if38_condition
	// examples/reti/stakingPool.algo.ts:753
	// tokenRewardAvail > 0
	frame_dig 14 // tokenRewardAvail: uint64
	int 0
	>
	bz *if38_end

	// *if38_consequent
	// examples/reti/stakingPool.algo.ts:755
	// stakerTokenReward = wideRatio(
	//                   [cmpStaker.balance, tokenRewardAvail, timePercentage],
	//                   [this.totalAlgoStaked.value, 1000]
	//                 )
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	frame_dig 14 // tokenRewardAvail: uint64
	mulw
	frame_dig 27 // timePercentage: uint64
	uncover 2
	dig 1
	*
	cover 2
	mulw
	cover 2
	+
	swap
	byte 0x7374616b6564 // "staked"
	app_global_get
	int 1000
	mulw
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	frame_bury 28 // stakerTokenReward: uint64

	// examples/reti/stakingPool.algo.ts:762
	// tokenRewardAvail -= stakerTokenReward
	frame_dig 14 // tokenRewardAvail: uint64
	frame_dig 28 // stakerTokenReward: uint64
	-
	frame_bury 14 // tokenRewardAvail: uint64

	// examples/reti/stakingPool.algo.ts:763
	// cmpStaker.rewardTokenBalance += stakerTokenReward
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	pushint 48 // headOffset
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 48 8
	btoi
	frame_dig 28 // stakerTokenReward: uint64
	+
	itob
	replace3
	frame_bury 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:764
	// tokenRewardPaidOut += stakerTokenReward
	frame_dig 15 // tokenRewardPaidOut: uint64
	frame_dig 28 // stakerTokenReward: uint64
	+
	frame_bury 15 // tokenRewardPaidOut: uint64

*if38_end:
	// *if39_condition
	// examples/reti/stakingPool.algo.ts:766
	// algoRewardAvail > 0
	frame_dig 11 // algoRewardAvail: uint64
	int 0
	>
	bz *if39_end

	// *if39_consequent
	// examples/reti/stakingPool.algo.ts:768
	// stakerReward = wideRatio(
	//                   [cmpStaker.balance, algoRewardAvail, timePercentage],
	//                   [this.totalAlgoStaked.value, 1000]
	//                 )
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	frame_dig 11 // algoRewardAvail: uint64
	mulw
	frame_dig 27 // timePercentage: uint64
	uncover 2
	dig 1
	*
	cover 2
	mulw
	cover 2
	+
	swap
	byte 0x7374616b6564 // "staked"
	app_global_get
	int 1000
	mulw
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	frame_bury 29 // stakerReward: uint64

	// examples/reti/stakingPool.algo.ts:775
	// algoRewardAvail -= stakerReward
	frame_dig 11 // algoRewardAvail: uint64
	frame_dig 29 // stakerReward: uint64
	-
	frame_bury 11 // algoRewardAvail: uint64

	// examples/reti/stakingPool.algo.ts:778
	// cmpStaker.balance += stakerReward
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	int 32 // headOffset
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	frame_dig 29 // stakerReward: uint64
	+
	itob
	replace3
	frame_bury 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:779
	// cmpStaker.totalRewarded += stakerReward
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	pushint 40 // headOffset
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 40 8
	btoi
	frame_dig 29 // stakerReward: uint64
	+
	itob
	replace3
	frame_bury 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:780
	// increasedStake += stakerReward
	frame_dig 22 // increasedStake: uint64
	frame_dig 29 // stakerReward: uint64
	+
	frame_bury 22 // increasedStake: uint64

*if39_end:
	// examples/reti/stakingPool.algo.ts:783
	// this.stakers.value[i] = cmpStaker
	frame_dig 24 // i: uint64
	int 64
	* // acc * typeLength
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_replace

*if37_end:

*if36_end:

*if35_end:

*for_4_continue:
	// examples/reti/stakingPool.algo.ts:732
	// i += 1
	frame_dig 24 // i: uint64
	int 1
	+
	frame_bury 24 // i: uint64
	b *for_4

*for_4_end:
	// examples/reti/stakingPool.algo.ts:791
	// newPoolTotalStake = this.totalAlgoStaked.value - partialStakersTotalStake
	byte 0x7374616b6564 // "staked"
	app_global_get
	frame_dig 23 // partialStakersTotalStake: uint64
	-
	frame_bury 30 // newPoolTotalStake: uint64

	// *if40_condition
	// examples/reti/stakingPool.algo.ts:795
	// newPoolTotalStake > 0
	frame_dig 30 // newPoolTotalStake: uint64
	int 0
	>
	bz *if40_end

	// *if40_consequent
	// examples/reti/stakingPool.algo.ts:797
	// for (let i = 0; i < this.stakers.value.length; i += 1)
	int 0
	frame_bury 31 // i: uint64

*for_5:
	// examples/reti/stakingPool.algo.ts:797
	// i < this.stakers.value.length
	frame_dig 31 // i: uint64
	int 200
	<
	bz *for_5_end

	// *if41_condition
	// examples/reti/stakingPool.algo.ts:798
	// globals.opcodeBudget < 200
	global OpcodeBudget
	int 200
	<
	bz *if41_end

	// *if41_consequent
	// examples/reti/stakingPool.algo.ts:799
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	pushint 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

*if41_end:
	// examples/reti/stakingPool.algo.ts:801
	// cmpStaker = clone(this.stakers.value[i])
	frame_dig 31 // i: uint64
	int 64
	* // acc * typeLength
	int 64
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_extract
	frame_bury 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// *if42_condition
	// examples/reti/stakingPool.algo.ts:802
	// cmpStaker.account !== globals.zeroAddress && cmpStaker.entryRound < thisEpochBegin
	frame_dig 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 0 32
	global ZeroAddress
	!=
	dup
	bz *skip_and4
	frame_dig 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 56 8
	btoi
	frame_dig 3 // thisEpochBegin: uint64
	<
	&&

*skip_and4:
	bz *if42_end

	// *if42_consequent
	// examples/reti/stakingPool.algo.ts:803
	// timeInPool = thisEpochBegin - cmpStaker.entryRound
	frame_dig 3 // thisEpochBegin: uint64
	frame_dig 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 56 8
	btoi
	-
	frame_bury 33 // timeInPool: uint64

	// *if43_condition
	// examples/reti/stakingPool.algo.ts:805
	// timeInPool >= epochRoundLength
	frame_dig 33 // timeInPool: uint64
	frame_dig 1 // epochRoundLength: uint64
	>=
	bz *if43_end

	// *if43_consequent
	// *if44_condition
	// examples/reti/stakingPool.algo.ts:810
	// tokenRewardAvail > 0
	frame_dig 14 // tokenRewardAvail: uint64
	int 0
	>
	bz *if44_end

	// *if44_consequent
	// examples/reti/stakingPool.algo.ts:811
	// stakerTokenReward = wideRatio([cmpStaker.balance, tokenRewardAvail], [newPoolTotalStake])
	frame_dig 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	frame_dig 14 // tokenRewardAvail: uint64
	mulw
	int 0
	frame_dig 30 // newPoolTotalStake: uint64
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	frame_bury 34 // stakerTokenReward: uint64

	// examples/reti/stakingPool.algo.ts:814
	// cmpStaker.rewardTokenBalance += stakerTokenReward
	frame_dig 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	pushint 48 // headOffset
	frame_dig 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 48 8
	btoi
	frame_dig 34 // stakerTokenReward: uint64
	+
	itob
	replace3
	frame_bury 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:815
	// tokenRewardPaidOut += stakerTokenReward
	frame_dig 15 // tokenRewardPaidOut: uint64
	frame_dig 34 // stakerTokenReward: uint64
	+
	frame_bury 15 // tokenRewardPaidOut: uint64

*if44_end:
	// *if45_condition
	// examples/reti/stakingPool.algo.ts:817
	// algoRewardAvail > 0
	frame_dig 11 // algoRewardAvail: uint64
	int 0
	>
	bz *if45_end

	// *if45_consequent
	// examples/reti/stakingPool.algo.ts:818
	// stakerReward = wideRatio([cmpStaker.balance, algoRewardAvail], [newPoolTotalStake])
	frame_dig 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	frame_dig 11 // algoRewardAvail: uint64
	mulw
	int 0
	frame_dig 30 // newPoolTotalStake: uint64
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	frame_bury 35 // stakerReward: uint64

	// examples/reti/stakingPool.algo.ts:821
	// cmpStaker.balance += stakerReward
	frame_dig 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	int 32 // headOffset
	frame_dig 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	frame_dig 35 // stakerReward: uint64
	+
	itob
	replace3
	frame_bury 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:822
	// cmpStaker.totalRewarded += stakerReward
	frame_dig 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	pushint 40 // headOffset
	frame_dig 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 40 8
	btoi
	frame_dig 35 // stakerReward: uint64
	+
	itob
	replace3
	frame_bury 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:823
	// increasedStake += stakerReward
	frame_dig 22 // increasedStake: uint64
	frame_dig 35 // stakerReward: uint64
	+
	frame_bury 22 // increasedStake: uint64

*if45_end:
	// examples/reti/stakingPool.algo.ts:827
	// this.stakers.value[i] = cmpStaker
	frame_dig 31 // i: uint64
	int 64
	* // acc * typeLength
	frame_dig 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_replace

*if43_end:

*if42_end:

*for_5_continue:
	// examples/reti/stakingPool.algo.ts:797
	// i += 1
	frame_dig 31 // i: uint64
	int 1
	+
	frame_bury 31 // i: uint64
	b *for_5

*for_5_end:

*if40_end:

*if33_end:
	// examples/reti/stakingPool.algo.ts:837
	// roundsLeftInBin = this.binRoundStart.value + this.roundsPerDay.value - globals.round
	byte 0x62696e526f756e645374617274 // "binRoundStart"
	app_global_get
	byte 0x726f756e6473506572446179 // "roundsPerDay"
	app_global_get
	+
	global Round
	-
	frame_bury 36 // roundsLeftInBin: uint64

	// examples/reti/stakingPool.algo.ts:838
	// this.totalAlgoStaked.value += increasedStake
	byte 0x7374616b6564 // "staked"
	app_global_get
	frame_dig 22 // increasedStake: uint64
	+
	byte 0x7374616b6564 // "staked"
	swap
	app_global_put

	// examples/reti/stakingPool.algo.ts:839
	// this.stakeAccumulator.value =
	//       this.stakeAccumulator.value + (increasedStake as uint128) * (roundsLeftInBin as uint128)
	byte 0x7374616b65416363756d756c61746f72 // "stakeAccumulator"
	dup
	app_global_get
	frame_dig 22 // increasedStake: uint64
	itob
	frame_dig 36 // roundsLeftInBin: uint64
	itob
	b*
	b+
	dup
	bitlen
	int 128
	<=

	// this.stakeAccumulator.value + (increasedStake as uint128) * (roundsLeftInBin as uint128) overflowed 128 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 16
	-
	swap
	substring3
	app_global_put

	// examples/reti/stakingPool.algo.ts:841
	// this.rewardAccumulator.value = this.rewardAccumulator.value + increasedStake
	byte 0x726577617264416363756d756c61746f72 // "rewardAccumulator"
	dup
	app_global_get
	frame_dig 22 // increasedStake: uint64
	+
	app_global_put

	// examples/reti/stakingPool.algo.ts:847
	// sendMethodCall<typeof ValidatorRegistry.prototype.stakeUpdatedViaRewards>({
	//       applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//       methodArgs: [
	//         { id: this.validatorId.value, poolId: this.poolId.value, poolAppId: this.app.id },
	//         increasedStake,
	//         tokenRewardPaidOut,
	//         validatorCommissionPaidOut,
	//         excessToFeeSink,
	//       ],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	pushbytes 0x418fcefc // method "stakeUpdatedViaRewards((uint64,uint64,uint64),uint64,uint64,uint64,uint64)void"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:848
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:849
	// methodArgs: [
	//         { id: this.validatorId.value, poolId: this.poolId.value, poolAppId: this.app.id },
	//         increasedStake,
	//         tokenRewardPaidOut,
	//         validatorCommissionPaidOut,
	//         excessToFeeSink,
	//       ]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	itob
	concat
	txna Applications 0
	itob
	concat
	itxn_field ApplicationArgs
	frame_dig 22 // increasedStake: uint64
	itob
	itxn_field ApplicationArgs
	frame_dig 15 // tokenRewardPaidOut: uint64
	itob
	itxn_field ApplicationArgs
	frame_dig 16 // validatorCommissionPaidOut: uint64
	itob
	itxn_field ApplicationArgs
	frame_dig 17 // excessToFeeSink: uint64
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// goOnline(pay,byte[],byte[],byte[],uint64,uint64,uint64)void
*abi_route_goOnline:
	// voteKeyDilution: uint64
	txna ApplicationArgs 6
	btoi

	// voteLast: uint64
	txna ApplicationArgs 5
	btoi

	// voteFirst: uint64
	txna ApplicationArgs 4
	btoi

	// stateProofPK: byte[]
	txna ApplicationArgs 3
	extract 2 0

	// selectionPK: byte[]
	txna ApplicationArgs 2
	extract 2 0

	// votePK: byte[]
	txna ApplicationArgs 1
	extract 2 0

	// feePayment: pay
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// argument 6 (feePayment) for goOnline must be a pay transaction
	assert

	// execute goOnline(pay,byte[],byte[],byte[],uint64,uint64,uint64)void
	callsub goOnline
	int 1
	return

// goOnline(feePayment: PayTxn, votePK: bytes, selectionPK: bytes, stateProofPK: bytes, voteFirst: uint64, voteLast: uint64, voteKeyDilution: uint64): void
//
// Registers a staking pool key online against a participation key.
// [ ONLY OWNER OR MANAGER CAN CALL ]
//
// @param {PayTxn} feePayment - payment to cover extra fee of going online if offline - or 0 if not renewal
// @param {bytes} votePK - The vote public key.
// @param {bytes} selectionPK - The selection public key.
// @param {bytes} stateProofPK - The state proof public key.
// @param {uint64} voteFirst - The first vote index.
// @param {uint64} voteLast - The last vote index.
// @param {uint64} voteKeyDilution - The vote key dilution value.
// @throws {Error} Will throw an error if the caller is not the owner or a manager.
goOnline:
	proto 7 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/reti/stakingPool.algo.ts:881
	// assert(this.isOwnerOrManagerCaller(), 'can only be called by owner or manager of validator')
	callsub isOwnerOrManagerCaller

	// can only be called by owner or manager of validator
	assert

	// examples/reti/stakingPool.algo.ts:882
	// extraFee = this.getGoOnlineFee()
	callsub getGoOnlineFee
	frame_bury 0 // extraFee: uint64

	// examples/reti/stakingPool.algo.ts:883
	// verifyPayTxn(feePayment, { receiver: this.app.address, amount: extraFee })
	// verify receiver
	frame_dig -1 // feePayment: PayTxn
	gtxns Receiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"feePayment","field":"receiver","expected":"this.app.address"}
	assert

	// verify amount
	frame_dig -1 // feePayment: PayTxn
	gtxns Amount
	frame_dig 0 // extraFee: uint64
	==

	// transaction verification failed: {"txn":"feePayment","field":"amount","expected":"extraFee"}
	assert

	// examples/reti/stakingPool.algo.ts:884
	// sendOnlineKeyRegistration({
	//       votePK: votePK,
	//       selectionPK: selectionPK,
	//       stateProofPK: stateProofPK,
	//       voteFirst: voteFirst,
	//       voteLast: voteLast,
	//       voteKeyDilution: voteKeyDilution,
	//       fee: this.getGoOnlineFee(),
	//     })
	itxn_begin
	pushint 2 // keyreg
	itxn_field TypeEnum

	// examples/reti/stakingPool.algo.ts:885
	// votePK: votePK
	frame_dig -2 // votePK: bytes
	itxn_field VotePK

	// examples/reti/stakingPool.algo.ts:886
	// selectionPK: selectionPK
	frame_dig -3 // selectionPK: bytes
	itxn_field SelectionPK

	// examples/reti/stakingPool.algo.ts:887
	// stateProofPK: stateProofPK
	frame_dig -4 // stateProofPK: bytes
	itxn_field StateProofPK

	// examples/reti/stakingPool.algo.ts:888
	// voteFirst: voteFirst
	frame_dig -5 // voteFirst: uint64
	itxn_field VoteFirst

	// examples/reti/stakingPool.algo.ts:889
	// voteLast: voteLast
	frame_dig -6 // voteLast: uint64
	itxn_field VoteLast

	// examples/reti/stakingPool.algo.ts:890
	// voteKeyDilution: voteKeyDilution
	frame_dig -7 // voteKeyDilution: uint64
	itxn_field VoteKeyDilution

	// examples/reti/stakingPool.algo.ts:891
	// fee: this.getGoOnlineFee()
	callsub getGoOnlineFee
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// goOffline()void
*abi_route_goOffline:
	// execute goOffline()void
	callsub goOffline
	int 1
	return

// goOffline(): void
//
// Marks a staking pool key OFFLINE.
// [ ONLY OWNER OR MANAGER CAN CALL ]
goOffline:
	proto 0 0

	// *if46_condition
	// examples/reti/stakingPool.algo.ts:903
	// this.txn.sender !== AppID.fromUint64(this.creatingValidatorContractAppId.value).address
	txn Sender
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	app_params_get AppAddress
	pop
	!=
	bz *if46_end

	// *if46_consequent
	// examples/reti/stakingPool.algo.ts:904
	// assert(this.isOwnerOrManagerCaller(), 'can only be called by owner or manager of validator')
	callsub isOwnerOrManagerCaller

	// can only be called by owner or manager of validator
	assert

*if46_end:
	// examples/reti/stakingPool.algo.ts:907
	// sendOfflineKeyRegistration({})
	itxn_begin
	pushint 2 // keyreg
	itxn_field TypeEnum

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// linkToNFD(uint64,string)void
*abi_route_linkToNFD:
	// nfdName: string
	txna ApplicationArgs 2
	extract 2 0

	// nfdAppId: uint64
	txna ApplicationArgs 1
	btoi

	// execute linkToNFD(uint64,string)void
	callsub linkToNFD
	int 1
	return

// linkToNFD(nfdAppId: uint64, nfdName: string): void
linkToNFD:
	proto 2 0

	// examples/reti/stakingPool.algo.ts:914
	// assert(this.isOwnerOrManagerCaller(), 'can only be called by owner or manager of validator')
	callsub isOwnerOrManagerCaller

	// can only be called by owner or manager of validator
	assert

	// examples/reti/stakingPool.algo.ts:916
	// sendAppCall({
	//       applicationID: AppID.fromUint64(this.nfdRegistryAppId),
	//       applicationArgs: ['verify_nfd_addr', nfdName, itob(nfdAppId), rawBytes(this.app.address)],
	//       applications: [AppID.fromUint64(nfdAppId)],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum

	// examples/reti/stakingPool.algo.ts:917
	// applicationID: AppID.fromUint64(this.nfdRegistryAppId)
	intc 0 // TMPL_nfdRegistryAppId
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:918
	// applicationArgs: ['verify_nfd_addr', nfdName, itob(nfdAppId), rawBytes(this.app.address)]
	pushbytes 0x7665726966795f6e66645f61646472 // "verify_nfd_addr"
	itxn_field ApplicationArgs
	frame_dig -2 // nfdName: string
	itxn_field ApplicationArgs
	frame_dig -1 // nfdAppId: uint64
	itob
	itxn_field ApplicationArgs
	global CurrentApplicationAddress
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:919
	// applications: [AppID.fromUint64(nfdAppId)]
	frame_dig -1 // nfdAppId: uint64
	itxn_field Applications

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// proxiedSetTokenPayoutRatio((uint64,uint64,uint64))(uint64[24],uint64)
*abi_route_proxiedSetTokenPayoutRatio:
	// The ABI return prefix
	byte 0x151f7c75

	// poolKey: (uint64,uint64,uint64)
	txna ApplicationArgs 1
	dup
	len
	pushint 24
	==

	// argument 0 (poolKey) for proxiedSetTokenPayoutRatio must be a (uint64,uint64,uint64)
	assert

	// execute proxiedSetTokenPayoutRatio((uint64,uint64,uint64))(uint64[24],uint64)
	callsub proxiedSetTokenPayoutRatio
	concat
	log
	int 1
	return

// proxiedSetTokenPayoutRatio(poolKey: ValidatorPoolKey): PoolTokenPayoutRatio
//
// proxiedSetTokenPayoutRatio is meant to be called by pools != 1 - calling US, pool #1
// We need to verify that we are in fact being called by another of OUR pools (not us)
// and then we'll call the validator on their behalf to update the token payouts
// @param poolKey - ValidatorPoolKey tuple
proxiedSetTokenPayoutRatio:
	proto 1 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/reti/stakingPool.algo.ts:930
	// assert(this.validatorId.value === poolKey.id, 'caller must be part of same validator set!')
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	==

	// caller must be part of same validator set!
	assert

	// examples/reti/stakingPool.algo.ts:931
	// assert(this.poolId.value === 1, 'callee must be pool 1')
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	int 1
	==

	// callee must be pool 1
	assert

	// examples/reti/stakingPool.algo.ts:932
	// assert(poolKey.poolId !== 1, 'caller must NOT be pool 1')
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	!=

	// caller must NOT be pool 1
	assert

	// examples/reti/stakingPool.algo.ts:934
	// callerPoolAppID = sendMethodCall<typeof ValidatorRegistry.prototype.getPoolAppId>({
	//       applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//       methodArgs: [poolKey.id, poolKey.poolId],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0x572767d1 // method "getPoolAppId(uint64,uint64)uint64"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:935
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:936
	// methodArgs: [poolKey.id, poolKey.poolId]
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	itxn_field ApplicationArgs
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0
	btoi
	frame_bury 0 // callerPoolAppID: uint64

	// examples/reti/stakingPool.algo.ts:938
	// assert(callerPoolAppID === poolKey.poolAppId)
	frame_dig 0 // callerPoolAppID: uint64
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 16 8
	btoi
	==
	assert

	// examples/reti/stakingPool.algo.ts:939
	// assert(this.txn.sender === AppID.fromUint64(poolKey.poolAppId).address)
	txn Sender
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 16 8
	btoi
	app_params_get AppAddress
	pop
	==
	assert

	// examples/reti/stakingPool.algo.ts:941
	// return sendMethodCall<typeof ValidatorRegistry.prototype.setTokenPayoutRatio>({
	//       applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//       methodArgs: [this.validatorId.value],
	//     });
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0x4df8d86e // method "setTokenPayoutRatio(uint64)(uint64[24],uint64)"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:942
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:943
	// methodArgs: [this.validatorId.value]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0

	// set the subroutine return value
	frame_bury 0
	retsub

// isOwnerOrManagerCaller(): boolean
isOwnerOrManagerCaller:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/reti/stakingPool.algo.ts:948
	// OwnerAndManager = sendMethodCall<typeof ValidatorRegistry.prototype.getValidatorOwnerAndManager>({
	//       applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//       methodArgs: [this.validatorId.value],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	pushbytes 0x2fa22c4b // method "getValidatorOwnerAndManager(uint64)(address,address)"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:949
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:950
	// methodArgs: [this.validatorId.value]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0
	frame_bury 0 // OwnerAndManager: (address,address)

	// examples/reti/stakingPool.algo.ts:952
	// return this.txn.sender === OwnerAndManager[0] || this.txn.sender === OwnerAndManager[1];
	txn Sender
	frame_dig 0 // OwnerAndManager: (address,address)
	extract 0 32
	==
	dup
	bnz *skip_or2
	txn Sender
	frame_dig 0 // OwnerAndManager: (address,address)
	extract 32 32
	==
	||

*skip_or2:
	// set the subroutine return value
	frame_bury 0
	retsub

// getFeeSink(): Address
getFeeSink:
	proto 0 1

	// examples/reti/stakingPool.algo.ts:956
	// return this.feeSinkAddr;
	bytec 0 // TMPL_feeSinkAddr
	retsub

// algoSaturationLevel(): uint64
//
// Returns the maximum allowed stake per validator based on a percentage of all current online stake before
// the validator is considered saturated - where rewards are diminished.
algoSaturationLevel:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/reti/stakingPool.algo.ts:966
	// online = this.getCurrentOnlineStake()
	callsub getCurrentOnlineStake
	frame_bury 0 // online: uint64

	// examples/reti/stakingPool.algo.ts:968
	// return wideRatio([online, MAX_VALIDATOR_SOFT_PCT_OF_ONLINE_1DECIMAL], [1000]);
	frame_dig 0 // online: uint64
	pushint 100
	mulw
	int 0
	int 1000
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert

	// set the subroutine return value
	frame_bury 0
	retsub

// getGoOnlineFee(): uint64
getGoOnlineFee:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/reti/stakingPool.algo.ts:975
	// isOnline = false
	int 0
	frame_bury 0 // isOnline: bool

	// *if47_condition
	// examples/reti/stakingPool.algo.ts:976
	// !isOnline
	frame_dig 0 // isOnline: bool
	!
	bz *if47_end

	// *if47_consequent
	// examples/reti/stakingPool.algo.ts:978
	// return 2_000_000;
	pushint 2_000_000
	b *getGoOnlineFee*return

*if47_end:
	// examples/reti/stakingPool.algo.ts:980
	// return 0;
	int 0

*getGoOnlineFee*return:
	// set the subroutine return value
	frame_bury 0
	retsub

// getCurrentOnlineStake(): uint64
getCurrentOnlineStake:
	proto 0 1

	// examples/reti/stakingPool.algo.ts:985
	// return 2_000_000_000_000_000;
	pushint 2_000_000_000_000_000
	retsub

// checkIfBinClosed(): void
//
// Checks if the current round is in a 'new calculation bin' (approximately daily)
checkIfBinClosed:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 4

	// examples/reti/stakingPool.algo.ts:992
	// currentBinSize = this.roundsPerDay.value as uint128
	byte 0x726f756e6473506572446179 // "roundsPerDay"
	app_global_get
	itob
	frame_bury 0 // currentBinSize: unsafe uint128

	// *if48_condition
	// examples/reti/stakingPool.algo.ts:993
	// globals.round >= this.binRoundStart.value + (currentBinSize as uint64)
	global Round
	byte 0x62696e526f756e645374617274 // "binRoundStart"
	app_global_get
	frame_dig 0 // currentBinSize: unsafe uint128
	dup
	bitlen
	int 64
	<=

	// currentBinSize as uint64 overflowed 64 bits
	assert
	pushbytes 0xFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	pushint 8
	-
	swap
	substring3
	btoi
	+
	>=
	bz *if48_end

	// *if48_consequent
	// *if49_condition
	// examples/reti/stakingPool.algo.ts:994
	// globals.opcodeBudget < 300
	global OpcodeBudget
	int 300
	<
	bz *if49_end

	// *if49_consequent
	// examples/reti/stakingPool.algo.ts:995
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	pushint 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

*if49_end:
	// examples/reti/stakingPool.algo.ts:997
	// approxRoundsPerYear: uint128 = currentBinSize * (365 as uint128)
	frame_dig 0 // currentBinSize: unsafe uint128
	pushbytes 0x0000000000000000000000000000016d
	b*
	dup
	bitlen
	int 128
	<=

	// currentBinSize * (365 as uint128) overflowed 128 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 16
	-
	swap
	substring3
	frame_bury 1 // approxRoundsPerYear: uint128

	// examples/reti/stakingPool.algo.ts:998
	// avgStake: uint128 = this.stakeAccumulator.value / currentBinSize
	byte 0x7374616b65416363756d756c61746f72 // "stakeAccumulator"
	app_global_get
	frame_dig 0 // currentBinSize: unsafe uint128
	b/
	dup
	bitlen
	int 128
	<=

	// this.stakeAccumulator.value / currentBinSize overflowed 128 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 16
	-
	swap
	substring3
	frame_bury 2 // avgStake: uint128

	// *if50_condition
	// examples/reti/stakingPool.algo.ts:999
	// avgStake !== 0
	frame_dig 2 // avgStake: uint128
	byte 0x00000000000000000000000000000000
	b!=
	bz *if50_end

	// *if50_consequent
	// examples/reti/stakingPool.algo.ts:1003
	// apr: uint128 =
	//           (((this.rewardAccumulator.value as uint128) * (10000 as uint128)) / avgStake) *
	//           (approxRoundsPerYear / currentBinSize)
	byte 0x726577617264416363756d756c61746f72 // "rewardAccumulator"
	app_global_get
	itob
	pushbytes 0x00000000000000000000000000002710
	b*
	frame_dig 2 // avgStake: uint128
	b/
	frame_dig 1 // approxRoundsPerYear: uint128
	frame_dig 0 // currentBinSize: unsafe uint128
	b/
	b*
	dup
	bitlen
	int 128
	<=

	// (((this.rewardAccumulator.value as uint128) * (10000 as uint128)) / avgStake) *\n          (approxRoundsPerYear / currentBinSize) overflowed 128 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 16
	-
	swap
	substring3
	frame_bury 3 // apr: uint128

	// examples/reti/stakingPool.algo.ts:1007
	// alpha: uint128 = 10 as uint128
	pushbytes 0x0000000000000000000000000000000a
	frame_bury 4 // alpha: unsafe uint128

	// *if51_condition
	// examples/reti/stakingPool.algo.ts:1009
	// avgStake > 300000000000
	frame_dig 2 // avgStake: uint128
	pushbytes 0x000000000000000000000045d964b800
	b>
	bz *if51_end

	// *if51_consequent
	// examples/reti/stakingPool.algo.ts:1010
	// alpha = 90 as uint128
	pushbytes 0x0000000000000000000000000000005a
	frame_bury 4 // alpha: unsafe uint128

*if51_end:
	// examples/reti/stakingPool.algo.ts:1012
	// this.weightedMovingAverage.value =
	//           (this.weightedMovingAverage.value * ((100 as uint128) - alpha)) / (100 as uint128) +
	//           (apr * alpha) / (100 as uint128)
	byte 0x65776d61 // "ewma"
	dup
	app_global_get
	byte 0x00000000000000000000000000000064
	frame_dig 4 // alpha: unsafe uint128
	b-
	b*
	byte 0x00000000000000000000000000000064
	b/
	frame_dig 3 // apr: uint128
	frame_dig 4 // alpha: unsafe uint128
	b*
	byte 0x00000000000000000000000000000064
	b/
	b+
	dup
	bitlen
	int 128
	<=

	// (this.weightedMovingAverage.value * ((100 as uint128) - alpha)) / (100 as uint128) +\n          (apr * alpha) / (100 as uint128) overflowed 128 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 16
	-
	swap
	substring3
	app_global_put

*if50_end:
	// examples/reti/stakingPool.algo.ts:1018
	// this.setRoundsPerDay()
	callsub setRoundsPerDay

	// examples/reti/stakingPool.algo.ts:1019
	// this.stakeAccumulator.value = (this.totalAlgoStaked.value as uint128) * (this.roundsPerDay.value as uint128)
	byte 0x7374616b65416363756d756c61746f72 // "stakeAccumulator"
	byte 0x7374616b6564 // "staked"
	app_global_get
	itob
	byte 0x726f756e6473506572446179 // "roundsPerDay"
	app_global_get
	itob
	b*
	dup
	bitlen
	int 128
	<=

	// (this.totalAlgoStaked.value as uint128) * (this.roundsPerDay.value as uint128) overflowed 128 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 16
	-
	swap
	substring3
	app_global_put

	// examples/reti/stakingPool.algo.ts:1020
	// this.rewardAccumulator.value = 0
	byte 0x726577617264416363756d756c61746f72 // "rewardAccumulator"
	int 0
	app_global_put

	// examples/reti/stakingPool.algo.ts:1021
	// this.binRoundStart.value = globals.round - (globals.round % this.roundsPerDay.value)
	byte 0x62696e526f756e645374617274 // "binRoundStart"
	global Round
	global Round
	byte 0x726f756e6473506572446179 // "roundsPerDay"
	app_global_get
	%
	-
	app_global_put

*if48_end:
	retsub

// setRoundsPerDay(): void
setRoundsPerDay:
	proto 0 0

	// examples/reti/stakingPool.algo.ts:1026
	// this.roundsPerDay.value = AVG_ROUNDS_PER_DAY
	byte 0x726f756e6473506572446179 // "roundsPerDay"
	pushint 30857
	app_global_put
	retsub

*create_NoOp:
	pushbytes 0x59e90aa6 // method "createApplication(uint64,uint64,uint64,uint64)void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x3172ca9d // method "gas()void"
	pushbytes 0x47cfcc04 // method "initStorage(pay)void"
	pushbytes 0xf9c70cbd // method "addStake(pay,address)uint64"
	pushbytes 0x421b5abe // method "removeStake(address,uint64)void"
	pushbytes 0xf5892d56 // method "claimTokens()void"
	pushbytes 0x5cfbb057 // method "getStakerInfo(address)(address,uint64,uint64,uint64,uint64)"
	pushbytes 0x63f3f28b // method "payTokenReward(address,uint64,uint64)void"
	pushbytes 0x86a3725c // method "updateAlgodVer(string)void"
	pushbytes 0xefc2608d // method "epochBalanceUpdate()void"
	pushbytes 0x400e14fb // method "goOnline(pay,byte[],byte[],byte[],uint64,uint64,uint64)void"
	pushbytes 0x51ef3b21 // method "goOffline()void"
	pushbytes 0xa24e2717 // method "linkToNFD(uint64,string)void"
	byte 0x0c2245e1 // method "proxiedSetTokenPayoutRatio((uint64,uint64,uint64))(uint64[24],uint64)"
	txna ApplicationArgs 0
	match *abi_route_gas *abi_route_initStorage *abi_route_addStake *abi_route_removeStake *abi_route_claimTokens *abi_route_getStakerInfo *abi_route_payTokenReward *abi_route_updateAlgodVer *abi_route_epochBalanceUpdate *abi_route_goOnline *abi_route_goOffline *abi_route_linkToNFD *abi_route_proxiedSetTokenPayoutRatio

	// this contract does not implement the given ABI method for call NoOp
	err

*call_UpdateApplication:
	pushbytes 0x46f76533 // method "updateApplication()void"
	txna ApplicationArgs 0
	match *abi_route_updateApplication

	// this contract does not implement the given ABI method for call UpdateApplication
	err", + "approval": "#pragma version 10
intcblock TMPL_nfdRegistryAppId 0 1 6 64 32 16 128 1_000_000 2_100_000 200 300 1000
bytecblock TMPL_feeSinkAddr 0x63726561746f72417070 0x76616c696461746f724964 0x7374616b65416363756d756c61746f72 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF 0x7374616b657273 0x726f756e6473506572446179 0x706f6f6c4964 0x726577617264416363756d756c61746f72 0x7374616b6564 0x62696e526f756e645374617274 0x0000000000000000 0x 0x0a8101 0x6e756d5374616b657273 0x6c6173745061796f7574 0x00000000000000000000000000000000 0x00000000000000000000000000000064 0x6d696e456e7472795374616b65 0x65706f63684e756d626572 0x75aff61d 0x65776d61 0x151f7c75 0xa2dc51b5 0x572767d1 0x4df8d86e 0x0c2245e1 0x00

// This TEAL was generated by TEALScript v0.105.0
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following lines of TEAL are used to initialize template variables in scratch slots
bytec 0 // TMPL_feeSinkAddr
intc 0 // TMPL_nfdRegistryAppId

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
int 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *call_UpdateApplication *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// updateApplication()void
*abi_route_updateApplication:
	// execute updateApplication()void
	callsub updateApplication
	int 1
	return

// updateApplication(): void
updateApplication:
	proto 0 0

	// examples/reti/stakingPool.algo.ts:94
	// assert(
	//       this.txn.sender === Address.fromAddress('LZ4V2IRVLCXFJK4REJV4TAGEKEYTA2GMR6TC2344OB3L3AF3MWXZ6ZAFIQ'),
	//       'Temporary: contract is upgradeable but only during testing and only from a development account'
	//     )
	txn Sender
	pushbytes 0x5e795d223558ae54ab91226bc980c451313068cc8fa62d6f9c7076bd80bb65af // addr "LZ4V2IRVLCXFJK4REJV4TAGEKEYTA2GMR6TC2344OB3L3AF3MWXZ6ZAFIQ"
	==

	// Temporary: contract is upgradeable but only during testing and only from a development account
	assert
	retsub

// createApplication(uint64,uint64,uint64,uint64)void
*abi_route_createApplication:
	// minEntryStake: uint64
	txna ApplicationArgs 4
	btoi

	// poolId: uint64
	txna ApplicationArgs 3
	btoi

	// validatorId: uint64
	txna ApplicationArgs 2
	btoi

	// creatingContractId: uint64
	txna ApplicationArgs 1
	btoi

	// execute createApplication(uint64,uint64,uint64,uint64)void
	callsub createApplication
	int 1
	return

// createApplication(creatingContractId: uint64, validatorId: uint64, poolId: uint64, minEntryStake: uint64): void
//
// Initialize the staking pool w/ owner and manager, but can only be created by the validator contract.
// @param {uint64} creatingContractId - id of contract that constructed us - the validator application (single global instance)
// @param {uint64} validatorId - id of validator we're a staking pool of
// @param {uint64} poolId - which pool id are we
// @param {uint64} minEntryStake - minimum amount to be in pool, but also minimum amount balance can't go below (without removing all!)
createApplication:
	proto 4 0

	// *if0_condition
	// examples/reti/stakingPool.algo.ts:108
	// creatingContractId === 0
	frame_dig -1 // creatingContractId: uint64
	int 0
	==
	bz *if0_else

	// *if0_consequent
	// examples/reti/stakingPool.algo.ts:110
	// assert(validatorId === 0)
	frame_dig -2 // validatorId: uint64
	int 0
	==
	assert

	// examples/reti/stakingPool.algo.ts:111
	// assert(poolId === 0)
	frame_dig -3 // poolId: uint64
	int 0
	==
	assert
	b *if0_end

*if0_else:
	// examples/reti/stakingPool.algo.ts:113
	// assert(validatorId !== 0)
	frame_dig -2 // validatorId: uint64
	int 0
	!=
	assert

	// examples/reti/stakingPool.algo.ts:114
	// assert(poolId !== 0)
	frame_dig -3 // poolId: uint64
	int 0
	!=
	assert

*if0_end:
	// examples/reti/stakingPool.algo.ts:116
	// assert(minEntryStake >= MIN_ALGO_STAKE_PER_POOL, 'staking pool must have minimum entry of 1 algo')
	frame_dig -4 // minEntryStake: uint64
	pushint 1000000
	>=

	// staking pool must have minimum entry of 1 algo
	assert

	// examples/reti/stakingPool.algo.ts:117
	// this.creatingValidatorContractAppId.value = creatingContractId
	byte 0x63726561746f72417070 // "creatorApp"
	frame_dig -1 // creatingContractId: uint64
	app_global_put

	// examples/reti/stakingPool.algo.ts:118
	// this.validatorId.value = validatorId
	byte 0x76616c696461746f724964 // "validatorId"
	frame_dig -2 // validatorId: uint64
	app_global_put

	// examples/reti/stakingPool.algo.ts:119
	// this.poolId.value = poolId
	byte 0x706f6f6c4964 // "poolId"
	frame_dig -3 // poolId: uint64
	app_global_put

	// examples/reti/stakingPool.algo.ts:120
	// this.numStakers.value = 0
	byte 0x6e756d5374616b657273 // "numStakers"
	int 0
	app_global_put

	// examples/reti/stakingPool.algo.ts:121
	// this.totalAlgoStaked.value = 0
	byte 0x7374616b6564 // "staked"
	int 0
	app_global_put

	// examples/reti/stakingPool.algo.ts:122
	// this.minEntryStake.value = minEntryStake
	byte 0x6d696e456e7472795374616b65 // "minEntryStake"
	frame_dig -4 // minEntryStake: uint64
	app_global_put

	// examples/reti/stakingPool.algo.ts:123
	// this.lastPayout.value = globals.round
	byte 0x6c6173745061796f7574 // "lastPayout"
	global Round
	app_global_put

	// examples/reti/stakingPool.algo.ts:124
	// this.epochNumber.value = 0
	byte 0x65706f63684e756d626572 // "epochNumber"
	int 0
	app_global_put

	// examples/reti/stakingPool.algo.ts:126
	// this.setRoundsPerDay()
	callsub setRoundsPerDay

	// examples/reti/stakingPool.algo.ts:127
	// this.binRoundStart.value = globals.round - (globals.round % this.roundsPerDay.value)
	byte 0x62696e526f756e645374617274 // "binRoundStart"
	global Round
	global Round
	byte 0x726f756e6473506572446179 // "roundsPerDay"
	app_global_get
	%
	-
	app_global_put

	// examples/reti/stakingPool.algo.ts:128
	// this.stakeAccumulator.value = 0 as uint128
	byte 0x7374616b65416363756d756c61746f72 // "stakeAccumulator"
	byte 0x00000000000000000000000000000000
	app_global_put

	// examples/reti/stakingPool.algo.ts:129
	// this.rewardAccumulator.value = 0
	byte 0x726577617264416363756d756c61746f72 // "rewardAccumulator"
	int 0
	app_global_put

	// examples/reti/stakingPool.algo.ts:130
	// this.weightedMovingAverage.value = 0 as uint128
	byte 0x65776d61 // "ewma"
	byte 0x00000000000000000000000000000000
	app_global_put
	retsub

// gas()void
*abi_route_gas:
	// execute gas()void
	callsub gas
	int 1
	return

// gas(): void
//
// gas is a dummy no-op call that can be used to pool-up resource references and opcode cost
gas:
	proto 0 0
	retsub

// costForBoxStorage(totalNumBytes: uint64): uint64
costForBoxStorage:
	proto 1 1

	// examples/reti/stakingPool.algo.ts:142
	// return SCBOX_PERBOX + totalNumBytes * SCBOX_PERBYTE;
	pushint 2500
	frame_dig -1 // totalNumBytes: uint64
	pushint 400
	*
	+
	retsub

// initStorage(pay)void
*abi_route_initStorage:
	// mbrPayment: pay
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// argument 0 (mbrPayment) for initStorage must be a pay transaction
	assert

	// execute initStorage(pay)void
	callsub initStorage
	int 1
	return

// initStorage(mbrPayment: PayTxn): void
//
// Called after we're created and then funded, so we can create our large stakers ledger storage
// Caller has to get MBR amounts from ValidatorRegistry to know how much to fund us to cover the box storage cost
// If this is pool 1 AND the validator has specified a reward token, opt-in to that token
// so that the validator can seed the pool with future rewards of that token.
// @param mbrPayment payment from caller which covers mbr increase of new staking pools' storage
initStorage:
	proto 1 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 3

	// examples/reti/stakingPool.algo.ts:153
	// assert(!this.stakers.exists, 'staking pool already initialized')
	byte 0x7374616b657273 // "stakers"
	box_len
	swap
	pop
	!

	// staking pool already initialized
	assert

	// examples/reti/stakingPool.algo.ts:156
	// validatorConfig = sendMethodCall<typeof ValidatorRegistry.prototype.getValidatorConfig>({
	//       applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//       methodArgs: [this.validatorId.value],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0x75aff61d // method "getValidatorConfig(uint64)(uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:157
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:158
	// methodArgs: [this.validatorId.value]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0
	frame_bury 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:160
	// isTokenEligible = validatorConfig.rewardTokenId !== 0
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 153 8
	btoi
	int 0
	!=
	frame_bury 1 // isTokenEligible: bool

	// examples/reti/stakingPool.algo.ts:161
	// extraMBR = isTokenEligible && this.poolId.value === 1 ? ASSET_HOLDING_FEE : 0
	frame_dig 1 // isTokenEligible: bool
	dup
	bz *skip_and0
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	int 1
	==
	&&

*skip_and0:
	bz *ternary0_false
	pushint 100000
	b *ternary0_end

*ternary0_false:
	int 0

*ternary0_end:
	frame_bury 2 // extraMBR: uint64

	// examples/reti/stakingPool.algo.ts:162
	// PoolInitMbr =
	//       ALGORAND_ACCOUNT_MIN_BALANCE +
	//       extraMBR +
	//       this.costForBoxStorage(7 /* 'stakers' name */ + len<StakedInfo>() * MAX_STAKERS_PER_POOL)
	pushint 100000
	frame_dig 2 // extraMBR: uint64
	+
	pushint 12807
	callsub costForBoxStorage
	+
	frame_bury 3 // PoolInitMbr: uint64

	// examples/reti/stakingPool.algo.ts:168
	// verifyPayTxn(mbrPayment, { receiver: this.app.address, amount: PoolInitMbr })
	// verify receiver
	frame_dig -1 // mbrPayment: PayTxn
	gtxns Receiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"mbrPayment","field":"receiver","expected":"this.app.address"}
	assert

	// verify amount
	frame_dig -1 // mbrPayment: PayTxn
	gtxns Amount
	frame_dig 3 // PoolInitMbr: uint64
	==

	// transaction verification failed: {"txn":"mbrPayment","field":"amount","expected":"PoolInitMbr"}
	assert

	// examples/reti/stakingPool.algo.ts:169
	// this.stakers.create()
	byte 0x7374616b657273 // "stakers"
	pushint 12800
	box_create
	pop

	// *if1_condition
	// examples/reti/stakingPool.algo.ts:171
	// isTokenEligible && this.poolId.value === 1
	frame_dig 1 // isTokenEligible: bool
	dup
	bz *skip_and1
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	int 1
	==
	&&

*skip_and1:
	bz *if1_end

	// *if1_consequent
	// examples/reti/stakingPool.algo.ts:173
	// sendAssetTransfer({
	//         xferAsset: AssetID.fromUint64(validatorConfig.rewardTokenId),
	//         assetReceiver: this.app.address,
	//         assetAmount: 0,
	//       })
	itxn_begin
	pushint 4 // axfer
	itxn_field TypeEnum

	// examples/reti/stakingPool.algo.ts:174
	// xferAsset: AssetID.fromUint64(validatorConfig.rewardTokenId)
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 153 8
	btoi
	itxn_field XferAsset

	// examples/reti/stakingPool.algo.ts:175
	// assetReceiver: this.app.address
	global CurrentApplicationAddress
	itxn_field AssetReceiver

	// examples/reti/stakingPool.algo.ts:176
	// assetAmount: 0
	int 0
	itxn_field AssetAmount

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

*if1_end:
	retsub

// addStake(pay,address)uint64
*abi_route_addStake:
	// The ABI return prefix
	byte 0x151f7c75

	// staker: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (staker) for addStake must be a address
	assert

	// stakedAmountPayment: pay
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// argument 1 (stakedAmountPayment) for addStake must be a pay transaction
	assert

	// execute addStake(pay,address)uint64
	callsub addStake
	itob
	concat
	log
	int 1
	return

// addStake(stakedAmountPayment: PayTxn, staker: Address): uint64
//
// Adds stake to the given account.
// Can ONLY be called by the validator contract that created us
// Must receive payment from the validator contract for amount being staked.
//
// @param {PayTxn} stakedAmountPayment prior payment coming from validator contract to us on behalf of staker.
// @param {Address} staker - The account adding new stake
// @throws {Error} - Throws an error if the staking pool is full.
// @returns {uint64} new 'entry round' round number of stake add
addStake:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 4

	// examples/reti/stakingPool.algo.ts:192
	// assert(this.stakers.exists, 'staking pool must be initialized first')
	byte 0x7374616b657273 // "stakers"
	box_len
	swap
	pop

	// staking pool must be initialized first
	assert

	// examples/reti/stakingPool.algo.ts:195
	// assert(
	//       this.txn.sender === AppID.fromUint64(this.creatingValidatorContractAppId.value).address,
	//       'stake can only be added via the validator contract'
	//     )
	txn Sender
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	app_params_get AppAddress
	pop
	==

	// stake can only be added via the validator contract
	assert

	// examples/reti/stakingPool.algo.ts:199
	// assert(staker !== globals.zeroAddress)
	frame_dig -2 // staker: Address
	global ZeroAddress
	!=
	assert

	// examples/reti/stakingPool.algo.ts:202
	// this.checkIfBinClosed()
	callsub checkIfBinClosed

	// examples/reti/stakingPool.algo.ts:206
	// verifyPayTxn(stakedAmountPayment, {
	//       sender: AppID.fromUint64(this.creatingValidatorContractAppId.value).address,
	//       receiver: this.app.address,
	//       amount: stakedAmountPayment.amount,
	//     })
	// verify sender
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Sender
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	app_params_get AppAddress
	pop
	==

	// transaction verification failed: {"txn":"stakedAmountPayment","field":"sender","expected":"AppID.fromUint64(this.creatingValidatorContractAppId.value).address"}
	assert

	// verify receiver
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Receiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"stakedAmountPayment","field":"receiver","expected":"this.app.address"}
	assert

	// verify amount
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Amount
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Amount
	==

	// transaction verification failed: {"txn":"stakedAmountPayment","field":"amount","expected":"stakedAmountPayment.amount"}
	assert

	// examples/reti/stakingPool.algo.ts:215
	// entryRound = globals.round + ALGORAND_STAKING_BLOCK_DELAY
	global Round
	pushint 320
	+
	frame_bury 0 // entryRound: uint64

	// examples/reti/stakingPool.algo.ts:216
	// firstEmpty = 0
	int 0
	frame_bury 1 // firstEmpty: uint64

	// examples/reti/stakingPool.algo.ts:218
	// this.totalAlgoStaked.value += stakedAmountPayment.amount
	byte 0x7374616b6564 // "staked"
	app_global_get
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Amount
	+
	byte 0x7374616b6564 // "staked"
	swap
	app_global_put

	// examples/reti/stakingPool.algo.ts:220
	// roundsLeftInBin = this.binRoundStart.value + this.roundsPerDay.value - globals.round
	byte 0x62696e526f756e645374617274 // "binRoundStart"
	app_global_get
	byte 0x726f756e6473506572446179 // "roundsPerDay"
	app_global_get
	+
	global Round
	-
	frame_bury 2 // roundsLeftInBin: uint64

	// examples/reti/stakingPool.algo.ts:221
	// this.stakeAccumulator.value =
	//       this.stakeAccumulator.value + (stakedAmountPayment.amount as uint128) * (roundsLeftInBin as uint128)
	byte 0x7374616b65416363756d756c61746f72 // "stakeAccumulator"
	dup
	app_global_get
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Amount
	itob
	frame_dig 2 // roundsLeftInBin: uint64
	itob
	b*
	b+
	dup
	bitlen
	int 128
	<=

	// this.stakeAccumulator.value + (stakedAmountPayment.amount as uint128) * (roundsLeftInBin as uint128) overflowed 128 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 16
	-
	swap
	substring3
	app_global_put

	// examples/reti/stakingPool.algo.ts:225
	// for (let i = 0; i < this.stakers.value.length; i += 1)
	int 0
	frame_bury 3 // i: uint64

*for_0:
	// examples/reti/stakingPool.algo.ts:225
	// i < this.stakers.value.length
	frame_dig 3 // i: uint64
	int 200
	<
	bz *for_0_end

	// *if2_condition
	// examples/reti/stakingPool.algo.ts:226
	// globals.opcodeBudget < 300
	global OpcodeBudget
	int 300
	<
	bz *if2_end

	// *if2_consequent
	// examples/reti/stakingPool.algo.ts:227
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	pushint 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

*if2_end:
	// examples/reti/stakingPool.algo.ts:229
	// cmpStaker = clone(this.stakers.value[i])
	frame_dig 3 // i: uint64
	int 64
	* // acc * typeLength
	int 64
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_extract
	frame_bury 4 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// *if3_condition
	// examples/reti/stakingPool.algo.ts:230
	// cmpStaker.account === staker
	frame_dig 4 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 0 32
	frame_dig -2 // staker: Address
	==
	bz *if3_end

	// *if3_consequent
	// examples/reti/stakingPool.algo.ts:232
	// cmpStaker.balance += stakedAmountPayment.amount
	frame_dig 4 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	int 32 // headOffset
	frame_dig 4 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Amount
	+
	itob
	replace3
	frame_bury 4 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:233
	// cmpStaker.entryRound = entryRound
	frame_dig 4 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	pushint 56 // headOffset
	frame_dig 0 // entryRound: uint64
	itob
	replace3
	frame_bury 4 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:236
	// this.stakers.value[i] = cmpStaker
	frame_dig 3 // i: uint64
	int 64
	* // acc * typeLength
	frame_dig 4 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_replace

	// examples/reti/stakingPool.algo.ts:238
	// return entryRound;
	frame_dig 0 // entryRound: uint64
	b *addStake*return

*if3_end:
	// *if4_condition
	// examples/reti/stakingPool.algo.ts:240
	// firstEmpty === 0 && cmpStaker.account === globals.zeroAddress
	frame_dig 1 // firstEmpty: uint64
	int 0
	==
	dup
	bz *skip_and2
	frame_dig 4 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 0 32
	global ZeroAddress
	==
	&&

*skip_and2:
	bz *if4_end

	// *if4_consequent
	// examples/reti/stakingPool.algo.ts:241
	// firstEmpty = i + 1
	frame_dig 3 // i: uint64
	int 1
	+
	frame_bury 1 // firstEmpty: uint64

*if4_end:

*for_0_continue:
	// examples/reti/stakingPool.algo.ts:225
	// i += 1
	frame_dig 3 // i: uint64
	int 1
	+
	frame_bury 3 // i: uint64
	b *for_0

*for_0_end:
	// *if5_condition
	// examples/reti/stakingPool.algo.ts:245
	// firstEmpty === 0
	frame_dig 1 // firstEmpty: uint64
	int 0
	==
	bz *if5_end

	// *if5_consequent
	// Staking pool full
	err

*if5_end:
	// examples/reti/stakingPool.algo.ts:252
	// assert(stakedAmountPayment.amount >= this.minEntryStake.value, 'must stake at least the minimum for this pool')
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Amount
	byte 0x6d696e456e7472795374616b65 // "minEntryStake"
	app_global_get
	>=

	// must stake at least the minimum for this pool
	assert

	// examples/reti/stakingPool.algo.ts:254
	// assert(this.stakers.value[firstEmpty - 1].account === globals.zeroAddress)
	frame_dig 1 // firstEmpty: uint64
	int 1
	-
	int 64
	* // acc * typeLength
	int 0
	+
	int 32
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_extract
	global ZeroAddress
	==
	assert

	// examples/reti/stakingPool.algo.ts:255
	// this.stakers.value[firstEmpty - 1] = {
	//       account: staker,
	//       balance: stakedAmountPayment.amount,
	//       totalRewarded: 0,
	//       rewardTokenBalance: 0,
	//       entryRound: entryRound,
	//     }
	frame_dig 1 // firstEmpty: uint64
	int 1
	-
	int 64
	* // acc * typeLength
	frame_dig -2 // staker: Address
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Amount
	itob
	concat
	byte 0x0000000000000000
	concat
	byte 0x0000000000000000
	concat
	frame_dig 0 // entryRound: uint64
	itob
	concat
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_replace

	// examples/reti/stakingPool.algo.ts:262
	// this.numStakers.value += 1
	byte 0x6e756d5374616b657273 // "numStakers"
	app_global_get
	int 1
	+
	byte 0x6e756d5374616b657273 // "numStakers"
	swap
	app_global_put

	// examples/reti/stakingPool.algo.ts:263
	// return entryRound;
	frame_dig 0 // entryRound: uint64

*addStake*return:
	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 4
	retsub

// removeStake(address,uint64)void
*abi_route_removeStake:
	// amountToUnstake: uint64
	txna ApplicationArgs 2
	btoi

	// staker: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (staker) for removeStake must be a address
	assert

	// execute removeStake(address,uint64)void
	callsub removeStake
	int 1
	return

// removeStake(staker: Address, amountToUnstake: uint64): void
//
// Removes stake on behalf of caller (removing own stake).  If any token rewards exist, those are always sent in
// full. Also notifies the validator contract for this pools validator of the staker / balance changes.
//
// @param {Address} staker - account to remove.  normally same as sender, but the validator owner or manager can also call
// this to remove the specified staker explicitly. The removed stake MUST only go to the staker of course.  This is
// so a validator can shut down a poool and refund the stakers.  It can also be used to kick out stakers who no longer
// meet the gating requirements (determined by the node daemon).
// @param {uint64} amountToUnstake - The amount of stake to be removed.  Specify 0 to remove all stake.
// @throws {Error} If the account has insufficient balance or if the account is not found.
removeStake:
	proto 2 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 6

	// *if6_condition
	// examples/reti/stakingPool.algo.ts:280
	// staker !== this.txn.sender
	frame_dig -1 // staker: Address
	txn Sender
	!=
	bz *if6_end

	// *if6_consequent
	// examples/reti/stakingPool.algo.ts:281
	// assert(
	//         this.isOwnerOrManagerCaller(),
	//         'If staker is not sender in removeStake call, then sender MUST be owner or manager of validator'
	//       )
	callsub isOwnerOrManagerCaller

	// If staker is not sender in removeStake call, then sender MUST be owner or manager of validator
	assert

*if6_end:
	// examples/reti/stakingPool.algo.ts:287
	// this.checkIfBinClosed()
	callsub checkIfBinClosed

	// examples/reti/stakingPool.algo.ts:289
	// for (let i = 0; i < this.stakers.value.length; i += 1)
	int 0
	frame_bury 0 // i: uint64

*for_1:
	// examples/reti/stakingPool.algo.ts:289
	// i < this.stakers.value.length
	frame_dig 0 // i: uint64
	int 200
	<
	bz *for_1_end

	// *if7_condition
	// examples/reti/stakingPool.algo.ts:290
	// globals.opcodeBudget < 300
	global OpcodeBudget
	int 300
	<
	bz *if7_end

	// *if7_consequent
	// examples/reti/stakingPool.algo.ts:291
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	pushint 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

*if7_end:
	// examples/reti/stakingPool.algo.ts:293
	// cmpStaker = clone(this.stakers.value[i])
	frame_dig 0 // i: uint64
	int 64
	* // acc * typeLength
	int 64
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_extract
	frame_bury 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// *if8_condition
	// examples/reti/stakingPool.algo.ts:294
	// cmpStaker.account === staker
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 0 32
	frame_dig -1 // staker: Address
	==
	bz *if8_end

	// *if8_consequent
	// *if9_condition
	// examples/reti/stakingPool.algo.ts:295
	// amountToUnstake === 0
	frame_dig -2 // amountToUnstake: uint64
	int 0
	==
	bz *if9_end

	// *if9_consequent
	// examples/reti/stakingPool.algo.ts:297
	// amountToUnstake = cmpStaker.balance
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	frame_bury -2 // amountToUnstake: uint64

*if9_end:
	// *if10_condition
	// examples/reti/stakingPool.algo.ts:299
	// cmpStaker.balance < amountToUnstake
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	frame_dig -2 // amountToUnstake: uint64
	<
	bz *if10_end

	// *if10_consequent
	// Insufficient balance
	err

*if10_end:
	// examples/reti/stakingPool.algo.ts:302
	// cmpStaker.balance -= amountToUnstake
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	int 32 // headOffset
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	frame_dig -2 // amountToUnstake: uint64
	-
	itob
	replace3
	frame_bury 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:303
	// this.totalAlgoStaked.value -= amountToUnstake
	byte 0x7374616b6564 // "staked"
	app_global_get
	frame_dig -2 // amountToUnstake: uint64
	-
	byte 0x7374616b6564 // "staked"
	swap
	app_global_put

	// examples/reti/stakingPool.algo.ts:305
	// amountRewardTokenRemoved = 0
	int 0
	frame_bury 2 // amountRewardTokenRemoved: uint64

	// *if11_condition
	// examples/reti/stakingPool.algo.ts:306
	// cmpStaker.rewardTokenBalance > 0
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 48 8
	btoi
	int 0
	>
	bz *if11_end

	// *if11_consequent
	// *if12_condition
	// examples/reti/stakingPool.algo.ts:308
	// this.poolId.value === 1
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	int 1
	==
	bz *if12_else

	// *if12_consequent
	// examples/reti/stakingPool.algo.ts:309
	// validatorConfig = sendMethodCall<typeof ValidatorRegistry.prototype.getValidatorConfig>({
	//               applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//               methodArgs: [this.validatorId.value],
	//             })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0x75aff61d // method "getValidatorConfig(uint64)(uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:310
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:311
	// methodArgs: [this.validatorId.value]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0
	frame_bury 3 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:317
	// sendAssetTransfer({
	//               xferAsset: AssetID.fromUint64(validatorConfig.rewardTokenId),
	//               assetReceiver: staker,
	//               assetAmount: cmpStaker.rewardTokenBalance,
	//             })
	itxn_begin
	pushint 4 // axfer
	itxn_field TypeEnum

	// examples/reti/stakingPool.algo.ts:318
	// xferAsset: AssetID.fromUint64(validatorConfig.rewardTokenId)
	frame_dig 3 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 153 8
	btoi
	itxn_field XferAsset

	// examples/reti/stakingPool.algo.ts:319
	// assetReceiver: staker
	frame_dig -1 // staker: Address
	itxn_field AssetReceiver

	// examples/reti/stakingPool.algo.ts:320
	// assetAmount: cmpStaker.rewardTokenBalance
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 48 8
	btoi
	itxn_field AssetAmount

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/stakingPool.algo.ts:322
	// amountRewardTokenRemoved = cmpStaker.rewardTokenBalance
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 48 8
	btoi
	frame_bury 2 // amountRewardTokenRemoved: uint64

	// examples/reti/stakingPool.algo.ts:323
	// cmpStaker.rewardTokenBalance = 0
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	byte 0x0000000000000000
	replace2 48
	frame_bury 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	b *if12_end

*if12_else:
	// examples/reti/stakingPool.algo.ts:328
	// amountRewardTokenRemoved = cmpStaker.rewardTokenBalance
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 48 8
	btoi
	frame_bury 2 // amountRewardTokenRemoved: uint64

	// examples/reti/stakingPool.algo.ts:329
	// cmpStaker.rewardTokenBalance = 0
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	byte 0x0000000000000000
	replace2 48
	frame_bury 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)

*if12_end:

*if11_end:
	// examples/reti/stakingPool.algo.ts:334
	// assert(
	//           cmpStaker.balance === 0 || cmpStaker.balance >= this.minEntryStake.value,
	//           'cannot reduce balance below minimum allowed stake unless all is removed'
	//         )
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	int 0
	==
	dup
	bnz *skip_or0
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	byte 0x6d696e456e7472795374616b65 // "minEntryStake"
	app_global_get
	>=
	||

*skip_or0:
	// cannot reduce balance below minimum allowed stake unless all is removed
	assert

	// examples/reti/stakingPool.algo.ts:342
	// sendPayment({
	//           amount: amountToUnstake,
	//           receiver: staker,
	//           note: 'unstaked',
	//         })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// examples/reti/stakingPool.algo.ts:343
	// amount: amountToUnstake
	frame_dig -2 // amountToUnstake: uint64
	itxn_field Amount

	// examples/reti/stakingPool.algo.ts:344
	// receiver: staker
	frame_dig -1 // staker: Address
	itxn_field Receiver

	// examples/reti/stakingPool.algo.ts:345
	// note: 'unstaked'
	pushbytes 0x756e7374616b6564 // "unstaked"
	itxn_field Note

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/stakingPool.algo.ts:347
	// stakerRemoved = false
	int 0
	frame_bury 4 // stakerRemoved: bool

	// *if13_condition
	// examples/reti/stakingPool.algo.ts:348
	// cmpStaker.balance === 0
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	int 0
	==
	bz *if13_end

	// *if13_consequent
	// examples/reti/stakingPool.algo.ts:350
	// this.numStakers.value -= 1
	byte 0x6e756d5374616b657273 // "numStakers"
	app_global_get
	int 1
	-
	byte 0x6e756d5374616b657273 // "numStakers"
	swap
	app_global_put

	// examples/reti/stakingPool.algo.ts:351
	// cmpStaker.account = globals.zeroAddress
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	int 0
	global ZeroAddress
	replace3
	frame_bury 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:352
	// cmpStaker.totalRewarded = 0
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	byte 0x0000000000000000
	replace2 40
	frame_bury 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:353
	// cmpStaker.rewardTokenBalance = 0
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	byte 0x0000000000000000
	replace2 48
	frame_bury 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:354
	// stakerRemoved = true
	int 1
	frame_bury 4 // stakerRemoved: bool

*if13_end:
	// examples/reti/stakingPool.algo.ts:357
	// this.stakers.value[i] = cmpStaker
	frame_dig 0 // i: uint64
	int 64
	* // acc * typeLength
	frame_dig 1 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_replace

	// examples/reti/stakingPool.algo.ts:359
	// roundsLeftInBin = this.binRoundStart.value + this.roundsPerDay.value - globals.round
	byte 0x62696e526f756e645374617274 // "binRoundStart"
	app_global_get
	byte 0x726f756e6473506572446179 // "roundsPerDay"
	app_global_get
	+
	global Round
	-
	frame_bury 5 // roundsLeftInBin: uint64

	// examples/reti/stakingPool.algo.ts:360
	// subtractAmount: uint128 = (amountToUnstake as uint128) * (roundsLeftInBin as uint128)
	frame_dig -2 // amountToUnstake: uint64
	itob
	frame_dig 5 // roundsLeftInBin: uint64
	itob
	b*
	dup
	bitlen
	int 128
	<=

	// (amountToUnstake as uint128) * (roundsLeftInBin as uint128) overflowed 128 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 16
	-
	swap
	substring3
	frame_bury 6 // subtractAmount: uint128

	// examples/reti/stakingPool.algo.ts:361
	// this.stakeAccumulator.value = this.stakeAccumulator.value - subtractAmount
	byte 0x7374616b65416363756d756c61746f72 // "stakeAccumulator"
	dup
	app_global_get
	frame_dig 6 // subtractAmount: uint128
	b-
	dup
	bitlen
	int 128
	<=

	// this.stakeAccumulator.value - subtractAmount overflowed 128 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 16
	-
	swap
	substring3
	app_global_put

	// examples/reti/stakingPool.algo.ts:366
	// sendMethodCall<typeof ValidatorRegistry.prototype.stakeRemoved>({
	//           applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//           methodArgs: [
	//             { id: this.validatorId.value, poolId: this.poolId.value, poolAppId: this.app.id },
	//             staker,
	//             amountToUnstake,
	//             amountRewardTokenRemoved,
	//             stakerRemoved,
	//           ],
	//         })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0xa2dc51b5 // method "stakeRemoved((uint64,uint64,uint64),address,uint64,uint64,bool)void"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:367
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:368
	// methodArgs: [
	//             { id: this.validatorId.value, poolId: this.poolId.value, poolAppId: this.app.id },
	//             staker,
	//             amountToUnstake,
	//             amountRewardTokenRemoved,
	//             stakerRemoved,
	//           ]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	itob
	concat
	txna Applications 0
	itob
	concat
	itxn_field ApplicationArgs
	frame_dig -1 // staker: Address
	itxn_field ApplicationArgs
	frame_dig -2 // amountToUnstake: uint64
	itob
	itxn_field ApplicationArgs
	frame_dig 2 // amountRewardTokenRemoved: uint64
	itob
	itxn_field ApplicationArgs
	frame_dig 4 // stakerRemoved: bool
	byte 0x00
	int 0
	uncover 2
	setbit
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/stakingPool.algo.ts:376
	// return;
	retsub

*if8_end:

*for_1_continue:
	// examples/reti/stakingPool.algo.ts:289
	// i += 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64
	b *for_1

*for_1_end:
	// account not found
	err
	retsub

// claimTokens()void
*abi_route_claimTokens:
	// execute claimTokens()void
	callsub claimTokens
	int 1
	return

// claimTokens(): void
//
// Claims all the available reward tokens a staker has available, sending their entire balance to the staker from
// pool 1 (either directly, or via validator->pool1 to pay it out)
// Also notifies the validator contract for this pools validator of the staker / balance changes.
claimTokens:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 4

	// examples/reti/stakingPool.algo.ts:391
	// staker = this.txn.sender
	txn Sender
	frame_bury 0 // staker: address

	// examples/reti/stakingPool.algo.ts:393
	// for (let i = 0; i < this.stakers.value.length; i += 1)
	int 0
	frame_bury 1 // i: uint64

*for_2:
	// examples/reti/stakingPool.algo.ts:393
	// i < this.stakers.value.length
	frame_dig 1 // i: uint64
	int 200
	<
	bz *for_2_end

	// *if14_condition
	// examples/reti/stakingPool.algo.ts:394
	// globals.opcodeBudget < 300
	global OpcodeBudget
	int 300
	<
	bz *if14_end

	// *if14_consequent
	// examples/reti/stakingPool.algo.ts:395
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	pushint 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

*if14_end:
	// examples/reti/stakingPool.algo.ts:397
	// cmpStaker = clone(this.stakers.value[i])
	frame_dig 1 // i: uint64
	int 64
	* // acc * typeLength
	int 64
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_extract
	frame_bury 2 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// *if15_condition
	// examples/reti/stakingPool.algo.ts:398
	// cmpStaker.account === staker
	frame_dig 2 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 0 32
	frame_dig 0 // staker: address
	==
	bz *if15_end

	// *if15_consequent
	// *if16_condition
	// examples/reti/stakingPool.algo.ts:399
	// cmpStaker.rewardTokenBalance === 0
	frame_dig 2 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 48 8
	btoi
	int 0
	==
	bz *if16_end

	// *if16_consequent
	// examples/reti/stakingPool.algo.ts:400
	// return;
	retsub

*if16_end:
	// examples/reti/stakingPool.algo.ts:402
	// amountRewardTokenRemoved = 0
	int 0
	frame_bury 3 // amountRewardTokenRemoved: uint64

	// *if17_condition
	// examples/reti/stakingPool.algo.ts:404
	// this.poolId.value === 1
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	int 1
	==
	bz *if17_else

	// *if17_consequent
	// examples/reti/stakingPool.algo.ts:405
	// validatorConfig = sendMethodCall<typeof ValidatorRegistry.prototype.getValidatorConfig>({
	//             applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//             methodArgs: [this.validatorId.value],
	//           })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0x75aff61d // method "getValidatorConfig(uint64)(uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:406
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:407
	// methodArgs: [this.validatorId.value]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0
	frame_bury 4 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:412
	// sendAssetTransfer({
	//             xferAsset: AssetID.fromUint64(validatorConfig.rewardTokenId),
	//             assetReceiver: staker,
	//             assetAmount: cmpStaker.rewardTokenBalance,
	//           })
	itxn_begin
	pushint 4 // axfer
	itxn_field TypeEnum

	// examples/reti/stakingPool.algo.ts:413
	// xferAsset: AssetID.fromUint64(validatorConfig.rewardTokenId)
	frame_dig 4 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 153 8
	btoi
	itxn_field XferAsset

	// examples/reti/stakingPool.algo.ts:414
	// assetReceiver: staker
	frame_dig 0 // staker: address
	itxn_field AssetReceiver

	// examples/reti/stakingPool.algo.ts:415
	// assetAmount: cmpStaker.rewardTokenBalance
	frame_dig 2 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 48 8
	btoi
	itxn_field AssetAmount

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/stakingPool.algo.ts:417
	// amountRewardTokenRemoved = cmpStaker.rewardTokenBalance
	frame_dig 2 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 48 8
	btoi
	frame_bury 3 // amountRewardTokenRemoved: uint64

	// examples/reti/stakingPool.algo.ts:418
	// cmpStaker.rewardTokenBalance = 0
	frame_dig 2 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	byte 0x0000000000000000
	replace2 48
	frame_bury 2 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	b *if17_end

*if17_else:
	// examples/reti/stakingPool.algo.ts:423
	// amountRewardTokenRemoved = cmpStaker.rewardTokenBalance
	frame_dig 2 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 48 8
	btoi
	frame_bury 3 // amountRewardTokenRemoved: uint64

	// examples/reti/stakingPool.algo.ts:424
	// cmpStaker.rewardTokenBalance = 0
	frame_dig 2 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	byte 0x0000000000000000
	replace2 48
	frame_bury 2 // cmpStaker: (address,uint64,uint64,uint64,uint64)

*if17_end:
	// examples/reti/stakingPool.algo.ts:428
	// this.stakers.value[i] = cmpStaker
	frame_dig 1 // i: uint64
	int 64
	* // acc * typeLength
	frame_dig 2 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_replace

	// examples/reti/stakingPool.algo.ts:433
	// sendMethodCall<typeof ValidatorRegistry.prototype.stakeRemoved>({
	//           applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//           methodArgs: [
	//             { id: this.validatorId.value, poolId: this.poolId.value, poolAppId: this.app.id },
	//             staker,
	//             0, // no algo removed
	//             amountRewardTokenRemoved,
	//             false, // staker isn't being removed.
	//           ],
	//         })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0xa2dc51b5 // method "stakeRemoved((uint64,uint64,uint64),address,uint64,uint64,bool)void"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:434
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:435
	// methodArgs: [
	//             { id: this.validatorId.value, poolId: this.poolId.value, poolAppId: this.app.id },
	//             staker,
	//             0, // no algo removed
	//             amountRewardTokenRemoved,
	//             false, // staker isn't being removed.
	//           ]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	itob
	concat
	txna Applications 0
	itob
	concat
	itxn_field ApplicationArgs
	frame_dig 0 // staker: address
	itxn_field ApplicationArgs
	byte 0x0000000000000000
	itxn_field ApplicationArgs
	frame_dig 3 // amountRewardTokenRemoved: uint64
	itob
	itxn_field ApplicationArgs
	int 0
	byte 0x00
	int 0
	uncover 2
	setbit
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/stakingPool.algo.ts:443
	// return;
	retsub

*if15_end:

*for_2_continue:
	// examples/reti/stakingPool.algo.ts:393
	// i += 1
	frame_dig 1 // i: uint64
	int 1
	+
	frame_bury 1 // i: uint64
	b *for_2

*for_2_end:
	// account not found
	err
	retsub

// getStakerInfo(address)(address,uint64,uint64,uint64,uint64)
*abi_route_getStakerInfo:
	// The ABI return prefix
	byte 0x151f7c75

	// staker: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (staker) for getStakerInfo must be a address
	assert

	// execute getStakerInfo(address)(address,uint64,uint64,uint64,uint64)
	callsub getStakerInfo
	concat
	log
	int 1
	return

// getStakerInfo(staker: Address): StakedInfo
//
// Retrieves the staked information for a given staker.
//
// @param {Address} staker - The address of the staker.
// @returns {StakedInfo} - The staked information for the given staker.
// @throws {Error} - If the staker's account is not found.
getStakerInfo:
	proto 1 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/reti/stakingPool.algo.ts:458
	// for (let i = 0; i < this.stakers.value.length; i += 1)
	int 0
	frame_bury 0 // i: uint64

*for_3:
	// examples/reti/stakingPool.algo.ts:458
	// i < this.stakers.value.length
	frame_dig 0 // i: uint64
	int 200
	<
	bz *for_3_end

	// *if18_condition
	// examples/reti/stakingPool.algo.ts:459
	// globals.opcodeBudget < 200
	global OpcodeBudget
	int 200
	<
	bz *if18_end

	// *if18_consequent
	// examples/reti/stakingPool.algo.ts:460
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	pushint 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

*if18_end:
	// *if19_condition
	// examples/reti/stakingPool.algo.ts:462
	// this.stakers.value[i].account === staker
	frame_dig 0 // i: uint64
	int 64
	* // acc * typeLength
	int 0
	+
	int 32
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_extract
	frame_dig -1 // staker: Address
	==
	bz *if19_end

	// *if19_consequent
	// examples/reti/stakingPool.algo.ts:463
	// return this.stakers.value[i];
	frame_dig 0 // i: uint64
	int 64
	* // acc * typeLength
	int 64
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_extract
	b *getStakerInfo*return

*if19_end:

*for_3_continue:
	// examples/reti/stakingPool.algo.ts:458
	// i += 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64
	b *for_3

*for_3_end:
	// account not found
	err

*getStakerInfo*return:
	// set the subroutine return value
	frame_bury 0
	retsub

// payTokenReward(address,uint64,uint64)void
*abi_route_payTokenReward:
	// amountToSend: uint64
	txna ApplicationArgs 3
	btoi

	// rewardToken: uint64
	txna ApplicationArgs 2
	btoi

	// staker: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 2 (staker) for payTokenReward must be a address
	assert

	// execute payTokenReward(address,uint64,uint64)void
	callsub payTokenReward
	int 1
	return

// payTokenReward(staker: Address, rewardToken: uint64, amountToSend: uint64): void
//
// [Internal protocol method] Remove a specified amount of 'community token' rewards for a staker.
// This can ONLY be called by our validator and only if we're pool 1 - with the token.
// Note: this can also be called by validator as part of OWNER wanting to send the reward tokens
// somewhere else (ie if they're sunsetting their validator and need the reward tokens back).
// It's up to the validator to ensure that the balance in rewardTokenHeldBack is honored.
// @param staker - the staker account to send rewards to
// @param rewardToken - id of reward token (to avoid re-entrancy in calling validator back to get id)
// @param amountToSend - amount to send the staker (there is significant trust here(!) - also why only validator can call us
payTokenReward:
	proto 3 0

	// examples/reti/stakingPool.algo.ts:481
	// assert(
	//       this.txn.sender === AppID.fromUint64(this.creatingValidatorContractAppId.value).address,
	//       'this can only be called via the validator contract'
	//     )
	txn Sender
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	app_params_get AppAddress
	pop
	==

	// this can only be called via the validator contract
	assert

	// examples/reti/stakingPool.algo.ts:485
	// assert(this.poolId.value === 1, 'must be pool 1 in order to be called to pay out token rewards')
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	int 1
	==

	// must be pool 1 in order to be called to pay out token rewards
	assert

	// examples/reti/stakingPool.algo.ts:486
	// assert(rewardToken !== 0, 'can only claim token rewards from validator that has them')
	frame_dig -2 // rewardToken: uint64
	int 0
	!=

	// can only claim token rewards from validator that has them
	assert

	// examples/reti/stakingPool.algo.ts:489
	// sendAssetTransfer({
	//       xferAsset: AssetID.fromUint64(rewardToken),
	//       assetReceiver: staker,
	//       assetAmount: amountToSend,
	//     })
	itxn_begin
	pushint 4 // axfer
	itxn_field TypeEnum

	// examples/reti/stakingPool.algo.ts:490
	// xferAsset: AssetID.fromUint64(rewardToken)
	frame_dig -2 // rewardToken: uint64
	itxn_field XferAsset

	// examples/reti/stakingPool.algo.ts:491
	// assetReceiver: staker
	frame_dig -1 // staker: Address
	itxn_field AssetReceiver

	// examples/reti/stakingPool.algo.ts:492
	// assetAmount: amountToSend
	frame_dig -3 // amountToSend: uint64
	itxn_field AssetAmount

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// updateAlgodVer(string)void
*abi_route_updateAlgodVer:
	// algodVer: string
	txna ApplicationArgs 1
	extract 2 0

	// execute updateAlgodVer(string)void
	callsub updateAlgodVer
	int 1
	return

// updateAlgodVer(algodVer: string): void
//
// Update the (honor system) algod version for the node associated to this pool.  The node management daemon
// should compare its current nodes version to the version stored in global state, updating when different.
// The reti node daemon composes its own version string using format:
// {major}.{minor}.{build} {branch} [{commit hash}],
// ie: 3.22.0 rel/stable [6b508975]
// [ ONLY OWNER OR MANAGER CAN CALL ]
// @param {string} algodVer - string representing the algorand node daemon version (reti node daemon composes its own meta version)
updateAlgodVer:
	proto 1 0

	// examples/reti/stakingPool.algo.ts:506
	// assert(this.isOwnerOrManagerCaller(), 'can only be called by owner or manager of validator')
	callsub isOwnerOrManagerCaller

	// can only be called by owner or manager of validator
	assert

	// examples/reti/stakingPool.algo.ts:507
	// this.algodVer.value = algodVer
	pushbytes 0x616c676f64566572 // "algodVer"
	frame_dig -1 // algodVer: string
	app_global_put
	retsub

// epochBalanceUpdate()void
*abi_route_epochBalanceUpdate:
	// execute epochBalanceUpdate()void
	callsub epochBalanceUpdate
	int 1
	return

// epochBalanceUpdate(): void
//
// Updates the balance of stakers in the pool based on the received 'rewards' (current balance vs known staked balance)
// stakers outstanding balance is adjusted based on their % of stake and time in the current epoch - so that balance
// compounds over time and staker can remove that amount at will.
// The validator is paid their percentage each epoch payout.
//
// Note: ANYONE can call this.
epochBalanceUpdate:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 36

	// examples/reti/stakingPool.algo.ts:520
	// validatorConfig = sendMethodCall<typeof ValidatorRegistry.prototype.getValidatorConfig>({
	//       applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//       methodArgs: [this.validatorId.value],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0x75aff61d // method "getValidatorConfig(uint64)(uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:521
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:522
	// methodArgs: [this.validatorId.value]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0
	frame_bury 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:529
	// epochRoundLength = validatorConfig.epochRoundLength as uint64
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 169 4
	btoi
	frame_bury 1 // epochRoundLength: uint64

	// examples/reti/stakingPool.algo.ts:530
	// curRound = globals.round
	global Round
	frame_bury 2 // curRound: uint64

	// examples/reti/stakingPool.algo.ts:531
	// thisEpochBegin = curRound - (curRound % epochRoundLength)
	frame_dig 2 // curRound: uint64
	frame_dig 2 // curRound: uint64
	frame_dig 1 // epochRoundLength: uint64
	%
	-
	frame_bury 3 // thisEpochBegin: uint64

	// *if20_condition
	// examples/reti/stakingPool.algo.ts:534
	// this.lastPayout.exists
	txna Applications 0
	byte 0x6c6173745061796f7574 // "lastPayout"
	app_global_get_ex
	swap
	pop
	bz *if20_end

	// *if20_consequent
	// examples/reti/stakingPool.algo.ts:535
	// lastPayoutEpoch = this.lastPayout.value - (this.lastPayout.value % epochRoundLength)
	byte 0x6c6173745061796f7574 // "lastPayout"
	app_global_get
	byte 0x6c6173745061796f7574 // "lastPayout"
	app_global_get
	frame_dig 1 // epochRoundLength: uint64
	%
	-
	frame_bury 4 // lastPayoutEpoch: uint64

	// examples/reti/stakingPool.algo.ts:539
	// assert(lastPayoutEpoch !== thisEpochBegin, "can't call epochBalanceUpdate in same epoch as prior call")
	frame_dig 4 // lastPayoutEpoch: uint64
	frame_dig 3 // thisEpochBegin: uint64
	!=

	// can't call epochBalanceUpdate in same epoch as prior call
	assert

*if20_end:
	// examples/reti/stakingPool.algo.ts:542
	// this.checkIfBinClosed()
	callsub checkIfBinClosed

	// examples/reti/stakingPool.algo.ts:545
	// this.lastPayout.value = curRound
	byte 0x6c6173745061796f7574 // "lastPayout"
	frame_dig 2 // curRound: uint64
	app_global_put

	// examples/reti/stakingPool.algo.ts:546
	// this.epochNumber.value += 1
	byte 0x65706f63684e756d626572 // "epochNumber"
	app_global_get
	int 1
	+
	byte 0x65706f63684e756d626572 // "epochNumber"
	swap
	app_global_put

	// examples/reti/stakingPool.algo.ts:551
	// isTokenEligible = validatorConfig.rewardTokenId !== 0
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 153 8
	btoi
	int 0
	!=
	frame_bury 5 // isTokenEligible: bool

	// examples/reti/stakingPool.algo.ts:552
	// poolOneAppID = this.app.id
	txna Applications 0
	frame_bury 6 // poolOneAppID: uint64

	// examples/reti/stakingPool.algo.ts:553
	// poolOneAddress = this.app.address
	global CurrentApplicationAddress
	frame_bury 7 // poolOneAddress: address

	// *if21_condition
	// examples/reti/stakingPool.algo.ts:558
	// isTokenEligible
	frame_dig 5 // isTokenEligible: bool
	bz *if21_end

	// *if21_consequent
	// *if22_condition
	// examples/reti/stakingPool.algo.ts:559
	// this.poolId.value !== 1
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	int 1
	!=
	bz *if22_end

	// *if22_consequent
	// examples/reti/stakingPool.algo.ts:561
	// poolOneAppID = sendMethodCall<typeof ValidatorRegistry.prototype.getPoolAppId>({
	//           applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//           methodArgs: [this.validatorId.value, 1],
	//         })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0x572767d1 // method "getPoolAppId(uint64,uint64)uint64"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:562
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:563
	// methodArgs: [this.validatorId.value, 1]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	itxn_field ApplicationArgs
	pushbytes 0x0000000000000001
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0
	btoi
	frame_bury 6 // poolOneAppID: uint64

	// examples/reti/stakingPool.algo.ts:565
	// poolOneAddress = AppID.fromUint64(poolOneAppID).address
	frame_dig 6 // poolOneAppID: uint64
	app_params_get AppAddress
	pop
	frame_bury 7 // poolOneAddress: address

*if22_end:
	// *if23_condition
	// examples/reti/stakingPool.algo.ts:570
	// this.poolId.value === 1
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	int 1
	==
	bz *if23_else

	// *if23_consequent
	// examples/reti/stakingPool.algo.ts:571
	// tokenPayoutRatio = sendMethodCall<typeof ValidatorRegistry.prototype.setTokenPayoutRatio>({
	//           applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//           methodArgs: [this.validatorId.value],
	//         })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0x4df8d86e // method "setTokenPayoutRatio(uint64)(uint64[24],uint64)"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:572
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:573
	// methodArgs: [this.validatorId.value]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0
	frame_bury 8 // tokenPayoutRatio: PoolTokenPayoutRatio
	b *if23_end

*if23_else:
	// examples/reti/stakingPool.algo.ts:577
	// tokenPayoutRatio = sendMethodCall<typeof StakingPool.prototype.proxiedSetTokenPayoutRatio>({
	//           applicationID: AppID.fromUint64(poolOneAppID),
	//           methodArgs: [{ id: this.validatorId.value, poolId: this.poolId.value, poolAppId: this.app.id }],
	//         })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0x0c2245e1 // method "proxiedSetTokenPayoutRatio((uint64,uint64,uint64))(uint64[24],uint64)"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:578
	// applicationID: AppID.fromUint64(poolOneAppID)
	frame_dig 6 // poolOneAppID: uint64
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:579
	// methodArgs: [{ id: this.validatorId.value, poolId: this.poolId.value, poolAppId: this.app.id }]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	itob
	concat
	txna Applications 0
	itob
	concat
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0
	frame_bury 8 // tokenPayoutRatio: PoolTokenPayoutRatio

*if23_end:

*if21_end:
	// examples/reti/stakingPool.algo.ts:586
	// validatorState = sendMethodCall<typeof ValidatorRegistry.prototype.getValidatorState>({
	//       applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//       methodArgs: [this.validatorId.value],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	pushbytes 0x1f2f0109 // method "getValidatorState(uint64)(uint16,uint64,uint64,uint64)"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:587
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:588
	// methodArgs: [this.validatorId.value]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0
	frame_bury 9 // validatorState: (uint16,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:590
	// rewardTokenHeldBack = validatorState.rewardTokenHeldBack
	frame_dig 9 // validatorState: (uint16,uint64,uint64,uint64)
	extract 18 8
	btoi
	frame_bury 10 // rewardTokenHeldBack: uint64

	// examples/reti/stakingPool.algo.ts:596
	// algoRewardAvail = this.app.address.balance - this.totalAlgoStaked.value - this.app.address.minBalance
	global CurrentApplicationAddress
	acct_params_get AcctBalance
	pop
	byte 0x7374616b6564 // "staked"
	app_global_get
	-
	global CurrentApplicationAddress
	acct_params_get AcctMinBalance
	pop
	-
	frame_bury 11 // algoRewardAvail: uint64

	// examples/reti/stakingPool.algo.ts:597
	// isPoolSaturated = false
	int 0
	frame_bury 12 // isPoolSaturated: bool

	// examples/reti/stakingPool.algo.ts:598
	// algoSaturationAmt = this.algoSaturationLevel()
	callsub algoSaturationLevel
	frame_bury 13 // algoSaturationAmt: uint64

	// *if24_condition
	// examples/reti/stakingPool.algo.ts:606
	// validatorState.totalAlgoStaked > algoSaturationAmt
	frame_dig 9 // validatorState: (uint16,uint64,uint64,uint64)
	extract 10 8
	btoi
	frame_dig 13 // algoSaturationAmt: uint64
	>
	bz *if24_end

	// *if24_consequent
	// examples/reti/stakingPool.algo.ts:607
	// isPoolSaturated = true
	int 1
	frame_bury 12 // isPoolSaturated: bool

*if24_end:
	// examples/reti/stakingPool.algo.ts:613
	// tokenRewardAvail = 0
	int 0
	frame_bury 14 // tokenRewardAvail: uint64

	// examples/reti/stakingPool.algo.ts:614
	// tokenRewardPaidOut = 0
	int 0
	frame_bury 15 // tokenRewardPaidOut: uint64

	// examples/reti/stakingPool.algo.ts:615
	// validatorCommissionPaidOut = 0
	int 0
	frame_bury 16 // validatorCommissionPaidOut: uint64

	// examples/reti/stakingPool.algo.ts:616
	// excessToFeeSink = 0
	int 0
	frame_bury 17 // excessToFeeSink: uint64

	// *if25_condition
	// examples/reti/stakingPool.algo.ts:617
	// isTokenEligible
	frame_dig 5 // isTokenEligible: bool
	bz *if25_end

	// *if25_consequent
	// examples/reti/stakingPool.algo.ts:618
	// tokenRewardBal =
	//         poolOneAddress.assetBalance(AssetID.fromUint64(validatorConfig.rewardTokenId)) - rewardTokenHeldBack
	frame_dig 7 // poolOneAddress: address
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 153 8
	btoi
	asset_holding_get AssetBalance
	pop
	frame_dig 10 // rewardTokenHeldBack: uint64
	-
	frame_bury 18 // tokenRewardBal: uint64

	// *if26_condition
	// examples/reti/stakingPool.algo.ts:623
	// tokenRewardBal >= validatorConfig.rewardPerPayout
	frame_dig 18 // tokenRewardBal: uint64
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 161 8
	btoi
	>=
	bz *if26_end

	// *if26_consequent
	// examples/reti/stakingPool.algo.ts:629
	// ourPoolPctOfWhole = tokenPayoutRatio.poolPctOfWhole[this.poolId.value - 1]
	frame_dig 8 // tokenPayoutRatio: PoolTokenPayoutRatio
	int 0
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	int 1
	-
	pushint 8
	* // acc * typeLength
	+
	pushint 8
	extract3
	btoi
	frame_bury 19 // ourPoolPctOfWhole: uint64

	// examples/reti/stakingPool.algo.ts:632
	// tokenRewardAvail = wideRatio([validatorConfig.rewardPerPayout, ourPoolPctOfWhole], [1_000_000])
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 161 8
	btoi
	frame_dig 19 // ourPoolPctOfWhole: uint64
	mulw
	int 0
	int 1_000_000
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	frame_bury 14 // tokenRewardAvail: uint64

*if26_end:

*if25_end:
	// *if27_condition
	// examples/reti/stakingPool.algo.ts:635
	// tokenRewardAvail === 0
	frame_dig 14 // tokenRewardAvail: uint64
	int 0
	==
	bz *if27_end

	// *if27_consequent
	// *if28_condition
	// examples/reti/stakingPool.algo.ts:640
	// algoRewardAvail < 1_000_000
	frame_dig 11 // algoRewardAvail: uint64
	int 1_000_000
	<
	bz *if28_end

	// *if28_consequent
	// examples/reti/stakingPool.algo.ts:641
	// log('!token&&!noalgo to pay')
	pushbytes 0x21746f6b656e2626216e6f616c676f20746f20706179 // "!token&&!noalgo to pay"
	log

	// examples/reti/stakingPool.algo.ts:642
	// return;
	retsub

*if28_end:

*if27_end:
	// *if29_condition
	// examples/reti/stakingPool.algo.ts:646
	// isPoolSaturated
	frame_dig 12 // isPoolSaturated: bool
	bz *if29_elseif1_condition

	// *if29_consequent
	// examples/reti/stakingPool.algo.ts:649
	// diminishedReward = wideRatio([algoRewardAvail, algoSaturationAmt], [validatorState.totalAlgoStaked])
	frame_dig 11 // algoRewardAvail: uint64
	frame_dig 13 // algoSaturationAmt: uint64
	mulw
	int 0
	frame_dig 9 // validatorState: (uint16,uint64,uint64,uint64)
	extract 10 8
	btoi
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	frame_bury 20 // diminishedReward: uint64

	// examples/reti/stakingPool.algo.ts:651
	// excessToFeeSink = algoRewardAvail - diminishedReward
	frame_dig 11 // algoRewardAvail: uint64
	frame_dig 20 // diminishedReward: uint64
	-
	frame_bury 17 // excessToFeeSink: uint64

	// examples/reti/stakingPool.algo.ts:652
	// sendPayment({
	//         amount: excessToFeeSink,
	//         receiver: this.getFeeSink(),
	//         note: 'pool saturated, excess to fee sink',
	//       })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// examples/reti/stakingPool.algo.ts:653
	// amount: excessToFeeSink
	frame_dig 17 // excessToFeeSink: uint64
	itxn_field Amount

	// examples/reti/stakingPool.algo.ts:654
	// receiver: this.getFeeSink()
	callsub getFeeSink
	itxn_field Receiver

	// examples/reti/stakingPool.algo.ts:655
	// note: 'pool saturated, excess to fee sink'
	pushbytes 0x706f6f6c207361747572617465642c2065786365737320746f206665652073696e6b // "pool saturated, excess to fee sink"
	itxn_field Note

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/stakingPool.algo.ts:658
	// algoRewardAvail = diminishedReward
	frame_dig 20 // diminishedReward: uint64
	frame_bury 11 // algoRewardAvail: uint64
	b *if29_end

*if29_elseif1_condition:
	// examples/reti/stakingPool.algo.ts:659
	// validatorConfig.percentToValidator !== 0
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 173 4
	btoi
	int 0
	!=
	bz *if29_end

	// *if29_elseif1_consequent
	// examples/reti/stakingPool.algo.ts:662
	// validatorCommissionPaidOut = wideRatio(
	//         [algoRewardAvail, validatorConfig.percentToValidator as uint64],
	//         [1_000_000]
	//       )
	frame_dig 11 // algoRewardAvail: uint64
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 173 4
	btoi
	mulw
	int 0
	int 1_000_000
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	frame_bury 16 // validatorCommissionPaidOut: uint64

	// examples/reti/stakingPool.algo.ts:668
	// algoRewardAvail -= validatorCommissionPaidOut
	frame_dig 11 // algoRewardAvail: uint64
	frame_dig 16 // validatorCommissionPaidOut: uint64
	-
	frame_bury 11 // algoRewardAvail: uint64

	// *if30_condition
	// examples/reti/stakingPool.algo.ts:675
	// validatorCommissionPaidOut > 0
	frame_dig 16 // validatorCommissionPaidOut: uint64
	int 0
	>
	bz *if30_end

	// *if30_consequent
	// examples/reti/stakingPool.algo.ts:678
	// managerTopOff = 0
	int 0
	frame_bury 21 // managerTopOff: uint64

	// *if31_condition
	// examples/reti/stakingPool.algo.ts:680
	// validatorConfig.manager !== validatorConfig.validatorCommissionAddress &&
	//           validatorConfig.manager.balance - validatorConfig.manager.minBalance < 2_100_000
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 40 32
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 177 32
	!=
	dup
	bz *skip_and3
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 40 32
	acct_params_get AcctBalance
	pop
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 40 32
	acct_params_get AcctMinBalance
	pop
	-
	int 2_100_000
	<
	&&

*skip_and3:
	bz *if31_end

	// *if31_consequent
	// examples/reti/stakingPool.algo.ts:683
	// managerTopOff = validatorCommissionPaidOut < 2_100_000 ? validatorCommissionPaidOut : 2_100_000
	frame_dig 16 // validatorCommissionPaidOut: uint64
	int 2_100_000
	<
	bz *ternary1_false
	frame_dig 16 // validatorCommissionPaidOut: uint64
	b *ternary1_end

*ternary1_false:
	int 2_100_000

*ternary1_end:
	frame_bury 21 // managerTopOff: uint64

	// examples/reti/stakingPool.algo.ts:684
	// sendPayment({
	//             amount: managerTopOff,
	//             receiver: validatorConfig.manager,
	//             note: 'validator reward to manager for funding epoch updates',
	//           })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// examples/reti/stakingPool.algo.ts:685
	// amount: managerTopOff
	frame_dig 21 // managerTopOff: uint64
	itxn_field Amount

	// examples/reti/stakingPool.algo.ts:686
	// receiver: validatorConfig.manager
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 40 32
	itxn_field Receiver

	// examples/reti/stakingPool.algo.ts:687
	// note: 'validator reward to manager for funding epoch updates'
	pushbytes 0x76616c696461746f722072657761726420746f206d616e6167657220666f722066756e64696e672065706f63682075706461746573 // "validator reward to manager for funding epoch updates"
	itxn_field Note

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

*if31_end:
	// *if32_condition
	// examples/reti/stakingPool.algo.ts:690
	// validatorCommissionPaidOut - managerTopOff > 0
	frame_dig 16 // validatorCommissionPaidOut: uint64
	frame_dig 21 // managerTopOff: uint64
	-
	int 0
	>
	bz *if32_end

	// *if32_consequent
	// examples/reti/stakingPool.algo.ts:691
	// sendPayment({
	//             amount: validatorCommissionPaidOut - managerTopOff,
	//             receiver: validatorConfig.validatorCommissionAddress,
	//             note: 'validator reward',
	//           })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// examples/reti/stakingPool.algo.ts:692
	// amount: validatorCommissionPaidOut - managerTopOff
	frame_dig 16 // validatorCommissionPaidOut: uint64
	frame_dig 21 // managerTopOff: uint64
	-
	itxn_field Amount

	// examples/reti/stakingPool.algo.ts:693
	// receiver: validatorConfig.validatorCommissionAddress
	frame_dig 0 // validatorConfig: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 177 32
	itxn_field Receiver

	// examples/reti/stakingPool.algo.ts:694
	// note: 'validator reward'
	pushbytes 0x76616c696461746f7220726577617264 // "validator reward"
	itxn_field Note

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

*if32_end:

*if30_end:

*if29_end:
	// examples/reti/stakingPool.algo.ts:706
	// increasedStake = 0
	int 0
	frame_bury 22 // increasedStake: uint64

	// *if33_condition
	// examples/reti/stakingPool.algo.ts:730
	// algoRewardAvail !== 0 || tokenRewardAvail !== 0
	frame_dig 11 // algoRewardAvail: uint64
	int 0
	!=
	dup
	bnz *skip_or1
	frame_dig 14 // tokenRewardAvail: uint64
	int 0
	!=
	||

*skip_or1:
	bz *if33_end

	// *if33_consequent
	// examples/reti/stakingPool.algo.ts:731
	// partialStakersTotalStake: uint64 = 0
	int 0
	frame_bury 23 // partialStakersTotalStake: uint64

	// examples/reti/stakingPool.algo.ts:732
	// for (let i = 0; i < this.stakers.value.length; i += 1)
	int 0
	frame_bury 24 // i: uint64

*for_4:
	// examples/reti/stakingPool.algo.ts:732
	// i < this.stakers.value.length
	frame_dig 24 // i: uint64
	int 200
	<
	bz *for_4_end

	// *if34_condition
	// examples/reti/stakingPool.algo.ts:733
	// globals.opcodeBudget < 400
	global OpcodeBudget
	pushint 400
	<
	bz *if34_end

	// *if34_consequent
	// examples/reti/stakingPool.algo.ts:734
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	pushint 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

*if34_end:
	// examples/reti/stakingPool.algo.ts:736
	// cmpStaker = clone(this.stakers.value[i])
	frame_dig 24 // i: uint64
	int 64
	* // acc * typeLength
	int 64
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_extract
	frame_bury 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// *if35_condition
	// examples/reti/stakingPool.algo.ts:737
	// cmpStaker.account !== globals.zeroAddress
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 0 32
	global ZeroAddress
	!=
	bz *if35_end

	// *if35_consequent
	// *if36_condition
	// examples/reti/stakingPool.algo.ts:738
	// cmpStaker.entryRound >= thisEpochBegin
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 56 8
	btoi
	frame_dig 3 // thisEpochBegin: uint64
	>=
	bz *if36_else

	// *if36_consequent
	// examples/reti/stakingPool.algo.ts:741
	// partialStakersTotalStake += cmpStaker.balance
	frame_dig 23 // partialStakersTotalStake: uint64
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	+
	frame_bury 23 // partialStakersTotalStake: uint64
	b *if36_end

*if36_else:
	// examples/reti/stakingPool.algo.ts:745
	// timeInPool = thisEpochBegin - cmpStaker.entryRound
	frame_dig 3 // thisEpochBegin: uint64
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 56 8
	btoi
	-
	frame_bury 26 // timeInPool: uint64

	// *if37_condition
	// examples/reti/stakingPool.algo.ts:749
	// timeInPool < epochRoundLength
	frame_dig 26 // timeInPool: uint64
	frame_dig 1 // epochRoundLength: uint64
	<
	bz *if37_end

	// *if37_consequent
	// examples/reti/stakingPool.algo.ts:750
	// partialStakersTotalStake += cmpStaker.balance
	frame_dig 23 // partialStakersTotalStake: uint64
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	+
	frame_bury 23 // partialStakersTotalStake: uint64

	// examples/reti/stakingPool.algo.ts:751
	// timePercentage = (timeInPool * 1000) / epochRoundLength
	frame_dig 26 // timeInPool: uint64
	int 1000
	*
	frame_dig 1 // epochRoundLength: uint64
	/
	frame_bury 27 // timePercentage: uint64

	// *if38_condition
	// examples/reti/stakingPool.algo.ts:753
	// tokenRewardAvail > 0
	frame_dig 14 // tokenRewardAvail: uint64
	int 0
	>
	bz *if38_end

	// *if38_consequent
	// examples/reti/stakingPool.algo.ts:755
	// stakerTokenReward = wideRatio(
	//                   [cmpStaker.balance, tokenRewardAvail, timePercentage],
	//                   [this.totalAlgoStaked.value, 1000]
	//                 )
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	frame_dig 14 // tokenRewardAvail: uint64
	mulw
	frame_dig 27 // timePercentage: uint64
	uncover 2
	dig 1
	*
	cover 2
	mulw
	cover 2
	+
	swap
	byte 0x7374616b6564 // "staked"
	app_global_get
	int 1000
	mulw
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	frame_bury 28 // stakerTokenReward: uint64

	// examples/reti/stakingPool.algo.ts:762
	// tokenRewardAvail -= stakerTokenReward
	frame_dig 14 // tokenRewardAvail: uint64
	frame_dig 28 // stakerTokenReward: uint64
	-
	frame_bury 14 // tokenRewardAvail: uint64

	// examples/reti/stakingPool.algo.ts:763
	// cmpStaker.rewardTokenBalance += stakerTokenReward
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	pushint 48 // headOffset
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 48 8
	btoi
	frame_dig 28 // stakerTokenReward: uint64
	+
	itob
	replace3
	frame_bury 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:764
	// tokenRewardPaidOut += stakerTokenReward
	frame_dig 15 // tokenRewardPaidOut: uint64
	frame_dig 28 // stakerTokenReward: uint64
	+
	frame_bury 15 // tokenRewardPaidOut: uint64

*if38_end:
	// *if39_condition
	// examples/reti/stakingPool.algo.ts:766
	// algoRewardAvail > 0
	frame_dig 11 // algoRewardAvail: uint64
	int 0
	>
	bz *if39_end

	// *if39_consequent
	// examples/reti/stakingPool.algo.ts:768
	// stakerReward = wideRatio(
	//                   [cmpStaker.balance, algoRewardAvail, timePercentage],
	//                   [this.totalAlgoStaked.value, 1000]
	//                 )
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	frame_dig 11 // algoRewardAvail: uint64
	mulw
	frame_dig 27 // timePercentage: uint64
	uncover 2
	dig 1
	*
	cover 2
	mulw
	cover 2
	+
	swap
	byte 0x7374616b6564 // "staked"
	app_global_get
	int 1000
	mulw
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	frame_bury 29 // stakerReward: uint64

	// examples/reti/stakingPool.algo.ts:775
	// algoRewardAvail -= stakerReward
	frame_dig 11 // algoRewardAvail: uint64
	frame_dig 29 // stakerReward: uint64
	-
	frame_bury 11 // algoRewardAvail: uint64

	// examples/reti/stakingPool.algo.ts:778
	// cmpStaker.balance += stakerReward
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	int 32 // headOffset
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	frame_dig 29 // stakerReward: uint64
	+
	itob
	replace3
	frame_bury 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:779
	// cmpStaker.totalRewarded += stakerReward
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	pushint 40 // headOffset
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 40 8
	btoi
	frame_dig 29 // stakerReward: uint64
	+
	itob
	replace3
	frame_bury 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:780
	// increasedStake += stakerReward
	frame_dig 22 // increasedStake: uint64
	frame_dig 29 // stakerReward: uint64
	+
	frame_bury 22 // increasedStake: uint64

*if39_end:
	// examples/reti/stakingPool.algo.ts:783
	// this.stakers.value[i] = cmpStaker
	frame_dig 24 // i: uint64
	int 64
	* // acc * typeLength
	frame_dig 25 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_replace

*if37_end:

*if36_end:

*if35_end:

*for_4_continue:
	// examples/reti/stakingPool.algo.ts:732
	// i += 1
	frame_dig 24 // i: uint64
	int 1
	+
	frame_bury 24 // i: uint64
	b *for_4

*for_4_end:
	// examples/reti/stakingPool.algo.ts:791
	// newPoolTotalStake = this.totalAlgoStaked.value - partialStakersTotalStake
	byte 0x7374616b6564 // "staked"
	app_global_get
	frame_dig 23 // partialStakersTotalStake: uint64
	-
	frame_bury 30 // newPoolTotalStake: uint64

	// *if40_condition
	// examples/reti/stakingPool.algo.ts:795
	// newPoolTotalStake > 0
	frame_dig 30 // newPoolTotalStake: uint64
	int 0
	>
	bz *if40_end

	// *if40_consequent
	// examples/reti/stakingPool.algo.ts:797
	// for (let i = 0; i < this.stakers.value.length; i += 1)
	int 0
	frame_bury 31 // i: uint64

*for_5:
	// examples/reti/stakingPool.algo.ts:797
	// i < this.stakers.value.length
	frame_dig 31 // i: uint64
	int 200
	<
	bz *for_5_end

	// *if41_condition
	// examples/reti/stakingPool.algo.ts:798
	// globals.opcodeBudget < 200
	global OpcodeBudget
	int 200
	<
	bz *if41_end

	// *if41_consequent
	// examples/reti/stakingPool.algo.ts:799
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	pushint 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

*if41_end:
	// examples/reti/stakingPool.algo.ts:801
	// cmpStaker = clone(this.stakers.value[i])
	frame_dig 31 // i: uint64
	int 64
	* // acc * typeLength
	int 64
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_extract
	frame_bury 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// *if42_condition
	// examples/reti/stakingPool.algo.ts:802
	// cmpStaker.account !== globals.zeroAddress && cmpStaker.entryRound < thisEpochBegin
	frame_dig 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 0 32
	global ZeroAddress
	!=
	dup
	bz *skip_and4
	frame_dig 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 56 8
	btoi
	frame_dig 3 // thisEpochBegin: uint64
	<
	&&

*skip_and4:
	bz *if42_end

	// *if42_consequent
	// examples/reti/stakingPool.algo.ts:803
	// timeInPool = thisEpochBegin - cmpStaker.entryRound
	frame_dig 3 // thisEpochBegin: uint64
	frame_dig 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 56 8
	btoi
	-
	frame_bury 33 // timeInPool: uint64

	// *if43_condition
	// examples/reti/stakingPool.algo.ts:805
	// timeInPool >= epochRoundLength
	frame_dig 33 // timeInPool: uint64
	frame_dig 1 // epochRoundLength: uint64
	>=
	bz *if43_end

	// *if43_consequent
	// *if44_condition
	// examples/reti/stakingPool.algo.ts:810
	// tokenRewardAvail > 0
	frame_dig 14 // tokenRewardAvail: uint64
	int 0
	>
	bz *if44_end

	// *if44_consequent
	// examples/reti/stakingPool.algo.ts:811
	// stakerTokenReward = wideRatio([cmpStaker.balance, tokenRewardAvail], [newPoolTotalStake])
	frame_dig 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	frame_dig 14 // tokenRewardAvail: uint64
	mulw
	int 0
	frame_dig 30 // newPoolTotalStake: uint64
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	frame_bury 34 // stakerTokenReward: uint64

	// examples/reti/stakingPool.algo.ts:814
	// cmpStaker.rewardTokenBalance += stakerTokenReward
	frame_dig 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	pushint 48 // headOffset
	frame_dig 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 48 8
	btoi
	frame_dig 34 // stakerTokenReward: uint64
	+
	itob
	replace3
	frame_bury 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:815
	// tokenRewardPaidOut += stakerTokenReward
	frame_dig 15 // tokenRewardPaidOut: uint64
	frame_dig 34 // stakerTokenReward: uint64
	+
	frame_bury 15 // tokenRewardPaidOut: uint64

*if44_end:
	// *if45_condition
	// examples/reti/stakingPool.algo.ts:817
	// algoRewardAvail > 0
	frame_dig 11 // algoRewardAvail: uint64
	int 0
	>
	bz *if45_end

	// *if45_consequent
	// examples/reti/stakingPool.algo.ts:818
	// stakerReward = wideRatio([cmpStaker.balance, algoRewardAvail], [newPoolTotalStake])
	frame_dig 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	frame_dig 11 // algoRewardAvail: uint64
	mulw
	int 0
	frame_dig 30 // newPoolTotalStake: uint64
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	frame_bury 35 // stakerReward: uint64

	// examples/reti/stakingPool.algo.ts:821
	// cmpStaker.balance += stakerReward
	frame_dig 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	int 32 // headOffset
	frame_dig 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 32 8
	btoi
	frame_dig 35 // stakerReward: uint64
	+
	itob
	replace3
	frame_bury 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:822
	// cmpStaker.totalRewarded += stakerReward
	frame_dig 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	pushint 40 // headOffset
	frame_dig 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	extract 40 8
	btoi
	frame_dig 35 // stakerReward: uint64
	+
	itob
	replace3
	frame_bury 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)

	// examples/reti/stakingPool.algo.ts:823
	// increasedStake += stakerReward
	frame_dig 22 // increasedStake: uint64
	frame_dig 35 // stakerReward: uint64
	+
	frame_bury 22 // increasedStake: uint64

*if45_end:
	// examples/reti/stakingPool.algo.ts:827
	// this.stakers.value[i] = cmpStaker
	frame_dig 31 // i: uint64
	int 64
	* // acc * typeLength
	frame_dig 32 // cmpStaker: (address,uint64,uint64,uint64,uint64)
	byte 0x7374616b657273 // "stakers"
	cover 2
	box_replace

*if43_end:

*if42_end:

*for_5_continue:
	// examples/reti/stakingPool.algo.ts:797
	// i += 1
	frame_dig 31 // i: uint64
	int 1
	+
	frame_bury 31 // i: uint64
	b *for_5

*for_5_end:

*if40_end:

*if33_end:
	// examples/reti/stakingPool.algo.ts:837
	// roundsLeftInBin = this.binRoundStart.value + this.roundsPerDay.value - globals.round
	byte 0x62696e526f756e645374617274 // "binRoundStart"
	app_global_get
	byte 0x726f756e6473506572446179 // "roundsPerDay"
	app_global_get
	+
	global Round
	-
	frame_bury 36 // roundsLeftInBin: uint64

	// examples/reti/stakingPool.algo.ts:838
	// this.totalAlgoStaked.value += increasedStake
	byte 0x7374616b6564 // "staked"
	app_global_get
	frame_dig 22 // increasedStake: uint64
	+
	byte 0x7374616b6564 // "staked"
	swap
	app_global_put

	// examples/reti/stakingPool.algo.ts:839
	// this.stakeAccumulator.value =
	//       this.stakeAccumulator.value + (increasedStake as uint128) * (roundsLeftInBin as uint128)
	byte 0x7374616b65416363756d756c61746f72 // "stakeAccumulator"
	dup
	app_global_get
	frame_dig 22 // increasedStake: uint64
	itob
	frame_dig 36 // roundsLeftInBin: uint64
	itob
	b*
	b+
	dup
	bitlen
	int 128
	<=

	// this.stakeAccumulator.value + (increasedStake as uint128) * (roundsLeftInBin as uint128) overflowed 128 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 16
	-
	swap
	substring3
	app_global_put

	// examples/reti/stakingPool.algo.ts:841
	// this.rewardAccumulator.value = this.rewardAccumulator.value + increasedStake
	byte 0x726577617264416363756d756c61746f72 // "rewardAccumulator"
	dup
	app_global_get
	frame_dig 22 // increasedStake: uint64
	+
	app_global_put

	// examples/reti/stakingPool.algo.ts:847
	// sendMethodCall<typeof ValidatorRegistry.prototype.stakeUpdatedViaRewards>({
	//       applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//       methodArgs: [
	//         { id: this.validatorId.value, poolId: this.poolId.value, poolAppId: this.app.id },
	//         increasedStake,
	//         tokenRewardPaidOut,
	//         validatorCommissionPaidOut,
	//         excessToFeeSink,
	//       ],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	pushbytes 0x418fcefc // method "stakeUpdatedViaRewards((uint64,uint64,uint64),uint64,uint64,uint64,uint64)void"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:848
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:849
	// methodArgs: [
	//         { id: this.validatorId.value, poolId: this.poolId.value, poolAppId: this.app.id },
	//         increasedStake,
	//         tokenRewardPaidOut,
	//         validatorCommissionPaidOut,
	//         excessToFeeSink,
	//       ]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	itob
	concat
	txna Applications 0
	itob
	concat
	itxn_field ApplicationArgs
	frame_dig 22 // increasedStake: uint64
	itob
	itxn_field ApplicationArgs
	frame_dig 15 // tokenRewardPaidOut: uint64
	itob
	itxn_field ApplicationArgs
	frame_dig 16 // validatorCommissionPaidOut: uint64
	itob
	itxn_field ApplicationArgs
	frame_dig 17 // excessToFeeSink: uint64
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// goOnline(pay,byte[],byte[],byte[],uint64,uint64,uint64)void
*abi_route_goOnline:
	// voteKeyDilution: uint64
	txna ApplicationArgs 6
	btoi

	// voteLast: uint64
	txna ApplicationArgs 5
	btoi

	// voteFirst: uint64
	txna ApplicationArgs 4
	btoi

	// stateProofPK: byte[]
	txna ApplicationArgs 3
	extract 2 0

	// selectionPK: byte[]
	txna ApplicationArgs 2
	extract 2 0

	// votePK: byte[]
	txna ApplicationArgs 1
	extract 2 0

	// feePayment: pay
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// argument 6 (feePayment) for goOnline must be a pay transaction
	assert

	// execute goOnline(pay,byte[],byte[],byte[],uint64,uint64,uint64)void
	callsub goOnline
	int 1
	return

// goOnline(feePayment: PayTxn, votePK: bytes, selectionPK: bytes, stateProofPK: bytes, voteFirst: uint64, voteLast: uint64, voteKeyDilution: uint64): void
//
// Registers a staking pool key online against a participation key.
// [ ONLY OWNER OR MANAGER CAN CALL ]
//
// @param {PayTxn} feePayment - payment to cover extra fee of going online if offline - or 0 if not renewal
// @param {bytes} votePK - The vote public key.
// @param {bytes} selectionPK - The selection public key.
// @param {bytes} stateProofPK - The state proof public key.
// @param {uint64} voteFirst - The first vote index.
// @param {uint64} voteLast - The last vote index.
// @param {uint64} voteKeyDilution - The vote key dilution value.
// @throws {Error} Will throw an error if the caller is not the owner or a manager.
goOnline:
	proto 7 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/reti/stakingPool.algo.ts:881
	// assert(this.isOwnerOrManagerCaller(), 'can only be called by owner or manager of validator')
	callsub isOwnerOrManagerCaller

	// can only be called by owner or manager of validator
	assert

	// examples/reti/stakingPool.algo.ts:882
	// extraFee = this.getGoOnlineFee()
	callsub getGoOnlineFee
	frame_bury 0 // extraFee: uint64

	// examples/reti/stakingPool.algo.ts:883
	// verifyPayTxn(feePayment, { receiver: this.app.address, amount: extraFee })
	// verify receiver
	frame_dig -1 // feePayment: PayTxn
	gtxns Receiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"feePayment","field":"receiver","expected":"this.app.address"}
	assert

	// verify amount
	frame_dig -1 // feePayment: PayTxn
	gtxns Amount
	frame_dig 0 // extraFee: uint64
	==

	// transaction verification failed: {"txn":"feePayment","field":"amount","expected":"extraFee"}
	assert

	// examples/reti/stakingPool.algo.ts:884
	// sendOnlineKeyRegistration({
	//       votePK: votePK,
	//       selectionPK: selectionPK,
	//       stateProofPK: stateProofPK,
	//       voteFirst: voteFirst,
	//       voteLast: voteLast,
	//       voteKeyDilution: voteKeyDilution,
	//       fee: this.getGoOnlineFee(),
	//     })
	itxn_begin
	pushint 2 // keyreg
	itxn_field TypeEnum

	// examples/reti/stakingPool.algo.ts:885
	// votePK: votePK
	frame_dig -2 // votePK: bytes
	itxn_field VotePK

	// examples/reti/stakingPool.algo.ts:886
	// selectionPK: selectionPK
	frame_dig -3 // selectionPK: bytes
	itxn_field SelectionPK

	// examples/reti/stakingPool.algo.ts:887
	// stateProofPK: stateProofPK
	frame_dig -4 // stateProofPK: bytes
	itxn_field StateProofPK

	// examples/reti/stakingPool.algo.ts:888
	// voteFirst: voteFirst
	frame_dig -5 // voteFirst: uint64
	itxn_field VoteFirst

	// examples/reti/stakingPool.algo.ts:889
	// voteLast: voteLast
	frame_dig -6 // voteLast: uint64
	itxn_field VoteLast

	// examples/reti/stakingPool.algo.ts:890
	// voteKeyDilution: voteKeyDilution
	frame_dig -7 // voteKeyDilution: uint64
	itxn_field VoteKeyDilution

	// examples/reti/stakingPool.algo.ts:891
	// fee: this.getGoOnlineFee()
	callsub getGoOnlineFee
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// goOffline()void
*abi_route_goOffline:
	// execute goOffline()void
	callsub goOffline
	int 1
	return

// goOffline(): void
//
// Marks a staking pool key OFFLINE.
// [ ONLY OWNER OR MANAGER CAN CALL ]
goOffline:
	proto 0 0

	// *if46_condition
	// examples/reti/stakingPool.algo.ts:903
	// this.txn.sender !== AppID.fromUint64(this.creatingValidatorContractAppId.value).address
	txn Sender
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	app_params_get AppAddress
	pop
	!=
	bz *if46_end

	// *if46_consequent
	// examples/reti/stakingPool.algo.ts:904
	// assert(this.isOwnerOrManagerCaller(), 'can only be called by owner or manager of validator')
	callsub isOwnerOrManagerCaller

	// can only be called by owner or manager of validator
	assert

*if46_end:
	// examples/reti/stakingPool.algo.ts:907
	// sendOfflineKeyRegistration({})
	itxn_begin
	pushint 2 // keyreg
	itxn_field TypeEnum

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// linkToNFD(uint64,string)void
*abi_route_linkToNFD:
	// nfdName: string
	txna ApplicationArgs 2
	extract 2 0

	// nfdAppId: uint64
	txna ApplicationArgs 1
	btoi

	// execute linkToNFD(uint64,string)void
	callsub linkToNFD
	int 1
	return

// linkToNFD(nfdAppId: uint64, nfdName: string): void
linkToNFD:
	proto 2 0

	// examples/reti/stakingPool.algo.ts:914
	// assert(this.isOwnerOrManagerCaller(), 'can only be called by owner or manager of validator')
	callsub isOwnerOrManagerCaller

	// can only be called by owner or manager of validator
	assert

	// examples/reti/stakingPool.algo.ts:916
	// sendAppCall({
	//       applicationID: AppID.fromUint64(this.nfdRegistryAppId),
	//       applicationArgs: ['verify_nfd_addr', nfdName, itob(nfdAppId), rawBytes(this.app.address)],
	//       applications: [AppID.fromUint64(nfdAppId)],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum

	// examples/reti/stakingPool.algo.ts:917
	// applicationID: AppID.fromUint64(this.nfdRegistryAppId)
	intc 0 // TMPL_nfdRegistryAppId
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:918
	// applicationArgs: ['verify_nfd_addr', nfdName, itob(nfdAppId), rawBytes(this.app.address)]
	pushbytes 0x7665726966795f6e66645f61646472 // "verify_nfd_addr"
	itxn_field ApplicationArgs
	frame_dig -2 // nfdName: string
	itxn_field ApplicationArgs
	frame_dig -1 // nfdAppId: uint64
	itob
	itxn_field ApplicationArgs
	global CurrentApplicationAddress
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:919
	// applications: [AppID.fromUint64(nfdAppId)]
	frame_dig -1 // nfdAppId: uint64
	itxn_field Applications

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// proxiedSetTokenPayoutRatio((uint64,uint64,uint64))(uint64[24],uint64)
*abi_route_proxiedSetTokenPayoutRatio:
	// The ABI return prefix
	byte 0x151f7c75

	// poolKey: (uint64,uint64,uint64)
	txna ApplicationArgs 1
	dup
	len
	pushint 24
	==

	// argument 0 (poolKey) for proxiedSetTokenPayoutRatio must be a (uint64,uint64,uint64)
	assert

	// execute proxiedSetTokenPayoutRatio((uint64,uint64,uint64))(uint64[24],uint64)
	callsub proxiedSetTokenPayoutRatio
	concat
	log
	int 1
	return

// proxiedSetTokenPayoutRatio(poolKey: ValidatorPoolKey): PoolTokenPayoutRatio
//
// proxiedSetTokenPayoutRatio is meant to be called by pools != 1 - calling US, pool #1
// We need to verify that we are in fact being called by another of OUR pools (not us)
// and then we'll call the validator on their behalf to update the token payouts
// @param poolKey - ValidatorPoolKey tuple
proxiedSetTokenPayoutRatio:
	proto 1 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/reti/stakingPool.algo.ts:930
	// assert(this.validatorId.value === poolKey.id, 'caller must be part of same validator set!')
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	==

	// caller must be part of same validator set!
	assert

	// examples/reti/stakingPool.algo.ts:931
	// assert(this.poolId.value === 1, 'callee must be pool 1')
	byte 0x706f6f6c4964 // "poolId"
	app_global_get
	int 1
	==

	// callee must be pool 1
	assert

	// examples/reti/stakingPool.algo.ts:932
	// assert(poolKey.poolId !== 1, 'caller must NOT be pool 1')
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	!=

	// caller must NOT be pool 1
	assert

	// examples/reti/stakingPool.algo.ts:934
	// callerPoolAppID = sendMethodCall<typeof ValidatorRegistry.prototype.getPoolAppId>({
	//       applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//       methodArgs: [poolKey.id, poolKey.poolId],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0x572767d1 // method "getPoolAppId(uint64,uint64)uint64"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:935
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:936
	// methodArgs: [poolKey.id, poolKey.poolId]
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	itxn_field ApplicationArgs
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0
	btoi
	frame_bury 0 // callerPoolAppID: uint64

	// examples/reti/stakingPool.algo.ts:938
	// assert(callerPoolAppID === poolKey.poolAppId)
	frame_dig 0 // callerPoolAppID: uint64
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 16 8
	btoi
	==
	assert

	// examples/reti/stakingPool.algo.ts:939
	// assert(this.txn.sender === AppID.fromUint64(poolKey.poolAppId).address)
	txn Sender
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 16 8
	btoi
	app_params_get AppAddress
	pop
	==
	assert

	// examples/reti/stakingPool.algo.ts:941
	// return sendMethodCall<typeof ValidatorRegistry.prototype.setTokenPayoutRatio>({
	//       applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//       methodArgs: [this.validatorId.value],
	//     });
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0x4df8d86e // method "setTokenPayoutRatio(uint64)(uint64[24],uint64)"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:942
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:943
	// methodArgs: [this.validatorId.value]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0

	// set the subroutine return value
	frame_bury 0
	retsub

// isOwnerOrManagerCaller(): boolean
isOwnerOrManagerCaller:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/reti/stakingPool.algo.ts:948
	// OwnerAndManager = sendMethodCall<typeof ValidatorRegistry.prototype.getValidatorOwnerAndManager>({
	//       applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value),
	//       methodArgs: [this.validatorId.value],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	pushbytes 0x2fa22c4b // method "getValidatorOwnerAndManager(uint64)(address,address)"
	itxn_field ApplicationArgs

	// examples/reti/stakingPool.algo.ts:949
	// applicationID: AppID.fromUint64(this.creatingValidatorContractAppId.value)
	byte 0x63726561746f72417070 // "creatorApp"
	app_global_get
	itxn_field ApplicationID

	// examples/reti/stakingPool.algo.ts:950
	// methodArgs: [this.validatorId.value]
	byte 0x76616c696461746f724964 // "validatorId"
	app_global_get
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0
	frame_bury 0 // OwnerAndManager: (address,address)

	// examples/reti/stakingPool.algo.ts:952
	// return this.txn.sender === OwnerAndManager[0] || this.txn.sender === OwnerAndManager[1];
	txn Sender
	frame_dig 0 // OwnerAndManager: (address,address)
	extract 0 32
	==
	dup
	bnz *skip_or2
	txn Sender
	frame_dig 0 // OwnerAndManager: (address,address)
	extract 32 32
	==
	||

*skip_or2:
	// set the subroutine return value
	frame_bury 0
	retsub

// getFeeSink(): Address
getFeeSink:
	proto 0 1

	// examples/reti/stakingPool.algo.ts:956
	// return this.feeSinkAddr;
	bytec 0 // TMPL_feeSinkAddr
	retsub

// algoSaturationLevel(): uint64
//
// Returns the maximum allowed stake per validator based on a percentage of all current online stake before
// the validator is considered saturated - where rewards are diminished.
algoSaturationLevel:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/reti/stakingPool.algo.ts:966
	// online = this.getCurrentOnlineStake()
	callsub getCurrentOnlineStake
	frame_bury 0 // online: uint64

	// examples/reti/stakingPool.algo.ts:968
	// return wideRatio([online, MAX_VALIDATOR_SOFT_PCT_OF_ONLINE_1DECIMAL], [1000]);
	frame_dig 0 // online: uint64
	pushint 100
	mulw
	int 0
	int 1000
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert

	// set the subroutine return value
	frame_bury 0
	retsub

// getGoOnlineFee(): uint64
getGoOnlineFee:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/reti/stakingPool.algo.ts:975
	// isOnline = false
	int 0
	frame_bury 0 // isOnline: bool

	// *if47_condition
	// examples/reti/stakingPool.algo.ts:976
	// !isOnline
	frame_dig 0 // isOnline: bool
	!
	bz *if47_end

	// *if47_consequent
	// examples/reti/stakingPool.algo.ts:978
	// return 2_000_000;
	pushint 2_000_000
	b *getGoOnlineFee*return

*if47_end:
	// examples/reti/stakingPool.algo.ts:980
	// return 0;
	int 0

*getGoOnlineFee*return:
	// set the subroutine return value
	frame_bury 0
	retsub

// getCurrentOnlineStake(): uint64
getCurrentOnlineStake:
	proto 0 1

	// examples/reti/stakingPool.algo.ts:985
	// return 2_000_000_000_000_000;
	pushint 2_000_000_000_000_000
	retsub

// checkIfBinClosed(): void
//
// Checks if the current round is in a 'new calculation bin' (approximately daily)
checkIfBinClosed:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 4

	// examples/reti/stakingPool.algo.ts:992
	// currentBinSize = this.roundsPerDay.value as uint128
	byte 0x726f756e6473506572446179 // "roundsPerDay"
	app_global_get
	itob
	frame_bury 0 // currentBinSize: unsafe uint128

	// *if48_condition
	// examples/reti/stakingPool.algo.ts:993
	// globals.round >= this.binRoundStart.value + (currentBinSize as uint64)
	global Round
	byte 0x62696e526f756e645374617274 // "binRoundStart"
	app_global_get
	frame_dig 0 // currentBinSize: unsafe uint128
	dup
	bitlen
	int 64
	<=

	// currentBinSize as uint64 overflowed 64 bits
	assert
	pushbytes 0xFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	pushint 8
	-
	swap
	substring3
	btoi
	+
	>=
	bz *if48_end

	// *if48_consequent
	// *if49_condition
	// examples/reti/stakingPool.algo.ts:994
	// globals.opcodeBudget < 300
	global OpcodeBudget
	int 300
	<
	bz *if49_end

	// *if49_consequent
	// examples/reti/stakingPool.algo.ts:995
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	pushint 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

*if49_end:
	// examples/reti/stakingPool.algo.ts:997
	// approxRoundsPerYear: uint128 = currentBinSize * (365 as uint128)
	frame_dig 0 // currentBinSize: unsafe uint128
	pushbytes 0x0000000000000000000000000000016d
	b*
	dup
	bitlen
	int 128
	<=

	// currentBinSize * (365 as uint128) overflowed 128 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 16
	-
	swap
	substring3
	frame_bury 1 // approxRoundsPerYear: uint128

	// examples/reti/stakingPool.algo.ts:998
	// avgStake: uint128 = this.stakeAccumulator.value / currentBinSize
	byte 0x7374616b65416363756d756c61746f72 // "stakeAccumulator"
	app_global_get
	frame_dig 0 // currentBinSize: unsafe uint128
	b/
	dup
	bitlen
	int 128
	<=

	// this.stakeAccumulator.value / currentBinSize overflowed 128 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 16
	-
	swap
	substring3
	frame_bury 2 // avgStake: uint128

	// *if50_condition
	// examples/reti/stakingPool.algo.ts:999
	// avgStake !== 0
	frame_dig 2 // avgStake: uint128
	byte 0x00000000000000000000000000000000
	b!=
	bz *if50_end

	// *if50_consequent
	// examples/reti/stakingPool.algo.ts:1003
	// apr: uint128 =
	//           (((this.rewardAccumulator.value as uint128) * (10000 as uint128)) / avgStake) *
	//           (approxRoundsPerYear / currentBinSize)
	byte 0x726577617264416363756d756c61746f72 // "rewardAccumulator"
	app_global_get
	itob
	pushbytes 0x00000000000000000000000000002710
	b*
	frame_dig 2 // avgStake: uint128
	b/
	frame_dig 1 // approxRoundsPerYear: uint128
	frame_dig 0 // currentBinSize: unsafe uint128
	b/
	b*
	dup
	bitlen
	int 128
	<=

	// (((this.rewardAccumulator.value as uint128) * (10000 as uint128)) / avgStake) *\n          (approxRoundsPerYear / currentBinSize) overflowed 128 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 16
	-
	swap
	substring3
	frame_bury 3 // apr: uint128

	// examples/reti/stakingPool.algo.ts:1007
	// alpha: uint128 = 10 as uint128
	pushbytes 0x0000000000000000000000000000000a
	frame_bury 4 // alpha: unsafe uint128

	// *if51_condition
	// examples/reti/stakingPool.algo.ts:1009
	// avgStake > 300000000000
	frame_dig 2 // avgStake: uint128
	pushbytes 0x000000000000000000000045d964b800
	b>
	bz *if51_end

	// *if51_consequent
	// examples/reti/stakingPool.algo.ts:1010
	// alpha = 90 as uint128
	pushbytes 0x0000000000000000000000000000005a
	frame_bury 4 // alpha: unsafe uint128

*if51_end:
	// examples/reti/stakingPool.algo.ts:1012
	// this.weightedMovingAverage.value =
	//           (this.weightedMovingAverage.value * ((100 as uint128) - alpha)) / (100 as uint128) +
	//           (apr * alpha) / (100 as uint128)
	byte 0x65776d61 // "ewma"
	dup
	app_global_get
	byte 0x00000000000000000000000000000064
	frame_dig 4 // alpha: unsafe uint128
	b-
	b*
	byte 0x00000000000000000000000000000064
	b/
	frame_dig 3 // apr: uint128
	frame_dig 4 // alpha: unsafe uint128
	b*
	byte 0x00000000000000000000000000000064
	b/
	b+
	dup
	bitlen
	int 128
	<=

	// (this.weightedMovingAverage.value * ((100 as uint128) - alpha)) / (100 as uint128) +\n          (apr * alpha) / (100 as uint128) overflowed 128 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 16
	-
	swap
	substring3
	app_global_put

*if50_end:
	// examples/reti/stakingPool.algo.ts:1018
	// this.setRoundsPerDay()
	callsub setRoundsPerDay

	// examples/reti/stakingPool.algo.ts:1019
	// this.stakeAccumulator.value = (this.totalAlgoStaked.value as uint128) * (this.roundsPerDay.value as uint128)
	byte 0x7374616b65416363756d756c61746f72 // "stakeAccumulator"
	byte 0x7374616b6564 // "staked"
	app_global_get
	itob
	byte 0x726f756e6473506572446179 // "roundsPerDay"
	app_global_get
	itob
	b*
	dup
	bitlen
	int 128
	<=

	// (this.totalAlgoStaked.value as uint128) * (this.roundsPerDay.value as uint128) overflowed 128 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 16
	-
	swap
	substring3
	app_global_put

	// examples/reti/stakingPool.algo.ts:1020
	// this.rewardAccumulator.value = 0
	byte 0x726577617264416363756d756c61746f72 // "rewardAccumulator"
	int 0
	app_global_put

	// examples/reti/stakingPool.algo.ts:1021
	// this.binRoundStart.value = globals.round - (globals.round % this.roundsPerDay.value)
	byte 0x62696e526f756e645374617274 // "binRoundStart"
	global Round
	global Round
	byte 0x726f756e6473506572446179 // "roundsPerDay"
	app_global_get
	%
	-
	app_global_put

*if48_end:
	retsub

// setRoundsPerDay(): void
setRoundsPerDay:
	proto 0 0

	// examples/reti/stakingPool.algo.ts:1026
	// this.roundsPerDay.value = AVG_ROUNDS_PER_DAY
	byte 0x726f756e6473506572446179 // "roundsPerDay"
	pushint 30857
	app_global_put
	retsub

*create_NoOp:
	pushbytes 0x59e90aa6 // method "createApplication(uint64,uint64,uint64,uint64)void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x3172ca9d // method "gas()void"
	pushbytes 0x47cfcc04 // method "initStorage(pay)void"
	pushbytes 0xf9c70cbd // method "addStake(pay,address)uint64"
	pushbytes 0x421b5abe // method "removeStake(address,uint64)void"
	pushbytes 0xf5892d56 // method "claimTokens()void"
	pushbytes 0x5cfbb057 // method "getStakerInfo(address)(address,uint64,uint64,uint64,uint64)"
	pushbytes 0x63f3f28b // method "payTokenReward(address,uint64,uint64)void"
	pushbytes 0x86a3725c // method "updateAlgodVer(string)void"
	pushbytes 0xefc2608d // method "epochBalanceUpdate()void"
	pushbytes 0x400e14fb // method "goOnline(pay,byte[],byte[],byte[],uint64,uint64,uint64)void"
	pushbytes 0x51ef3b21 // method "goOffline()void"
	pushbytes 0xa24e2717 // method "linkToNFD(uint64,string)void"
	byte 0x0c2245e1 // method "proxiedSetTokenPayoutRatio((uint64,uint64,uint64))(uint64[24],uint64)"
	txna ApplicationArgs 0
	match *abi_route_gas *abi_route_initStorage *abi_route_addStake *abi_route_removeStake *abi_route_claimTokens *abi_route_getStakerInfo *abi_route_payTokenReward *abi_route_updateAlgodVer *abi_route_epochBalanceUpdate *abi_route_goOnline *abi_route_goOffline *abi_route_linkToNFD *abi_route_proxiedSetTokenPayoutRatio

	// this contract does not implement the given ABI method for call NoOp
	err

*call_UpdateApplication:
	pushbytes 0x46f76533 // method "updateApplication()void"
	txna ApplicationArgs 0
	match *abi_route_updateApplication

	// this contract does not implement the given ABI method for call UpdateApplication
	err", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "templateVariables": { diff --git a/examples/reti/artifacts/ValidatorRegistry.approval.teal b/examples/reti/artifacts/ValidatorRegistry.approval.teal index 17c8ab692..4e042990f 100644 --- a/examples/reti/artifacts/ValidatorRegistry.approval.teal +++ b/examples/reti/artifacts/ValidatorRegistry.approval.teal @@ -2,7 +2,7 @@ intcblock TMPL_nfdRegistryAppId 0 1 8 268 24 32 18 6 100000 260 700 242 900 3 1000000 2 10 252 bytecblock 0x76 0x706f6f6c54656d706c617465417070726f76616c4279746573 0x151f7c75 0x 0x6e756d5374616b657273 0x69735f76616c69645f6e66645f6170706964 0x7374616b6564 0x737073 0x692e6f776e65722e61 0x0000000000000000 0x0a8101 0x696e6974 0x6e756d56 0x00 0x63f3f28b -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/examples/reti/artifacts/ValidatorRegistry.arc32.json b/examples/reti/artifacts/ValidatorRegistry.arc32.json index 47e8f1281..1c95d7cf7 100644 --- a/examples/reti/artifacts/ValidatorRegistry.arc32.json +++ b/examples/reti/artifacts/ValidatorRegistry.arc32.json @@ -221,7 +221,7 @@ } }, "source": { - "approval": "#pragma version 10
intcblock TMPL_nfdRegistryAppId 0 1 8 268 24 32 18 6 100000 260 700 242 900 3 1000000 2 10 252
bytecblock 0x76 0x706f6f6c54656d706c617465417070726f76616c4279746573 0x151f7c75 0x 0x6e756d5374616b657273 0x69735f76616c69645f6e66645f6170706964 0x7374616b6564 0x737073 0x692e6f776e65722e61 0x0000000000000000 0x0a8101 0x696e6974 0x6e756d56 0x00 0x63f3f28b

// This TEAL was generated by TEALScript v0.104.1
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following lines of TEAL are used to initialize template variables in scratch slots
intc 0 // TMPL_nfdRegistryAppId

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
int 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *call_UpdateApplication *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// updateApplication()void
*abi_route_updateApplication:
	// execute updateApplication()void
	callsub updateApplication
	int 1
	return

// updateApplication(): void
updateApplication:
	proto 0 0

	// examples/reti/validatorRegistry.algo.ts:202
	// assert(this.txn.sender === Address.fromAddress('LZ4V2IRVLCXFJK4REJV4TAGEKEYTA2GMR6TC2344OB3L3AF3MWXZ6ZAFIQ'))
	txn Sender
	pushbytes 0x5e795d223558ae54ab91226bc980c451313068cc8fa62d6f9c7076bd80bb65af // addr "LZ4V2IRVLCXFJK4REJV4TAGEKEYTA2GMR6TC2344OB3L3AF3MWXZ6ZAFIQ"
	==
	assert

	// examples/reti/validatorRegistry.algo.ts:204
	// this.stakingPoolApprovalProgram.delete()
	byte 0x706f6f6c54656d706c617465417070726f76616c4279746573 // "poolTemplateApprovalBytes"
	box_del

	// examples/reti/validatorRegistry.algo.ts:205
	// this.stakingPoolInitialized.value = false
	byte 0x696e6974 // "init"
	int 0
	byte 0x00
	int 0
	uncover 2
	setbit
	app_global_put
	retsub

// createApplication()void
*abi_route_createApplication:
	// execute createApplication()void
	callsub createApplication
	int 1
	return

// createApplication(): void
createApplication:
	proto 0 0

	// examples/reti/validatorRegistry.algo.ts:209
	// this.stakingPoolInitialized.value = false
	byte 0x696e6974 // "init"
	int 0
	byte 0x00
	int 0
	uncover 2
	setbit
	app_global_put

	// examples/reti/validatorRegistry.algo.ts:210
	// this.numValidators.value = 0
	byte 0x6e756d56 // "numV"
	int 0
	app_global_put

	// examples/reti/validatorRegistry.algo.ts:211
	// this.numStakers.value = 0
	byte 0x6e756d5374616b657273 // "numStakers"
	int 0
	app_global_put

	// examples/reti/validatorRegistry.algo.ts:212
	// this.totalAlgoStaked.value = 0
	byte 0x7374616b6564 // "staked"
	int 0
	app_global_put
	retsub

// initStakingContract(uint64)void
*abi_route_initStakingContract:
	// approvalProgramSize: uint64
	txna ApplicationArgs 1
	btoi

	// execute initStakingContract(uint64)void
	callsub initStakingContract
	int 1
	return

// initStakingContract(approvalProgramSize: uint64): void
initStakingContract:
	proto 1 0

	// examples/reti/validatorRegistry.algo.ts:217
	// this.stakingPoolApprovalProgram.create(approvalProgramSize)
	byte 0x706f6f6c54656d706c617465417070726f76616c4279746573 // "poolTemplateApprovalBytes"
	frame_dig -1 // approvalProgramSize: uint64
	box_create
	pop
	retsub

// loadStakingContractData(uint64,byte[])void
*abi_route_loadStakingContractData:
	// data: byte[]
	txna ApplicationArgs 2
	extract 2 0

	// offset: uint64
	txna ApplicationArgs 1
	btoi

	// execute loadStakingContractData(uint64,byte[])void
	callsub loadStakingContractData
	int 1
	return

// loadStakingContractData(offset: uint64, data: bytes): void
loadStakingContractData:
	proto 2 0

	// examples/reti/validatorRegistry.algo.ts:221
	// assert(!this.stakingPoolInitialized.value)
	byte 0x696e6974 // "init"
	app_global_get
	int 0
	getbit
	!
	assert

	// examples/reti/validatorRegistry.algo.ts:222
	// this.stakingPoolApprovalProgram.replace(offset, data)
	byte 0x706f6f6c54656d706c617465417070726f76616c4279746573 // "poolTemplateApprovalBytes"
	frame_dig -1 // offset: uint64
	frame_dig -2 // data: bytes
	box_replace
	retsub

// finalizeStakingContract()void
*abi_route_finalizeStakingContract:
	// execute finalizeStakingContract()void
	callsub finalizeStakingContract
	int 1
	return

// finalizeStakingContract(): void
finalizeStakingContract:
	proto 0 0

	// examples/reti/validatorRegistry.algo.ts:226
	// this.stakingPoolInitialized.value = true
	byte 0x696e6974 // "init"
	int 1
	byte 0x00
	int 0
	uncover 2
	setbit
	app_global_put
	retsub

// gas()void
*abi_route_gas:
	// execute gas()void
	callsub gas
	int 1
	return

// gas(): void
//
// gas is a dummy no-op call that can be used to pool-up resource references and opcode cost
gas:
	proto 0 0
	retsub

// getMbrAmounts()(uint64,uint64,uint64,uint64)
*abi_route_getMbrAmounts:
	// The ABI return prefix
	byte 0x151f7c75

	// execute getMbrAmounts()(uint64,uint64,uint64,uint64)
	callsub getMbrAmounts
	concat
	log
	int 1
	return

// getMbrAmounts(): MbrAmounts
//
// Returns the MBR amounts needed for various actions:
// [
// addValidatorMbr: uint64 - mbr needed to add a new validator - paid to validator contract
// addPoolMbr: uint64 - mbr needed to add a new pool - paid to validator
// poolInitMbr: uint64 - mbr needed to initStorage() of pool - paid to pool itself
// addStakerMbr: uint64 - mbr staker needs to add to first staking payment (stays w/ validator)
// ]
getMbrAmounts:
	proto 0 1

	// examples/reti/validatorRegistry.algo.ts:246
	// return {
	//       addValidatorMbr: this.costForBoxStorage(1 /* v prefix */ + len<ValidatorIdType>() + len<ValidatorInfo>()),
	//       addPoolMbr: this.minBalanceForAccount(
	//         1,
	//         // we could calculate this directly by referencing the size of stakingPoolApprovalProgram but it would
	//         // mean our callers would have to reference the box AND buy up i/o - so just go max on extra pages
	//         3,
	//         0,
	//         0,
	//         0,
	//         StakingPool.schema.global.numUint,
	//         StakingPool.schema.global.numByteSlice
	//       ),
	//       poolInitMbr:
	//         ALGORAND_ACCOUNT_MIN_BALANCE +
	//         this.costForBoxStorage(7 /* 'stakers' name */ + len<StakedInfo>() * MAX_STAKERS_PER_POOL),
	//       addStakerMbr:
	//         // how much to charge for first time a staker adds stake - since we add a tracking box per staker
	//         this.costForBoxStorage(3 /* 'sps' prefix */ + len<Address>() + len<ValidatorPoolKey>() * MAX_POOLS_PER_STAKER), // size of key + all values
	//     };
	pushint 1101
	callsub costForBoxStorage
	itob
	int 3
	pushint 11
	int 0
	dupn 2
	int 3
	int 1
	callsub minBalanceForAccount
	itob
	concat
	int 100000
	pushint 12807
	callsub costForBoxStorage
	+
	itob
	concat
	pushint 179
	callsub costForBoxStorage
	itob
	concat
	retsub

// getProtocolConstraints()(uint64,uint64,uint64,uint64,uint64,uint64,uint64,uint64,uint64,uint64,uint64)
*abi_route_getProtocolConstraints:
	// The ABI return prefix
	byte 0x151f7c75

	// execute getProtocolConstraints()(uint64,uint64,uint64,uint64,uint64,uint64,uint64,uint64,uint64,uint64,uint64)
	callsub getProtocolConstraints
	concat
	log
	int 1
	return

// getProtocolConstraints(): Constraints
//
// Returns the protocol constraints so that UIs can limit what users specify for validator configuration parameters.
getProtocolConstraints:
	proto 0 1

	// examples/reti/validatorRegistry.algo.ts:272
	// return {
	//       epochPayoutRoundsMin: MIN_EPOCH_LENGTH,
	//       epochPayoutRoundsMax: MAX_EPOCH_LENGTH,
	//       minPctToValidatorWFourDecimals: MIN_PCT_TO_VALIDATOR,
	//       maxPctToValidatorWFourDecimals: MAX_PCT_TO_VALIDATOR,
	//       minEntryStake: MIN_ALGO_STAKE_PER_POOL,
	//       maxAlgoPerPool: this.maxAlgoAllowedPerPool(),
	//       maxAlgoPerValidator: this.maxAllowedStake(),
	//       amtConsideredSaturated: this.algoSaturationLevel(),
	//       maxNodes: MAX_NODES,
	//       maxPoolsPerNode: MAX_POOLS_PER_NODE,
	//       maxStakersPerPool: MAX_STAKERS_PER_POOL,
	//     };
	pushbytes 0x000000000000000100000000000f4240000000000000000000000000000f424000000000000f4240
	callsub maxAlgoAllowedPerPool
	itob
	concat
	callsub maxAllowedStake
	itob
	concat
	callsub algoSaturationLevel
	itob
	concat
	pushbytes 0x0000000000000008
	concat
	pushbytes 0x0000000000000003
	concat
	pushbytes 0x00000000000000c8
	concat
	retsub

// getNumValidators()uint64
*abi_route_getNumValidators:
	// The ABI return prefix
	byte 0x151f7c75

	// execute getNumValidators()uint64
	callsub getNumValidators
	itob
	concat
	log
	int 1
	return

// getNumValidators(): uint64
//
// Returns the current number of validators
getNumValidators:
	proto 0 1

	// examples/reti/validatorRegistry.algo.ts:292
	// return this.numValidators.value;
	byte 0x6e756d56 // "numV"
	app_global_get
	retsub

// getValidatorConfig(uint64)(uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
*abi_route_getValidatorConfig:
	// The ABI return prefix
	byte 0x151f7c75

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute getValidatorConfig(uint64)(uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	callsub getValidatorConfig
	concat
	log
	int 1
	return

// getValidatorConfig(validatorId: ValidatorIdType): ValidatorConfig
getValidatorConfig:
	proto 1 1

	// examples/reti/validatorRegistry.algo.ts:297
	// return this.validatorList(validatorId).value.config;
	int 0
	int 242
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	retsub

// getValidatorState(uint64)(uint16,uint64,uint64,uint64)
*abi_route_getValidatorState:
	// The ABI return prefix
	byte 0x151f7c75

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute getValidatorState(uint64)(uint16,uint64,uint64,uint64)
	callsub getValidatorState
	concat
	log
	int 1
	return

// getValidatorState(validatorId: ValidatorIdType): ValidatorCurState
getValidatorState:
	proto 1 1

	// examples/reti/validatorRegistry.algo.ts:302
	// return this.validatorList(validatorId).value.state;
	int 242 // headOffset
	pushint 26
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	retsub

// getValidatorOwnerAndManager(uint64)(address,address)
*abi_route_getValidatorOwnerAndManager:
	// The ABI return prefix
	byte 0x151f7c75

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute getValidatorOwnerAndManager(uint64)(address,address)
	callsub getValidatorOwnerAndManager
	concat
	log
	int 1
	return

// getValidatorOwnerAndManager(validatorId: ValidatorIdType): [Address, Address]
getValidatorOwnerAndManager:
	proto 1 1

	// examples/reti/validatorRegistry.algo.ts:307
	// return [this.validatorList(validatorId).value.config.owner, this.validatorList(validatorId).value.config.manager];
	int 8
	int 32
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	pushint 40
	int 32
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	concat
	retsub

// getPools(uint64)(uint64,uint16,uint64)[]
*abi_route_getPools:
	// The ABI return prefix
	byte 0x151f7c75

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute getPools(uint64)(uint64,uint16,uint64)[]
	callsub getPools
	dup
	len
	int 18
	/
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// getPools(validatorId: ValidatorIdType): PoolInfo[]
//
// Return list of all pools for this validator.
// @param {uint64} validatorId
// @return {PoolInfo[]} - array of pools
// Not callable from other contracts because >1K return but can be called w/ simulate which bumps log returns
getPools:
	proto 1 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// examples/reti/validatorRegistry.algo.ts:318
	// retData: PoolInfo[] = []
	byte 0x
	frame_bury 0 // retData: PoolInfo[]

	// examples/reti/validatorRegistry.algo.ts:319
	// poolSet = clone(this.validatorList(validatorId).value.pools)
	int 268 // headOffset
	pushint 432
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	frame_bury 1 // poolSet: (uint64,uint16,uint64)[24]

	// examples/reti/validatorRegistry.algo.ts:320
	// for (let i = 0; i < poolSet.length; i += 1)
	int 0
	frame_bury 2 // i: uint64

*for_0:
	// examples/reti/validatorRegistry.algo.ts:320
	// i < poolSet.length
	frame_dig 2 // i: uint64
	int 24
	<
	bz *for_0_end

	// *if0_condition
	// examples/reti/validatorRegistry.algo.ts:321
	// poolSet[i].poolAppId === 0
	frame_dig 1 // poolSet: (uint64,uint16,uint64)[24]
	frame_dig 2 // i: uint64
	int 18
	* // acc * typeLength
	int 0
	+
	int 8
	extract3
	btoi
	int 0
	==
	bz *if0_end

	// *if0_consequent
	b *for_0_end

*if0_end:
	// examples/reti/validatorRegistry.algo.ts:325
	// retData.push(poolSet[i])
	frame_dig 0 // retData: PoolInfo[]
	frame_dig 1 // poolSet: (uint64,uint16,uint64)[24]
	frame_dig 2 // i: uint64
	int 18
	* // acc * typeLength
	int 18
	extract3
	concat
	frame_bury 0 // retData: PoolInfo[]

*for_0_continue:
	// examples/reti/validatorRegistry.algo.ts:320
	// i += 1
	frame_dig 2 // i: uint64
	int 1
	+
	frame_bury 2 // i: uint64
	b *for_0

*for_0_end:
	// examples/reti/validatorRegistry.algo.ts:327
	// return retData;
	frame_dig 0 // retData: PoolInfo[]

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 2
	retsub

// getPoolAppId(uint64,uint64)uint64
*abi_route_getPoolAppId:
	// The ABI return prefix
	byte 0x151f7c75

	// poolId: uint64
	txna ApplicationArgs 2
	btoi

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute getPoolAppId(uint64,uint64)uint64
	callsub getPoolAppId
	itob
	concat
	log
	int 1
	return

// getPoolAppId(validatorId: uint64, poolId: uint64): uint64
getPoolAppId:
	proto 2 1

	// examples/reti/validatorRegistry.algo.ts:335
	// assert(
	//       poolId !== 0 && poolId <= this.validatorList(validatorId).value.pools.length,
	//       'pool id must be between 1 and number of pools for this validator'
	//     )
	frame_dig -2 // poolId: uint64
	int 0
	!=
	dup
	bz *skip_and0
	frame_dig -2 // poolId: uint64
	int 24
	<=
	&&

*skip_and0:
	// pool id must be between 1 and number of pools for this validator
	assert

	// examples/reti/validatorRegistry.algo.ts:339
	// return this.validatorList(validatorId).value.pools[poolId - 1].poolAppId;
	int 268 // headOffset
	frame_dig -2 // poolId: uint64
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 0
	+
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: uint64
	itob
	concat
	cover 2
	box_extract
	btoi
	retsub

// getPoolInfo((uint64,uint64,uint64))(uint64,uint16,uint64)
*abi_route_getPoolInfo:
	// The ABI return prefix
	byte 0x151f7c75

	// poolKey: (uint64,uint64,uint64)
	txna ApplicationArgs 1
	dup
	len
	int 24
	==

	// argument 0 (poolKey) for getPoolInfo must be a (uint64,uint64,uint64)
	assert

	// execute getPoolInfo((uint64,uint64,uint64))(uint64,uint16,uint64)
	callsub getPoolInfo
	concat
	log
	int 1
	return

// getPoolInfo(poolKey: ValidatorPoolKey): PoolInfo
getPoolInfo:
	proto 1 1

	// examples/reti/validatorRegistry.algo.ts:344
	// return this.validatorList(poolKey.id).value.pools[poolKey.poolId - 1];
	int 268 // headOffset
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 18
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	retsub

// getCurMaxStakePerPool(uint64)uint64
*abi_route_getCurMaxStakePerPool:
	// The ABI return prefix
	byte 0x151f7c75

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute getCurMaxStakePerPool(uint64)uint64
	callsub getCurMaxStakePerPool
	itob
	concat
	log
	int 1
	return

// getCurMaxStakePerPool(validatorId: ValidatorIdType): uint64
//
// Calculate the maximum stake per pool for a given validator.
// Normally this would be maxAlgoPerPool, but it should also never go above MaxAllowedStake / numPools so
// as pools are added the max allowed per pool can reduce.
//
// @param {ValidatorIdType} validatorId - The id of the validator.
getCurMaxStakePerPool:
	proto 1 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// examples/reti/validatorRegistry.algo.ts:355
	// numPools = this.validatorList(validatorId).value.state.numPools as uint64
	int 242
	int 2
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 0 // numPools: uint64

	// examples/reti/validatorRegistry.algo.ts:356
	// hardMaxDividedBetweenPools = this.maxAllowedStake() / numPools
	callsub maxAllowedStake
	frame_dig 0 // numPools: uint64
	/
	frame_bury 1 // hardMaxDividedBetweenPools: uint64

	// examples/reti/validatorRegistry.algo.ts:357
	// maxPerPool: uint64 = this.validatorList(validatorId).value.config.maxAlgoPerPool
	pushint 217
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 2 // maxPerPool: uint64

	// *if1_condition
	// examples/reti/validatorRegistry.algo.ts:358
	// maxPerPool === 0
	frame_dig 2 // maxPerPool: uint64
	int 0
	==
	bz *if1_end

	// *if1_consequent
	// examples/reti/validatorRegistry.algo.ts:359
	// maxPerPool = this.maxAlgoAllowedPerPool()
	callsub maxAlgoAllowedPerPool
	frame_bury 2 // maxPerPool: uint64

*if1_end:
	// *if2_condition
	// examples/reti/validatorRegistry.algo.ts:361
	// hardMaxDividedBetweenPools < maxPerPool
	frame_dig 1 // hardMaxDividedBetweenPools: uint64
	frame_dig 2 // maxPerPool: uint64
	<
	bz *if2_end

	// *if2_consequent
	// examples/reti/validatorRegistry.algo.ts:362
	// maxPerPool = hardMaxDividedBetweenPools
	frame_dig 1 // hardMaxDividedBetweenPools: uint64
	frame_bury 2 // maxPerPool: uint64

*if2_end:
	// examples/reti/validatorRegistry.algo.ts:364
	// return maxPerPool;
	frame_dig 2 // maxPerPool: uint64

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 2
	retsub

// doesStakerNeedToPayMBR(address)bool
*abi_route_doesStakerNeedToPayMBR:
	// The ABI return prefix
	byte 0x151f7c75

	// staker: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (staker) for doesStakerNeedToPayMBR must be a address
	assert

	// execute doesStakerNeedToPayMBR(address)bool
	callsub doesStakerNeedToPayMBR
	byte 0x00
	int 0
	uncover 2
	setbit
	concat
	log
	int 1
	return

// doesStakerNeedToPayMBR(staker: Address): boolean
//
// Helper callers can call w/ simulate to determine if 'AddStaker' MBR should be included w/ staking amount
// @param staker
doesStakerNeedToPayMBR:
	proto 1 1

	// examples/reti/validatorRegistry.algo.ts:373
	// return !this.stakerPoolSet(staker).exists;
	byte 0x737073 // "sps"
	frame_dig -1 // staker: Address
	concat
	box_len
	swap
	pop
	!
	retsub

// getStakedPoolsForAccount(address)(uint64,uint64,uint64)[]
*abi_route_getStakedPoolsForAccount:
	// The ABI return prefix
	byte 0x151f7c75

	// staker: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (staker) for getStakedPoolsForAccount must be a address
	assert

	// execute getStakedPoolsForAccount(address)(uint64,uint64,uint64)[]
	callsub getStakedPoolsForAccount
	dup
	len
	int 24
	/
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// getStakedPoolsForAccount(staker: Address): ValidatorPoolKey[]
//
// Retrieves the staked pools for an account.
//
// @param {Address} staker - The account to retrieve staked pools for.
// @return {ValidatorPoolKey[]} - The array of staked pools for the account.
getStakedPoolsForAccount:
	proto 1 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// *if3_condition
	// examples/reti/validatorRegistry.algo.ts:383
	// !this.stakerPoolSet(staker).exists
	byte 0x737073 // "sps"
	frame_dig -1 // staker: Address
	concat
	box_len
	swap
	pop
	!
	bz *if3_end

	// *if3_consequent
	// examples/reti/validatorRegistry.algo.ts:384
	// return [];
	byte 0x
	b *getStakedPoolsForAccount*return

*if3_end:
	// examples/reti/validatorRegistry.algo.ts:386
	// retData: ValidatorPoolKey[] = []
	byte 0x
	frame_bury 0 // retData: ValidatorPoolKey[]

	// examples/reti/validatorRegistry.algo.ts:387
	// poolSet = clone(this.stakerPoolSet(staker).value)
	byte 0x737073 // "sps"
	frame_dig -1 // staker: Address
	concat
	box_get

	// box value does not exist: this.stakerPoolSet(staker).value
	assert
	frame_bury 1 // poolSet: (uint64,uint64,uint64)[6]

	// examples/reti/validatorRegistry.algo.ts:388
	// for (let i = 0; i < poolSet.length; i += 1)
	int 0
	frame_bury 2 // i: uint64

*for_1:
	// examples/reti/validatorRegistry.algo.ts:388
	// i < poolSet.length
	frame_dig 2 // i: uint64
	int 6
	<
	bz *for_1_end

	// *if4_condition
	// examples/reti/validatorRegistry.algo.ts:389
	// poolSet[i].id !== 0
	frame_dig 1 // poolSet: (uint64,uint64,uint64)[6]
	frame_dig 2 // i: uint64
	int 24
	* // acc * typeLength
	int 0
	+
	int 8
	extract3
	btoi
	int 0
	!=
	bz *if4_end

	// *if4_consequent
	// examples/reti/validatorRegistry.algo.ts:390
	// retData.push(poolSet[i])
	frame_dig 0 // retData: ValidatorPoolKey[]
	frame_dig 1 // poolSet: (uint64,uint64,uint64)[6]
	frame_dig 2 // i: uint64
	int 24
	* // acc * typeLength
	int 24
	extract3
	concat
	frame_bury 0 // retData: ValidatorPoolKey[]

*if4_end:

*for_1_continue:
	// examples/reti/validatorRegistry.algo.ts:388
	// i += 1
	frame_dig 2 // i: uint64
	int 1
	+
	frame_bury 2 // i: uint64
	b *for_1

*for_1_end:
	// examples/reti/validatorRegistry.algo.ts:393
	// return retData;
	frame_dig 0 // retData: ValidatorPoolKey[]

*getStakedPoolsForAccount*return:
	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 2
	retsub

// getTokenPayoutRatio(uint64)(uint64[24],uint64)
*abi_route_getTokenPayoutRatio:
	// The ABI return prefix
	byte 0x151f7c75

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute getTokenPayoutRatio(uint64)(uint64[24],uint64)
	callsub getTokenPayoutRatio
	concat
	log
	int 1
	return

// getTokenPayoutRatio(validatorId: ValidatorIdType): PoolTokenPayoutRatio
//
// Retrieves the token payout ratio for a given validator - returning the pool ratios of whole so that token
// payouts across pools can be based on a stable snaphost of stake.
//
// @param {ValidatorIdType} validatorId - The id of the validator.
// @return {PoolTokenPayoutRatio} - The token payout ratio for the validator.
getTokenPayoutRatio:
	proto 1 1

	// examples/reti/validatorRegistry.algo.ts:405
	// return this.validatorList(validatorId).value.tokenPayoutRatio;
	int 700 // headOffset
	pushint 200
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	retsub

// getNodePoolAssignments(uint64)((uint64[3])[8])
*abi_route_getNodePoolAssignments:
	// The ABI return prefix
	byte 0x151f7c75

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute getNodePoolAssignments(uint64)((uint64[3])[8])
	callsub getNodePoolAssignments
	concat
	log
	int 1
	return

// getNodePoolAssignments(validatorId: uint64): NodePoolAssignmentConfig
getNodePoolAssignments:
	proto 1 1

	// examples/reti/validatorRegistry.algo.ts:410
	// assert(this.validatorList(validatorId).exists, "the specified validator id doesn't exist")
	byte 0x76 // "v"
	frame_dig -1 // validatorId: uint64
	itob
	concat
	box_len
	swap
	pop

	// the specified validator id doesn't exist
	assert

	// examples/reti/validatorRegistry.algo.ts:412
	// return this.validatorList(validatorId).value.nodePoolAssignments;
	int 900 // headOffset
	pushint 192
	byte 0x76 // "v"
	frame_dig -1 // validatorId: uint64
	itob
	concat
	cover 2
	box_extract
	retsub

// getNFDRegistryID()uint64
*abi_route_getNFDRegistryID:
	// The ABI return prefix
	byte 0x151f7c75

	// execute getNFDRegistryID()uint64
	callsub getNFDRegistryID
	itob
	concat
	log
	int 1
	return

// getNFDRegistryID(): uint64
getNFDRegistryID:
	proto 0 1

	// examples/reti/validatorRegistry.algo.ts:416
	// return this.nfdRegistryAppId;
	intc 0 // TMPL_nfdRegistryAppId
	retsub

// addValidator(pay,string,(uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64))uint64
*abi_route_addValidator:
	// The ABI return prefix
	byte 0x151f7c75

	// config: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	txna ApplicationArgs 2
	dup
	len
	int 242
	==

	// argument 0 (config) for addValidator must be a (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	assert

	// nfdName: string
	txna ApplicationArgs 1
	extract 2 0

	// mbrPayment: pay
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// argument 2 (mbrPayment) for addValidator must be a pay transaction
	assert

	// execute addValidator(pay,string,(uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64))uint64
	callsub addValidator
	itob
	concat
	log
	int 1
	return

// addValidator(mbrPayment: PayTxn, nfdName: string, config: ValidatorConfig): uint64
//
// Adds a new validator
// Requires at least 10 ALGO as the 'fee' for the transaction to help dissuade spammed validator adds.
//
// @param {PayTxn} mbrPayment payment from caller which covers mbr increase of new validator storage
// @param {string} nfdName (Optional) Name of nfd (used as double-check against id specified in config)
// @param {ValidatorConfig} config ValidatorConfig struct
// @returns {uint64} validator id
addValidator:
	proto 3 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/reti/validatorRegistry.algo.ts:428
	// this.validateConfig(config)
	frame_dig -3 // config: ValidatorConfig
	callsub validateConfig

	// examples/reti/validatorRegistry.algo.ts:429
	// assert(config.owner !== Address.zeroAddress)
	frame_dig -3 // config: ValidatorConfig
	extract 8 32
	global ZeroAddress
	!=
	assert

	// examples/reti/validatorRegistry.algo.ts:430
	// assert(config.manager !== Address.zeroAddress)
	frame_dig -3 // config: ValidatorConfig
	extract 40 32
	global ZeroAddress
	!=
	assert

	// examples/reti/validatorRegistry.algo.ts:431
	// assert(this.txn.sender === config.owner, 'sender must be owner to add new validator')
	txn Sender
	frame_dig -3 // config: ValidatorConfig
	extract 8 32
	==

	// sender must be owner to add new validator
	assert

	// examples/reti/validatorRegistry.algo.ts:433
	// verifyPayTxn(mbrPayment, { amount: this.getMbrAmounts().addValidatorMbr })
	// verify amount
	frame_dig -1 // mbrPayment: PayTxn
	gtxns Amount
	callsub getMbrAmounts
	extract 0 8
	btoi
	==

	// transaction verification failed: {"txn":"mbrPayment","field":"amount","expected":"this.getMbrAmounts().addValidatorMbr"}
	assert

	// examples/reti/validatorRegistry.algo.ts:435
	// assert(mbrPayment.fee > 10 * 1000000, 'fee must be 10 ALGO or more to prevent spamming of validators')
	frame_dig -1 // mbrPayment: PayTxn
	gtxns Fee
	pushint 10000000
	>

	// fee must be 10 ALGO or more to prevent spamming of validators
	assert

	// examples/reti/validatorRegistry.algo.ts:438
	// validatorId = this.numValidators.value + 1
	byte 0x6e756d56 // "numV"
	app_global_get
	int 1
	+
	frame_bury 0 // validatorId: uint64

	// examples/reti/validatorRegistry.algo.ts:439
	// this.numValidators.value = validatorId
	byte 0x6e756d56 // "numV"
	frame_dig 0 // validatorId: uint64
	app_global_put

	// examples/reti/validatorRegistry.algo.ts:441
	// this.validatorList(validatorId).create()
	byte 0x76 // "v"
	frame_dig 0 // validatorId: uint64
	itob
	concat
	pushint 1092
	box_create
	pop

	// examples/reti/validatorRegistry.algo.ts:442
	// this.validatorList(validatorId).value.config = config
	int 0
	frame_dig -3 // config: ValidatorConfig
	byte 0x76 // "v"
	frame_dig 0 // validatorId: uint64
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:443
	// this.validatorList(validatorId).value.config.id = validatorId
	int 0
	frame_dig 0 // validatorId: uint64
	itob
	byte 0x76 // "v"
	frame_dig 0 // validatorId: uint64
	itob
	concat
	cover 2
	box_replace

	// *if5_condition
	// examples/reti/validatorRegistry.algo.ts:446
	// config.nfdForInfo !== 0
	frame_dig -3 // config: ValidatorConfig
	extract 72 8
	btoi
	int 0
	!=
	bz *if5_end

	// *if5_consequent
	// examples/reti/validatorRegistry.algo.ts:448
	// sendAppCall({
	//         applicationID: AppID.fromUint64(this.nfdRegistryAppId),
	//         applicationArgs: ['is_valid_nfd_appid', nfdName, itob(config.nfdForInfo)],
	//         applications: [AppID.fromUint64(config.nfdForInfo)],
	//       })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum

	// examples/reti/validatorRegistry.algo.ts:449
	// applicationID: AppID.fromUint64(this.nfdRegistryAppId)
	intc 0 // TMPL_nfdRegistryAppId
	itxn_field ApplicationID

	// examples/reti/validatorRegistry.algo.ts:450
	// applicationArgs: ['is_valid_nfd_appid', nfdName, itob(config.nfdForInfo)]
	byte 0x69735f76616c69645f6e66645f6170706964 // "is_valid_nfd_appid"
	itxn_field ApplicationArgs
	frame_dig -2 // nfdName: string
	itxn_field ApplicationArgs
	frame_dig -3 // config: ValidatorConfig
	extract 72 8
	btoi
	itob
	itxn_field ApplicationArgs

	// examples/reti/validatorRegistry.algo.ts:451
	// applications: [AppID.fromUint64(config.nfdForInfo)]
	frame_dig -3 // config: ValidatorConfig
	extract 72 8
	btoi
	itxn_field Applications

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/validatorRegistry.algo.ts:453
	// assert(btoi(this.itxn.lastLog) === 1, "provided NFD isn't valid")
	itxn LastLog
	btoi
	int 1
	==

	// provided NFD isn't valid
	assert

	// examples/reti/validatorRegistry.algo.ts:455
	// assert(
	//         this.txn.sender === (AppID.fromUint64(config.nfdForInfo).globalState('i.owner.a') as Address),
	//         'If specifying NFD, account adding validator must be owner'
	//       )
	txn Sender
	frame_dig -3 // config: ValidatorConfig
	extract 72 8
	btoi
	byte 0x692e6f776e65722e61 // "i.owner.a"
	app_global_get_ex

	// global state value does not exist: AppID.fromUint64(config.nfdForInfo).globalState('i.owner.a')
	assert
	==

	// If specifying NFD, account adding validator must be owner
	assert

*if5_end:
	// *if6_condition
	// examples/reti/validatorRegistry.algo.ts:461
	// config.entryGatingType === GATING_TYPE_CREATED_BY_NFD_ADDRESSES ||
	//       config.entryGatingType === GATING_TYPE_SEGMENT_OF_NFD
	frame_dig -3 // config: ValidatorConfig
	extract 80 1
	btoi
	int 3
	==
	dup
	bnz *skip_or0
	frame_dig -3 // config: ValidatorConfig
	extract 80 1
	btoi
	pushint 4
	==
	||

*skip_or0:
	bz *if6_end

	// *if6_consequent
	// examples/reti/validatorRegistry.algo.ts:465
	// assert(this.isNFDAppIDValid(config.entryGatingAssets[0]), 'provided NFD App id for gating must be valid NFD')
	frame_dig -3 // config: ValidatorConfig
	extract 113 8
	btoi
	callsub isNFDAppIDValid

	// provided NFD App id for gating must be valid NFD
	assert

*if6_end:
	// examples/reti/validatorRegistry.algo.ts:468
	// return validatorId;
	frame_dig 0 // validatorId: uint64

	// set the subroutine return value
	frame_bury 0
	retsub

// changeValidatorManager(uint64,address)void
*abi_route_changeValidatorManager:
	// manager: address
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (manager) for changeValidatorManager must be a address
	assert

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute changeValidatorManager(uint64,address)void
	callsub changeValidatorManager
	int 1
	return

// changeValidatorManager(validatorId: ValidatorIdType, manager: Address): void
//
// Changes the Validator manager for a specific Validator id.
// [ ONLY OWNER CAN CHANGE ]
//
// @param {ValidatorIdType} validatorId - The id of the validator to change the manager for.
// @param {Address} manager - The new manager address.
changeValidatorManager:
	proto 2 0

	// examples/reti/validatorRegistry.algo.ts:479
	// assert(
	//       this.txn.sender === this.validatorList(validatorId).value.config.owner,
	//       'can only be called by validator owner'
	//     )
	txn Sender
	int 8
	int 32
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	==

	// can only be called by validator owner
	assert

	// examples/reti/validatorRegistry.algo.ts:483
	// this.validatorList(validatorId).value.config.manager = manager
	pushint 40
	frame_dig -2 // manager: Address
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace
	retsub

// changeValidatorSunsetInfo(uint64,uint64,uint64)void
*abi_route_changeValidatorSunsetInfo:
	// sunsettingTo: uint64
	txna ApplicationArgs 3
	btoi

	// sunsettingOn: uint64
	txna ApplicationArgs 2
	btoi

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute changeValidatorSunsetInfo(uint64,uint64,uint64)void
	callsub changeValidatorSunsetInfo
	int 1
	return

// changeValidatorSunsetInfo(validatorId: ValidatorIdType, sunsettingOn: uint64, sunsettingTo: ValidatorIdType): void
//
// Updates the sunset information for a given validator.
// [ ONLY OWNER CAN CHANGE ]
//
// @param {ValidatorIdType} validatorId - The id of the validator to update.
// @param {uint64} sunsettingOn - The new sunset timestamp.
// @param {uint64} sunsettingTo - The new sunset to validator id.
changeValidatorSunsetInfo:
	proto 3 0

	// examples/reti/validatorRegistry.algo.ts:495
	// assert(
	//       this.txn.sender === this.validatorList(validatorId).value.config.owner,
	//       'can only be called by validator owner'
	//     )
	txn Sender
	int 8
	int 32
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	==

	// can only be called by validator owner
	assert

	// examples/reti/validatorRegistry.algo.ts:499
	// this.validatorList(validatorId).value.config.sunsettingOn = sunsettingOn
	pushint 226
	frame_dig -2 // sunsettingOn: uint64
	itob
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:500
	// this.validatorList(validatorId).value.config.sunsettingTo = sunsettingTo
	pushint 234
	frame_dig -3 // sunsettingTo: ValidatorIdType
	itob
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace
	retsub

// changeValidatorNFD(uint64,uint64,string)void
*abi_route_changeValidatorNFD:
	// nfdName: string
	txna ApplicationArgs 3
	extract 2 0

	// nfdAppID: uint64
	txna ApplicationArgs 2
	btoi

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute changeValidatorNFD(uint64,uint64,string)void
	callsub changeValidatorNFD
	int 1
	return

// changeValidatorNFD(validatorId: ValidatorIdType, nfdAppID: uint64, nfdName: string): void
//
// Changes the NFD for a validator in the validatorList contract.
// [ ONLY OWNER CAN CHANGE ]
//
// @param {ValidatorIdType} validatorId - The id of the validator to update.
// @param {uint64} nfdAppID - The application id of the NFD to assign to the validator.
// @param {string} nfdName - The name of the NFD (which must match)
changeValidatorNFD:
	proto 3 0

	// examples/reti/validatorRegistry.algo.ts:513
	// assert(
	//       this.txn.sender === this.validatorList(validatorId).value.config.owner,
	//       'can only be called by validator owner'
	//     )
	txn Sender
	int 8
	int 32
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	==

	// can only be called by validator owner
	assert

	// examples/reti/validatorRegistry.algo.ts:518
	// sendAppCall({
	//       applicationID: AppID.fromUint64(this.nfdRegistryAppId),
	//       applicationArgs: ['is_valid_nfd_appid', nfdName, itob(nfdAppID)],
	//       applications: [AppID.fromUint64(nfdAppID)],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum

	// examples/reti/validatorRegistry.algo.ts:519
	// applicationID: AppID.fromUint64(this.nfdRegistryAppId)
	intc 0 // TMPL_nfdRegistryAppId
	itxn_field ApplicationID

	// examples/reti/validatorRegistry.algo.ts:520
	// applicationArgs: ['is_valid_nfd_appid', nfdName, itob(nfdAppID)]
	byte 0x69735f76616c69645f6e66645f6170706964 // "is_valid_nfd_appid"
	itxn_field ApplicationArgs
	frame_dig -3 // nfdName: string
	itxn_field ApplicationArgs
	frame_dig -2 // nfdAppID: uint64
	itob
	itxn_field ApplicationArgs

	// examples/reti/validatorRegistry.algo.ts:521
	// applications: [AppID.fromUint64(nfdAppID)]
	frame_dig -2 // nfdAppID: uint64
	itxn_field Applications

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/validatorRegistry.algo.ts:524
	// assert(
	//       this.txn.sender === (AppID.fromUint64(nfdAppID).globalState('i.owner.a') as Address),
	//       'If specifying NFD, account adding validator must be owner'
	//     )
	txn Sender
	frame_dig -2 // nfdAppID: uint64
	byte 0x692e6f776e65722e61 // "i.owner.a"
	app_global_get_ex

	// global state value does not exist: AppID.fromUint64(nfdAppID).globalState('i.owner.a')
	assert
	==

	// If specifying NFD, account adding validator must be owner
	assert

	// examples/reti/validatorRegistry.algo.ts:528
	// this.validatorList(validatorId).value.config.nfdForInfo = nfdAppID
	pushint 72
	frame_dig -2 // nfdAppID: uint64
	itob
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace
	retsub

// changeValidatorCommissionAddress(uint64,address)void
*abi_route_changeValidatorCommissionAddress:
	// commissionAddress: address
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (commissionAddress) for changeValidatorCommissionAddress must be a address
	assert

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute changeValidatorCommissionAddress(uint64,address)void
	callsub changeValidatorCommissionAddress
	int 1
	return

// changeValidatorCommissionAddress(validatorId: ValidatorIdType, commissionAddress: Address): void
//
// Change the commission address that validator rewards are sent to.
// [ ONLY OWNER CAN CHANGE ]
changeValidatorCommissionAddress:
	proto 2 0

	// examples/reti/validatorRegistry.algo.ts:536
	// assert(
	//       this.txn.sender === this.validatorList(validatorId).value.config.owner,
	//       'can only be called by validator owner'
	//     )
	txn Sender
	int 8
	int 32
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	==

	// can only be called by validator owner
	assert

	// examples/reti/validatorRegistry.algo.ts:540
	// assert(commissionAddress !== Address.zeroAddress)
	frame_dig -2 // commissionAddress: Address
	global ZeroAddress
	!=
	assert

	// examples/reti/validatorRegistry.algo.ts:541
	// this.validatorList(validatorId).value.config.validatorCommissionAddress = commissionAddress
	pushint 177
	frame_dig -2 // commissionAddress: Address
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace
	retsub

// changeValidatorRewardInfo(uint64,uint8,address,uint64[4],uint64,uint64)void
*abi_route_changeValidatorRewardInfo:
	// RewardPerPayout: uint64
	txna ApplicationArgs 6
	btoi

	// GatingAssetMinBalance: uint64
	txna ApplicationArgs 5
	btoi

	// EntryGatingAssets: uint64[4]
	txna ApplicationArgs 4
	dup
	len
	int 32
	==

	// argument 2 (EntryGatingAssets) for changeValidatorRewardInfo must be a uint64[4]
	assert

	// EntryGatingAddress: address
	txna ApplicationArgs 3
	dup
	len
	int 32
	==

	// argument 3 (EntryGatingAddress) for changeValidatorRewardInfo must be a address
	assert

	// EntryGatingType: uint8
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 4 (EntryGatingType) for changeValidatorRewardInfo must be a uint8
	assert
	btoi

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute changeValidatorRewardInfo(uint64,uint8,address,uint64[4],uint64,uint64)void
	callsub changeValidatorRewardInfo
	int 1
	return

// changeValidatorRewardInfo(validatorId: ValidatorIdType, EntryGatingType: uint8, EntryGatingAddress: Address, EntryGatingAssets: StaticArray<uint64, 4>, GatingAssetMinBalance: uint64, RewardPerPayout: uint64): void
//
// Allow the additional rewards (gating entry, additional token rewards) information be changed at will.
// [ ONLY OWNER CAN CHANGE ]
changeValidatorRewardInfo:
	proto 6 0

	// examples/reti/validatorRegistry.algo.ts:556
	// assert(
	//       this.txn.sender === this.validatorList(validatorId).value.config.owner,
	//       'can only be called by validator owner'
	//     )
	txn Sender
	int 8
	int 32
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	==

	// can only be called by validator owner
	assert

	// examples/reti/validatorRegistry.algo.ts:561
	// this.validatorList(validatorId).value.config.entryGatingType = EntryGatingType
	pushint 80
	frame_dig -2 // EntryGatingType: uint8
	itob
	extract 7 1
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:562
	// this.validatorList(validatorId).value.config.entryGatingAddress = EntryGatingAddress
	pushint 81
	frame_dig -3 // EntryGatingAddress: Address
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:563
	// this.validatorList(validatorId).value.config.entryGatingAssets = EntryGatingAssets
	pushint 113
	frame_dig -4 // EntryGatingAssets: StaticArray<uint64, 4>
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:564
	// this.validatorList(validatorId).value.config.gatingAssetMinBalance = GatingAssetMinBalance
	pushint 145
	frame_dig -5 // GatingAssetMinBalance: uint64
	itob
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:565
	// this.validatorList(validatorId).value.config.rewardPerPayout = RewardPerPayout
	pushint 161
	frame_dig -6 // RewardPerPayout: uint64
	itob
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace
	retsub

// addPool(pay,uint64,uint64)(uint64,uint64,uint64)
*abi_route_addPool:
	// The ABI return prefix
	byte 0x151f7c75

	// nodeNum: uint64
	txna ApplicationArgs 2
	btoi

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// mbrPayment: pay
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// argument 2 (mbrPayment) for addPool must be a pay transaction
	assert

	// execute addPool(pay,uint64,uint64)(uint64,uint64,uint64)
	callsub addPool
	concat
	log
	int 1
	return

// addPool(mbrPayment: PayTxn, validatorId: ValidatorIdType, nodeNum: uint64): ValidatorPoolKey
//
// Adds a new pool to a validator's pool set, returning the 'key' to reference the pool in the future for staking, etc.
// The caller must pay the cost of the validators MBR increase as well as the MBR that will be needed for the pool itself.
//
// [ ONLY OWNER OR MANAGER CAN call ]
// @param {PayTxn} mbrPayment payment from caller which covers mbr increase of adding a new pool
// @param {uint64} validatorId is id of validator to pool to (must be owner or manager)
// @param {uint64} nodeNum is node number to add to
// @returns {ValidatorPoolKey} pool key to created pool
addPool:
	proto 3 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// examples/reti/validatorRegistry.algo.ts:581
	// assert(
	//       this.txn.sender === this.validatorList(validatorId).value.config.owner ||
	//         this.txn.sender === this.validatorList(validatorId).value.config.manager,
	//       'can only be called by owner or manager of validator'
	//     )
	txn Sender
	int 8
	int 32
	byte 0x76 // "v"
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	==
	dup
	bnz *skip_or1
	txn Sender
	pushint 40
	int 32
	byte 0x76 // "v"
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	==
	||

*skip_or1:
	// can only be called by owner or manager of validator
	assert

	// examples/reti/validatorRegistry.algo.ts:588
	// verifyPayTxn(mbrPayment, { amount: this.getMbrAmounts().addPoolMbr, receiver: this.app.address })
	// verify amount
	frame_dig -1 // mbrPayment: PayTxn
	gtxns Amount
	callsub getMbrAmounts
	extract 8 8
	btoi
	==

	// transaction verification failed: {"txn":"mbrPayment","field":"amount","expected":"this.getMbrAmounts().addPoolMbr"}
	assert

	// verify receiver
	frame_dig -1 // mbrPayment: PayTxn
	gtxns Receiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"mbrPayment","field":"receiver","expected":"this.app.address"}
	assert

	// examples/reti/validatorRegistry.algo.ts:590
	// assert(this.validatorList(validatorId).exists, "specified validator id isn't valid")
	byte 0x76 // "v"
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	concat
	box_len
	swap
	pop

	// specified validator id isn't valid
	assert

	// examples/reti/validatorRegistry.algo.ts:592
	// numPools: uint64 = this.validatorList(validatorId).value.state.numPools as uint64
	int 242
	int 2
	byte 0x76 // "v"
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 0 // numPools: uint64

	// *if7_condition
	// examples/reti/validatorRegistry.algo.ts:593
	// (numPools as uint64) >= MAX_POOLS
	frame_dig 0 // numPools: uint64
	int 24
	>=
	bz *if7_end

	// *if7_consequent
	// already at max pool size
	err

*if7_end:
	// examples/reti/validatorRegistry.algo.ts:596
	// numPools += 1
	frame_dig 0 // numPools: uint64
	int 1
	+
	frame_bury 0 // numPools: uint64

	// examples/reti/validatorRegistry.algo.ts:599
	// sendAppCall({
	//       onCompletion: OnCompletion.NoOp,
	//       approvalProgram: [
	//         this.stakingPoolApprovalProgram.extract(0, 4096),
	//         this.stakingPoolApprovalProgram.extract(4096, this.stakingPoolApprovalProgram.size - 4096),
	//       ],
	//       clearStateProgram: StakingPool.clearProgram(),
	//       globalNumUint: StakingPool.schema.global.numUint,
	//       globalNumByteSlice: StakingPool.schema.global.numByteSlice,
	//       extraProgramPages: 3,
	//       applicationArgs: [
	//         // creatingContractID, validatorId, poolId, minEntryStake
	//         method('createApplication(uint64,uint64,uint64,uint64)void'),
	//         itob(this.app.id),
	//         itob(validatorId),
	//         itob(numPools as uint64),
	//         itob(this.validatorList(validatorId).value.config.minEntryStake),
	//       ],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum

	// examples/reti/validatorRegistry.algo.ts:600
	// onCompletion: OnCompletion.NoOp
	int 0 // NoOp
	itxn_field OnCompletion

	// examples/reti/validatorRegistry.algo.ts:601
	// approvalProgram: [
	//         this.stakingPoolApprovalProgram.extract(0, 4096),
	//         this.stakingPoolApprovalProgram.extract(4096, this.stakingPoolApprovalProgram.size - 4096),
	//       ]
	byte 0x706f6f6c54656d706c617465417070726f76616c4279746573 // "poolTemplateApprovalBytes"
	int 0
	pushint 4096
	box_extract
	itxn_field ApprovalProgramPages
	byte 0x706f6f6c54656d706c617465417070726f76616c4279746573 // "poolTemplateApprovalBytes"
	pushint 4096
	byte 0x706f6f6c54656d706c617465417070726f76616c4279746573 // "poolTemplateApprovalBytes"
	box_len

	// box value does not exist: this.stakingPoolApprovalProgram.size
	assert
	pushint 4096
	-
	box_extract
	itxn_field ApprovalProgramPages

	// examples/reti/validatorRegistry.algo.ts:605
	// clearStateProgram: StakingPool.clearProgram()
	pushbytes 0x0a
	itxn_field ClearStateProgram

	// examples/reti/validatorRegistry.algo.ts:606
	// globalNumUint: StakingPool.schema.global.numUint
	pushint 11
	itxn_field GlobalNumUint

	// examples/reti/validatorRegistry.algo.ts:607
	// globalNumByteSlice: StakingPool.schema.global.numByteSlice
	int 3
	itxn_field GlobalNumByteSlice

	// examples/reti/validatorRegistry.algo.ts:608
	// extraProgramPages: 3
	int 3
	itxn_field ExtraProgramPages

	// examples/reti/validatorRegistry.algo.ts:609
	// applicationArgs: [
	//         // creatingContractID, validatorId, poolId, minEntryStake
	//         method('createApplication(uint64,uint64,uint64,uint64)void'),
	//         itob(this.app.id),
	//         itob(validatorId),
	//         itob(numPools as uint64),
	//         itob(this.validatorList(validatorId).value.config.minEntryStake),
	//       ]
	pushbytes 0x59e90aa6 // method "createApplication(uint64,uint64,uint64,uint64)void"
	itxn_field ApplicationArgs
	txna Applications 0
	itob
	itxn_field ApplicationArgs
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	itxn_field ApplicationArgs
	frame_dig 0 // numPools: uint64
	itob
	itxn_field ApplicationArgs
	pushint 209
	int 8
	byte 0x76 // "v"
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/validatorRegistry.algo.ts:619
	// this.validatorList(validatorId).value.state.numPools = numPools as uint16
	int 242
	frame_dig 0 // numPools: uint64
	itob
	extract 6 2
	byte 0x76 // "v"
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:622
	// poolAppId = this.itxn.createdApplicationID.id
	itxn CreatedApplicationID
	frame_bury 1 // poolAppId: uint64

	// examples/reti/validatorRegistry.algo.ts:623
	// this.validatorList(validatorId).value.pools[numPools - 1].poolAppId = poolAppId
	int 268 // headOffset
	frame_dig 0 // numPools: uint64
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 0
	+
	frame_dig 1 // poolAppId: uint64
	itob
	byte 0x76 // "v"
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:624
	// this.addPoolToNode(validatorId, poolAppId, nodeNum)
	frame_dig -3 // nodeNum: uint64
	frame_dig 1 // poolAppId: uint64
	frame_dig -2 // validatorId: ValidatorIdType
	callsub addPoolToNode

	// examples/reti/validatorRegistry.algo.ts:632
	// return { id: validatorId, poolId: numPools as uint64, poolAppId: this.itxn!.createdApplicationID.id };
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	frame_dig 0 // numPools: uint64
	itob
	concat
	itxn CreatedApplicationID
	itob
	concat

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 1
	retsub

// addStake(pay,uint64,uint64)(uint64,uint64,uint64)
*abi_route_addStake:
	// The ABI return prefix
	byte 0x151f7c75

	// valueToVerify: uint64
	txna ApplicationArgs 2
	btoi

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// stakedAmountPayment: pay
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// argument 2 (stakedAmountPayment) for addStake must be a pay transaction
	assert

	// execute addStake(pay,uint64,uint64)(uint64,uint64,uint64)
	callsub addStake
	concat
	log
	int 1
	return

// addStake(stakedAmountPayment: PayTxn, validatorId: ValidatorIdType, valueToVerify: uint64): ValidatorPoolKey
//
// Adds stake to a validator pool.
//
// @param {PayTxn} stakedAmountPayment - payment coming from staker to place into a pool
// @param {ValidatorIdType} validatorId - The id of the validator.
// @param {uint64} valueToVerify - only if validator has gating to enter - this is asset id or nfd id that corresponds to gating.
// Txn sender is factored in as well if that is part of gating.
// * @returns {ValidatorPoolKey} - The key of the validator pool.
addStake:
	proto 3 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 5

	// examples/reti/validatorRegistry.algo.ts:645
	// assert(this.validatorList(validatorId).exists, "specified validator id isn't valid")
	byte 0x76 // "v"
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	concat
	box_len
	swap
	pop

	// specified validator id isn't valid
	assert

	// *if8_condition
	// examples/reti/validatorRegistry.algo.ts:648
	// this.validatorList(validatorId).value.config.sunsettingOn > 0
	pushint 226
	int 8
	byte 0x76 // "v"
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	int 0
	>
	bz *if8_end

	// *if8_consequent
	// examples/reti/validatorRegistry.algo.ts:649
	// assert(
	//         this.validatorList(validatorId).value.config.sunsettingOn < globals.latestTimestamp,
	//         "can't stake with a validator that is past its sunsetting time"
	//       )
	pushint 226
	int 8
	byte 0x76 // "v"
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	global LatestTimestamp
	<

	// can't stake with a validator that is past its sunsetting time
	assert

*if8_end:
	// examples/reti/validatorRegistry.algo.ts:655
	// staker = this.txn.sender
	txn Sender
	frame_bury 0 // staker: address

	// examples/reti/validatorRegistry.algo.ts:659
	// verifyPayTxn(stakedAmountPayment, {
	//       sender: staker,
	//       receiver: this.app.address,
	//     })
	// verify sender
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Sender
	frame_dig 0 // staker: address
	==

	// transaction verification failed: {"txn":"stakedAmountPayment","field":"sender","expected":"staker"}
	assert

	// verify receiver
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Receiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"stakedAmountPayment","field":"receiver","expected":"this.app.address"}
	assert

	// examples/reti/validatorRegistry.algo.ts:666
	// assert(
	//       this.validatorList(validatorId).value.state.totalAlgoStaked < this.maxAllowedStake(),
	//       'total staked for all of a validators pools may not exceed hard cap'
	//     )
	int 252
	int 8
	byte 0x76 // "v"
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	callsub maxAllowedStake
	<

	// total staked for all of a validators pools may not exceed hard cap
	assert

	// examples/reti/validatorRegistry.algo.ts:673
	// this.doesStakerMeetGating(validatorId, valueToVerify)
	frame_dig -3 // valueToVerify: uint64
	frame_dig -2 // validatorId: ValidatorIdType
	callsub doesStakerMeetGating

	// examples/reti/validatorRegistry.algo.ts:675
	// realAmount = stakedAmountPayment.amount
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Amount
	frame_bury 1 // realAmount: uint64

	// examples/reti/validatorRegistry.algo.ts:676
	// mbrAmtLeftBehind: uint64 = 0
	int 0
	frame_bury 2 // mbrAmtLeftBehind: uint64

	// *if9_condition
	// examples/reti/validatorRegistry.algo.ts:678
	// !this.stakerPoolSet(staker).exists
	byte 0x737073 // "sps"
	frame_dig 0 // staker: address
	concat
	box_len
	swap
	pop
	!
	bz *if9_end

	// *if9_consequent
	// examples/reti/validatorRegistry.algo.ts:681
	// mbrAmtLeftBehind = this.getMbrAmounts().addStakerMbr
	callsub getMbrAmounts
	extract 24 8
	btoi
	frame_bury 2 // mbrAmtLeftBehind: uint64

	// examples/reti/validatorRegistry.algo.ts:682
	// realAmount -= mbrAmtLeftBehind
	frame_dig 1 // realAmount: uint64
	frame_dig 2 // mbrAmtLeftBehind: uint64
	-
	frame_bury 1 // realAmount: uint64

	// examples/reti/validatorRegistry.algo.ts:683
	// this.stakerPoolSet(staker).create()
	byte 0x737073 // "sps"
	frame_dig 0 // staker: address
	concat
	pushint 144
	box_create
	pop

*if9_end:
	// examples/reti/validatorRegistry.algo.ts:687
	// findRet = this.findPoolForStaker(validatorId, staker, realAmount)
	frame_dig 1 // realAmount: uint64
	frame_dig 0 // staker: address
	frame_dig -2 // validatorId: ValidatorIdType
	callsub findPoolForStaker
	frame_bury 3 // findRet: ((uint64,uint64,uint64),bool,bool)

	// examples/reti/validatorRegistry.algo.ts:688
	// poolKey = findRet[0]
	// examples/reti/validatorRegistry.algo.ts:689
	// isNewStakerToValidator = findRet[1]
	frame_dig 3 // findRet: ((uint64,uint64,uint64),bool,bool)
	store 255 // full array
	load 255 // full array
	pushint 192
	getbit
	frame_bury 4 // isNewStakerToValidator: bool

	// examples/reti/validatorRegistry.algo.ts:690
	// isNewStakerToProtocol = findRet[2]
	frame_dig 3 // findRet: ((uint64,uint64,uint64),bool,bool)
	store 255 // full array
	load 255 // full array
	pushint 193
	getbit
	frame_bury 5 // isNewStakerToProtocol: bool

	// *if10_condition
	// examples/reti/validatorRegistry.algo.ts:691
	// poolKey.poolId === 0
	frame_dig 3 // findRet: ((uint64,uint64,uint64),bool,bool)
	store 255 // full array
	load 255 // full array
	extract 8 8
	btoi
	int 0
	==
	bz *if10_end

	// *if10_consequent
	// No pool available with free stake.  Validator needs to add another pool
	err

*if10_end:
	// examples/reti/validatorRegistry.algo.ts:696
	// this.updateStakerPoolSet(staker, poolKey)
	frame_dig 3 // findRet: ((uint64,uint64,uint64),bool,bool)
	store 255 // full array
	load 255 // full array
	extract 0 24
	frame_dig 0 // staker: address
	callsub updateStakerPoolSet

	// examples/reti/validatorRegistry.algo.ts:699
	// this.callPoolAddStake(
	//       stakedAmountPayment,
	//       poolKey,
	//       mbrAmtLeftBehind,
	//       isNewStakerToValidator,
	//       isNewStakerToProtocol
	//     )
	frame_dig 5 // isNewStakerToProtocol: bool
	frame_dig 4 // isNewStakerToValidator: bool
	frame_dig 2 // mbrAmtLeftBehind: uint64
	frame_dig 3 // findRet: ((uint64,uint64,uint64),bool,bool)
	store 255 // full array
	load 255 // full array
	extract 0 24
	frame_dig -1 // stakedAmountPayment: PayTxn
	callsub callPoolAddStake

	// examples/reti/validatorRegistry.algo.ts:714
	// return poolKey;
	frame_dig 3 // findRet: ((uint64,uint64,uint64),bool,bool)
	store 255 // full array
	load 255 // full array
	extract 0 24

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 5
	retsub

// setTokenPayoutRatio(uint64)(uint64[24],uint64)
*abi_route_setTokenPayoutRatio:
	// The ABI return prefix
	byte 0x151f7c75

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute setTokenPayoutRatio(uint64)(uint64[24],uint64)
	callsub setTokenPayoutRatio
	concat
	log
	int 1
	return

// setTokenPayoutRatio(validatorId: ValidatorIdType): PoolTokenPayoutRatio
//
// setTokenPayoutRatio is called by Staking Pool # 1 (ONLY) to ask the validator (us) to calculate the ratios
// of stake in the pools for subsequent token payouts (ie: 2 pools, '100' algo total staked, 60 in pool 1, and 40
// in pool 2)  This is done so we have a stable snapshot of stake - taken once per epoch - only triggered by
// pool 1 doing payout.  pools other than 1 doing payout call pool 1 to ask it do it first.
// It would be 60/40% in the poolPctOfWhole values.  The token reward payouts then use these values instead of
// their 'current' stake which changes as part of the payouts themselves (and people could be changing stake
// during the epoch updates across pools)
//
// Multiple pools will call us via pool 1 (pool2->pool1->validator, etc.) so don't assert on pool1 calling multiple
// times in same epoch.  Just return.
//
// @param validatorId - validator id (and thus pool) calling us.  Verified so that sender MUST be pool 1 of this validator.
// @returns PoolTokenPayoutRatio - the finished ratio data
setTokenPayoutRatio:
	proto 1 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 8

	// examples/reti/validatorRegistry.algo.ts:734
	// pool1AppID = this.validatorList(validatorId).value.pools[0].poolAppId
	int 268
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 0 // pool1AppID: uint64

	// examples/reti/validatorRegistry.algo.ts:735
	// assert(pool1AppID !== 0)
	frame_dig 0 // pool1AppID: uint64
	int 0
	!=
	assert

	// *if11_condition
	// examples/reti/validatorRegistry.algo.ts:737
	// this.txn.sender !== AppID.fromUint64(pool1AppID).address
	txn Sender
	frame_dig 0 // pool1AppID: uint64
	app_params_get AppAddress
	pop
	!=
	bz *if11_end

	// *if11_consequent
	// examples/reti/validatorRegistry.algo.ts:738
	// return this.validatorList(validatorId).value.tokenPayoutRatio;
	int 700 // headOffset
	pushint 200
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	b *setTokenPayoutRatio*return

*if11_end:
	// examples/reti/validatorRegistry.algo.ts:744
	// curRound = globals.round
	global Round
	frame_bury 1 // curRound: uint64

	// examples/reti/validatorRegistry.algo.ts:745
	// lastPayoutUpdate = this.validatorList(validatorId).value.tokenPayoutRatio.updatedForPayout
	pushint 892
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 2 // lastPayoutUpdate: uint64

	// *if12_condition
	// examples/reti/validatorRegistry.algo.ts:746
	// lastPayoutUpdate !== 0
	frame_dig 2 // lastPayoutUpdate: uint64
	int 0
	!=
	bz *if12_end

	// *if12_consequent
	// *if13_condition
	// examples/reti/validatorRegistry.algo.ts:748
	// (AppID.fromUint64(pool1AppID).globalState('lastPayout') as uint64) === lastPayoutUpdate
	frame_dig 0 // pool1AppID: uint64
	pushbytes 0x6c6173745061796f7574 // "lastPayout"
	app_global_get_ex

	// global state value does not exist: AppID.fromUint64(pool1AppID).globalState('lastPayout')
	assert
	frame_dig 2 // lastPayoutUpdate: uint64
	==
	bz *if13_end

	// *if13_consequent
	// examples/reti/validatorRegistry.algo.ts:749
	// return this.validatorList(validatorId).value.tokenPayoutRatio;
	int 700 // headOffset
	pushint 200
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	b *setTokenPayoutRatio*return

*if13_end:
	// examples/reti/validatorRegistry.algo.ts:751
	// epochRoundLength = this.validatorList(validatorId).value.config.epochRoundLength as uint64
	pushint 169
	pushint 4
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 3 // epochRoundLength: uint64

	// examples/reti/validatorRegistry.algo.ts:752
	// thisEpochBegin = curRound - (curRound % epochRoundLength)
	frame_dig 1 // curRound: uint64
	frame_dig 1 // curRound: uint64
	frame_dig 3 // epochRoundLength: uint64
	%
	-
	frame_bury 4 // thisEpochBegin: uint64

	// *if14_condition
	// examples/reti/validatorRegistry.algo.ts:754
	// lastPayoutUpdate - (lastPayoutUpdate % epochRoundLength) === thisEpochBegin
	frame_dig 2 // lastPayoutUpdate: uint64
	frame_dig 2 // lastPayoutUpdate: uint64
	frame_dig 3 // epochRoundLength: uint64
	%
	-
	frame_dig 4 // thisEpochBegin: uint64
	==
	bz *if14_end

	// *if14_consequent
	// examples/reti/validatorRegistry.algo.ts:755
	// return this.validatorList(validatorId).value.tokenPayoutRatio;
	int 700 // headOffset
	pushint 200
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	b *setTokenPayoutRatio*return

*if14_end:

*if12_end:
	// examples/reti/validatorRegistry.algo.ts:758
	// this.validatorList(validatorId).value.tokenPayoutRatio.updatedForPayout = curRound
	pushint 892
	frame_dig 1 // curRound: uint64
	itob
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:760
	// curNumPools = this.validatorList(validatorId).value.state.numPools as uint64
	int 242
	int 2
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 5 // curNumPools: uint64

	// examples/reti/validatorRegistry.algo.ts:761
	// totalStakeForValidator = this.validatorList(validatorId).value.state.totalAlgoStaked
	int 252
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 6 // totalStakeForValidator: uint64

	// examples/reti/validatorRegistry.algo.ts:762
	// for (let i = 0; i < curNumPools; i += 1)
	int 0
	frame_bury 7 // i: uint64

*for_2:
	// examples/reti/validatorRegistry.algo.ts:762
	// i < curNumPools
	frame_dig 7 // i: uint64
	frame_dig 5 // curNumPools: uint64
	<
	bz *for_2_end

	// examples/reti/validatorRegistry.algo.ts:767
	// ourPoolPctOfWhole = wideRatio(
	//         [this.validatorList(validatorId).value.pools[i].totalAlgoStaked, 1_000_000],
	//         [totalStakeForValidator]
	//       )
	int 268 // headOffset
	frame_dig 7 // i: uint64
	int 18
	* // acc * typeLength
	+
	int 10 // headOffset
	+
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	pushint 1_000_000
	mulw
	int 0
	frame_dig 6 // totalStakeForValidator: uint64
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	frame_bury 8 // ourPoolPctOfWhole: uint64

	// examples/reti/validatorRegistry.algo.ts:771
	// this.validatorList(validatorId).value.tokenPayoutRatio.poolPctOfWhole[i] = ourPoolPctOfWhole
	int 700
	frame_dig 7 // i: uint64
	int 8
	* // acc * typeLength
	+
	frame_dig 8 // ourPoolPctOfWhole: uint64
	itob
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace

*for_2_continue:
	// examples/reti/validatorRegistry.algo.ts:762
	// i += 1
	frame_dig 7 // i: uint64
	int 1
	+
	frame_bury 7 // i: uint64
	b *for_2

*for_2_end:
	// examples/reti/validatorRegistry.algo.ts:773
	// return this.validatorList(validatorId).value.tokenPayoutRatio;
	int 700 // headOffset
	pushint 200
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract

*setTokenPayoutRatio*return:
	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 8
	retsub

// stakeUpdatedViaRewards((uint64,uint64,uint64),uint64,uint64,uint64,uint64)void
*abi_route_stakeUpdatedViaRewards:
	// saturatedBurnToFeeSink: uint64
	txna ApplicationArgs 5
	btoi

	// validatorCommission: uint64
	txna ApplicationArgs 4
	btoi

	// rewardTokenAmountReserved: uint64
	txna ApplicationArgs 3
	btoi

	// algoToAdd: uint64
	txna ApplicationArgs 2
	btoi

	// poolKey: (uint64,uint64,uint64)
	txna ApplicationArgs 1
	dup
	len
	int 24
	==

	// argument 4 (poolKey) for stakeUpdatedViaRewards must be a (uint64,uint64,uint64)
	assert

	// execute stakeUpdatedViaRewards((uint64,uint64,uint64),uint64,uint64,uint64,uint64)void
	callsub stakeUpdatedViaRewards
	int 1
	return

// stakeUpdatedViaRewards(poolKey: ValidatorPoolKey, algoToAdd: uint64, rewardTokenAmountReserved: uint64, validatorCommission: uint64, saturatedBurnToFeeSink: uint64): void
//
// stakeUpdatedViaRewards is called by Staking pools to inform the validator (us) that a particular amount of total
// stake has been added to the specified pool.  This is used to update the stats we have in our PoolInfo storage.
// The calling App id is validated against our pool list as well.
// @param {ValidatorPoolKey} poolKey - ValidatorPoolKey type
// @param {uint64} algoToAdd - amount this validator's total stake increased via rewards
// @param {uint64} rewardTokenAmountReserved - amount this validator's total stake increased via rewards (that should be
// @param {uint64} validatorCommission - the commission amount the validator was paid, if any
// @param {uint64} saturatedBurnToFeeSink - if the pool was in saturated state, the amount sent back to the fee sink.
// seen as 'accounted for/pending spent')
stakeUpdatedViaRewards:
	proto 5 0

	// examples/reti/validatorRegistry.algo.ts:794
	// this.verifyPoolKeyCaller(poolKey)
	frame_dig -1 // poolKey: ValidatorPoolKey
	callsub verifyPoolKeyCaller

	// examples/reti/validatorRegistry.algo.ts:797
	// this.validatorList(poolKey.id).value.pools[poolKey.poolId - 1].totalAlgoStaked += algoToAdd
	int 268 // headOffset
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 10 // headOffset
	+
	int 268 // headOffset
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 10 // headOffset
	+
	int 8
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_dig -2 // algoToAdd: uint64
	+
	itob
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:798
	// this.validatorList(poolKey.id).value.state.totalAlgoStaked += algoToAdd
	int 252
	dup
	int 8
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_dig -2 // algoToAdd: uint64
	+
	itob
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:799
	// this.validatorList(poolKey.id).value.state.rewardTokenHeldBack += rewardTokenAmountReserved
	int 260
	dup
	int 8
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_dig -3 // rewardTokenAmountReserved: uint64
	+
	itob
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:801
	// this.totalAlgoStaked.value += algoToAdd
	byte 0x7374616b6564 // "staked"
	app_global_get
	frame_dig -2 // algoToAdd: uint64
	+
	byte 0x7374616b6564 // "staked"
	swap
	app_global_put

	// examples/reti/validatorRegistry.algo.ts:804
	// this.reverifyNFDOwnership(poolKey.id)
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	callsub reverifyNFDOwnership
	retsub

// stakeRemoved((uint64,uint64,uint64),address,uint64,uint64,bool)void
*abi_route_stakeRemoved:
	// stakerRemoved: bool
	txna ApplicationArgs 5
	dup
	len
	int 1
	==

	// argument 0 (stakerRemoved) for stakeRemoved must be a bool
	assert
	int 0
	getbit

	// rewardRemoved: uint64
	txna ApplicationArgs 4
	btoi

	// amountRemoved: uint64
	txna ApplicationArgs 3
	btoi

	// staker: address
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 3 (staker) for stakeRemoved must be a address
	assert

	// poolKey: (uint64,uint64,uint64)
	txna ApplicationArgs 1
	dup
	len
	int 24
	==

	// argument 4 (poolKey) for stakeRemoved must be a (uint64,uint64,uint64)
	assert

	// execute stakeRemoved((uint64,uint64,uint64),address,uint64,uint64,bool)void
	callsub stakeRemoved
	int 1
	return

// stakeRemoved(poolKey: ValidatorPoolKey, staker: Address, amountRemoved: uint64, rewardRemoved: uint64, stakerRemoved: boolean): void
//
// stakeRemoved is called by Staking pools to inform the validator (us) that a particular amount of total stake has been removed
// from the specified pool.  This is used to update the stats we have in our PoolInfo storage.
// If any amount of rewardRemoved is specified, then that amount of reward is sent to the use
// The calling App id is validated against our pool list as well.
//
// @param {ValidatorPoolKey} poolKey calling us from which stake was removed
// @param {Address} staker
// @param {uint64} amountRemoved - algo amount removed
// @param {uint64} rewardRemoved - if applicable, amount of token reward removed (by pool 1 caller) or TO remove and pay out (via pool 1 from different pool caller)
// @param {boolean} stakerRemoved
stakeRemoved:
	proto 5 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 3

	// *if15_condition
	// examples/reti/validatorRegistry.algo.ts:836
	// globals.opcodeBudget < 300
	global OpcodeBudget
	pushint 300
	<
	bz *if15_end

	// *if15_consequent
	// examples/reti/validatorRegistry.algo.ts:837
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	pushint 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

*if15_end:
	// examples/reti/validatorRegistry.algo.ts:839
	// this.verifyPoolKeyCaller(poolKey)
	frame_dig -1 // poolKey: ValidatorPoolKey
	callsub verifyPoolKeyCaller

	// examples/reti/validatorRegistry.algo.ts:843
	// assert(amountRemoved > 0 || rewardRemoved > 0, 'should only be called if algo or reward was removed')
	frame_dig -3 // amountRemoved: uint64
	int 0
	>
	dup
	bnz *skip_or2
	frame_dig -4 // rewardRemoved: uint64
	int 0
	>
	||

*skip_or2:
	// should only be called if algo or reward was removed
	assert

	// examples/reti/validatorRegistry.algo.ts:846
	// this.validatorList(poolKey.id).value.pools[poolKey.poolId - 1].totalAlgoStaked -= amountRemoved
	int 268 // headOffset
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 10 // headOffset
	+
	int 268 // headOffset
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 10 // headOffset
	+
	int 8
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_dig -3 // amountRemoved: uint64
	-
	itob
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:847
	// this.validatorList(poolKey.id).value.state.totalAlgoStaked -= amountRemoved
	int 252
	dup
	int 8
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_dig -3 // amountRemoved: uint64
	-
	itob
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:848
	// this.totalAlgoStaked.value -= amountRemoved
	byte 0x7374616b6564 // "staked"
	app_global_get
	frame_dig -3 // amountRemoved: uint64
	-
	byte 0x7374616b6564 // "staked"
	swap
	app_global_put

	// *if16_condition
	// examples/reti/validatorRegistry.algo.ts:850
	// rewardRemoved > 0
	frame_dig -4 // rewardRemoved: uint64
	int 0
	>
	bz *if16_else

	// *if16_consequent
	// examples/reti/validatorRegistry.algo.ts:851
	// rewardTokenID = this.validatorList(poolKey.id).value.config.rewardTokenId
	pushint 153
	int 8
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 0 // rewardTokenID: uint64

	// examples/reti/validatorRegistry.algo.ts:852
	// assert(rewardTokenID !== 0, "rewardRemoved can't be set if validator doesn't have reward token!")
	frame_dig 0 // rewardTokenID: uint64
	int 0
	!=

	// rewardRemoved can't be set if validator doesn't have reward token!
	assert

	// examples/reti/validatorRegistry.algo.ts:853
	// assert(
	//         this.validatorList(poolKey.id).value.state.rewardTokenHeldBack >= rewardRemoved,
	//         'reward being removed must be covered by hold back amount'
	//       )
	int 260
	int 8
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_dig -4 // rewardRemoved: uint64
	>=

	// reward being removed must be covered by hold back amount
	assert

	// examples/reti/validatorRegistry.algo.ts:859
	// this.validatorList(poolKey.id).value.state.rewardTokenHeldBack -= rewardRemoved
	int 260
	dup
	int 8
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_dig -4 // rewardRemoved: uint64
	-
	itob
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_replace

	// *if17_condition
	// examples/reti/validatorRegistry.algo.ts:864
	// poolKey.poolId !== 1
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	!=
	bz *if17_end

	// *if17_consequent
	// examples/reti/validatorRegistry.algo.ts:865
	// sendMethodCall<typeof StakingPool.prototype.payTokenReward>({
	//           applicationID: AppID.fromUint64(this.validatorList(poolKey.id).value.pools[0].poolAppId),
	//           methodArgs: [staker, rewardTokenID, rewardRemoved],
	//         })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0x63f3f28b // method "payTokenReward(address,uint64,uint64)void"
	itxn_field ApplicationArgs

	// examples/reti/validatorRegistry.algo.ts:866
	// applicationID: AppID.fromUint64(this.validatorList(poolKey.id).value.pools[0].poolAppId)
	int 268
	int 8
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	itxn_field ApplicationID

	// examples/reti/validatorRegistry.algo.ts:867
	// methodArgs: [staker, rewardTokenID, rewardRemoved]
	frame_dig -2 // staker: Address
	itxn_field ApplicationArgs
	frame_dig 0 // rewardTokenID: uint64
	itob
	itxn_field ApplicationArgs
	frame_dig -4 // rewardRemoved: uint64
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

*if17_end:
	b *if16_end

*if16_else:

*if16_end:
	// *if18_condition
	// examples/reti/validatorRegistry.algo.ts:892
	// stakerRemoved
	frame_dig -5 // stakerRemoved: boolean
	bz *if18_end

	// *if18_consequent
	// examples/reti/validatorRegistry.algo.ts:894
	// this.validatorList(poolKey.id).value.pools[poolKey.poolId - 1].totalStakers -= 1
	int 268 // headOffset
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 8 // headOffset
	+
	int 268 // headOffset
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 8 // headOffset
	+
	int 2
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	int 1
	-
	itob
	extract 6 2
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:896
	// removeRet = this.removeFromStakerPoolSet(staker, <ValidatorPoolKey>{
	//         id: poolKey.id,
	//         poolId: poolKey.poolId,
	//         poolAppId: poolKey.poolAppId,
	//       })
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	itob
	concat
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 16 8
	btoi
	itob
	concat
	frame_dig -2 // staker: Address
	callsub removeFromStakerPoolSet
	frame_bury 1 // removeRet: (bool,bool)

	// examples/reti/validatorRegistry.algo.ts:901
	// stakerOutOfThisValidator = removeRet[0]
	frame_dig 1 // removeRet: (bool,bool)
	store 255 // full array
	load 255 // full array
	int 0
	getbit
	frame_bury 2 // stakerOutOfThisValidator: bool

	// examples/reti/validatorRegistry.algo.ts:902
	// stakerOutOfProtocol = removeRet[1]
	frame_dig 1 // removeRet: (bool,bool)
	store 255 // full array
	load 255 // full array
	int 1
	getbit
	frame_bury 3 // stakerOutOfProtocol: bool

	// *if19_condition
	// examples/reti/validatorRegistry.algo.ts:904
	// stakerOutOfThisValidator
	frame_dig 2 // stakerOutOfThisValidator: bool
	bz *if19_end

	// *if19_consequent
	// examples/reti/validatorRegistry.algo.ts:905
	// this.validatorList(poolKey.id).value.state.totalStakers -= 1
	pushint 244
	pushint 244
	int 8
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	int 1
	-
	itob
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_replace

*if19_end:
	// *if20_condition
	// examples/reti/validatorRegistry.algo.ts:908
	// stakerOutOfProtocol
	frame_dig 3 // stakerOutOfProtocol: bool
	bz *if20_end

	// *if20_consequent
	// examples/reti/validatorRegistry.algo.ts:909
	// this.numStakers.value -= 1
	byte 0x6e756d5374616b657273 // "numStakers"
	app_global_get
	int 1
	-
	byte 0x6e756d5374616b657273 // "numStakers"
	swap
	app_global_put

*if20_end:

*if18_end:
	retsub

// findPoolForStaker(uint64,address,uint64)((uint64,uint64,uint64),bool,bool)
*abi_route_findPoolForStaker:
	// The ABI return prefix
	byte 0x151f7c75

	// amountToStake: uint64
	txna ApplicationArgs 3
	btoi

	// staker: address
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 1 (staker) for findPoolForStaker must be a address
	assert

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute findPoolForStaker(uint64,address,uint64)((uint64,uint64,uint64),bool,bool)
	callsub findPoolForStaker
	concat
	log
	int 1
	return

// findPoolForStaker(validatorId: ValidatorIdType, staker: Address, amountToStake: uint64): [ValidatorPoolKey, boolean, boolean]
//
// Finds the pool for a staker based on the provided validator id, staker address, and amount to stake.
// First checks the stakers 'already staked list' for the validator preferring those (adding if possible) then adds
// to new pool if necessary.
//
// @param {ValidatorIdType} validatorId - The id of the validator.
// @param {Address} staker - The address of the staker.
// @param {uint64} amountToStake - The amount to stake.
// @returns {ValidatorPoolKey, boolean, boolean} - The pool for the staker, true/false on whether the staker is 'new'
// to this VALIDATOR, and true/false if staker is new to the protocol.
findPoolForStaker:
	proto 3 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 7

	// examples/reti/validatorRegistry.algo.ts:930
	// isNewStakerToValidator = true
	int 1
	frame_bury 0 // isNewStakerToValidator: bool

	// examples/reti/validatorRegistry.algo.ts:931
	// isNewStakerToProtocol = true
	int 1
	frame_bury 1 // isNewStakerToProtocol: bool

	// examples/reti/validatorRegistry.algo.ts:939
	// maxPerPool = this.getCurMaxStakePerPool(validatorId)
	frame_dig -1 // validatorId: ValidatorIdType
	callsub getCurMaxStakePerPool
	frame_bury 2 // maxPerPool: uint64

	// *if21_condition
	// examples/reti/validatorRegistry.algo.ts:942
	// this.stakerPoolSet(staker).exists
	byte 0x737073 // "sps"
	frame_dig -2 // staker: Address
	concat
	box_len
	swap
	pop
	bz *if21_end

	// *if21_consequent
	// examples/reti/validatorRegistry.algo.ts:943
	// poolSet = clone(this.stakerPoolSet(staker).value)
	byte 0x737073 // "sps"
	frame_dig -2 // staker: Address
	concat
	box_get

	// box value does not exist: this.stakerPoolSet(staker).value
	assert
	frame_bury 3 // poolSet: (uint64,uint64,uint64)[6]

	// examples/reti/validatorRegistry.algo.ts:944
	// assert(validatorId !== 0)
	frame_dig -1 // validatorId: ValidatorIdType
	int 0
	!=
	assert

	// examples/reti/validatorRegistry.algo.ts:945
	// for (let i = 0; i < poolSet.length; i += 1)
	int 0
	frame_bury 4 // i: uint64

*for_3:
	// examples/reti/validatorRegistry.algo.ts:945
	// i < poolSet.length
	frame_dig 4 // i: uint64
	int 6
	<
	bz *for_3_end

	// *if22_condition
	// examples/reti/validatorRegistry.algo.ts:946
	// globals.opcodeBudget < 300
	global OpcodeBudget
	pushint 300
	<
	bz *if22_end

	// *if22_consequent
	// examples/reti/validatorRegistry.algo.ts:947
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	pushint 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

*if22_end:
	// *if23_condition
	// examples/reti/validatorRegistry.algo.ts:949
	// poolSet[i].id === 0
	frame_dig 3 // poolSet: (uint64,uint64,uint64)[6]
	frame_dig 4 // i: uint64
	int 24
	* // acc * typeLength
	int 0
	+
	int 8
	extract3
	btoi
	int 0
	==
	bz *if23_end

	// *if23_consequent
	b *for_3_continue

*if23_end:
	// examples/reti/validatorRegistry.algo.ts:952
	// isNewStakerToProtocol = false
	int 0
	frame_bury 1 // isNewStakerToProtocol: bool

	// *if24_condition
	// examples/reti/validatorRegistry.algo.ts:953
	// poolSet[i].id === validatorId
	frame_dig 3 // poolSet: (uint64,uint64,uint64)[6]
	frame_dig 4 // i: uint64
	int 24
	* // acc * typeLength
	int 0
	+
	int 8
	extract3
	btoi
	frame_dig -1 // validatorId: ValidatorIdType
	==
	bz *if24_end

	// *if24_consequent
	// examples/reti/validatorRegistry.algo.ts:955
	// isNewStakerToValidator = false
	int 0
	frame_bury 0 // isNewStakerToValidator: bool

	// *if25_condition
	// examples/reti/validatorRegistry.algo.ts:957
	// this.validatorList(validatorId).value.pools[poolSet[i].poolId - 1].totalAlgoStaked + amountToStake <=
	//             maxPerPool
	int 268 // headOffset
	frame_dig 3 // poolSet: (uint64,uint64,uint64)[6]
	frame_dig 4 // i: uint64
	int 24
	* // acc * typeLength
	int 8 // headOffset
	+
	int 8
	extract3
	btoi
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 10 // headOffset
	+
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_dig -3 // amountToStake: uint64
	+
	frame_dig 2 // maxPerPool: uint64
	<=
	bz *if25_end

	// *if25_consequent
	// examples/reti/validatorRegistry.algo.ts:960
	// return [poolSet[i], isNewStakerToValidator, isNewStakerToProtocol];
	frame_dig 3 // poolSet: (uint64,uint64,uint64)[6]
	frame_dig 4 // i: uint64
	int 24
	* // acc * typeLength
	int 24
	extract3
	byte 0x00
	int 0
	frame_dig 0 // isNewStakerToValidator: bool
	setbit
	int 1
	frame_dig 1 // isNewStakerToProtocol: bool
	setbit
	concat
	b *findPoolForStaker*return

*if25_end:

*if24_end:

*for_3_continue:
	// examples/reti/validatorRegistry.algo.ts:945
	// i += 1
	frame_dig 4 // i: uint64
	int 1
	+
	frame_bury 4 // i: uint64
	b *for_3

*for_3_end:

*if21_end:
	// examples/reti/validatorRegistry.algo.ts:967
	// assert(
	//       amountToStake >= this.validatorList(validatorId).value.config.minEntryStake,
	//       'must stake at least the minimum for this pool'
	//     )
	frame_dig -3 // amountToStake: uint64
	pushint 209
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	>=

	// must stake at least the minimum for this pool
	assert

	// examples/reti/validatorRegistry.algo.ts:973
	// pools = clone(this.validatorList(validatorId).value.pools)
	int 268 // headOffset
	pushint 432
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	frame_bury 5 // pools: (uint64,uint16,uint64)[24]

	// examples/reti/validatorRegistry.algo.ts:974
	// curNumPools = this.validatorList(validatorId).value.state.numPools as uint64
	int 242
	int 2
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 6 // curNumPools: uint64

	// examples/reti/validatorRegistry.algo.ts:975
	// for (let i = 0; i < curNumPools; i += 1)
	int 0
	frame_bury 7 // i: uint64

*for_4:
	// examples/reti/validatorRegistry.algo.ts:975
	// i < curNumPools
	frame_dig 7 // i: uint64
	frame_dig 6 // curNumPools: uint64
	<
	bz *for_4_end

	// *if26_condition
	// examples/reti/validatorRegistry.algo.ts:976
	// pools[i].totalAlgoStaked + amountToStake <= maxPerPool
	frame_dig 5 // pools: (uint64,uint16,uint64)[24]
	frame_dig 7 // i: uint64
	int 18
	* // acc * typeLength
	int 10 // headOffset
	+
	int 8
	extract3
	btoi
	frame_dig -3 // amountToStake: uint64
	+
	frame_dig 2 // maxPerPool: uint64
	<=
	bz *if26_end

	// *if26_consequent
	// examples/reti/validatorRegistry.algo.ts:977
	// return [
	//           { id: validatorId, poolId: i + 1, poolAppId: pools[i].poolAppId },
	//           isNewStakerToValidator,
	//           isNewStakerToProtocol,
	//         ];
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	frame_dig 7 // i: uint64
	int 1
	+
	itob
	concat
	frame_dig 5 // pools: (uint64,uint16,uint64)[24]
	frame_dig 7 // i: uint64
	int 18
	* // acc * typeLength
	int 0
	+
	int 8
	extract3
	btoi
	itob
	concat
	byte 0x00
	int 0
	frame_dig 0 // isNewStakerToValidator: bool
	setbit
	int 1
	frame_dig 1 // isNewStakerToProtocol: bool
	setbit
	concat
	b *findPoolForStaker*return

*if26_end:

*for_4_continue:
	// examples/reti/validatorRegistry.algo.ts:975
	// i += 1
	frame_dig 7 // i: uint64
	int 1
	+
	frame_bury 7 // i: uint64
	b *for_4

*for_4_end:
	// examples/reti/validatorRegistry.algo.ts:985
	// return [{ id: validatorId, poolId: 0, poolAppId: 0 }, isNewStakerToValidator, isNewStakerToProtocol];
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	byte 0x0000000000000000
	concat
	byte 0x0000000000000000
	concat
	byte 0x00
	int 0
	frame_dig 0 // isNewStakerToValidator: bool
	setbit
	int 1
	frame_dig 1 // isNewStakerToProtocol: bool
	setbit
	concat

*findPoolForStaker*return:
	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 7
	retsub

// movePoolToNode(uint64,uint64,uint64)void
*abi_route_movePoolToNode:
	// nodeNum: uint64
	txna ApplicationArgs 3
	btoi

	// poolAppId: uint64
	txna ApplicationArgs 2
	btoi

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute movePoolToNode(uint64,uint64,uint64)void
	callsub movePoolToNode
	int 1
	return

// movePoolToNode(validatorId: ValidatorIdType, poolAppId: uint64, nodeNum: uint64): void
//
// Find the specified pool (in any node number) and move it to the specified node.
// The pool account is forced offline if moved so prior node will still run for 320 rounds but
// new key goes online on new node soon after (320 rounds after it goes online)
// No-op if success, asserts if not found or can't move  (no space in target)
// [ ONLY OWNER OR MANAGER CAN CHANGE ]
//
// @param {ValidatorIdType} validatorId - The id of the validator.
// @param {uint64} poolAppId
// @param {uint64} nodeNum
movePoolToNode:
	proto 3 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// examples/reti/validatorRegistry.algo.ts:1001
	// assert(
	//       this.txn.sender === this.validatorList(validatorId).value.config.owner ||
	//         this.txn.sender === this.validatorList(validatorId).value.config.manager,
	//       'can only be called by owner or manager of validator'
	//     )
	txn Sender
	int 8
	int 32
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	==
	dup
	bnz *skip_or3
	txn Sender
	pushint 40
	int 32
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	==
	||

*skip_or3:
	// can only be called by owner or manager of validator
	assert

	// examples/reti/validatorRegistry.algo.ts:1007
	// nodePoolAssignments = clone(this.validatorList(validatorId).value.nodePoolAssignments)
	int 900 // headOffset
	pushint 192
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	frame_bury 0 // nodePoolAssignments: ((uint64[3])[8])

	// examples/reti/validatorRegistry.algo.ts:1008
	// assert(nodeNum >= 1 && nodeNum <= MAX_NODES, 'node number out of allowable range')
	frame_dig -3 // nodeNum: uint64
	int 1
	>=
	dup
	bz *skip_and1
	frame_dig -3 // nodeNum: uint64
	int 8
	<=
	&&

*skip_and1:
	// node number out of allowable range
	assert

	// examples/reti/validatorRegistry.algo.ts:1010
	// for (let srcNodeIdx = 0; srcNodeIdx < MAX_NODES; srcNodeIdx += 1)
	int 0
	frame_bury 1 // srcNodeIdx: uint64

*for_5:
	// examples/reti/validatorRegistry.algo.ts:1010
	// srcNodeIdx < MAX_NODES
	frame_dig 1 // srcNodeIdx: uint64
	int 8
	<
	bz *for_5_end

	// examples/reti/validatorRegistry.algo.ts:1011
	// for (let i = 0; i < MAX_POOLS_PER_NODE; i += 1)
	int 0
	frame_bury 2 // i: uint64

*for_6:
	// examples/reti/validatorRegistry.algo.ts:1011
	// i < MAX_POOLS_PER_NODE
	frame_dig 2 // i: uint64
	int 3
	<
	bz *for_6_end

	// *if27_condition
	// examples/reti/validatorRegistry.algo.ts:1012
	// nodePoolAssignments.nodes[srcNodeIdx].poolAppIds[i] === poolAppId
	frame_dig 0 // nodePoolAssignments: ((uint64[3])[8])
	int 0
	frame_dig 1 // srcNodeIdx: uint64
	int 24
	* // acc * typeLength
	+
	int 0
	+
	frame_dig 2 // i: uint64
	int 8
	* // acc * typeLength
	+
	int 8
	extract3
	btoi
	frame_dig -2 // poolAppId: uint64
	==
	bz *if27_end

	// *if27_consequent
	// examples/reti/validatorRegistry.algo.ts:1013
	// assert(nodeNum - 1 !== srcNodeIdx, "can't move to same node")
	frame_dig -3 // nodeNum: uint64
	int 1
	-
	frame_dig 1 // srcNodeIdx: uint64
	!=

	// can't move to same node
	assert

	// examples/reti/validatorRegistry.algo.ts:1015
	// this.validatorList(validatorId).value.nodePoolAssignments.nodes[srcNodeIdx].poolAppIds[i] = 0
	int 900
	frame_dig 1 // srcNodeIdx: uint64
	int 24
	* // acc * typeLength
	+
	int 0
	+
	frame_dig 2 // i: uint64
	int 8
	* // acc * typeLength
	+
	byte 0x0000000000000000
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:1018
	// sendMethodCall<typeof StakingPool.prototype.goOffline>({
	//             applicationID: AppID.fromUint64(poolAppId),
	//           })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	pushbytes 0x51ef3b21 // method "goOffline()void"
	itxn_field ApplicationArgs

	// examples/reti/validatorRegistry.algo.ts:1019
	// applicationID: AppID.fromUint64(poolAppId)
	frame_dig -2 // poolAppId: uint64
	itxn_field ApplicationID

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/validatorRegistry.algo.ts:1023
	// this.addPoolToNode(validatorId, poolAppId, nodeNum)
	frame_dig -3 // nodeNum: uint64
	frame_dig -2 // poolAppId: uint64
	frame_dig -1 // validatorId: ValidatorIdType
	callsub addPoolToNode

	// examples/reti/validatorRegistry.algo.ts:1024
	// return;
	retsub

*if27_end:

*for_6_continue:
	// examples/reti/validatorRegistry.algo.ts:1011
	// i += 1
	frame_dig 2 // i: uint64
	int 1
	+
	frame_bury 2 // i: uint64
	b *for_6

*for_6_end:

*for_5_continue:
	// examples/reti/validatorRegistry.algo.ts:1010
	// srcNodeIdx += 1
	frame_dig 1 // srcNodeIdx: uint64
	int 1
	+
	frame_bury 1 // srcNodeIdx: uint64
	b *for_5

*for_5_end:
	// couldn't find pool app id in nodes to move
	err
	retsub

// emptyTokenRewards(uint64,address)uint64
*abi_route_emptyTokenRewards:
	// The ABI return prefix
	byte 0x151f7c75

	// receiver: address
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (receiver) for emptyTokenRewards must be a address
	assert

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute emptyTokenRewards(uint64,address)uint64
	callsub emptyTokenRewards
	itob
	concat
	log
	int 1
	return

// emptyTokenRewards(validatorId: ValidatorIdType, receiver: Address): uint64
//
// Sends the reward tokens held in pool 1 to specified receiver.
// This is intended to be used by the owner when they want to get reward tokens 'back' which they sent to
// the first pool (likely because validator is sunsetting.  Any tokens currently 'reserved' for stakers to claim will
// NOT be sent as they must be held back for stakers to later claim.
// [ ONLY OWNER CAN CALL]
//
// @param {ValidatorIdType} validatorId - The id of the validator.
// @param {Address} receiver - the account to send the tokens to (must already be opted-in to the reward token)
// @returns {uint64} the amount of reward token sent
emptyTokenRewards:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 3

	// examples/reti/validatorRegistry.algo.ts:1043
	// assert(
	//       this.txn.sender === this.validatorList(validatorId).value.config.owner,
	//       'can only be called by validator owner'
	//     )
	txn Sender
	int 8
	int 32
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	==

	// can only be called by validator owner
	assert

	// examples/reti/validatorRegistry.algo.ts:1047
	// rewardTokenId = this.validatorList(validatorId).value.config.rewardTokenId
	pushint 153
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 0 // rewardTokenId: uint64

	// examples/reti/validatorRegistry.algo.ts:1048
	// rewardTokenHeldBack = this.validatorList(validatorId).value.state.rewardTokenHeldBack
	int 260
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 1 // rewardTokenHeldBack: uint64

	// examples/reti/validatorRegistry.algo.ts:1049
	// assert(rewardTokenId !== 0, "this validator doesn't have a reward token defined")
	frame_dig 0 // rewardTokenId: uint64
	int 0
	!=

	// this validator doesn't have a reward token defined
	assert

	// examples/reti/validatorRegistry.algo.ts:1050
	// poolOneAppId = AppID.fromUint64(this.validatorList(validatorId).value.pools[0].poolAppId)
	int 268
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 2 // poolOneAppId: uint64

	// examples/reti/validatorRegistry.algo.ts:1052
	// tokenRewardBal = poolOneAppId.address.assetBalance(AssetID.fromUint64(rewardTokenId)) - rewardTokenHeldBack
	frame_dig 2 // poolOneAppId: uint64
	app_params_get AppAddress
	pop
	frame_dig 0 // rewardTokenId: uint64
	asset_holding_get AssetBalance
	pop
	frame_dig 1 // rewardTokenHeldBack: uint64
	-
	frame_bury 3 // tokenRewardBal: uint64

	// examples/reti/validatorRegistry.algo.ts:1055
	// sendMethodCall<typeof StakingPool.prototype.payTokenReward>({
	//       applicationID: poolOneAppId,
	//       methodArgs: [receiver, rewardTokenId, tokenRewardBal],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0x63f3f28b // method "payTokenReward(address,uint64,uint64)void"
	itxn_field ApplicationArgs

	// examples/reti/validatorRegistry.algo.ts:1056
	// applicationID: poolOneAppId
	frame_dig 2 // poolOneAppId: uint64
	itxn_field ApplicationID

	// examples/reti/validatorRegistry.algo.ts:1057
	// methodArgs: [receiver, rewardTokenId, tokenRewardBal]
	frame_dig -2 // receiver: Address
	itxn_field ApplicationArgs
	frame_dig 0 // rewardTokenId: uint64
	itob
	itxn_field ApplicationArgs
	frame_dig 3 // tokenRewardBal: uint64
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/validatorRegistry.algo.ts:1059
	// assert(
	//       poolOneAppId.address.assetBalance(AssetID.fromUint64(rewardTokenId)) === rewardTokenHeldBack,
	//       'balance of remaining reward tokens should match the held back amount'
	//     )
	frame_dig 2 // poolOneAppId: uint64
	app_params_get AppAddress
	pop
	frame_dig 0 // rewardTokenId: uint64
	asset_holding_get AssetBalance
	pop
	frame_dig 1 // rewardTokenHeldBack: uint64
	==

	// balance of remaining reward tokens should match the held back amount
	assert

	// examples/reti/validatorRegistry.algo.ts:1063
	// return tokenRewardBal;
	frame_dig 3 // tokenRewardBal: uint64

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 3
	retsub

// verifyPoolKeyCaller(poolKey: ValidatorPoolKey): void
//
// Logs the addition of a new validator to the system, its initial owner and manager
//
//
// verifyPoolKeyCaller verifies the passed in key (from a staking pool calling us to update metrics) is valid
// and matches the information we have in our state.  'Fake' pools could call us to update our data, but they
// can't fake the ids and most importantly application id(!) of the caller that has to match.
verifyPoolKeyCaller:
	proto 1 0

	// examples/reti/validatorRegistry.algo.ts:1161
	// assert(this.validatorList(poolKey.id).exists, "the specified validator id isn't valid")
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	box_len
	swap
	pop

	// the specified validator id isn't valid
	assert

	// examples/reti/validatorRegistry.algo.ts:1162
	// assert(poolKey.poolId <= MAX_POOLS, 'pool id not in valid range')
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 24
	<=

	// pool id not in valid range
	assert

	// examples/reti/validatorRegistry.algo.ts:1163
	// assert(
	//       poolKey.poolId > 0 && (poolKey.poolId as uint16) <= this.validatorList(poolKey.id).value.state.numPools,
	//       'pool id outside of range of pools created for this validator'
	//     )
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 0
	>
	dup
	bz *skip_and2
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 242
	int 2
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	<=
	&&

*skip_and2:
	// pool id outside of range of pools created for this validator
	assert

	// examples/reti/validatorRegistry.algo.ts:1169
	// assert(
	//       poolKey.poolAppId === this.validatorList(poolKey.id).value.pools[poolKey.poolId - 1].poolAppId,
	//       "The passed in app id doesn't match the passed in ids"
	//     )
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 16 8
	btoi
	int 268 // headOffset
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 0
	+
	int 8
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	==

	// The passed in app id doesn't match the passed in ids
	assert

	// examples/reti/validatorRegistry.algo.ts:1174
	// assert(this.txn.sender === AppID.fromUint64(poolKey.poolAppId).address)
	txn Sender
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 16 8
	btoi
	app_params_get AppAddress
	pop
	==
	assert

	// examples/reti/validatorRegistry.algo.ts:1176
	// assert(poolKey.id === (AppID.fromUint64(poolKey.poolAppId).globalState('validatorId') as uint64))
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 16 8
	btoi
	pushbytes 0x76616c696461746f724964 // "validatorId"
	app_global_get_ex

	// global state value does not exist: AppID.fromUint64(poolKey.poolAppId).globalState('validatorId')
	assert
	==
	assert

	// examples/reti/validatorRegistry.algo.ts:1177
	// assert(poolKey.poolId === (AppID.fromUint64(poolKey.poolAppId).globalState('poolId') as uint64))
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 16 8
	btoi
	pushbytes 0x706f6f6c4964 // "poolId"
	app_global_get_ex

	// global state value does not exist: AppID.fromUint64(poolKey.poolAppId).globalState('poolId')
	assert
	==
	assert
	retsub

// reverifyNFDOwnership(validatorId: ValidatorIdType): void
//
// This method verifies the ownership of NFD (Named Function Data) by a validator.
// If the ownership is no longer valid, it removes the NFD from the validator's configuration.
//
// @param {ValidatorIdType} validatorId - The id of the validator whose data should be re-evaluated.
reverifyNFDOwnership:
	proto 1 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// examples/reti/validatorRegistry.algo.ts:1187
	// validatorConfig = this.validatorList(validatorId).value.config
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	frame_bury 0 // storage key//validatorConfig

	// *if28_condition
	// examples/reti/validatorRegistry.algo.ts:1188
	// validatorConfig.nfdForInfo !== 0
	pushint 72
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	int 0
	!=
	bz *if28_end

	// *if28_consequent
	// examples/reti/validatorRegistry.algo.ts:1191
	// nfdOwner = AppID.fromUint64(validatorConfig.nfdForInfo).globalState('i.owner.a') as Address
	pushint 72
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	byte 0x692e6f776e65722e61 // "i.owner.a"
	app_global_get_ex

	// global state value does not exist: AppID.fromUint64(validatorConfig.nfdForInfo).globalState('i.owner.a')
	assert
	frame_bury 1 // nfdOwner: address

	// *if29_condition
	// examples/reti/validatorRegistry.algo.ts:1193
	// validatorConfig.owner !== nfdOwner && validatorConfig.manager !== nfdOwner
	int 8
	int 32
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	frame_dig 1 // nfdOwner: address
	!=
	dup
	bz *skip_and3
	pushint 40
	int 32
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	frame_dig 1 // nfdOwner: address
	!=
	&&

*skip_and3:
	bz *if29_end

	// *if29_consequent
	// examples/reti/validatorRegistry.algo.ts:1195
	// this.validatorList(validatorId).value.config.nfdForInfo = 0
	pushint 72
	byte 0x0000000000000000
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace

*if29_end:

*if28_end:
	retsub

// validateConfig(config: ValidatorConfig): void
validateConfig:
	proto 1 0

	// examples/reti/validatorRegistry.algo.ts:1202
	// assert(
	//       config.entryGatingType >= GATING_TYPE_NONE && config.entryGatingType <= GATING_TYPE_CONST_MAX,
	//       'gating type not valid'
	//     )
	frame_dig -1 // config: ValidatorConfig
	extract 80 1
	btoi
	int 0
	>=
	dup
	bz *skip_and4
	frame_dig -1 // config: ValidatorConfig
	extract 80 1
	btoi
	pushint 4
	<=
	&&

*skip_and4:
	// gating type not valid
	assert

	// examples/reti/validatorRegistry.algo.ts:1206
	// assert(
	//       config.epochRoundLength >= MIN_EPOCH_LENGTH && config.epochRoundLength <= MAX_EPOCH_LENGTH,
	//       'epoch length not in allowable range'
	//     )
	frame_dig -1 // config: ValidatorConfig
	extract 169 4
	btoi
	int 1
	>=
	dup
	bz *skip_and5
	frame_dig -1 // config: ValidatorConfig
	extract 169 4
	btoi
	int 1000000
	<=
	&&

*skip_and5:
	// epoch length not in allowable range
	assert

	// examples/reti/validatorRegistry.algo.ts:1210
	// assert(
	//       config.percentToValidator >= MIN_PCT_TO_VALIDATOR && config.percentToValidator <= MAX_PCT_TO_VALIDATOR,
	//       'commission percentage not valid'
	//     )
	frame_dig -1 // config: ValidatorConfig
	extract 173 4
	btoi
	int 0
	>=
	dup
	bz *skip_and6
	frame_dig -1 // config: ValidatorConfig
	extract 173 4
	btoi
	int 1000000
	<=
	&&

*skip_and6:
	// commission percentage not valid
	assert

	// *if30_condition
	// examples/reti/validatorRegistry.algo.ts:1214
	// config.percentToValidator !== 0
	frame_dig -1 // config: ValidatorConfig
	extract 173 4
	btoi
	int 0
	!=
	bz *if30_end

	// *if30_consequent
	// examples/reti/validatorRegistry.algo.ts:1215
	// assert(
	//         config.validatorCommissionAddress !== Address.zeroAddress,
	//         'validatorCommissionAddress must be set if percent to validator is not 0'
	//       )
	frame_dig -1 // config: ValidatorConfig
	extract 177 32
	global ZeroAddress
	!=

	// validatorCommissionAddress must be set if percent to validator is not 0
	assert

*if30_end:
	// examples/reti/validatorRegistry.algo.ts:1220
	// assert(config.minEntryStake >= MIN_ALGO_STAKE_PER_POOL, 'staking pool must have minimum entry of 1 algo')
	frame_dig -1 // config: ValidatorConfig
	extract 209 8
	btoi
	int 1000000
	>=

	// staking pool must have minimum entry of 1 algo
	assert

	// examples/reti/validatorRegistry.algo.ts:1222
	// assert(
	//       config.poolsPerNode > 0 && config.poolsPerNode <= MAX_POOLS_PER_NODE,
	//       'number of pools per node exceeds allowed number'
	//     )
	frame_dig -1 // config: ValidatorConfig
	extract 225 1
	btoi
	int 0
	>
	dup
	bz *skip_and7
	frame_dig -1 // config: ValidatorConfig
	extract 225 1
	btoi
	int 3
	<=
	&&

*skip_and7:
	// number of pools per node exceeds allowed number
	assert

	// *if31_condition
	// examples/reti/validatorRegistry.algo.ts:1226
	// config.sunsettingOn !== 0
	frame_dig -1 // config: ValidatorConfig
	extract 226 8
	btoi
	int 0
	!=
	bz *if31_end

	// *if31_consequent
	// examples/reti/validatorRegistry.algo.ts:1227
	// assert(config.sunsettingOn > globals.latestTimestamp, 'sunsettingOn must be later than now if set')
	frame_dig -1 // config: ValidatorConfig
	extract 226 8
	btoi
	global LatestTimestamp
	>

	// sunsettingOn must be later than now if set
	assert

*if31_end:
	retsub

// callPoolAddStake(stakedAmountPayment: PayTxn, poolKey: ValidatorPoolKey, mbrAmtPaid: uint64, isNewStakerToValidator: boolean, isNewStakerToProtocol: boolean): void
//
// Adds a stakers amount of algo to a validator pool, transferring the algo we received from them (already verified
// by our caller) to the staking pool account, and then telling it about the amount being added for the specified
// staker.
//
// @param {PayTxn} stakedAmountPayment - payment coming from staker to place into a pool
// @param {ValidatorPoolKey} poolKey - The key of the validator pool.
// @param {uint64} mbrAmtPaid - Amount the user is leaving behind in the validator to pay for their staker MBR cost
// @param {boolean} isNewStakerToValidator - if this is a new, first-time staker to the validator
// @param {boolean} isNewStakerToProtocol - if this is a new, first-time staker to the protocol
callPoolAddStake:
	proto 5 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// examples/reti/validatorRegistry.algo.ts:1249
	// poolAppId = this.validatorList(poolKey.id).value.pools[poolKey.poolId - 1].poolAppId
	int 268 // headOffset
	frame_dig -2 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 0
	+
	int 8
	byte 0x76 // "v"
	frame_dig -2 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 0 // poolAppId: uint64

	// examples/reti/validatorRegistry.algo.ts:1253
	// sendMethodCall<typeof StakingPool.prototype.addStake, uint64>({
	//       applicationID: AppID.fromUint64(poolAppId),
	//       methodArgs: [
	//         // =======
	//         // THIS IS A SEND of the amount received right back out and into the staking pool contract account.
	//         { amount: stakedAmountPayment.amount - mbrAmtPaid, receiver: AppID.fromUint64(poolAppId).address },
	//         // =======
	//         stakedAmountPayment.sender,
	//       ],
	//     })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// examples/reti/validatorRegistry.algo.ts:1258
	// amount: stakedAmountPayment.amount - mbrAmtPaid
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Amount
	frame_dig -3 // mbrAmtPaid: uint64
	-
	itxn_field Amount

	// examples/reti/validatorRegistry.algo.ts:1258
	// receiver: AppID.fromUint64(poolAppId).address
	frame_dig 0 // poolAppId: uint64
	app_params_get AppAddress
	pop
	itxn_field Receiver

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee
	itxn_next
	int 6 // appl
	itxn_field TypeEnum
	pushbytes 0xf9c70cbd // method "addStake(pay,address)uint64"
	itxn_field ApplicationArgs

	// examples/reti/validatorRegistry.algo.ts:1254
	// applicationID: AppID.fromUint64(poolAppId)
	frame_dig 0 // poolAppId: uint64
	itxn_field ApplicationID

	// examples/reti/validatorRegistry.algo.ts:1255
	// methodArgs: [
	//         // =======
	//         // THIS IS A SEND of the amount received right back out and into the staking pool contract account.
	//         { amount: stakedAmountPayment.amount - mbrAmtPaid, receiver: AppID.fromUint64(poolAppId).address },
	//         // =======
	//         stakedAmountPayment.sender,
	//       ]
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Sender
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0
	btoi

	// *if32_condition
	// examples/reti/validatorRegistry.algo.ts:1263
	// globals.opcodeBudget < 500
	global OpcodeBudget
	pushint 500
	<
	bz *if32_end

	// *if32_consequent
	// examples/reti/validatorRegistry.algo.ts:1264
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	pushint 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

*if32_end:
	// examples/reti/validatorRegistry.algo.ts:1268
	// poolNumStakers = AppID.fromUint64(poolAppId).globalState('numStakers') as uint64
	frame_dig 0 // poolAppId: uint64
	byte 0x6e756d5374616b657273 // "numStakers"
	app_global_get_ex

	// global state value does not exist: AppID.fromUint64(poolAppId).globalState('numStakers')
	assert
	frame_bury 1 // poolNumStakers: uint64

	// examples/reti/validatorRegistry.algo.ts:1269
	// poolAlgoStaked = AppID.fromUint64(poolAppId).globalState('staked') as uint64
	frame_dig 0 // poolAppId: uint64
	byte 0x7374616b6564 // "staked"
	app_global_get_ex

	// global state value does not exist: AppID.fromUint64(poolAppId).globalState('staked')
	assert
	frame_bury 2 // poolAlgoStaked: uint64

	// examples/reti/validatorRegistry.algo.ts:1270
	// this.validatorList(poolKey.id).value.pools[poolKey.poolId - 1].totalStakers = poolNumStakers as uint16
	int 268 // headOffset
	frame_dig -2 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 8 // headOffset
	+
	frame_dig 1 // poolNumStakers: uint64
	itob
	extract 6 2
	byte 0x76 // "v"
	frame_dig -2 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:1271
	// this.validatorList(poolKey.id).value.pools[poolKey.poolId - 1].totalAlgoStaked = poolAlgoStaked
	int 268 // headOffset
	frame_dig -2 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 10 // headOffset
	+
	frame_dig 2 // poolAlgoStaked: uint64
	itob
	byte 0x76 // "v"
	frame_dig -2 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_replace

	// *if33_condition
	// examples/reti/validatorRegistry.algo.ts:1274
	// isNewStakerToValidator
	frame_dig -4 // isNewStakerToValidator: boolean
	bz *if33_end

	// *if33_consequent
	// examples/reti/validatorRegistry.algo.ts:1275
	// this.validatorList(poolKey.id).value.state.totalStakers += 1
	pushint 244
	pushint 244
	int 8
	byte 0x76 // "v"
	frame_dig -2 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	int 1
	+
	itob
	byte 0x76 // "v"
	frame_dig -2 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_replace

*if33_end:
	// *if34_condition
	// examples/reti/validatorRegistry.algo.ts:1277
	// isNewStakerToProtocol
	frame_dig -5 // isNewStakerToProtocol: boolean
	bz *if34_end

	// *if34_consequent
	// examples/reti/validatorRegistry.algo.ts:1278
	// this.numStakers.value += 1
	byte 0x6e756d5374616b657273 // "numStakers"
	app_global_get
	int 1
	+
	byte 0x6e756d5374616b657273 // "numStakers"
	swap
	app_global_put

*if34_end:
	// examples/reti/validatorRegistry.algo.ts:1280
	// this.validatorList(poolKey.id).value.state.totalAlgoStaked += stakedAmountPayment.amount - mbrAmtPaid
	int 252
	dup
	int 8
	byte 0x76 // "v"
	frame_dig -2 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Amount
	frame_dig -3 // mbrAmtPaid: uint64
	-
	+
	itob
	byte 0x76 // "v"
	frame_dig -2 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:1281
	// this.totalAlgoStaked.value += stakedAmountPayment.amount - mbrAmtPaid
	byte 0x7374616b6564 // "staked"
	app_global_get
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Amount
	frame_dig -3 // mbrAmtPaid: uint64
	-
	+
	byte 0x7374616b6564 // "staked"
	swap
	app_global_put
	retsub

// updateStakerPoolSet(staker: Address, poolKey: ValidatorPoolKey): void
updateStakerPoolSet:
	proto 2 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// examples/reti/validatorRegistry.algo.ts:1285
	// assert(this.stakerPoolSet(staker).exists)
	byte 0x737073 // "sps"
	frame_dig -1 // staker: Address
	concat
	box_len
	swap
	pop
	assert

	// examples/reti/validatorRegistry.algo.ts:1287
	// poolSet = clone(this.stakerPoolSet(staker).value)
	byte 0x737073 // "sps"
	frame_dig -1 // staker: Address
	concat
	box_get

	// box value does not exist: this.stakerPoolSet(staker).value
	assert
	frame_bury 0 // poolSet: (uint64,uint64,uint64)[6]

	// examples/reti/validatorRegistry.algo.ts:1288
	// firstEmpty = 0
	int 0
	frame_bury 1 // firstEmpty: uint64

	// examples/reti/validatorRegistry.algo.ts:1289
	// for (let i = 0; i < this.stakerPoolSet(staker).value.length; i += 1)
	int 0
	frame_bury 2 // i: uint64

*for_7:
	// examples/reti/validatorRegistry.algo.ts:1289
	// i < this.stakerPoolSet(staker).value.length
	frame_dig 2 // i: uint64
	int 6
	<
	bz *for_7_end

	// *if35_condition
	// examples/reti/validatorRegistry.algo.ts:1290
	// poolSet[i] === poolKey
	frame_dig 0 // poolSet: (uint64,uint64,uint64)[6]
	frame_dig 2 // i: uint64
	int 24
	* // acc * typeLength
	int 24
	extract3
	frame_dig -2 // poolKey: ValidatorPoolKey
	==
	bz *if35_end

	// *if35_consequent
	// examples/reti/validatorRegistry.algo.ts:1292
	// return;
	retsub

*if35_end:
	// *if36_condition
	// examples/reti/validatorRegistry.algo.ts:1294
	// firstEmpty === 0 && poolSet[i].id === 0
	frame_dig 1 // firstEmpty: uint64
	int 0
	==
	dup
	bz *skip_and8
	frame_dig 0 // poolSet: (uint64,uint64,uint64)[6]
	frame_dig 2 // i: uint64
	int 24
	* // acc * typeLength
	int 0
	+
	int 8
	extract3
	btoi
	int 0
	==
	&&

*skip_and8:
	bz *if36_end

	// *if36_consequent
	// examples/reti/validatorRegistry.algo.ts:1295
	// firstEmpty = i + 1
	frame_dig 2 // i: uint64
	int 1
	+
	frame_bury 1 // firstEmpty: uint64

*if36_end:

*for_7_continue:
	// examples/reti/validatorRegistry.algo.ts:1289
	// i += 1
	frame_dig 2 // i: uint64
	int 1
	+
	frame_bury 2 // i: uint64
	b *for_7

*for_7_end:
	// *if37_condition
	// examples/reti/validatorRegistry.algo.ts:1298
	// firstEmpty === 0
	frame_dig 1 // firstEmpty: uint64
	int 0
	==
	bz *if37_end

	// *if37_consequent
	// No empty slot available in the staker pool set
	err

*if37_end:
	// examples/reti/validatorRegistry.algo.ts:1301
	// this.stakerPoolSet(staker).value[firstEmpty - 1] = poolKey
	frame_dig 1 // firstEmpty: uint64
	int 1
	-
	int 24
	* // acc * typeLength
	frame_dig -2 // poolKey: ValidatorPoolKey
	byte 0x737073 // "sps"
	frame_dig -1 // staker: Address
	concat
	cover 2
	box_replace
	retsub

// removeFromStakerPoolSet(staker: Address, poolKey: ValidatorPoolKey): [boolean, boolean]
//
// Removes a pool key from the staker's active pool set - fails if not found (!)
//
// @param {Address} staker - The address of the staker.
// @param {ValidatorPoolKey} poolKey - The pool key they should be stored in
//
// @return [boolean, boolean] [is the staker gone from ALL pools of the given VALIDATOR, and is staker gone from ALL pools]
removeFromStakerPoolSet:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 4

	// examples/reti/validatorRegistry.algo.ts:1314
	// inSameValidatorPoolCount = 0
	int 0
	frame_bury 0 // inSameValidatorPoolCount: uint64

	// examples/reti/validatorRegistry.algo.ts:1315
	// inAnyPoolCount = 0
	int 0
	frame_bury 1 // inAnyPoolCount: uint64

	// examples/reti/validatorRegistry.algo.ts:1316
	// found = false
	int 0
	frame_bury 2 // found: bool

	// examples/reti/validatorRegistry.algo.ts:1318
	// poolSet = clone(this.stakerPoolSet(staker).value)
	byte 0x737073 // "sps"
	frame_dig -1 // staker: Address
	concat
	box_get

	// box value does not exist: this.stakerPoolSet(staker).value
	assert
	frame_bury 3 // poolSet: (uint64,uint64,uint64)[6]

	// examples/reti/validatorRegistry.algo.ts:1319
	// for (let i = 0; i < this.stakerPoolSet(staker).value.length; i += 1)
	int 0
	frame_bury 4 // i: uint64

*for_8:
	// examples/reti/validatorRegistry.algo.ts:1319
	// i < this.stakerPoolSet(staker).value.length
	frame_dig 4 // i: uint64
	int 6
	<
	bz *for_8_end

	// *if38_condition
	// examples/reti/validatorRegistry.algo.ts:1320
	// poolSet[i].id === 0
	frame_dig 3 // poolSet: (uint64,uint64,uint64)[6]
	frame_dig 4 // i: uint64
	int 24
	* // acc * typeLength
	int 0
	+
	int 8
	extract3
	btoi
	int 0
	==
	bz *if38_end

	// *if38_consequent
	b *for_8_continue

*if38_end:
	// examples/reti/validatorRegistry.algo.ts:1323
	// inAnyPoolCount += 1
	frame_dig 1 // inAnyPoolCount: uint64
	int 1
	+
	frame_bury 1 // inAnyPoolCount: uint64

	// *if39_condition
	// examples/reti/validatorRegistry.algo.ts:1324
	// poolSet[i].id === poolKey.id
	frame_dig 3 // poolSet: (uint64,uint64,uint64)[6]
	frame_dig 4 // i: uint64
	int 24
	* // acc * typeLength
	int 0
	+
	int 8
	extract3
	btoi
	frame_dig -2 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	==
	bz *if39_end

	// *if39_consequent
	// *if40_condition
	// examples/reti/validatorRegistry.algo.ts:1325
	// poolSet[i] === poolKey
	frame_dig 3 // poolSet: (uint64,uint64,uint64)[6]
	frame_dig 4 // i: uint64
	int 24
	* // acc * typeLength
	int 24
	extract3
	frame_dig -2 // poolKey: ValidatorPoolKey
	==
	bz *if40_else

	// *if40_consequent
	// examples/reti/validatorRegistry.algo.ts:1326
	// found = true
	int 1
	frame_bury 2 // found: bool

	// examples/reti/validatorRegistry.algo.ts:1328
	// this.stakerPoolSet(staker).value[i] = { id: 0, poolId: 0, poolAppId: 0 }
	frame_dig 4 // i: uint64
	int 24
	* // acc * typeLength
	pushbytes 0x000000000000000000000000000000000000000000000000
	byte 0x737073 // "sps"
	frame_dig -1 // staker: Address
	concat
	cover 2
	box_replace
	b *if40_end

*if40_else:
	// examples/reti/validatorRegistry.algo.ts:1330
	// inSameValidatorPoolCount += 1
	frame_dig 0 // inSameValidatorPoolCount: uint64
	int 1
	+
	frame_bury 0 // inSameValidatorPoolCount: uint64

*if40_end:

*if39_end:

*for_8_continue:
	// examples/reti/validatorRegistry.algo.ts:1319
	// i += 1
	frame_dig 4 // i: uint64
	int 1
	+
	frame_bury 4 // i: uint64
	b *for_8

*for_8_end:
	// *if41_condition
	// examples/reti/validatorRegistry.algo.ts:1334
	// !found
	frame_dig 2 // found: bool
	!
	bz *if41_end

	// *if41_consequent
	// No matching slot found when told to remove a pool from the stakers set
	err

*if41_end:
	// examples/reti/validatorRegistry.algo.ts:1338
	// return [inSameValidatorPoolCount === 0, inAnyPoolCount === 0];
	byte 0x00
	int 0
	frame_dig 0 // inSameValidatorPoolCount: uint64
	int 0
	==
	setbit
	int 1
	frame_dig 1 // inAnyPoolCount: uint64
	int 0
	==
	setbit

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 4
	retsub

// addPoolToNode(validatorId: ValidatorIdType, poolAppId: uint64, nodeNum: uint64): void
addPoolToNode:
	proto 3 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// examples/reti/validatorRegistry.algo.ts:1342
	// nodePoolAssignments = clone(this.validatorList(validatorId).value.nodePoolAssignments)
	int 900 // headOffset
	pushint 192
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	frame_bury 0 // nodePoolAssignments: ((uint64[3])[8])

	// examples/reti/validatorRegistry.algo.ts:1343
	// maxPoolsPerNodeForThisValidator = this.validatorList(validatorId).value.config.poolsPerNode as uint64
	pushint 225
	int 1
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 1 // maxPoolsPerNodeForThisValidator: uint64

	// examples/reti/validatorRegistry.algo.ts:1345
	// assert(nodeNum >= 1 && nodeNum <= MAX_NODES, 'node number not in valid range')
	frame_dig -3 // nodeNum: uint64
	int 1
	>=
	dup
	bz *skip_and9
	frame_dig -3 // nodeNum: uint64
	int 8
	<=
	&&

*skip_and9:
	// node number not in valid range
	assert

	// examples/reti/validatorRegistry.algo.ts:1347
	// for (let i = 0; i < maxPoolsPerNodeForThisValidator; i += 1)
	int 0
	frame_bury 2 // i: uint64

*for_9:
	// examples/reti/validatorRegistry.algo.ts:1347
	// i < maxPoolsPerNodeForThisValidator
	frame_dig 2 // i: uint64
	frame_dig 1 // maxPoolsPerNodeForThisValidator: uint64
	<
	bz *for_9_end

	// *if42_condition
	// examples/reti/validatorRegistry.algo.ts:1348
	// nodePoolAssignments.nodes[nodeNum - 1].poolAppIds[i] === 0
	frame_dig 0 // nodePoolAssignments: ((uint64[3])[8])
	int 0
	frame_dig -3 // nodeNum: uint64
	int 1
	-
	int 24
	* // acc * typeLength
	+
	int 0
	+
	frame_dig 2 // i: uint64
	int 8
	* // acc * typeLength
	+
	int 8
	extract3
	btoi
	int 0
	==
	bz *if42_end

	// *if42_consequent
	// examples/reti/validatorRegistry.algo.ts:1350
	// this.validatorList(validatorId).value.nodePoolAssignments.nodes[nodeNum - 1].poolAppIds[i] = poolAppId
	int 900
	frame_dig -3 // nodeNum: uint64
	int 1
	-
	int 24
	* // acc * typeLength
	+
	int 0
	+
	frame_dig 2 // i: uint64
	int 8
	* // acc * typeLength
	+
	frame_dig -2 // poolAppId: uint64
	itob
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:1351
	// return;
	retsub

*if42_end:

*for_9_continue:
	// examples/reti/validatorRegistry.algo.ts:1347
	// i += 1
	frame_dig 2 // i: uint64
	int 1
	+
	frame_bury 2 // i: uint64
	b *for_9

*for_9_end:
	// no available space in specified node for this pool
	err
	retsub

// doesStakerMeetGating(validatorId: ValidatorIdType, valueToVerify: uint64): void
//
// Checks if a staker meets the gating requirements specified by the validator.
//
// @param {ValidatorIdType} validatorId - The id of the validator.
// @param {uint64} valueToVerify - The value to verify against the gating requirements.
// @returns {void} or asserts if requirements not met.
doesStakerMeetGating:
	proto 2 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 8

	// examples/reti/validatorRegistry.algo.ts:1365
	// type = this.validatorList(validatorId).value.config.entryGatingType
	pushint 80
	int 1
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 0 // type: uint8

	// *if43_condition
	// examples/reti/validatorRegistry.algo.ts:1366
	// type === GATING_TYPE_NONE
	frame_dig 0 // type: uint8
	int 0
	==
	bz *if43_end

	// *if43_consequent
	// examples/reti/validatorRegistry.algo.ts:1367
	// return;
	retsub

*if43_end:
	// examples/reti/validatorRegistry.algo.ts:1369
	// staker = this.txn.sender
	txn Sender
	frame_bury 1 // staker: address

	// examples/reti/validatorRegistry.algo.ts:1370
	// config = clone(this.validatorList(validatorId).value.config)
	int 0
	int 242
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	frame_bury 2 // config: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)

	// *if44_condition
	// examples/reti/validatorRegistry.algo.ts:1374
	// type === GATING_TYPE_ASSETS_CREATED_BY ||
	//       type === GATING_TYPE_ASSET_ID ||
	//       type === GATING_TYPE_CREATED_BY_NFD_ADDRESSES
	frame_dig 0 // type: uint8
	int 1
	==
	dup
	bnz *skip_or4
	frame_dig 0 // type: uint8
	int 2
	==
	||

*skip_or4:
	dup
	bnz *skip_or5
	frame_dig 0 // type: uint8
	int 3
	==
	||

*skip_or5:
	bz *if44_end

	// *if44_consequent
	// examples/reti/validatorRegistry.algo.ts:1378
	// assert(valueToVerify !== 0)
	frame_dig -2 // valueToVerify: uint64
	int 0
	!=
	assert

	// examples/reti/validatorRegistry.algo.ts:1379
	// balRequired = this.validatorList(validatorId).value.config.gatingAssetMinBalance
	pushint 145
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 3 // balRequired: uint64

	// *if45_condition
	// examples/reti/validatorRegistry.algo.ts:1380
	// balRequired === 0
	frame_dig 3 // balRequired: uint64
	int 0
	==
	bz *if45_end

	// *if45_consequent
	// examples/reti/validatorRegistry.algo.ts:1381
	// balRequired = 1
	int 1
	frame_bury 3 // balRequired: uint64

*if45_end:
	// examples/reti/validatorRegistry.algo.ts:1383
	// assert(
	//         staker.assetBalance(AssetID.fromUint64(valueToVerify)) >= balRequired,
	//         'must have required minimum balance of validator defined token to add stake'
	//       )
	frame_dig 1 // staker: address
	frame_dig -2 // valueToVerify: uint64
	asset_holding_get AssetBalance
	pop
	frame_dig 3 // balRequired: uint64
	>=

	// must have required minimum balance of validator defined token to add stake
	assert

*if44_end:
	// *if46_condition
	// examples/reti/validatorRegistry.algo.ts:1388
	// type === GATING_TYPE_ASSETS_CREATED_BY
	frame_dig 0 // type: uint8
	int 1
	==
	bz *if46_end

	// *if46_consequent
	// examples/reti/validatorRegistry.algo.ts:1389
	// assert(
	//         AssetID.fromUint64(valueToVerify).creator === config.entryGatingAddress,
	//         'specified asset must be created by creator that the validator defined as a requirement to stake'
	//       )
	frame_dig -2 // valueToVerify: uint64
	asset_params_get AssetCreator
	pop
	frame_dig 2 // config: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 81 32
	==

	// specified asset must be created by creator that the validator defined as a requirement to stake
	assert

*if46_end:
	// *if47_condition
	// examples/reti/validatorRegistry.algo.ts:1394
	// type === GATING_TYPE_ASSET_ID
	frame_dig 0 // type: uint8
	int 2
	==
	bz *if47_end

	// *if47_consequent
	// examples/reti/validatorRegistry.algo.ts:1395
	// assert(valueToVerify !== 0)
	frame_dig -2 // valueToVerify: uint64
	int 0
	!=
	assert

	// examples/reti/validatorRegistry.algo.ts:1396
	// found = false
	int 0
	frame_bury 4 // found: bool

	// examples/reti/validatorRegistry.algo.ts:1397
	// config.entryGatingAssets
	frame_dig 2 // config: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 113 32
	dup
	frame_bury 5 // copy of the array we are iterating over
	extract 0 8
	btoi
	frame_bury 6 // assetId: uint64
	int 0
	frame_bury 7 // the offset we are extracting the next element from

*forOf_0:
	// *if48_condition
	// examples/reti/validatorRegistry.algo.ts:1398
	// valueToVerify === assetId
	frame_dig -2 // valueToVerify: uint64
	frame_dig 6 // assetId: uint64
	==
	bz *if48_end

	// *if48_consequent
	// examples/reti/validatorRegistry.algo.ts:1399
	// found = true
	int 1
	frame_bury 4 // found: bool
	b *forOf_0_end

*if48_end:

*forOf_0_continue:
	// increment offset and loop if not out of bounds
	frame_dig 7 // the offset we are extracting the next element from
	int 8
	+
	dup
	int 32 // offset of last element
	<
	bz *forOf_0_end
	frame_bury 7 // the offset we are extracting the next element from
	frame_dig 5 // copy of the array we are iterating over
	frame_dig 7 // the offset we are extracting the next element from
	int 8
	extract
	btoi
	frame_bury 6 // assetId: uint64
	b *forOf_0

*forOf_0_end:
	// examples/reti/validatorRegistry.algo.ts:1403
	// assert(found, 'specified asset must be identical to the asset id defined as a requirement to stake')
	frame_dig 4 // found: bool

	// specified asset must be identical to the asset id defined as a requirement to stake
	assert

*if47_end:
	// *if49_condition
	// examples/reti/validatorRegistry.algo.ts:1405
	// type === GATING_TYPE_CREATED_BY_NFD_ADDRESSES
	frame_dig 0 // type: uint8
	int 3
	==
	bz *if49_end

	// *if49_consequent
	// examples/reti/validatorRegistry.algo.ts:1408
	// assert(
	//         this.isAddressInNFDCAAlgoList(config.entryGatingAssets[0], AssetID.fromUint64(valueToVerify).creator),
	//         'specified asset must be created by creator that is one of the linked addresses in an nfd'
	//       )
	frame_dig -2 // valueToVerify: uint64
	asset_params_get AssetCreator
	pop
	frame_dig 2 // config: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 113 8
	btoi
	callsub isAddressInNFDCAAlgoList

	// specified asset must be created by creator that is one of the linked addresses in an nfd
	assert

*if49_end:
	// *if50_condition
	// examples/reti/validatorRegistry.algo.ts:1413
	// type === GATING_TYPE_SEGMENT_OF_NFD
	frame_dig 0 // type: uint8
	pushint 4
	==
	bz *if50_end

	// *if50_consequent
	// examples/reti/validatorRegistry.algo.ts:1415
	// userOfferedNFDAppID = valueToVerify
	frame_dig -2 // valueToVerify: uint64
	frame_bury 8 // userOfferedNFDAppID: uint64

	// examples/reti/validatorRegistry.algo.ts:1416
	// assert(this.isNFDAppIDValid(userOfferedNFDAppID), 'provided NFD must be valid')
	frame_dig 8 // userOfferedNFDAppID: uint64
	callsub isNFDAppIDValid

	// provided NFD must be valid
	assert

	// examples/reti/validatorRegistry.algo.ts:1419
	// assert(
	//         rawBytes(AppID.fromUint64(userOfferedNFDAppID).globalState('i.owner.a') as Address) === rawBytes(staker) ||
	//           this.isAddressInNFDCAAlgoList(userOfferedNFDAppID, staker),
	//         "provided nfd for entry isn't owned or linked to the staker"
	//       )
	frame_dig 8 // userOfferedNFDAppID: uint64
	byte 0x692e6f776e65722e61 // "i.owner.a"
	app_global_get_ex

	// global state value does not exist: AppID.fromUint64(userOfferedNFDAppID).globalState('i.owner.a')
	assert
	frame_dig 1 // staker: address
	==
	dup
	bnz *skip_or6
	frame_dig 1 // staker: address
	frame_dig 8 // userOfferedNFDAppID: uint64
	callsub isAddressInNFDCAAlgoList
	||

*skip_or6:
	// provided nfd for entry isn't owned or linked to the staker
	assert

	// examples/reti/validatorRegistry.algo.ts:1426
	// assert(
	//         btoi(AppID.fromUint64(userOfferedNFDAppID).globalState('i.parentAppID') as bytes) ===
	//           config.entryGatingAssets[0],
	//         'specified nfd must be a segment of the nfd the validator specified as a requirement'
	//       )
	frame_dig 8 // userOfferedNFDAppID: uint64
	pushbytes 0x692e706172656e744170704944 // "i.parentAppID"
	app_global_get_ex

	// global state value does not exist: AppID.fromUint64(userOfferedNFDAppID).globalState('i.parentAppID')
	assert
	btoi
	frame_dig 2 // config: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 113 8
	btoi
	==

	// specified nfd must be a segment of the nfd the validator specified as a requirement
	assert

*if50_end:
	retsub

// isNFDAppIDValid(nfdAppID: uint64): boolean
//
// Checks if the given NFD App id is valid.  Using only the App id there's no validation against the name (ie: that nfd X is name Y)
// So it's assumed for the caller, the app id alone is fine.  The name is fetched from the specified app id and the two
// together are used for validity check call to the nfd registry.
//
// @param {uint64} nfdAppID - The NFD App id to verify.
//
// @returns {boolean} - Returns true if the NFD App id is valid, otherwise false.
isNFDAppIDValid:
	proto 1 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/reti/validatorRegistry.algo.ts:1445
	// userOfferedNFDName = AppID.fromUint64(nfdAppID).globalState('i.name') as string
	frame_dig -1 // nfdAppID: uint64
	pushbytes 0x692e6e616d65 // "i.name"
	app_global_get_ex

	// global state value does not exist: AppID.fromUint64(nfdAppID).globalState('i.name')
	assert
	frame_bury 0 // userOfferedNFDName: string

	// examples/reti/validatorRegistry.algo.ts:1447
	// sendAppCall({
	//       applicationID: AppID.fromUint64(this.nfdRegistryAppId),
	//       applicationArgs: ['is_valid_nfd_appid', userOfferedNFDName, itob(nfdAppID)],
	//       applications: [AppID.fromUint64(nfdAppID)],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum

	// examples/reti/validatorRegistry.algo.ts:1448
	// applicationID: AppID.fromUint64(this.nfdRegistryAppId)
	intc 0 // TMPL_nfdRegistryAppId
	itxn_field ApplicationID

	// examples/reti/validatorRegistry.algo.ts:1449
	// applicationArgs: ['is_valid_nfd_appid', userOfferedNFDName, itob(nfdAppID)]
	byte 0x69735f76616c69645f6e66645f6170706964 // "is_valid_nfd_appid"
	itxn_field ApplicationArgs
	frame_dig 0 // userOfferedNFDName: string
	itxn_field ApplicationArgs
	frame_dig -1 // nfdAppID: uint64
	itob
	itxn_field ApplicationArgs

	// examples/reti/validatorRegistry.algo.ts:1450
	// applications: [AppID.fromUint64(nfdAppID)]
	frame_dig -1 // nfdAppID: uint64
	itxn_field Applications

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/validatorRegistry.algo.ts:1452
	// return btoi(this.itxn.lastLog) === 1;
	itxn LastLog
	btoi
	int 1
	==

	// set the subroutine return value
	frame_bury 0
	retsub

// isAddressInNFDCAAlgoList(nfdAppID: uint64, addrToFind: Address): boolean
//
// Checks if the specified address is present in an NFDs list of verified addresses.
// The NFD is assumed to have already been validated as official.
//
// @param {uint64} nfdAppID - The NFD application id.
// @param {Address} addrToFind - The address to find in the v.caAlgo.0.as property
// @return {boolean} - `true` if the address is present, `false` otherwise.
isAddressInNFDCAAlgoList:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// examples/reti/validatorRegistry.algo.ts:1464
	// sendAppCall({
	//       applicationID: AppID.fromUint64(nfdAppID),
	//       applicationArgs: ['read_property', 'v.caAlgo.0.as'],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum

	// examples/reti/validatorRegistry.algo.ts:1465
	// applicationID: AppID.fromUint64(nfdAppID)
	frame_dig -1 // nfdAppID: uint64
	itxn_field ApplicationID

	// examples/reti/validatorRegistry.algo.ts:1466
	// applicationArgs: ['read_property', 'v.caAlgo.0.as']
	pushbytes 0x726561645f70726f7065727479 // "read_property"
	itxn_field ApplicationArgs
	pushbytes 0x762e6361416c676f2e302e6173 // "v.caAlgo.0.as"
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/validatorRegistry.algo.ts:1468
	// caAlgoData = this.itxn.lastLog
	itxn LastLog
	frame_bury 0 // caAlgoData: byte[]

	// examples/reti/validatorRegistry.algo.ts:1469
	// for (let i = 0; i < caAlgoData.length; i += 32)
	int 0
	frame_bury 1 // i: uint64

*for_10:
	// examples/reti/validatorRegistry.algo.ts:1469
	// i < caAlgoData.length
	frame_dig 1 // i: uint64
	frame_dig 0 // caAlgoData: byte[]
	len
	<
	bz *for_10_end

	// examples/reti/validatorRegistry.algo.ts:1470
	// addr = extract3(caAlgoData, i, 32)
	frame_dig 0 // caAlgoData: byte[]
	frame_dig 1 // i: uint64
	int 32
	extract3
	frame_bury 2 // addr: byte[]

	// *if51_condition
	// examples/reti/validatorRegistry.algo.ts:1471
	// addr !== rawBytes(globals.zeroAddress) && addr === rawBytes(addrToFind)
	frame_dig 2 // addr: byte[]
	global ZeroAddress
	!=
	dup
	bz *skip_and10
	frame_dig 2 // addr: byte[]
	frame_dig -2 // addrToFind: Address
	==
	&&

*skip_and10:
	bz *if51_end

	// *if51_consequent
	// examples/reti/validatorRegistry.algo.ts:1472
	// return true;
	int 1
	b *isAddressInNFDCAAlgoList*return

*if51_end:

*for_10_continue:
	// examples/reti/validatorRegistry.algo.ts:1469
	// i += 32
	frame_dig 1 // i: uint64
	int 32
	+
	frame_bury 1 // i: uint64
	b *for_10

*for_10_end:
	// examples/reti/validatorRegistry.algo.ts:1475
	// return false;
	int 0

*isAddressInNFDCAAlgoList*return:
	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 2
	retsub

// algoSaturationLevel(): uint64
//
// Returns the maximum allowed stake per validator based on a percentage of all current online stake before
// the validator is considered saturated - where rewards are diminished.
// NOTE: this function is defined twice - here and in staking pool contract.  Both must be identical.
algoSaturationLevel:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/reti/validatorRegistry.algo.ts:1484
	// online = this.getCurrentOnlineStake()
	callsub getCurrentOnlineStake
	frame_bury 0 // online: uint64

	// examples/reti/validatorRegistry.algo.ts:1486
	// return wideRatio([online, MAX_VALIDATOR_SOFT_PCT_OF_ONLINE_1DECIMAL], [1000]);
	frame_dig 0 // online: uint64
	pushint 100
	mulw
	int 0
	pushint 1000
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert

	// set the subroutine return value
	frame_bury 0
	retsub

// maxAllowedStake(): uint64
//
// Returns the MAXIMUM allowed stake per validator based on a percentage of all current online stake.
// Adding stake is completely blocked at this amount.
maxAllowedStake:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/reti/validatorRegistry.algo.ts:1494
	// online = this.getCurrentOnlineStake()
	callsub getCurrentOnlineStake
	frame_bury 0 // online: uint64

	// examples/reti/validatorRegistry.algo.ts:1496
	// return wideRatio([online, MAX_VALIDATOR_HARD_PCT_OF_ONLINE_1DECIMAL], [1000]);
	frame_dig 0 // online: uint64
	pushint 150
	mulw
	int 0
	pushint 1000
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert

	// set the subroutine return value
	frame_bury 0
	retsub

// maxAlgoAllowedPerPool(): uint64
//
// Returns the MAXIMUM allowed stake per pool and still receive incentives - we'll treat this as the 'max per pool'
maxAlgoAllowedPerPool:
	proto 0 1

	// examples/reti/validatorRegistry.algo.ts:1504
	// return 70_000_000_000_000;
	pushint 70_000_000_000_000
	retsub

// getCurrentOnlineStake(): uint64
getCurrentOnlineStake:
	proto 0 1

	// examples/reti/validatorRegistry.algo.ts:1509
	// return 2_000_000_000_000_000;
	pushint 2_000_000_000_000_000
	retsub

// minBalanceForAccount(contracts: uint64, extraPages: uint64, assets: uint64, localInts: uint64, localBytes: uint64, globalInts: uint64, globalBytes: uint64): uint64
minBalanceForAccount:
	proto 7 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/reti/validatorRegistry.algo.ts:1521
	// minBal = ALGORAND_ACCOUNT_MIN_BALANCE
	int 100000
	frame_bury 0 // minBal: uint64

	// examples/reti/validatorRegistry.algo.ts:1522
	// minBal += contracts * APPLICATION_BASE_FEE
	frame_dig 0 // minBal: uint64
	frame_dig -1 // contracts: uint64
	int 100000
	*
	+
	frame_bury 0 // minBal: uint64

	// examples/reti/validatorRegistry.algo.ts:1523
	// minBal += extraPages * APPLICATION_BASE_FEE
	frame_dig 0 // minBal: uint64
	frame_dig -2 // extraPages: uint64
	int 100000
	*
	+
	frame_bury 0 // minBal: uint64

	// examples/reti/validatorRegistry.algo.ts:1524
	// minBal += assets * ASSET_HOLDING_FEE
	frame_dig 0 // minBal: uint64
	frame_dig -3 // assets: uint64
	int 100000
	*
	+
	frame_bury 0 // minBal: uint64

	// examples/reti/validatorRegistry.algo.ts:1525
	// minBal += localInts * SSC_VALUE_UINT
	frame_dig 0 // minBal: uint64
	frame_dig -4 // localInts: uint64
	pushint 28500
	*
	+
	frame_bury 0 // minBal: uint64

	// examples/reti/validatorRegistry.algo.ts:1526
	// minBal += globalInts * SSC_VALUE_UINT
	frame_dig 0 // minBal: uint64
	frame_dig -6 // globalInts: uint64
	pushint 28500
	*
	+
	frame_bury 0 // minBal: uint64

	// examples/reti/validatorRegistry.algo.ts:1527
	// minBal += localBytes * SSC_VALUE_BYTES
	frame_dig 0 // minBal: uint64
	frame_dig -5 // localBytes: uint64
	pushint 50000
	*
	+
	frame_bury 0 // minBal: uint64

	// examples/reti/validatorRegistry.algo.ts:1528
	// minBal += globalBytes * SSC_VALUE_BYTES
	frame_dig 0 // minBal: uint64
	frame_dig -7 // globalBytes: uint64
	pushint 50000
	*
	+
	frame_bury 0 // minBal: uint64

	// examples/reti/validatorRegistry.algo.ts:1529
	// return minBal;
	frame_dig 0 // minBal: uint64

	// set the subroutine return value
	frame_bury 0
	retsub

// costForBoxStorage(totalNumBytes: uint64): uint64
costForBoxStorage:
	proto 1 1

	// examples/reti/validatorRegistry.algo.ts:1536
	// return SCBOX_PERBOX + totalNumBytes * SCBOX_PERBYTE;
	pushint 2500
	frame_dig -1 // totalNumBytes: uint64
	pushint 400
	*
	+
	retsub

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x1b5e82c6 // method "initStakingContract(uint64)void"
	pushbytes 0x79472d83 // method "loadStakingContractData(uint64,byte[])void"
	pushbytes 0x5f7acfd9 // method "finalizeStakingContract()void"
	pushbytes 0x3172ca9d // method "gas()void"
	pushbytes 0x8a87142d // method "getMbrAmounts()(uint64,uint64,uint64,uint64)"
	pushbytes 0xd1366cc3 // method "getProtocolConstraints()(uint64,uint64,uint64,uint64,uint64,uint64,uint64,uint64,uint64,uint64,uint64)"
	pushbytes 0x3b045c5c // method "getNumValidators()uint64"
	pushbytes 0x75aff61d // method "getValidatorConfig(uint64)(uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)"
	pushbytes 0x1f2f0109 // method "getValidatorState(uint64)(uint16,uint64,uint64,uint64)"
	pushbytes 0x2fa22c4b // method "getValidatorOwnerAndManager(uint64)(address,address)"
	pushbytes 0x910e94ac // method "getPools(uint64)(uint64,uint16,uint64)[]"
	pushbytes 0x572767d1 // method "getPoolAppId(uint64,uint64)uint64"
	pushbytes 0x9b504aaf // method "getPoolInfo((uint64,uint64,uint64))(uint64,uint16,uint64)"
	pushbytes 0xfbc63178 // method "getCurMaxStakePerPool(uint64)uint64"
	pushbytes 0x24498cf4 // method "doesStakerNeedToPayMBR(address)bool"
	pushbytes 0xf846dd7a // method "getStakedPoolsForAccount(address)(uint64,uint64,uint64)[]"
	pushbytes 0x83050501 // method "getTokenPayoutRatio(uint64)(uint64[24],uint64)"
	pushbytes 0x7bbb6c8d // method "getNodePoolAssignments(uint64)((uint64[3])[8])"
	pushbytes 0xf839414a // method "getNFDRegistryID()uint64"
	pushbytes 0x0c317cfb // method "addValidator(pay,string,(uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64))uint64"
	pushbytes 0x3e288972 // method "changeValidatorManager(uint64,address)void"
	pushbytes 0xdd5faada // method "changeValidatorSunsetInfo(uint64,uint64,uint64)void"
	pushbytes 0x18aac7a7 // method "changeValidatorNFD(uint64,uint64,string)void"
	pushbytes 0xf99ef54d // method "changeValidatorCommissionAddress(uint64,address)void"
	pushbytes 0x10809d4d // method "changeValidatorRewardInfo(uint64,uint8,address,uint64[4],uint64,uint64)void"
	pushbytes 0xe778dd5a // method "addPool(pay,uint64,uint64)(uint64,uint64,uint64)"
	pushbytes 0xbf5259d0 // method "addStake(pay,uint64,uint64)(uint64,uint64,uint64)"
	pushbytes 0x4df8d86e // method "setTokenPayoutRatio(uint64)(uint64[24],uint64)"
	pushbytes 0x418fcefc // method "stakeUpdatedViaRewards((uint64,uint64,uint64),uint64,uint64,uint64,uint64)void"
	pushbytes 0xa2dc51b5 // method "stakeRemoved((uint64,uint64,uint64),address,uint64,uint64,bool)void"
	pushbytes 0x2873f504 // method "findPoolForStaker(uint64,address,uint64)((uint64,uint64,uint64),bool,bool)"
	pushbytes 0x0547f4fe // method "movePoolToNode(uint64,uint64,uint64)void"
	pushbytes 0xcb668358 // method "emptyTokenRewards(uint64,address)uint64"
	txna ApplicationArgs 0
	match *abi_route_initStakingContract *abi_route_loadStakingContractData *abi_route_finalizeStakingContract *abi_route_gas *abi_route_getMbrAmounts *abi_route_getProtocolConstraints *abi_route_getNumValidators *abi_route_getValidatorConfig *abi_route_getValidatorState *abi_route_getValidatorOwnerAndManager *abi_route_getPools *abi_route_getPoolAppId *abi_route_getPoolInfo *abi_route_getCurMaxStakePerPool *abi_route_doesStakerNeedToPayMBR *abi_route_getStakedPoolsForAccount *abi_route_getTokenPayoutRatio *abi_route_getNodePoolAssignments *abi_route_getNFDRegistryID *abi_route_addValidator *abi_route_changeValidatorManager *abi_route_changeValidatorSunsetInfo *abi_route_changeValidatorNFD *abi_route_changeValidatorCommissionAddress *abi_route_changeValidatorRewardInfo *abi_route_addPool *abi_route_addStake *abi_route_setTokenPayoutRatio *abi_route_stakeUpdatedViaRewards *abi_route_stakeRemoved *abi_route_findPoolForStaker *abi_route_movePoolToNode *abi_route_emptyTokenRewards

	// this contract does not implement the given ABI method for call NoOp
	err

*call_UpdateApplication:
	pushbytes 0x46f76533 // method "updateApplication()void"
	txna ApplicationArgs 0
	match *abi_route_updateApplication

	// this contract does not implement the given ABI method for call UpdateApplication
	err", + "approval": "#pragma version 10
intcblock TMPL_nfdRegistryAppId 0 1 8 268 24 32 18 6 100000 260 700 242 900 3 1000000 2 10 252
bytecblock 0x76 0x706f6f6c54656d706c617465417070726f76616c4279746573 0x151f7c75 0x 0x6e756d5374616b657273 0x69735f76616c69645f6e66645f6170706964 0x7374616b6564 0x737073 0x692e6f776e65722e61 0x0000000000000000 0x0a8101 0x696e6974 0x6e756d56 0x00 0x63f3f28b

// This TEAL was generated by TEALScript v0.105.0
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following lines of TEAL are used to initialize template variables in scratch slots
intc 0 // TMPL_nfdRegistryAppId

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
int 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *call_UpdateApplication *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// updateApplication()void
*abi_route_updateApplication:
	// execute updateApplication()void
	callsub updateApplication
	int 1
	return

// updateApplication(): void
updateApplication:
	proto 0 0

	// examples/reti/validatorRegistry.algo.ts:202
	// assert(this.txn.sender === Address.fromAddress('LZ4V2IRVLCXFJK4REJV4TAGEKEYTA2GMR6TC2344OB3L3AF3MWXZ6ZAFIQ'))
	txn Sender
	pushbytes 0x5e795d223558ae54ab91226bc980c451313068cc8fa62d6f9c7076bd80bb65af // addr "LZ4V2IRVLCXFJK4REJV4TAGEKEYTA2GMR6TC2344OB3L3AF3MWXZ6ZAFIQ"
	==
	assert

	// examples/reti/validatorRegistry.algo.ts:204
	// this.stakingPoolApprovalProgram.delete()
	byte 0x706f6f6c54656d706c617465417070726f76616c4279746573 // "poolTemplateApprovalBytes"
	box_del

	// examples/reti/validatorRegistry.algo.ts:205
	// this.stakingPoolInitialized.value = false
	byte 0x696e6974 // "init"
	int 0
	byte 0x00
	int 0
	uncover 2
	setbit
	app_global_put
	retsub

// createApplication()void
*abi_route_createApplication:
	// execute createApplication()void
	callsub createApplication
	int 1
	return

// createApplication(): void
createApplication:
	proto 0 0

	// examples/reti/validatorRegistry.algo.ts:209
	// this.stakingPoolInitialized.value = false
	byte 0x696e6974 // "init"
	int 0
	byte 0x00
	int 0
	uncover 2
	setbit
	app_global_put

	// examples/reti/validatorRegistry.algo.ts:210
	// this.numValidators.value = 0
	byte 0x6e756d56 // "numV"
	int 0
	app_global_put

	// examples/reti/validatorRegistry.algo.ts:211
	// this.numStakers.value = 0
	byte 0x6e756d5374616b657273 // "numStakers"
	int 0
	app_global_put

	// examples/reti/validatorRegistry.algo.ts:212
	// this.totalAlgoStaked.value = 0
	byte 0x7374616b6564 // "staked"
	int 0
	app_global_put
	retsub

// initStakingContract(uint64)void
*abi_route_initStakingContract:
	// approvalProgramSize: uint64
	txna ApplicationArgs 1
	btoi

	// execute initStakingContract(uint64)void
	callsub initStakingContract
	int 1
	return

// initStakingContract(approvalProgramSize: uint64): void
initStakingContract:
	proto 1 0

	// examples/reti/validatorRegistry.algo.ts:217
	// this.stakingPoolApprovalProgram.create(approvalProgramSize)
	byte 0x706f6f6c54656d706c617465417070726f76616c4279746573 // "poolTemplateApprovalBytes"
	frame_dig -1 // approvalProgramSize: uint64
	box_create
	pop
	retsub

// loadStakingContractData(uint64,byte[])void
*abi_route_loadStakingContractData:
	// data: byte[]
	txna ApplicationArgs 2
	extract 2 0

	// offset: uint64
	txna ApplicationArgs 1
	btoi

	// execute loadStakingContractData(uint64,byte[])void
	callsub loadStakingContractData
	int 1
	return

// loadStakingContractData(offset: uint64, data: bytes): void
loadStakingContractData:
	proto 2 0

	// examples/reti/validatorRegistry.algo.ts:221
	// assert(!this.stakingPoolInitialized.value)
	byte 0x696e6974 // "init"
	app_global_get
	int 0
	getbit
	!
	assert

	// examples/reti/validatorRegistry.algo.ts:222
	// this.stakingPoolApprovalProgram.replace(offset, data)
	byte 0x706f6f6c54656d706c617465417070726f76616c4279746573 // "poolTemplateApprovalBytes"
	frame_dig -1 // offset: uint64
	frame_dig -2 // data: bytes
	box_replace
	retsub

// finalizeStakingContract()void
*abi_route_finalizeStakingContract:
	// execute finalizeStakingContract()void
	callsub finalizeStakingContract
	int 1
	return

// finalizeStakingContract(): void
finalizeStakingContract:
	proto 0 0

	// examples/reti/validatorRegistry.algo.ts:226
	// this.stakingPoolInitialized.value = true
	byte 0x696e6974 // "init"
	int 1
	byte 0x00
	int 0
	uncover 2
	setbit
	app_global_put
	retsub

// gas()void
*abi_route_gas:
	// execute gas()void
	callsub gas
	int 1
	return

// gas(): void
//
// gas is a dummy no-op call that can be used to pool-up resource references and opcode cost
gas:
	proto 0 0
	retsub

// getMbrAmounts()(uint64,uint64,uint64,uint64)
*abi_route_getMbrAmounts:
	// The ABI return prefix
	byte 0x151f7c75

	// execute getMbrAmounts()(uint64,uint64,uint64,uint64)
	callsub getMbrAmounts
	concat
	log
	int 1
	return

// getMbrAmounts(): MbrAmounts
//
// Returns the MBR amounts needed for various actions:
// [
// addValidatorMbr: uint64 - mbr needed to add a new validator - paid to validator contract
// addPoolMbr: uint64 - mbr needed to add a new pool - paid to validator
// poolInitMbr: uint64 - mbr needed to initStorage() of pool - paid to pool itself
// addStakerMbr: uint64 - mbr staker needs to add to first staking payment (stays w/ validator)
// ]
getMbrAmounts:
	proto 0 1

	// examples/reti/validatorRegistry.algo.ts:246
	// return {
	//       addValidatorMbr: this.costForBoxStorage(1 /* v prefix */ + len<ValidatorIdType>() + len<ValidatorInfo>()),
	//       addPoolMbr: this.minBalanceForAccount(
	//         1,
	//         // we could calculate this directly by referencing the size of stakingPoolApprovalProgram but it would
	//         // mean our callers would have to reference the box AND buy up i/o - so just go max on extra pages
	//         3,
	//         0,
	//         0,
	//         0,
	//         StakingPool.schema.global.numUint,
	//         StakingPool.schema.global.numByteSlice
	//       ),
	//       poolInitMbr:
	//         ALGORAND_ACCOUNT_MIN_BALANCE +
	//         this.costForBoxStorage(7 /* 'stakers' name */ + len<StakedInfo>() * MAX_STAKERS_PER_POOL),
	//       addStakerMbr:
	//         // how much to charge for first time a staker adds stake - since we add a tracking box per staker
	//         this.costForBoxStorage(3 /* 'sps' prefix */ + len<Address>() + len<ValidatorPoolKey>() * MAX_POOLS_PER_STAKER), // size of key + all values
	//     };
	pushint 1101
	callsub costForBoxStorage
	itob
	int 3
	pushint 11
	int 0
	dupn 2
	int 3
	int 1
	callsub minBalanceForAccount
	itob
	concat
	int 100000
	pushint 12807
	callsub costForBoxStorage
	+
	itob
	concat
	pushint 179
	callsub costForBoxStorage
	itob
	concat
	retsub

// getProtocolConstraints()(uint64,uint64,uint64,uint64,uint64,uint64,uint64,uint64,uint64,uint64,uint64)
*abi_route_getProtocolConstraints:
	// The ABI return prefix
	byte 0x151f7c75

	// execute getProtocolConstraints()(uint64,uint64,uint64,uint64,uint64,uint64,uint64,uint64,uint64,uint64,uint64)
	callsub getProtocolConstraints
	concat
	log
	int 1
	return

// getProtocolConstraints(): Constraints
//
// Returns the protocol constraints so that UIs can limit what users specify for validator configuration parameters.
getProtocolConstraints:
	proto 0 1

	// examples/reti/validatorRegistry.algo.ts:272
	// return {
	//       epochPayoutRoundsMin: MIN_EPOCH_LENGTH,
	//       epochPayoutRoundsMax: MAX_EPOCH_LENGTH,
	//       minPctToValidatorWFourDecimals: MIN_PCT_TO_VALIDATOR,
	//       maxPctToValidatorWFourDecimals: MAX_PCT_TO_VALIDATOR,
	//       minEntryStake: MIN_ALGO_STAKE_PER_POOL,
	//       maxAlgoPerPool: this.maxAlgoAllowedPerPool(),
	//       maxAlgoPerValidator: this.maxAllowedStake(),
	//       amtConsideredSaturated: this.algoSaturationLevel(),
	//       maxNodes: MAX_NODES,
	//       maxPoolsPerNode: MAX_POOLS_PER_NODE,
	//       maxStakersPerPool: MAX_STAKERS_PER_POOL,
	//     };
	pushbytes 0x000000000000000100000000000f4240000000000000000000000000000f424000000000000f4240
	callsub maxAlgoAllowedPerPool
	itob
	concat
	callsub maxAllowedStake
	itob
	concat
	callsub algoSaturationLevel
	itob
	concat
	pushbytes 0x0000000000000008
	concat
	pushbytes 0x0000000000000003
	concat
	pushbytes 0x00000000000000c8
	concat
	retsub

// getNumValidators()uint64
*abi_route_getNumValidators:
	// The ABI return prefix
	byte 0x151f7c75

	// execute getNumValidators()uint64
	callsub getNumValidators
	itob
	concat
	log
	int 1
	return

// getNumValidators(): uint64
//
// Returns the current number of validators
getNumValidators:
	proto 0 1

	// examples/reti/validatorRegistry.algo.ts:292
	// return this.numValidators.value;
	byte 0x6e756d56 // "numV"
	app_global_get
	retsub

// getValidatorConfig(uint64)(uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
*abi_route_getValidatorConfig:
	// The ABI return prefix
	byte 0x151f7c75

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute getValidatorConfig(uint64)(uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	callsub getValidatorConfig
	concat
	log
	int 1
	return

// getValidatorConfig(validatorId: ValidatorIdType): ValidatorConfig
getValidatorConfig:
	proto 1 1

	// examples/reti/validatorRegistry.algo.ts:297
	// return this.validatorList(validatorId).value.config;
	int 0
	int 242
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	retsub

// getValidatorState(uint64)(uint16,uint64,uint64,uint64)
*abi_route_getValidatorState:
	// The ABI return prefix
	byte 0x151f7c75

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute getValidatorState(uint64)(uint16,uint64,uint64,uint64)
	callsub getValidatorState
	concat
	log
	int 1
	return

// getValidatorState(validatorId: ValidatorIdType): ValidatorCurState
getValidatorState:
	proto 1 1

	// examples/reti/validatorRegistry.algo.ts:302
	// return this.validatorList(validatorId).value.state;
	int 242 // headOffset
	pushint 26
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	retsub

// getValidatorOwnerAndManager(uint64)(address,address)
*abi_route_getValidatorOwnerAndManager:
	// The ABI return prefix
	byte 0x151f7c75

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute getValidatorOwnerAndManager(uint64)(address,address)
	callsub getValidatorOwnerAndManager
	concat
	log
	int 1
	return

// getValidatorOwnerAndManager(validatorId: ValidatorIdType): [Address, Address]
getValidatorOwnerAndManager:
	proto 1 1

	// examples/reti/validatorRegistry.algo.ts:307
	// return [this.validatorList(validatorId).value.config.owner, this.validatorList(validatorId).value.config.manager];
	int 8
	int 32
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	pushint 40
	int 32
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	concat
	retsub

// getPools(uint64)(uint64,uint16,uint64)[]
*abi_route_getPools:
	// The ABI return prefix
	byte 0x151f7c75

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute getPools(uint64)(uint64,uint16,uint64)[]
	callsub getPools
	dup
	len
	int 18
	/
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// getPools(validatorId: ValidatorIdType): PoolInfo[]
//
// Return list of all pools for this validator.
// @param {uint64} validatorId
// @return {PoolInfo[]} - array of pools
// Not callable from other contracts because >1K return but can be called w/ simulate which bumps log returns
getPools:
	proto 1 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// examples/reti/validatorRegistry.algo.ts:318
	// retData: PoolInfo[] = []
	byte 0x
	frame_bury 0 // retData: PoolInfo[]

	// examples/reti/validatorRegistry.algo.ts:319
	// poolSet = clone(this.validatorList(validatorId).value.pools)
	int 268 // headOffset
	pushint 432
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	frame_bury 1 // poolSet: (uint64,uint16,uint64)[24]

	// examples/reti/validatorRegistry.algo.ts:320
	// for (let i = 0; i < poolSet.length; i += 1)
	int 0
	frame_bury 2 // i: uint64

*for_0:
	// examples/reti/validatorRegistry.algo.ts:320
	// i < poolSet.length
	frame_dig 2 // i: uint64
	int 24
	<
	bz *for_0_end

	// *if0_condition
	// examples/reti/validatorRegistry.algo.ts:321
	// poolSet[i].poolAppId === 0
	frame_dig 1 // poolSet: (uint64,uint16,uint64)[24]
	frame_dig 2 // i: uint64
	int 18
	* // acc * typeLength
	int 0
	+
	int 8
	extract3
	btoi
	int 0
	==
	bz *if0_end

	// *if0_consequent
	b *for_0_end

*if0_end:
	// examples/reti/validatorRegistry.algo.ts:325
	// retData.push(poolSet[i])
	frame_dig 0 // retData: PoolInfo[]
	frame_dig 1 // poolSet: (uint64,uint16,uint64)[24]
	frame_dig 2 // i: uint64
	int 18
	* // acc * typeLength
	int 18
	extract3
	concat
	frame_bury 0 // retData: PoolInfo[]

*for_0_continue:
	// examples/reti/validatorRegistry.algo.ts:320
	// i += 1
	frame_dig 2 // i: uint64
	int 1
	+
	frame_bury 2 // i: uint64
	b *for_0

*for_0_end:
	// examples/reti/validatorRegistry.algo.ts:327
	// return retData;
	frame_dig 0 // retData: PoolInfo[]

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 2
	retsub

// getPoolAppId(uint64,uint64)uint64
*abi_route_getPoolAppId:
	// The ABI return prefix
	byte 0x151f7c75

	// poolId: uint64
	txna ApplicationArgs 2
	btoi

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute getPoolAppId(uint64,uint64)uint64
	callsub getPoolAppId
	itob
	concat
	log
	int 1
	return

// getPoolAppId(validatorId: uint64, poolId: uint64): uint64
getPoolAppId:
	proto 2 1

	// examples/reti/validatorRegistry.algo.ts:335
	// assert(
	//       poolId !== 0 && poolId <= this.validatorList(validatorId).value.pools.length,
	//       'pool id must be between 1 and number of pools for this validator'
	//     )
	frame_dig -2 // poolId: uint64
	int 0
	!=
	dup
	bz *skip_and0
	frame_dig -2 // poolId: uint64
	int 24
	<=
	&&

*skip_and0:
	// pool id must be between 1 and number of pools for this validator
	assert

	// examples/reti/validatorRegistry.algo.ts:339
	// return this.validatorList(validatorId).value.pools[poolId - 1].poolAppId;
	int 268 // headOffset
	frame_dig -2 // poolId: uint64
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 0
	+
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: uint64
	itob
	concat
	cover 2
	box_extract
	btoi
	retsub

// getPoolInfo((uint64,uint64,uint64))(uint64,uint16,uint64)
*abi_route_getPoolInfo:
	// The ABI return prefix
	byte 0x151f7c75

	// poolKey: (uint64,uint64,uint64)
	txna ApplicationArgs 1
	dup
	len
	int 24
	==

	// argument 0 (poolKey) for getPoolInfo must be a (uint64,uint64,uint64)
	assert

	// execute getPoolInfo((uint64,uint64,uint64))(uint64,uint16,uint64)
	callsub getPoolInfo
	concat
	log
	int 1
	return

// getPoolInfo(poolKey: ValidatorPoolKey): PoolInfo
getPoolInfo:
	proto 1 1

	// examples/reti/validatorRegistry.algo.ts:344
	// return this.validatorList(poolKey.id).value.pools[poolKey.poolId - 1];
	int 268 // headOffset
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 18
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	retsub

// getCurMaxStakePerPool(uint64)uint64
*abi_route_getCurMaxStakePerPool:
	// The ABI return prefix
	byte 0x151f7c75

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute getCurMaxStakePerPool(uint64)uint64
	callsub getCurMaxStakePerPool
	itob
	concat
	log
	int 1
	return

// getCurMaxStakePerPool(validatorId: ValidatorIdType): uint64
//
// Calculate the maximum stake per pool for a given validator.
// Normally this would be maxAlgoPerPool, but it should also never go above MaxAllowedStake / numPools so
// as pools are added the max allowed per pool can reduce.
//
// @param {ValidatorIdType} validatorId - The id of the validator.
getCurMaxStakePerPool:
	proto 1 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// examples/reti/validatorRegistry.algo.ts:355
	// numPools = this.validatorList(validatorId).value.state.numPools as uint64
	int 242
	int 2
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 0 // numPools: uint64

	// examples/reti/validatorRegistry.algo.ts:356
	// hardMaxDividedBetweenPools = this.maxAllowedStake() / numPools
	callsub maxAllowedStake
	frame_dig 0 // numPools: uint64
	/
	frame_bury 1 // hardMaxDividedBetweenPools: uint64

	// examples/reti/validatorRegistry.algo.ts:357
	// maxPerPool: uint64 = this.validatorList(validatorId).value.config.maxAlgoPerPool
	pushint 217
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 2 // maxPerPool: uint64

	// *if1_condition
	// examples/reti/validatorRegistry.algo.ts:358
	// maxPerPool === 0
	frame_dig 2 // maxPerPool: uint64
	int 0
	==
	bz *if1_end

	// *if1_consequent
	// examples/reti/validatorRegistry.algo.ts:359
	// maxPerPool = this.maxAlgoAllowedPerPool()
	callsub maxAlgoAllowedPerPool
	frame_bury 2 // maxPerPool: uint64

*if1_end:
	// *if2_condition
	// examples/reti/validatorRegistry.algo.ts:361
	// hardMaxDividedBetweenPools < maxPerPool
	frame_dig 1 // hardMaxDividedBetweenPools: uint64
	frame_dig 2 // maxPerPool: uint64
	<
	bz *if2_end

	// *if2_consequent
	// examples/reti/validatorRegistry.algo.ts:362
	// maxPerPool = hardMaxDividedBetweenPools
	frame_dig 1 // hardMaxDividedBetweenPools: uint64
	frame_bury 2 // maxPerPool: uint64

*if2_end:
	// examples/reti/validatorRegistry.algo.ts:364
	// return maxPerPool;
	frame_dig 2 // maxPerPool: uint64

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 2
	retsub

// doesStakerNeedToPayMBR(address)bool
*abi_route_doesStakerNeedToPayMBR:
	// The ABI return prefix
	byte 0x151f7c75

	// staker: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (staker) for doesStakerNeedToPayMBR must be a address
	assert

	// execute doesStakerNeedToPayMBR(address)bool
	callsub doesStakerNeedToPayMBR
	byte 0x00
	int 0
	uncover 2
	setbit
	concat
	log
	int 1
	return

// doesStakerNeedToPayMBR(staker: Address): boolean
//
// Helper callers can call w/ simulate to determine if 'AddStaker' MBR should be included w/ staking amount
// @param staker
doesStakerNeedToPayMBR:
	proto 1 1

	// examples/reti/validatorRegistry.algo.ts:373
	// return !this.stakerPoolSet(staker).exists;
	byte 0x737073 // "sps"
	frame_dig -1 // staker: Address
	concat
	box_len
	swap
	pop
	!
	retsub

// getStakedPoolsForAccount(address)(uint64,uint64,uint64)[]
*abi_route_getStakedPoolsForAccount:
	// The ABI return prefix
	byte 0x151f7c75

	// staker: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (staker) for getStakedPoolsForAccount must be a address
	assert

	// execute getStakedPoolsForAccount(address)(uint64,uint64,uint64)[]
	callsub getStakedPoolsForAccount
	dup
	len
	int 24
	/
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// getStakedPoolsForAccount(staker: Address): ValidatorPoolKey[]
//
// Retrieves the staked pools for an account.
//
// @param {Address} staker - The account to retrieve staked pools for.
// @return {ValidatorPoolKey[]} - The array of staked pools for the account.
getStakedPoolsForAccount:
	proto 1 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// *if3_condition
	// examples/reti/validatorRegistry.algo.ts:383
	// !this.stakerPoolSet(staker).exists
	byte 0x737073 // "sps"
	frame_dig -1 // staker: Address
	concat
	box_len
	swap
	pop
	!
	bz *if3_end

	// *if3_consequent
	// examples/reti/validatorRegistry.algo.ts:384
	// return [];
	byte 0x
	b *getStakedPoolsForAccount*return

*if3_end:
	// examples/reti/validatorRegistry.algo.ts:386
	// retData: ValidatorPoolKey[] = []
	byte 0x
	frame_bury 0 // retData: ValidatorPoolKey[]

	// examples/reti/validatorRegistry.algo.ts:387
	// poolSet = clone(this.stakerPoolSet(staker).value)
	byte 0x737073 // "sps"
	frame_dig -1 // staker: Address
	concat
	box_get

	// box value does not exist: this.stakerPoolSet(staker).value
	assert
	frame_bury 1 // poolSet: (uint64,uint64,uint64)[6]

	// examples/reti/validatorRegistry.algo.ts:388
	// for (let i = 0; i < poolSet.length; i += 1)
	int 0
	frame_bury 2 // i: uint64

*for_1:
	// examples/reti/validatorRegistry.algo.ts:388
	// i < poolSet.length
	frame_dig 2 // i: uint64
	int 6
	<
	bz *for_1_end

	// *if4_condition
	// examples/reti/validatorRegistry.algo.ts:389
	// poolSet[i].id !== 0
	frame_dig 1 // poolSet: (uint64,uint64,uint64)[6]
	frame_dig 2 // i: uint64
	int 24
	* // acc * typeLength
	int 0
	+
	int 8
	extract3
	btoi
	int 0
	!=
	bz *if4_end

	// *if4_consequent
	// examples/reti/validatorRegistry.algo.ts:390
	// retData.push(poolSet[i])
	frame_dig 0 // retData: ValidatorPoolKey[]
	frame_dig 1 // poolSet: (uint64,uint64,uint64)[6]
	frame_dig 2 // i: uint64
	int 24
	* // acc * typeLength
	int 24
	extract3
	concat
	frame_bury 0 // retData: ValidatorPoolKey[]

*if4_end:

*for_1_continue:
	// examples/reti/validatorRegistry.algo.ts:388
	// i += 1
	frame_dig 2 // i: uint64
	int 1
	+
	frame_bury 2 // i: uint64
	b *for_1

*for_1_end:
	// examples/reti/validatorRegistry.algo.ts:393
	// return retData;
	frame_dig 0 // retData: ValidatorPoolKey[]

*getStakedPoolsForAccount*return:
	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 2
	retsub

// getTokenPayoutRatio(uint64)(uint64[24],uint64)
*abi_route_getTokenPayoutRatio:
	// The ABI return prefix
	byte 0x151f7c75

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute getTokenPayoutRatio(uint64)(uint64[24],uint64)
	callsub getTokenPayoutRatio
	concat
	log
	int 1
	return

// getTokenPayoutRatio(validatorId: ValidatorIdType): PoolTokenPayoutRatio
//
// Retrieves the token payout ratio for a given validator - returning the pool ratios of whole so that token
// payouts across pools can be based on a stable snaphost of stake.
//
// @param {ValidatorIdType} validatorId - The id of the validator.
// @return {PoolTokenPayoutRatio} - The token payout ratio for the validator.
getTokenPayoutRatio:
	proto 1 1

	// examples/reti/validatorRegistry.algo.ts:405
	// return this.validatorList(validatorId).value.tokenPayoutRatio;
	int 700 // headOffset
	pushint 200
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	retsub

// getNodePoolAssignments(uint64)((uint64[3])[8])
*abi_route_getNodePoolAssignments:
	// The ABI return prefix
	byte 0x151f7c75

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute getNodePoolAssignments(uint64)((uint64[3])[8])
	callsub getNodePoolAssignments
	concat
	log
	int 1
	return

// getNodePoolAssignments(validatorId: uint64): NodePoolAssignmentConfig
getNodePoolAssignments:
	proto 1 1

	// examples/reti/validatorRegistry.algo.ts:410
	// assert(this.validatorList(validatorId).exists, "the specified validator id doesn't exist")
	byte 0x76 // "v"
	frame_dig -1 // validatorId: uint64
	itob
	concat
	box_len
	swap
	pop

	// the specified validator id doesn't exist
	assert

	// examples/reti/validatorRegistry.algo.ts:412
	// return this.validatorList(validatorId).value.nodePoolAssignments;
	int 900 // headOffset
	pushint 192
	byte 0x76 // "v"
	frame_dig -1 // validatorId: uint64
	itob
	concat
	cover 2
	box_extract
	retsub

// getNFDRegistryID()uint64
*abi_route_getNFDRegistryID:
	// The ABI return prefix
	byte 0x151f7c75

	// execute getNFDRegistryID()uint64
	callsub getNFDRegistryID
	itob
	concat
	log
	int 1
	return

// getNFDRegistryID(): uint64
getNFDRegistryID:
	proto 0 1

	// examples/reti/validatorRegistry.algo.ts:416
	// return this.nfdRegistryAppId;
	intc 0 // TMPL_nfdRegistryAppId
	retsub

// addValidator(pay,string,(uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64))uint64
*abi_route_addValidator:
	// The ABI return prefix
	byte 0x151f7c75

	// config: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	txna ApplicationArgs 2
	dup
	len
	int 242
	==

	// argument 0 (config) for addValidator must be a (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	assert

	// nfdName: string
	txna ApplicationArgs 1
	extract 2 0

	// mbrPayment: pay
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// argument 2 (mbrPayment) for addValidator must be a pay transaction
	assert

	// execute addValidator(pay,string,(uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64))uint64
	callsub addValidator
	itob
	concat
	log
	int 1
	return

// addValidator(mbrPayment: PayTxn, nfdName: string, config: ValidatorConfig): uint64
//
// Adds a new validator
// Requires at least 10 ALGO as the 'fee' for the transaction to help dissuade spammed validator adds.
//
// @param {PayTxn} mbrPayment payment from caller which covers mbr increase of new validator storage
// @param {string} nfdName (Optional) Name of nfd (used as double-check against id specified in config)
// @param {ValidatorConfig} config ValidatorConfig struct
// @returns {uint64} validator id
addValidator:
	proto 3 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/reti/validatorRegistry.algo.ts:428
	// this.validateConfig(config)
	frame_dig -3 // config: ValidatorConfig
	callsub validateConfig

	// examples/reti/validatorRegistry.algo.ts:429
	// assert(config.owner !== Address.zeroAddress)
	frame_dig -3 // config: ValidatorConfig
	extract 8 32
	global ZeroAddress
	!=
	assert

	// examples/reti/validatorRegistry.algo.ts:430
	// assert(config.manager !== Address.zeroAddress)
	frame_dig -3 // config: ValidatorConfig
	extract 40 32
	global ZeroAddress
	!=
	assert

	// examples/reti/validatorRegistry.algo.ts:431
	// assert(this.txn.sender === config.owner, 'sender must be owner to add new validator')
	txn Sender
	frame_dig -3 // config: ValidatorConfig
	extract 8 32
	==

	// sender must be owner to add new validator
	assert

	// examples/reti/validatorRegistry.algo.ts:433
	// verifyPayTxn(mbrPayment, { amount: this.getMbrAmounts().addValidatorMbr })
	// verify amount
	frame_dig -1 // mbrPayment: PayTxn
	gtxns Amount
	callsub getMbrAmounts
	extract 0 8
	btoi
	==

	// transaction verification failed: {"txn":"mbrPayment","field":"amount","expected":"this.getMbrAmounts().addValidatorMbr"}
	assert

	// examples/reti/validatorRegistry.algo.ts:435
	// assert(mbrPayment.fee > 10 * 1000000, 'fee must be 10 ALGO or more to prevent spamming of validators')
	frame_dig -1 // mbrPayment: PayTxn
	gtxns Fee
	pushint 10000000
	>

	// fee must be 10 ALGO or more to prevent spamming of validators
	assert

	// examples/reti/validatorRegistry.algo.ts:438
	// validatorId = this.numValidators.value + 1
	byte 0x6e756d56 // "numV"
	app_global_get
	int 1
	+
	frame_bury 0 // validatorId: uint64

	// examples/reti/validatorRegistry.algo.ts:439
	// this.numValidators.value = validatorId
	byte 0x6e756d56 // "numV"
	frame_dig 0 // validatorId: uint64
	app_global_put

	// examples/reti/validatorRegistry.algo.ts:441
	// this.validatorList(validatorId).create()
	byte 0x76 // "v"
	frame_dig 0 // validatorId: uint64
	itob
	concat
	pushint 1092
	box_create
	pop

	// examples/reti/validatorRegistry.algo.ts:442
	// this.validatorList(validatorId).value.config = config
	int 0
	frame_dig -3 // config: ValidatorConfig
	byte 0x76 // "v"
	frame_dig 0 // validatorId: uint64
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:443
	// this.validatorList(validatorId).value.config.id = validatorId
	int 0
	frame_dig 0 // validatorId: uint64
	itob
	byte 0x76 // "v"
	frame_dig 0 // validatorId: uint64
	itob
	concat
	cover 2
	box_replace

	// *if5_condition
	// examples/reti/validatorRegistry.algo.ts:446
	// config.nfdForInfo !== 0
	frame_dig -3 // config: ValidatorConfig
	extract 72 8
	btoi
	int 0
	!=
	bz *if5_end

	// *if5_consequent
	// examples/reti/validatorRegistry.algo.ts:448
	// sendAppCall({
	//         applicationID: AppID.fromUint64(this.nfdRegistryAppId),
	//         applicationArgs: ['is_valid_nfd_appid', nfdName, itob(config.nfdForInfo)],
	//         applications: [AppID.fromUint64(config.nfdForInfo)],
	//       })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum

	// examples/reti/validatorRegistry.algo.ts:449
	// applicationID: AppID.fromUint64(this.nfdRegistryAppId)
	intc 0 // TMPL_nfdRegistryAppId
	itxn_field ApplicationID

	// examples/reti/validatorRegistry.algo.ts:450
	// applicationArgs: ['is_valid_nfd_appid', nfdName, itob(config.nfdForInfo)]
	byte 0x69735f76616c69645f6e66645f6170706964 // "is_valid_nfd_appid"
	itxn_field ApplicationArgs
	frame_dig -2 // nfdName: string
	itxn_field ApplicationArgs
	frame_dig -3 // config: ValidatorConfig
	extract 72 8
	btoi
	itob
	itxn_field ApplicationArgs

	// examples/reti/validatorRegistry.algo.ts:451
	// applications: [AppID.fromUint64(config.nfdForInfo)]
	frame_dig -3 // config: ValidatorConfig
	extract 72 8
	btoi
	itxn_field Applications

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/validatorRegistry.algo.ts:453
	// assert(btoi(this.itxn.lastLog) === 1, "provided NFD isn't valid")
	itxn LastLog
	btoi
	int 1
	==

	// provided NFD isn't valid
	assert

	// examples/reti/validatorRegistry.algo.ts:455
	// assert(
	//         this.txn.sender === (AppID.fromUint64(config.nfdForInfo).globalState('i.owner.a') as Address),
	//         'If specifying NFD, account adding validator must be owner'
	//       )
	txn Sender
	frame_dig -3 // config: ValidatorConfig
	extract 72 8
	btoi
	byte 0x692e6f776e65722e61 // "i.owner.a"
	app_global_get_ex

	// global state value does not exist: AppID.fromUint64(config.nfdForInfo).globalState('i.owner.a')
	assert
	==

	// If specifying NFD, account adding validator must be owner
	assert

*if5_end:
	// *if6_condition
	// examples/reti/validatorRegistry.algo.ts:461
	// config.entryGatingType === GATING_TYPE_CREATED_BY_NFD_ADDRESSES ||
	//       config.entryGatingType === GATING_TYPE_SEGMENT_OF_NFD
	frame_dig -3 // config: ValidatorConfig
	extract 80 1
	btoi
	int 3
	==
	dup
	bnz *skip_or0
	frame_dig -3 // config: ValidatorConfig
	extract 80 1
	btoi
	pushint 4
	==
	||

*skip_or0:
	bz *if6_end

	// *if6_consequent
	// examples/reti/validatorRegistry.algo.ts:465
	// assert(this.isNFDAppIDValid(config.entryGatingAssets[0]), 'provided NFD App id for gating must be valid NFD')
	frame_dig -3 // config: ValidatorConfig
	extract 113 8
	btoi
	callsub isNFDAppIDValid

	// provided NFD App id for gating must be valid NFD
	assert

*if6_end:
	// examples/reti/validatorRegistry.algo.ts:468
	// return validatorId;
	frame_dig 0 // validatorId: uint64

	// set the subroutine return value
	frame_bury 0
	retsub

// changeValidatorManager(uint64,address)void
*abi_route_changeValidatorManager:
	// manager: address
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (manager) for changeValidatorManager must be a address
	assert

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute changeValidatorManager(uint64,address)void
	callsub changeValidatorManager
	int 1
	return

// changeValidatorManager(validatorId: ValidatorIdType, manager: Address): void
//
// Changes the Validator manager for a specific Validator id.
// [ ONLY OWNER CAN CHANGE ]
//
// @param {ValidatorIdType} validatorId - The id of the validator to change the manager for.
// @param {Address} manager - The new manager address.
changeValidatorManager:
	proto 2 0

	// examples/reti/validatorRegistry.algo.ts:479
	// assert(
	//       this.txn.sender === this.validatorList(validatorId).value.config.owner,
	//       'can only be called by validator owner'
	//     )
	txn Sender
	int 8
	int 32
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	==

	// can only be called by validator owner
	assert

	// examples/reti/validatorRegistry.algo.ts:483
	// this.validatorList(validatorId).value.config.manager = manager
	pushint 40
	frame_dig -2 // manager: Address
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace
	retsub

// changeValidatorSunsetInfo(uint64,uint64,uint64)void
*abi_route_changeValidatorSunsetInfo:
	// sunsettingTo: uint64
	txna ApplicationArgs 3
	btoi

	// sunsettingOn: uint64
	txna ApplicationArgs 2
	btoi

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute changeValidatorSunsetInfo(uint64,uint64,uint64)void
	callsub changeValidatorSunsetInfo
	int 1
	return

// changeValidatorSunsetInfo(validatorId: ValidatorIdType, sunsettingOn: uint64, sunsettingTo: ValidatorIdType): void
//
// Updates the sunset information for a given validator.
// [ ONLY OWNER CAN CHANGE ]
//
// @param {ValidatorIdType} validatorId - The id of the validator to update.
// @param {uint64} sunsettingOn - The new sunset timestamp.
// @param {uint64} sunsettingTo - The new sunset to validator id.
changeValidatorSunsetInfo:
	proto 3 0

	// examples/reti/validatorRegistry.algo.ts:495
	// assert(
	//       this.txn.sender === this.validatorList(validatorId).value.config.owner,
	//       'can only be called by validator owner'
	//     )
	txn Sender
	int 8
	int 32
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	==

	// can only be called by validator owner
	assert

	// examples/reti/validatorRegistry.algo.ts:499
	// this.validatorList(validatorId).value.config.sunsettingOn = sunsettingOn
	pushint 226
	frame_dig -2 // sunsettingOn: uint64
	itob
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:500
	// this.validatorList(validatorId).value.config.sunsettingTo = sunsettingTo
	pushint 234
	frame_dig -3 // sunsettingTo: ValidatorIdType
	itob
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace
	retsub

// changeValidatorNFD(uint64,uint64,string)void
*abi_route_changeValidatorNFD:
	// nfdName: string
	txna ApplicationArgs 3
	extract 2 0

	// nfdAppID: uint64
	txna ApplicationArgs 2
	btoi

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute changeValidatorNFD(uint64,uint64,string)void
	callsub changeValidatorNFD
	int 1
	return

// changeValidatorNFD(validatorId: ValidatorIdType, nfdAppID: uint64, nfdName: string): void
//
// Changes the NFD for a validator in the validatorList contract.
// [ ONLY OWNER CAN CHANGE ]
//
// @param {ValidatorIdType} validatorId - The id of the validator to update.
// @param {uint64} nfdAppID - The application id of the NFD to assign to the validator.
// @param {string} nfdName - The name of the NFD (which must match)
changeValidatorNFD:
	proto 3 0

	// examples/reti/validatorRegistry.algo.ts:513
	// assert(
	//       this.txn.sender === this.validatorList(validatorId).value.config.owner,
	//       'can only be called by validator owner'
	//     )
	txn Sender
	int 8
	int 32
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	==

	// can only be called by validator owner
	assert

	// examples/reti/validatorRegistry.algo.ts:518
	// sendAppCall({
	//       applicationID: AppID.fromUint64(this.nfdRegistryAppId),
	//       applicationArgs: ['is_valid_nfd_appid', nfdName, itob(nfdAppID)],
	//       applications: [AppID.fromUint64(nfdAppID)],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum

	// examples/reti/validatorRegistry.algo.ts:519
	// applicationID: AppID.fromUint64(this.nfdRegistryAppId)
	intc 0 // TMPL_nfdRegistryAppId
	itxn_field ApplicationID

	// examples/reti/validatorRegistry.algo.ts:520
	// applicationArgs: ['is_valid_nfd_appid', nfdName, itob(nfdAppID)]
	byte 0x69735f76616c69645f6e66645f6170706964 // "is_valid_nfd_appid"
	itxn_field ApplicationArgs
	frame_dig -3 // nfdName: string
	itxn_field ApplicationArgs
	frame_dig -2 // nfdAppID: uint64
	itob
	itxn_field ApplicationArgs

	// examples/reti/validatorRegistry.algo.ts:521
	// applications: [AppID.fromUint64(nfdAppID)]
	frame_dig -2 // nfdAppID: uint64
	itxn_field Applications

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/validatorRegistry.algo.ts:524
	// assert(
	//       this.txn.sender === (AppID.fromUint64(nfdAppID).globalState('i.owner.a') as Address),
	//       'If specifying NFD, account adding validator must be owner'
	//     )
	txn Sender
	frame_dig -2 // nfdAppID: uint64
	byte 0x692e6f776e65722e61 // "i.owner.a"
	app_global_get_ex

	// global state value does not exist: AppID.fromUint64(nfdAppID).globalState('i.owner.a')
	assert
	==

	// If specifying NFD, account adding validator must be owner
	assert

	// examples/reti/validatorRegistry.algo.ts:528
	// this.validatorList(validatorId).value.config.nfdForInfo = nfdAppID
	pushint 72
	frame_dig -2 // nfdAppID: uint64
	itob
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace
	retsub

// changeValidatorCommissionAddress(uint64,address)void
*abi_route_changeValidatorCommissionAddress:
	// commissionAddress: address
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (commissionAddress) for changeValidatorCommissionAddress must be a address
	assert

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute changeValidatorCommissionAddress(uint64,address)void
	callsub changeValidatorCommissionAddress
	int 1
	return

// changeValidatorCommissionAddress(validatorId: ValidatorIdType, commissionAddress: Address): void
//
// Change the commission address that validator rewards are sent to.
// [ ONLY OWNER CAN CHANGE ]
changeValidatorCommissionAddress:
	proto 2 0

	// examples/reti/validatorRegistry.algo.ts:536
	// assert(
	//       this.txn.sender === this.validatorList(validatorId).value.config.owner,
	//       'can only be called by validator owner'
	//     )
	txn Sender
	int 8
	int 32
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	==

	// can only be called by validator owner
	assert

	// examples/reti/validatorRegistry.algo.ts:540
	// assert(commissionAddress !== Address.zeroAddress)
	frame_dig -2 // commissionAddress: Address
	global ZeroAddress
	!=
	assert

	// examples/reti/validatorRegistry.algo.ts:541
	// this.validatorList(validatorId).value.config.validatorCommissionAddress = commissionAddress
	pushint 177
	frame_dig -2 // commissionAddress: Address
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace
	retsub

// changeValidatorRewardInfo(uint64,uint8,address,uint64[4],uint64,uint64)void
*abi_route_changeValidatorRewardInfo:
	// RewardPerPayout: uint64
	txna ApplicationArgs 6
	btoi

	// GatingAssetMinBalance: uint64
	txna ApplicationArgs 5
	btoi

	// EntryGatingAssets: uint64[4]
	txna ApplicationArgs 4
	dup
	len
	int 32
	==

	// argument 2 (EntryGatingAssets) for changeValidatorRewardInfo must be a uint64[4]
	assert

	// EntryGatingAddress: address
	txna ApplicationArgs 3
	dup
	len
	int 32
	==

	// argument 3 (EntryGatingAddress) for changeValidatorRewardInfo must be a address
	assert

	// EntryGatingType: uint8
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 4 (EntryGatingType) for changeValidatorRewardInfo must be a uint8
	assert
	btoi

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute changeValidatorRewardInfo(uint64,uint8,address,uint64[4],uint64,uint64)void
	callsub changeValidatorRewardInfo
	int 1
	return

// changeValidatorRewardInfo(validatorId: ValidatorIdType, EntryGatingType: uint8, EntryGatingAddress: Address, EntryGatingAssets: StaticArray<uint64, 4>, GatingAssetMinBalance: uint64, RewardPerPayout: uint64): void
//
// Allow the additional rewards (gating entry, additional token rewards) information be changed at will.
// [ ONLY OWNER CAN CHANGE ]
changeValidatorRewardInfo:
	proto 6 0

	// examples/reti/validatorRegistry.algo.ts:556
	// assert(
	//       this.txn.sender === this.validatorList(validatorId).value.config.owner,
	//       'can only be called by validator owner'
	//     )
	txn Sender
	int 8
	int 32
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	==

	// can only be called by validator owner
	assert

	// examples/reti/validatorRegistry.algo.ts:561
	// this.validatorList(validatorId).value.config.entryGatingType = EntryGatingType
	pushint 80
	frame_dig -2 // EntryGatingType: uint8
	itob
	extract 7 1
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:562
	// this.validatorList(validatorId).value.config.entryGatingAddress = EntryGatingAddress
	pushint 81
	frame_dig -3 // EntryGatingAddress: Address
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:563
	// this.validatorList(validatorId).value.config.entryGatingAssets = EntryGatingAssets
	pushint 113
	frame_dig -4 // EntryGatingAssets: StaticArray<uint64, 4>
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:564
	// this.validatorList(validatorId).value.config.gatingAssetMinBalance = GatingAssetMinBalance
	pushint 145
	frame_dig -5 // GatingAssetMinBalance: uint64
	itob
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:565
	// this.validatorList(validatorId).value.config.rewardPerPayout = RewardPerPayout
	pushint 161
	frame_dig -6 // RewardPerPayout: uint64
	itob
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace
	retsub

// addPool(pay,uint64,uint64)(uint64,uint64,uint64)
*abi_route_addPool:
	// The ABI return prefix
	byte 0x151f7c75

	// nodeNum: uint64
	txna ApplicationArgs 2
	btoi

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// mbrPayment: pay
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// argument 2 (mbrPayment) for addPool must be a pay transaction
	assert

	// execute addPool(pay,uint64,uint64)(uint64,uint64,uint64)
	callsub addPool
	concat
	log
	int 1
	return

// addPool(mbrPayment: PayTxn, validatorId: ValidatorIdType, nodeNum: uint64): ValidatorPoolKey
//
// Adds a new pool to a validator's pool set, returning the 'key' to reference the pool in the future for staking, etc.
// The caller must pay the cost of the validators MBR increase as well as the MBR that will be needed for the pool itself.
//
// [ ONLY OWNER OR MANAGER CAN call ]
// @param {PayTxn} mbrPayment payment from caller which covers mbr increase of adding a new pool
// @param {uint64} validatorId is id of validator to pool to (must be owner or manager)
// @param {uint64} nodeNum is node number to add to
// @returns {ValidatorPoolKey} pool key to created pool
addPool:
	proto 3 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// examples/reti/validatorRegistry.algo.ts:581
	// assert(
	//       this.txn.sender === this.validatorList(validatorId).value.config.owner ||
	//         this.txn.sender === this.validatorList(validatorId).value.config.manager,
	//       'can only be called by owner or manager of validator'
	//     )
	txn Sender
	int 8
	int 32
	byte 0x76 // "v"
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	==
	dup
	bnz *skip_or1
	txn Sender
	pushint 40
	int 32
	byte 0x76 // "v"
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	==
	||

*skip_or1:
	// can only be called by owner or manager of validator
	assert

	// examples/reti/validatorRegistry.algo.ts:588
	// verifyPayTxn(mbrPayment, { amount: this.getMbrAmounts().addPoolMbr, receiver: this.app.address })
	// verify amount
	frame_dig -1 // mbrPayment: PayTxn
	gtxns Amount
	callsub getMbrAmounts
	extract 8 8
	btoi
	==

	// transaction verification failed: {"txn":"mbrPayment","field":"amount","expected":"this.getMbrAmounts().addPoolMbr"}
	assert

	// verify receiver
	frame_dig -1 // mbrPayment: PayTxn
	gtxns Receiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"mbrPayment","field":"receiver","expected":"this.app.address"}
	assert

	// examples/reti/validatorRegistry.algo.ts:590
	// assert(this.validatorList(validatorId).exists, "specified validator id isn't valid")
	byte 0x76 // "v"
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	concat
	box_len
	swap
	pop

	// specified validator id isn't valid
	assert

	// examples/reti/validatorRegistry.algo.ts:592
	// numPools: uint64 = this.validatorList(validatorId).value.state.numPools as uint64
	int 242
	int 2
	byte 0x76 // "v"
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 0 // numPools: uint64

	// *if7_condition
	// examples/reti/validatorRegistry.algo.ts:593
	// (numPools as uint64) >= MAX_POOLS
	frame_dig 0 // numPools: uint64
	int 24
	>=
	bz *if7_end

	// *if7_consequent
	// already at max pool size
	err

*if7_end:
	// examples/reti/validatorRegistry.algo.ts:596
	// numPools += 1
	frame_dig 0 // numPools: uint64
	int 1
	+
	frame_bury 0 // numPools: uint64

	// examples/reti/validatorRegistry.algo.ts:599
	// sendAppCall({
	//       onCompletion: OnCompletion.NoOp,
	//       approvalProgram: [
	//         this.stakingPoolApprovalProgram.extract(0, 4096),
	//         this.stakingPoolApprovalProgram.extract(4096, this.stakingPoolApprovalProgram.size - 4096),
	//       ],
	//       clearStateProgram: StakingPool.clearProgram(),
	//       globalNumUint: StakingPool.schema.global.numUint,
	//       globalNumByteSlice: StakingPool.schema.global.numByteSlice,
	//       extraProgramPages: 3,
	//       applicationArgs: [
	//         // creatingContractID, validatorId, poolId, minEntryStake
	//         method('createApplication(uint64,uint64,uint64,uint64)void'),
	//         itob(this.app.id),
	//         itob(validatorId),
	//         itob(numPools as uint64),
	//         itob(this.validatorList(validatorId).value.config.minEntryStake),
	//       ],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum

	// examples/reti/validatorRegistry.algo.ts:600
	// onCompletion: OnCompletion.NoOp
	int 0 // NoOp
	itxn_field OnCompletion

	// examples/reti/validatorRegistry.algo.ts:601
	// approvalProgram: [
	//         this.stakingPoolApprovalProgram.extract(0, 4096),
	//         this.stakingPoolApprovalProgram.extract(4096, this.stakingPoolApprovalProgram.size - 4096),
	//       ]
	byte 0x706f6f6c54656d706c617465417070726f76616c4279746573 // "poolTemplateApprovalBytes"
	int 0
	pushint 4096
	box_extract
	itxn_field ApprovalProgramPages
	byte 0x706f6f6c54656d706c617465417070726f76616c4279746573 // "poolTemplateApprovalBytes"
	pushint 4096
	byte 0x706f6f6c54656d706c617465417070726f76616c4279746573 // "poolTemplateApprovalBytes"
	box_len

	// box value does not exist: this.stakingPoolApprovalProgram.size
	assert
	pushint 4096
	-
	box_extract
	itxn_field ApprovalProgramPages

	// examples/reti/validatorRegistry.algo.ts:605
	// clearStateProgram: StakingPool.clearProgram()
	pushbytes 0x0a
	itxn_field ClearStateProgram

	// examples/reti/validatorRegistry.algo.ts:606
	// globalNumUint: StakingPool.schema.global.numUint
	pushint 11
	itxn_field GlobalNumUint

	// examples/reti/validatorRegistry.algo.ts:607
	// globalNumByteSlice: StakingPool.schema.global.numByteSlice
	int 3
	itxn_field GlobalNumByteSlice

	// examples/reti/validatorRegistry.algo.ts:608
	// extraProgramPages: 3
	int 3
	itxn_field ExtraProgramPages

	// examples/reti/validatorRegistry.algo.ts:609
	// applicationArgs: [
	//         // creatingContractID, validatorId, poolId, minEntryStake
	//         method('createApplication(uint64,uint64,uint64,uint64)void'),
	//         itob(this.app.id),
	//         itob(validatorId),
	//         itob(numPools as uint64),
	//         itob(this.validatorList(validatorId).value.config.minEntryStake),
	//       ]
	pushbytes 0x59e90aa6 // method "createApplication(uint64,uint64,uint64,uint64)void"
	itxn_field ApplicationArgs
	txna Applications 0
	itob
	itxn_field ApplicationArgs
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	itxn_field ApplicationArgs
	frame_dig 0 // numPools: uint64
	itob
	itxn_field ApplicationArgs
	pushint 209
	int 8
	byte 0x76 // "v"
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/validatorRegistry.algo.ts:619
	// this.validatorList(validatorId).value.state.numPools = numPools as uint16
	int 242
	frame_dig 0 // numPools: uint64
	itob
	extract 6 2
	byte 0x76 // "v"
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:622
	// poolAppId = this.itxn.createdApplicationID.id
	itxn CreatedApplicationID
	frame_bury 1 // poolAppId: uint64

	// examples/reti/validatorRegistry.algo.ts:623
	// this.validatorList(validatorId).value.pools[numPools - 1].poolAppId = poolAppId
	int 268 // headOffset
	frame_dig 0 // numPools: uint64
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 0
	+
	frame_dig 1 // poolAppId: uint64
	itob
	byte 0x76 // "v"
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:624
	// this.addPoolToNode(validatorId, poolAppId, nodeNum)
	frame_dig -3 // nodeNum: uint64
	frame_dig 1 // poolAppId: uint64
	frame_dig -2 // validatorId: ValidatorIdType
	callsub addPoolToNode

	// examples/reti/validatorRegistry.algo.ts:632
	// return { id: validatorId, poolId: numPools as uint64, poolAppId: this.itxn!.createdApplicationID.id };
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	frame_dig 0 // numPools: uint64
	itob
	concat
	itxn CreatedApplicationID
	itob
	concat

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 1
	retsub

// addStake(pay,uint64,uint64)(uint64,uint64,uint64)
*abi_route_addStake:
	// The ABI return prefix
	byte 0x151f7c75

	// valueToVerify: uint64
	txna ApplicationArgs 2
	btoi

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// stakedAmountPayment: pay
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// argument 2 (stakedAmountPayment) for addStake must be a pay transaction
	assert

	// execute addStake(pay,uint64,uint64)(uint64,uint64,uint64)
	callsub addStake
	concat
	log
	int 1
	return

// addStake(stakedAmountPayment: PayTxn, validatorId: ValidatorIdType, valueToVerify: uint64): ValidatorPoolKey
//
// Adds stake to a validator pool.
//
// @param {PayTxn} stakedAmountPayment - payment coming from staker to place into a pool
// @param {ValidatorIdType} validatorId - The id of the validator.
// @param {uint64} valueToVerify - only if validator has gating to enter - this is asset id or nfd id that corresponds to gating.
// Txn sender is factored in as well if that is part of gating.
// * @returns {ValidatorPoolKey} - The key of the validator pool.
addStake:
	proto 3 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 5

	// examples/reti/validatorRegistry.algo.ts:645
	// assert(this.validatorList(validatorId).exists, "specified validator id isn't valid")
	byte 0x76 // "v"
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	concat
	box_len
	swap
	pop

	// specified validator id isn't valid
	assert

	// *if8_condition
	// examples/reti/validatorRegistry.algo.ts:648
	// this.validatorList(validatorId).value.config.sunsettingOn > 0
	pushint 226
	int 8
	byte 0x76 // "v"
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	int 0
	>
	bz *if8_end

	// *if8_consequent
	// examples/reti/validatorRegistry.algo.ts:649
	// assert(
	//         this.validatorList(validatorId).value.config.sunsettingOn < globals.latestTimestamp,
	//         "can't stake with a validator that is past its sunsetting time"
	//       )
	pushint 226
	int 8
	byte 0x76 // "v"
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	global LatestTimestamp
	<

	// can't stake with a validator that is past its sunsetting time
	assert

*if8_end:
	// examples/reti/validatorRegistry.algo.ts:655
	// staker = this.txn.sender
	txn Sender
	frame_bury 0 // staker: address

	// examples/reti/validatorRegistry.algo.ts:659
	// verifyPayTxn(stakedAmountPayment, {
	//       sender: staker,
	//       receiver: this.app.address,
	//     })
	// verify sender
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Sender
	frame_dig 0 // staker: address
	==

	// transaction verification failed: {"txn":"stakedAmountPayment","field":"sender","expected":"staker"}
	assert

	// verify receiver
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Receiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"stakedAmountPayment","field":"receiver","expected":"this.app.address"}
	assert

	// examples/reti/validatorRegistry.algo.ts:666
	// assert(
	//       this.validatorList(validatorId).value.state.totalAlgoStaked < this.maxAllowedStake(),
	//       'total staked for all of a validators pools may not exceed hard cap'
	//     )
	int 252
	int 8
	byte 0x76 // "v"
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	callsub maxAllowedStake
	<

	// total staked for all of a validators pools may not exceed hard cap
	assert

	// examples/reti/validatorRegistry.algo.ts:673
	// this.doesStakerMeetGating(validatorId, valueToVerify)
	frame_dig -3 // valueToVerify: uint64
	frame_dig -2 // validatorId: ValidatorIdType
	callsub doesStakerMeetGating

	// examples/reti/validatorRegistry.algo.ts:675
	// realAmount = stakedAmountPayment.amount
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Amount
	frame_bury 1 // realAmount: uint64

	// examples/reti/validatorRegistry.algo.ts:676
	// mbrAmtLeftBehind: uint64 = 0
	int 0
	frame_bury 2 // mbrAmtLeftBehind: uint64

	// *if9_condition
	// examples/reti/validatorRegistry.algo.ts:678
	// !this.stakerPoolSet(staker).exists
	byte 0x737073 // "sps"
	frame_dig 0 // staker: address
	concat
	box_len
	swap
	pop
	!
	bz *if9_end

	// *if9_consequent
	// examples/reti/validatorRegistry.algo.ts:681
	// mbrAmtLeftBehind = this.getMbrAmounts().addStakerMbr
	callsub getMbrAmounts
	extract 24 8
	btoi
	frame_bury 2 // mbrAmtLeftBehind: uint64

	// examples/reti/validatorRegistry.algo.ts:682
	// realAmount -= mbrAmtLeftBehind
	frame_dig 1 // realAmount: uint64
	frame_dig 2 // mbrAmtLeftBehind: uint64
	-
	frame_bury 1 // realAmount: uint64

	// examples/reti/validatorRegistry.algo.ts:683
	// this.stakerPoolSet(staker).create()
	byte 0x737073 // "sps"
	frame_dig 0 // staker: address
	concat
	pushint 144
	box_create
	pop

*if9_end:
	// examples/reti/validatorRegistry.algo.ts:687
	// findRet = this.findPoolForStaker(validatorId, staker, realAmount)
	frame_dig 1 // realAmount: uint64
	frame_dig 0 // staker: address
	frame_dig -2 // validatorId: ValidatorIdType
	callsub findPoolForStaker
	frame_bury 3 // findRet: ((uint64,uint64,uint64),bool,bool)

	// examples/reti/validatorRegistry.algo.ts:688
	// poolKey = findRet[0]
	// examples/reti/validatorRegistry.algo.ts:689
	// isNewStakerToValidator = findRet[1]
	frame_dig 3 // findRet: ((uint64,uint64,uint64),bool,bool)
	store 255 // full array
	load 255 // full array
	pushint 192
	getbit
	frame_bury 4 // isNewStakerToValidator: bool

	// examples/reti/validatorRegistry.algo.ts:690
	// isNewStakerToProtocol = findRet[2]
	frame_dig 3 // findRet: ((uint64,uint64,uint64),bool,bool)
	store 255 // full array
	load 255 // full array
	pushint 193
	getbit
	frame_bury 5 // isNewStakerToProtocol: bool

	// *if10_condition
	// examples/reti/validatorRegistry.algo.ts:691
	// poolKey.poolId === 0
	frame_dig 3 // findRet: ((uint64,uint64,uint64),bool,bool)
	store 255 // full array
	load 255 // full array
	extract 8 8
	btoi
	int 0
	==
	bz *if10_end

	// *if10_consequent
	// No pool available with free stake.  Validator needs to add another pool
	err

*if10_end:
	// examples/reti/validatorRegistry.algo.ts:696
	// this.updateStakerPoolSet(staker, poolKey)
	frame_dig 3 // findRet: ((uint64,uint64,uint64),bool,bool)
	store 255 // full array
	load 255 // full array
	extract 0 24
	frame_dig 0 // staker: address
	callsub updateStakerPoolSet

	// examples/reti/validatorRegistry.algo.ts:699
	// this.callPoolAddStake(
	//       stakedAmountPayment,
	//       poolKey,
	//       mbrAmtLeftBehind,
	//       isNewStakerToValidator,
	//       isNewStakerToProtocol
	//     )
	frame_dig 5 // isNewStakerToProtocol: bool
	frame_dig 4 // isNewStakerToValidator: bool
	frame_dig 2 // mbrAmtLeftBehind: uint64
	frame_dig 3 // findRet: ((uint64,uint64,uint64),bool,bool)
	store 255 // full array
	load 255 // full array
	extract 0 24
	frame_dig -1 // stakedAmountPayment: PayTxn
	callsub callPoolAddStake

	// examples/reti/validatorRegistry.algo.ts:714
	// return poolKey;
	frame_dig 3 // findRet: ((uint64,uint64,uint64),bool,bool)
	store 255 // full array
	load 255 // full array
	extract 0 24

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 5
	retsub

// setTokenPayoutRatio(uint64)(uint64[24],uint64)
*abi_route_setTokenPayoutRatio:
	// The ABI return prefix
	byte 0x151f7c75

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute setTokenPayoutRatio(uint64)(uint64[24],uint64)
	callsub setTokenPayoutRatio
	concat
	log
	int 1
	return

// setTokenPayoutRatio(validatorId: ValidatorIdType): PoolTokenPayoutRatio
//
// setTokenPayoutRatio is called by Staking Pool # 1 (ONLY) to ask the validator (us) to calculate the ratios
// of stake in the pools for subsequent token payouts (ie: 2 pools, '100' algo total staked, 60 in pool 1, and 40
// in pool 2)  This is done so we have a stable snapshot of stake - taken once per epoch - only triggered by
// pool 1 doing payout.  pools other than 1 doing payout call pool 1 to ask it do it first.
// It would be 60/40% in the poolPctOfWhole values.  The token reward payouts then use these values instead of
// their 'current' stake which changes as part of the payouts themselves (and people could be changing stake
// during the epoch updates across pools)
//
// Multiple pools will call us via pool 1 (pool2->pool1->validator, etc.) so don't assert on pool1 calling multiple
// times in same epoch.  Just return.
//
// @param validatorId - validator id (and thus pool) calling us.  Verified so that sender MUST be pool 1 of this validator.
// @returns PoolTokenPayoutRatio - the finished ratio data
setTokenPayoutRatio:
	proto 1 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 8

	// examples/reti/validatorRegistry.algo.ts:734
	// pool1AppID = this.validatorList(validatorId).value.pools[0].poolAppId
	int 268
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 0 // pool1AppID: uint64

	// examples/reti/validatorRegistry.algo.ts:735
	// assert(pool1AppID !== 0)
	frame_dig 0 // pool1AppID: uint64
	int 0
	!=
	assert

	// *if11_condition
	// examples/reti/validatorRegistry.algo.ts:737
	// this.txn.sender !== AppID.fromUint64(pool1AppID).address
	txn Sender
	frame_dig 0 // pool1AppID: uint64
	app_params_get AppAddress
	pop
	!=
	bz *if11_end

	// *if11_consequent
	// examples/reti/validatorRegistry.algo.ts:738
	// return this.validatorList(validatorId).value.tokenPayoutRatio;
	int 700 // headOffset
	pushint 200
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	b *setTokenPayoutRatio*return

*if11_end:
	// examples/reti/validatorRegistry.algo.ts:744
	// curRound = globals.round
	global Round
	frame_bury 1 // curRound: uint64

	// examples/reti/validatorRegistry.algo.ts:745
	// lastPayoutUpdate = this.validatorList(validatorId).value.tokenPayoutRatio.updatedForPayout
	pushint 892
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 2 // lastPayoutUpdate: uint64

	// *if12_condition
	// examples/reti/validatorRegistry.algo.ts:746
	// lastPayoutUpdate !== 0
	frame_dig 2 // lastPayoutUpdate: uint64
	int 0
	!=
	bz *if12_end

	// *if12_consequent
	// *if13_condition
	// examples/reti/validatorRegistry.algo.ts:748
	// (AppID.fromUint64(pool1AppID).globalState('lastPayout') as uint64) === lastPayoutUpdate
	frame_dig 0 // pool1AppID: uint64
	pushbytes 0x6c6173745061796f7574 // "lastPayout"
	app_global_get_ex

	// global state value does not exist: AppID.fromUint64(pool1AppID).globalState('lastPayout')
	assert
	frame_dig 2 // lastPayoutUpdate: uint64
	==
	bz *if13_end

	// *if13_consequent
	// examples/reti/validatorRegistry.algo.ts:749
	// return this.validatorList(validatorId).value.tokenPayoutRatio;
	int 700 // headOffset
	pushint 200
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	b *setTokenPayoutRatio*return

*if13_end:
	// examples/reti/validatorRegistry.algo.ts:751
	// epochRoundLength = this.validatorList(validatorId).value.config.epochRoundLength as uint64
	pushint 169
	pushint 4
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 3 // epochRoundLength: uint64

	// examples/reti/validatorRegistry.algo.ts:752
	// thisEpochBegin = curRound - (curRound % epochRoundLength)
	frame_dig 1 // curRound: uint64
	frame_dig 1 // curRound: uint64
	frame_dig 3 // epochRoundLength: uint64
	%
	-
	frame_bury 4 // thisEpochBegin: uint64

	// *if14_condition
	// examples/reti/validatorRegistry.algo.ts:754
	// lastPayoutUpdate - (lastPayoutUpdate % epochRoundLength) === thisEpochBegin
	frame_dig 2 // lastPayoutUpdate: uint64
	frame_dig 2 // lastPayoutUpdate: uint64
	frame_dig 3 // epochRoundLength: uint64
	%
	-
	frame_dig 4 // thisEpochBegin: uint64
	==
	bz *if14_end

	// *if14_consequent
	// examples/reti/validatorRegistry.algo.ts:755
	// return this.validatorList(validatorId).value.tokenPayoutRatio;
	int 700 // headOffset
	pushint 200
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	b *setTokenPayoutRatio*return

*if14_end:

*if12_end:
	// examples/reti/validatorRegistry.algo.ts:758
	// this.validatorList(validatorId).value.tokenPayoutRatio.updatedForPayout = curRound
	pushint 892
	frame_dig 1 // curRound: uint64
	itob
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:760
	// curNumPools = this.validatorList(validatorId).value.state.numPools as uint64
	int 242
	int 2
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 5 // curNumPools: uint64

	// examples/reti/validatorRegistry.algo.ts:761
	// totalStakeForValidator = this.validatorList(validatorId).value.state.totalAlgoStaked
	int 252
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 6 // totalStakeForValidator: uint64

	// examples/reti/validatorRegistry.algo.ts:762
	// for (let i = 0; i < curNumPools; i += 1)
	int 0
	frame_bury 7 // i: uint64

*for_2:
	// examples/reti/validatorRegistry.algo.ts:762
	// i < curNumPools
	frame_dig 7 // i: uint64
	frame_dig 5 // curNumPools: uint64
	<
	bz *for_2_end

	// examples/reti/validatorRegistry.algo.ts:767
	// ourPoolPctOfWhole = wideRatio(
	//         [this.validatorList(validatorId).value.pools[i].totalAlgoStaked, 1_000_000],
	//         [totalStakeForValidator]
	//       )
	int 268 // headOffset
	frame_dig 7 // i: uint64
	int 18
	* // acc * typeLength
	+
	int 10 // headOffset
	+
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	pushint 1_000_000
	mulw
	int 0
	frame_dig 6 // totalStakeForValidator: uint64
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	frame_bury 8 // ourPoolPctOfWhole: uint64

	// examples/reti/validatorRegistry.algo.ts:771
	// this.validatorList(validatorId).value.tokenPayoutRatio.poolPctOfWhole[i] = ourPoolPctOfWhole
	int 700
	frame_dig 7 // i: uint64
	int 8
	* // acc * typeLength
	+
	frame_dig 8 // ourPoolPctOfWhole: uint64
	itob
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace

*for_2_continue:
	// examples/reti/validatorRegistry.algo.ts:762
	// i += 1
	frame_dig 7 // i: uint64
	int 1
	+
	frame_bury 7 // i: uint64
	b *for_2

*for_2_end:
	// examples/reti/validatorRegistry.algo.ts:773
	// return this.validatorList(validatorId).value.tokenPayoutRatio;
	int 700 // headOffset
	pushint 200
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract

*setTokenPayoutRatio*return:
	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 8
	retsub

// stakeUpdatedViaRewards((uint64,uint64,uint64),uint64,uint64,uint64,uint64)void
*abi_route_stakeUpdatedViaRewards:
	// saturatedBurnToFeeSink: uint64
	txna ApplicationArgs 5
	btoi

	// validatorCommission: uint64
	txna ApplicationArgs 4
	btoi

	// rewardTokenAmountReserved: uint64
	txna ApplicationArgs 3
	btoi

	// algoToAdd: uint64
	txna ApplicationArgs 2
	btoi

	// poolKey: (uint64,uint64,uint64)
	txna ApplicationArgs 1
	dup
	len
	int 24
	==

	// argument 4 (poolKey) for stakeUpdatedViaRewards must be a (uint64,uint64,uint64)
	assert

	// execute stakeUpdatedViaRewards((uint64,uint64,uint64),uint64,uint64,uint64,uint64)void
	callsub stakeUpdatedViaRewards
	int 1
	return

// stakeUpdatedViaRewards(poolKey: ValidatorPoolKey, algoToAdd: uint64, rewardTokenAmountReserved: uint64, validatorCommission: uint64, saturatedBurnToFeeSink: uint64): void
//
// stakeUpdatedViaRewards is called by Staking pools to inform the validator (us) that a particular amount of total
// stake has been added to the specified pool.  This is used to update the stats we have in our PoolInfo storage.
// The calling App id is validated against our pool list as well.
// @param {ValidatorPoolKey} poolKey - ValidatorPoolKey type
// @param {uint64} algoToAdd - amount this validator's total stake increased via rewards
// @param {uint64} rewardTokenAmountReserved - amount this validator's total stake increased via rewards (that should be
// @param {uint64} validatorCommission - the commission amount the validator was paid, if any
// @param {uint64} saturatedBurnToFeeSink - if the pool was in saturated state, the amount sent back to the fee sink.
// seen as 'accounted for/pending spent')
stakeUpdatedViaRewards:
	proto 5 0

	// examples/reti/validatorRegistry.algo.ts:794
	// this.verifyPoolKeyCaller(poolKey)
	frame_dig -1 // poolKey: ValidatorPoolKey
	callsub verifyPoolKeyCaller

	// examples/reti/validatorRegistry.algo.ts:797
	// this.validatorList(poolKey.id).value.pools[poolKey.poolId - 1].totalAlgoStaked += algoToAdd
	int 268 // headOffset
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 10 // headOffset
	+
	int 268 // headOffset
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 10 // headOffset
	+
	int 8
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_dig -2 // algoToAdd: uint64
	+
	itob
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:798
	// this.validatorList(poolKey.id).value.state.totalAlgoStaked += algoToAdd
	int 252
	dup
	int 8
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_dig -2 // algoToAdd: uint64
	+
	itob
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:799
	// this.validatorList(poolKey.id).value.state.rewardTokenHeldBack += rewardTokenAmountReserved
	int 260
	dup
	int 8
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_dig -3 // rewardTokenAmountReserved: uint64
	+
	itob
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:801
	// this.totalAlgoStaked.value += algoToAdd
	byte 0x7374616b6564 // "staked"
	app_global_get
	frame_dig -2 // algoToAdd: uint64
	+
	byte 0x7374616b6564 // "staked"
	swap
	app_global_put

	// examples/reti/validatorRegistry.algo.ts:804
	// this.reverifyNFDOwnership(poolKey.id)
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	callsub reverifyNFDOwnership
	retsub

// stakeRemoved((uint64,uint64,uint64),address,uint64,uint64,bool)void
*abi_route_stakeRemoved:
	// stakerRemoved: bool
	txna ApplicationArgs 5
	dup
	len
	int 1
	==

	// argument 0 (stakerRemoved) for stakeRemoved must be a bool
	assert
	int 0
	getbit

	// rewardRemoved: uint64
	txna ApplicationArgs 4
	btoi

	// amountRemoved: uint64
	txna ApplicationArgs 3
	btoi

	// staker: address
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 3 (staker) for stakeRemoved must be a address
	assert

	// poolKey: (uint64,uint64,uint64)
	txna ApplicationArgs 1
	dup
	len
	int 24
	==

	// argument 4 (poolKey) for stakeRemoved must be a (uint64,uint64,uint64)
	assert

	// execute stakeRemoved((uint64,uint64,uint64),address,uint64,uint64,bool)void
	callsub stakeRemoved
	int 1
	return

// stakeRemoved(poolKey: ValidatorPoolKey, staker: Address, amountRemoved: uint64, rewardRemoved: uint64, stakerRemoved: boolean): void
//
// stakeRemoved is called by Staking pools to inform the validator (us) that a particular amount of total stake has been removed
// from the specified pool.  This is used to update the stats we have in our PoolInfo storage.
// If any amount of rewardRemoved is specified, then that amount of reward is sent to the use
// The calling App id is validated against our pool list as well.
//
// @param {ValidatorPoolKey} poolKey calling us from which stake was removed
// @param {Address} staker
// @param {uint64} amountRemoved - algo amount removed
// @param {uint64} rewardRemoved - if applicable, amount of token reward removed (by pool 1 caller) or TO remove and pay out (via pool 1 from different pool caller)
// @param {boolean} stakerRemoved
stakeRemoved:
	proto 5 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 3

	// *if15_condition
	// examples/reti/validatorRegistry.algo.ts:836
	// globals.opcodeBudget < 300
	global OpcodeBudget
	pushint 300
	<
	bz *if15_end

	// *if15_consequent
	// examples/reti/validatorRegistry.algo.ts:837
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	pushint 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

*if15_end:
	// examples/reti/validatorRegistry.algo.ts:839
	// this.verifyPoolKeyCaller(poolKey)
	frame_dig -1 // poolKey: ValidatorPoolKey
	callsub verifyPoolKeyCaller

	// examples/reti/validatorRegistry.algo.ts:843
	// assert(amountRemoved > 0 || rewardRemoved > 0, 'should only be called if algo or reward was removed')
	frame_dig -3 // amountRemoved: uint64
	int 0
	>
	dup
	bnz *skip_or2
	frame_dig -4 // rewardRemoved: uint64
	int 0
	>
	||

*skip_or2:
	// should only be called if algo or reward was removed
	assert

	// examples/reti/validatorRegistry.algo.ts:846
	// this.validatorList(poolKey.id).value.pools[poolKey.poolId - 1].totalAlgoStaked -= amountRemoved
	int 268 // headOffset
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 10 // headOffset
	+
	int 268 // headOffset
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 10 // headOffset
	+
	int 8
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_dig -3 // amountRemoved: uint64
	-
	itob
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:847
	// this.validatorList(poolKey.id).value.state.totalAlgoStaked -= amountRemoved
	int 252
	dup
	int 8
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_dig -3 // amountRemoved: uint64
	-
	itob
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:848
	// this.totalAlgoStaked.value -= amountRemoved
	byte 0x7374616b6564 // "staked"
	app_global_get
	frame_dig -3 // amountRemoved: uint64
	-
	byte 0x7374616b6564 // "staked"
	swap
	app_global_put

	// *if16_condition
	// examples/reti/validatorRegistry.algo.ts:850
	// rewardRemoved > 0
	frame_dig -4 // rewardRemoved: uint64
	int 0
	>
	bz *if16_else

	// *if16_consequent
	// examples/reti/validatorRegistry.algo.ts:851
	// rewardTokenID = this.validatorList(poolKey.id).value.config.rewardTokenId
	pushint 153
	int 8
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 0 // rewardTokenID: uint64

	// examples/reti/validatorRegistry.algo.ts:852
	// assert(rewardTokenID !== 0, "rewardRemoved can't be set if validator doesn't have reward token!")
	frame_dig 0 // rewardTokenID: uint64
	int 0
	!=

	// rewardRemoved can't be set if validator doesn't have reward token!
	assert

	// examples/reti/validatorRegistry.algo.ts:853
	// assert(
	//         this.validatorList(poolKey.id).value.state.rewardTokenHeldBack >= rewardRemoved,
	//         'reward being removed must be covered by hold back amount'
	//       )
	int 260
	int 8
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_dig -4 // rewardRemoved: uint64
	>=

	// reward being removed must be covered by hold back amount
	assert

	// examples/reti/validatorRegistry.algo.ts:859
	// this.validatorList(poolKey.id).value.state.rewardTokenHeldBack -= rewardRemoved
	int 260
	dup
	int 8
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_dig -4 // rewardRemoved: uint64
	-
	itob
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_replace

	// *if17_condition
	// examples/reti/validatorRegistry.algo.ts:864
	// poolKey.poolId !== 1
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	!=
	bz *if17_end

	// *if17_consequent
	// examples/reti/validatorRegistry.algo.ts:865
	// sendMethodCall<typeof StakingPool.prototype.payTokenReward>({
	//           applicationID: AppID.fromUint64(this.validatorList(poolKey.id).value.pools[0].poolAppId),
	//           methodArgs: [staker, rewardTokenID, rewardRemoved],
	//         })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0x63f3f28b // method "payTokenReward(address,uint64,uint64)void"
	itxn_field ApplicationArgs

	// examples/reti/validatorRegistry.algo.ts:866
	// applicationID: AppID.fromUint64(this.validatorList(poolKey.id).value.pools[0].poolAppId)
	int 268
	int 8
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	itxn_field ApplicationID

	// examples/reti/validatorRegistry.algo.ts:867
	// methodArgs: [staker, rewardTokenID, rewardRemoved]
	frame_dig -2 // staker: Address
	itxn_field ApplicationArgs
	frame_dig 0 // rewardTokenID: uint64
	itob
	itxn_field ApplicationArgs
	frame_dig -4 // rewardRemoved: uint64
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

*if17_end:
	b *if16_end

*if16_else:

*if16_end:
	// *if18_condition
	// examples/reti/validatorRegistry.algo.ts:892
	// stakerRemoved
	frame_dig -5 // stakerRemoved: boolean
	bz *if18_end

	// *if18_consequent
	// examples/reti/validatorRegistry.algo.ts:894
	// this.validatorList(poolKey.id).value.pools[poolKey.poolId - 1].totalStakers -= 1
	int 268 // headOffset
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 8 // headOffset
	+
	int 268 // headOffset
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 8 // headOffset
	+
	int 2
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	int 1
	-
	itob
	extract 6 2
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:896
	// removeRet = this.removeFromStakerPoolSet(staker, <ValidatorPoolKey>{
	//         id: poolKey.id,
	//         poolId: poolKey.poolId,
	//         poolAppId: poolKey.poolAppId,
	//       })
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	itob
	concat
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 16 8
	btoi
	itob
	concat
	frame_dig -2 // staker: Address
	callsub removeFromStakerPoolSet
	frame_bury 1 // removeRet: (bool,bool)

	// examples/reti/validatorRegistry.algo.ts:901
	// stakerOutOfThisValidator = removeRet[0]
	frame_dig 1 // removeRet: (bool,bool)
	store 255 // full array
	load 255 // full array
	int 0
	getbit
	frame_bury 2 // stakerOutOfThisValidator: bool

	// examples/reti/validatorRegistry.algo.ts:902
	// stakerOutOfProtocol = removeRet[1]
	frame_dig 1 // removeRet: (bool,bool)
	store 255 // full array
	load 255 // full array
	int 1
	getbit
	frame_bury 3 // stakerOutOfProtocol: bool

	// *if19_condition
	// examples/reti/validatorRegistry.algo.ts:904
	// stakerOutOfThisValidator
	frame_dig 2 // stakerOutOfThisValidator: bool
	bz *if19_end

	// *if19_consequent
	// examples/reti/validatorRegistry.algo.ts:905
	// this.validatorList(poolKey.id).value.state.totalStakers -= 1
	pushint 244
	pushint 244
	int 8
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	int 1
	-
	itob
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_replace

*if19_end:
	// *if20_condition
	// examples/reti/validatorRegistry.algo.ts:908
	// stakerOutOfProtocol
	frame_dig 3 // stakerOutOfProtocol: bool
	bz *if20_end

	// *if20_consequent
	// examples/reti/validatorRegistry.algo.ts:909
	// this.numStakers.value -= 1
	byte 0x6e756d5374616b657273 // "numStakers"
	app_global_get
	int 1
	-
	byte 0x6e756d5374616b657273 // "numStakers"
	swap
	app_global_put

*if20_end:

*if18_end:
	retsub

// findPoolForStaker(uint64,address,uint64)((uint64,uint64,uint64),bool,bool)
*abi_route_findPoolForStaker:
	// The ABI return prefix
	byte 0x151f7c75

	// amountToStake: uint64
	txna ApplicationArgs 3
	btoi

	// staker: address
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 1 (staker) for findPoolForStaker must be a address
	assert

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute findPoolForStaker(uint64,address,uint64)((uint64,uint64,uint64),bool,bool)
	callsub findPoolForStaker
	concat
	log
	int 1
	return

// findPoolForStaker(validatorId: ValidatorIdType, staker: Address, amountToStake: uint64): [ValidatorPoolKey, boolean, boolean]
//
// Finds the pool for a staker based on the provided validator id, staker address, and amount to stake.
// First checks the stakers 'already staked list' for the validator preferring those (adding if possible) then adds
// to new pool if necessary.
//
// @param {ValidatorIdType} validatorId - The id of the validator.
// @param {Address} staker - The address of the staker.
// @param {uint64} amountToStake - The amount to stake.
// @returns {ValidatorPoolKey, boolean, boolean} - The pool for the staker, true/false on whether the staker is 'new'
// to this VALIDATOR, and true/false if staker is new to the protocol.
findPoolForStaker:
	proto 3 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 7

	// examples/reti/validatorRegistry.algo.ts:930
	// isNewStakerToValidator = true
	int 1
	frame_bury 0 // isNewStakerToValidator: bool

	// examples/reti/validatorRegistry.algo.ts:931
	// isNewStakerToProtocol = true
	int 1
	frame_bury 1 // isNewStakerToProtocol: bool

	// examples/reti/validatorRegistry.algo.ts:939
	// maxPerPool = this.getCurMaxStakePerPool(validatorId)
	frame_dig -1 // validatorId: ValidatorIdType
	callsub getCurMaxStakePerPool
	frame_bury 2 // maxPerPool: uint64

	// *if21_condition
	// examples/reti/validatorRegistry.algo.ts:942
	// this.stakerPoolSet(staker).exists
	byte 0x737073 // "sps"
	frame_dig -2 // staker: Address
	concat
	box_len
	swap
	pop
	bz *if21_end

	// *if21_consequent
	// examples/reti/validatorRegistry.algo.ts:943
	// poolSet = clone(this.stakerPoolSet(staker).value)
	byte 0x737073 // "sps"
	frame_dig -2 // staker: Address
	concat
	box_get

	// box value does not exist: this.stakerPoolSet(staker).value
	assert
	frame_bury 3 // poolSet: (uint64,uint64,uint64)[6]

	// examples/reti/validatorRegistry.algo.ts:944
	// assert(validatorId !== 0)
	frame_dig -1 // validatorId: ValidatorIdType
	int 0
	!=
	assert

	// examples/reti/validatorRegistry.algo.ts:945
	// for (let i = 0; i < poolSet.length; i += 1)
	int 0
	frame_bury 4 // i: uint64

*for_3:
	// examples/reti/validatorRegistry.algo.ts:945
	// i < poolSet.length
	frame_dig 4 // i: uint64
	int 6
	<
	bz *for_3_end

	// *if22_condition
	// examples/reti/validatorRegistry.algo.ts:946
	// globals.opcodeBudget < 300
	global OpcodeBudget
	pushint 300
	<
	bz *if22_end

	// *if22_consequent
	// examples/reti/validatorRegistry.algo.ts:947
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	pushint 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

*if22_end:
	// *if23_condition
	// examples/reti/validatorRegistry.algo.ts:949
	// poolSet[i].id === 0
	frame_dig 3 // poolSet: (uint64,uint64,uint64)[6]
	frame_dig 4 // i: uint64
	int 24
	* // acc * typeLength
	int 0
	+
	int 8
	extract3
	btoi
	int 0
	==
	bz *if23_end

	// *if23_consequent
	b *for_3_continue

*if23_end:
	// examples/reti/validatorRegistry.algo.ts:952
	// isNewStakerToProtocol = false
	int 0
	frame_bury 1 // isNewStakerToProtocol: bool

	// *if24_condition
	// examples/reti/validatorRegistry.algo.ts:953
	// poolSet[i].id === validatorId
	frame_dig 3 // poolSet: (uint64,uint64,uint64)[6]
	frame_dig 4 // i: uint64
	int 24
	* // acc * typeLength
	int 0
	+
	int 8
	extract3
	btoi
	frame_dig -1 // validatorId: ValidatorIdType
	==
	bz *if24_end

	// *if24_consequent
	// examples/reti/validatorRegistry.algo.ts:955
	// isNewStakerToValidator = false
	int 0
	frame_bury 0 // isNewStakerToValidator: bool

	// *if25_condition
	// examples/reti/validatorRegistry.algo.ts:957
	// this.validatorList(validatorId).value.pools[poolSet[i].poolId - 1].totalAlgoStaked + amountToStake <=
	//             maxPerPool
	int 268 // headOffset
	frame_dig 3 // poolSet: (uint64,uint64,uint64)[6]
	frame_dig 4 // i: uint64
	int 24
	* // acc * typeLength
	int 8 // headOffset
	+
	int 8
	extract3
	btoi
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 10 // headOffset
	+
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_dig -3 // amountToStake: uint64
	+
	frame_dig 2 // maxPerPool: uint64
	<=
	bz *if25_end

	// *if25_consequent
	// examples/reti/validatorRegistry.algo.ts:960
	// return [poolSet[i], isNewStakerToValidator, isNewStakerToProtocol];
	frame_dig 3 // poolSet: (uint64,uint64,uint64)[6]
	frame_dig 4 // i: uint64
	int 24
	* // acc * typeLength
	int 24
	extract3
	byte 0x00
	int 0
	frame_dig 0 // isNewStakerToValidator: bool
	setbit
	int 1
	frame_dig 1 // isNewStakerToProtocol: bool
	setbit
	concat
	b *findPoolForStaker*return

*if25_end:

*if24_end:

*for_3_continue:
	// examples/reti/validatorRegistry.algo.ts:945
	// i += 1
	frame_dig 4 // i: uint64
	int 1
	+
	frame_bury 4 // i: uint64
	b *for_3

*for_3_end:

*if21_end:
	// examples/reti/validatorRegistry.algo.ts:967
	// assert(
	//       amountToStake >= this.validatorList(validatorId).value.config.minEntryStake,
	//       'must stake at least the minimum for this pool'
	//     )
	frame_dig -3 // amountToStake: uint64
	pushint 209
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	>=

	// must stake at least the minimum for this pool
	assert

	// examples/reti/validatorRegistry.algo.ts:973
	// pools = clone(this.validatorList(validatorId).value.pools)
	int 268 // headOffset
	pushint 432
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	frame_bury 5 // pools: (uint64,uint16,uint64)[24]

	// examples/reti/validatorRegistry.algo.ts:974
	// curNumPools = this.validatorList(validatorId).value.state.numPools as uint64
	int 242
	int 2
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 6 // curNumPools: uint64

	// examples/reti/validatorRegistry.algo.ts:975
	// for (let i = 0; i < curNumPools; i += 1)
	int 0
	frame_bury 7 // i: uint64

*for_4:
	// examples/reti/validatorRegistry.algo.ts:975
	// i < curNumPools
	frame_dig 7 // i: uint64
	frame_dig 6 // curNumPools: uint64
	<
	bz *for_4_end

	// *if26_condition
	// examples/reti/validatorRegistry.algo.ts:976
	// pools[i].totalAlgoStaked + amountToStake <= maxPerPool
	frame_dig 5 // pools: (uint64,uint16,uint64)[24]
	frame_dig 7 // i: uint64
	int 18
	* // acc * typeLength
	int 10 // headOffset
	+
	int 8
	extract3
	btoi
	frame_dig -3 // amountToStake: uint64
	+
	frame_dig 2 // maxPerPool: uint64
	<=
	bz *if26_end

	// *if26_consequent
	// examples/reti/validatorRegistry.algo.ts:977
	// return [
	//           { id: validatorId, poolId: i + 1, poolAppId: pools[i].poolAppId },
	//           isNewStakerToValidator,
	//           isNewStakerToProtocol,
	//         ];
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	frame_dig 7 // i: uint64
	int 1
	+
	itob
	concat
	frame_dig 5 // pools: (uint64,uint16,uint64)[24]
	frame_dig 7 // i: uint64
	int 18
	* // acc * typeLength
	int 0
	+
	int 8
	extract3
	btoi
	itob
	concat
	byte 0x00
	int 0
	frame_dig 0 // isNewStakerToValidator: bool
	setbit
	int 1
	frame_dig 1 // isNewStakerToProtocol: bool
	setbit
	concat
	b *findPoolForStaker*return

*if26_end:

*for_4_continue:
	// examples/reti/validatorRegistry.algo.ts:975
	// i += 1
	frame_dig 7 // i: uint64
	int 1
	+
	frame_bury 7 // i: uint64
	b *for_4

*for_4_end:
	// examples/reti/validatorRegistry.algo.ts:985
	// return [{ id: validatorId, poolId: 0, poolAppId: 0 }, isNewStakerToValidator, isNewStakerToProtocol];
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	byte 0x0000000000000000
	concat
	byte 0x0000000000000000
	concat
	byte 0x00
	int 0
	frame_dig 0 // isNewStakerToValidator: bool
	setbit
	int 1
	frame_dig 1 // isNewStakerToProtocol: bool
	setbit
	concat

*findPoolForStaker*return:
	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 7
	retsub

// movePoolToNode(uint64,uint64,uint64)void
*abi_route_movePoolToNode:
	// nodeNum: uint64
	txna ApplicationArgs 3
	btoi

	// poolAppId: uint64
	txna ApplicationArgs 2
	btoi

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute movePoolToNode(uint64,uint64,uint64)void
	callsub movePoolToNode
	int 1
	return

// movePoolToNode(validatorId: ValidatorIdType, poolAppId: uint64, nodeNum: uint64): void
//
// Find the specified pool (in any node number) and move it to the specified node.
// The pool account is forced offline if moved so prior node will still run for 320 rounds but
// new key goes online on new node soon after (320 rounds after it goes online)
// No-op if success, asserts if not found or can't move  (no space in target)
// [ ONLY OWNER OR MANAGER CAN CHANGE ]
//
// @param {ValidatorIdType} validatorId - The id of the validator.
// @param {uint64} poolAppId
// @param {uint64} nodeNum
movePoolToNode:
	proto 3 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// examples/reti/validatorRegistry.algo.ts:1001
	// assert(
	//       this.txn.sender === this.validatorList(validatorId).value.config.owner ||
	//         this.txn.sender === this.validatorList(validatorId).value.config.manager,
	//       'can only be called by owner or manager of validator'
	//     )
	txn Sender
	int 8
	int 32
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	==
	dup
	bnz *skip_or3
	txn Sender
	pushint 40
	int 32
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	==
	||

*skip_or3:
	// can only be called by owner or manager of validator
	assert

	// examples/reti/validatorRegistry.algo.ts:1007
	// nodePoolAssignments = clone(this.validatorList(validatorId).value.nodePoolAssignments)
	int 900 // headOffset
	pushint 192
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	frame_bury 0 // nodePoolAssignments: ((uint64[3])[8])

	// examples/reti/validatorRegistry.algo.ts:1008
	// assert(nodeNum >= 1 && nodeNum <= MAX_NODES, 'node number out of allowable range')
	frame_dig -3 // nodeNum: uint64
	int 1
	>=
	dup
	bz *skip_and1
	frame_dig -3 // nodeNum: uint64
	int 8
	<=
	&&

*skip_and1:
	// node number out of allowable range
	assert

	// examples/reti/validatorRegistry.algo.ts:1010
	// for (let srcNodeIdx = 0; srcNodeIdx < MAX_NODES; srcNodeIdx += 1)
	int 0
	frame_bury 1 // srcNodeIdx: uint64

*for_5:
	// examples/reti/validatorRegistry.algo.ts:1010
	// srcNodeIdx < MAX_NODES
	frame_dig 1 // srcNodeIdx: uint64
	int 8
	<
	bz *for_5_end

	// examples/reti/validatorRegistry.algo.ts:1011
	// for (let i = 0; i < MAX_POOLS_PER_NODE; i += 1)
	int 0
	frame_bury 2 // i: uint64

*for_6:
	// examples/reti/validatorRegistry.algo.ts:1011
	// i < MAX_POOLS_PER_NODE
	frame_dig 2 // i: uint64
	int 3
	<
	bz *for_6_end

	// *if27_condition
	// examples/reti/validatorRegistry.algo.ts:1012
	// nodePoolAssignments.nodes[srcNodeIdx].poolAppIds[i] === poolAppId
	frame_dig 0 // nodePoolAssignments: ((uint64[3])[8])
	int 0
	frame_dig 1 // srcNodeIdx: uint64
	int 24
	* // acc * typeLength
	+
	int 0
	+
	frame_dig 2 // i: uint64
	int 8
	* // acc * typeLength
	+
	int 8
	extract3
	btoi
	frame_dig -2 // poolAppId: uint64
	==
	bz *if27_end

	// *if27_consequent
	// examples/reti/validatorRegistry.algo.ts:1013
	// assert(nodeNum - 1 !== srcNodeIdx, "can't move to same node")
	frame_dig -3 // nodeNum: uint64
	int 1
	-
	frame_dig 1 // srcNodeIdx: uint64
	!=

	// can't move to same node
	assert

	// examples/reti/validatorRegistry.algo.ts:1015
	// this.validatorList(validatorId).value.nodePoolAssignments.nodes[srcNodeIdx].poolAppIds[i] = 0
	int 900
	frame_dig 1 // srcNodeIdx: uint64
	int 24
	* // acc * typeLength
	+
	int 0
	+
	frame_dig 2 // i: uint64
	int 8
	* // acc * typeLength
	+
	byte 0x0000000000000000
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:1018
	// sendMethodCall<typeof StakingPool.prototype.goOffline>({
	//             applicationID: AppID.fromUint64(poolAppId),
	//           })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	pushbytes 0x51ef3b21 // method "goOffline()void"
	itxn_field ApplicationArgs

	// examples/reti/validatorRegistry.algo.ts:1019
	// applicationID: AppID.fromUint64(poolAppId)
	frame_dig -2 // poolAppId: uint64
	itxn_field ApplicationID

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/validatorRegistry.algo.ts:1023
	// this.addPoolToNode(validatorId, poolAppId, nodeNum)
	frame_dig -3 // nodeNum: uint64
	frame_dig -2 // poolAppId: uint64
	frame_dig -1 // validatorId: ValidatorIdType
	callsub addPoolToNode

	// examples/reti/validatorRegistry.algo.ts:1024
	// return;
	retsub

*if27_end:

*for_6_continue:
	// examples/reti/validatorRegistry.algo.ts:1011
	// i += 1
	frame_dig 2 // i: uint64
	int 1
	+
	frame_bury 2 // i: uint64
	b *for_6

*for_6_end:

*for_5_continue:
	// examples/reti/validatorRegistry.algo.ts:1010
	// srcNodeIdx += 1
	frame_dig 1 // srcNodeIdx: uint64
	int 1
	+
	frame_bury 1 // srcNodeIdx: uint64
	b *for_5

*for_5_end:
	// couldn't find pool app id in nodes to move
	err
	retsub

// emptyTokenRewards(uint64,address)uint64
*abi_route_emptyTokenRewards:
	// The ABI return prefix
	byte 0x151f7c75

	// receiver: address
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (receiver) for emptyTokenRewards must be a address
	assert

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute emptyTokenRewards(uint64,address)uint64
	callsub emptyTokenRewards
	itob
	concat
	log
	int 1
	return

// emptyTokenRewards(validatorId: ValidatorIdType, receiver: Address): uint64
//
// Sends the reward tokens held in pool 1 to specified receiver.
// This is intended to be used by the owner when they want to get reward tokens 'back' which they sent to
// the first pool (likely because validator is sunsetting.  Any tokens currently 'reserved' for stakers to claim will
// NOT be sent as they must be held back for stakers to later claim.
// [ ONLY OWNER CAN CALL]
//
// @param {ValidatorIdType} validatorId - The id of the validator.
// @param {Address} receiver - the account to send the tokens to (must already be opted-in to the reward token)
// @returns {uint64} the amount of reward token sent
emptyTokenRewards:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 3

	// examples/reti/validatorRegistry.algo.ts:1043
	// assert(
	//       this.txn.sender === this.validatorList(validatorId).value.config.owner,
	//       'can only be called by validator owner'
	//     )
	txn Sender
	int 8
	int 32
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	==

	// can only be called by validator owner
	assert

	// examples/reti/validatorRegistry.algo.ts:1047
	// rewardTokenId = this.validatorList(validatorId).value.config.rewardTokenId
	pushint 153
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 0 // rewardTokenId: uint64

	// examples/reti/validatorRegistry.algo.ts:1048
	// rewardTokenHeldBack = this.validatorList(validatorId).value.state.rewardTokenHeldBack
	int 260
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 1 // rewardTokenHeldBack: uint64

	// examples/reti/validatorRegistry.algo.ts:1049
	// assert(rewardTokenId !== 0, "this validator doesn't have a reward token defined")
	frame_dig 0 // rewardTokenId: uint64
	int 0
	!=

	// this validator doesn't have a reward token defined
	assert

	// examples/reti/validatorRegistry.algo.ts:1050
	// poolOneAppId = AppID.fromUint64(this.validatorList(validatorId).value.pools[0].poolAppId)
	int 268
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 2 // poolOneAppId: uint64

	// examples/reti/validatorRegistry.algo.ts:1052
	// tokenRewardBal = poolOneAppId.address.assetBalance(AssetID.fromUint64(rewardTokenId)) - rewardTokenHeldBack
	frame_dig 2 // poolOneAppId: uint64
	app_params_get AppAddress
	pop
	frame_dig 0 // rewardTokenId: uint64
	asset_holding_get AssetBalance
	pop
	frame_dig 1 // rewardTokenHeldBack: uint64
	-
	frame_bury 3 // tokenRewardBal: uint64

	// examples/reti/validatorRegistry.algo.ts:1055
	// sendMethodCall<typeof StakingPool.prototype.payTokenReward>({
	//       applicationID: poolOneAppId,
	//       methodArgs: [receiver, rewardTokenId, tokenRewardBal],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0x63f3f28b // method "payTokenReward(address,uint64,uint64)void"
	itxn_field ApplicationArgs

	// examples/reti/validatorRegistry.algo.ts:1056
	// applicationID: poolOneAppId
	frame_dig 2 // poolOneAppId: uint64
	itxn_field ApplicationID

	// examples/reti/validatorRegistry.algo.ts:1057
	// methodArgs: [receiver, rewardTokenId, tokenRewardBal]
	frame_dig -2 // receiver: Address
	itxn_field ApplicationArgs
	frame_dig 0 // rewardTokenId: uint64
	itob
	itxn_field ApplicationArgs
	frame_dig 3 // tokenRewardBal: uint64
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/validatorRegistry.algo.ts:1059
	// assert(
	//       poolOneAppId.address.assetBalance(AssetID.fromUint64(rewardTokenId)) === rewardTokenHeldBack,
	//       'balance of remaining reward tokens should match the held back amount'
	//     )
	frame_dig 2 // poolOneAppId: uint64
	app_params_get AppAddress
	pop
	frame_dig 0 // rewardTokenId: uint64
	asset_holding_get AssetBalance
	pop
	frame_dig 1 // rewardTokenHeldBack: uint64
	==

	// balance of remaining reward tokens should match the held back amount
	assert

	// examples/reti/validatorRegistry.algo.ts:1063
	// return tokenRewardBal;
	frame_dig 3 // tokenRewardBal: uint64

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 3
	retsub

// verifyPoolKeyCaller(poolKey: ValidatorPoolKey): void
//
// Logs the addition of a new validator to the system, its initial owner and manager
//
//
// verifyPoolKeyCaller verifies the passed in key (from a staking pool calling us to update metrics) is valid
// and matches the information we have in our state.  'Fake' pools could call us to update our data, but they
// can't fake the ids and most importantly application id(!) of the caller that has to match.
verifyPoolKeyCaller:
	proto 1 0

	// examples/reti/validatorRegistry.algo.ts:1161
	// assert(this.validatorList(poolKey.id).exists, "the specified validator id isn't valid")
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	box_len
	swap
	pop

	// the specified validator id isn't valid
	assert

	// examples/reti/validatorRegistry.algo.ts:1162
	// assert(poolKey.poolId <= MAX_POOLS, 'pool id not in valid range')
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 24
	<=

	// pool id not in valid range
	assert

	// examples/reti/validatorRegistry.algo.ts:1163
	// assert(
	//       poolKey.poolId > 0 && (poolKey.poolId as uint16) <= this.validatorList(poolKey.id).value.state.numPools,
	//       'pool id outside of range of pools created for this validator'
	//     )
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 0
	>
	dup
	bz *skip_and2
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 242
	int 2
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	<=
	&&

*skip_and2:
	// pool id outside of range of pools created for this validator
	assert

	// examples/reti/validatorRegistry.algo.ts:1169
	// assert(
	//       poolKey.poolAppId === this.validatorList(poolKey.id).value.pools[poolKey.poolId - 1].poolAppId,
	//       "The passed in app id doesn't match the passed in ids"
	//     )
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 16 8
	btoi
	int 268 // headOffset
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 0
	+
	int 8
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	==

	// The passed in app id doesn't match the passed in ids
	assert

	// examples/reti/validatorRegistry.algo.ts:1174
	// assert(this.txn.sender === AppID.fromUint64(poolKey.poolAppId).address)
	txn Sender
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 16 8
	btoi
	app_params_get AppAddress
	pop
	==
	assert

	// examples/reti/validatorRegistry.algo.ts:1176
	// assert(poolKey.id === (AppID.fromUint64(poolKey.poolAppId).globalState('validatorId') as uint64))
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 16 8
	btoi
	pushbytes 0x76616c696461746f724964 // "validatorId"
	app_global_get_ex

	// global state value does not exist: AppID.fromUint64(poolKey.poolAppId).globalState('validatorId')
	assert
	==
	assert

	// examples/reti/validatorRegistry.algo.ts:1177
	// assert(poolKey.poolId === (AppID.fromUint64(poolKey.poolAppId).globalState('poolId') as uint64))
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 16 8
	btoi
	pushbytes 0x706f6f6c4964 // "poolId"
	app_global_get_ex

	// global state value does not exist: AppID.fromUint64(poolKey.poolAppId).globalState('poolId')
	assert
	==
	assert
	retsub

// reverifyNFDOwnership(validatorId: ValidatorIdType): void
//
// This method verifies the ownership of NFD (Named Function Data) by a validator.
// If the ownership is no longer valid, it removes the NFD from the validator's configuration.
//
// @param {ValidatorIdType} validatorId - The id of the validator whose data should be re-evaluated.
reverifyNFDOwnership:
	proto 1 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// examples/reti/validatorRegistry.algo.ts:1187
	// validatorConfig = this.validatorList(validatorId).value.config
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	frame_bury 0 // storage key//validatorConfig

	// *if28_condition
	// examples/reti/validatorRegistry.algo.ts:1188
	// validatorConfig.nfdForInfo !== 0
	pushint 72
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	int 0
	!=
	bz *if28_end

	// *if28_consequent
	// examples/reti/validatorRegistry.algo.ts:1191
	// nfdOwner = AppID.fromUint64(validatorConfig.nfdForInfo).globalState('i.owner.a') as Address
	pushint 72
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	byte 0x692e6f776e65722e61 // "i.owner.a"
	app_global_get_ex

	// global state value does not exist: AppID.fromUint64(validatorConfig.nfdForInfo).globalState('i.owner.a')
	assert
	frame_bury 1 // nfdOwner: address

	// *if29_condition
	// examples/reti/validatorRegistry.algo.ts:1193
	// validatorConfig.owner !== nfdOwner && validatorConfig.manager !== nfdOwner
	int 8
	int 32
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	frame_dig 1 // nfdOwner: address
	!=
	dup
	bz *skip_and3
	pushint 40
	int 32
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	frame_dig 1 // nfdOwner: address
	!=
	&&

*skip_and3:
	bz *if29_end

	// *if29_consequent
	// examples/reti/validatorRegistry.algo.ts:1195
	// this.validatorList(validatorId).value.config.nfdForInfo = 0
	pushint 72
	byte 0x0000000000000000
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace

*if29_end:

*if28_end:
	retsub

// validateConfig(config: ValidatorConfig): void
validateConfig:
	proto 1 0

	// examples/reti/validatorRegistry.algo.ts:1202
	// assert(
	//       config.entryGatingType >= GATING_TYPE_NONE && config.entryGatingType <= GATING_TYPE_CONST_MAX,
	//       'gating type not valid'
	//     )
	frame_dig -1 // config: ValidatorConfig
	extract 80 1
	btoi
	int 0
	>=
	dup
	bz *skip_and4
	frame_dig -1 // config: ValidatorConfig
	extract 80 1
	btoi
	pushint 4
	<=
	&&

*skip_and4:
	// gating type not valid
	assert

	// examples/reti/validatorRegistry.algo.ts:1206
	// assert(
	//       config.epochRoundLength >= MIN_EPOCH_LENGTH && config.epochRoundLength <= MAX_EPOCH_LENGTH,
	//       'epoch length not in allowable range'
	//     )
	frame_dig -1 // config: ValidatorConfig
	extract 169 4
	btoi
	int 1
	>=
	dup
	bz *skip_and5
	frame_dig -1 // config: ValidatorConfig
	extract 169 4
	btoi
	int 1000000
	<=
	&&

*skip_and5:
	// epoch length not in allowable range
	assert

	// examples/reti/validatorRegistry.algo.ts:1210
	// assert(
	//       config.percentToValidator >= MIN_PCT_TO_VALIDATOR && config.percentToValidator <= MAX_PCT_TO_VALIDATOR,
	//       'commission percentage not valid'
	//     )
	frame_dig -1 // config: ValidatorConfig
	extract 173 4
	btoi
	int 0
	>=
	dup
	bz *skip_and6
	frame_dig -1 // config: ValidatorConfig
	extract 173 4
	btoi
	int 1000000
	<=
	&&

*skip_and6:
	// commission percentage not valid
	assert

	// *if30_condition
	// examples/reti/validatorRegistry.algo.ts:1214
	// config.percentToValidator !== 0
	frame_dig -1 // config: ValidatorConfig
	extract 173 4
	btoi
	int 0
	!=
	bz *if30_end

	// *if30_consequent
	// examples/reti/validatorRegistry.algo.ts:1215
	// assert(
	//         config.validatorCommissionAddress !== Address.zeroAddress,
	//         'validatorCommissionAddress must be set if percent to validator is not 0'
	//       )
	frame_dig -1 // config: ValidatorConfig
	extract 177 32
	global ZeroAddress
	!=

	// validatorCommissionAddress must be set if percent to validator is not 0
	assert

*if30_end:
	// examples/reti/validatorRegistry.algo.ts:1220
	// assert(config.minEntryStake >= MIN_ALGO_STAKE_PER_POOL, 'staking pool must have minimum entry of 1 algo')
	frame_dig -1 // config: ValidatorConfig
	extract 209 8
	btoi
	int 1000000
	>=

	// staking pool must have minimum entry of 1 algo
	assert

	// examples/reti/validatorRegistry.algo.ts:1222
	// assert(
	//       config.poolsPerNode > 0 && config.poolsPerNode <= MAX_POOLS_PER_NODE,
	//       'number of pools per node exceeds allowed number'
	//     )
	frame_dig -1 // config: ValidatorConfig
	extract 225 1
	btoi
	int 0
	>
	dup
	bz *skip_and7
	frame_dig -1 // config: ValidatorConfig
	extract 225 1
	btoi
	int 3
	<=
	&&

*skip_and7:
	// number of pools per node exceeds allowed number
	assert

	// *if31_condition
	// examples/reti/validatorRegistry.algo.ts:1226
	// config.sunsettingOn !== 0
	frame_dig -1 // config: ValidatorConfig
	extract 226 8
	btoi
	int 0
	!=
	bz *if31_end

	// *if31_consequent
	// examples/reti/validatorRegistry.algo.ts:1227
	// assert(config.sunsettingOn > globals.latestTimestamp, 'sunsettingOn must be later than now if set')
	frame_dig -1 // config: ValidatorConfig
	extract 226 8
	btoi
	global LatestTimestamp
	>

	// sunsettingOn must be later than now if set
	assert

*if31_end:
	retsub

// callPoolAddStake(stakedAmountPayment: PayTxn, poolKey: ValidatorPoolKey, mbrAmtPaid: uint64, isNewStakerToValidator: boolean, isNewStakerToProtocol: boolean): void
//
// Adds a stakers amount of algo to a validator pool, transferring the algo we received from them (already verified
// by our caller) to the staking pool account, and then telling it about the amount being added for the specified
// staker.
//
// @param {PayTxn} stakedAmountPayment - payment coming from staker to place into a pool
// @param {ValidatorPoolKey} poolKey - The key of the validator pool.
// @param {uint64} mbrAmtPaid - Amount the user is leaving behind in the validator to pay for their staker MBR cost
// @param {boolean} isNewStakerToValidator - if this is a new, first-time staker to the validator
// @param {boolean} isNewStakerToProtocol - if this is a new, first-time staker to the protocol
callPoolAddStake:
	proto 5 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// examples/reti/validatorRegistry.algo.ts:1249
	// poolAppId = this.validatorList(poolKey.id).value.pools[poolKey.poolId - 1].poolAppId
	int 268 // headOffset
	frame_dig -2 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 0
	+
	int 8
	byte 0x76 // "v"
	frame_dig -2 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 0 // poolAppId: uint64

	// examples/reti/validatorRegistry.algo.ts:1253
	// sendMethodCall<typeof StakingPool.prototype.addStake, uint64>({
	//       applicationID: AppID.fromUint64(poolAppId),
	//       methodArgs: [
	//         // =======
	//         // THIS IS A SEND of the amount received right back out and into the staking pool contract account.
	//         { amount: stakedAmountPayment.amount - mbrAmtPaid, receiver: AppID.fromUint64(poolAppId).address },
	//         // =======
	//         stakedAmountPayment.sender,
	//       ],
	//     })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// examples/reti/validatorRegistry.algo.ts:1258
	// amount: stakedAmountPayment.amount - mbrAmtPaid
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Amount
	frame_dig -3 // mbrAmtPaid: uint64
	-
	itxn_field Amount

	// examples/reti/validatorRegistry.algo.ts:1258
	// receiver: AppID.fromUint64(poolAppId).address
	frame_dig 0 // poolAppId: uint64
	app_params_get AppAddress
	pop
	itxn_field Receiver

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee
	itxn_next
	int 6 // appl
	itxn_field TypeEnum
	pushbytes 0xf9c70cbd // method "addStake(pay,address)uint64"
	itxn_field ApplicationArgs

	// examples/reti/validatorRegistry.algo.ts:1254
	// applicationID: AppID.fromUint64(poolAppId)
	frame_dig 0 // poolAppId: uint64
	itxn_field ApplicationID

	// examples/reti/validatorRegistry.algo.ts:1255
	// methodArgs: [
	//         // =======
	//         // THIS IS A SEND of the amount received right back out and into the staking pool contract account.
	//         { amount: stakedAmountPayment.amount - mbrAmtPaid, receiver: AppID.fromUint64(poolAppId).address },
	//         // =======
	//         stakedAmountPayment.sender,
	//       ]
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Sender
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0
	btoi

	// *if32_condition
	// examples/reti/validatorRegistry.algo.ts:1263
	// globals.opcodeBudget < 500
	global OpcodeBudget
	pushint 500
	<
	bz *if32_end

	// *if32_consequent
	// examples/reti/validatorRegistry.algo.ts:1264
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	pushint 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

*if32_end:
	// examples/reti/validatorRegistry.algo.ts:1268
	// poolNumStakers = AppID.fromUint64(poolAppId).globalState('numStakers') as uint64
	frame_dig 0 // poolAppId: uint64
	byte 0x6e756d5374616b657273 // "numStakers"
	app_global_get_ex

	// global state value does not exist: AppID.fromUint64(poolAppId).globalState('numStakers')
	assert
	frame_bury 1 // poolNumStakers: uint64

	// examples/reti/validatorRegistry.algo.ts:1269
	// poolAlgoStaked = AppID.fromUint64(poolAppId).globalState('staked') as uint64
	frame_dig 0 // poolAppId: uint64
	byte 0x7374616b6564 // "staked"
	app_global_get_ex

	// global state value does not exist: AppID.fromUint64(poolAppId).globalState('staked')
	assert
	frame_bury 2 // poolAlgoStaked: uint64

	// examples/reti/validatorRegistry.algo.ts:1270
	// this.validatorList(poolKey.id).value.pools[poolKey.poolId - 1].totalStakers = poolNumStakers as uint16
	int 268 // headOffset
	frame_dig -2 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 8 // headOffset
	+
	frame_dig 1 // poolNumStakers: uint64
	itob
	extract 6 2
	byte 0x76 // "v"
	frame_dig -2 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:1271
	// this.validatorList(poolKey.id).value.pools[poolKey.poolId - 1].totalAlgoStaked = poolAlgoStaked
	int 268 // headOffset
	frame_dig -2 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 10 // headOffset
	+
	frame_dig 2 // poolAlgoStaked: uint64
	itob
	byte 0x76 // "v"
	frame_dig -2 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_replace

	// *if33_condition
	// examples/reti/validatorRegistry.algo.ts:1274
	// isNewStakerToValidator
	frame_dig -4 // isNewStakerToValidator: boolean
	bz *if33_end

	// *if33_consequent
	// examples/reti/validatorRegistry.algo.ts:1275
	// this.validatorList(poolKey.id).value.state.totalStakers += 1
	pushint 244
	pushint 244
	int 8
	byte 0x76 // "v"
	frame_dig -2 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	int 1
	+
	itob
	byte 0x76 // "v"
	frame_dig -2 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_replace

*if33_end:
	// *if34_condition
	// examples/reti/validatorRegistry.algo.ts:1277
	// isNewStakerToProtocol
	frame_dig -5 // isNewStakerToProtocol: boolean
	bz *if34_end

	// *if34_consequent
	// examples/reti/validatorRegistry.algo.ts:1278
	// this.numStakers.value += 1
	byte 0x6e756d5374616b657273 // "numStakers"
	app_global_get
	int 1
	+
	byte 0x6e756d5374616b657273 // "numStakers"
	swap
	app_global_put

*if34_end:
	// examples/reti/validatorRegistry.algo.ts:1280
	// this.validatorList(poolKey.id).value.state.totalAlgoStaked += stakedAmountPayment.amount - mbrAmtPaid
	int 252
	dup
	int 8
	byte 0x76 // "v"
	frame_dig -2 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Amount
	frame_dig -3 // mbrAmtPaid: uint64
	-
	+
	itob
	byte 0x76 // "v"
	frame_dig -2 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:1281
	// this.totalAlgoStaked.value += stakedAmountPayment.amount - mbrAmtPaid
	byte 0x7374616b6564 // "staked"
	app_global_get
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Amount
	frame_dig -3 // mbrAmtPaid: uint64
	-
	+
	byte 0x7374616b6564 // "staked"
	swap
	app_global_put
	retsub

// updateStakerPoolSet(staker: Address, poolKey: ValidatorPoolKey): void
updateStakerPoolSet:
	proto 2 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// examples/reti/validatorRegistry.algo.ts:1285
	// assert(this.stakerPoolSet(staker).exists)
	byte 0x737073 // "sps"
	frame_dig -1 // staker: Address
	concat
	box_len
	swap
	pop
	assert

	// examples/reti/validatorRegistry.algo.ts:1287
	// poolSet = clone(this.stakerPoolSet(staker).value)
	byte 0x737073 // "sps"
	frame_dig -1 // staker: Address
	concat
	box_get

	// box value does not exist: this.stakerPoolSet(staker).value
	assert
	frame_bury 0 // poolSet: (uint64,uint64,uint64)[6]

	// examples/reti/validatorRegistry.algo.ts:1288
	// firstEmpty = 0
	int 0
	frame_bury 1 // firstEmpty: uint64

	// examples/reti/validatorRegistry.algo.ts:1289
	// for (let i = 0; i < this.stakerPoolSet(staker).value.length; i += 1)
	int 0
	frame_bury 2 // i: uint64

*for_7:
	// examples/reti/validatorRegistry.algo.ts:1289
	// i < this.stakerPoolSet(staker).value.length
	frame_dig 2 // i: uint64
	int 6
	<
	bz *for_7_end

	// *if35_condition
	// examples/reti/validatorRegistry.algo.ts:1290
	// poolSet[i] === poolKey
	frame_dig 0 // poolSet: (uint64,uint64,uint64)[6]
	frame_dig 2 // i: uint64
	int 24
	* // acc * typeLength
	int 24
	extract3
	frame_dig -2 // poolKey: ValidatorPoolKey
	==
	bz *if35_end

	// *if35_consequent
	// examples/reti/validatorRegistry.algo.ts:1292
	// return;
	retsub

*if35_end:
	// *if36_condition
	// examples/reti/validatorRegistry.algo.ts:1294
	// firstEmpty === 0 && poolSet[i].id === 0
	frame_dig 1 // firstEmpty: uint64
	int 0
	==
	dup
	bz *skip_and8
	frame_dig 0 // poolSet: (uint64,uint64,uint64)[6]
	frame_dig 2 // i: uint64
	int 24
	* // acc * typeLength
	int 0
	+
	int 8
	extract3
	btoi
	int 0
	==
	&&

*skip_and8:
	bz *if36_end

	// *if36_consequent
	// examples/reti/validatorRegistry.algo.ts:1295
	// firstEmpty = i + 1
	frame_dig 2 // i: uint64
	int 1
	+
	frame_bury 1 // firstEmpty: uint64

*if36_end:

*for_7_continue:
	// examples/reti/validatorRegistry.algo.ts:1289
	// i += 1
	frame_dig 2 // i: uint64
	int 1
	+
	frame_bury 2 // i: uint64
	b *for_7

*for_7_end:
	// *if37_condition
	// examples/reti/validatorRegistry.algo.ts:1298
	// firstEmpty === 0
	frame_dig 1 // firstEmpty: uint64
	int 0
	==
	bz *if37_end

	// *if37_consequent
	// No empty slot available in the staker pool set
	err

*if37_end:
	// examples/reti/validatorRegistry.algo.ts:1301
	// this.stakerPoolSet(staker).value[firstEmpty - 1] = poolKey
	frame_dig 1 // firstEmpty: uint64
	int 1
	-
	int 24
	* // acc * typeLength
	frame_dig -2 // poolKey: ValidatorPoolKey
	byte 0x737073 // "sps"
	frame_dig -1 // staker: Address
	concat
	cover 2
	box_replace
	retsub

// removeFromStakerPoolSet(staker: Address, poolKey: ValidatorPoolKey): [boolean, boolean]
//
// Removes a pool key from the staker's active pool set - fails if not found (!)
//
// @param {Address} staker - The address of the staker.
// @param {ValidatorPoolKey} poolKey - The pool key they should be stored in
//
// @return [boolean, boolean] [is the staker gone from ALL pools of the given VALIDATOR, and is staker gone from ALL pools]
removeFromStakerPoolSet:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 4

	// examples/reti/validatorRegistry.algo.ts:1314
	// inSameValidatorPoolCount = 0
	int 0
	frame_bury 0 // inSameValidatorPoolCount: uint64

	// examples/reti/validatorRegistry.algo.ts:1315
	// inAnyPoolCount = 0
	int 0
	frame_bury 1 // inAnyPoolCount: uint64

	// examples/reti/validatorRegistry.algo.ts:1316
	// found = false
	int 0
	frame_bury 2 // found: bool

	// examples/reti/validatorRegistry.algo.ts:1318
	// poolSet = clone(this.stakerPoolSet(staker).value)
	byte 0x737073 // "sps"
	frame_dig -1 // staker: Address
	concat
	box_get

	// box value does not exist: this.stakerPoolSet(staker).value
	assert
	frame_bury 3 // poolSet: (uint64,uint64,uint64)[6]

	// examples/reti/validatorRegistry.algo.ts:1319
	// for (let i = 0; i < this.stakerPoolSet(staker).value.length; i += 1)
	int 0
	frame_bury 4 // i: uint64

*for_8:
	// examples/reti/validatorRegistry.algo.ts:1319
	// i < this.stakerPoolSet(staker).value.length
	frame_dig 4 // i: uint64
	int 6
	<
	bz *for_8_end

	// *if38_condition
	// examples/reti/validatorRegistry.algo.ts:1320
	// poolSet[i].id === 0
	frame_dig 3 // poolSet: (uint64,uint64,uint64)[6]
	frame_dig 4 // i: uint64
	int 24
	* // acc * typeLength
	int 0
	+
	int 8
	extract3
	btoi
	int 0
	==
	bz *if38_end

	// *if38_consequent
	b *for_8_continue

*if38_end:
	// examples/reti/validatorRegistry.algo.ts:1323
	// inAnyPoolCount += 1
	frame_dig 1 // inAnyPoolCount: uint64
	int 1
	+
	frame_bury 1 // inAnyPoolCount: uint64

	// *if39_condition
	// examples/reti/validatorRegistry.algo.ts:1324
	// poolSet[i].id === poolKey.id
	frame_dig 3 // poolSet: (uint64,uint64,uint64)[6]
	frame_dig 4 // i: uint64
	int 24
	* // acc * typeLength
	int 0
	+
	int 8
	extract3
	btoi
	frame_dig -2 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	==
	bz *if39_end

	// *if39_consequent
	// *if40_condition
	// examples/reti/validatorRegistry.algo.ts:1325
	// poolSet[i] === poolKey
	frame_dig 3 // poolSet: (uint64,uint64,uint64)[6]
	frame_dig 4 // i: uint64
	int 24
	* // acc * typeLength
	int 24
	extract3
	frame_dig -2 // poolKey: ValidatorPoolKey
	==
	bz *if40_else

	// *if40_consequent
	// examples/reti/validatorRegistry.algo.ts:1326
	// found = true
	int 1
	frame_bury 2 // found: bool

	// examples/reti/validatorRegistry.algo.ts:1328
	// this.stakerPoolSet(staker).value[i] = { id: 0, poolId: 0, poolAppId: 0 }
	frame_dig 4 // i: uint64
	int 24
	* // acc * typeLength
	pushbytes 0x000000000000000000000000000000000000000000000000
	byte 0x737073 // "sps"
	frame_dig -1 // staker: Address
	concat
	cover 2
	box_replace
	b *if40_end

*if40_else:
	// examples/reti/validatorRegistry.algo.ts:1330
	// inSameValidatorPoolCount += 1
	frame_dig 0 // inSameValidatorPoolCount: uint64
	int 1
	+
	frame_bury 0 // inSameValidatorPoolCount: uint64

*if40_end:

*if39_end:

*for_8_continue:
	// examples/reti/validatorRegistry.algo.ts:1319
	// i += 1
	frame_dig 4 // i: uint64
	int 1
	+
	frame_bury 4 // i: uint64
	b *for_8

*for_8_end:
	// *if41_condition
	// examples/reti/validatorRegistry.algo.ts:1334
	// !found
	frame_dig 2 // found: bool
	!
	bz *if41_end

	// *if41_consequent
	// No matching slot found when told to remove a pool from the stakers set
	err

*if41_end:
	// examples/reti/validatorRegistry.algo.ts:1338
	// return [inSameValidatorPoolCount === 0, inAnyPoolCount === 0];
	byte 0x00
	int 0
	frame_dig 0 // inSameValidatorPoolCount: uint64
	int 0
	==
	setbit
	int 1
	frame_dig 1 // inAnyPoolCount: uint64
	int 0
	==
	setbit

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 4
	retsub

// addPoolToNode(validatorId: ValidatorIdType, poolAppId: uint64, nodeNum: uint64): void
addPoolToNode:
	proto 3 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// examples/reti/validatorRegistry.algo.ts:1342
	// nodePoolAssignments = clone(this.validatorList(validatorId).value.nodePoolAssignments)
	int 900 // headOffset
	pushint 192
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	frame_bury 0 // nodePoolAssignments: ((uint64[3])[8])

	// examples/reti/validatorRegistry.algo.ts:1343
	// maxPoolsPerNodeForThisValidator = this.validatorList(validatorId).value.config.poolsPerNode as uint64
	pushint 225
	int 1
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 1 // maxPoolsPerNodeForThisValidator: uint64

	// examples/reti/validatorRegistry.algo.ts:1345
	// assert(nodeNum >= 1 && nodeNum <= MAX_NODES, 'node number not in valid range')
	frame_dig -3 // nodeNum: uint64
	int 1
	>=
	dup
	bz *skip_and9
	frame_dig -3 // nodeNum: uint64
	int 8
	<=
	&&

*skip_and9:
	// node number not in valid range
	assert

	// examples/reti/validatorRegistry.algo.ts:1347
	// for (let i = 0; i < maxPoolsPerNodeForThisValidator; i += 1)
	int 0
	frame_bury 2 // i: uint64

*for_9:
	// examples/reti/validatorRegistry.algo.ts:1347
	// i < maxPoolsPerNodeForThisValidator
	frame_dig 2 // i: uint64
	frame_dig 1 // maxPoolsPerNodeForThisValidator: uint64
	<
	bz *for_9_end

	// *if42_condition
	// examples/reti/validatorRegistry.algo.ts:1348
	// nodePoolAssignments.nodes[nodeNum - 1].poolAppIds[i] === 0
	frame_dig 0 // nodePoolAssignments: ((uint64[3])[8])
	int 0
	frame_dig -3 // nodeNum: uint64
	int 1
	-
	int 24
	* // acc * typeLength
	+
	int 0
	+
	frame_dig 2 // i: uint64
	int 8
	* // acc * typeLength
	+
	int 8
	extract3
	btoi
	int 0
	==
	bz *if42_end

	// *if42_consequent
	// examples/reti/validatorRegistry.algo.ts:1350
	// this.validatorList(validatorId).value.nodePoolAssignments.nodes[nodeNum - 1].poolAppIds[i] = poolAppId
	int 900
	frame_dig -3 // nodeNum: uint64
	int 1
	-
	int 24
	* // acc * typeLength
	+
	int 0
	+
	frame_dig 2 // i: uint64
	int 8
	* // acc * typeLength
	+
	frame_dig -2 // poolAppId: uint64
	itob
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:1351
	// return;
	retsub

*if42_end:

*for_9_continue:
	// examples/reti/validatorRegistry.algo.ts:1347
	// i += 1
	frame_dig 2 // i: uint64
	int 1
	+
	frame_bury 2 // i: uint64
	b *for_9

*for_9_end:
	// no available space in specified node for this pool
	err
	retsub

// doesStakerMeetGating(validatorId: ValidatorIdType, valueToVerify: uint64): void
//
// Checks if a staker meets the gating requirements specified by the validator.
//
// @param {ValidatorIdType} validatorId - The id of the validator.
// @param {uint64} valueToVerify - The value to verify against the gating requirements.
// @returns {void} or asserts if requirements not met.
doesStakerMeetGating:
	proto 2 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 8

	// examples/reti/validatorRegistry.algo.ts:1365
	// type = this.validatorList(validatorId).value.config.entryGatingType
	pushint 80
	int 1
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 0 // type: uint8

	// *if43_condition
	// examples/reti/validatorRegistry.algo.ts:1366
	// type === GATING_TYPE_NONE
	frame_dig 0 // type: uint8
	int 0
	==
	bz *if43_end

	// *if43_consequent
	// examples/reti/validatorRegistry.algo.ts:1367
	// return;
	retsub

*if43_end:
	// examples/reti/validatorRegistry.algo.ts:1369
	// staker = this.txn.sender
	txn Sender
	frame_bury 1 // staker: address

	// examples/reti/validatorRegistry.algo.ts:1370
	// config = clone(this.validatorList(validatorId).value.config)
	int 0
	int 242
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	frame_bury 2 // config: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)

	// *if44_condition
	// examples/reti/validatorRegistry.algo.ts:1374
	// type === GATING_TYPE_ASSETS_CREATED_BY ||
	//       type === GATING_TYPE_ASSET_ID ||
	//       type === GATING_TYPE_CREATED_BY_NFD_ADDRESSES
	frame_dig 0 // type: uint8
	int 1
	==
	dup
	bnz *skip_or4
	frame_dig 0 // type: uint8
	int 2
	==
	||

*skip_or4:
	dup
	bnz *skip_or5
	frame_dig 0 // type: uint8
	int 3
	==
	||

*skip_or5:
	bz *if44_end

	// *if44_consequent
	// examples/reti/validatorRegistry.algo.ts:1378
	// assert(valueToVerify !== 0)
	frame_dig -2 // valueToVerify: uint64
	int 0
	!=
	assert

	// examples/reti/validatorRegistry.algo.ts:1379
	// balRequired = this.validatorList(validatorId).value.config.gatingAssetMinBalance
	pushint 145
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 3 // balRequired: uint64

	// *if45_condition
	// examples/reti/validatorRegistry.algo.ts:1380
	// balRequired === 0
	frame_dig 3 // balRequired: uint64
	int 0
	==
	bz *if45_end

	// *if45_consequent
	// examples/reti/validatorRegistry.algo.ts:1381
	// balRequired = 1
	int 1
	frame_bury 3 // balRequired: uint64

*if45_end:
	// examples/reti/validatorRegistry.algo.ts:1383
	// assert(
	//         staker.assetBalance(AssetID.fromUint64(valueToVerify)) >= balRequired,
	//         'must have required minimum balance of validator defined token to add stake'
	//       )
	frame_dig 1 // staker: address
	frame_dig -2 // valueToVerify: uint64
	asset_holding_get AssetBalance
	pop
	frame_dig 3 // balRequired: uint64
	>=

	// must have required minimum balance of validator defined token to add stake
	assert

*if44_end:
	// *if46_condition
	// examples/reti/validatorRegistry.algo.ts:1388
	// type === GATING_TYPE_ASSETS_CREATED_BY
	frame_dig 0 // type: uint8
	int 1
	==
	bz *if46_end

	// *if46_consequent
	// examples/reti/validatorRegistry.algo.ts:1389
	// assert(
	//         AssetID.fromUint64(valueToVerify).creator === config.entryGatingAddress,
	//         'specified asset must be created by creator that the validator defined as a requirement to stake'
	//       )
	frame_dig -2 // valueToVerify: uint64
	asset_params_get AssetCreator
	pop
	frame_dig 2 // config: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 81 32
	==

	// specified asset must be created by creator that the validator defined as a requirement to stake
	assert

*if46_end:
	// *if47_condition
	// examples/reti/validatorRegistry.algo.ts:1394
	// type === GATING_TYPE_ASSET_ID
	frame_dig 0 // type: uint8
	int 2
	==
	bz *if47_end

	// *if47_consequent
	// examples/reti/validatorRegistry.algo.ts:1395
	// assert(valueToVerify !== 0)
	frame_dig -2 // valueToVerify: uint64
	int 0
	!=
	assert

	// examples/reti/validatorRegistry.algo.ts:1396
	// found = false
	int 0
	frame_bury 4 // found: bool

	// examples/reti/validatorRegistry.algo.ts:1397
	// config.entryGatingAssets
	frame_dig 2 // config: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 113 32
	dup
	frame_bury 5 // copy of the array we are iterating over
	extract 0 8
	btoi
	frame_bury 6 // assetId: uint64
	int 0
	frame_bury 7 // the offset we are extracting the next element from

*forOf_0:
	// *if48_condition
	// examples/reti/validatorRegistry.algo.ts:1398
	// valueToVerify === assetId
	frame_dig -2 // valueToVerify: uint64
	frame_dig 6 // assetId: uint64
	==
	bz *if48_end

	// *if48_consequent
	// examples/reti/validatorRegistry.algo.ts:1399
	// found = true
	int 1
	frame_bury 4 // found: bool
	b *forOf_0_end

*if48_end:

*forOf_0_continue:
	// increment offset and loop if not out of bounds
	frame_dig 7 // the offset we are extracting the next element from
	int 8
	+
	dup
	int 32 // offset of last element
	<
	bz *forOf_0_end
	frame_bury 7 // the offset we are extracting the next element from
	frame_dig 5 // copy of the array we are iterating over
	frame_dig 7 // the offset we are extracting the next element from
	int 8
	extract
	btoi
	frame_bury 6 // assetId: uint64
	b *forOf_0

*forOf_0_end:
	// examples/reti/validatorRegistry.algo.ts:1403
	// assert(found, 'specified asset must be identical to the asset id defined as a requirement to stake')
	frame_dig 4 // found: bool

	// specified asset must be identical to the asset id defined as a requirement to stake
	assert

*if47_end:
	// *if49_condition
	// examples/reti/validatorRegistry.algo.ts:1405
	// type === GATING_TYPE_CREATED_BY_NFD_ADDRESSES
	frame_dig 0 // type: uint8
	int 3
	==
	bz *if49_end

	// *if49_consequent
	// examples/reti/validatorRegistry.algo.ts:1408
	// assert(
	//         this.isAddressInNFDCAAlgoList(config.entryGatingAssets[0], AssetID.fromUint64(valueToVerify).creator),
	//         'specified asset must be created by creator that is one of the linked addresses in an nfd'
	//       )
	frame_dig -2 // valueToVerify: uint64
	asset_params_get AssetCreator
	pop
	frame_dig 2 // config: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 113 8
	btoi
	callsub isAddressInNFDCAAlgoList

	// specified asset must be created by creator that is one of the linked addresses in an nfd
	assert

*if49_end:
	// *if50_condition
	// examples/reti/validatorRegistry.algo.ts:1413
	// type === GATING_TYPE_SEGMENT_OF_NFD
	frame_dig 0 // type: uint8
	pushint 4
	==
	bz *if50_end

	// *if50_consequent
	// examples/reti/validatorRegistry.algo.ts:1415
	// userOfferedNFDAppID = valueToVerify
	frame_dig -2 // valueToVerify: uint64
	frame_bury 8 // userOfferedNFDAppID: uint64

	// examples/reti/validatorRegistry.algo.ts:1416
	// assert(this.isNFDAppIDValid(userOfferedNFDAppID), 'provided NFD must be valid')
	frame_dig 8 // userOfferedNFDAppID: uint64
	callsub isNFDAppIDValid

	// provided NFD must be valid
	assert

	// examples/reti/validatorRegistry.algo.ts:1419
	// assert(
	//         rawBytes(AppID.fromUint64(userOfferedNFDAppID).globalState('i.owner.a') as Address) === rawBytes(staker) ||
	//           this.isAddressInNFDCAAlgoList(userOfferedNFDAppID, staker),
	//         "provided nfd for entry isn't owned or linked to the staker"
	//       )
	frame_dig 8 // userOfferedNFDAppID: uint64
	byte 0x692e6f776e65722e61 // "i.owner.a"
	app_global_get_ex

	// global state value does not exist: AppID.fromUint64(userOfferedNFDAppID).globalState('i.owner.a')
	assert
	frame_dig 1 // staker: address
	==
	dup
	bnz *skip_or6
	frame_dig 1 // staker: address
	frame_dig 8 // userOfferedNFDAppID: uint64
	callsub isAddressInNFDCAAlgoList
	||

*skip_or6:
	// provided nfd for entry isn't owned or linked to the staker
	assert

	// examples/reti/validatorRegistry.algo.ts:1426
	// assert(
	//         btoi(AppID.fromUint64(userOfferedNFDAppID).globalState('i.parentAppID') as bytes) ===
	//           config.entryGatingAssets[0],
	//         'specified nfd must be a segment of the nfd the validator specified as a requirement'
	//       )
	frame_dig 8 // userOfferedNFDAppID: uint64
	pushbytes 0x692e706172656e744170704944 // "i.parentAppID"
	app_global_get_ex

	// global state value does not exist: AppID.fromUint64(userOfferedNFDAppID).globalState('i.parentAppID')
	assert
	btoi
	frame_dig 2 // config: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 113 8
	btoi
	==

	// specified nfd must be a segment of the nfd the validator specified as a requirement
	assert

*if50_end:
	retsub

// isNFDAppIDValid(nfdAppID: uint64): boolean
//
// Checks if the given NFD App id is valid.  Using only the App id there's no validation against the name (ie: that nfd X is name Y)
// So it's assumed for the caller, the app id alone is fine.  The name is fetched from the specified app id and the two
// together are used for validity check call to the nfd registry.
//
// @param {uint64} nfdAppID - The NFD App id to verify.
//
// @returns {boolean} - Returns true if the NFD App id is valid, otherwise false.
isNFDAppIDValid:
	proto 1 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/reti/validatorRegistry.algo.ts:1445
	// userOfferedNFDName = AppID.fromUint64(nfdAppID).globalState('i.name') as string
	frame_dig -1 // nfdAppID: uint64
	pushbytes 0x692e6e616d65 // "i.name"
	app_global_get_ex

	// global state value does not exist: AppID.fromUint64(nfdAppID).globalState('i.name')
	assert
	frame_bury 0 // userOfferedNFDName: string

	// examples/reti/validatorRegistry.algo.ts:1447
	// sendAppCall({
	//       applicationID: AppID.fromUint64(this.nfdRegistryAppId),
	//       applicationArgs: ['is_valid_nfd_appid', userOfferedNFDName, itob(nfdAppID)],
	//       applications: [AppID.fromUint64(nfdAppID)],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum

	// examples/reti/validatorRegistry.algo.ts:1448
	// applicationID: AppID.fromUint64(this.nfdRegistryAppId)
	intc 0 // TMPL_nfdRegistryAppId
	itxn_field ApplicationID

	// examples/reti/validatorRegistry.algo.ts:1449
	// applicationArgs: ['is_valid_nfd_appid', userOfferedNFDName, itob(nfdAppID)]
	byte 0x69735f76616c69645f6e66645f6170706964 // "is_valid_nfd_appid"
	itxn_field ApplicationArgs
	frame_dig 0 // userOfferedNFDName: string
	itxn_field ApplicationArgs
	frame_dig -1 // nfdAppID: uint64
	itob
	itxn_field ApplicationArgs

	// examples/reti/validatorRegistry.algo.ts:1450
	// applications: [AppID.fromUint64(nfdAppID)]
	frame_dig -1 // nfdAppID: uint64
	itxn_field Applications

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/validatorRegistry.algo.ts:1452
	// return btoi(this.itxn.lastLog) === 1;
	itxn LastLog
	btoi
	int 1
	==

	// set the subroutine return value
	frame_bury 0
	retsub

// isAddressInNFDCAAlgoList(nfdAppID: uint64, addrToFind: Address): boolean
//
// Checks if the specified address is present in an NFDs list of verified addresses.
// The NFD is assumed to have already been validated as official.
//
// @param {uint64} nfdAppID - The NFD application id.
// @param {Address} addrToFind - The address to find in the v.caAlgo.0.as property
// @return {boolean} - `true` if the address is present, `false` otherwise.
isAddressInNFDCAAlgoList:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// examples/reti/validatorRegistry.algo.ts:1464
	// sendAppCall({
	//       applicationID: AppID.fromUint64(nfdAppID),
	//       applicationArgs: ['read_property', 'v.caAlgo.0.as'],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum

	// examples/reti/validatorRegistry.algo.ts:1465
	// applicationID: AppID.fromUint64(nfdAppID)
	frame_dig -1 // nfdAppID: uint64
	itxn_field ApplicationID

	// examples/reti/validatorRegistry.algo.ts:1466
	// applicationArgs: ['read_property', 'v.caAlgo.0.as']
	pushbytes 0x726561645f70726f7065727479 // "read_property"
	itxn_field ApplicationArgs
	pushbytes 0x762e6361416c676f2e302e6173 // "v.caAlgo.0.as"
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/validatorRegistry.algo.ts:1468
	// caAlgoData = this.itxn.lastLog
	itxn LastLog
	frame_bury 0 // caAlgoData: byte[]

	// examples/reti/validatorRegistry.algo.ts:1469
	// for (let i = 0; i < caAlgoData.length; i += 32)
	int 0
	frame_bury 1 // i: uint64

*for_10:
	// examples/reti/validatorRegistry.algo.ts:1469
	// i < caAlgoData.length
	frame_dig 1 // i: uint64
	frame_dig 0 // caAlgoData: byte[]
	len
	<
	bz *for_10_end

	// examples/reti/validatorRegistry.algo.ts:1470
	// addr = extract3(caAlgoData, i, 32)
	frame_dig 0 // caAlgoData: byte[]
	frame_dig 1 // i: uint64
	int 32
	extract3
	frame_bury 2 // addr: byte[]

	// *if51_condition
	// examples/reti/validatorRegistry.algo.ts:1471
	// addr !== rawBytes(globals.zeroAddress) && addr === rawBytes(addrToFind)
	frame_dig 2 // addr: byte[]
	global ZeroAddress
	!=
	dup
	bz *skip_and10
	frame_dig 2 // addr: byte[]
	frame_dig -2 // addrToFind: Address
	==
	&&

*skip_and10:
	bz *if51_end

	// *if51_consequent
	// examples/reti/validatorRegistry.algo.ts:1472
	// return true;
	int 1
	b *isAddressInNFDCAAlgoList*return

*if51_end:

*for_10_continue:
	// examples/reti/validatorRegistry.algo.ts:1469
	// i += 32
	frame_dig 1 // i: uint64
	int 32
	+
	frame_bury 1 // i: uint64
	b *for_10

*for_10_end:
	// examples/reti/validatorRegistry.algo.ts:1475
	// return false;
	int 0

*isAddressInNFDCAAlgoList*return:
	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 2
	retsub

// algoSaturationLevel(): uint64
//
// Returns the maximum allowed stake per validator based on a percentage of all current online stake before
// the validator is considered saturated - where rewards are diminished.
// NOTE: this function is defined twice - here and in staking pool contract.  Both must be identical.
algoSaturationLevel:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/reti/validatorRegistry.algo.ts:1484
	// online = this.getCurrentOnlineStake()
	callsub getCurrentOnlineStake
	frame_bury 0 // online: uint64

	// examples/reti/validatorRegistry.algo.ts:1486
	// return wideRatio([online, MAX_VALIDATOR_SOFT_PCT_OF_ONLINE_1DECIMAL], [1000]);
	frame_dig 0 // online: uint64
	pushint 100
	mulw
	int 0
	pushint 1000
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert

	// set the subroutine return value
	frame_bury 0
	retsub

// maxAllowedStake(): uint64
//
// Returns the MAXIMUM allowed stake per validator based on a percentage of all current online stake.
// Adding stake is completely blocked at this amount.
maxAllowedStake:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/reti/validatorRegistry.algo.ts:1494
	// online = this.getCurrentOnlineStake()
	callsub getCurrentOnlineStake
	frame_bury 0 // online: uint64

	// examples/reti/validatorRegistry.algo.ts:1496
	// return wideRatio([online, MAX_VALIDATOR_HARD_PCT_OF_ONLINE_1DECIMAL], [1000]);
	frame_dig 0 // online: uint64
	pushint 150
	mulw
	int 0
	pushint 1000
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert

	// set the subroutine return value
	frame_bury 0
	retsub

// maxAlgoAllowedPerPool(): uint64
//
// Returns the MAXIMUM allowed stake per pool and still receive incentives - we'll treat this as the 'max per pool'
maxAlgoAllowedPerPool:
	proto 0 1

	// examples/reti/validatorRegistry.algo.ts:1504
	// return 70_000_000_000_000;
	pushint 70_000_000_000_000
	retsub

// getCurrentOnlineStake(): uint64
getCurrentOnlineStake:
	proto 0 1

	// examples/reti/validatorRegistry.algo.ts:1509
	// return 2_000_000_000_000_000;
	pushint 2_000_000_000_000_000
	retsub

// minBalanceForAccount(contracts: uint64, extraPages: uint64, assets: uint64, localInts: uint64, localBytes: uint64, globalInts: uint64, globalBytes: uint64): uint64
minBalanceForAccount:
	proto 7 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/reti/validatorRegistry.algo.ts:1521
	// minBal = ALGORAND_ACCOUNT_MIN_BALANCE
	int 100000
	frame_bury 0 // minBal: uint64

	// examples/reti/validatorRegistry.algo.ts:1522
	// minBal += contracts * APPLICATION_BASE_FEE
	frame_dig 0 // minBal: uint64
	frame_dig -1 // contracts: uint64
	int 100000
	*
	+
	frame_bury 0 // minBal: uint64

	// examples/reti/validatorRegistry.algo.ts:1523
	// minBal += extraPages * APPLICATION_BASE_FEE
	frame_dig 0 // minBal: uint64
	frame_dig -2 // extraPages: uint64
	int 100000
	*
	+
	frame_bury 0 // minBal: uint64

	// examples/reti/validatorRegistry.algo.ts:1524
	// minBal += assets * ASSET_HOLDING_FEE
	frame_dig 0 // minBal: uint64
	frame_dig -3 // assets: uint64
	int 100000
	*
	+
	frame_bury 0 // minBal: uint64

	// examples/reti/validatorRegistry.algo.ts:1525
	// minBal += localInts * SSC_VALUE_UINT
	frame_dig 0 // minBal: uint64
	frame_dig -4 // localInts: uint64
	pushint 28500
	*
	+
	frame_bury 0 // minBal: uint64

	// examples/reti/validatorRegistry.algo.ts:1526
	// minBal += globalInts * SSC_VALUE_UINT
	frame_dig 0 // minBal: uint64
	frame_dig -6 // globalInts: uint64
	pushint 28500
	*
	+
	frame_bury 0 // minBal: uint64

	// examples/reti/validatorRegistry.algo.ts:1527
	// minBal += localBytes * SSC_VALUE_BYTES
	frame_dig 0 // minBal: uint64
	frame_dig -5 // localBytes: uint64
	pushint 50000
	*
	+
	frame_bury 0 // minBal: uint64

	// examples/reti/validatorRegistry.algo.ts:1528
	// minBal += globalBytes * SSC_VALUE_BYTES
	frame_dig 0 // minBal: uint64
	frame_dig -7 // globalBytes: uint64
	pushint 50000
	*
	+
	frame_bury 0 // minBal: uint64

	// examples/reti/validatorRegistry.algo.ts:1529
	// return minBal;
	frame_dig 0 // minBal: uint64

	// set the subroutine return value
	frame_bury 0
	retsub

// costForBoxStorage(totalNumBytes: uint64): uint64
costForBoxStorage:
	proto 1 1

	// examples/reti/validatorRegistry.algo.ts:1536
	// return SCBOX_PERBOX + totalNumBytes * SCBOX_PERBYTE;
	pushint 2500
	frame_dig -1 // totalNumBytes: uint64
	pushint 400
	*
	+
	retsub

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x1b5e82c6 // method "initStakingContract(uint64)void"
	pushbytes 0x79472d83 // method "loadStakingContractData(uint64,byte[])void"
	pushbytes 0x5f7acfd9 // method "finalizeStakingContract()void"
	pushbytes 0x3172ca9d // method "gas()void"
	pushbytes 0x8a87142d // method "getMbrAmounts()(uint64,uint64,uint64,uint64)"
	pushbytes 0xd1366cc3 // method "getProtocolConstraints()(uint64,uint64,uint64,uint64,uint64,uint64,uint64,uint64,uint64,uint64,uint64)"
	pushbytes 0x3b045c5c // method "getNumValidators()uint64"
	pushbytes 0x75aff61d // method "getValidatorConfig(uint64)(uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)"
	pushbytes 0x1f2f0109 // method "getValidatorState(uint64)(uint16,uint64,uint64,uint64)"
	pushbytes 0x2fa22c4b // method "getValidatorOwnerAndManager(uint64)(address,address)"
	pushbytes 0x910e94ac // method "getPools(uint64)(uint64,uint16,uint64)[]"
	pushbytes 0x572767d1 // method "getPoolAppId(uint64,uint64)uint64"
	pushbytes 0x9b504aaf // method "getPoolInfo((uint64,uint64,uint64))(uint64,uint16,uint64)"
	pushbytes 0xfbc63178 // method "getCurMaxStakePerPool(uint64)uint64"
	pushbytes 0x24498cf4 // method "doesStakerNeedToPayMBR(address)bool"
	pushbytes 0xf846dd7a // method "getStakedPoolsForAccount(address)(uint64,uint64,uint64)[]"
	pushbytes 0x83050501 // method "getTokenPayoutRatio(uint64)(uint64[24],uint64)"
	pushbytes 0x7bbb6c8d // method "getNodePoolAssignments(uint64)((uint64[3])[8])"
	pushbytes 0xf839414a // method "getNFDRegistryID()uint64"
	pushbytes 0x0c317cfb // method "addValidator(pay,string,(uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64))uint64"
	pushbytes 0x3e288972 // method "changeValidatorManager(uint64,address)void"
	pushbytes 0xdd5faada // method "changeValidatorSunsetInfo(uint64,uint64,uint64)void"
	pushbytes 0x18aac7a7 // method "changeValidatorNFD(uint64,uint64,string)void"
	pushbytes 0xf99ef54d // method "changeValidatorCommissionAddress(uint64,address)void"
	pushbytes 0x10809d4d // method "changeValidatorRewardInfo(uint64,uint8,address,uint64[4],uint64,uint64)void"
	pushbytes 0xe778dd5a // method "addPool(pay,uint64,uint64)(uint64,uint64,uint64)"
	pushbytes 0xbf5259d0 // method "addStake(pay,uint64,uint64)(uint64,uint64,uint64)"
	pushbytes 0x4df8d86e // method "setTokenPayoutRatio(uint64)(uint64[24],uint64)"
	pushbytes 0x418fcefc // method "stakeUpdatedViaRewards((uint64,uint64,uint64),uint64,uint64,uint64,uint64)void"
	pushbytes 0xa2dc51b5 // method "stakeRemoved((uint64,uint64,uint64),address,uint64,uint64,bool)void"
	pushbytes 0x2873f504 // method "findPoolForStaker(uint64,address,uint64)((uint64,uint64,uint64),bool,bool)"
	pushbytes 0x0547f4fe // method "movePoolToNode(uint64,uint64,uint64)void"
	pushbytes 0xcb668358 // method "emptyTokenRewards(uint64,address)uint64"
	txna ApplicationArgs 0
	match *abi_route_initStakingContract *abi_route_loadStakingContractData *abi_route_finalizeStakingContract *abi_route_gas *abi_route_getMbrAmounts *abi_route_getProtocolConstraints *abi_route_getNumValidators *abi_route_getValidatorConfig *abi_route_getValidatorState *abi_route_getValidatorOwnerAndManager *abi_route_getPools *abi_route_getPoolAppId *abi_route_getPoolInfo *abi_route_getCurMaxStakePerPool *abi_route_doesStakerNeedToPayMBR *abi_route_getStakedPoolsForAccount *abi_route_getTokenPayoutRatio *abi_route_getNodePoolAssignments *abi_route_getNFDRegistryID *abi_route_addValidator *abi_route_changeValidatorManager *abi_route_changeValidatorSunsetInfo *abi_route_changeValidatorNFD *abi_route_changeValidatorCommissionAddress *abi_route_changeValidatorRewardInfo *abi_route_addPool *abi_route_addStake *abi_route_setTokenPayoutRatio *abi_route_stakeUpdatedViaRewards *abi_route_stakeRemoved *abi_route_findPoolForStaker *abi_route_movePoolToNode *abi_route_emptyTokenRewards

	// this contract does not implement the given ABI method for call NoOp
	err

*call_UpdateApplication:
	pushbytes 0x46f76533 // method "updateApplication()void"
	txna ApplicationArgs 0
	match *abi_route_updateApplication

	// this contract does not implement the given ABI method for call UpdateApplication
	err", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/examples/reti/artifacts/ValidatorRegistry.arc56_draft.json b/examples/reti/artifacts/ValidatorRegistry.arc56_draft.json index b79dce7a8..9e25efeea 100644 --- a/examples/reti/artifacts/ValidatorRegistry.arc56_draft.json +++ b/examples/reti/artifacts/ValidatorRegistry.arc56_draft.json @@ -29816,7 +29816,7 @@ } }, "source": { - "approval": "#pragma version 10
intcblock TMPL_nfdRegistryAppId 0 1 8 268 24 32 18 6 100000 260 700 242 900 3 1000000 2 10 252
bytecblock 0x76 0x706f6f6c54656d706c617465417070726f76616c4279746573 0x151f7c75 0x 0x6e756d5374616b657273 0x69735f76616c69645f6e66645f6170706964 0x7374616b6564 0x737073 0x692e6f776e65722e61 0x0000000000000000 0x0a8101 0x696e6974 0x6e756d56 0x00 0x63f3f28b

// This TEAL was generated by TEALScript v0.104.1
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following lines of TEAL are used to initialize template variables in scratch slots
intc 0 // TMPL_nfdRegistryAppId

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
int 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *call_UpdateApplication *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// updateApplication()void
*abi_route_updateApplication:
	// execute updateApplication()void
	callsub updateApplication
	int 1
	return

// updateApplication(): void
updateApplication:
	proto 0 0

	// examples/reti/validatorRegistry.algo.ts:202
	// assert(this.txn.sender === Address.fromAddress('LZ4V2IRVLCXFJK4REJV4TAGEKEYTA2GMR6TC2344OB3L3AF3MWXZ6ZAFIQ'))
	txn Sender
	pushbytes 0x5e795d223558ae54ab91226bc980c451313068cc8fa62d6f9c7076bd80bb65af // addr "LZ4V2IRVLCXFJK4REJV4TAGEKEYTA2GMR6TC2344OB3L3AF3MWXZ6ZAFIQ"
	==
	assert

	// examples/reti/validatorRegistry.algo.ts:204
	// this.stakingPoolApprovalProgram.delete()
	byte 0x706f6f6c54656d706c617465417070726f76616c4279746573 // "poolTemplateApprovalBytes"
	box_del

	// examples/reti/validatorRegistry.algo.ts:205
	// this.stakingPoolInitialized.value = false
	byte 0x696e6974 // "init"
	int 0
	byte 0x00
	int 0
	uncover 2
	setbit
	app_global_put
	retsub

// createApplication()void
*abi_route_createApplication:
	// execute createApplication()void
	callsub createApplication
	int 1
	return

// createApplication(): void
createApplication:
	proto 0 0

	// examples/reti/validatorRegistry.algo.ts:209
	// this.stakingPoolInitialized.value = false
	byte 0x696e6974 // "init"
	int 0
	byte 0x00
	int 0
	uncover 2
	setbit
	app_global_put

	// examples/reti/validatorRegistry.algo.ts:210
	// this.numValidators.value = 0
	byte 0x6e756d56 // "numV"
	int 0
	app_global_put

	// examples/reti/validatorRegistry.algo.ts:211
	// this.numStakers.value = 0
	byte 0x6e756d5374616b657273 // "numStakers"
	int 0
	app_global_put

	// examples/reti/validatorRegistry.algo.ts:212
	// this.totalAlgoStaked.value = 0
	byte 0x7374616b6564 // "staked"
	int 0
	app_global_put
	retsub

// initStakingContract(uint64)void
*abi_route_initStakingContract:
	// approvalProgramSize: uint64
	txna ApplicationArgs 1
	btoi

	// execute initStakingContract(uint64)void
	callsub initStakingContract
	int 1
	return

// initStakingContract(approvalProgramSize: uint64): void
initStakingContract:
	proto 1 0

	// examples/reti/validatorRegistry.algo.ts:217
	// this.stakingPoolApprovalProgram.create(approvalProgramSize)
	byte 0x706f6f6c54656d706c617465417070726f76616c4279746573 // "poolTemplateApprovalBytes"
	frame_dig -1 // approvalProgramSize: uint64
	box_create
	pop
	retsub

// loadStakingContractData(uint64,byte[])void
*abi_route_loadStakingContractData:
	// data: byte[]
	txna ApplicationArgs 2
	extract 2 0

	// offset: uint64
	txna ApplicationArgs 1
	btoi

	// execute loadStakingContractData(uint64,byte[])void
	callsub loadStakingContractData
	int 1
	return

// loadStakingContractData(offset: uint64, data: bytes): void
loadStakingContractData:
	proto 2 0

	// examples/reti/validatorRegistry.algo.ts:221
	// assert(!this.stakingPoolInitialized.value)
	byte 0x696e6974 // "init"
	app_global_get
	int 0
	getbit
	!
	assert

	// examples/reti/validatorRegistry.algo.ts:222
	// this.stakingPoolApprovalProgram.replace(offset, data)
	byte 0x706f6f6c54656d706c617465417070726f76616c4279746573 // "poolTemplateApprovalBytes"
	frame_dig -1 // offset: uint64
	frame_dig -2 // data: bytes
	box_replace
	retsub

// finalizeStakingContract()void
*abi_route_finalizeStakingContract:
	// execute finalizeStakingContract()void
	callsub finalizeStakingContract
	int 1
	return

// finalizeStakingContract(): void
finalizeStakingContract:
	proto 0 0

	// examples/reti/validatorRegistry.algo.ts:226
	// this.stakingPoolInitialized.value = true
	byte 0x696e6974 // "init"
	int 1
	byte 0x00
	int 0
	uncover 2
	setbit
	app_global_put
	retsub

// gas()void
*abi_route_gas:
	// execute gas()void
	callsub gas
	int 1
	return

// gas(): void
//
// gas is a dummy no-op call that can be used to pool-up resource references and opcode cost
gas:
	proto 0 0
	retsub

// getMbrAmounts()(uint64,uint64,uint64,uint64)
*abi_route_getMbrAmounts:
	// The ABI return prefix
	byte 0x151f7c75

	// execute getMbrAmounts()(uint64,uint64,uint64,uint64)
	callsub getMbrAmounts
	concat
	log
	int 1
	return

// getMbrAmounts(): MbrAmounts
//
// Returns the MBR amounts needed for various actions:
// [
// addValidatorMbr: uint64 - mbr needed to add a new validator - paid to validator contract
// addPoolMbr: uint64 - mbr needed to add a new pool - paid to validator
// poolInitMbr: uint64 - mbr needed to initStorage() of pool - paid to pool itself
// addStakerMbr: uint64 - mbr staker needs to add to first staking payment (stays w/ validator)
// ]
getMbrAmounts:
	proto 0 1

	// examples/reti/validatorRegistry.algo.ts:246
	// return {
	//       addValidatorMbr: this.costForBoxStorage(1 /* v prefix */ + len<ValidatorIdType>() + len<ValidatorInfo>()),
	//       addPoolMbr: this.minBalanceForAccount(
	//         1,
	//         // we could calculate this directly by referencing the size of stakingPoolApprovalProgram but it would
	//         // mean our callers would have to reference the box AND buy up i/o - so just go max on extra pages
	//         3,
	//         0,
	//         0,
	//         0,
	//         StakingPool.schema.global.numUint,
	//         StakingPool.schema.global.numByteSlice
	//       ),
	//       poolInitMbr:
	//         ALGORAND_ACCOUNT_MIN_BALANCE +
	//         this.costForBoxStorage(7 /* 'stakers' name */ + len<StakedInfo>() * MAX_STAKERS_PER_POOL),
	//       addStakerMbr:
	//         // how much to charge for first time a staker adds stake - since we add a tracking box per staker
	//         this.costForBoxStorage(3 /* 'sps' prefix */ + len<Address>() + len<ValidatorPoolKey>() * MAX_POOLS_PER_STAKER), // size of key + all values
	//     };
	pushint 1101
	callsub costForBoxStorage
	itob
	int 3
	pushint 11
	int 0
	dupn 2
	int 3
	int 1
	callsub minBalanceForAccount
	itob
	concat
	int 100000
	pushint 12807
	callsub costForBoxStorage
	+
	itob
	concat
	pushint 179
	callsub costForBoxStorage
	itob
	concat
	retsub

// getProtocolConstraints()(uint64,uint64,uint64,uint64,uint64,uint64,uint64,uint64,uint64,uint64,uint64)
*abi_route_getProtocolConstraints:
	// The ABI return prefix
	byte 0x151f7c75

	// execute getProtocolConstraints()(uint64,uint64,uint64,uint64,uint64,uint64,uint64,uint64,uint64,uint64,uint64)
	callsub getProtocolConstraints
	concat
	log
	int 1
	return

// getProtocolConstraints(): Constraints
//
// Returns the protocol constraints so that UIs can limit what users specify for validator configuration parameters.
getProtocolConstraints:
	proto 0 1

	// examples/reti/validatorRegistry.algo.ts:272
	// return {
	//       epochPayoutRoundsMin: MIN_EPOCH_LENGTH,
	//       epochPayoutRoundsMax: MAX_EPOCH_LENGTH,
	//       minPctToValidatorWFourDecimals: MIN_PCT_TO_VALIDATOR,
	//       maxPctToValidatorWFourDecimals: MAX_PCT_TO_VALIDATOR,
	//       minEntryStake: MIN_ALGO_STAKE_PER_POOL,
	//       maxAlgoPerPool: this.maxAlgoAllowedPerPool(),
	//       maxAlgoPerValidator: this.maxAllowedStake(),
	//       amtConsideredSaturated: this.algoSaturationLevel(),
	//       maxNodes: MAX_NODES,
	//       maxPoolsPerNode: MAX_POOLS_PER_NODE,
	//       maxStakersPerPool: MAX_STAKERS_PER_POOL,
	//     };
	pushbytes 0x000000000000000100000000000f4240000000000000000000000000000f424000000000000f4240
	callsub maxAlgoAllowedPerPool
	itob
	concat
	callsub maxAllowedStake
	itob
	concat
	callsub algoSaturationLevel
	itob
	concat
	pushbytes 0x0000000000000008
	concat
	pushbytes 0x0000000000000003
	concat
	pushbytes 0x00000000000000c8
	concat
	retsub

// getNumValidators()uint64
*abi_route_getNumValidators:
	// The ABI return prefix
	byte 0x151f7c75

	// execute getNumValidators()uint64
	callsub getNumValidators
	itob
	concat
	log
	int 1
	return

// getNumValidators(): uint64
//
// Returns the current number of validators
getNumValidators:
	proto 0 1

	// examples/reti/validatorRegistry.algo.ts:292
	// return this.numValidators.value;
	byte 0x6e756d56 // "numV"
	app_global_get
	retsub

// getValidatorConfig(uint64)(uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
*abi_route_getValidatorConfig:
	// The ABI return prefix
	byte 0x151f7c75

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute getValidatorConfig(uint64)(uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	callsub getValidatorConfig
	concat
	log
	int 1
	return

// getValidatorConfig(validatorId: ValidatorIdType): ValidatorConfig
getValidatorConfig:
	proto 1 1

	// examples/reti/validatorRegistry.algo.ts:297
	// return this.validatorList(validatorId).value.config;
	int 0
	int 242
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	retsub

// getValidatorState(uint64)(uint16,uint64,uint64,uint64)
*abi_route_getValidatorState:
	// The ABI return prefix
	byte 0x151f7c75

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute getValidatorState(uint64)(uint16,uint64,uint64,uint64)
	callsub getValidatorState
	concat
	log
	int 1
	return

// getValidatorState(validatorId: ValidatorIdType): ValidatorCurState
getValidatorState:
	proto 1 1

	// examples/reti/validatorRegistry.algo.ts:302
	// return this.validatorList(validatorId).value.state;
	int 242 // headOffset
	pushint 26
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	retsub

// getValidatorOwnerAndManager(uint64)(address,address)
*abi_route_getValidatorOwnerAndManager:
	// The ABI return prefix
	byte 0x151f7c75

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute getValidatorOwnerAndManager(uint64)(address,address)
	callsub getValidatorOwnerAndManager
	concat
	log
	int 1
	return

// getValidatorOwnerAndManager(validatorId: ValidatorIdType): [Address, Address]
getValidatorOwnerAndManager:
	proto 1 1

	// examples/reti/validatorRegistry.algo.ts:307
	// return [this.validatorList(validatorId).value.config.owner, this.validatorList(validatorId).value.config.manager];
	int 8
	int 32
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	pushint 40
	int 32
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	concat
	retsub

// getPools(uint64)(uint64,uint16,uint64)[]
*abi_route_getPools:
	// The ABI return prefix
	byte 0x151f7c75

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute getPools(uint64)(uint64,uint16,uint64)[]
	callsub getPools
	dup
	len
	int 18
	/
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// getPools(validatorId: ValidatorIdType): PoolInfo[]
//
// Return list of all pools for this validator.
// @param {uint64} validatorId
// @return {PoolInfo[]} - array of pools
// Not callable from other contracts because >1K return but can be called w/ simulate which bumps log returns
getPools:
	proto 1 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// examples/reti/validatorRegistry.algo.ts:318
	// retData: PoolInfo[] = []
	byte 0x
	frame_bury 0 // retData: PoolInfo[]

	// examples/reti/validatorRegistry.algo.ts:319
	// poolSet = clone(this.validatorList(validatorId).value.pools)
	int 268 // headOffset
	pushint 432
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	frame_bury 1 // poolSet: (uint64,uint16,uint64)[24]

	// examples/reti/validatorRegistry.algo.ts:320
	// for (let i = 0; i < poolSet.length; i += 1)
	int 0
	frame_bury 2 // i: uint64

*for_0:
	// examples/reti/validatorRegistry.algo.ts:320
	// i < poolSet.length
	frame_dig 2 // i: uint64
	int 24
	<
	bz *for_0_end

	// *if0_condition
	// examples/reti/validatorRegistry.algo.ts:321
	// poolSet[i].poolAppId === 0
	frame_dig 1 // poolSet: (uint64,uint16,uint64)[24]
	frame_dig 2 // i: uint64
	int 18
	* // acc * typeLength
	int 0
	+
	int 8
	extract3
	btoi
	int 0
	==
	bz *if0_end

	// *if0_consequent
	b *for_0_end

*if0_end:
	// examples/reti/validatorRegistry.algo.ts:325
	// retData.push(poolSet[i])
	frame_dig 0 // retData: PoolInfo[]
	frame_dig 1 // poolSet: (uint64,uint16,uint64)[24]
	frame_dig 2 // i: uint64
	int 18
	* // acc * typeLength
	int 18
	extract3
	concat
	frame_bury 0 // retData: PoolInfo[]

*for_0_continue:
	// examples/reti/validatorRegistry.algo.ts:320
	// i += 1
	frame_dig 2 // i: uint64
	int 1
	+
	frame_bury 2 // i: uint64
	b *for_0

*for_0_end:
	// examples/reti/validatorRegistry.algo.ts:327
	// return retData;
	frame_dig 0 // retData: PoolInfo[]

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 2
	retsub

// getPoolAppId(uint64,uint64)uint64
*abi_route_getPoolAppId:
	// The ABI return prefix
	byte 0x151f7c75

	// poolId: uint64
	txna ApplicationArgs 2
	btoi

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute getPoolAppId(uint64,uint64)uint64
	callsub getPoolAppId
	itob
	concat
	log
	int 1
	return

// getPoolAppId(validatorId: uint64, poolId: uint64): uint64
getPoolAppId:
	proto 2 1

	// examples/reti/validatorRegistry.algo.ts:335
	// assert(
	//       poolId !== 0 && poolId <= this.validatorList(validatorId).value.pools.length,
	//       'pool id must be between 1 and number of pools for this validator'
	//     )
	frame_dig -2 // poolId: uint64
	int 0
	!=
	dup
	bz *skip_and0
	frame_dig -2 // poolId: uint64
	int 24
	<=
	&&

*skip_and0:
	// pool id must be between 1 and number of pools for this validator
	assert

	// examples/reti/validatorRegistry.algo.ts:339
	// return this.validatorList(validatorId).value.pools[poolId - 1].poolAppId;
	int 268 // headOffset
	frame_dig -2 // poolId: uint64
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 0
	+
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: uint64
	itob
	concat
	cover 2
	box_extract
	btoi
	retsub

// getPoolInfo((uint64,uint64,uint64))(uint64,uint16,uint64)
*abi_route_getPoolInfo:
	// The ABI return prefix
	byte 0x151f7c75

	// poolKey: (uint64,uint64,uint64)
	txna ApplicationArgs 1
	dup
	len
	int 24
	==

	// argument 0 (poolKey) for getPoolInfo must be a (uint64,uint64,uint64)
	assert

	// execute getPoolInfo((uint64,uint64,uint64))(uint64,uint16,uint64)
	callsub getPoolInfo
	concat
	log
	int 1
	return

// getPoolInfo(poolKey: ValidatorPoolKey): PoolInfo
getPoolInfo:
	proto 1 1

	// examples/reti/validatorRegistry.algo.ts:344
	// return this.validatorList(poolKey.id).value.pools[poolKey.poolId - 1];
	int 268 // headOffset
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 18
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	retsub

// getCurMaxStakePerPool(uint64)uint64
*abi_route_getCurMaxStakePerPool:
	// The ABI return prefix
	byte 0x151f7c75

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute getCurMaxStakePerPool(uint64)uint64
	callsub getCurMaxStakePerPool
	itob
	concat
	log
	int 1
	return

// getCurMaxStakePerPool(validatorId: ValidatorIdType): uint64
//
// Calculate the maximum stake per pool for a given validator.
// Normally this would be maxAlgoPerPool, but it should also never go above MaxAllowedStake / numPools so
// as pools are added the max allowed per pool can reduce.
//
// @param {ValidatorIdType} validatorId - The id of the validator.
getCurMaxStakePerPool:
	proto 1 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// examples/reti/validatorRegistry.algo.ts:355
	// numPools = this.validatorList(validatorId).value.state.numPools as uint64
	int 242
	int 2
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 0 // numPools: uint64

	// examples/reti/validatorRegistry.algo.ts:356
	// hardMaxDividedBetweenPools = this.maxAllowedStake() / numPools
	callsub maxAllowedStake
	frame_dig 0 // numPools: uint64
	/
	frame_bury 1 // hardMaxDividedBetweenPools: uint64

	// examples/reti/validatorRegistry.algo.ts:357
	// maxPerPool: uint64 = this.validatorList(validatorId).value.config.maxAlgoPerPool
	pushint 217
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 2 // maxPerPool: uint64

	// *if1_condition
	// examples/reti/validatorRegistry.algo.ts:358
	// maxPerPool === 0
	frame_dig 2 // maxPerPool: uint64
	int 0
	==
	bz *if1_end

	// *if1_consequent
	// examples/reti/validatorRegistry.algo.ts:359
	// maxPerPool = this.maxAlgoAllowedPerPool()
	callsub maxAlgoAllowedPerPool
	frame_bury 2 // maxPerPool: uint64

*if1_end:
	// *if2_condition
	// examples/reti/validatorRegistry.algo.ts:361
	// hardMaxDividedBetweenPools < maxPerPool
	frame_dig 1 // hardMaxDividedBetweenPools: uint64
	frame_dig 2 // maxPerPool: uint64
	<
	bz *if2_end

	// *if2_consequent
	// examples/reti/validatorRegistry.algo.ts:362
	// maxPerPool = hardMaxDividedBetweenPools
	frame_dig 1 // hardMaxDividedBetweenPools: uint64
	frame_bury 2 // maxPerPool: uint64

*if2_end:
	// examples/reti/validatorRegistry.algo.ts:364
	// return maxPerPool;
	frame_dig 2 // maxPerPool: uint64

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 2
	retsub

// doesStakerNeedToPayMBR(address)bool
*abi_route_doesStakerNeedToPayMBR:
	// The ABI return prefix
	byte 0x151f7c75

	// staker: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (staker) for doesStakerNeedToPayMBR must be a address
	assert

	// execute doesStakerNeedToPayMBR(address)bool
	callsub doesStakerNeedToPayMBR
	byte 0x00
	int 0
	uncover 2
	setbit
	concat
	log
	int 1
	return

// doesStakerNeedToPayMBR(staker: Address): boolean
//
// Helper callers can call w/ simulate to determine if 'AddStaker' MBR should be included w/ staking amount
// @param staker
doesStakerNeedToPayMBR:
	proto 1 1

	// examples/reti/validatorRegistry.algo.ts:373
	// return !this.stakerPoolSet(staker).exists;
	byte 0x737073 // "sps"
	frame_dig -1 // staker: Address
	concat
	box_len
	swap
	pop
	!
	retsub

// getStakedPoolsForAccount(address)(uint64,uint64,uint64)[]
*abi_route_getStakedPoolsForAccount:
	// The ABI return prefix
	byte 0x151f7c75

	// staker: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (staker) for getStakedPoolsForAccount must be a address
	assert

	// execute getStakedPoolsForAccount(address)(uint64,uint64,uint64)[]
	callsub getStakedPoolsForAccount
	dup
	len
	int 24
	/
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// getStakedPoolsForAccount(staker: Address): ValidatorPoolKey[]
//
// Retrieves the staked pools for an account.
//
// @param {Address} staker - The account to retrieve staked pools for.
// @return {ValidatorPoolKey[]} - The array of staked pools for the account.
getStakedPoolsForAccount:
	proto 1 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// *if3_condition
	// examples/reti/validatorRegistry.algo.ts:383
	// !this.stakerPoolSet(staker).exists
	byte 0x737073 // "sps"
	frame_dig -1 // staker: Address
	concat
	box_len
	swap
	pop
	!
	bz *if3_end

	// *if3_consequent
	// examples/reti/validatorRegistry.algo.ts:384
	// return [];
	byte 0x
	b *getStakedPoolsForAccount*return

*if3_end:
	// examples/reti/validatorRegistry.algo.ts:386
	// retData: ValidatorPoolKey[] = []
	byte 0x
	frame_bury 0 // retData: ValidatorPoolKey[]

	// examples/reti/validatorRegistry.algo.ts:387
	// poolSet = clone(this.stakerPoolSet(staker).value)
	byte 0x737073 // "sps"
	frame_dig -1 // staker: Address
	concat
	box_get

	// box value does not exist: this.stakerPoolSet(staker).value
	assert
	frame_bury 1 // poolSet: (uint64,uint64,uint64)[6]

	// examples/reti/validatorRegistry.algo.ts:388
	// for (let i = 0; i < poolSet.length; i += 1)
	int 0
	frame_bury 2 // i: uint64

*for_1:
	// examples/reti/validatorRegistry.algo.ts:388
	// i < poolSet.length
	frame_dig 2 // i: uint64
	int 6
	<
	bz *for_1_end

	// *if4_condition
	// examples/reti/validatorRegistry.algo.ts:389
	// poolSet[i].id !== 0
	frame_dig 1 // poolSet: (uint64,uint64,uint64)[6]
	frame_dig 2 // i: uint64
	int 24
	* // acc * typeLength
	int 0
	+
	int 8
	extract3
	btoi
	int 0
	!=
	bz *if4_end

	// *if4_consequent
	// examples/reti/validatorRegistry.algo.ts:390
	// retData.push(poolSet[i])
	frame_dig 0 // retData: ValidatorPoolKey[]
	frame_dig 1 // poolSet: (uint64,uint64,uint64)[6]
	frame_dig 2 // i: uint64
	int 24
	* // acc * typeLength
	int 24
	extract3
	concat
	frame_bury 0 // retData: ValidatorPoolKey[]

*if4_end:

*for_1_continue:
	// examples/reti/validatorRegistry.algo.ts:388
	// i += 1
	frame_dig 2 // i: uint64
	int 1
	+
	frame_bury 2 // i: uint64
	b *for_1

*for_1_end:
	// examples/reti/validatorRegistry.algo.ts:393
	// return retData;
	frame_dig 0 // retData: ValidatorPoolKey[]

*getStakedPoolsForAccount*return:
	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 2
	retsub

// getTokenPayoutRatio(uint64)(uint64[24],uint64)
*abi_route_getTokenPayoutRatio:
	// The ABI return prefix
	byte 0x151f7c75

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute getTokenPayoutRatio(uint64)(uint64[24],uint64)
	callsub getTokenPayoutRatio
	concat
	log
	int 1
	return

// getTokenPayoutRatio(validatorId: ValidatorIdType): PoolTokenPayoutRatio
//
// Retrieves the token payout ratio for a given validator - returning the pool ratios of whole so that token
// payouts across pools can be based on a stable snaphost of stake.
//
// @param {ValidatorIdType} validatorId - The id of the validator.
// @return {PoolTokenPayoutRatio} - The token payout ratio for the validator.
getTokenPayoutRatio:
	proto 1 1

	// examples/reti/validatorRegistry.algo.ts:405
	// return this.validatorList(validatorId).value.tokenPayoutRatio;
	int 700 // headOffset
	pushint 200
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	retsub

// getNodePoolAssignments(uint64)((uint64[3])[8])
*abi_route_getNodePoolAssignments:
	// The ABI return prefix
	byte 0x151f7c75

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute getNodePoolAssignments(uint64)((uint64[3])[8])
	callsub getNodePoolAssignments
	concat
	log
	int 1
	return

// getNodePoolAssignments(validatorId: uint64): NodePoolAssignmentConfig
getNodePoolAssignments:
	proto 1 1

	// examples/reti/validatorRegistry.algo.ts:410
	// assert(this.validatorList(validatorId).exists, "the specified validator id doesn't exist")
	byte 0x76 // "v"
	frame_dig -1 // validatorId: uint64
	itob
	concat
	box_len
	swap
	pop

	// the specified validator id doesn't exist
	assert

	// examples/reti/validatorRegistry.algo.ts:412
	// return this.validatorList(validatorId).value.nodePoolAssignments;
	int 900 // headOffset
	pushint 192
	byte 0x76 // "v"
	frame_dig -1 // validatorId: uint64
	itob
	concat
	cover 2
	box_extract
	retsub

// getNFDRegistryID()uint64
*abi_route_getNFDRegistryID:
	// The ABI return prefix
	byte 0x151f7c75

	// execute getNFDRegistryID()uint64
	callsub getNFDRegistryID
	itob
	concat
	log
	int 1
	return

// getNFDRegistryID(): uint64
getNFDRegistryID:
	proto 0 1

	// examples/reti/validatorRegistry.algo.ts:416
	// return this.nfdRegistryAppId;
	intc 0 // TMPL_nfdRegistryAppId
	retsub

// addValidator(pay,string,(uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64))uint64
*abi_route_addValidator:
	// The ABI return prefix
	byte 0x151f7c75

	// config: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	txna ApplicationArgs 2
	dup
	len
	int 242
	==

	// argument 0 (config) for addValidator must be a (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	assert

	// nfdName: string
	txna ApplicationArgs 1
	extract 2 0

	// mbrPayment: pay
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// argument 2 (mbrPayment) for addValidator must be a pay transaction
	assert

	// execute addValidator(pay,string,(uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64))uint64
	callsub addValidator
	itob
	concat
	log
	int 1
	return

// addValidator(mbrPayment: PayTxn, nfdName: string, config: ValidatorConfig): uint64
//
// Adds a new validator
// Requires at least 10 ALGO as the 'fee' for the transaction to help dissuade spammed validator adds.
//
// @param {PayTxn} mbrPayment payment from caller which covers mbr increase of new validator storage
// @param {string} nfdName (Optional) Name of nfd (used as double-check against id specified in config)
// @param {ValidatorConfig} config ValidatorConfig struct
// @returns {uint64} validator id
addValidator:
	proto 3 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/reti/validatorRegistry.algo.ts:428
	// this.validateConfig(config)
	frame_dig -3 // config: ValidatorConfig
	callsub validateConfig

	// examples/reti/validatorRegistry.algo.ts:429
	// assert(config.owner !== Address.zeroAddress)
	frame_dig -3 // config: ValidatorConfig
	extract 8 32
	global ZeroAddress
	!=
	assert

	// examples/reti/validatorRegistry.algo.ts:430
	// assert(config.manager !== Address.zeroAddress)
	frame_dig -3 // config: ValidatorConfig
	extract 40 32
	global ZeroAddress
	!=
	assert

	// examples/reti/validatorRegistry.algo.ts:431
	// assert(this.txn.sender === config.owner, 'sender must be owner to add new validator')
	txn Sender
	frame_dig -3 // config: ValidatorConfig
	extract 8 32
	==

	// sender must be owner to add new validator
	assert

	// examples/reti/validatorRegistry.algo.ts:433
	// verifyPayTxn(mbrPayment, { amount: this.getMbrAmounts().addValidatorMbr })
	// verify amount
	frame_dig -1 // mbrPayment: PayTxn
	gtxns Amount
	callsub getMbrAmounts
	extract 0 8
	btoi
	==

	// transaction verification failed: {"txn":"mbrPayment","field":"amount","expected":"this.getMbrAmounts().addValidatorMbr"}
	assert

	// examples/reti/validatorRegistry.algo.ts:435
	// assert(mbrPayment.fee > 10 * 1000000, 'fee must be 10 ALGO or more to prevent spamming of validators')
	frame_dig -1 // mbrPayment: PayTxn
	gtxns Fee
	pushint 10000000
	>

	// fee must be 10 ALGO or more to prevent spamming of validators
	assert

	// examples/reti/validatorRegistry.algo.ts:438
	// validatorId = this.numValidators.value + 1
	byte 0x6e756d56 // "numV"
	app_global_get
	int 1
	+
	frame_bury 0 // validatorId: uint64

	// examples/reti/validatorRegistry.algo.ts:439
	// this.numValidators.value = validatorId
	byte 0x6e756d56 // "numV"
	frame_dig 0 // validatorId: uint64
	app_global_put

	// examples/reti/validatorRegistry.algo.ts:441
	// this.validatorList(validatorId).create()
	byte 0x76 // "v"
	frame_dig 0 // validatorId: uint64
	itob
	concat
	pushint 1092
	box_create
	pop

	// examples/reti/validatorRegistry.algo.ts:442
	// this.validatorList(validatorId).value.config = config
	int 0
	frame_dig -3 // config: ValidatorConfig
	byte 0x76 // "v"
	frame_dig 0 // validatorId: uint64
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:443
	// this.validatorList(validatorId).value.config.id = validatorId
	int 0
	frame_dig 0 // validatorId: uint64
	itob
	byte 0x76 // "v"
	frame_dig 0 // validatorId: uint64
	itob
	concat
	cover 2
	box_replace

	// *if5_condition
	// examples/reti/validatorRegistry.algo.ts:446
	// config.nfdForInfo !== 0
	frame_dig -3 // config: ValidatorConfig
	extract 72 8
	btoi
	int 0
	!=
	bz *if5_end

	// *if5_consequent
	// examples/reti/validatorRegistry.algo.ts:448
	// sendAppCall({
	//         applicationID: AppID.fromUint64(this.nfdRegistryAppId),
	//         applicationArgs: ['is_valid_nfd_appid', nfdName, itob(config.nfdForInfo)],
	//         applications: [AppID.fromUint64(config.nfdForInfo)],
	//       })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum

	// examples/reti/validatorRegistry.algo.ts:449
	// applicationID: AppID.fromUint64(this.nfdRegistryAppId)
	intc 0 // TMPL_nfdRegistryAppId
	itxn_field ApplicationID

	// examples/reti/validatorRegistry.algo.ts:450
	// applicationArgs: ['is_valid_nfd_appid', nfdName, itob(config.nfdForInfo)]
	byte 0x69735f76616c69645f6e66645f6170706964 // "is_valid_nfd_appid"
	itxn_field ApplicationArgs
	frame_dig -2 // nfdName: string
	itxn_field ApplicationArgs
	frame_dig -3 // config: ValidatorConfig
	extract 72 8
	btoi
	itob
	itxn_field ApplicationArgs

	// examples/reti/validatorRegistry.algo.ts:451
	// applications: [AppID.fromUint64(config.nfdForInfo)]
	frame_dig -3 // config: ValidatorConfig
	extract 72 8
	btoi
	itxn_field Applications

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/validatorRegistry.algo.ts:453
	// assert(btoi(this.itxn.lastLog) === 1, "provided NFD isn't valid")
	itxn LastLog
	btoi
	int 1
	==

	// provided NFD isn't valid
	assert

	// examples/reti/validatorRegistry.algo.ts:455
	// assert(
	//         this.txn.sender === (AppID.fromUint64(config.nfdForInfo).globalState('i.owner.a') as Address),
	//         'If specifying NFD, account adding validator must be owner'
	//       )
	txn Sender
	frame_dig -3 // config: ValidatorConfig
	extract 72 8
	btoi
	byte 0x692e6f776e65722e61 // "i.owner.a"
	app_global_get_ex

	// global state value does not exist: AppID.fromUint64(config.nfdForInfo).globalState('i.owner.a')
	assert
	==

	// If specifying NFD, account adding validator must be owner
	assert

*if5_end:
	// *if6_condition
	// examples/reti/validatorRegistry.algo.ts:461
	// config.entryGatingType === GATING_TYPE_CREATED_BY_NFD_ADDRESSES ||
	//       config.entryGatingType === GATING_TYPE_SEGMENT_OF_NFD
	frame_dig -3 // config: ValidatorConfig
	extract 80 1
	btoi
	int 3
	==
	dup
	bnz *skip_or0
	frame_dig -3 // config: ValidatorConfig
	extract 80 1
	btoi
	pushint 4
	==
	||

*skip_or0:
	bz *if6_end

	// *if6_consequent
	// examples/reti/validatorRegistry.algo.ts:465
	// assert(this.isNFDAppIDValid(config.entryGatingAssets[0]), 'provided NFD App id for gating must be valid NFD')
	frame_dig -3 // config: ValidatorConfig
	extract 113 8
	btoi
	callsub isNFDAppIDValid

	// provided NFD App id for gating must be valid NFD
	assert

*if6_end:
	// examples/reti/validatorRegistry.algo.ts:468
	// return validatorId;
	frame_dig 0 // validatorId: uint64

	// set the subroutine return value
	frame_bury 0
	retsub

// changeValidatorManager(uint64,address)void
*abi_route_changeValidatorManager:
	// manager: address
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (manager) for changeValidatorManager must be a address
	assert

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute changeValidatorManager(uint64,address)void
	callsub changeValidatorManager
	int 1
	return

// changeValidatorManager(validatorId: ValidatorIdType, manager: Address): void
//
// Changes the Validator manager for a specific Validator id.
// [ ONLY OWNER CAN CHANGE ]
//
// @param {ValidatorIdType} validatorId - The id of the validator to change the manager for.
// @param {Address} manager - The new manager address.
changeValidatorManager:
	proto 2 0

	// examples/reti/validatorRegistry.algo.ts:479
	// assert(
	//       this.txn.sender === this.validatorList(validatorId).value.config.owner,
	//       'can only be called by validator owner'
	//     )
	txn Sender
	int 8
	int 32
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	==

	// can only be called by validator owner
	assert

	// examples/reti/validatorRegistry.algo.ts:483
	// this.validatorList(validatorId).value.config.manager = manager
	pushint 40
	frame_dig -2 // manager: Address
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace
	retsub

// changeValidatorSunsetInfo(uint64,uint64,uint64)void
*abi_route_changeValidatorSunsetInfo:
	// sunsettingTo: uint64
	txna ApplicationArgs 3
	btoi

	// sunsettingOn: uint64
	txna ApplicationArgs 2
	btoi

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute changeValidatorSunsetInfo(uint64,uint64,uint64)void
	callsub changeValidatorSunsetInfo
	int 1
	return

// changeValidatorSunsetInfo(validatorId: ValidatorIdType, sunsettingOn: uint64, sunsettingTo: ValidatorIdType): void
//
// Updates the sunset information for a given validator.
// [ ONLY OWNER CAN CHANGE ]
//
// @param {ValidatorIdType} validatorId - The id of the validator to update.
// @param {uint64} sunsettingOn - The new sunset timestamp.
// @param {uint64} sunsettingTo - The new sunset to validator id.
changeValidatorSunsetInfo:
	proto 3 0

	// examples/reti/validatorRegistry.algo.ts:495
	// assert(
	//       this.txn.sender === this.validatorList(validatorId).value.config.owner,
	//       'can only be called by validator owner'
	//     )
	txn Sender
	int 8
	int 32
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	==

	// can only be called by validator owner
	assert

	// examples/reti/validatorRegistry.algo.ts:499
	// this.validatorList(validatorId).value.config.sunsettingOn = sunsettingOn
	pushint 226
	frame_dig -2 // sunsettingOn: uint64
	itob
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:500
	// this.validatorList(validatorId).value.config.sunsettingTo = sunsettingTo
	pushint 234
	frame_dig -3 // sunsettingTo: ValidatorIdType
	itob
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace
	retsub

// changeValidatorNFD(uint64,uint64,string)void
*abi_route_changeValidatorNFD:
	// nfdName: string
	txna ApplicationArgs 3
	extract 2 0

	// nfdAppID: uint64
	txna ApplicationArgs 2
	btoi

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute changeValidatorNFD(uint64,uint64,string)void
	callsub changeValidatorNFD
	int 1
	return

// changeValidatorNFD(validatorId: ValidatorIdType, nfdAppID: uint64, nfdName: string): void
//
// Changes the NFD for a validator in the validatorList contract.
// [ ONLY OWNER CAN CHANGE ]
//
// @param {ValidatorIdType} validatorId - The id of the validator to update.
// @param {uint64} nfdAppID - The application id of the NFD to assign to the validator.
// @param {string} nfdName - The name of the NFD (which must match)
changeValidatorNFD:
	proto 3 0

	// examples/reti/validatorRegistry.algo.ts:513
	// assert(
	//       this.txn.sender === this.validatorList(validatorId).value.config.owner,
	//       'can only be called by validator owner'
	//     )
	txn Sender
	int 8
	int 32
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	==

	// can only be called by validator owner
	assert

	// examples/reti/validatorRegistry.algo.ts:518
	// sendAppCall({
	//       applicationID: AppID.fromUint64(this.nfdRegistryAppId),
	//       applicationArgs: ['is_valid_nfd_appid', nfdName, itob(nfdAppID)],
	//       applications: [AppID.fromUint64(nfdAppID)],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum

	// examples/reti/validatorRegistry.algo.ts:519
	// applicationID: AppID.fromUint64(this.nfdRegistryAppId)
	intc 0 // TMPL_nfdRegistryAppId
	itxn_field ApplicationID

	// examples/reti/validatorRegistry.algo.ts:520
	// applicationArgs: ['is_valid_nfd_appid', nfdName, itob(nfdAppID)]
	byte 0x69735f76616c69645f6e66645f6170706964 // "is_valid_nfd_appid"
	itxn_field ApplicationArgs
	frame_dig -3 // nfdName: string
	itxn_field ApplicationArgs
	frame_dig -2 // nfdAppID: uint64
	itob
	itxn_field ApplicationArgs

	// examples/reti/validatorRegistry.algo.ts:521
	// applications: [AppID.fromUint64(nfdAppID)]
	frame_dig -2 // nfdAppID: uint64
	itxn_field Applications

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/validatorRegistry.algo.ts:524
	// assert(
	//       this.txn.sender === (AppID.fromUint64(nfdAppID).globalState('i.owner.a') as Address),
	//       'If specifying NFD, account adding validator must be owner'
	//     )
	txn Sender
	frame_dig -2 // nfdAppID: uint64
	byte 0x692e6f776e65722e61 // "i.owner.a"
	app_global_get_ex

	// global state value does not exist: AppID.fromUint64(nfdAppID).globalState('i.owner.a')
	assert
	==

	// If specifying NFD, account adding validator must be owner
	assert

	// examples/reti/validatorRegistry.algo.ts:528
	// this.validatorList(validatorId).value.config.nfdForInfo = nfdAppID
	pushint 72
	frame_dig -2 // nfdAppID: uint64
	itob
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace
	retsub

// changeValidatorCommissionAddress(uint64,address)void
*abi_route_changeValidatorCommissionAddress:
	// commissionAddress: address
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (commissionAddress) for changeValidatorCommissionAddress must be a address
	assert

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute changeValidatorCommissionAddress(uint64,address)void
	callsub changeValidatorCommissionAddress
	int 1
	return

// changeValidatorCommissionAddress(validatorId: ValidatorIdType, commissionAddress: Address): void
//
// Change the commission address that validator rewards are sent to.
// [ ONLY OWNER CAN CHANGE ]
changeValidatorCommissionAddress:
	proto 2 0

	// examples/reti/validatorRegistry.algo.ts:536
	// assert(
	//       this.txn.sender === this.validatorList(validatorId).value.config.owner,
	//       'can only be called by validator owner'
	//     )
	txn Sender
	int 8
	int 32
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	==

	// can only be called by validator owner
	assert

	// examples/reti/validatorRegistry.algo.ts:540
	// assert(commissionAddress !== Address.zeroAddress)
	frame_dig -2 // commissionAddress: Address
	global ZeroAddress
	!=
	assert

	// examples/reti/validatorRegistry.algo.ts:541
	// this.validatorList(validatorId).value.config.validatorCommissionAddress = commissionAddress
	pushint 177
	frame_dig -2 // commissionAddress: Address
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace
	retsub

// changeValidatorRewardInfo(uint64,uint8,address,uint64[4],uint64,uint64)void
*abi_route_changeValidatorRewardInfo:
	// RewardPerPayout: uint64
	txna ApplicationArgs 6
	btoi

	// GatingAssetMinBalance: uint64
	txna ApplicationArgs 5
	btoi

	// EntryGatingAssets: uint64[4]
	txna ApplicationArgs 4
	dup
	len
	int 32
	==

	// argument 2 (EntryGatingAssets) for changeValidatorRewardInfo must be a uint64[4]
	assert

	// EntryGatingAddress: address
	txna ApplicationArgs 3
	dup
	len
	int 32
	==

	// argument 3 (EntryGatingAddress) for changeValidatorRewardInfo must be a address
	assert

	// EntryGatingType: uint8
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 4 (EntryGatingType) for changeValidatorRewardInfo must be a uint8
	assert
	btoi

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute changeValidatorRewardInfo(uint64,uint8,address,uint64[4],uint64,uint64)void
	callsub changeValidatorRewardInfo
	int 1
	return

// changeValidatorRewardInfo(validatorId: ValidatorIdType, EntryGatingType: uint8, EntryGatingAddress: Address, EntryGatingAssets: StaticArray<uint64, 4>, GatingAssetMinBalance: uint64, RewardPerPayout: uint64): void
//
// Allow the additional rewards (gating entry, additional token rewards) information be changed at will.
// [ ONLY OWNER CAN CHANGE ]
changeValidatorRewardInfo:
	proto 6 0

	// examples/reti/validatorRegistry.algo.ts:556
	// assert(
	//       this.txn.sender === this.validatorList(validatorId).value.config.owner,
	//       'can only be called by validator owner'
	//     )
	txn Sender
	int 8
	int 32
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	==

	// can only be called by validator owner
	assert

	// examples/reti/validatorRegistry.algo.ts:561
	// this.validatorList(validatorId).value.config.entryGatingType = EntryGatingType
	pushint 80
	frame_dig -2 // EntryGatingType: uint8
	itob
	extract 7 1
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:562
	// this.validatorList(validatorId).value.config.entryGatingAddress = EntryGatingAddress
	pushint 81
	frame_dig -3 // EntryGatingAddress: Address
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:563
	// this.validatorList(validatorId).value.config.entryGatingAssets = EntryGatingAssets
	pushint 113
	frame_dig -4 // EntryGatingAssets: StaticArray<uint64, 4>
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:564
	// this.validatorList(validatorId).value.config.gatingAssetMinBalance = GatingAssetMinBalance
	pushint 145
	frame_dig -5 // GatingAssetMinBalance: uint64
	itob
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:565
	// this.validatorList(validatorId).value.config.rewardPerPayout = RewardPerPayout
	pushint 161
	frame_dig -6 // RewardPerPayout: uint64
	itob
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace
	retsub

// addPool(pay,uint64,uint64)(uint64,uint64,uint64)
*abi_route_addPool:
	// The ABI return prefix
	byte 0x151f7c75

	// nodeNum: uint64
	txna ApplicationArgs 2
	btoi

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// mbrPayment: pay
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// argument 2 (mbrPayment) for addPool must be a pay transaction
	assert

	// execute addPool(pay,uint64,uint64)(uint64,uint64,uint64)
	callsub addPool
	concat
	log
	int 1
	return

// addPool(mbrPayment: PayTxn, validatorId: ValidatorIdType, nodeNum: uint64): ValidatorPoolKey
//
// Adds a new pool to a validator's pool set, returning the 'key' to reference the pool in the future for staking, etc.
// The caller must pay the cost of the validators MBR increase as well as the MBR that will be needed for the pool itself.
//
// [ ONLY OWNER OR MANAGER CAN call ]
// @param {PayTxn} mbrPayment payment from caller which covers mbr increase of adding a new pool
// @param {uint64} validatorId is id of validator to pool to (must be owner or manager)
// @param {uint64} nodeNum is node number to add to
// @returns {ValidatorPoolKey} pool key to created pool
addPool:
	proto 3 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// examples/reti/validatorRegistry.algo.ts:581
	// assert(
	//       this.txn.sender === this.validatorList(validatorId).value.config.owner ||
	//         this.txn.sender === this.validatorList(validatorId).value.config.manager,
	//       'can only be called by owner or manager of validator'
	//     )
	txn Sender
	int 8
	int 32
	byte 0x76 // "v"
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	==
	dup
	bnz *skip_or1
	txn Sender
	pushint 40
	int 32
	byte 0x76 // "v"
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	==
	||

*skip_or1:
	// can only be called by owner or manager of validator
	assert

	// examples/reti/validatorRegistry.algo.ts:588
	// verifyPayTxn(mbrPayment, { amount: this.getMbrAmounts().addPoolMbr, receiver: this.app.address })
	// verify amount
	frame_dig -1 // mbrPayment: PayTxn
	gtxns Amount
	callsub getMbrAmounts
	extract 8 8
	btoi
	==

	// transaction verification failed: {"txn":"mbrPayment","field":"amount","expected":"this.getMbrAmounts().addPoolMbr"}
	assert

	// verify receiver
	frame_dig -1 // mbrPayment: PayTxn
	gtxns Receiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"mbrPayment","field":"receiver","expected":"this.app.address"}
	assert

	// examples/reti/validatorRegistry.algo.ts:590
	// assert(this.validatorList(validatorId).exists, "specified validator id isn't valid")
	byte 0x76 // "v"
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	concat
	box_len
	swap
	pop

	// specified validator id isn't valid
	assert

	// examples/reti/validatorRegistry.algo.ts:592
	// numPools: uint64 = this.validatorList(validatorId).value.state.numPools as uint64
	int 242
	int 2
	byte 0x76 // "v"
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 0 // numPools: uint64

	// *if7_condition
	// examples/reti/validatorRegistry.algo.ts:593
	// (numPools as uint64) >= MAX_POOLS
	frame_dig 0 // numPools: uint64
	int 24
	>=
	bz *if7_end

	// *if7_consequent
	// already at max pool size
	err

*if7_end:
	// examples/reti/validatorRegistry.algo.ts:596
	// numPools += 1
	frame_dig 0 // numPools: uint64
	int 1
	+
	frame_bury 0 // numPools: uint64

	// examples/reti/validatorRegistry.algo.ts:599
	// sendAppCall({
	//       onCompletion: OnCompletion.NoOp,
	//       approvalProgram: [
	//         this.stakingPoolApprovalProgram.extract(0, 4096),
	//         this.stakingPoolApprovalProgram.extract(4096, this.stakingPoolApprovalProgram.size - 4096),
	//       ],
	//       clearStateProgram: StakingPool.clearProgram(),
	//       globalNumUint: StakingPool.schema.global.numUint,
	//       globalNumByteSlice: StakingPool.schema.global.numByteSlice,
	//       extraProgramPages: 3,
	//       applicationArgs: [
	//         // creatingContractID, validatorId, poolId, minEntryStake
	//         method('createApplication(uint64,uint64,uint64,uint64)void'),
	//         itob(this.app.id),
	//         itob(validatorId),
	//         itob(numPools as uint64),
	//         itob(this.validatorList(validatorId).value.config.minEntryStake),
	//       ],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum

	// examples/reti/validatorRegistry.algo.ts:600
	// onCompletion: OnCompletion.NoOp
	int 0 // NoOp
	itxn_field OnCompletion

	// examples/reti/validatorRegistry.algo.ts:601
	// approvalProgram: [
	//         this.stakingPoolApprovalProgram.extract(0, 4096),
	//         this.stakingPoolApprovalProgram.extract(4096, this.stakingPoolApprovalProgram.size - 4096),
	//       ]
	byte 0x706f6f6c54656d706c617465417070726f76616c4279746573 // "poolTemplateApprovalBytes"
	int 0
	pushint 4096
	box_extract
	itxn_field ApprovalProgramPages
	byte 0x706f6f6c54656d706c617465417070726f76616c4279746573 // "poolTemplateApprovalBytes"
	pushint 4096
	byte 0x706f6f6c54656d706c617465417070726f76616c4279746573 // "poolTemplateApprovalBytes"
	box_len

	// box value does not exist: this.stakingPoolApprovalProgram.size
	assert
	pushint 4096
	-
	box_extract
	itxn_field ApprovalProgramPages

	// examples/reti/validatorRegistry.algo.ts:605
	// clearStateProgram: StakingPool.clearProgram()
	pushbytes 0x0a
	itxn_field ClearStateProgram

	// examples/reti/validatorRegistry.algo.ts:606
	// globalNumUint: StakingPool.schema.global.numUint
	pushint 11
	itxn_field GlobalNumUint

	// examples/reti/validatorRegistry.algo.ts:607
	// globalNumByteSlice: StakingPool.schema.global.numByteSlice
	int 3
	itxn_field GlobalNumByteSlice

	// examples/reti/validatorRegistry.algo.ts:608
	// extraProgramPages: 3
	int 3
	itxn_field ExtraProgramPages

	// examples/reti/validatorRegistry.algo.ts:609
	// applicationArgs: [
	//         // creatingContractID, validatorId, poolId, minEntryStake
	//         method('createApplication(uint64,uint64,uint64,uint64)void'),
	//         itob(this.app.id),
	//         itob(validatorId),
	//         itob(numPools as uint64),
	//         itob(this.validatorList(validatorId).value.config.minEntryStake),
	//       ]
	pushbytes 0x59e90aa6 // method "createApplication(uint64,uint64,uint64,uint64)void"
	itxn_field ApplicationArgs
	txna Applications 0
	itob
	itxn_field ApplicationArgs
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	itxn_field ApplicationArgs
	frame_dig 0 // numPools: uint64
	itob
	itxn_field ApplicationArgs
	pushint 209
	int 8
	byte 0x76 // "v"
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/validatorRegistry.algo.ts:619
	// this.validatorList(validatorId).value.state.numPools = numPools as uint16
	int 242
	frame_dig 0 // numPools: uint64
	itob
	extract 6 2
	byte 0x76 // "v"
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:622
	// poolAppId = this.itxn.createdApplicationID.id
	itxn CreatedApplicationID
	frame_bury 1 // poolAppId: uint64

	// examples/reti/validatorRegistry.algo.ts:623
	// this.validatorList(validatorId).value.pools[numPools - 1].poolAppId = poolAppId
	int 268 // headOffset
	frame_dig 0 // numPools: uint64
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 0
	+
	frame_dig 1 // poolAppId: uint64
	itob
	byte 0x76 // "v"
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:624
	// this.addPoolToNode(validatorId, poolAppId, nodeNum)
	frame_dig -3 // nodeNum: uint64
	frame_dig 1 // poolAppId: uint64
	frame_dig -2 // validatorId: ValidatorIdType
	callsub addPoolToNode

	// examples/reti/validatorRegistry.algo.ts:632
	// return { id: validatorId, poolId: numPools as uint64, poolAppId: this.itxn!.createdApplicationID.id };
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	frame_dig 0 // numPools: uint64
	itob
	concat
	itxn CreatedApplicationID
	itob
	concat

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 1
	retsub

// addStake(pay,uint64,uint64)(uint64,uint64,uint64)
*abi_route_addStake:
	// The ABI return prefix
	byte 0x151f7c75

	// valueToVerify: uint64
	txna ApplicationArgs 2
	btoi

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// stakedAmountPayment: pay
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// argument 2 (stakedAmountPayment) for addStake must be a pay transaction
	assert

	// execute addStake(pay,uint64,uint64)(uint64,uint64,uint64)
	callsub addStake
	concat
	log
	int 1
	return

// addStake(stakedAmountPayment: PayTxn, validatorId: ValidatorIdType, valueToVerify: uint64): ValidatorPoolKey
//
// Adds stake to a validator pool.
//
// @param {PayTxn} stakedAmountPayment - payment coming from staker to place into a pool
// @param {ValidatorIdType} validatorId - The id of the validator.
// @param {uint64} valueToVerify - only if validator has gating to enter - this is asset id or nfd id that corresponds to gating.
// Txn sender is factored in as well if that is part of gating.
// * @returns {ValidatorPoolKey} - The key of the validator pool.
addStake:
	proto 3 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 5

	// examples/reti/validatorRegistry.algo.ts:645
	// assert(this.validatorList(validatorId).exists, "specified validator id isn't valid")
	byte 0x76 // "v"
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	concat
	box_len
	swap
	pop

	// specified validator id isn't valid
	assert

	// *if8_condition
	// examples/reti/validatorRegistry.algo.ts:648
	// this.validatorList(validatorId).value.config.sunsettingOn > 0
	pushint 226
	int 8
	byte 0x76 // "v"
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	int 0
	>
	bz *if8_end

	// *if8_consequent
	// examples/reti/validatorRegistry.algo.ts:649
	// assert(
	//         this.validatorList(validatorId).value.config.sunsettingOn < globals.latestTimestamp,
	//         "can't stake with a validator that is past its sunsetting time"
	//       )
	pushint 226
	int 8
	byte 0x76 // "v"
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	global LatestTimestamp
	<

	// can't stake with a validator that is past its sunsetting time
	assert

*if8_end:
	// examples/reti/validatorRegistry.algo.ts:655
	// staker = this.txn.sender
	txn Sender
	frame_bury 0 // staker: address

	// examples/reti/validatorRegistry.algo.ts:659
	// verifyPayTxn(stakedAmountPayment, {
	//       sender: staker,
	//       receiver: this.app.address,
	//     })
	// verify sender
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Sender
	frame_dig 0 // staker: address
	==

	// transaction verification failed: {"txn":"stakedAmountPayment","field":"sender","expected":"staker"}
	assert

	// verify receiver
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Receiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"stakedAmountPayment","field":"receiver","expected":"this.app.address"}
	assert

	// examples/reti/validatorRegistry.algo.ts:666
	// assert(
	//       this.validatorList(validatorId).value.state.totalAlgoStaked < this.maxAllowedStake(),
	//       'total staked for all of a validators pools may not exceed hard cap'
	//     )
	int 252
	int 8
	byte 0x76 // "v"
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	callsub maxAllowedStake
	<

	// total staked for all of a validators pools may not exceed hard cap
	assert

	// examples/reti/validatorRegistry.algo.ts:673
	// this.doesStakerMeetGating(validatorId, valueToVerify)
	frame_dig -3 // valueToVerify: uint64
	frame_dig -2 // validatorId: ValidatorIdType
	callsub doesStakerMeetGating

	// examples/reti/validatorRegistry.algo.ts:675
	// realAmount = stakedAmountPayment.amount
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Amount
	frame_bury 1 // realAmount: uint64

	// examples/reti/validatorRegistry.algo.ts:676
	// mbrAmtLeftBehind: uint64 = 0
	int 0
	frame_bury 2 // mbrAmtLeftBehind: uint64

	// *if9_condition
	// examples/reti/validatorRegistry.algo.ts:678
	// !this.stakerPoolSet(staker).exists
	byte 0x737073 // "sps"
	frame_dig 0 // staker: address
	concat
	box_len
	swap
	pop
	!
	bz *if9_end

	// *if9_consequent
	// examples/reti/validatorRegistry.algo.ts:681
	// mbrAmtLeftBehind = this.getMbrAmounts().addStakerMbr
	callsub getMbrAmounts
	extract 24 8
	btoi
	frame_bury 2 // mbrAmtLeftBehind: uint64

	// examples/reti/validatorRegistry.algo.ts:682
	// realAmount -= mbrAmtLeftBehind
	frame_dig 1 // realAmount: uint64
	frame_dig 2 // mbrAmtLeftBehind: uint64
	-
	frame_bury 1 // realAmount: uint64

	// examples/reti/validatorRegistry.algo.ts:683
	// this.stakerPoolSet(staker).create()
	byte 0x737073 // "sps"
	frame_dig 0 // staker: address
	concat
	pushint 144
	box_create
	pop

*if9_end:
	// examples/reti/validatorRegistry.algo.ts:687
	// findRet = this.findPoolForStaker(validatorId, staker, realAmount)
	frame_dig 1 // realAmount: uint64
	frame_dig 0 // staker: address
	frame_dig -2 // validatorId: ValidatorIdType
	callsub findPoolForStaker
	frame_bury 3 // findRet: ((uint64,uint64,uint64),bool,bool)

	// examples/reti/validatorRegistry.algo.ts:688
	// poolKey = findRet[0]
	// examples/reti/validatorRegistry.algo.ts:689
	// isNewStakerToValidator = findRet[1]
	frame_dig 3 // findRet: ((uint64,uint64,uint64),bool,bool)
	store 255 // full array
	load 255 // full array
	pushint 192
	getbit
	frame_bury 4 // isNewStakerToValidator: bool

	// examples/reti/validatorRegistry.algo.ts:690
	// isNewStakerToProtocol = findRet[2]
	frame_dig 3 // findRet: ((uint64,uint64,uint64),bool,bool)
	store 255 // full array
	load 255 // full array
	pushint 193
	getbit
	frame_bury 5 // isNewStakerToProtocol: bool

	// *if10_condition
	// examples/reti/validatorRegistry.algo.ts:691
	// poolKey.poolId === 0
	frame_dig 3 // findRet: ((uint64,uint64,uint64),bool,bool)
	store 255 // full array
	load 255 // full array
	extract 8 8
	btoi
	int 0
	==
	bz *if10_end

	// *if10_consequent
	// No pool available with free stake.  Validator needs to add another pool
	err

*if10_end:
	// examples/reti/validatorRegistry.algo.ts:696
	// this.updateStakerPoolSet(staker, poolKey)
	frame_dig 3 // findRet: ((uint64,uint64,uint64),bool,bool)
	store 255 // full array
	load 255 // full array
	extract 0 24
	frame_dig 0 // staker: address
	callsub updateStakerPoolSet

	// examples/reti/validatorRegistry.algo.ts:699
	// this.callPoolAddStake(
	//       stakedAmountPayment,
	//       poolKey,
	//       mbrAmtLeftBehind,
	//       isNewStakerToValidator,
	//       isNewStakerToProtocol
	//     )
	frame_dig 5 // isNewStakerToProtocol: bool
	frame_dig 4 // isNewStakerToValidator: bool
	frame_dig 2 // mbrAmtLeftBehind: uint64
	frame_dig 3 // findRet: ((uint64,uint64,uint64),bool,bool)
	store 255 // full array
	load 255 // full array
	extract 0 24
	frame_dig -1 // stakedAmountPayment: PayTxn
	callsub callPoolAddStake

	// examples/reti/validatorRegistry.algo.ts:714
	// return poolKey;
	frame_dig 3 // findRet: ((uint64,uint64,uint64),bool,bool)
	store 255 // full array
	load 255 // full array
	extract 0 24

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 5
	retsub

// setTokenPayoutRatio(uint64)(uint64[24],uint64)
*abi_route_setTokenPayoutRatio:
	// The ABI return prefix
	byte 0x151f7c75

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute setTokenPayoutRatio(uint64)(uint64[24],uint64)
	callsub setTokenPayoutRatio
	concat
	log
	int 1
	return

// setTokenPayoutRatio(validatorId: ValidatorIdType): PoolTokenPayoutRatio
//
// setTokenPayoutRatio is called by Staking Pool # 1 (ONLY) to ask the validator (us) to calculate the ratios
// of stake in the pools for subsequent token payouts (ie: 2 pools, '100' algo total staked, 60 in pool 1, and 40
// in pool 2)  This is done so we have a stable snapshot of stake - taken once per epoch - only triggered by
// pool 1 doing payout.  pools other than 1 doing payout call pool 1 to ask it do it first.
// It would be 60/40% in the poolPctOfWhole values.  The token reward payouts then use these values instead of
// their 'current' stake which changes as part of the payouts themselves (and people could be changing stake
// during the epoch updates across pools)
//
// Multiple pools will call us via pool 1 (pool2->pool1->validator, etc.) so don't assert on pool1 calling multiple
// times in same epoch.  Just return.
//
// @param validatorId - validator id (and thus pool) calling us.  Verified so that sender MUST be pool 1 of this validator.
// @returns PoolTokenPayoutRatio - the finished ratio data
setTokenPayoutRatio:
	proto 1 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 8

	// examples/reti/validatorRegistry.algo.ts:734
	// pool1AppID = this.validatorList(validatorId).value.pools[0].poolAppId
	int 268
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 0 // pool1AppID: uint64

	// examples/reti/validatorRegistry.algo.ts:735
	// assert(pool1AppID !== 0)
	frame_dig 0 // pool1AppID: uint64
	int 0
	!=
	assert

	// *if11_condition
	// examples/reti/validatorRegistry.algo.ts:737
	// this.txn.sender !== AppID.fromUint64(pool1AppID).address
	txn Sender
	frame_dig 0 // pool1AppID: uint64
	app_params_get AppAddress
	pop
	!=
	bz *if11_end

	// *if11_consequent
	// examples/reti/validatorRegistry.algo.ts:738
	// return this.validatorList(validatorId).value.tokenPayoutRatio;
	int 700 // headOffset
	pushint 200
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	b *setTokenPayoutRatio*return

*if11_end:
	// examples/reti/validatorRegistry.algo.ts:744
	// curRound = globals.round
	global Round
	frame_bury 1 // curRound: uint64

	// examples/reti/validatorRegistry.algo.ts:745
	// lastPayoutUpdate = this.validatorList(validatorId).value.tokenPayoutRatio.updatedForPayout
	pushint 892
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 2 // lastPayoutUpdate: uint64

	// *if12_condition
	// examples/reti/validatorRegistry.algo.ts:746
	// lastPayoutUpdate !== 0
	frame_dig 2 // lastPayoutUpdate: uint64
	int 0
	!=
	bz *if12_end

	// *if12_consequent
	// *if13_condition
	// examples/reti/validatorRegistry.algo.ts:748
	// (AppID.fromUint64(pool1AppID).globalState('lastPayout') as uint64) === lastPayoutUpdate
	frame_dig 0 // pool1AppID: uint64
	pushbytes 0x6c6173745061796f7574 // "lastPayout"
	app_global_get_ex

	// global state value does not exist: AppID.fromUint64(pool1AppID).globalState('lastPayout')
	assert
	frame_dig 2 // lastPayoutUpdate: uint64
	==
	bz *if13_end

	// *if13_consequent
	// examples/reti/validatorRegistry.algo.ts:749
	// return this.validatorList(validatorId).value.tokenPayoutRatio;
	int 700 // headOffset
	pushint 200
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	b *setTokenPayoutRatio*return

*if13_end:
	// examples/reti/validatorRegistry.algo.ts:751
	// epochRoundLength = this.validatorList(validatorId).value.config.epochRoundLength as uint64
	pushint 169
	pushint 4
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 3 // epochRoundLength: uint64

	// examples/reti/validatorRegistry.algo.ts:752
	// thisEpochBegin = curRound - (curRound % epochRoundLength)
	frame_dig 1 // curRound: uint64
	frame_dig 1 // curRound: uint64
	frame_dig 3 // epochRoundLength: uint64
	%
	-
	frame_bury 4 // thisEpochBegin: uint64

	// *if14_condition
	// examples/reti/validatorRegistry.algo.ts:754
	// lastPayoutUpdate - (lastPayoutUpdate % epochRoundLength) === thisEpochBegin
	frame_dig 2 // lastPayoutUpdate: uint64
	frame_dig 2 // lastPayoutUpdate: uint64
	frame_dig 3 // epochRoundLength: uint64
	%
	-
	frame_dig 4 // thisEpochBegin: uint64
	==
	bz *if14_end

	// *if14_consequent
	// examples/reti/validatorRegistry.algo.ts:755
	// return this.validatorList(validatorId).value.tokenPayoutRatio;
	int 700 // headOffset
	pushint 200
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	b *setTokenPayoutRatio*return

*if14_end:

*if12_end:
	// examples/reti/validatorRegistry.algo.ts:758
	// this.validatorList(validatorId).value.tokenPayoutRatio.updatedForPayout = curRound
	pushint 892
	frame_dig 1 // curRound: uint64
	itob
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:760
	// curNumPools = this.validatorList(validatorId).value.state.numPools as uint64
	int 242
	int 2
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 5 // curNumPools: uint64

	// examples/reti/validatorRegistry.algo.ts:761
	// totalStakeForValidator = this.validatorList(validatorId).value.state.totalAlgoStaked
	int 252
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 6 // totalStakeForValidator: uint64

	// examples/reti/validatorRegistry.algo.ts:762
	// for (let i = 0; i < curNumPools; i += 1)
	int 0
	frame_bury 7 // i: uint64

*for_2:
	// examples/reti/validatorRegistry.algo.ts:762
	// i < curNumPools
	frame_dig 7 // i: uint64
	frame_dig 5 // curNumPools: uint64
	<
	bz *for_2_end

	// examples/reti/validatorRegistry.algo.ts:767
	// ourPoolPctOfWhole = wideRatio(
	//         [this.validatorList(validatorId).value.pools[i].totalAlgoStaked, 1_000_000],
	//         [totalStakeForValidator]
	//       )
	int 268 // headOffset
	frame_dig 7 // i: uint64
	int 18
	* // acc * typeLength
	+
	int 10 // headOffset
	+
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	pushint 1_000_000
	mulw
	int 0
	frame_dig 6 // totalStakeForValidator: uint64
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	frame_bury 8 // ourPoolPctOfWhole: uint64

	// examples/reti/validatorRegistry.algo.ts:771
	// this.validatorList(validatorId).value.tokenPayoutRatio.poolPctOfWhole[i] = ourPoolPctOfWhole
	int 700
	frame_dig 7 // i: uint64
	int 8
	* // acc * typeLength
	+
	frame_dig 8 // ourPoolPctOfWhole: uint64
	itob
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace

*for_2_continue:
	// examples/reti/validatorRegistry.algo.ts:762
	// i += 1
	frame_dig 7 // i: uint64
	int 1
	+
	frame_bury 7 // i: uint64
	b *for_2

*for_2_end:
	// examples/reti/validatorRegistry.algo.ts:773
	// return this.validatorList(validatorId).value.tokenPayoutRatio;
	int 700 // headOffset
	pushint 200
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract

*setTokenPayoutRatio*return:
	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 8
	retsub

// stakeUpdatedViaRewards((uint64,uint64,uint64),uint64,uint64,uint64,uint64)void
*abi_route_stakeUpdatedViaRewards:
	// saturatedBurnToFeeSink: uint64
	txna ApplicationArgs 5
	btoi

	// validatorCommission: uint64
	txna ApplicationArgs 4
	btoi

	// rewardTokenAmountReserved: uint64
	txna ApplicationArgs 3
	btoi

	// algoToAdd: uint64
	txna ApplicationArgs 2
	btoi

	// poolKey: (uint64,uint64,uint64)
	txna ApplicationArgs 1
	dup
	len
	int 24
	==

	// argument 4 (poolKey) for stakeUpdatedViaRewards must be a (uint64,uint64,uint64)
	assert

	// execute stakeUpdatedViaRewards((uint64,uint64,uint64),uint64,uint64,uint64,uint64)void
	callsub stakeUpdatedViaRewards
	int 1
	return

// stakeUpdatedViaRewards(poolKey: ValidatorPoolKey, algoToAdd: uint64, rewardTokenAmountReserved: uint64, validatorCommission: uint64, saturatedBurnToFeeSink: uint64): void
//
// stakeUpdatedViaRewards is called by Staking pools to inform the validator (us) that a particular amount of total
// stake has been added to the specified pool.  This is used to update the stats we have in our PoolInfo storage.
// The calling App id is validated against our pool list as well.
// @param {ValidatorPoolKey} poolKey - ValidatorPoolKey type
// @param {uint64} algoToAdd - amount this validator's total stake increased via rewards
// @param {uint64} rewardTokenAmountReserved - amount this validator's total stake increased via rewards (that should be
// @param {uint64} validatorCommission - the commission amount the validator was paid, if any
// @param {uint64} saturatedBurnToFeeSink - if the pool was in saturated state, the amount sent back to the fee sink.
// seen as 'accounted for/pending spent')
stakeUpdatedViaRewards:
	proto 5 0

	// examples/reti/validatorRegistry.algo.ts:794
	// this.verifyPoolKeyCaller(poolKey)
	frame_dig -1 // poolKey: ValidatorPoolKey
	callsub verifyPoolKeyCaller

	// examples/reti/validatorRegistry.algo.ts:797
	// this.validatorList(poolKey.id).value.pools[poolKey.poolId - 1].totalAlgoStaked += algoToAdd
	int 268 // headOffset
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 10 // headOffset
	+
	int 268 // headOffset
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 10 // headOffset
	+
	int 8
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_dig -2 // algoToAdd: uint64
	+
	itob
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:798
	// this.validatorList(poolKey.id).value.state.totalAlgoStaked += algoToAdd
	int 252
	dup
	int 8
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_dig -2 // algoToAdd: uint64
	+
	itob
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:799
	// this.validatorList(poolKey.id).value.state.rewardTokenHeldBack += rewardTokenAmountReserved
	int 260
	dup
	int 8
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_dig -3 // rewardTokenAmountReserved: uint64
	+
	itob
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:801
	// this.totalAlgoStaked.value += algoToAdd
	byte 0x7374616b6564 // "staked"
	app_global_get
	frame_dig -2 // algoToAdd: uint64
	+
	byte 0x7374616b6564 // "staked"
	swap
	app_global_put

	// examples/reti/validatorRegistry.algo.ts:804
	// this.reverifyNFDOwnership(poolKey.id)
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	callsub reverifyNFDOwnership
	retsub

// stakeRemoved((uint64,uint64,uint64),address,uint64,uint64,bool)void
*abi_route_stakeRemoved:
	// stakerRemoved: bool
	txna ApplicationArgs 5
	dup
	len
	int 1
	==

	// argument 0 (stakerRemoved) for stakeRemoved must be a bool
	assert
	int 0
	getbit

	// rewardRemoved: uint64
	txna ApplicationArgs 4
	btoi

	// amountRemoved: uint64
	txna ApplicationArgs 3
	btoi

	// staker: address
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 3 (staker) for stakeRemoved must be a address
	assert

	// poolKey: (uint64,uint64,uint64)
	txna ApplicationArgs 1
	dup
	len
	int 24
	==

	// argument 4 (poolKey) for stakeRemoved must be a (uint64,uint64,uint64)
	assert

	// execute stakeRemoved((uint64,uint64,uint64),address,uint64,uint64,bool)void
	callsub stakeRemoved
	int 1
	return

// stakeRemoved(poolKey: ValidatorPoolKey, staker: Address, amountRemoved: uint64, rewardRemoved: uint64, stakerRemoved: boolean): void
//
// stakeRemoved is called by Staking pools to inform the validator (us) that a particular amount of total stake has been removed
// from the specified pool.  This is used to update the stats we have in our PoolInfo storage.
// If any amount of rewardRemoved is specified, then that amount of reward is sent to the use
// The calling App id is validated against our pool list as well.
//
// @param {ValidatorPoolKey} poolKey calling us from which stake was removed
// @param {Address} staker
// @param {uint64} amountRemoved - algo amount removed
// @param {uint64} rewardRemoved - if applicable, amount of token reward removed (by pool 1 caller) or TO remove and pay out (via pool 1 from different pool caller)
// @param {boolean} stakerRemoved
stakeRemoved:
	proto 5 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 3

	// *if15_condition
	// examples/reti/validatorRegistry.algo.ts:836
	// globals.opcodeBudget < 300
	global OpcodeBudget
	pushint 300
	<
	bz *if15_end

	// *if15_consequent
	// examples/reti/validatorRegistry.algo.ts:837
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	pushint 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

*if15_end:
	// examples/reti/validatorRegistry.algo.ts:839
	// this.verifyPoolKeyCaller(poolKey)
	frame_dig -1 // poolKey: ValidatorPoolKey
	callsub verifyPoolKeyCaller

	// examples/reti/validatorRegistry.algo.ts:843
	// assert(amountRemoved > 0 || rewardRemoved > 0, 'should only be called if algo or reward was removed')
	frame_dig -3 // amountRemoved: uint64
	int 0
	>
	dup
	bnz *skip_or2
	frame_dig -4 // rewardRemoved: uint64
	int 0
	>
	||

*skip_or2:
	// should only be called if algo or reward was removed
	assert

	// examples/reti/validatorRegistry.algo.ts:846
	// this.validatorList(poolKey.id).value.pools[poolKey.poolId - 1].totalAlgoStaked -= amountRemoved
	int 268 // headOffset
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 10 // headOffset
	+
	int 268 // headOffset
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 10 // headOffset
	+
	int 8
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_dig -3 // amountRemoved: uint64
	-
	itob
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:847
	// this.validatorList(poolKey.id).value.state.totalAlgoStaked -= amountRemoved
	int 252
	dup
	int 8
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_dig -3 // amountRemoved: uint64
	-
	itob
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:848
	// this.totalAlgoStaked.value -= amountRemoved
	byte 0x7374616b6564 // "staked"
	app_global_get
	frame_dig -3 // amountRemoved: uint64
	-
	byte 0x7374616b6564 // "staked"
	swap
	app_global_put

	// *if16_condition
	// examples/reti/validatorRegistry.algo.ts:850
	// rewardRemoved > 0
	frame_dig -4 // rewardRemoved: uint64
	int 0
	>
	bz *if16_else

	// *if16_consequent
	// examples/reti/validatorRegistry.algo.ts:851
	// rewardTokenID = this.validatorList(poolKey.id).value.config.rewardTokenId
	pushint 153
	int 8
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 0 // rewardTokenID: uint64

	// examples/reti/validatorRegistry.algo.ts:852
	// assert(rewardTokenID !== 0, "rewardRemoved can't be set if validator doesn't have reward token!")
	frame_dig 0 // rewardTokenID: uint64
	int 0
	!=

	// rewardRemoved can't be set if validator doesn't have reward token!
	assert

	// examples/reti/validatorRegistry.algo.ts:853
	// assert(
	//         this.validatorList(poolKey.id).value.state.rewardTokenHeldBack >= rewardRemoved,
	//         'reward being removed must be covered by hold back amount'
	//       )
	int 260
	int 8
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_dig -4 // rewardRemoved: uint64
	>=

	// reward being removed must be covered by hold back amount
	assert

	// examples/reti/validatorRegistry.algo.ts:859
	// this.validatorList(poolKey.id).value.state.rewardTokenHeldBack -= rewardRemoved
	int 260
	dup
	int 8
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_dig -4 // rewardRemoved: uint64
	-
	itob
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_replace

	// *if17_condition
	// examples/reti/validatorRegistry.algo.ts:864
	// poolKey.poolId !== 1
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	!=
	bz *if17_end

	// *if17_consequent
	// examples/reti/validatorRegistry.algo.ts:865
	// sendMethodCall<typeof StakingPool.prototype.payTokenReward>({
	//           applicationID: AppID.fromUint64(this.validatorList(poolKey.id).value.pools[0].poolAppId),
	//           methodArgs: [staker, rewardTokenID, rewardRemoved],
	//         })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0x63f3f28b // method "payTokenReward(address,uint64,uint64)void"
	itxn_field ApplicationArgs

	// examples/reti/validatorRegistry.algo.ts:866
	// applicationID: AppID.fromUint64(this.validatorList(poolKey.id).value.pools[0].poolAppId)
	int 268
	int 8
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	itxn_field ApplicationID

	// examples/reti/validatorRegistry.algo.ts:867
	// methodArgs: [staker, rewardTokenID, rewardRemoved]
	frame_dig -2 // staker: Address
	itxn_field ApplicationArgs
	frame_dig 0 // rewardTokenID: uint64
	itob
	itxn_field ApplicationArgs
	frame_dig -4 // rewardRemoved: uint64
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

*if17_end:
	b *if16_end

*if16_else:

*if16_end:
	// *if18_condition
	// examples/reti/validatorRegistry.algo.ts:892
	// stakerRemoved
	frame_dig -5 // stakerRemoved: boolean
	bz *if18_end

	// *if18_consequent
	// examples/reti/validatorRegistry.algo.ts:894
	// this.validatorList(poolKey.id).value.pools[poolKey.poolId - 1].totalStakers -= 1
	int 268 // headOffset
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 8 // headOffset
	+
	int 268 // headOffset
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 8 // headOffset
	+
	int 2
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	int 1
	-
	itob
	extract 6 2
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:896
	// removeRet = this.removeFromStakerPoolSet(staker, <ValidatorPoolKey>{
	//         id: poolKey.id,
	//         poolId: poolKey.poolId,
	//         poolAppId: poolKey.poolAppId,
	//       })
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	itob
	concat
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 16 8
	btoi
	itob
	concat
	frame_dig -2 // staker: Address
	callsub removeFromStakerPoolSet
	frame_bury 1 // removeRet: (bool,bool)

	// examples/reti/validatorRegistry.algo.ts:901
	// stakerOutOfThisValidator = removeRet[0]
	frame_dig 1 // removeRet: (bool,bool)
	store 255 // full array
	load 255 // full array
	int 0
	getbit
	frame_bury 2 // stakerOutOfThisValidator: bool

	// examples/reti/validatorRegistry.algo.ts:902
	// stakerOutOfProtocol = removeRet[1]
	frame_dig 1 // removeRet: (bool,bool)
	store 255 // full array
	load 255 // full array
	int 1
	getbit
	frame_bury 3 // stakerOutOfProtocol: bool

	// *if19_condition
	// examples/reti/validatorRegistry.algo.ts:904
	// stakerOutOfThisValidator
	frame_dig 2 // stakerOutOfThisValidator: bool
	bz *if19_end

	// *if19_consequent
	// examples/reti/validatorRegistry.algo.ts:905
	// this.validatorList(poolKey.id).value.state.totalStakers -= 1
	pushint 244
	pushint 244
	int 8
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	int 1
	-
	itob
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_replace

*if19_end:
	// *if20_condition
	// examples/reti/validatorRegistry.algo.ts:908
	// stakerOutOfProtocol
	frame_dig 3 // stakerOutOfProtocol: bool
	bz *if20_end

	// *if20_consequent
	// examples/reti/validatorRegistry.algo.ts:909
	// this.numStakers.value -= 1
	byte 0x6e756d5374616b657273 // "numStakers"
	app_global_get
	int 1
	-
	byte 0x6e756d5374616b657273 // "numStakers"
	swap
	app_global_put

*if20_end:

*if18_end:
	retsub

// findPoolForStaker(uint64,address,uint64)((uint64,uint64,uint64),bool,bool)
*abi_route_findPoolForStaker:
	// The ABI return prefix
	byte 0x151f7c75

	// amountToStake: uint64
	txna ApplicationArgs 3
	btoi

	// staker: address
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 1 (staker) for findPoolForStaker must be a address
	assert

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute findPoolForStaker(uint64,address,uint64)((uint64,uint64,uint64),bool,bool)
	callsub findPoolForStaker
	concat
	log
	int 1
	return

// findPoolForStaker(validatorId: ValidatorIdType, staker: Address, amountToStake: uint64): [ValidatorPoolKey, boolean, boolean]
//
// Finds the pool for a staker based on the provided validator id, staker address, and amount to stake.
// First checks the stakers 'already staked list' for the validator preferring those (adding if possible) then adds
// to new pool if necessary.
//
// @param {ValidatorIdType} validatorId - The id of the validator.
// @param {Address} staker - The address of the staker.
// @param {uint64} amountToStake - The amount to stake.
// @returns {ValidatorPoolKey, boolean, boolean} - The pool for the staker, true/false on whether the staker is 'new'
// to this VALIDATOR, and true/false if staker is new to the protocol.
findPoolForStaker:
	proto 3 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 7

	// examples/reti/validatorRegistry.algo.ts:930
	// isNewStakerToValidator = true
	int 1
	frame_bury 0 // isNewStakerToValidator: bool

	// examples/reti/validatorRegistry.algo.ts:931
	// isNewStakerToProtocol = true
	int 1
	frame_bury 1 // isNewStakerToProtocol: bool

	// examples/reti/validatorRegistry.algo.ts:939
	// maxPerPool = this.getCurMaxStakePerPool(validatorId)
	frame_dig -1 // validatorId: ValidatorIdType
	callsub getCurMaxStakePerPool
	frame_bury 2 // maxPerPool: uint64

	// *if21_condition
	// examples/reti/validatorRegistry.algo.ts:942
	// this.stakerPoolSet(staker).exists
	byte 0x737073 // "sps"
	frame_dig -2 // staker: Address
	concat
	box_len
	swap
	pop
	bz *if21_end

	// *if21_consequent
	// examples/reti/validatorRegistry.algo.ts:943
	// poolSet = clone(this.stakerPoolSet(staker).value)
	byte 0x737073 // "sps"
	frame_dig -2 // staker: Address
	concat
	box_get

	// box value does not exist: this.stakerPoolSet(staker).value
	assert
	frame_bury 3 // poolSet: (uint64,uint64,uint64)[6]

	// examples/reti/validatorRegistry.algo.ts:944
	// assert(validatorId !== 0)
	frame_dig -1 // validatorId: ValidatorIdType
	int 0
	!=
	assert

	// examples/reti/validatorRegistry.algo.ts:945
	// for (let i = 0; i < poolSet.length; i += 1)
	int 0
	frame_bury 4 // i: uint64

*for_3:
	// examples/reti/validatorRegistry.algo.ts:945
	// i < poolSet.length
	frame_dig 4 // i: uint64
	int 6
	<
	bz *for_3_end

	// *if22_condition
	// examples/reti/validatorRegistry.algo.ts:946
	// globals.opcodeBudget < 300
	global OpcodeBudget
	pushint 300
	<
	bz *if22_end

	// *if22_consequent
	// examples/reti/validatorRegistry.algo.ts:947
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	pushint 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

*if22_end:
	// *if23_condition
	// examples/reti/validatorRegistry.algo.ts:949
	// poolSet[i].id === 0
	frame_dig 3 // poolSet: (uint64,uint64,uint64)[6]
	frame_dig 4 // i: uint64
	int 24
	* // acc * typeLength
	int 0
	+
	int 8
	extract3
	btoi
	int 0
	==
	bz *if23_end

	// *if23_consequent
	b *for_3_continue

*if23_end:
	// examples/reti/validatorRegistry.algo.ts:952
	// isNewStakerToProtocol = false
	int 0
	frame_bury 1 // isNewStakerToProtocol: bool

	// *if24_condition
	// examples/reti/validatorRegistry.algo.ts:953
	// poolSet[i].id === validatorId
	frame_dig 3 // poolSet: (uint64,uint64,uint64)[6]
	frame_dig 4 // i: uint64
	int 24
	* // acc * typeLength
	int 0
	+
	int 8
	extract3
	btoi
	frame_dig -1 // validatorId: ValidatorIdType
	==
	bz *if24_end

	// *if24_consequent
	// examples/reti/validatorRegistry.algo.ts:955
	// isNewStakerToValidator = false
	int 0
	frame_bury 0 // isNewStakerToValidator: bool

	// *if25_condition
	// examples/reti/validatorRegistry.algo.ts:957
	// this.validatorList(validatorId).value.pools[poolSet[i].poolId - 1].totalAlgoStaked + amountToStake <=
	//             maxPerPool
	int 268 // headOffset
	frame_dig 3 // poolSet: (uint64,uint64,uint64)[6]
	frame_dig 4 // i: uint64
	int 24
	* // acc * typeLength
	int 8 // headOffset
	+
	int 8
	extract3
	btoi
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 10 // headOffset
	+
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_dig -3 // amountToStake: uint64
	+
	frame_dig 2 // maxPerPool: uint64
	<=
	bz *if25_end

	// *if25_consequent
	// examples/reti/validatorRegistry.algo.ts:960
	// return [poolSet[i], isNewStakerToValidator, isNewStakerToProtocol];
	frame_dig 3 // poolSet: (uint64,uint64,uint64)[6]
	frame_dig 4 // i: uint64
	int 24
	* // acc * typeLength
	int 24
	extract3
	byte 0x00
	int 0
	frame_dig 0 // isNewStakerToValidator: bool
	setbit
	int 1
	frame_dig 1 // isNewStakerToProtocol: bool
	setbit
	concat
	b *findPoolForStaker*return

*if25_end:

*if24_end:

*for_3_continue:
	// examples/reti/validatorRegistry.algo.ts:945
	// i += 1
	frame_dig 4 // i: uint64
	int 1
	+
	frame_bury 4 // i: uint64
	b *for_3

*for_3_end:

*if21_end:
	// examples/reti/validatorRegistry.algo.ts:967
	// assert(
	//       amountToStake >= this.validatorList(validatorId).value.config.minEntryStake,
	//       'must stake at least the minimum for this pool'
	//     )
	frame_dig -3 // amountToStake: uint64
	pushint 209
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	>=

	// must stake at least the minimum for this pool
	assert

	// examples/reti/validatorRegistry.algo.ts:973
	// pools = clone(this.validatorList(validatorId).value.pools)
	int 268 // headOffset
	pushint 432
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	frame_bury 5 // pools: (uint64,uint16,uint64)[24]

	// examples/reti/validatorRegistry.algo.ts:974
	// curNumPools = this.validatorList(validatorId).value.state.numPools as uint64
	int 242
	int 2
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 6 // curNumPools: uint64

	// examples/reti/validatorRegistry.algo.ts:975
	// for (let i = 0; i < curNumPools; i += 1)
	int 0
	frame_bury 7 // i: uint64

*for_4:
	// examples/reti/validatorRegistry.algo.ts:975
	// i < curNumPools
	frame_dig 7 // i: uint64
	frame_dig 6 // curNumPools: uint64
	<
	bz *for_4_end

	// *if26_condition
	// examples/reti/validatorRegistry.algo.ts:976
	// pools[i].totalAlgoStaked + amountToStake <= maxPerPool
	frame_dig 5 // pools: (uint64,uint16,uint64)[24]
	frame_dig 7 // i: uint64
	int 18
	* // acc * typeLength
	int 10 // headOffset
	+
	int 8
	extract3
	btoi
	frame_dig -3 // amountToStake: uint64
	+
	frame_dig 2 // maxPerPool: uint64
	<=
	bz *if26_end

	// *if26_consequent
	// examples/reti/validatorRegistry.algo.ts:977
	// return [
	//           { id: validatorId, poolId: i + 1, poolAppId: pools[i].poolAppId },
	//           isNewStakerToValidator,
	//           isNewStakerToProtocol,
	//         ];
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	frame_dig 7 // i: uint64
	int 1
	+
	itob
	concat
	frame_dig 5 // pools: (uint64,uint16,uint64)[24]
	frame_dig 7 // i: uint64
	int 18
	* // acc * typeLength
	int 0
	+
	int 8
	extract3
	btoi
	itob
	concat
	byte 0x00
	int 0
	frame_dig 0 // isNewStakerToValidator: bool
	setbit
	int 1
	frame_dig 1 // isNewStakerToProtocol: bool
	setbit
	concat
	b *findPoolForStaker*return

*if26_end:

*for_4_continue:
	// examples/reti/validatorRegistry.algo.ts:975
	// i += 1
	frame_dig 7 // i: uint64
	int 1
	+
	frame_bury 7 // i: uint64
	b *for_4

*for_4_end:
	// examples/reti/validatorRegistry.algo.ts:985
	// return [{ id: validatorId, poolId: 0, poolAppId: 0 }, isNewStakerToValidator, isNewStakerToProtocol];
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	byte 0x0000000000000000
	concat
	byte 0x0000000000000000
	concat
	byte 0x00
	int 0
	frame_dig 0 // isNewStakerToValidator: bool
	setbit
	int 1
	frame_dig 1 // isNewStakerToProtocol: bool
	setbit
	concat

*findPoolForStaker*return:
	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 7
	retsub

// movePoolToNode(uint64,uint64,uint64)void
*abi_route_movePoolToNode:
	// nodeNum: uint64
	txna ApplicationArgs 3
	btoi

	// poolAppId: uint64
	txna ApplicationArgs 2
	btoi

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute movePoolToNode(uint64,uint64,uint64)void
	callsub movePoolToNode
	int 1
	return

// movePoolToNode(validatorId: ValidatorIdType, poolAppId: uint64, nodeNum: uint64): void
//
// Find the specified pool (in any node number) and move it to the specified node.
// The pool account is forced offline if moved so prior node will still run for 320 rounds but
// new key goes online on new node soon after (320 rounds after it goes online)
// No-op if success, asserts if not found or can't move  (no space in target)
// [ ONLY OWNER OR MANAGER CAN CHANGE ]
//
// @param {ValidatorIdType} validatorId - The id of the validator.
// @param {uint64} poolAppId
// @param {uint64} nodeNum
movePoolToNode:
	proto 3 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// examples/reti/validatorRegistry.algo.ts:1001
	// assert(
	//       this.txn.sender === this.validatorList(validatorId).value.config.owner ||
	//         this.txn.sender === this.validatorList(validatorId).value.config.manager,
	//       'can only be called by owner or manager of validator'
	//     )
	txn Sender
	int 8
	int 32
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	==
	dup
	bnz *skip_or3
	txn Sender
	pushint 40
	int 32
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	==
	||

*skip_or3:
	// can only be called by owner or manager of validator
	assert

	// examples/reti/validatorRegistry.algo.ts:1007
	// nodePoolAssignments = clone(this.validatorList(validatorId).value.nodePoolAssignments)
	int 900 // headOffset
	pushint 192
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	frame_bury 0 // nodePoolAssignments: ((uint64[3])[8])

	// examples/reti/validatorRegistry.algo.ts:1008
	// assert(nodeNum >= 1 && nodeNum <= MAX_NODES, 'node number out of allowable range')
	frame_dig -3 // nodeNum: uint64
	int 1
	>=
	dup
	bz *skip_and1
	frame_dig -3 // nodeNum: uint64
	int 8
	<=
	&&

*skip_and1:
	// node number out of allowable range
	assert

	// examples/reti/validatorRegistry.algo.ts:1010
	// for (let srcNodeIdx = 0; srcNodeIdx < MAX_NODES; srcNodeIdx += 1)
	int 0
	frame_bury 1 // srcNodeIdx: uint64

*for_5:
	// examples/reti/validatorRegistry.algo.ts:1010
	// srcNodeIdx < MAX_NODES
	frame_dig 1 // srcNodeIdx: uint64
	int 8
	<
	bz *for_5_end

	// examples/reti/validatorRegistry.algo.ts:1011
	// for (let i = 0; i < MAX_POOLS_PER_NODE; i += 1)
	int 0
	frame_bury 2 // i: uint64

*for_6:
	// examples/reti/validatorRegistry.algo.ts:1011
	// i < MAX_POOLS_PER_NODE
	frame_dig 2 // i: uint64
	int 3
	<
	bz *for_6_end

	// *if27_condition
	// examples/reti/validatorRegistry.algo.ts:1012
	// nodePoolAssignments.nodes[srcNodeIdx].poolAppIds[i] === poolAppId
	frame_dig 0 // nodePoolAssignments: ((uint64[3])[8])
	int 0
	frame_dig 1 // srcNodeIdx: uint64
	int 24
	* // acc * typeLength
	+
	int 0
	+
	frame_dig 2 // i: uint64
	int 8
	* // acc * typeLength
	+
	int 8
	extract3
	btoi
	frame_dig -2 // poolAppId: uint64
	==
	bz *if27_end

	// *if27_consequent
	// examples/reti/validatorRegistry.algo.ts:1013
	// assert(nodeNum - 1 !== srcNodeIdx, "can't move to same node")
	frame_dig -3 // nodeNum: uint64
	int 1
	-
	frame_dig 1 // srcNodeIdx: uint64
	!=

	// can't move to same node
	assert

	// examples/reti/validatorRegistry.algo.ts:1015
	// this.validatorList(validatorId).value.nodePoolAssignments.nodes[srcNodeIdx].poolAppIds[i] = 0
	int 900
	frame_dig 1 // srcNodeIdx: uint64
	int 24
	* // acc * typeLength
	+
	int 0
	+
	frame_dig 2 // i: uint64
	int 8
	* // acc * typeLength
	+
	byte 0x0000000000000000
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:1018
	// sendMethodCall<typeof StakingPool.prototype.goOffline>({
	//             applicationID: AppID.fromUint64(poolAppId),
	//           })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	pushbytes 0x51ef3b21 // method "goOffline()void"
	itxn_field ApplicationArgs

	// examples/reti/validatorRegistry.algo.ts:1019
	// applicationID: AppID.fromUint64(poolAppId)
	frame_dig -2 // poolAppId: uint64
	itxn_field ApplicationID

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/validatorRegistry.algo.ts:1023
	// this.addPoolToNode(validatorId, poolAppId, nodeNum)
	frame_dig -3 // nodeNum: uint64
	frame_dig -2 // poolAppId: uint64
	frame_dig -1 // validatorId: ValidatorIdType
	callsub addPoolToNode

	// examples/reti/validatorRegistry.algo.ts:1024
	// return;
	retsub

*if27_end:

*for_6_continue:
	// examples/reti/validatorRegistry.algo.ts:1011
	// i += 1
	frame_dig 2 // i: uint64
	int 1
	+
	frame_bury 2 // i: uint64
	b *for_6

*for_6_end:

*for_5_continue:
	// examples/reti/validatorRegistry.algo.ts:1010
	// srcNodeIdx += 1
	frame_dig 1 // srcNodeIdx: uint64
	int 1
	+
	frame_bury 1 // srcNodeIdx: uint64
	b *for_5

*for_5_end:
	// couldn't find pool app id in nodes to move
	err
	retsub

// emptyTokenRewards(uint64,address)uint64
*abi_route_emptyTokenRewards:
	// The ABI return prefix
	byte 0x151f7c75

	// receiver: address
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (receiver) for emptyTokenRewards must be a address
	assert

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute emptyTokenRewards(uint64,address)uint64
	callsub emptyTokenRewards
	itob
	concat
	log
	int 1
	return

// emptyTokenRewards(validatorId: ValidatorIdType, receiver: Address): uint64
//
// Sends the reward tokens held in pool 1 to specified receiver.
// This is intended to be used by the owner when they want to get reward tokens 'back' which they sent to
// the first pool (likely because validator is sunsetting.  Any tokens currently 'reserved' for stakers to claim will
// NOT be sent as they must be held back for stakers to later claim.
// [ ONLY OWNER CAN CALL]
//
// @param {ValidatorIdType} validatorId - The id of the validator.
// @param {Address} receiver - the account to send the tokens to (must already be opted-in to the reward token)
// @returns {uint64} the amount of reward token sent
emptyTokenRewards:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 3

	// examples/reti/validatorRegistry.algo.ts:1043
	// assert(
	//       this.txn.sender === this.validatorList(validatorId).value.config.owner,
	//       'can only be called by validator owner'
	//     )
	txn Sender
	int 8
	int 32
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	==

	// can only be called by validator owner
	assert

	// examples/reti/validatorRegistry.algo.ts:1047
	// rewardTokenId = this.validatorList(validatorId).value.config.rewardTokenId
	pushint 153
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 0 // rewardTokenId: uint64

	// examples/reti/validatorRegistry.algo.ts:1048
	// rewardTokenHeldBack = this.validatorList(validatorId).value.state.rewardTokenHeldBack
	int 260
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 1 // rewardTokenHeldBack: uint64

	// examples/reti/validatorRegistry.algo.ts:1049
	// assert(rewardTokenId !== 0, "this validator doesn't have a reward token defined")
	frame_dig 0 // rewardTokenId: uint64
	int 0
	!=

	// this validator doesn't have a reward token defined
	assert

	// examples/reti/validatorRegistry.algo.ts:1050
	// poolOneAppId = AppID.fromUint64(this.validatorList(validatorId).value.pools[0].poolAppId)
	int 268
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 2 // poolOneAppId: uint64

	// examples/reti/validatorRegistry.algo.ts:1052
	// tokenRewardBal = poolOneAppId.address.assetBalance(AssetID.fromUint64(rewardTokenId)) - rewardTokenHeldBack
	frame_dig 2 // poolOneAppId: uint64
	app_params_get AppAddress
	pop
	frame_dig 0 // rewardTokenId: uint64
	asset_holding_get AssetBalance
	pop
	frame_dig 1 // rewardTokenHeldBack: uint64
	-
	frame_bury 3 // tokenRewardBal: uint64

	// examples/reti/validatorRegistry.algo.ts:1055
	// sendMethodCall<typeof StakingPool.prototype.payTokenReward>({
	//       applicationID: poolOneAppId,
	//       methodArgs: [receiver, rewardTokenId, tokenRewardBal],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0x63f3f28b // method "payTokenReward(address,uint64,uint64)void"
	itxn_field ApplicationArgs

	// examples/reti/validatorRegistry.algo.ts:1056
	// applicationID: poolOneAppId
	frame_dig 2 // poolOneAppId: uint64
	itxn_field ApplicationID

	// examples/reti/validatorRegistry.algo.ts:1057
	// methodArgs: [receiver, rewardTokenId, tokenRewardBal]
	frame_dig -2 // receiver: Address
	itxn_field ApplicationArgs
	frame_dig 0 // rewardTokenId: uint64
	itob
	itxn_field ApplicationArgs
	frame_dig 3 // tokenRewardBal: uint64
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/validatorRegistry.algo.ts:1059
	// assert(
	//       poolOneAppId.address.assetBalance(AssetID.fromUint64(rewardTokenId)) === rewardTokenHeldBack,
	//       'balance of remaining reward tokens should match the held back amount'
	//     )
	frame_dig 2 // poolOneAppId: uint64
	app_params_get AppAddress
	pop
	frame_dig 0 // rewardTokenId: uint64
	asset_holding_get AssetBalance
	pop
	frame_dig 1 // rewardTokenHeldBack: uint64
	==

	// balance of remaining reward tokens should match the held back amount
	assert

	// examples/reti/validatorRegistry.algo.ts:1063
	// return tokenRewardBal;
	frame_dig 3 // tokenRewardBal: uint64

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 3
	retsub

// verifyPoolKeyCaller(poolKey: ValidatorPoolKey): void
//
// Logs the addition of a new validator to the system, its initial owner and manager
//
//
// verifyPoolKeyCaller verifies the passed in key (from a staking pool calling us to update metrics) is valid
// and matches the information we have in our state.  'Fake' pools could call us to update our data, but they
// can't fake the ids and most importantly application id(!) of the caller that has to match.
verifyPoolKeyCaller:
	proto 1 0

	// examples/reti/validatorRegistry.algo.ts:1161
	// assert(this.validatorList(poolKey.id).exists, "the specified validator id isn't valid")
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	box_len
	swap
	pop

	// the specified validator id isn't valid
	assert

	// examples/reti/validatorRegistry.algo.ts:1162
	// assert(poolKey.poolId <= MAX_POOLS, 'pool id not in valid range')
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 24
	<=

	// pool id not in valid range
	assert

	// examples/reti/validatorRegistry.algo.ts:1163
	// assert(
	//       poolKey.poolId > 0 && (poolKey.poolId as uint16) <= this.validatorList(poolKey.id).value.state.numPools,
	//       'pool id outside of range of pools created for this validator'
	//     )
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 0
	>
	dup
	bz *skip_and2
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 242
	int 2
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	<=
	&&

*skip_and2:
	// pool id outside of range of pools created for this validator
	assert

	// examples/reti/validatorRegistry.algo.ts:1169
	// assert(
	//       poolKey.poolAppId === this.validatorList(poolKey.id).value.pools[poolKey.poolId - 1].poolAppId,
	//       "The passed in app id doesn't match the passed in ids"
	//     )
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 16 8
	btoi
	int 268 // headOffset
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 0
	+
	int 8
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	==

	// The passed in app id doesn't match the passed in ids
	assert

	// examples/reti/validatorRegistry.algo.ts:1174
	// assert(this.txn.sender === AppID.fromUint64(poolKey.poolAppId).address)
	txn Sender
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 16 8
	btoi
	app_params_get AppAddress
	pop
	==
	assert

	// examples/reti/validatorRegistry.algo.ts:1176
	// assert(poolKey.id === (AppID.fromUint64(poolKey.poolAppId).globalState('validatorId') as uint64))
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 16 8
	btoi
	pushbytes 0x76616c696461746f724964 // "validatorId"
	app_global_get_ex

	// global state value does not exist: AppID.fromUint64(poolKey.poolAppId).globalState('validatorId')
	assert
	==
	assert

	// examples/reti/validatorRegistry.algo.ts:1177
	// assert(poolKey.poolId === (AppID.fromUint64(poolKey.poolAppId).globalState('poolId') as uint64))
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 16 8
	btoi
	pushbytes 0x706f6f6c4964 // "poolId"
	app_global_get_ex

	// global state value does not exist: AppID.fromUint64(poolKey.poolAppId).globalState('poolId')
	assert
	==
	assert
	retsub

// reverifyNFDOwnership(validatorId: ValidatorIdType): void
//
// This method verifies the ownership of NFD (Named Function Data) by a validator.
// If the ownership is no longer valid, it removes the NFD from the validator's configuration.
//
// @param {ValidatorIdType} validatorId - The id of the validator whose data should be re-evaluated.
reverifyNFDOwnership:
	proto 1 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// examples/reti/validatorRegistry.algo.ts:1187
	// validatorConfig = this.validatorList(validatorId).value.config
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	frame_bury 0 // storage key//validatorConfig

	// *if28_condition
	// examples/reti/validatorRegistry.algo.ts:1188
	// validatorConfig.nfdForInfo !== 0
	pushint 72
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	int 0
	!=
	bz *if28_end

	// *if28_consequent
	// examples/reti/validatorRegistry.algo.ts:1191
	// nfdOwner = AppID.fromUint64(validatorConfig.nfdForInfo).globalState('i.owner.a') as Address
	pushint 72
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	byte 0x692e6f776e65722e61 // "i.owner.a"
	app_global_get_ex

	// global state value does not exist: AppID.fromUint64(validatorConfig.nfdForInfo).globalState('i.owner.a')
	assert
	frame_bury 1 // nfdOwner: address

	// *if29_condition
	// examples/reti/validatorRegistry.algo.ts:1193
	// validatorConfig.owner !== nfdOwner && validatorConfig.manager !== nfdOwner
	int 8
	int 32
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	frame_dig 1 // nfdOwner: address
	!=
	dup
	bz *skip_and3
	pushint 40
	int 32
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	frame_dig 1 // nfdOwner: address
	!=
	&&

*skip_and3:
	bz *if29_end

	// *if29_consequent
	// examples/reti/validatorRegistry.algo.ts:1195
	// this.validatorList(validatorId).value.config.nfdForInfo = 0
	pushint 72
	byte 0x0000000000000000
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace

*if29_end:

*if28_end:
	retsub

// validateConfig(config: ValidatorConfig): void
validateConfig:
	proto 1 0

	// examples/reti/validatorRegistry.algo.ts:1202
	// assert(
	//       config.entryGatingType >= GATING_TYPE_NONE && config.entryGatingType <= GATING_TYPE_CONST_MAX,
	//       'gating type not valid'
	//     )
	frame_dig -1 // config: ValidatorConfig
	extract 80 1
	btoi
	int 0
	>=
	dup
	bz *skip_and4
	frame_dig -1 // config: ValidatorConfig
	extract 80 1
	btoi
	pushint 4
	<=
	&&

*skip_and4:
	// gating type not valid
	assert

	// examples/reti/validatorRegistry.algo.ts:1206
	// assert(
	//       config.epochRoundLength >= MIN_EPOCH_LENGTH && config.epochRoundLength <= MAX_EPOCH_LENGTH,
	//       'epoch length not in allowable range'
	//     )
	frame_dig -1 // config: ValidatorConfig
	extract 169 4
	btoi
	int 1
	>=
	dup
	bz *skip_and5
	frame_dig -1 // config: ValidatorConfig
	extract 169 4
	btoi
	int 1000000
	<=
	&&

*skip_and5:
	// epoch length not in allowable range
	assert

	// examples/reti/validatorRegistry.algo.ts:1210
	// assert(
	//       config.percentToValidator >= MIN_PCT_TO_VALIDATOR && config.percentToValidator <= MAX_PCT_TO_VALIDATOR,
	//       'commission percentage not valid'
	//     )
	frame_dig -1 // config: ValidatorConfig
	extract 173 4
	btoi
	int 0
	>=
	dup
	bz *skip_and6
	frame_dig -1 // config: ValidatorConfig
	extract 173 4
	btoi
	int 1000000
	<=
	&&

*skip_and6:
	// commission percentage not valid
	assert

	// *if30_condition
	// examples/reti/validatorRegistry.algo.ts:1214
	// config.percentToValidator !== 0
	frame_dig -1 // config: ValidatorConfig
	extract 173 4
	btoi
	int 0
	!=
	bz *if30_end

	// *if30_consequent
	// examples/reti/validatorRegistry.algo.ts:1215
	// assert(
	//         config.validatorCommissionAddress !== Address.zeroAddress,
	//         'validatorCommissionAddress must be set if percent to validator is not 0'
	//       )
	frame_dig -1 // config: ValidatorConfig
	extract 177 32
	global ZeroAddress
	!=

	// validatorCommissionAddress must be set if percent to validator is not 0
	assert

*if30_end:
	// examples/reti/validatorRegistry.algo.ts:1220
	// assert(config.minEntryStake >= MIN_ALGO_STAKE_PER_POOL, 'staking pool must have minimum entry of 1 algo')
	frame_dig -1 // config: ValidatorConfig
	extract 209 8
	btoi
	int 1000000
	>=

	// staking pool must have minimum entry of 1 algo
	assert

	// examples/reti/validatorRegistry.algo.ts:1222
	// assert(
	//       config.poolsPerNode > 0 && config.poolsPerNode <= MAX_POOLS_PER_NODE,
	//       'number of pools per node exceeds allowed number'
	//     )
	frame_dig -1 // config: ValidatorConfig
	extract 225 1
	btoi
	int 0
	>
	dup
	bz *skip_and7
	frame_dig -1 // config: ValidatorConfig
	extract 225 1
	btoi
	int 3
	<=
	&&

*skip_and7:
	// number of pools per node exceeds allowed number
	assert

	// *if31_condition
	// examples/reti/validatorRegistry.algo.ts:1226
	// config.sunsettingOn !== 0
	frame_dig -1 // config: ValidatorConfig
	extract 226 8
	btoi
	int 0
	!=
	bz *if31_end

	// *if31_consequent
	// examples/reti/validatorRegistry.algo.ts:1227
	// assert(config.sunsettingOn > globals.latestTimestamp, 'sunsettingOn must be later than now if set')
	frame_dig -1 // config: ValidatorConfig
	extract 226 8
	btoi
	global LatestTimestamp
	>

	// sunsettingOn must be later than now if set
	assert

*if31_end:
	retsub

// callPoolAddStake(stakedAmountPayment: PayTxn, poolKey: ValidatorPoolKey, mbrAmtPaid: uint64, isNewStakerToValidator: boolean, isNewStakerToProtocol: boolean): void
//
// Adds a stakers amount of algo to a validator pool, transferring the algo we received from them (already verified
// by our caller) to the staking pool account, and then telling it about the amount being added for the specified
// staker.
//
// @param {PayTxn} stakedAmountPayment - payment coming from staker to place into a pool
// @param {ValidatorPoolKey} poolKey - The key of the validator pool.
// @param {uint64} mbrAmtPaid - Amount the user is leaving behind in the validator to pay for their staker MBR cost
// @param {boolean} isNewStakerToValidator - if this is a new, first-time staker to the validator
// @param {boolean} isNewStakerToProtocol - if this is a new, first-time staker to the protocol
callPoolAddStake:
	proto 5 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// examples/reti/validatorRegistry.algo.ts:1249
	// poolAppId = this.validatorList(poolKey.id).value.pools[poolKey.poolId - 1].poolAppId
	int 268 // headOffset
	frame_dig -2 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 0
	+
	int 8
	byte 0x76 // "v"
	frame_dig -2 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 0 // poolAppId: uint64

	// examples/reti/validatorRegistry.algo.ts:1253
	// sendMethodCall<typeof StakingPool.prototype.addStake, uint64>({
	//       applicationID: AppID.fromUint64(poolAppId),
	//       methodArgs: [
	//         // =======
	//         // THIS IS A SEND of the amount received right back out and into the staking pool contract account.
	//         { amount: stakedAmountPayment.amount - mbrAmtPaid, receiver: AppID.fromUint64(poolAppId).address },
	//         // =======
	//         stakedAmountPayment.sender,
	//       ],
	//     })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// examples/reti/validatorRegistry.algo.ts:1258
	// amount: stakedAmountPayment.amount - mbrAmtPaid
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Amount
	frame_dig -3 // mbrAmtPaid: uint64
	-
	itxn_field Amount

	// examples/reti/validatorRegistry.algo.ts:1258
	// receiver: AppID.fromUint64(poolAppId).address
	frame_dig 0 // poolAppId: uint64
	app_params_get AppAddress
	pop
	itxn_field Receiver

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee
	itxn_next
	int 6 // appl
	itxn_field TypeEnum
	pushbytes 0xf9c70cbd // method "addStake(pay,address)uint64"
	itxn_field ApplicationArgs

	// examples/reti/validatorRegistry.algo.ts:1254
	// applicationID: AppID.fromUint64(poolAppId)
	frame_dig 0 // poolAppId: uint64
	itxn_field ApplicationID

	// examples/reti/validatorRegistry.algo.ts:1255
	// methodArgs: [
	//         // =======
	//         // THIS IS A SEND of the amount received right back out and into the staking pool contract account.
	//         { amount: stakedAmountPayment.amount - mbrAmtPaid, receiver: AppID.fromUint64(poolAppId).address },
	//         // =======
	//         stakedAmountPayment.sender,
	//       ]
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Sender
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0
	btoi

	// *if32_condition
	// examples/reti/validatorRegistry.algo.ts:1263
	// globals.opcodeBudget < 500
	global OpcodeBudget
	pushint 500
	<
	bz *if32_end

	// *if32_consequent
	// examples/reti/validatorRegistry.algo.ts:1264
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	pushint 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

*if32_end:
	// examples/reti/validatorRegistry.algo.ts:1268
	// poolNumStakers = AppID.fromUint64(poolAppId).globalState('numStakers') as uint64
	frame_dig 0 // poolAppId: uint64
	byte 0x6e756d5374616b657273 // "numStakers"
	app_global_get_ex

	// global state value does not exist: AppID.fromUint64(poolAppId).globalState('numStakers')
	assert
	frame_bury 1 // poolNumStakers: uint64

	// examples/reti/validatorRegistry.algo.ts:1269
	// poolAlgoStaked = AppID.fromUint64(poolAppId).globalState('staked') as uint64
	frame_dig 0 // poolAppId: uint64
	byte 0x7374616b6564 // "staked"
	app_global_get_ex

	// global state value does not exist: AppID.fromUint64(poolAppId).globalState('staked')
	assert
	frame_bury 2 // poolAlgoStaked: uint64

	// examples/reti/validatorRegistry.algo.ts:1270
	// this.validatorList(poolKey.id).value.pools[poolKey.poolId - 1].totalStakers = poolNumStakers as uint16
	int 268 // headOffset
	frame_dig -2 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 8 // headOffset
	+
	frame_dig 1 // poolNumStakers: uint64
	itob
	extract 6 2
	byte 0x76 // "v"
	frame_dig -2 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:1271
	// this.validatorList(poolKey.id).value.pools[poolKey.poolId - 1].totalAlgoStaked = poolAlgoStaked
	int 268 // headOffset
	frame_dig -2 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 10 // headOffset
	+
	frame_dig 2 // poolAlgoStaked: uint64
	itob
	byte 0x76 // "v"
	frame_dig -2 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_replace

	// *if33_condition
	// examples/reti/validatorRegistry.algo.ts:1274
	// isNewStakerToValidator
	frame_dig -4 // isNewStakerToValidator: boolean
	bz *if33_end

	// *if33_consequent
	// examples/reti/validatorRegistry.algo.ts:1275
	// this.validatorList(poolKey.id).value.state.totalStakers += 1
	pushint 244
	pushint 244
	int 8
	byte 0x76 // "v"
	frame_dig -2 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	int 1
	+
	itob
	byte 0x76 // "v"
	frame_dig -2 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_replace

*if33_end:
	// *if34_condition
	// examples/reti/validatorRegistry.algo.ts:1277
	// isNewStakerToProtocol
	frame_dig -5 // isNewStakerToProtocol: boolean
	bz *if34_end

	// *if34_consequent
	// examples/reti/validatorRegistry.algo.ts:1278
	// this.numStakers.value += 1
	byte 0x6e756d5374616b657273 // "numStakers"
	app_global_get
	int 1
	+
	byte 0x6e756d5374616b657273 // "numStakers"
	swap
	app_global_put

*if34_end:
	// examples/reti/validatorRegistry.algo.ts:1280
	// this.validatorList(poolKey.id).value.state.totalAlgoStaked += stakedAmountPayment.amount - mbrAmtPaid
	int 252
	dup
	int 8
	byte 0x76 // "v"
	frame_dig -2 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Amount
	frame_dig -3 // mbrAmtPaid: uint64
	-
	+
	itob
	byte 0x76 // "v"
	frame_dig -2 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:1281
	// this.totalAlgoStaked.value += stakedAmountPayment.amount - mbrAmtPaid
	byte 0x7374616b6564 // "staked"
	app_global_get
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Amount
	frame_dig -3 // mbrAmtPaid: uint64
	-
	+
	byte 0x7374616b6564 // "staked"
	swap
	app_global_put
	retsub

// updateStakerPoolSet(staker: Address, poolKey: ValidatorPoolKey): void
updateStakerPoolSet:
	proto 2 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// examples/reti/validatorRegistry.algo.ts:1285
	// assert(this.stakerPoolSet(staker).exists)
	byte 0x737073 // "sps"
	frame_dig -1 // staker: Address
	concat
	box_len
	swap
	pop
	assert

	// examples/reti/validatorRegistry.algo.ts:1287
	// poolSet = clone(this.stakerPoolSet(staker).value)
	byte 0x737073 // "sps"
	frame_dig -1 // staker: Address
	concat
	box_get

	// box value does not exist: this.stakerPoolSet(staker).value
	assert
	frame_bury 0 // poolSet: (uint64,uint64,uint64)[6]

	// examples/reti/validatorRegistry.algo.ts:1288
	// firstEmpty = 0
	int 0
	frame_bury 1 // firstEmpty: uint64

	// examples/reti/validatorRegistry.algo.ts:1289
	// for (let i = 0; i < this.stakerPoolSet(staker).value.length; i += 1)
	int 0
	frame_bury 2 // i: uint64

*for_7:
	// examples/reti/validatorRegistry.algo.ts:1289
	// i < this.stakerPoolSet(staker).value.length
	frame_dig 2 // i: uint64
	int 6
	<
	bz *for_7_end

	// *if35_condition
	// examples/reti/validatorRegistry.algo.ts:1290
	// poolSet[i] === poolKey
	frame_dig 0 // poolSet: (uint64,uint64,uint64)[6]
	frame_dig 2 // i: uint64
	int 24
	* // acc * typeLength
	int 24
	extract3
	frame_dig -2 // poolKey: ValidatorPoolKey
	==
	bz *if35_end

	// *if35_consequent
	// examples/reti/validatorRegistry.algo.ts:1292
	// return;
	retsub

*if35_end:
	// *if36_condition
	// examples/reti/validatorRegistry.algo.ts:1294
	// firstEmpty === 0 && poolSet[i].id === 0
	frame_dig 1 // firstEmpty: uint64
	int 0
	==
	dup
	bz *skip_and8
	frame_dig 0 // poolSet: (uint64,uint64,uint64)[6]
	frame_dig 2 // i: uint64
	int 24
	* // acc * typeLength
	int 0
	+
	int 8
	extract3
	btoi
	int 0
	==
	&&

*skip_and8:
	bz *if36_end

	// *if36_consequent
	// examples/reti/validatorRegistry.algo.ts:1295
	// firstEmpty = i + 1
	frame_dig 2 // i: uint64
	int 1
	+
	frame_bury 1 // firstEmpty: uint64

*if36_end:

*for_7_continue:
	// examples/reti/validatorRegistry.algo.ts:1289
	// i += 1
	frame_dig 2 // i: uint64
	int 1
	+
	frame_bury 2 // i: uint64
	b *for_7

*for_7_end:
	// *if37_condition
	// examples/reti/validatorRegistry.algo.ts:1298
	// firstEmpty === 0
	frame_dig 1 // firstEmpty: uint64
	int 0
	==
	bz *if37_end

	// *if37_consequent
	// No empty slot available in the staker pool set
	err

*if37_end:
	// examples/reti/validatorRegistry.algo.ts:1301
	// this.stakerPoolSet(staker).value[firstEmpty - 1] = poolKey
	frame_dig 1 // firstEmpty: uint64
	int 1
	-
	int 24
	* // acc * typeLength
	frame_dig -2 // poolKey: ValidatorPoolKey
	byte 0x737073 // "sps"
	frame_dig -1 // staker: Address
	concat
	cover 2
	box_replace
	retsub

// removeFromStakerPoolSet(staker: Address, poolKey: ValidatorPoolKey): [boolean, boolean]
//
// Removes a pool key from the staker's active pool set - fails if not found (!)
//
// @param {Address} staker - The address of the staker.
// @param {ValidatorPoolKey} poolKey - The pool key they should be stored in
//
// @return [boolean, boolean] [is the staker gone from ALL pools of the given VALIDATOR, and is staker gone from ALL pools]
removeFromStakerPoolSet:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 4

	// examples/reti/validatorRegistry.algo.ts:1314
	// inSameValidatorPoolCount = 0
	int 0
	frame_bury 0 // inSameValidatorPoolCount: uint64

	// examples/reti/validatorRegistry.algo.ts:1315
	// inAnyPoolCount = 0
	int 0
	frame_bury 1 // inAnyPoolCount: uint64

	// examples/reti/validatorRegistry.algo.ts:1316
	// found = false
	int 0
	frame_bury 2 // found: bool

	// examples/reti/validatorRegistry.algo.ts:1318
	// poolSet = clone(this.stakerPoolSet(staker).value)
	byte 0x737073 // "sps"
	frame_dig -1 // staker: Address
	concat
	box_get

	// box value does not exist: this.stakerPoolSet(staker).value
	assert
	frame_bury 3 // poolSet: (uint64,uint64,uint64)[6]

	// examples/reti/validatorRegistry.algo.ts:1319
	// for (let i = 0; i < this.stakerPoolSet(staker).value.length; i += 1)
	int 0
	frame_bury 4 // i: uint64

*for_8:
	// examples/reti/validatorRegistry.algo.ts:1319
	// i < this.stakerPoolSet(staker).value.length
	frame_dig 4 // i: uint64
	int 6
	<
	bz *for_8_end

	// *if38_condition
	// examples/reti/validatorRegistry.algo.ts:1320
	// poolSet[i].id === 0
	frame_dig 3 // poolSet: (uint64,uint64,uint64)[6]
	frame_dig 4 // i: uint64
	int 24
	* // acc * typeLength
	int 0
	+
	int 8
	extract3
	btoi
	int 0
	==
	bz *if38_end

	// *if38_consequent
	b *for_8_continue

*if38_end:
	// examples/reti/validatorRegistry.algo.ts:1323
	// inAnyPoolCount += 1
	frame_dig 1 // inAnyPoolCount: uint64
	int 1
	+
	frame_bury 1 // inAnyPoolCount: uint64

	// *if39_condition
	// examples/reti/validatorRegistry.algo.ts:1324
	// poolSet[i].id === poolKey.id
	frame_dig 3 // poolSet: (uint64,uint64,uint64)[6]
	frame_dig 4 // i: uint64
	int 24
	* // acc * typeLength
	int 0
	+
	int 8
	extract3
	btoi
	frame_dig -2 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	==
	bz *if39_end

	// *if39_consequent
	// *if40_condition
	// examples/reti/validatorRegistry.algo.ts:1325
	// poolSet[i] === poolKey
	frame_dig 3 // poolSet: (uint64,uint64,uint64)[6]
	frame_dig 4 // i: uint64
	int 24
	* // acc * typeLength
	int 24
	extract3
	frame_dig -2 // poolKey: ValidatorPoolKey
	==
	bz *if40_else

	// *if40_consequent
	// examples/reti/validatorRegistry.algo.ts:1326
	// found = true
	int 1
	frame_bury 2 // found: bool

	// examples/reti/validatorRegistry.algo.ts:1328
	// this.stakerPoolSet(staker).value[i] = { id: 0, poolId: 0, poolAppId: 0 }
	frame_dig 4 // i: uint64
	int 24
	* // acc * typeLength
	pushbytes 0x000000000000000000000000000000000000000000000000
	byte 0x737073 // "sps"
	frame_dig -1 // staker: Address
	concat
	cover 2
	box_replace
	b *if40_end

*if40_else:
	// examples/reti/validatorRegistry.algo.ts:1330
	// inSameValidatorPoolCount += 1
	frame_dig 0 // inSameValidatorPoolCount: uint64
	int 1
	+
	frame_bury 0 // inSameValidatorPoolCount: uint64

*if40_end:

*if39_end:

*for_8_continue:
	// examples/reti/validatorRegistry.algo.ts:1319
	// i += 1
	frame_dig 4 // i: uint64
	int 1
	+
	frame_bury 4 // i: uint64
	b *for_8

*for_8_end:
	// *if41_condition
	// examples/reti/validatorRegistry.algo.ts:1334
	// !found
	frame_dig 2 // found: bool
	!
	bz *if41_end

	// *if41_consequent
	// No matching slot found when told to remove a pool from the stakers set
	err

*if41_end:
	// examples/reti/validatorRegistry.algo.ts:1338
	// return [inSameValidatorPoolCount === 0, inAnyPoolCount === 0];
	byte 0x00
	int 0
	frame_dig 0 // inSameValidatorPoolCount: uint64
	int 0
	==
	setbit
	int 1
	frame_dig 1 // inAnyPoolCount: uint64
	int 0
	==
	setbit

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 4
	retsub

// addPoolToNode(validatorId: ValidatorIdType, poolAppId: uint64, nodeNum: uint64): void
addPoolToNode:
	proto 3 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// examples/reti/validatorRegistry.algo.ts:1342
	// nodePoolAssignments = clone(this.validatorList(validatorId).value.nodePoolAssignments)
	int 900 // headOffset
	pushint 192
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	frame_bury 0 // nodePoolAssignments: ((uint64[3])[8])

	// examples/reti/validatorRegistry.algo.ts:1343
	// maxPoolsPerNodeForThisValidator = this.validatorList(validatorId).value.config.poolsPerNode as uint64
	pushint 225
	int 1
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 1 // maxPoolsPerNodeForThisValidator: uint64

	// examples/reti/validatorRegistry.algo.ts:1345
	// assert(nodeNum >= 1 && nodeNum <= MAX_NODES, 'node number not in valid range')
	frame_dig -3 // nodeNum: uint64
	int 1
	>=
	dup
	bz *skip_and9
	frame_dig -3 // nodeNum: uint64
	int 8
	<=
	&&

*skip_and9:
	// node number not in valid range
	assert

	// examples/reti/validatorRegistry.algo.ts:1347
	// for (let i = 0; i < maxPoolsPerNodeForThisValidator; i += 1)
	int 0
	frame_bury 2 // i: uint64

*for_9:
	// examples/reti/validatorRegistry.algo.ts:1347
	// i < maxPoolsPerNodeForThisValidator
	frame_dig 2 // i: uint64
	frame_dig 1 // maxPoolsPerNodeForThisValidator: uint64
	<
	bz *for_9_end

	// *if42_condition
	// examples/reti/validatorRegistry.algo.ts:1348
	// nodePoolAssignments.nodes[nodeNum - 1].poolAppIds[i] === 0
	frame_dig 0 // nodePoolAssignments: ((uint64[3])[8])
	int 0
	frame_dig -3 // nodeNum: uint64
	int 1
	-
	int 24
	* // acc * typeLength
	+
	int 0
	+
	frame_dig 2 // i: uint64
	int 8
	* // acc * typeLength
	+
	int 8
	extract3
	btoi
	int 0
	==
	bz *if42_end

	// *if42_consequent
	// examples/reti/validatorRegistry.algo.ts:1350
	// this.validatorList(validatorId).value.nodePoolAssignments.nodes[nodeNum - 1].poolAppIds[i] = poolAppId
	int 900
	frame_dig -3 // nodeNum: uint64
	int 1
	-
	int 24
	* // acc * typeLength
	+
	int 0
	+
	frame_dig 2 // i: uint64
	int 8
	* // acc * typeLength
	+
	frame_dig -2 // poolAppId: uint64
	itob
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:1351
	// return;
	retsub

*if42_end:

*for_9_continue:
	// examples/reti/validatorRegistry.algo.ts:1347
	// i += 1
	frame_dig 2 // i: uint64
	int 1
	+
	frame_bury 2 // i: uint64
	b *for_9

*for_9_end:
	// no available space in specified node for this pool
	err
	retsub

// doesStakerMeetGating(validatorId: ValidatorIdType, valueToVerify: uint64): void
//
// Checks if a staker meets the gating requirements specified by the validator.
//
// @param {ValidatorIdType} validatorId - The id of the validator.
// @param {uint64} valueToVerify - The value to verify against the gating requirements.
// @returns {void} or asserts if requirements not met.
doesStakerMeetGating:
	proto 2 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 8

	// examples/reti/validatorRegistry.algo.ts:1365
	// type = this.validatorList(validatorId).value.config.entryGatingType
	pushint 80
	int 1
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 0 // type: uint8

	// *if43_condition
	// examples/reti/validatorRegistry.algo.ts:1366
	// type === GATING_TYPE_NONE
	frame_dig 0 // type: uint8
	int 0
	==
	bz *if43_end

	// *if43_consequent
	// examples/reti/validatorRegistry.algo.ts:1367
	// return;
	retsub

*if43_end:
	// examples/reti/validatorRegistry.algo.ts:1369
	// staker = this.txn.sender
	txn Sender
	frame_bury 1 // staker: address

	// examples/reti/validatorRegistry.algo.ts:1370
	// config = clone(this.validatorList(validatorId).value.config)
	int 0
	int 242
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	frame_bury 2 // config: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)

	// *if44_condition
	// examples/reti/validatorRegistry.algo.ts:1374
	// type === GATING_TYPE_ASSETS_CREATED_BY ||
	//       type === GATING_TYPE_ASSET_ID ||
	//       type === GATING_TYPE_CREATED_BY_NFD_ADDRESSES
	frame_dig 0 // type: uint8
	int 1
	==
	dup
	bnz *skip_or4
	frame_dig 0 // type: uint8
	int 2
	==
	||

*skip_or4:
	dup
	bnz *skip_or5
	frame_dig 0 // type: uint8
	int 3
	==
	||

*skip_or5:
	bz *if44_end

	// *if44_consequent
	// examples/reti/validatorRegistry.algo.ts:1378
	// assert(valueToVerify !== 0)
	frame_dig -2 // valueToVerify: uint64
	int 0
	!=
	assert

	// examples/reti/validatorRegistry.algo.ts:1379
	// balRequired = this.validatorList(validatorId).value.config.gatingAssetMinBalance
	pushint 145
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 3 // balRequired: uint64

	// *if45_condition
	// examples/reti/validatorRegistry.algo.ts:1380
	// balRequired === 0
	frame_dig 3 // balRequired: uint64
	int 0
	==
	bz *if45_end

	// *if45_consequent
	// examples/reti/validatorRegistry.algo.ts:1381
	// balRequired = 1
	int 1
	frame_bury 3 // balRequired: uint64

*if45_end:
	// examples/reti/validatorRegistry.algo.ts:1383
	// assert(
	//         staker.assetBalance(AssetID.fromUint64(valueToVerify)) >= balRequired,
	//         'must have required minimum balance of validator defined token to add stake'
	//       )
	frame_dig 1 // staker: address
	frame_dig -2 // valueToVerify: uint64
	asset_holding_get AssetBalance
	pop
	frame_dig 3 // balRequired: uint64
	>=

	// must have required minimum balance of validator defined token to add stake
	assert

*if44_end:
	// *if46_condition
	// examples/reti/validatorRegistry.algo.ts:1388
	// type === GATING_TYPE_ASSETS_CREATED_BY
	frame_dig 0 // type: uint8
	int 1
	==
	bz *if46_end

	// *if46_consequent
	// examples/reti/validatorRegistry.algo.ts:1389
	// assert(
	//         AssetID.fromUint64(valueToVerify).creator === config.entryGatingAddress,
	//         'specified asset must be created by creator that the validator defined as a requirement to stake'
	//       )
	frame_dig -2 // valueToVerify: uint64
	asset_params_get AssetCreator
	pop
	frame_dig 2 // config: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 81 32
	==

	// specified asset must be created by creator that the validator defined as a requirement to stake
	assert

*if46_end:
	// *if47_condition
	// examples/reti/validatorRegistry.algo.ts:1394
	// type === GATING_TYPE_ASSET_ID
	frame_dig 0 // type: uint8
	int 2
	==
	bz *if47_end

	// *if47_consequent
	// examples/reti/validatorRegistry.algo.ts:1395
	// assert(valueToVerify !== 0)
	frame_dig -2 // valueToVerify: uint64
	int 0
	!=
	assert

	// examples/reti/validatorRegistry.algo.ts:1396
	// found = false
	int 0
	frame_bury 4 // found: bool

	// examples/reti/validatorRegistry.algo.ts:1397
	// config.entryGatingAssets
	frame_dig 2 // config: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 113 32
	dup
	frame_bury 5 // copy of the array we are iterating over
	extract 0 8
	btoi
	frame_bury 6 // assetId: uint64
	int 0
	frame_bury 7 // the offset we are extracting the next element from

*forOf_0:
	// *if48_condition
	// examples/reti/validatorRegistry.algo.ts:1398
	// valueToVerify === assetId
	frame_dig -2 // valueToVerify: uint64
	frame_dig 6 // assetId: uint64
	==
	bz *if48_end

	// *if48_consequent
	// examples/reti/validatorRegistry.algo.ts:1399
	// found = true
	int 1
	frame_bury 4 // found: bool
	b *forOf_0_end

*if48_end:

*forOf_0_continue:
	// increment offset and loop if not out of bounds
	frame_dig 7 // the offset we are extracting the next element from
	int 8
	+
	dup
	int 32 // offset of last element
	<
	bz *forOf_0_end
	frame_bury 7 // the offset we are extracting the next element from
	frame_dig 5 // copy of the array we are iterating over
	frame_dig 7 // the offset we are extracting the next element from
	int 8
	extract
	btoi
	frame_bury 6 // assetId: uint64
	b *forOf_0

*forOf_0_end:
	// examples/reti/validatorRegistry.algo.ts:1403
	// assert(found, 'specified asset must be identical to the asset id defined as a requirement to stake')
	frame_dig 4 // found: bool

	// specified asset must be identical to the asset id defined as a requirement to stake
	assert

*if47_end:
	// *if49_condition
	// examples/reti/validatorRegistry.algo.ts:1405
	// type === GATING_TYPE_CREATED_BY_NFD_ADDRESSES
	frame_dig 0 // type: uint8
	int 3
	==
	bz *if49_end

	// *if49_consequent
	// examples/reti/validatorRegistry.algo.ts:1408
	// assert(
	//         this.isAddressInNFDCAAlgoList(config.entryGatingAssets[0], AssetID.fromUint64(valueToVerify).creator),
	//         'specified asset must be created by creator that is one of the linked addresses in an nfd'
	//       )
	frame_dig -2 // valueToVerify: uint64
	asset_params_get AssetCreator
	pop
	frame_dig 2 // config: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 113 8
	btoi
	callsub isAddressInNFDCAAlgoList

	// specified asset must be created by creator that is one of the linked addresses in an nfd
	assert

*if49_end:
	// *if50_condition
	// examples/reti/validatorRegistry.algo.ts:1413
	// type === GATING_TYPE_SEGMENT_OF_NFD
	frame_dig 0 // type: uint8
	pushint 4
	==
	bz *if50_end

	// *if50_consequent
	// examples/reti/validatorRegistry.algo.ts:1415
	// userOfferedNFDAppID = valueToVerify
	frame_dig -2 // valueToVerify: uint64
	frame_bury 8 // userOfferedNFDAppID: uint64

	// examples/reti/validatorRegistry.algo.ts:1416
	// assert(this.isNFDAppIDValid(userOfferedNFDAppID), 'provided NFD must be valid')
	frame_dig 8 // userOfferedNFDAppID: uint64
	callsub isNFDAppIDValid

	// provided NFD must be valid
	assert

	// examples/reti/validatorRegistry.algo.ts:1419
	// assert(
	//         rawBytes(AppID.fromUint64(userOfferedNFDAppID).globalState('i.owner.a') as Address) === rawBytes(staker) ||
	//           this.isAddressInNFDCAAlgoList(userOfferedNFDAppID, staker),
	//         "provided nfd for entry isn't owned or linked to the staker"
	//       )
	frame_dig 8 // userOfferedNFDAppID: uint64
	byte 0x692e6f776e65722e61 // "i.owner.a"
	app_global_get_ex

	// global state value does not exist: AppID.fromUint64(userOfferedNFDAppID).globalState('i.owner.a')
	assert
	frame_dig 1 // staker: address
	==
	dup
	bnz *skip_or6
	frame_dig 1 // staker: address
	frame_dig 8 // userOfferedNFDAppID: uint64
	callsub isAddressInNFDCAAlgoList
	||

*skip_or6:
	// provided nfd for entry isn't owned or linked to the staker
	assert

	// examples/reti/validatorRegistry.algo.ts:1426
	// assert(
	//         btoi(AppID.fromUint64(userOfferedNFDAppID).globalState('i.parentAppID') as bytes) ===
	//           config.entryGatingAssets[0],
	//         'specified nfd must be a segment of the nfd the validator specified as a requirement'
	//       )
	frame_dig 8 // userOfferedNFDAppID: uint64
	pushbytes 0x692e706172656e744170704944 // "i.parentAppID"
	app_global_get_ex

	// global state value does not exist: AppID.fromUint64(userOfferedNFDAppID).globalState('i.parentAppID')
	assert
	btoi
	frame_dig 2 // config: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 113 8
	btoi
	==

	// specified nfd must be a segment of the nfd the validator specified as a requirement
	assert

*if50_end:
	retsub

// isNFDAppIDValid(nfdAppID: uint64): boolean
//
// Checks if the given NFD App id is valid.  Using only the App id there's no validation against the name (ie: that nfd X is name Y)
// So it's assumed for the caller, the app id alone is fine.  The name is fetched from the specified app id and the two
// together are used for validity check call to the nfd registry.
//
// @param {uint64} nfdAppID - The NFD App id to verify.
//
// @returns {boolean} - Returns true if the NFD App id is valid, otherwise false.
isNFDAppIDValid:
	proto 1 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/reti/validatorRegistry.algo.ts:1445
	// userOfferedNFDName = AppID.fromUint64(nfdAppID).globalState('i.name') as string
	frame_dig -1 // nfdAppID: uint64
	pushbytes 0x692e6e616d65 // "i.name"
	app_global_get_ex

	// global state value does not exist: AppID.fromUint64(nfdAppID).globalState('i.name')
	assert
	frame_bury 0 // userOfferedNFDName: string

	// examples/reti/validatorRegistry.algo.ts:1447
	// sendAppCall({
	//       applicationID: AppID.fromUint64(this.nfdRegistryAppId),
	//       applicationArgs: ['is_valid_nfd_appid', userOfferedNFDName, itob(nfdAppID)],
	//       applications: [AppID.fromUint64(nfdAppID)],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum

	// examples/reti/validatorRegistry.algo.ts:1448
	// applicationID: AppID.fromUint64(this.nfdRegistryAppId)
	intc 0 // TMPL_nfdRegistryAppId
	itxn_field ApplicationID

	// examples/reti/validatorRegistry.algo.ts:1449
	// applicationArgs: ['is_valid_nfd_appid', userOfferedNFDName, itob(nfdAppID)]
	byte 0x69735f76616c69645f6e66645f6170706964 // "is_valid_nfd_appid"
	itxn_field ApplicationArgs
	frame_dig 0 // userOfferedNFDName: string
	itxn_field ApplicationArgs
	frame_dig -1 // nfdAppID: uint64
	itob
	itxn_field ApplicationArgs

	// examples/reti/validatorRegistry.algo.ts:1450
	// applications: [AppID.fromUint64(nfdAppID)]
	frame_dig -1 // nfdAppID: uint64
	itxn_field Applications

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/validatorRegistry.algo.ts:1452
	// return btoi(this.itxn.lastLog) === 1;
	itxn LastLog
	btoi
	int 1
	==

	// set the subroutine return value
	frame_bury 0
	retsub

// isAddressInNFDCAAlgoList(nfdAppID: uint64, addrToFind: Address): boolean
//
// Checks if the specified address is present in an NFDs list of verified addresses.
// The NFD is assumed to have already been validated as official.
//
// @param {uint64} nfdAppID - The NFD application id.
// @param {Address} addrToFind - The address to find in the v.caAlgo.0.as property
// @return {boolean} - `true` if the address is present, `false` otherwise.
isAddressInNFDCAAlgoList:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// examples/reti/validatorRegistry.algo.ts:1464
	// sendAppCall({
	//       applicationID: AppID.fromUint64(nfdAppID),
	//       applicationArgs: ['read_property', 'v.caAlgo.0.as'],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum

	// examples/reti/validatorRegistry.algo.ts:1465
	// applicationID: AppID.fromUint64(nfdAppID)
	frame_dig -1 // nfdAppID: uint64
	itxn_field ApplicationID

	// examples/reti/validatorRegistry.algo.ts:1466
	// applicationArgs: ['read_property', 'v.caAlgo.0.as']
	pushbytes 0x726561645f70726f7065727479 // "read_property"
	itxn_field ApplicationArgs
	pushbytes 0x762e6361416c676f2e302e6173 // "v.caAlgo.0.as"
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/validatorRegistry.algo.ts:1468
	// caAlgoData = this.itxn.lastLog
	itxn LastLog
	frame_bury 0 // caAlgoData: byte[]

	// examples/reti/validatorRegistry.algo.ts:1469
	// for (let i = 0; i < caAlgoData.length; i += 32)
	int 0
	frame_bury 1 // i: uint64

*for_10:
	// examples/reti/validatorRegistry.algo.ts:1469
	// i < caAlgoData.length
	frame_dig 1 // i: uint64
	frame_dig 0 // caAlgoData: byte[]
	len
	<
	bz *for_10_end

	// examples/reti/validatorRegistry.algo.ts:1470
	// addr = extract3(caAlgoData, i, 32)
	frame_dig 0 // caAlgoData: byte[]
	frame_dig 1 // i: uint64
	int 32
	extract3
	frame_bury 2 // addr: byte[]

	// *if51_condition
	// examples/reti/validatorRegistry.algo.ts:1471
	// addr !== rawBytes(globals.zeroAddress) && addr === rawBytes(addrToFind)
	frame_dig 2 // addr: byte[]
	global ZeroAddress
	!=
	dup
	bz *skip_and10
	frame_dig 2 // addr: byte[]
	frame_dig -2 // addrToFind: Address
	==
	&&

*skip_and10:
	bz *if51_end

	// *if51_consequent
	// examples/reti/validatorRegistry.algo.ts:1472
	// return true;
	int 1
	b *isAddressInNFDCAAlgoList*return

*if51_end:

*for_10_continue:
	// examples/reti/validatorRegistry.algo.ts:1469
	// i += 32
	frame_dig 1 // i: uint64
	int 32
	+
	frame_bury 1 // i: uint64
	b *for_10

*for_10_end:
	// examples/reti/validatorRegistry.algo.ts:1475
	// return false;
	int 0

*isAddressInNFDCAAlgoList*return:
	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 2
	retsub

// algoSaturationLevel(): uint64
//
// Returns the maximum allowed stake per validator based on a percentage of all current online stake before
// the validator is considered saturated - where rewards are diminished.
// NOTE: this function is defined twice - here and in staking pool contract.  Both must be identical.
algoSaturationLevel:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/reti/validatorRegistry.algo.ts:1484
	// online = this.getCurrentOnlineStake()
	callsub getCurrentOnlineStake
	frame_bury 0 // online: uint64

	// examples/reti/validatorRegistry.algo.ts:1486
	// return wideRatio([online, MAX_VALIDATOR_SOFT_PCT_OF_ONLINE_1DECIMAL], [1000]);
	frame_dig 0 // online: uint64
	pushint 100
	mulw
	int 0
	pushint 1000
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert

	// set the subroutine return value
	frame_bury 0
	retsub

// maxAllowedStake(): uint64
//
// Returns the MAXIMUM allowed stake per validator based on a percentage of all current online stake.
// Adding stake is completely blocked at this amount.
maxAllowedStake:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/reti/validatorRegistry.algo.ts:1494
	// online = this.getCurrentOnlineStake()
	callsub getCurrentOnlineStake
	frame_bury 0 // online: uint64

	// examples/reti/validatorRegistry.algo.ts:1496
	// return wideRatio([online, MAX_VALIDATOR_HARD_PCT_OF_ONLINE_1DECIMAL], [1000]);
	frame_dig 0 // online: uint64
	pushint 150
	mulw
	int 0
	pushint 1000
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert

	// set the subroutine return value
	frame_bury 0
	retsub

// maxAlgoAllowedPerPool(): uint64
//
// Returns the MAXIMUM allowed stake per pool and still receive incentives - we'll treat this as the 'max per pool'
maxAlgoAllowedPerPool:
	proto 0 1

	// examples/reti/validatorRegistry.algo.ts:1504
	// return 70_000_000_000_000;
	pushint 70_000_000_000_000
	retsub

// getCurrentOnlineStake(): uint64
getCurrentOnlineStake:
	proto 0 1

	// examples/reti/validatorRegistry.algo.ts:1509
	// return 2_000_000_000_000_000;
	pushint 2_000_000_000_000_000
	retsub

// minBalanceForAccount(contracts: uint64, extraPages: uint64, assets: uint64, localInts: uint64, localBytes: uint64, globalInts: uint64, globalBytes: uint64): uint64
minBalanceForAccount:
	proto 7 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/reti/validatorRegistry.algo.ts:1521
	// minBal = ALGORAND_ACCOUNT_MIN_BALANCE
	int 100000
	frame_bury 0 // minBal: uint64

	// examples/reti/validatorRegistry.algo.ts:1522
	// minBal += contracts * APPLICATION_BASE_FEE
	frame_dig 0 // minBal: uint64
	frame_dig -1 // contracts: uint64
	int 100000
	*
	+
	frame_bury 0 // minBal: uint64

	// examples/reti/validatorRegistry.algo.ts:1523
	// minBal += extraPages * APPLICATION_BASE_FEE
	frame_dig 0 // minBal: uint64
	frame_dig -2 // extraPages: uint64
	int 100000
	*
	+
	frame_bury 0 // minBal: uint64

	// examples/reti/validatorRegistry.algo.ts:1524
	// minBal += assets * ASSET_HOLDING_FEE
	frame_dig 0 // minBal: uint64
	frame_dig -3 // assets: uint64
	int 100000
	*
	+
	frame_bury 0 // minBal: uint64

	// examples/reti/validatorRegistry.algo.ts:1525
	// minBal += localInts * SSC_VALUE_UINT
	frame_dig 0 // minBal: uint64
	frame_dig -4 // localInts: uint64
	pushint 28500
	*
	+
	frame_bury 0 // minBal: uint64

	// examples/reti/validatorRegistry.algo.ts:1526
	// minBal += globalInts * SSC_VALUE_UINT
	frame_dig 0 // minBal: uint64
	frame_dig -6 // globalInts: uint64
	pushint 28500
	*
	+
	frame_bury 0 // minBal: uint64

	// examples/reti/validatorRegistry.algo.ts:1527
	// minBal += localBytes * SSC_VALUE_BYTES
	frame_dig 0 // minBal: uint64
	frame_dig -5 // localBytes: uint64
	pushint 50000
	*
	+
	frame_bury 0 // minBal: uint64

	// examples/reti/validatorRegistry.algo.ts:1528
	// minBal += globalBytes * SSC_VALUE_BYTES
	frame_dig 0 // minBal: uint64
	frame_dig -7 // globalBytes: uint64
	pushint 50000
	*
	+
	frame_bury 0 // minBal: uint64

	// examples/reti/validatorRegistry.algo.ts:1529
	// return minBal;
	frame_dig 0 // minBal: uint64

	// set the subroutine return value
	frame_bury 0
	retsub

// costForBoxStorage(totalNumBytes: uint64): uint64
costForBoxStorage:
	proto 1 1

	// examples/reti/validatorRegistry.algo.ts:1536
	// return SCBOX_PERBOX + totalNumBytes * SCBOX_PERBYTE;
	pushint 2500
	frame_dig -1 // totalNumBytes: uint64
	pushint 400
	*
	+
	retsub

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x1b5e82c6 // method "initStakingContract(uint64)void"
	pushbytes 0x79472d83 // method "loadStakingContractData(uint64,byte[])void"
	pushbytes 0x5f7acfd9 // method "finalizeStakingContract()void"
	pushbytes 0x3172ca9d // method "gas()void"
	pushbytes 0x8a87142d // method "getMbrAmounts()(uint64,uint64,uint64,uint64)"
	pushbytes 0xd1366cc3 // method "getProtocolConstraints()(uint64,uint64,uint64,uint64,uint64,uint64,uint64,uint64,uint64,uint64,uint64)"
	pushbytes 0x3b045c5c // method "getNumValidators()uint64"
	pushbytes 0x75aff61d // method "getValidatorConfig(uint64)(uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)"
	pushbytes 0x1f2f0109 // method "getValidatorState(uint64)(uint16,uint64,uint64,uint64)"
	pushbytes 0x2fa22c4b // method "getValidatorOwnerAndManager(uint64)(address,address)"
	pushbytes 0x910e94ac // method "getPools(uint64)(uint64,uint16,uint64)[]"
	pushbytes 0x572767d1 // method "getPoolAppId(uint64,uint64)uint64"
	pushbytes 0x9b504aaf // method "getPoolInfo((uint64,uint64,uint64))(uint64,uint16,uint64)"
	pushbytes 0xfbc63178 // method "getCurMaxStakePerPool(uint64)uint64"
	pushbytes 0x24498cf4 // method "doesStakerNeedToPayMBR(address)bool"
	pushbytes 0xf846dd7a // method "getStakedPoolsForAccount(address)(uint64,uint64,uint64)[]"
	pushbytes 0x83050501 // method "getTokenPayoutRatio(uint64)(uint64[24],uint64)"
	pushbytes 0x7bbb6c8d // method "getNodePoolAssignments(uint64)((uint64[3])[8])"
	pushbytes 0xf839414a // method "getNFDRegistryID()uint64"
	pushbytes 0x0c317cfb // method "addValidator(pay,string,(uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64))uint64"
	pushbytes 0x3e288972 // method "changeValidatorManager(uint64,address)void"
	pushbytes 0xdd5faada // method "changeValidatorSunsetInfo(uint64,uint64,uint64)void"
	pushbytes 0x18aac7a7 // method "changeValidatorNFD(uint64,uint64,string)void"
	pushbytes 0xf99ef54d // method "changeValidatorCommissionAddress(uint64,address)void"
	pushbytes 0x10809d4d // method "changeValidatorRewardInfo(uint64,uint8,address,uint64[4],uint64,uint64)void"
	pushbytes 0xe778dd5a // method "addPool(pay,uint64,uint64)(uint64,uint64,uint64)"
	pushbytes 0xbf5259d0 // method "addStake(pay,uint64,uint64)(uint64,uint64,uint64)"
	pushbytes 0x4df8d86e // method "setTokenPayoutRatio(uint64)(uint64[24],uint64)"
	pushbytes 0x418fcefc // method "stakeUpdatedViaRewards((uint64,uint64,uint64),uint64,uint64,uint64,uint64)void"
	pushbytes 0xa2dc51b5 // method "stakeRemoved((uint64,uint64,uint64),address,uint64,uint64,bool)void"
	pushbytes 0x2873f504 // method "findPoolForStaker(uint64,address,uint64)((uint64,uint64,uint64),bool,bool)"
	pushbytes 0x0547f4fe // method "movePoolToNode(uint64,uint64,uint64)void"
	pushbytes 0xcb668358 // method "emptyTokenRewards(uint64,address)uint64"
	txna ApplicationArgs 0
	match *abi_route_initStakingContract *abi_route_loadStakingContractData *abi_route_finalizeStakingContract *abi_route_gas *abi_route_getMbrAmounts *abi_route_getProtocolConstraints *abi_route_getNumValidators *abi_route_getValidatorConfig *abi_route_getValidatorState *abi_route_getValidatorOwnerAndManager *abi_route_getPools *abi_route_getPoolAppId *abi_route_getPoolInfo *abi_route_getCurMaxStakePerPool *abi_route_doesStakerNeedToPayMBR *abi_route_getStakedPoolsForAccount *abi_route_getTokenPayoutRatio *abi_route_getNodePoolAssignments *abi_route_getNFDRegistryID *abi_route_addValidator *abi_route_changeValidatorManager *abi_route_changeValidatorSunsetInfo *abi_route_changeValidatorNFD *abi_route_changeValidatorCommissionAddress *abi_route_changeValidatorRewardInfo *abi_route_addPool *abi_route_addStake *abi_route_setTokenPayoutRatio *abi_route_stakeUpdatedViaRewards *abi_route_stakeRemoved *abi_route_findPoolForStaker *abi_route_movePoolToNode *abi_route_emptyTokenRewards

	// this contract does not implement the given ABI method for call NoOp
	err

*call_UpdateApplication:
	pushbytes 0x46f76533 // method "updateApplication()void"
	txna ApplicationArgs 0
	match *abi_route_updateApplication

	// this contract does not implement the given ABI method for call UpdateApplication
	err", + "approval": "#pragma version 10
intcblock TMPL_nfdRegistryAppId 0 1 8 268 24 32 18 6 100000 260 700 242 900 3 1000000 2 10 252
bytecblock 0x76 0x706f6f6c54656d706c617465417070726f76616c4279746573 0x151f7c75 0x 0x6e756d5374616b657273 0x69735f76616c69645f6e66645f6170706964 0x7374616b6564 0x737073 0x692e6f776e65722e61 0x0000000000000000 0x0a8101 0x696e6974 0x6e756d56 0x00 0x63f3f28b

// This TEAL was generated by TEALScript v0.105.0
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following lines of TEAL are used to initialize template variables in scratch slots
intc 0 // TMPL_nfdRegistryAppId

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
int 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *call_UpdateApplication *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// updateApplication()void
*abi_route_updateApplication:
	// execute updateApplication()void
	callsub updateApplication
	int 1
	return

// updateApplication(): void
updateApplication:
	proto 0 0

	// examples/reti/validatorRegistry.algo.ts:202
	// assert(this.txn.sender === Address.fromAddress('LZ4V2IRVLCXFJK4REJV4TAGEKEYTA2GMR6TC2344OB3L3AF3MWXZ6ZAFIQ'))
	txn Sender
	pushbytes 0x5e795d223558ae54ab91226bc980c451313068cc8fa62d6f9c7076bd80bb65af // addr "LZ4V2IRVLCXFJK4REJV4TAGEKEYTA2GMR6TC2344OB3L3AF3MWXZ6ZAFIQ"
	==
	assert

	// examples/reti/validatorRegistry.algo.ts:204
	// this.stakingPoolApprovalProgram.delete()
	byte 0x706f6f6c54656d706c617465417070726f76616c4279746573 // "poolTemplateApprovalBytes"
	box_del

	// examples/reti/validatorRegistry.algo.ts:205
	// this.stakingPoolInitialized.value = false
	byte 0x696e6974 // "init"
	int 0
	byte 0x00
	int 0
	uncover 2
	setbit
	app_global_put
	retsub

// createApplication()void
*abi_route_createApplication:
	// execute createApplication()void
	callsub createApplication
	int 1
	return

// createApplication(): void
createApplication:
	proto 0 0

	// examples/reti/validatorRegistry.algo.ts:209
	// this.stakingPoolInitialized.value = false
	byte 0x696e6974 // "init"
	int 0
	byte 0x00
	int 0
	uncover 2
	setbit
	app_global_put

	// examples/reti/validatorRegistry.algo.ts:210
	// this.numValidators.value = 0
	byte 0x6e756d56 // "numV"
	int 0
	app_global_put

	// examples/reti/validatorRegistry.algo.ts:211
	// this.numStakers.value = 0
	byte 0x6e756d5374616b657273 // "numStakers"
	int 0
	app_global_put

	// examples/reti/validatorRegistry.algo.ts:212
	// this.totalAlgoStaked.value = 0
	byte 0x7374616b6564 // "staked"
	int 0
	app_global_put
	retsub

// initStakingContract(uint64)void
*abi_route_initStakingContract:
	// approvalProgramSize: uint64
	txna ApplicationArgs 1
	btoi

	// execute initStakingContract(uint64)void
	callsub initStakingContract
	int 1
	return

// initStakingContract(approvalProgramSize: uint64): void
initStakingContract:
	proto 1 0

	// examples/reti/validatorRegistry.algo.ts:217
	// this.stakingPoolApprovalProgram.create(approvalProgramSize)
	byte 0x706f6f6c54656d706c617465417070726f76616c4279746573 // "poolTemplateApprovalBytes"
	frame_dig -1 // approvalProgramSize: uint64
	box_create
	pop
	retsub

// loadStakingContractData(uint64,byte[])void
*abi_route_loadStakingContractData:
	// data: byte[]
	txna ApplicationArgs 2
	extract 2 0

	// offset: uint64
	txna ApplicationArgs 1
	btoi

	// execute loadStakingContractData(uint64,byte[])void
	callsub loadStakingContractData
	int 1
	return

// loadStakingContractData(offset: uint64, data: bytes): void
loadStakingContractData:
	proto 2 0

	// examples/reti/validatorRegistry.algo.ts:221
	// assert(!this.stakingPoolInitialized.value)
	byte 0x696e6974 // "init"
	app_global_get
	int 0
	getbit
	!
	assert

	// examples/reti/validatorRegistry.algo.ts:222
	// this.stakingPoolApprovalProgram.replace(offset, data)
	byte 0x706f6f6c54656d706c617465417070726f76616c4279746573 // "poolTemplateApprovalBytes"
	frame_dig -1 // offset: uint64
	frame_dig -2 // data: bytes
	box_replace
	retsub

// finalizeStakingContract()void
*abi_route_finalizeStakingContract:
	// execute finalizeStakingContract()void
	callsub finalizeStakingContract
	int 1
	return

// finalizeStakingContract(): void
finalizeStakingContract:
	proto 0 0

	// examples/reti/validatorRegistry.algo.ts:226
	// this.stakingPoolInitialized.value = true
	byte 0x696e6974 // "init"
	int 1
	byte 0x00
	int 0
	uncover 2
	setbit
	app_global_put
	retsub

// gas()void
*abi_route_gas:
	// execute gas()void
	callsub gas
	int 1
	return

// gas(): void
//
// gas is a dummy no-op call that can be used to pool-up resource references and opcode cost
gas:
	proto 0 0
	retsub

// getMbrAmounts()(uint64,uint64,uint64,uint64)
*abi_route_getMbrAmounts:
	// The ABI return prefix
	byte 0x151f7c75

	// execute getMbrAmounts()(uint64,uint64,uint64,uint64)
	callsub getMbrAmounts
	concat
	log
	int 1
	return

// getMbrAmounts(): MbrAmounts
//
// Returns the MBR amounts needed for various actions:
// [
// addValidatorMbr: uint64 - mbr needed to add a new validator - paid to validator contract
// addPoolMbr: uint64 - mbr needed to add a new pool - paid to validator
// poolInitMbr: uint64 - mbr needed to initStorage() of pool - paid to pool itself
// addStakerMbr: uint64 - mbr staker needs to add to first staking payment (stays w/ validator)
// ]
getMbrAmounts:
	proto 0 1

	// examples/reti/validatorRegistry.algo.ts:246
	// return {
	//       addValidatorMbr: this.costForBoxStorage(1 /* v prefix */ + len<ValidatorIdType>() + len<ValidatorInfo>()),
	//       addPoolMbr: this.minBalanceForAccount(
	//         1,
	//         // we could calculate this directly by referencing the size of stakingPoolApprovalProgram but it would
	//         // mean our callers would have to reference the box AND buy up i/o - so just go max on extra pages
	//         3,
	//         0,
	//         0,
	//         0,
	//         StakingPool.schema.global.numUint,
	//         StakingPool.schema.global.numByteSlice
	//       ),
	//       poolInitMbr:
	//         ALGORAND_ACCOUNT_MIN_BALANCE +
	//         this.costForBoxStorage(7 /* 'stakers' name */ + len<StakedInfo>() * MAX_STAKERS_PER_POOL),
	//       addStakerMbr:
	//         // how much to charge for first time a staker adds stake - since we add a tracking box per staker
	//         this.costForBoxStorage(3 /* 'sps' prefix */ + len<Address>() + len<ValidatorPoolKey>() * MAX_POOLS_PER_STAKER), // size of key + all values
	//     };
	pushint 1101
	callsub costForBoxStorage
	itob
	int 3
	pushint 11
	int 0
	dupn 2
	int 3
	int 1
	callsub minBalanceForAccount
	itob
	concat
	int 100000
	pushint 12807
	callsub costForBoxStorage
	+
	itob
	concat
	pushint 179
	callsub costForBoxStorage
	itob
	concat
	retsub

// getProtocolConstraints()(uint64,uint64,uint64,uint64,uint64,uint64,uint64,uint64,uint64,uint64,uint64)
*abi_route_getProtocolConstraints:
	// The ABI return prefix
	byte 0x151f7c75

	// execute getProtocolConstraints()(uint64,uint64,uint64,uint64,uint64,uint64,uint64,uint64,uint64,uint64,uint64)
	callsub getProtocolConstraints
	concat
	log
	int 1
	return

// getProtocolConstraints(): Constraints
//
// Returns the protocol constraints so that UIs can limit what users specify for validator configuration parameters.
getProtocolConstraints:
	proto 0 1

	// examples/reti/validatorRegistry.algo.ts:272
	// return {
	//       epochPayoutRoundsMin: MIN_EPOCH_LENGTH,
	//       epochPayoutRoundsMax: MAX_EPOCH_LENGTH,
	//       minPctToValidatorWFourDecimals: MIN_PCT_TO_VALIDATOR,
	//       maxPctToValidatorWFourDecimals: MAX_PCT_TO_VALIDATOR,
	//       minEntryStake: MIN_ALGO_STAKE_PER_POOL,
	//       maxAlgoPerPool: this.maxAlgoAllowedPerPool(),
	//       maxAlgoPerValidator: this.maxAllowedStake(),
	//       amtConsideredSaturated: this.algoSaturationLevel(),
	//       maxNodes: MAX_NODES,
	//       maxPoolsPerNode: MAX_POOLS_PER_NODE,
	//       maxStakersPerPool: MAX_STAKERS_PER_POOL,
	//     };
	pushbytes 0x000000000000000100000000000f4240000000000000000000000000000f424000000000000f4240
	callsub maxAlgoAllowedPerPool
	itob
	concat
	callsub maxAllowedStake
	itob
	concat
	callsub algoSaturationLevel
	itob
	concat
	pushbytes 0x0000000000000008
	concat
	pushbytes 0x0000000000000003
	concat
	pushbytes 0x00000000000000c8
	concat
	retsub

// getNumValidators()uint64
*abi_route_getNumValidators:
	// The ABI return prefix
	byte 0x151f7c75

	// execute getNumValidators()uint64
	callsub getNumValidators
	itob
	concat
	log
	int 1
	return

// getNumValidators(): uint64
//
// Returns the current number of validators
getNumValidators:
	proto 0 1

	// examples/reti/validatorRegistry.algo.ts:292
	// return this.numValidators.value;
	byte 0x6e756d56 // "numV"
	app_global_get
	retsub

// getValidatorConfig(uint64)(uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
*abi_route_getValidatorConfig:
	// The ABI return prefix
	byte 0x151f7c75

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute getValidatorConfig(uint64)(uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	callsub getValidatorConfig
	concat
	log
	int 1
	return

// getValidatorConfig(validatorId: ValidatorIdType): ValidatorConfig
getValidatorConfig:
	proto 1 1

	// examples/reti/validatorRegistry.algo.ts:297
	// return this.validatorList(validatorId).value.config;
	int 0
	int 242
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	retsub

// getValidatorState(uint64)(uint16,uint64,uint64,uint64)
*abi_route_getValidatorState:
	// The ABI return prefix
	byte 0x151f7c75

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute getValidatorState(uint64)(uint16,uint64,uint64,uint64)
	callsub getValidatorState
	concat
	log
	int 1
	return

// getValidatorState(validatorId: ValidatorIdType): ValidatorCurState
getValidatorState:
	proto 1 1

	// examples/reti/validatorRegistry.algo.ts:302
	// return this.validatorList(validatorId).value.state;
	int 242 // headOffset
	pushint 26
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	retsub

// getValidatorOwnerAndManager(uint64)(address,address)
*abi_route_getValidatorOwnerAndManager:
	// The ABI return prefix
	byte 0x151f7c75

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute getValidatorOwnerAndManager(uint64)(address,address)
	callsub getValidatorOwnerAndManager
	concat
	log
	int 1
	return

// getValidatorOwnerAndManager(validatorId: ValidatorIdType): [Address, Address]
getValidatorOwnerAndManager:
	proto 1 1

	// examples/reti/validatorRegistry.algo.ts:307
	// return [this.validatorList(validatorId).value.config.owner, this.validatorList(validatorId).value.config.manager];
	int 8
	int 32
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	pushint 40
	int 32
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	concat
	retsub

// getPools(uint64)(uint64,uint16,uint64)[]
*abi_route_getPools:
	// The ABI return prefix
	byte 0x151f7c75

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute getPools(uint64)(uint64,uint16,uint64)[]
	callsub getPools
	dup
	len
	int 18
	/
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// getPools(validatorId: ValidatorIdType): PoolInfo[]
//
// Return list of all pools for this validator.
// @param {uint64} validatorId
// @return {PoolInfo[]} - array of pools
// Not callable from other contracts because >1K return but can be called w/ simulate which bumps log returns
getPools:
	proto 1 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// examples/reti/validatorRegistry.algo.ts:318
	// retData: PoolInfo[] = []
	byte 0x
	frame_bury 0 // retData: PoolInfo[]

	// examples/reti/validatorRegistry.algo.ts:319
	// poolSet = clone(this.validatorList(validatorId).value.pools)
	int 268 // headOffset
	pushint 432
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	frame_bury 1 // poolSet: (uint64,uint16,uint64)[24]

	// examples/reti/validatorRegistry.algo.ts:320
	// for (let i = 0; i < poolSet.length; i += 1)
	int 0
	frame_bury 2 // i: uint64

*for_0:
	// examples/reti/validatorRegistry.algo.ts:320
	// i < poolSet.length
	frame_dig 2 // i: uint64
	int 24
	<
	bz *for_0_end

	// *if0_condition
	// examples/reti/validatorRegistry.algo.ts:321
	// poolSet[i].poolAppId === 0
	frame_dig 1 // poolSet: (uint64,uint16,uint64)[24]
	frame_dig 2 // i: uint64
	int 18
	* // acc * typeLength
	int 0
	+
	int 8
	extract3
	btoi
	int 0
	==
	bz *if0_end

	// *if0_consequent
	b *for_0_end

*if0_end:
	// examples/reti/validatorRegistry.algo.ts:325
	// retData.push(poolSet[i])
	frame_dig 0 // retData: PoolInfo[]
	frame_dig 1 // poolSet: (uint64,uint16,uint64)[24]
	frame_dig 2 // i: uint64
	int 18
	* // acc * typeLength
	int 18
	extract3
	concat
	frame_bury 0 // retData: PoolInfo[]

*for_0_continue:
	// examples/reti/validatorRegistry.algo.ts:320
	// i += 1
	frame_dig 2 // i: uint64
	int 1
	+
	frame_bury 2 // i: uint64
	b *for_0

*for_0_end:
	// examples/reti/validatorRegistry.algo.ts:327
	// return retData;
	frame_dig 0 // retData: PoolInfo[]

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 2
	retsub

// getPoolAppId(uint64,uint64)uint64
*abi_route_getPoolAppId:
	// The ABI return prefix
	byte 0x151f7c75

	// poolId: uint64
	txna ApplicationArgs 2
	btoi

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute getPoolAppId(uint64,uint64)uint64
	callsub getPoolAppId
	itob
	concat
	log
	int 1
	return

// getPoolAppId(validatorId: uint64, poolId: uint64): uint64
getPoolAppId:
	proto 2 1

	// examples/reti/validatorRegistry.algo.ts:335
	// assert(
	//       poolId !== 0 && poolId <= this.validatorList(validatorId).value.pools.length,
	//       'pool id must be between 1 and number of pools for this validator'
	//     )
	frame_dig -2 // poolId: uint64
	int 0
	!=
	dup
	bz *skip_and0
	frame_dig -2 // poolId: uint64
	int 24
	<=
	&&

*skip_and0:
	// pool id must be between 1 and number of pools for this validator
	assert

	// examples/reti/validatorRegistry.algo.ts:339
	// return this.validatorList(validatorId).value.pools[poolId - 1].poolAppId;
	int 268 // headOffset
	frame_dig -2 // poolId: uint64
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 0
	+
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: uint64
	itob
	concat
	cover 2
	box_extract
	btoi
	retsub

// getPoolInfo((uint64,uint64,uint64))(uint64,uint16,uint64)
*abi_route_getPoolInfo:
	// The ABI return prefix
	byte 0x151f7c75

	// poolKey: (uint64,uint64,uint64)
	txna ApplicationArgs 1
	dup
	len
	int 24
	==

	// argument 0 (poolKey) for getPoolInfo must be a (uint64,uint64,uint64)
	assert

	// execute getPoolInfo((uint64,uint64,uint64))(uint64,uint16,uint64)
	callsub getPoolInfo
	concat
	log
	int 1
	return

// getPoolInfo(poolKey: ValidatorPoolKey): PoolInfo
getPoolInfo:
	proto 1 1

	// examples/reti/validatorRegistry.algo.ts:344
	// return this.validatorList(poolKey.id).value.pools[poolKey.poolId - 1];
	int 268 // headOffset
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 18
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	retsub

// getCurMaxStakePerPool(uint64)uint64
*abi_route_getCurMaxStakePerPool:
	// The ABI return prefix
	byte 0x151f7c75

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute getCurMaxStakePerPool(uint64)uint64
	callsub getCurMaxStakePerPool
	itob
	concat
	log
	int 1
	return

// getCurMaxStakePerPool(validatorId: ValidatorIdType): uint64
//
// Calculate the maximum stake per pool for a given validator.
// Normally this would be maxAlgoPerPool, but it should also never go above MaxAllowedStake / numPools so
// as pools are added the max allowed per pool can reduce.
//
// @param {ValidatorIdType} validatorId - The id of the validator.
getCurMaxStakePerPool:
	proto 1 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// examples/reti/validatorRegistry.algo.ts:355
	// numPools = this.validatorList(validatorId).value.state.numPools as uint64
	int 242
	int 2
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 0 // numPools: uint64

	// examples/reti/validatorRegistry.algo.ts:356
	// hardMaxDividedBetweenPools = this.maxAllowedStake() / numPools
	callsub maxAllowedStake
	frame_dig 0 // numPools: uint64
	/
	frame_bury 1 // hardMaxDividedBetweenPools: uint64

	// examples/reti/validatorRegistry.algo.ts:357
	// maxPerPool: uint64 = this.validatorList(validatorId).value.config.maxAlgoPerPool
	pushint 217
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 2 // maxPerPool: uint64

	// *if1_condition
	// examples/reti/validatorRegistry.algo.ts:358
	// maxPerPool === 0
	frame_dig 2 // maxPerPool: uint64
	int 0
	==
	bz *if1_end

	// *if1_consequent
	// examples/reti/validatorRegistry.algo.ts:359
	// maxPerPool = this.maxAlgoAllowedPerPool()
	callsub maxAlgoAllowedPerPool
	frame_bury 2 // maxPerPool: uint64

*if1_end:
	// *if2_condition
	// examples/reti/validatorRegistry.algo.ts:361
	// hardMaxDividedBetweenPools < maxPerPool
	frame_dig 1 // hardMaxDividedBetweenPools: uint64
	frame_dig 2 // maxPerPool: uint64
	<
	bz *if2_end

	// *if2_consequent
	// examples/reti/validatorRegistry.algo.ts:362
	// maxPerPool = hardMaxDividedBetweenPools
	frame_dig 1 // hardMaxDividedBetweenPools: uint64
	frame_bury 2 // maxPerPool: uint64

*if2_end:
	// examples/reti/validatorRegistry.algo.ts:364
	// return maxPerPool;
	frame_dig 2 // maxPerPool: uint64

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 2
	retsub

// doesStakerNeedToPayMBR(address)bool
*abi_route_doesStakerNeedToPayMBR:
	// The ABI return prefix
	byte 0x151f7c75

	// staker: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (staker) for doesStakerNeedToPayMBR must be a address
	assert

	// execute doesStakerNeedToPayMBR(address)bool
	callsub doesStakerNeedToPayMBR
	byte 0x00
	int 0
	uncover 2
	setbit
	concat
	log
	int 1
	return

// doesStakerNeedToPayMBR(staker: Address): boolean
//
// Helper callers can call w/ simulate to determine if 'AddStaker' MBR should be included w/ staking amount
// @param staker
doesStakerNeedToPayMBR:
	proto 1 1

	// examples/reti/validatorRegistry.algo.ts:373
	// return !this.stakerPoolSet(staker).exists;
	byte 0x737073 // "sps"
	frame_dig -1 // staker: Address
	concat
	box_len
	swap
	pop
	!
	retsub

// getStakedPoolsForAccount(address)(uint64,uint64,uint64)[]
*abi_route_getStakedPoolsForAccount:
	// The ABI return prefix
	byte 0x151f7c75

	// staker: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (staker) for getStakedPoolsForAccount must be a address
	assert

	// execute getStakedPoolsForAccount(address)(uint64,uint64,uint64)[]
	callsub getStakedPoolsForAccount
	dup
	len
	int 24
	/
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// getStakedPoolsForAccount(staker: Address): ValidatorPoolKey[]
//
// Retrieves the staked pools for an account.
//
// @param {Address} staker - The account to retrieve staked pools for.
// @return {ValidatorPoolKey[]} - The array of staked pools for the account.
getStakedPoolsForAccount:
	proto 1 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// *if3_condition
	// examples/reti/validatorRegistry.algo.ts:383
	// !this.stakerPoolSet(staker).exists
	byte 0x737073 // "sps"
	frame_dig -1 // staker: Address
	concat
	box_len
	swap
	pop
	!
	bz *if3_end

	// *if3_consequent
	// examples/reti/validatorRegistry.algo.ts:384
	// return [];
	byte 0x
	b *getStakedPoolsForAccount*return

*if3_end:
	// examples/reti/validatorRegistry.algo.ts:386
	// retData: ValidatorPoolKey[] = []
	byte 0x
	frame_bury 0 // retData: ValidatorPoolKey[]

	// examples/reti/validatorRegistry.algo.ts:387
	// poolSet = clone(this.stakerPoolSet(staker).value)
	byte 0x737073 // "sps"
	frame_dig -1 // staker: Address
	concat
	box_get

	// box value does not exist: this.stakerPoolSet(staker).value
	assert
	frame_bury 1 // poolSet: (uint64,uint64,uint64)[6]

	// examples/reti/validatorRegistry.algo.ts:388
	// for (let i = 0; i < poolSet.length; i += 1)
	int 0
	frame_bury 2 // i: uint64

*for_1:
	// examples/reti/validatorRegistry.algo.ts:388
	// i < poolSet.length
	frame_dig 2 // i: uint64
	int 6
	<
	bz *for_1_end

	// *if4_condition
	// examples/reti/validatorRegistry.algo.ts:389
	// poolSet[i].id !== 0
	frame_dig 1 // poolSet: (uint64,uint64,uint64)[6]
	frame_dig 2 // i: uint64
	int 24
	* // acc * typeLength
	int 0
	+
	int 8
	extract3
	btoi
	int 0
	!=
	bz *if4_end

	// *if4_consequent
	// examples/reti/validatorRegistry.algo.ts:390
	// retData.push(poolSet[i])
	frame_dig 0 // retData: ValidatorPoolKey[]
	frame_dig 1 // poolSet: (uint64,uint64,uint64)[6]
	frame_dig 2 // i: uint64
	int 24
	* // acc * typeLength
	int 24
	extract3
	concat
	frame_bury 0 // retData: ValidatorPoolKey[]

*if4_end:

*for_1_continue:
	// examples/reti/validatorRegistry.algo.ts:388
	// i += 1
	frame_dig 2 // i: uint64
	int 1
	+
	frame_bury 2 // i: uint64
	b *for_1

*for_1_end:
	// examples/reti/validatorRegistry.algo.ts:393
	// return retData;
	frame_dig 0 // retData: ValidatorPoolKey[]

*getStakedPoolsForAccount*return:
	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 2
	retsub

// getTokenPayoutRatio(uint64)(uint64[24],uint64)
*abi_route_getTokenPayoutRatio:
	// The ABI return prefix
	byte 0x151f7c75

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute getTokenPayoutRatio(uint64)(uint64[24],uint64)
	callsub getTokenPayoutRatio
	concat
	log
	int 1
	return

// getTokenPayoutRatio(validatorId: ValidatorIdType): PoolTokenPayoutRatio
//
// Retrieves the token payout ratio for a given validator - returning the pool ratios of whole so that token
// payouts across pools can be based on a stable snaphost of stake.
//
// @param {ValidatorIdType} validatorId - The id of the validator.
// @return {PoolTokenPayoutRatio} - The token payout ratio for the validator.
getTokenPayoutRatio:
	proto 1 1

	// examples/reti/validatorRegistry.algo.ts:405
	// return this.validatorList(validatorId).value.tokenPayoutRatio;
	int 700 // headOffset
	pushint 200
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	retsub

// getNodePoolAssignments(uint64)((uint64[3])[8])
*abi_route_getNodePoolAssignments:
	// The ABI return prefix
	byte 0x151f7c75

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute getNodePoolAssignments(uint64)((uint64[3])[8])
	callsub getNodePoolAssignments
	concat
	log
	int 1
	return

// getNodePoolAssignments(validatorId: uint64): NodePoolAssignmentConfig
getNodePoolAssignments:
	proto 1 1

	// examples/reti/validatorRegistry.algo.ts:410
	// assert(this.validatorList(validatorId).exists, "the specified validator id doesn't exist")
	byte 0x76 // "v"
	frame_dig -1 // validatorId: uint64
	itob
	concat
	box_len
	swap
	pop

	// the specified validator id doesn't exist
	assert

	// examples/reti/validatorRegistry.algo.ts:412
	// return this.validatorList(validatorId).value.nodePoolAssignments;
	int 900 // headOffset
	pushint 192
	byte 0x76 // "v"
	frame_dig -1 // validatorId: uint64
	itob
	concat
	cover 2
	box_extract
	retsub

// getNFDRegistryID()uint64
*abi_route_getNFDRegistryID:
	// The ABI return prefix
	byte 0x151f7c75

	// execute getNFDRegistryID()uint64
	callsub getNFDRegistryID
	itob
	concat
	log
	int 1
	return

// getNFDRegistryID(): uint64
getNFDRegistryID:
	proto 0 1

	// examples/reti/validatorRegistry.algo.ts:416
	// return this.nfdRegistryAppId;
	intc 0 // TMPL_nfdRegistryAppId
	retsub

// addValidator(pay,string,(uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64))uint64
*abi_route_addValidator:
	// The ABI return prefix
	byte 0x151f7c75

	// config: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	txna ApplicationArgs 2
	dup
	len
	int 242
	==

	// argument 0 (config) for addValidator must be a (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	assert

	// nfdName: string
	txna ApplicationArgs 1
	extract 2 0

	// mbrPayment: pay
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// argument 2 (mbrPayment) for addValidator must be a pay transaction
	assert

	// execute addValidator(pay,string,(uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64))uint64
	callsub addValidator
	itob
	concat
	log
	int 1
	return

// addValidator(mbrPayment: PayTxn, nfdName: string, config: ValidatorConfig): uint64
//
// Adds a new validator
// Requires at least 10 ALGO as the 'fee' for the transaction to help dissuade spammed validator adds.
//
// @param {PayTxn} mbrPayment payment from caller which covers mbr increase of new validator storage
// @param {string} nfdName (Optional) Name of nfd (used as double-check against id specified in config)
// @param {ValidatorConfig} config ValidatorConfig struct
// @returns {uint64} validator id
addValidator:
	proto 3 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/reti/validatorRegistry.algo.ts:428
	// this.validateConfig(config)
	frame_dig -3 // config: ValidatorConfig
	callsub validateConfig

	// examples/reti/validatorRegistry.algo.ts:429
	// assert(config.owner !== Address.zeroAddress)
	frame_dig -3 // config: ValidatorConfig
	extract 8 32
	global ZeroAddress
	!=
	assert

	// examples/reti/validatorRegistry.algo.ts:430
	// assert(config.manager !== Address.zeroAddress)
	frame_dig -3 // config: ValidatorConfig
	extract 40 32
	global ZeroAddress
	!=
	assert

	// examples/reti/validatorRegistry.algo.ts:431
	// assert(this.txn.sender === config.owner, 'sender must be owner to add new validator')
	txn Sender
	frame_dig -3 // config: ValidatorConfig
	extract 8 32
	==

	// sender must be owner to add new validator
	assert

	// examples/reti/validatorRegistry.algo.ts:433
	// verifyPayTxn(mbrPayment, { amount: this.getMbrAmounts().addValidatorMbr })
	// verify amount
	frame_dig -1 // mbrPayment: PayTxn
	gtxns Amount
	callsub getMbrAmounts
	extract 0 8
	btoi
	==

	// transaction verification failed: {"txn":"mbrPayment","field":"amount","expected":"this.getMbrAmounts().addValidatorMbr"}
	assert

	// examples/reti/validatorRegistry.algo.ts:435
	// assert(mbrPayment.fee > 10 * 1000000, 'fee must be 10 ALGO or more to prevent spamming of validators')
	frame_dig -1 // mbrPayment: PayTxn
	gtxns Fee
	pushint 10000000
	>

	// fee must be 10 ALGO or more to prevent spamming of validators
	assert

	// examples/reti/validatorRegistry.algo.ts:438
	// validatorId = this.numValidators.value + 1
	byte 0x6e756d56 // "numV"
	app_global_get
	int 1
	+
	frame_bury 0 // validatorId: uint64

	// examples/reti/validatorRegistry.algo.ts:439
	// this.numValidators.value = validatorId
	byte 0x6e756d56 // "numV"
	frame_dig 0 // validatorId: uint64
	app_global_put

	// examples/reti/validatorRegistry.algo.ts:441
	// this.validatorList(validatorId).create()
	byte 0x76 // "v"
	frame_dig 0 // validatorId: uint64
	itob
	concat
	pushint 1092
	box_create
	pop

	// examples/reti/validatorRegistry.algo.ts:442
	// this.validatorList(validatorId).value.config = config
	int 0
	frame_dig -3 // config: ValidatorConfig
	byte 0x76 // "v"
	frame_dig 0 // validatorId: uint64
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:443
	// this.validatorList(validatorId).value.config.id = validatorId
	int 0
	frame_dig 0 // validatorId: uint64
	itob
	byte 0x76 // "v"
	frame_dig 0 // validatorId: uint64
	itob
	concat
	cover 2
	box_replace

	// *if5_condition
	// examples/reti/validatorRegistry.algo.ts:446
	// config.nfdForInfo !== 0
	frame_dig -3 // config: ValidatorConfig
	extract 72 8
	btoi
	int 0
	!=
	bz *if5_end

	// *if5_consequent
	// examples/reti/validatorRegistry.algo.ts:448
	// sendAppCall({
	//         applicationID: AppID.fromUint64(this.nfdRegistryAppId),
	//         applicationArgs: ['is_valid_nfd_appid', nfdName, itob(config.nfdForInfo)],
	//         applications: [AppID.fromUint64(config.nfdForInfo)],
	//       })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum

	// examples/reti/validatorRegistry.algo.ts:449
	// applicationID: AppID.fromUint64(this.nfdRegistryAppId)
	intc 0 // TMPL_nfdRegistryAppId
	itxn_field ApplicationID

	// examples/reti/validatorRegistry.algo.ts:450
	// applicationArgs: ['is_valid_nfd_appid', nfdName, itob(config.nfdForInfo)]
	byte 0x69735f76616c69645f6e66645f6170706964 // "is_valid_nfd_appid"
	itxn_field ApplicationArgs
	frame_dig -2 // nfdName: string
	itxn_field ApplicationArgs
	frame_dig -3 // config: ValidatorConfig
	extract 72 8
	btoi
	itob
	itxn_field ApplicationArgs

	// examples/reti/validatorRegistry.algo.ts:451
	// applications: [AppID.fromUint64(config.nfdForInfo)]
	frame_dig -3 // config: ValidatorConfig
	extract 72 8
	btoi
	itxn_field Applications

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/validatorRegistry.algo.ts:453
	// assert(btoi(this.itxn.lastLog) === 1, "provided NFD isn't valid")
	itxn LastLog
	btoi
	int 1
	==

	// provided NFD isn't valid
	assert

	// examples/reti/validatorRegistry.algo.ts:455
	// assert(
	//         this.txn.sender === (AppID.fromUint64(config.nfdForInfo).globalState('i.owner.a') as Address),
	//         'If specifying NFD, account adding validator must be owner'
	//       )
	txn Sender
	frame_dig -3 // config: ValidatorConfig
	extract 72 8
	btoi
	byte 0x692e6f776e65722e61 // "i.owner.a"
	app_global_get_ex

	// global state value does not exist: AppID.fromUint64(config.nfdForInfo).globalState('i.owner.a')
	assert
	==

	// If specifying NFD, account adding validator must be owner
	assert

*if5_end:
	// *if6_condition
	// examples/reti/validatorRegistry.algo.ts:461
	// config.entryGatingType === GATING_TYPE_CREATED_BY_NFD_ADDRESSES ||
	//       config.entryGatingType === GATING_TYPE_SEGMENT_OF_NFD
	frame_dig -3 // config: ValidatorConfig
	extract 80 1
	btoi
	int 3
	==
	dup
	bnz *skip_or0
	frame_dig -3 // config: ValidatorConfig
	extract 80 1
	btoi
	pushint 4
	==
	||

*skip_or0:
	bz *if6_end

	// *if6_consequent
	// examples/reti/validatorRegistry.algo.ts:465
	// assert(this.isNFDAppIDValid(config.entryGatingAssets[0]), 'provided NFD App id for gating must be valid NFD')
	frame_dig -3 // config: ValidatorConfig
	extract 113 8
	btoi
	callsub isNFDAppIDValid

	// provided NFD App id for gating must be valid NFD
	assert

*if6_end:
	// examples/reti/validatorRegistry.algo.ts:468
	// return validatorId;
	frame_dig 0 // validatorId: uint64

	// set the subroutine return value
	frame_bury 0
	retsub

// changeValidatorManager(uint64,address)void
*abi_route_changeValidatorManager:
	// manager: address
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (manager) for changeValidatorManager must be a address
	assert

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute changeValidatorManager(uint64,address)void
	callsub changeValidatorManager
	int 1
	return

// changeValidatorManager(validatorId: ValidatorIdType, manager: Address): void
//
// Changes the Validator manager for a specific Validator id.
// [ ONLY OWNER CAN CHANGE ]
//
// @param {ValidatorIdType} validatorId - The id of the validator to change the manager for.
// @param {Address} manager - The new manager address.
changeValidatorManager:
	proto 2 0

	// examples/reti/validatorRegistry.algo.ts:479
	// assert(
	//       this.txn.sender === this.validatorList(validatorId).value.config.owner,
	//       'can only be called by validator owner'
	//     )
	txn Sender
	int 8
	int 32
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	==

	// can only be called by validator owner
	assert

	// examples/reti/validatorRegistry.algo.ts:483
	// this.validatorList(validatorId).value.config.manager = manager
	pushint 40
	frame_dig -2 // manager: Address
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace
	retsub

// changeValidatorSunsetInfo(uint64,uint64,uint64)void
*abi_route_changeValidatorSunsetInfo:
	// sunsettingTo: uint64
	txna ApplicationArgs 3
	btoi

	// sunsettingOn: uint64
	txna ApplicationArgs 2
	btoi

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute changeValidatorSunsetInfo(uint64,uint64,uint64)void
	callsub changeValidatorSunsetInfo
	int 1
	return

// changeValidatorSunsetInfo(validatorId: ValidatorIdType, sunsettingOn: uint64, sunsettingTo: ValidatorIdType): void
//
// Updates the sunset information for a given validator.
// [ ONLY OWNER CAN CHANGE ]
//
// @param {ValidatorIdType} validatorId - The id of the validator to update.
// @param {uint64} sunsettingOn - The new sunset timestamp.
// @param {uint64} sunsettingTo - The new sunset to validator id.
changeValidatorSunsetInfo:
	proto 3 0

	// examples/reti/validatorRegistry.algo.ts:495
	// assert(
	//       this.txn.sender === this.validatorList(validatorId).value.config.owner,
	//       'can only be called by validator owner'
	//     )
	txn Sender
	int 8
	int 32
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	==

	// can only be called by validator owner
	assert

	// examples/reti/validatorRegistry.algo.ts:499
	// this.validatorList(validatorId).value.config.sunsettingOn = sunsettingOn
	pushint 226
	frame_dig -2 // sunsettingOn: uint64
	itob
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:500
	// this.validatorList(validatorId).value.config.sunsettingTo = sunsettingTo
	pushint 234
	frame_dig -3 // sunsettingTo: ValidatorIdType
	itob
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace
	retsub

// changeValidatorNFD(uint64,uint64,string)void
*abi_route_changeValidatorNFD:
	// nfdName: string
	txna ApplicationArgs 3
	extract 2 0

	// nfdAppID: uint64
	txna ApplicationArgs 2
	btoi

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute changeValidatorNFD(uint64,uint64,string)void
	callsub changeValidatorNFD
	int 1
	return

// changeValidatorNFD(validatorId: ValidatorIdType, nfdAppID: uint64, nfdName: string): void
//
// Changes the NFD for a validator in the validatorList contract.
// [ ONLY OWNER CAN CHANGE ]
//
// @param {ValidatorIdType} validatorId - The id of the validator to update.
// @param {uint64} nfdAppID - The application id of the NFD to assign to the validator.
// @param {string} nfdName - The name of the NFD (which must match)
changeValidatorNFD:
	proto 3 0

	// examples/reti/validatorRegistry.algo.ts:513
	// assert(
	//       this.txn.sender === this.validatorList(validatorId).value.config.owner,
	//       'can only be called by validator owner'
	//     )
	txn Sender
	int 8
	int 32
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	==

	// can only be called by validator owner
	assert

	// examples/reti/validatorRegistry.algo.ts:518
	// sendAppCall({
	//       applicationID: AppID.fromUint64(this.nfdRegistryAppId),
	//       applicationArgs: ['is_valid_nfd_appid', nfdName, itob(nfdAppID)],
	//       applications: [AppID.fromUint64(nfdAppID)],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum

	// examples/reti/validatorRegistry.algo.ts:519
	// applicationID: AppID.fromUint64(this.nfdRegistryAppId)
	intc 0 // TMPL_nfdRegistryAppId
	itxn_field ApplicationID

	// examples/reti/validatorRegistry.algo.ts:520
	// applicationArgs: ['is_valid_nfd_appid', nfdName, itob(nfdAppID)]
	byte 0x69735f76616c69645f6e66645f6170706964 // "is_valid_nfd_appid"
	itxn_field ApplicationArgs
	frame_dig -3 // nfdName: string
	itxn_field ApplicationArgs
	frame_dig -2 // nfdAppID: uint64
	itob
	itxn_field ApplicationArgs

	// examples/reti/validatorRegistry.algo.ts:521
	// applications: [AppID.fromUint64(nfdAppID)]
	frame_dig -2 // nfdAppID: uint64
	itxn_field Applications

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/validatorRegistry.algo.ts:524
	// assert(
	//       this.txn.sender === (AppID.fromUint64(nfdAppID).globalState('i.owner.a') as Address),
	//       'If specifying NFD, account adding validator must be owner'
	//     )
	txn Sender
	frame_dig -2 // nfdAppID: uint64
	byte 0x692e6f776e65722e61 // "i.owner.a"
	app_global_get_ex

	// global state value does not exist: AppID.fromUint64(nfdAppID).globalState('i.owner.a')
	assert
	==

	// If specifying NFD, account adding validator must be owner
	assert

	// examples/reti/validatorRegistry.algo.ts:528
	// this.validatorList(validatorId).value.config.nfdForInfo = nfdAppID
	pushint 72
	frame_dig -2 // nfdAppID: uint64
	itob
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace
	retsub

// changeValidatorCommissionAddress(uint64,address)void
*abi_route_changeValidatorCommissionAddress:
	// commissionAddress: address
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (commissionAddress) for changeValidatorCommissionAddress must be a address
	assert

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute changeValidatorCommissionAddress(uint64,address)void
	callsub changeValidatorCommissionAddress
	int 1
	return

// changeValidatorCommissionAddress(validatorId: ValidatorIdType, commissionAddress: Address): void
//
// Change the commission address that validator rewards are sent to.
// [ ONLY OWNER CAN CHANGE ]
changeValidatorCommissionAddress:
	proto 2 0

	// examples/reti/validatorRegistry.algo.ts:536
	// assert(
	//       this.txn.sender === this.validatorList(validatorId).value.config.owner,
	//       'can only be called by validator owner'
	//     )
	txn Sender
	int 8
	int 32
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	==

	// can only be called by validator owner
	assert

	// examples/reti/validatorRegistry.algo.ts:540
	// assert(commissionAddress !== Address.zeroAddress)
	frame_dig -2 // commissionAddress: Address
	global ZeroAddress
	!=
	assert

	// examples/reti/validatorRegistry.algo.ts:541
	// this.validatorList(validatorId).value.config.validatorCommissionAddress = commissionAddress
	pushint 177
	frame_dig -2 // commissionAddress: Address
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace
	retsub

// changeValidatorRewardInfo(uint64,uint8,address,uint64[4],uint64,uint64)void
*abi_route_changeValidatorRewardInfo:
	// RewardPerPayout: uint64
	txna ApplicationArgs 6
	btoi

	// GatingAssetMinBalance: uint64
	txna ApplicationArgs 5
	btoi

	// EntryGatingAssets: uint64[4]
	txna ApplicationArgs 4
	dup
	len
	int 32
	==

	// argument 2 (EntryGatingAssets) for changeValidatorRewardInfo must be a uint64[4]
	assert

	// EntryGatingAddress: address
	txna ApplicationArgs 3
	dup
	len
	int 32
	==

	// argument 3 (EntryGatingAddress) for changeValidatorRewardInfo must be a address
	assert

	// EntryGatingType: uint8
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 4 (EntryGatingType) for changeValidatorRewardInfo must be a uint8
	assert
	btoi

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute changeValidatorRewardInfo(uint64,uint8,address,uint64[4],uint64,uint64)void
	callsub changeValidatorRewardInfo
	int 1
	return

// changeValidatorRewardInfo(validatorId: ValidatorIdType, EntryGatingType: uint8, EntryGatingAddress: Address, EntryGatingAssets: StaticArray<uint64, 4>, GatingAssetMinBalance: uint64, RewardPerPayout: uint64): void
//
// Allow the additional rewards (gating entry, additional token rewards) information be changed at will.
// [ ONLY OWNER CAN CHANGE ]
changeValidatorRewardInfo:
	proto 6 0

	// examples/reti/validatorRegistry.algo.ts:556
	// assert(
	//       this.txn.sender === this.validatorList(validatorId).value.config.owner,
	//       'can only be called by validator owner'
	//     )
	txn Sender
	int 8
	int 32
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	==

	// can only be called by validator owner
	assert

	// examples/reti/validatorRegistry.algo.ts:561
	// this.validatorList(validatorId).value.config.entryGatingType = EntryGatingType
	pushint 80
	frame_dig -2 // EntryGatingType: uint8
	itob
	extract 7 1
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:562
	// this.validatorList(validatorId).value.config.entryGatingAddress = EntryGatingAddress
	pushint 81
	frame_dig -3 // EntryGatingAddress: Address
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:563
	// this.validatorList(validatorId).value.config.entryGatingAssets = EntryGatingAssets
	pushint 113
	frame_dig -4 // EntryGatingAssets: StaticArray<uint64, 4>
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:564
	// this.validatorList(validatorId).value.config.gatingAssetMinBalance = GatingAssetMinBalance
	pushint 145
	frame_dig -5 // GatingAssetMinBalance: uint64
	itob
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:565
	// this.validatorList(validatorId).value.config.rewardPerPayout = RewardPerPayout
	pushint 161
	frame_dig -6 // RewardPerPayout: uint64
	itob
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace
	retsub

// addPool(pay,uint64,uint64)(uint64,uint64,uint64)
*abi_route_addPool:
	// The ABI return prefix
	byte 0x151f7c75

	// nodeNum: uint64
	txna ApplicationArgs 2
	btoi

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// mbrPayment: pay
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// argument 2 (mbrPayment) for addPool must be a pay transaction
	assert

	// execute addPool(pay,uint64,uint64)(uint64,uint64,uint64)
	callsub addPool
	concat
	log
	int 1
	return

// addPool(mbrPayment: PayTxn, validatorId: ValidatorIdType, nodeNum: uint64): ValidatorPoolKey
//
// Adds a new pool to a validator's pool set, returning the 'key' to reference the pool in the future for staking, etc.
// The caller must pay the cost of the validators MBR increase as well as the MBR that will be needed for the pool itself.
//
// [ ONLY OWNER OR MANAGER CAN call ]
// @param {PayTxn} mbrPayment payment from caller which covers mbr increase of adding a new pool
// @param {uint64} validatorId is id of validator to pool to (must be owner or manager)
// @param {uint64} nodeNum is node number to add to
// @returns {ValidatorPoolKey} pool key to created pool
addPool:
	proto 3 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// examples/reti/validatorRegistry.algo.ts:581
	// assert(
	//       this.txn.sender === this.validatorList(validatorId).value.config.owner ||
	//         this.txn.sender === this.validatorList(validatorId).value.config.manager,
	//       'can only be called by owner or manager of validator'
	//     )
	txn Sender
	int 8
	int 32
	byte 0x76 // "v"
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	==
	dup
	bnz *skip_or1
	txn Sender
	pushint 40
	int 32
	byte 0x76 // "v"
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	==
	||

*skip_or1:
	// can only be called by owner or manager of validator
	assert

	// examples/reti/validatorRegistry.algo.ts:588
	// verifyPayTxn(mbrPayment, { amount: this.getMbrAmounts().addPoolMbr, receiver: this.app.address })
	// verify amount
	frame_dig -1 // mbrPayment: PayTxn
	gtxns Amount
	callsub getMbrAmounts
	extract 8 8
	btoi
	==

	// transaction verification failed: {"txn":"mbrPayment","field":"amount","expected":"this.getMbrAmounts().addPoolMbr"}
	assert

	// verify receiver
	frame_dig -1 // mbrPayment: PayTxn
	gtxns Receiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"mbrPayment","field":"receiver","expected":"this.app.address"}
	assert

	// examples/reti/validatorRegistry.algo.ts:590
	// assert(this.validatorList(validatorId).exists, "specified validator id isn't valid")
	byte 0x76 // "v"
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	concat
	box_len
	swap
	pop

	// specified validator id isn't valid
	assert

	// examples/reti/validatorRegistry.algo.ts:592
	// numPools: uint64 = this.validatorList(validatorId).value.state.numPools as uint64
	int 242
	int 2
	byte 0x76 // "v"
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 0 // numPools: uint64

	// *if7_condition
	// examples/reti/validatorRegistry.algo.ts:593
	// (numPools as uint64) >= MAX_POOLS
	frame_dig 0 // numPools: uint64
	int 24
	>=
	bz *if7_end

	// *if7_consequent
	// already at max pool size
	err

*if7_end:
	// examples/reti/validatorRegistry.algo.ts:596
	// numPools += 1
	frame_dig 0 // numPools: uint64
	int 1
	+
	frame_bury 0 // numPools: uint64

	// examples/reti/validatorRegistry.algo.ts:599
	// sendAppCall({
	//       onCompletion: OnCompletion.NoOp,
	//       approvalProgram: [
	//         this.stakingPoolApprovalProgram.extract(0, 4096),
	//         this.stakingPoolApprovalProgram.extract(4096, this.stakingPoolApprovalProgram.size - 4096),
	//       ],
	//       clearStateProgram: StakingPool.clearProgram(),
	//       globalNumUint: StakingPool.schema.global.numUint,
	//       globalNumByteSlice: StakingPool.schema.global.numByteSlice,
	//       extraProgramPages: 3,
	//       applicationArgs: [
	//         // creatingContractID, validatorId, poolId, minEntryStake
	//         method('createApplication(uint64,uint64,uint64,uint64)void'),
	//         itob(this.app.id),
	//         itob(validatorId),
	//         itob(numPools as uint64),
	//         itob(this.validatorList(validatorId).value.config.minEntryStake),
	//       ],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum

	// examples/reti/validatorRegistry.algo.ts:600
	// onCompletion: OnCompletion.NoOp
	int 0 // NoOp
	itxn_field OnCompletion

	// examples/reti/validatorRegistry.algo.ts:601
	// approvalProgram: [
	//         this.stakingPoolApprovalProgram.extract(0, 4096),
	//         this.stakingPoolApprovalProgram.extract(4096, this.stakingPoolApprovalProgram.size - 4096),
	//       ]
	byte 0x706f6f6c54656d706c617465417070726f76616c4279746573 // "poolTemplateApprovalBytes"
	int 0
	pushint 4096
	box_extract
	itxn_field ApprovalProgramPages
	byte 0x706f6f6c54656d706c617465417070726f76616c4279746573 // "poolTemplateApprovalBytes"
	pushint 4096
	byte 0x706f6f6c54656d706c617465417070726f76616c4279746573 // "poolTemplateApprovalBytes"
	box_len

	// box value does not exist: this.stakingPoolApprovalProgram.size
	assert
	pushint 4096
	-
	box_extract
	itxn_field ApprovalProgramPages

	// examples/reti/validatorRegistry.algo.ts:605
	// clearStateProgram: StakingPool.clearProgram()
	pushbytes 0x0a
	itxn_field ClearStateProgram

	// examples/reti/validatorRegistry.algo.ts:606
	// globalNumUint: StakingPool.schema.global.numUint
	pushint 11
	itxn_field GlobalNumUint

	// examples/reti/validatorRegistry.algo.ts:607
	// globalNumByteSlice: StakingPool.schema.global.numByteSlice
	int 3
	itxn_field GlobalNumByteSlice

	// examples/reti/validatorRegistry.algo.ts:608
	// extraProgramPages: 3
	int 3
	itxn_field ExtraProgramPages

	// examples/reti/validatorRegistry.algo.ts:609
	// applicationArgs: [
	//         // creatingContractID, validatorId, poolId, minEntryStake
	//         method('createApplication(uint64,uint64,uint64,uint64)void'),
	//         itob(this.app.id),
	//         itob(validatorId),
	//         itob(numPools as uint64),
	//         itob(this.validatorList(validatorId).value.config.minEntryStake),
	//       ]
	pushbytes 0x59e90aa6 // method "createApplication(uint64,uint64,uint64,uint64)void"
	itxn_field ApplicationArgs
	txna Applications 0
	itob
	itxn_field ApplicationArgs
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	itxn_field ApplicationArgs
	frame_dig 0 // numPools: uint64
	itob
	itxn_field ApplicationArgs
	pushint 209
	int 8
	byte 0x76 // "v"
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/validatorRegistry.algo.ts:619
	// this.validatorList(validatorId).value.state.numPools = numPools as uint16
	int 242
	frame_dig 0 // numPools: uint64
	itob
	extract 6 2
	byte 0x76 // "v"
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:622
	// poolAppId = this.itxn.createdApplicationID.id
	itxn CreatedApplicationID
	frame_bury 1 // poolAppId: uint64

	// examples/reti/validatorRegistry.algo.ts:623
	// this.validatorList(validatorId).value.pools[numPools - 1].poolAppId = poolAppId
	int 268 // headOffset
	frame_dig 0 // numPools: uint64
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 0
	+
	frame_dig 1 // poolAppId: uint64
	itob
	byte 0x76 // "v"
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:624
	// this.addPoolToNode(validatorId, poolAppId, nodeNum)
	frame_dig -3 // nodeNum: uint64
	frame_dig 1 // poolAppId: uint64
	frame_dig -2 // validatorId: ValidatorIdType
	callsub addPoolToNode

	// examples/reti/validatorRegistry.algo.ts:632
	// return { id: validatorId, poolId: numPools as uint64, poolAppId: this.itxn!.createdApplicationID.id };
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	frame_dig 0 // numPools: uint64
	itob
	concat
	itxn CreatedApplicationID
	itob
	concat

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 1
	retsub

// addStake(pay,uint64,uint64)(uint64,uint64,uint64)
*abi_route_addStake:
	// The ABI return prefix
	byte 0x151f7c75

	// valueToVerify: uint64
	txna ApplicationArgs 2
	btoi

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// stakedAmountPayment: pay
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// argument 2 (stakedAmountPayment) for addStake must be a pay transaction
	assert

	// execute addStake(pay,uint64,uint64)(uint64,uint64,uint64)
	callsub addStake
	concat
	log
	int 1
	return

// addStake(stakedAmountPayment: PayTxn, validatorId: ValidatorIdType, valueToVerify: uint64): ValidatorPoolKey
//
// Adds stake to a validator pool.
//
// @param {PayTxn} stakedAmountPayment - payment coming from staker to place into a pool
// @param {ValidatorIdType} validatorId - The id of the validator.
// @param {uint64} valueToVerify - only if validator has gating to enter - this is asset id or nfd id that corresponds to gating.
// Txn sender is factored in as well if that is part of gating.
// * @returns {ValidatorPoolKey} - The key of the validator pool.
addStake:
	proto 3 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 5

	// examples/reti/validatorRegistry.algo.ts:645
	// assert(this.validatorList(validatorId).exists, "specified validator id isn't valid")
	byte 0x76 // "v"
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	concat
	box_len
	swap
	pop

	// specified validator id isn't valid
	assert

	// *if8_condition
	// examples/reti/validatorRegistry.algo.ts:648
	// this.validatorList(validatorId).value.config.sunsettingOn > 0
	pushint 226
	int 8
	byte 0x76 // "v"
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	int 0
	>
	bz *if8_end

	// *if8_consequent
	// examples/reti/validatorRegistry.algo.ts:649
	// assert(
	//         this.validatorList(validatorId).value.config.sunsettingOn < globals.latestTimestamp,
	//         "can't stake with a validator that is past its sunsetting time"
	//       )
	pushint 226
	int 8
	byte 0x76 // "v"
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	global LatestTimestamp
	<

	// can't stake with a validator that is past its sunsetting time
	assert

*if8_end:
	// examples/reti/validatorRegistry.algo.ts:655
	// staker = this.txn.sender
	txn Sender
	frame_bury 0 // staker: address

	// examples/reti/validatorRegistry.algo.ts:659
	// verifyPayTxn(stakedAmountPayment, {
	//       sender: staker,
	//       receiver: this.app.address,
	//     })
	// verify sender
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Sender
	frame_dig 0 // staker: address
	==

	// transaction verification failed: {"txn":"stakedAmountPayment","field":"sender","expected":"staker"}
	assert

	// verify receiver
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Receiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"stakedAmountPayment","field":"receiver","expected":"this.app.address"}
	assert

	// examples/reti/validatorRegistry.algo.ts:666
	// assert(
	//       this.validatorList(validatorId).value.state.totalAlgoStaked < this.maxAllowedStake(),
	//       'total staked for all of a validators pools may not exceed hard cap'
	//     )
	int 252
	int 8
	byte 0x76 // "v"
	frame_dig -2 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	callsub maxAllowedStake
	<

	// total staked for all of a validators pools may not exceed hard cap
	assert

	// examples/reti/validatorRegistry.algo.ts:673
	// this.doesStakerMeetGating(validatorId, valueToVerify)
	frame_dig -3 // valueToVerify: uint64
	frame_dig -2 // validatorId: ValidatorIdType
	callsub doesStakerMeetGating

	// examples/reti/validatorRegistry.algo.ts:675
	// realAmount = stakedAmountPayment.amount
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Amount
	frame_bury 1 // realAmount: uint64

	// examples/reti/validatorRegistry.algo.ts:676
	// mbrAmtLeftBehind: uint64 = 0
	int 0
	frame_bury 2 // mbrAmtLeftBehind: uint64

	// *if9_condition
	// examples/reti/validatorRegistry.algo.ts:678
	// !this.stakerPoolSet(staker).exists
	byte 0x737073 // "sps"
	frame_dig 0 // staker: address
	concat
	box_len
	swap
	pop
	!
	bz *if9_end

	// *if9_consequent
	// examples/reti/validatorRegistry.algo.ts:681
	// mbrAmtLeftBehind = this.getMbrAmounts().addStakerMbr
	callsub getMbrAmounts
	extract 24 8
	btoi
	frame_bury 2 // mbrAmtLeftBehind: uint64

	// examples/reti/validatorRegistry.algo.ts:682
	// realAmount -= mbrAmtLeftBehind
	frame_dig 1 // realAmount: uint64
	frame_dig 2 // mbrAmtLeftBehind: uint64
	-
	frame_bury 1 // realAmount: uint64

	// examples/reti/validatorRegistry.algo.ts:683
	// this.stakerPoolSet(staker).create()
	byte 0x737073 // "sps"
	frame_dig 0 // staker: address
	concat
	pushint 144
	box_create
	pop

*if9_end:
	// examples/reti/validatorRegistry.algo.ts:687
	// findRet = this.findPoolForStaker(validatorId, staker, realAmount)
	frame_dig 1 // realAmount: uint64
	frame_dig 0 // staker: address
	frame_dig -2 // validatorId: ValidatorIdType
	callsub findPoolForStaker
	frame_bury 3 // findRet: ((uint64,uint64,uint64),bool,bool)

	// examples/reti/validatorRegistry.algo.ts:688
	// poolKey = findRet[0]
	// examples/reti/validatorRegistry.algo.ts:689
	// isNewStakerToValidator = findRet[1]
	frame_dig 3 // findRet: ((uint64,uint64,uint64),bool,bool)
	store 255 // full array
	load 255 // full array
	pushint 192
	getbit
	frame_bury 4 // isNewStakerToValidator: bool

	// examples/reti/validatorRegistry.algo.ts:690
	// isNewStakerToProtocol = findRet[2]
	frame_dig 3 // findRet: ((uint64,uint64,uint64),bool,bool)
	store 255 // full array
	load 255 // full array
	pushint 193
	getbit
	frame_bury 5 // isNewStakerToProtocol: bool

	// *if10_condition
	// examples/reti/validatorRegistry.algo.ts:691
	// poolKey.poolId === 0
	frame_dig 3 // findRet: ((uint64,uint64,uint64),bool,bool)
	store 255 // full array
	load 255 // full array
	extract 8 8
	btoi
	int 0
	==
	bz *if10_end

	// *if10_consequent
	// No pool available with free stake.  Validator needs to add another pool
	err

*if10_end:
	// examples/reti/validatorRegistry.algo.ts:696
	// this.updateStakerPoolSet(staker, poolKey)
	frame_dig 3 // findRet: ((uint64,uint64,uint64),bool,bool)
	store 255 // full array
	load 255 // full array
	extract 0 24
	frame_dig 0 // staker: address
	callsub updateStakerPoolSet

	// examples/reti/validatorRegistry.algo.ts:699
	// this.callPoolAddStake(
	//       stakedAmountPayment,
	//       poolKey,
	//       mbrAmtLeftBehind,
	//       isNewStakerToValidator,
	//       isNewStakerToProtocol
	//     )
	frame_dig 5 // isNewStakerToProtocol: bool
	frame_dig 4 // isNewStakerToValidator: bool
	frame_dig 2 // mbrAmtLeftBehind: uint64
	frame_dig 3 // findRet: ((uint64,uint64,uint64),bool,bool)
	store 255 // full array
	load 255 // full array
	extract 0 24
	frame_dig -1 // stakedAmountPayment: PayTxn
	callsub callPoolAddStake

	// examples/reti/validatorRegistry.algo.ts:714
	// return poolKey;
	frame_dig 3 // findRet: ((uint64,uint64,uint64),bool,bool)
	store 255 // full array
	load 255 // full array
	extract 0 24

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 5
	retsub

// setTokenPayoutRatio(uint64)(uint64[24],uint64)
*abi_route_setTokenPayoutRatio:
	// The ABI return prefix
	byte 0x151f7c75

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute setTokenPayoutRatio(uint64)(uint64[24],uint64)
	callsub setTokenPayoutRatio
	concat
	log
	int 1
	return

// setTokenPayoutRatio(validatorId: ValidatorIdType): PoolTokenPayoutRatio
//
// setTokenPayoutRatio is called by Staking Pool # 1 (ONLY) to ask the validator (us) to calculate the ratios
// of stake in the pools for subsequent token payouts (ie: 2 pools, '100' algo total staked, 60 in pool 1, and 40
// in pool 2)  This is done so we have a stable snapshot of stake - taken once per epoch - only triggered by
// pool 1 doing payout.  pools other than 1 doing payout call pool 1 to ask it do it first.
// It would be 60/40% in the poolPctOfWhole values.  The token reward payouts then use these values instead of
// their 'current' stake which changes as part of the payouts themselves (and people could be changing stake
// during the epoch updates across pools)
//
// Multiple pools will call us via pool 1 (pool2->pool1->validator, etc.) so don't assert on pool1 calling multiple
// times in same epoch.  Just return.
//
// @param validatorId - validator id (and thus pool) calling us.  Verified so that sender MUST be pool 1 of this validator.
// @returns PoolTokenPayoutRatio - the finished ratio data
setTokenPayoutRatio:
	proto 1 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 8

	// examples/reti/validatorRegistry.algo.ts:734
	// pool1AppID = this.validatorList(validatorId).value.pools[0].poolAppId
	int 268
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 0 // pool1AppID: uint64

	// examples/reti/validatorRegistry.algo.ts:735
	// assert(pool1AppID !== 0)
	frame_dig 0 // pool1AppID: uint64
	int 0
	!=
	assert

	// *if11_condition
	// examples/reti/validatorRegistry.algo.ts:737
	// this.txn.sender !== AppID.fromUint64(pool1AppID).address
	txn Sender
	frame_dig 0 // pool1AppID: uint64
	app_params_get AppAddress
	pop
	!=
	bz *if11_end

	// *if11_consequent
	// examples/reti/validatorRegistry.algo.ts:738
	// return this.validatorList(validatorId).value.tokenPayoutRatio;
	int 700 // headOffset
	pushint 200
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	b *setTokenPayoutRatio*return

*if11_end:
	// examples/reti/validatorRegistry.algo.ts:744
	// curRound = globals.round
	global Round
	frame_bury 1 // curRound: uint64

	// examples/reti/validatorRegistry.algo.ts:745
	// lastPayoutUpdate = this.validatorList(validatorId).value.tokenPayoutRatio.updatedForPayout
	pushint 892
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 2 // lastPayoutUpdate: uint64

	// *if12_condition
	// examples/reti/validatorRegistry.algo.ts:746
	// lastPayoutUpdate !== 0
	frame_dig 2 // lastPayoutUpdate: uint64
	int 0
	!=
	bz *if12_end

	// *if12_consequent
	// *if13_condition
	// examples/reti/validatorRegistry.algo.ts:748
	// (AppID.fromUint64(pool1AppID).globalState('lastPayout') as uint64) === lastPayoutUpdate
	frame_dig 0 // pool1AppID: uint64
	pushbytes 0x6c6173745061796f7574 // "lastPayout"
	app_global_get_ex

	// global state value does not exist: AppID.fromUint64(pool1AppID).globalState('lastPayout')
	assert
	frame_dig 2 // lastPayoutUpdate: uint64
	==
	bz *if13_end

	// *if13_consequent
	// examples/reti/validatorRegistry.algo.ts:749
	// return this.validatorList(validatorId).value.tokenPayoutRatio;
	int 700 // headOffset
	pushint 200
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	b *setTokenPayoutRatio*return

*if13_end:
	// examples/reti/validatorRegistry.algo.ts:751
	// epochRoundLength = this.validatorList(validatorId).value.config.epochRoundLength as uint64
	pushint 169
	pushint 4
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 3 // epochRoundLength: uint64

	// examples/reti/validatorRegistry.algo.ts:752
	// thisEpochBegin = curRound - (curRound % epochRoundLength)
	frame_dig 1 // curRound: uint64
	frame_dig 1 // curRound: uint64
	frame_dig 3 // epochRoundLength: uint64
	%
	-
	frame_bury 4 // thisEpochBegin: uint64

	// *if14_condition
	// examples/reti/validatorRegistry.algo.ts:754
	// lastPayoutUpdate - (lastPayoutUpdate % epochRoundLength) === thisEpochBegin
	frame_dig 2 // lastPayoutUpdate: uint64
	frame_dig 2 // lastPayoutUpdate: uint64
	frame_dig 3 // epochRoundLength: uint64
	%
	-
	frame_dig 4 // thisEpochBegin: uint64
	==
	bz *if14_end

	// *if14_consequent
	// examples/reti/validatorRegistry.algo.ts:755
	// return this.validatorList(validatorId).value.tokenPayoutRatio;
	int 700 // headOffset
	pushint 200
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	b *setTokenPayoutRatio*return

*if14_end:

*if12_end:
	// examples/reti/validatorRegistry.algo.ts:758
	// this.validatorList(validatorId).value.tokenPayoutRatio.updatedForPayout = curRound
	pushint 892
	frame_dig 1 // curRound: uint64
	itob
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:760
	// curNumPools = this.validatorList(validatorId).value.state.numPools as uint64
	int 242
	int 2
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 5 // curNumPools: uint64

	// examples/reti/validatorRegistry.algo.ts:761
	// totalStakeForValidator = this.validatorList(validatorId).value.state.totalAlgoStaked
	int 252
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 6 // totalStakeForValidator: uint64

	// examples/reti/validatorRegistry.algo.ts:762
	// for (let i = 0; i < curNumPools; i += 1)
	int 0
	frame_bury 7 // i: uint64

*for_2:
	// examples/reti/validatorRegistry.algo.ts:762
	// i < curNumPools
	frame_dig 7 // i: uint64
	frame_dig 5 // curNumPools: uint64
	<
	bz *for_2_end

	// examples/reti/validatorRegistry.algo.ts:767
	// ourPoolPctOfWhole = wideRatio(
	//         [this.validatorList(validatorId).value.pools[i].totalAlgoStaked, 1_000_000],
	//         [totalStakeForValidator]
	//       )
	int 268 // headOffset
	frame_dig 7 // i: uint64
	int 18
	* // acc * typeLength
	+
	int 10 // headOffset
	+
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	pushint 1_000_000
	mulw
	int 0
	frame_dig 6 // totalStakeForValidator: uint64
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	frame_bury 8 // ourPoolPctOfWhole: uint64

	// examples/reti/validatorRegistry.algo.ts:771
	// this.validatorList(validatorId).value.tokenPayoutRatio.poolPctOfWhole[i] = ourPoolPctOfWhole
	int 700
	frame_dig 7 // i: uint64
	int 8
	* // acc * typeLength
	+
	frame_dig 8 // ourPoolPctOfWhole: uint64
	itob
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace

*for_2_continue:
	// examples/reti/validatorRegistry.algo.ts:762
	// i += 1
	frame_dig 7 // i: uint64
	int 1
	+
	frame_bury 7 // i: uint64
	b *for_2

*for_2_end:
	// examples/reti/validatorRegistry.algo.ts:773
	// return this.validatorList(validatorId).value.tokenPayoutRatio;
	int 700 // headOffset
	pushint 200
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract

*setTokenPayoutRatio*return:
	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 8
	retsub

// stakeUpdatedViaRewards((uint64,uint64,uint64),uint64,uint64,uint64,uint64)void
*abi_route_stakeUpdatedViaRewards:
	// saturatedBurnToFeeSink: uint64
	txna ApplicationArgs 5
	btoi

	// validatorCommission: uint64
	txna ApplicationArgs 4
	btoi

	// rewardTokenAmountReserved: uint64
	txna ApplicationArgs 3
	btoi

	// algoToAdd: uint64
	txna ApplicationArgs 2
	btoi

	// poolKey: (uint64,uint64,uint64)
	txna ApplicationArgs 1
	dup
	len
	int 24
	==

	// argument 4 (poolKey) for stakeUpdatedViaRewards must be a (uint64,uint64,uint64)
	assert

	// execute stakeUpdatedViaRewards((uint64,uint64,uint64),uint64,uint64,uint64,uint64)void
	callsub stakeUpdatedViaRewards
	int 1
	return

// stakeUpdatedViaRewards(poolKey: ValidatorPoolKey, algoToAdd: uint64, rewardTokenAmountReserved: uint64, validatorCommission: uint64, saturatedBurnToFeeSink: uint64): void
//
// stakeUpdatedViaRewards is called by Staking pools to inform the validator (us) that a particular amount of total
// stake has been added to the specified pool.  This is used to update the stats we have in our PoolInfo storage.
// The calling App id is validated against our pool list as well.
// @param {ValidatorPoolKey} poolKey - ValidatorPoolKey type
// @param {uint64} algoToAdd - amount this validator's total stake increased via rewards
// @param {uint64} rewardTokenAmountReserved - amount this validator's total stake increased via rewards (that should be
// @param {uint64} validatorCommission - the commission amount the validator was paid, if any
// @param {uint64} saturatedBurnToFeeSink - if the pool was in saturated state, the amount sent back to the fee sink.
// seen as 'accounted for/pending spent')
stakeUpdatedViaRewards:
	proto 5 0

	// examples/reti/validatorRegistry.algo.ts:794
	// this.verifyPoolKeyCaller(poolKey)
	frame_dig -1 // poolKey: ValidatorPoolKey
	callsub verifyPoolKeyCaller

	// examples/reti/validatorRegistry.algo.ts:797
	// this.validatorList(poolKey.id).value.pools[poolKey.poolId - 1].totalAlgoStaked += algoToAdd
	int 268 // headOffset
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 10 // headOffset
	+
	int 268 // headOffset
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 10 // headOffset
	+
	int 8
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_dig -2 // algoToAdd: uint64
	+
	itob
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:798
	// this.validatorList(poolKey.id).value.state.totalAlgoStaked += algoToAdd
	int 252
	dup
	int 8
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_dig -2 // algoToAdd: uint64
	+
	itob
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:799
	// this.validatorList(poolKey.id).value.state.rewardTokenHeldBack += rewardTokenAmountReserved
	int 260
	dup
	int 8
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_dig -3 // rewardTokenAmountReserved: uint64
	+
	itob
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:801
	// this.totalAlgoStaked.value += algoToAdd
	byte 0x7374616b6564 // "staked"
	app_global_get
	frame_dig -2 // algoToAdd: uint64
	+
	byte 0x7374616b6564 // "staked"
	swap
	app_global_put

	// examples/reti/validatorRegistry.algo.ts:804
	// this.reverifyNFDOwnership(poolKey.id)
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	callsub reverifyNFDOwnership
	retsub

// stakeRemoved((uint64,uint64,uint64),address,uint64,uint64,bool)void
*abi_route_stakeRemoved:
	// stakerRemoved: bool
	txna ApplicationArgs 5
	dup
	len
	int 1
	==

	// argument 0 (stakerRemoved) for stakeRemoved must be a bool
	assert
	int 0
	getbit

	// rewardRemoved: uint64
	txna ApplicationArgs 4
	btoi

	// amountRemoved: uint64
	txna ApplicationArgs 3
	btoi

	// staker: address
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 3 (staker) for stakeRemoved must be a address
	assert

	// poolKey: (uint64,uint64,uint64)
	txna ApplicationArgs 1
	dup
	len
	int 24
	==

	// argument 4 (poolKey) for stakeRemoved must be a (uint64,uint64,uint64)
	assert

	// execute stakeRemoved((uint64,uint64,uint64),address,uint64,uint64,bool)void
	callsub stakeRemoved
	int 1
	return

// stakeRemoved(poolKey: ValidatorPoolKey, staker: Address, amountRemoved: uint64, rewardRemoved: uint64, stakerRemoved: boolean): void
//
// stakeRemoved is called by Staking pools to inform the validator (us) that a particular amount of total stake has been removed
// from the specified pool.  This is used to update the stats we have in our PoolInfo storage.
// If any amount of rewardRemoved is specified, then that amount of reward is sent to the use
// The calling App id is validated against our pool list as well.
//
// @param {ValidatorPoolKey} poolKey calling us from which stake was removed
// @param {Address} staker
// @param {uint64} amountRemoved - algo amount removed
// @param {uint64} rewardRemoved - if applicable, amount of token reward removed (by pool 1 caller) or TO remove and pay out (via pool 1 from different pool caller)
// @param {boolean} stakerRemoved
stakeRemoved:
	proto 5 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 3

	// *if15_condition
	// examples/reti/validatorRegistry.algo.ts:836
	// globals.opcodeBudget < 300
	global OpcodeBudget
	pushint 300
	<
	bz *if15_end

	// *if15_consequent
	// examples/reti/validatorRegistry.algo.ts:837
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	pushint 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

*if15_end:
	// examples/reti/validatorRegistry.algo.ts:839
	// this.verifyPoolKeyCaller(poolKey)
	frame_dig -1 // poolKey: ValidatorPoolKey
	callsub verifyPoolKeyCaller

	// examples/reti/validatorRegistry.algo.ts:843
	// assert(amountRemoved > 0 || rewardRemoved > 0, 'should only be called if algo or reward was removed')
	frame_dig -3 // amountRemoved: uint64
	int 0
	>
	dup
	bnz *skip_or2
	frame_dig -4 // rewardRemoved: uint64
	int 0
	>
	||

*skip_or2:
	// should only be called if algo or reward was removed
	assert

	// examples/reti/validatorRegistry.algo.ts:846
	// this.validatorList(poolKey.id).value.pools[poolKey.poolId - 1].totalAlgoStaked -= amountRemoved
	int 268 // headOffset
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 10 // headOffset
	+
	int 268 // headOffset
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 10 // headOffset
	+
	int 8
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_dig -3 // amountRemoved: uint64
	-
	itob
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:847
	// this.validatorList(poolKey.id).value.state.totalAlgoStaked -= amountRemoved
	int 252
	dup
	int 8
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_dig -3 // amountRemoved: uint64
	-
	itob
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:848
	// this.totalAlgoStaked.value -= amountRemoved
	byte 0x7374616b6564 // "staked"
	app_global_get
	frame_dig -3 // amountRemoved: uint64
	-
	byte 0x7374616b6564 // "staked"
	swap
	app_global_put

	// *if16_condition
	// examples/reti/validatorRegistry.algo.ts:850
	// rewardRemoved > 0
	frame_dig -4 // rewardRemoved: uint64
	int 0
	>
	bz *if16_else

	// *if16_consequent
	// examples/reti/validatorRegistry.algo.ts:851
	// rewardTokenID = this.validatorList(poolKey.id).value.config.rewardTokenId
	pushint 153
	int 8
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 0 // rewardTokenID: uint64

	// examples/reti/validatorRegistry.algo.ts:852
	// assert(rewardTokenID !== 0, "rewardRemoved can't be set if validator doesn't have reward token!")
	frame_dig 0 // rewardTokenID: uint64
	int 0
	!=

	// rewardRemoved can't be set if validator doesn't have reward token!
	assert

	// examples/reti/validatorRegistry.algo.ts:853
	// assert(
	//         this.validatorList(poolKey.id).value.state.rewardTokenHeldBack >= rewardRemoved,
	//         'reward being removed must be covered by hold back amount'
	//       )
	int 260
	int 8
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_dig -4 // rewardRemoved: uint64
	>=

	// reward being removed must be covered by hold back amount
	assert

	// examples/reti/validatorRegistry.algo.ts:859
	// this.validatorList(poolKey.id).value.state.rewardTokenHeldBack -= rewardRemoved
	int 260
	dup
	int 8
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_dig -4 // rewardRemoved: uint64
	-
	itob
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_replace

	// *if17_condition
	// examples/reti/validatorRegistry.algo.ts:864
	// poolKey.poolId !== 1
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	!=
	bz *if17_end

	// *if17_consequent
	// examples/reti/validatorRegistry.algo.ts:865
	// sendMethodCall<typeof StakingPool.prototype.payTokenReward>({
	//           applicationID: AppID.fromUint64(this.validatorList(poolKey.id).value.pools[0].poolAppId),
	//           methodArgs: [staker, rewardTokenID, rewardRemoved],
	//         })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0x63f3f28b // method "payTokenReward(address,uint64,uint64)void"
	itxn_field ApplicationArgs

	// examples/reti/validatorRegistry.algo.ts:866
	// applicationID: AppID.fromUint64(this.validatorList(poolKey.id).value.pools[0].poolAppId)
	int 268
	int 8
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	itxn_field ApplicationID

	// examples/reti/validatorRegistry.algo.ts:867
	// methodArgs: [staker, rewardTokenID, rewardRemoved]
	frame_dig -2 // staker: Address
	itxn_field ApplicationArgs
	frame_dig 0 // rewardTokenID: uint64
	itob
	itxn_field ApplicationArgs
	frame_dig -4 // rewardRemoved: uint64
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

*if17_end:
	b *if16_end

*if16_else:

*if16_end:
	// *if18_condition
	// examples/reti/validatorRegistry.algo.ts:892
	// stakerRemoved
	frame_dig -5 // stakerRemoved: boolean
	bz *if18_end

	// *if18_consequent
	// examples/reti/validatorRegistry.algo.ts:894
	// this.validatorList(poolKey.id).value.pools[poolKey.poolId - 1].totalStakers -= 1
	int 268 // headOffset
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 8 // headOffset
	+
	int 268 // headOffset
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 8 // headOffset
	+
	int 2
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	int 1
	-
	itob
	extract 6 2
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:896
	// removeRet = this.removeFromStakerPoolSet(staker, <ValidatorPoolKey>{
	//         id: poolKey.id,
	//         poolId: poolKey.poolId,
	//         poolAppId: poolKey.poolAppId,
	//       })
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	itob
	concat
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 16 8
	btoi
	itob
	concat
	frame_dig -2 // staker: Address
	callsub removeFromStakerPoolSet
	frame_bury 1 // removeRet: (bool,bool)

	// examples/reti/validatorRegistry.algo.ts:901
	// stakerOutOfThisValidator = removeRet[0]
	frame_dig 1 // removeRet: (bool,bool)
	store 255 // full array
	load 255 // full array
	int 0
	getbit
	frame_bury 2 // stakerOutOfThisValidator: bool

	// examples/reti/validatorRegistry.algo.ts:902
	// stakerOutOfProtocol = removeRet[1]
	frame_dig 1 // removeRet: (bool,bool)
	store 255 // full array
	load 255 // full array
	int 1
	getbit
	frame_bury 3 // stakerOutOfProtocol: bool

	// *if19_condition
	// examples/reti/validatorRegistry.algo.ts:904
	// stakerOutOfThisValidator
	frame_dig 2 // stakerOutOfThisValidator: bool
	bz *if19_end

	// *if19_consequent
	// examples/reti/validatorRegistry.algo.ts:905
	// this.validatorList(poolKey.id).value.state.totalStakers -= 1
	pushint 244
	pushint 244
	int 8
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	int 1
	-
	itob
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_replace

*if19_end:
	// *if20_condition
	// examples/reti/validatorRegistry.algo.ts:908
	// stakerOutOfProtocol
	frame_dig 3 // stakerOutOfProtocol: bool
	bz *if20_end

	// *if20_consequent
	// examples/reti/validatorRegistry.algo.ts:909
	// this.numStakers.value -= 1
	byte 0x6e756d5374616b657273 // "numStakers"
	app_global_get
	int 1
	-
	byte 0x6e756d5374616b657273 // "numStakers"
	swap
	app_global_put

*if20_end:

*if18_end:
	retsub

// findPoolForStaker(uint64,address,uint64)((uint64,uint64,uint64),bool,bool)
*abi_route_findPoolForStaker:
	// The ABI return prefix
	byte 0x151f7c75

	// amountToStake: uint64
	txna ApplicationArgs 3
	btoi

	// staker: address
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 1 (staker) for findPoolForStaker must be a address
	assert

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute findPoolForStaker(uint64,address,uint64)((uint64,uint64,uint64),bool,bool)
	callsub findPoolForStaker
	concat
	log
	int 1
	return

// findPoolForStaker(validatorId: ValidatorIdType, staker: Address, amountToStake: uint64): [ValidatorPoolKey, boolean, boolean]
//
// Finds the pool for a staker based on the provided validator id, staker address, and amount to stake.
// First checks the stakers 'already staked list' for the validator preferring those (adding if possible) then adds
// to new pool if necessary.
//
// @param {ValidatorIdType} validatorId - The id of the validator.
// @param {Address} staker - The address of the staker.
// @param {uint64} amountToStake - The amount to stake.
// @returns {ValidatorPoolKey, boolean, boolean} - The pool for the staker, true/false on whether the staker is 'new'
// to this VALIDATOR, and true/false if staker is new to the protocol.
findPoolForStaker:
	proto 3 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 7

	// examples/reti/validatorRegistry.algo.ts:930
	// isNewStakerToValidator = true
	int 1
	frame_bury 0 // isNewStakerToValidator: bool

	// examples/reti/validatorRegistry.algo.ts:931
	// isNewStakerToProtocol = true
	int 1
	frame_bury 1 // isNewStakerToProtocol: bool

	// examples/reti/validatorRegistry.algo.ts:939
	// maxPerPool = this.getCurMaxStakePerPool(validatorId)
	frame_dig -1 // validatorId: ValidatorIdType
	callsub getCurMaxStakePerPool
	frame_bury 2 // maxPerPool: uint64

	// *if21_condition
	// examples/reti/validatorRegistry.algo.ts:942
	// this.stakerPoolSet(staker).exists
	byte 0x737073 // "sps"
	frame_dig -2 // staker: Address
	concat
	box_len
	swap
	pop
	bz *if21_end

	// *if21_consequent
	// examples/reti/validatorRegistry.algo.ts:943
	// poolSet = clone(this.stakerPoolSet(staker).value)
	byte 0x737073 // "sps"
	frame_dig -2 // staker: Address
	concat
	box_get

	// box value does not exist: this.stakerPoolSet(staker).value
	assert
	frame_bury 3 // poolSet: (uint64,uint64,uint64)[6]

	// examples/reti/validatorRegistry.algo.ts:944
	// assert(validatorId !== 0)
	frame_dig -1 // validatorId: ValidatorIdType
	int 0
	!=
	assert

	// examples/reti/validatorRegistry.algo.ts:945
	// for (let i = 0; i < poolSet.length; i += 1)
	int 0
	frame_bury 4 // i: uint64

*for_3:
	// examples/reti/validatorRegistry.algo.ts:945
	// i < poolSet.length
	frame_dig 4 // i: uint64
	int 6
	<
	bz *for_3_end

	// *if22_condition
	// examples/reti/validatorRegistry.algo.ts:946
	// globals.opcodeBudget < 300
	global OpcodeBudget
	pushint 300
	<
	bz *if22_end

	// *if22_consequent
	// examples/reti/validatorRegistry.algo.ts:947
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	pushint 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

*if22_end:
	// *if23_condition
	// examples/reti/validatorRegistry.algo.ts:949
	// poolSet[i].id === 0
	frame_dig 3 // poolSet: (uint64,uint64,uint64)[6]
	frame_dig 4 // i: uint64
	int 24
	* // acc * typeLength
	int 0
	+
	int 8
	extract3
	btoi
	int 0
	==
	bz *if23_end

	// *if23_consequent
	b *for_3_continue

*if23_end:
	// examples/reti/validatorRegistry.algo.ts:952
	// isNewStakerToProtocol = false
	int 0
	frame_bury 1 // isNewStakerToProtocol: bool

	// *if24_condition
	// examples/reti/validatorRegistry.algo.ts:953
	// poolSet[i].id === validatorId
	frame_dig 3 // poolSet: (uint64,uint64,uint64)[6]
	frame_dig 4 // i: uint64
	int 24
	* // acc * typeLength
	int 0
	+
	int 8
	extract3
	btoi
	frame_dig -1 // validatorId: ValidatorIdType
	==
	bz *if24_end

	// *if24_consequent
	// examples/reti/validatorRegistry.algo.ts:955
	// isNewStakerToValidator = false
	int 0
	frame_bury 0 // isNewStakerToValidator: bool

	// *if25_condition
	// examples/reti/validatorRegistry.algo.ts:957
	// this.validatorList(validatorId).value.pools[poolSet[i].poolId - 1].totalAlgoStaked + amountToStake <=
	//             maxPerPool
	int 268 // headOffset
	frame_dig 3 // poolSet: (uint64,uint64,uint64)[6]
	frame_dig 4 // i: uint64
	int 24
	* // acc * typeLength
	int 8 // headOffset
	+
	int 8
	extract3
	btoi
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 10 // headOffset
	+
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_dig -3 // amountToStake: uint64
	+
	frame_dig 2 // maxPerPool: uint64
	<=
	bz *if25_end

	// *if25_consequent
	// examples/reti/validatorRegistry.algo.ts:960
	// return [poolSet[i], isNewStakerToValidator, isNewStakerToProtocol];
	frame_dig 3 // poolSet: (uint64,uint64,uint64)[6]
	frame_dig 4 // i: uint64
	int 24
	* // acc * typeLength
	int 24
	extract3
	byte 0x00
	int 0
	frame_dig 0 // isNewStakerToValidator: bool
	setbit
	int 1
	frame_dig 1 // isNewStakerToProtocol: bool
	setbit
	concat
	b *findPoolForStaker*return

*if25_end:

*if24_end:

*for_3_continue:
	// examples/reti/validatorRegistry.algo.ts:945
	// i += 1
	frame_dig 4 // i: uint64
	int 1
	+
	frame_bury 4 // i: uint64
	b *for_3

*for_3_end:

*if21_end:
	// examples/reti/validatorRegistry.algo.ts:967
	// assert(
	//       amountToStake >= this.validatorList(validatorId).value.config.minEntryStake,
	//       'must stake at least the minimum for this pool'
	//     )
	frame_dig -3 // amountToStake: uint64
	pushint 209
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	>=

	// must stake at least the minimum for this pool
	assert

	// examples/reti/validatorRegistry.algo.ts:973
	// pools = clone(this.validatorList(validatorId).value.pools)
	int 268 // headOffset
	pushint 432
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	frame_bury 5 // pools: (uint64,uint16,uint64)[24]

	// examples/reti/validatorRegistry.algo.ts:974
	// curNumPools = this.validatorList(validatorId).value.state.numPools as uint64
	int 242
	int 2
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 6 // curNumPools: uint64

	// examples/reti/validatorRegistry.algo.ts:975
	// for (let i = 0; i < curNumPools; i += 1)
	int 0
	frame_bury 7 // i: uint64

*for_4:
	// examples/reti/validatorRegistry.algo.ts:975
	// i < curNumPools
	frame_dig 7 // i: uint64
	frame_dig 6 // curNumPools: uint64
	<
	bz *for_4_end

	// *if26_condition
	// examples/reti/validatorRegistry.algo.ts:976
	// pools[i].totalAlgoStaked + amountToStake <= maxPerPool
	frame_dig 5 // pools: (uint64,uint16,uint64)[24]
	frame_dig 7 // i: uint64
	int 18
	* // acc * typeLength
	int 10 // headOffset
	+
	int 8
	extract3
	btoi
	frame_dig -3 // amountToStake: uint64
	+
	frame_dig 2 // maxPerPool: uint64
	<=
	bz *if26_end

	// *if26_consequent
	// examples/reti/validatorRegistry.algo.ts:977
	// return [
	//           { id: validatorId, poolId: i + 1, poolAppId: pools[i].poolAppId },
	//           isNewStakerToValidator,
	//           isNewStakerToProtocol,
	//         ];
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	frame_dig 7 // i: uint64
	int 1
	+
	itob
	concat
	frame_dig 5 // pools: (uint64,uint16,uint64)[24]
	frame_dig 7 // i: uint64
	int 18
	* // acc * typeLength
	int 0
	+
	int 8
	extract3
	btoi
	itob
	concat
	byte 0x00
	int 0
	frame_dig 0 // isNewStakerToValidator: bool
	setbit
	int 1
	frame_dig 1 // isNewStakerToProtocol: bool
	setbit
	concat
	b *findPoolForStaker*return

*if26_end:

*for_4_continue:
	// examples/reti/validatorRegistry.algo.ts:975
	// i += 1
	frame_dig 7 // i: uint64
	int 1
	+
	frame_bury 7 // i: uint64
	b *for_4

*for_4_end:
	// examples/reti/validatorRegistry.algo.ts:985
	// return [{ id: validatorId, poolId: 0, poolAppId: 0 }, isNewStakerToValidator, isNewStakerToProtocol];
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	byte 0x0000000000000000
	concat
	byte 0x0000000000000000
	concat
	byte 0x00
	int 0
	frame_dig 0 // isNewStakerToValidator: bool
	setbit
	int 1
	frame_dig 1 // isNewStakerToProtocol: bool
	setbit
	concat

*findPoolForStaker*return:
	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 7
	retsub

// movePoolToNode(uint64,uint64,uint64)void
*abi_route_movePoolToNode:
	// nodeNum: uint64
	txna ApplicationArgs 3
	btoi

	// poolAppId: uint64
	txna ApplicationArgs 2
	btoi

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute movePoolToNode(uint64,uint64,uint64)void
	callsub movePoolToNode
	int 1
	return

// movePoolToNode(validatorId: ValidatorIdType, poolAppId: uint64, nodeNum: uint64): void
//
// Find the specified pool (in any node number) and move it to the specified node.
// The pool account is forced offline if moved so prior node will still run for 320 rounds but
// new key goes online on new node soon after (320 rounds after it goes online)
// No-op if success, asserts if not found or can't move  (no space in target)
// [ ONLY OWNER OR MANAGER CAN CHANGE ]
//
// @param {ValidatorIdType} validatorId - The id of the validator.
// @param {uint64} poolAppId
// @param {uint64} nodeNum
movePoolToNode:
	proto 3 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// examples/reti/validatorRegistry.algo.ts:1001
	// assert(
	//       this.txn.sender === this.validatorList(validatorId).value.config.owner ||
	//         this.txn.sender === this.validatorList(validatorId).value.config.manager,
	//       'can only be called by owner or manager of validator'
	//     )
	txn Sender
	int 8
	int 32
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	==
	dup
	bnz *skip_or3
	txn Sender
	pushint 40
	int 32
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	==
	||

*skip_or3:
	// can only be called by owner or manager of validator
	assert

	// examples/reti/validatorRegistry.algo.ts:1007
	// nodePoolAssignments = clone(this.validatorList(validatorId).value.nodePoolAssignments)
	int 900 // headOffset
	pushint 192
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	frame_bury 0 // nodePoolAssignments: ((uint64[3])[8])

	// examples/reti/validatorRegistry.algo.ts:1008
	// assert(nodeNum >= 1 && nodeNum <= MAX_NODES, 'node number out of allowable range')
	frame_dig -3 // nodeNum: uint64
	int 1
	>=
	dup
	bz *skip_and1
	frame_dig -3 // nodeNum: uint64
	int 8
	<=
	&&

*skip_and1:
	// node number out of allowable range
	assert

	// examples/reti/validatorRegistry.algo.ts:1010
	// for (let srcNodeIdx = 0; srcNodeIdx < MAX_NODES; srcNodeIdx += 1)
	int 0
	frame_bury 1 // srcNodeIdx: uint64

*for_5:
	// examples/reti/validatorRegistry.algo.ts:1010
	// srcNodeIdx < MAX_NODES
	frame_dig 1 // srcNodeIdx: uint64
	int 8
	<
	bz *for_5_end

	// examples/reti/validatorRegistry.algo.ts:1011
	// for (let i = 0; i < MAX_POOLS_PER_NODE; i += 1)
	int 0
	frame_bury 2 // i: uint64

*for_6:
	// examples/reti/validatorRegistry.algo.ts:1011
	// i < MAX_POOLS_PER_NODE
	frame_dig 2 // i: uint64
	int 3
	<
	bz *for_6_end

	// *if27_condition
	// examples/reti/validatorRegistry.algo.ts:1012
	// nodePoolAssignments.nodes[srcNodeIdx].poolAppIds[i] === poolAppId
	frame_dig 0 // nodePoolAssignments: ((uint64[3])[8])
	int 0
	frame_dig 1 // srcNodeIdx: uint64
	int 24
	* // acc * typeLength
	+
	int 0
	+
	frame_dig 2 // i: uint64
	int 8
	* // acc * typeLength
	+
	int 8
	extract3
	btoi
	frame_dig -2 // poolAppId: uint64
	==
	bz *if27_end

	// *if27_consequent
	// examples/reti/validatorRegistry.algo.ts:1013
	// assert(nodeNum - 1 !== srcNodeIdx, "can't move to same node")
	frame_dig -3 // nodeNum: uint64
	int 1
	-
	frame_dig 1 // srcNodeIdx: uint64
	!=

	// can't move to same node
	assert

	// examples/reti/validatorRegistry.algo.ts:1015
	// this.validatorList(validatorId).value.nodePoolAssignments.nodes[srcNodeIdx].poolAppIds[i] = 0
	int 900
	frame_dig 1 // srcNodeIdx: uint64
	int 24
	* // acc * typeLength
	+
	int 0
	+
	frame_dig 2 // i: uint64
	int 8
	* // acc * typeLength
	+
	byte 0x0000000000000000
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:1018
	// sendMethodCall<typeof StakingPool.prototype.goOffline>({
	//             applicationID: AppID.fromUint64(poolAppId),
	//           })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	pushbytes 0x51ef3b21 // method "goOffline()void"
	itxn_field ApplicationArgs

	// examples/reti/validatorRegistry.algo.ts:1019
	// applicationID: AppID.fromUint64(poolAppId)
	frame_dig -2 // poolAppId: uint64
	itxn_field ApplicationID

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/validatorRegistry.algo.ts:1023
	// this.addPoolToNode(validatorId, poolAppId, nodeNum)
	frame_dig -3 // nodeNum: uint64
	frame_dig -2 // poolAppId: uint64
	frame_dig -1 // validatorId: ValidatorIdType
	callsub addPoolToNode

	// examples/reti/validatorRegistry.algo.ts:1024
	// return;
	retsub

*if27_end:

*for_6_continue:
	// examples/reti/validatorRegistry.algo.ts:1011
	// i += 1
	frame_dig 2 // i: uint64
	int 1
	+
	frame_bury 2 // i: uint64
	b *for_6

*for_6_end:

*for_5_continue:
	// examples/reti/validatorRegistry.algo.ts:1010
	// srcNodeIdx += 1
	frame_dig 1 // srcNodeIdx: uint64
	int 1
	+
	frame_bury 1 // srcNodeIdx: uint64
	b *for_5

*for_5_end:
	// couldn't find pool app id in nodes to move
	err
	retsub

// emptyTokenRewards(uint64,address)uint64
*abi_route_emptyTokenRewards:
	// The ABI return prefix
	byte 0x151f7c75

	// receiver: address
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (receiver) for emptyTokenRewards must be a address
	assert

	// validatorId: uint64
	txna ApplicationArgs 1
	btoi

	// execute emptyTokenRewards(uint64,address)uint64
	callsub emptyTokenRewards
	itob
	concat
	log
	int 1
	return

// emptyTokenRewards(validatorId: ValidatorIdType, receiver: Address): uint64
//
// Sends the reward tokens held in pool 1 to specified receiver.
// This is intended to be used by the owner when they want to get reward tokens 'back' which they sent to
// the first pool (likely because validator is sunsetting.  Any tokens currently 'reserved' for stakers to claim will
// NOT be sent as they must be held back for stakers to later claim.
// [ ONLY OWNER CAN CALL]
//
// @param {ValidatorIdType} validatorId - The id of the validator.
// @param {Address} receiver - the account to send the tokens to (must already be opted-in to the reward token)
// @returns {uint64} the amount of reward token sent
emptyTokenRewards:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 3

	// examples/reti/validatorRegistry.algo.ts:1043
	// assert(
	//       this.txn.sender === this.validatorList(validatorId).value.config.owner,
	//       'can only be called by validator owner'
	//     )
	txn Sender
	int 8
	int 32
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	==

	// can only be called by validator owner
	assert

	// examples/reti/validatorRegistry.algo.ts:1047
	// rewardTokenId = this.validatorList(validatorId).value.config.rewardTokenId
	pushint 153
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 0 // rewardTokenId: uint64

	// examples/reti/validatorRegistry.algo.ts:1048
	// rewardTokenHeldBack = this.validatorList(validatorId).value.state.rewardTokenHeldBack
	int 260
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 1 // rewardTokenHeldBack: uint64

	// examples/reti/validatorRegistry.algo.ts:1049
	// assert(rewardTokenId !== 0, "this validator doesn't have a reward token defined")
	frame_dig 0 // rewardTokenId: uint64
	int 0
	!=

	// this validator doesn't have a reward token defined
	assert

	// examples/reti/validatorRegistry.algo.ts:1050
	// poolOneAppId = AppID.fromUint64(this.validatorList(validatorId).value.pools[0].poolAppId)
	int 268
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 2 // poolOneAppId: uint64

	// examples/reti/validatorRegistry.algo.ts:1052
	// tokenRewardBal = poolOneAppId.address.assetBalance(AssetID.fromUint64(rewardTokenId)) - rewardTokenHeldBack
	frame_dig 2 // poolOneAppId: uint64
	app_params_get AppAddress
	pop
	frame_dig 0 // rewardTokenId: uint64
	asset_holding_get AssetBalance
	pop
	frame_dig 1 // rewardTokenHeldBack: uint64
	-
	frame_bury 3 // tokenRewardBal: uint64

	// examples/reti/validatorRegistry.algo.ts:1055
	// sendMethodCall<typeof StakingPool.prototype.payTokenReward>({
	//       applicationID: poolOneAppId,
	//       methodArgs: [receiver, rewardTokenId, tokenRewardBal],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	byte 0x63f3f28b // method "payTokenReward(address,uint64,uint64)void"
	itxn_field ApplicationArgs

	// examples/reti/validatorRegistry.algo.ts:1056
	// applicationID: poolOneAppId
	frame_dig 2 // poolOneAppId: uint64
	itxn_field ApplicationID

	// examples/reti/validatorRegistry.algo.ts:1057
	// methodArgs: [receiver, rewardTokenId, tokenRewardBal]
	frame_dig -2 // receiver: Address
	itxn_field ApplicationArgs
	frame_dig 0 // rewardTokenId: uint64
	itob
	itxn_field ApplicationArgs
	frame_dig 3 // tokenRewardBal: uint64
	itob
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/validatorRegistry.algo.ts:1059
	// assert(
	//       poolOneAppId.address.assetBalance(AssetID.fromUint64(rewardTokenId)) === rewardTokenHeldBack,
	//       'balance of remaining reward tokens should match the held back amount'
	//     )
	frame_dig 2 // poolOneAppId: uint64
	app_params_get AppAddress
	pop
	frame_dig 0 // rewardTokenId: uint64
	asset_holding_get AssetBalance
	pop
	frame_dig 1 // rewardTokenHeldBack: uint64
	==

	// balance of remaining reward tokens should match the held back amount
	assert

	// examples/reti/validatorRegistry.algo.ts:1063
	// return tokenRewardBal;
	frame_dig 3 // tokenRewardBal: uint64

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 3
	retsub

// verifyPoolKeyCaller(poolKey: ValidatorPoolKey): void
//
// Logs the addition of a new validator to the system, its initial owner and manager
//
//
// verifyPoolKeyCaller verifies the passed in key (from a staking pool calling us to update metrics) is valid
// and matches the information we have in our state.  'Fake' pools could call us to update our data, but they
// can't fake the ids and most importantly application id(!) of the caller that has to match.
verifyPoolKeyCaller:
	proto 1 0

	// examples/reti/validatorRegistry.algo.ts:1161
	// assert(this.validatorList(poolKey.id).exists, "the specified validator id isn't valid")
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	box_len
	swap
	pop

	// the specified validator id isn't valid
	assert

	// examples/reti/validatorRegistry.algo.ts:1162
	// assert(poolKey.poolId <= MAX_POOLS, 'pool id not in valid range')
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 24
	<=

	// pool id not in valid range
	assert

	// examples/reti/validatorRegistry.algo.ts:1163
	// assert(
	//       poolKey.poolId > 0 && (poolKey.poolId as uint16) <= this.validatorList(poolKey.id).value.state.numPools,
	//       'pool id outside of range of pools created for this validator'
	//     )
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 0
	>
	dup
	bz *skip_and2
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 242
	int 2
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	<=
	&&

*skip_and2:
	// pool id outside of range of pools created for this validator
	assert

	// examples/reti/validatorRegistry.algo.ts:1169
	// assert(
	//       poolKey.poolAppId === this.validatorList(poolKey.id).value.pools[poolKey.poolId - 1].poolAppId,
	//       "The passed in app id doesn't match the passed in ids"
	//     )
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 16 8
	btoi
	int 268 // headOffset
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 0
	+
	int 8
	byte 0x76 // "v"
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	==

	// The passed in app id doesn't match the passed in ids
	assert

	// examples/reti/validatorRegistry.algo.ts:1174
	// assert(this.txn.sender === AppID.fromUint64(poolKey.poolAppId).address)
	txn Sender
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 16 8
	btoi
	app_params_get AppAddress
	pop
	==
	assert

	// examples/reti/validatorRegistry.algo.ts:1176
	// assert(poolKey.id === (AppID.fromUint64(poolKey.poolAppId).globalState('validatorId') as uint64))
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 16 8
	btoi
	pushbytes 0x76616c696461746f724964 // "validatorId"
	app_global_get_ex

	// global state value does not exist: AppID.fromUint64(poolKey.poolAppId).globalState('validatorId')
	assert
	==
	assert

	// examples/reti/validatorRegistry.algo.ts:1177
	// assert(poolKey.poolId === (AppID.fromUint64(poolKey.poolAppId).globalState('poolId') as uint64))
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	frame_dig -1 // poolKey: ValidatorPoolKey
	extract 16 8
	btoi
	pushbytes 0x706f6f6c4964 // "poolId"
	app_global_get_ex

	// global state value does not exist: AppID.fromUint64(poolKey.poolAppId).globalState('poolId')
	assert
	==
	assert
	retsub

// reverifyNFDOwnership(validatorId: ValidatorIdType): void
//
// This method verifies the ownership of NFD (Named Function Data) by a validator.
// If the ownership is no longer valid, it removes the NFD from the validator's configuration.
//
// @param {ValidatorIdType} validatorId - The id of the validator whose data should be re-evaluated.
reverifyNFDOwnership:
	proto 1 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// examples/reti/validatorRegistry.algo.ts:1187
	// validatorConfig = this.validatorList(validatorId).value.config
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	frame_bury 0 // storage key//validatorConfig

	// *if28_condition
	// examples/reti/validatorRegistry.algo.ts:1188
	// validatorConfig.nfdForInfo !== 0
	pushint 72
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	int 0
	!=
	bz *if28_end

	// *if28_consequent
	// examples/reti/validatorRegistry.algo.ts:1191
	// nfdOwner = AppID.fromUint64(validatorConfig.nfdForInfo).globalState('i.owner.a') as Address
	pushint 72
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	byte 0x692e6f776e65722e61 // "i.owner.a"
	app_global_get_ex

	// global state value does not exist: AppID.fromUint64(validatorConfig.nfdForInfo).globalState('i.owner.a')
	assert
	frame_bury 1 // nfdOwner: address

	// *if29_condition
	// examples/reti/validatorRegistry.algo.ts:1193
	// validatorConfig.owner !== nfdOwner && validatorConfig.manager !== nfdOwner
	int 8
	int 32
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	frame_dig 1 // nfdOwner: address
	!=
	dup
	bz *skip_and3
	pushint 40
	int 32
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	frame_dig 1 // nfdOwner: address
	!=
	&&

*skip_and3:
	bz *if29_end

	// *if29_consequent
	// examples/reti/validatorRegistry.algo.ts:1195
	// this.validatorList(validatorId).value.config.nfdForInfo = 0
	pushint 72
	byte 0x0000000000000000
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace

*if29_end:

*if28_end:
	retsub

// validateConfig(config: ValidatorConfig): void
validateConfig:
	proto 1 0

	// examples/reti/validatorRegistry.algo.ts:1202
	// assert(
	//       config.entryGatingType >= GATING_TYPE_NONE && config.entryGatingType <= GATING_TYPE_CONST_MAX,
	//       'gating type not valid'
	//     )
	frame_dig -1 // config: ValidatorConfig
	extract 80 1
	btoi
	int 0
	>=
	dup
	bz *skip_and4
	frame_dig -1 // config: ValidatorConfig
	extract 80 1
	btoi
	pushint 4
	<=
	&&

*skip_and4:
	// gating type not valid
	assert

	// examples/reti/validatorRegistry.algo.ts:1206
	// assert(
	//       config.epochRoundLength >= MIN_EPOCH_LENGTH && config.epochRoundLength <= MAX_EPOCH_LENGTH,
	//       'epoch length not in allowable range'
	//     )
	frame_dig -1 // config: ValidatorConfig
	extract 169 4
	btoi
	int 1
	>=
	dup
	bz *skip_and5
	frame_dig -1 // config: ValidatorConfig
	extract 169 4
	btoi
	int 1000000
	<=
	&&

*skip_and5:
	// epoch length not in allowable range
	assert

	// examples/reti/validatorRegistry.algo.ts:1210
	// assert(
	//       config.percentToValidator >= MIN_PCT_TO_VALIDATOR && config.percentToValidator <= MAX_PCT_TO_VALIDATOR,
	//       'commission percentage not valid'
	//     )
	frame_dig -1 // config: ValidatorConfig
	extract 173 4
	btoi
	int 0
	>=
	dup
	bz *skip_and6
	frame_dig -1 // config: ValidatorConfig
	extract 173 4
	btoi
	int 1000000
	<=
	&&

*skip_and6:
	// commission percentage not valid
	assert

	// *if30_condition
	// examples/reti/validatorRegistry.algo.ts:1214
	// config.percentToValidator !== 0
	frame_dig -1 // config: ValidatorConfig
	extract 173 4
	btoi
	int 0
	!=
	bz *if30_end

	// *if30_consequent
	// examples/reti/validatorRegistry.algo.ts:1215
	// assert(
	//         config.validatorCommissionAddress !== Address.zeroAddress,
	//         'validatorCommissionAddress must be set if percent to validator is not 0'
	//       )
	frame_dig -1 // config: ValidatorConfig
	extract 177 32
	global ZeroAddress
	!=

	// validatorCommissionAddress must be set if percent to validator is not 0
	assert

*if30_end:
	// examples/reti/validatorRegistry.algo.ts:1220
	// assert(config.minEntryStake >= MIN_ALGO_STAKE_PER_POOL, 'staking pool must have minimum entry of 1 algo')
	frame_dig -1 // config: ValidatorConfig
	extract 209 8
	btoi
	int 1000000
	>=

	// staking pool must have minimum entry of 1 algo
	assert

	// examples/reti/validatorRegistry.algo.ts:1222
	// assert(
	//       config.poolsPerNode > 0 && config.poolsPerNode <= MAX_POOLS_PER_NODE,
	//       'number of pools per node exceeds allowed number'
	//     )
	frame_dig -1 // config: ValidatorConfig
	extract 225 1
	btoi
	int 0
	>
	dup
	bz *skip_and7
	frame_dig -1 // config: ValidatorConfig
	extract 225 1
	btoi
	int 3
	<=
	&&

*skip_and7:
	// number of pools per node exceeds allowed number
	assert

	// *if31_condition
	// examples/reti/validatorRegistry.algo.ts:1226
	// config.sunsettingOn !== 0
	frame_dig -1 // config: ValidatorConfig
	extract 226 8
	btoi
	int 0
	!=
	bz *if31_end

	// *if31_consequent
	// examples/reti/validatorRegistry.algo.ts:1227
	// assert(config.sunsettingOn > globals.latestTimestamp, 'sunsettingOn must be later than now if set')
	frame_dig -1 // config: ValidatorConfig
	extract 226 8
	btoi
	global LatestTimestamp
	>

	// sunsettingOn must be later than now if set
	assert

*if31_end:
	retsub

// callPoolAddStake(stakedAmountPayment: PayTxn, poolKey: ValidatorPoolKey, mbrAmtPaid: uint64, isNewStakerToValidator: boolean, isNewStakerToProtocol: boolean): void
//
// Adds a stakers amount of algo to a validator pool, transferring the algo we received from them (already verified
// by our caller) to the staking pool account, and then telling it about the amount being added for the specified
// staker.
//
// @param {PayTxn} stakedAmountPayment - payment coming from staker to place into a pool
// @param {ValidatorPoolKey} poolKey - The key of the validator pool.
// @param {uint64} mbrAmtPaid - Amount the user is leaving behind in the validator to pay for their staker MBR cost
// @param {boolean} isNewStakerToValidator - if this is a new, first-time staker to the validator
// @param {boolean} isNewStakerToProtocol - if this is a new, first-time staker to the protocol
callPoolAddStake:
	proto 5 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// examples/reti/validatorRegistry.algo.ts:1249
	// poolAppId = this.validatorList(poolKey.id).value.pools[poolKey.poolId - 1].poolAppId
	int 268 // headOffset
	frame_dig -2 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 0
	+
	int 8
	byte 0x76 // "v"
	frame_dig -2 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 0 // poolAppId: uint64

	// examples/reti/validatorRegistry.algo.ts:1253
	// sendMethodCall<typeof StakingPool.prototype.addStake, uint64>({
	//       applicationID: AppID.fromUint64(poolAppId),
	//       methodArgs: [
	//         // =======
	//         // THIS IS A SEND of the amount received right back out and into the staking pool contract account.
	//         { amount: stakedAmountPayment.amount - mbrAmtPaid, receiver: AppID.fromUint64(poolAppId).address },
	//         // =======
	//         stakedAmountPayment.sender,
	//       ],
	//     })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// examples/reti/validatorRegistry.algo.ts:1258
	// amount: stakedAmountPayment.amount - mbrAmtPaid
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Amount
	frame_dig -3 // mbrAmtPaid: uint64
	-
	itxn_field Amount

	// examples/reti/validatorRegistry.algo.ts:1258
	// receiver: AppID.fromUint64(poolAppId).address
	frame_dig 0 // poolAppId: uint64
	app_params_get AppAddress
	pop
	itxn_field Receiver

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee
	itxn_next
	int 6 // appl
	itxn_field TypeEnum
	pushbytes 0xf9c70cbd // method "addStake(pay,address)uint64"
	itxn_field ApplicationArgs

	// examples/reti/validatorRegistry.algo.ts:1254
	// applicationID: AppID.fromUint64(poolAppId)
	frame_dig 0 // poolAppId: uint64
	itxn_field ApplicationID

	// examples/reti/validatorRegistry.algo.ts:1255
	// methodArgs: [
	//         // =======
	//         // THIS IS A SEND of the amount received right back out and into the staking pool contract account.
	//         { amount: stakedAmountPayment.amount - mbrAmtPaid, receiver: AppID.fromUint64(poolAppId).address },
	//         // =======
	//         stakedAmountPayment.sender,
	//       ]
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Sender
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0
	btoi

	// *if32_condition
	// examples/reti/validatorRegistry.algo.ts:1263
	// globals.opcodeBudget < 500
	global OpcodeBudget
	pushint 500
	<
	bz *if32_end

	// *if32_consequent
	// examples/reti/validatorRegistry.algo.ts:1264
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	pushint 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

*if32_end:
	// examples/reti/validatorRegistry.algo.ts:1268
	// poolNumStakers = AppID.fromUint64(poolAppId).globalState('numStakers') as uint64
	frame_dig 0 // poolAppId: uint64
	byte 0x6e756d5374616b657273 // "numStakers"
	app_global_get_ex

	// global state value does not exist: AppID.fromUint64(poolAppId).globalState('numStakers')
	assert
	frame_bury 1 // poolNumStakers: uint64

	// examples/reti/validatorRegistry.algo.ts:1269
	// poolAlgoStaked = AppID.fromUint64(poolAppId).globalState('staked') as uint64
	frame_dig 0 // poolAppId: uint64
	byte 0x7374616b6564 // "staked"
	app_global_get_ex

	// global state value does not exist: AppID.fromUint64(poolAppId).globalState('staked')
	assert
	frame_bury 2 // poolAlgoStaked: uint64

	// examples/reti/validatorRegistry.algo.ts:1270
	// this.validatorList(poolKey.id).value.pools[poolKey.poolId - 1].totalStakers = poolNumStakers as uint16
	int 268 // headOffset
	frame_dig -2 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 8 // headOffset
	+
	frame_dig 1 // poolNumStakers: uint64
	itob
	extract 6 2
	byte 0x76 // "v"
	frame_dig -2 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:1271
	// this.validatorList(poolKey.id).value.pools[poolKey.poolId - 1].totalAlgoStaked = poolAlgoStaked
	int 268 // headOffset
	frame_dig -2 // poolKey: ValidatorPoolKey
	extract 8 8
	btoi
	int 1
	-
	int 18
	* // acc * typeLength
	+
	int 10 // headOffset
	+
	frame_dig 2 // poolAlgoStaked: uint64
	itob
	byte 0x76 // "v"
	frame_dig -2 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_replace

	// *if33_condition
	// examples/reti/validatorRegistry.algo.ts:1274
	// isNewStakerToValidator
	frame_dig -4 // isNewStakerToValidator: boolean
	bz *if33_end

	// *if33_consequent
	// examples/reti/validatorRegistry.algo.ts:1275
	// this.validatorList(poolKey.id).value.state.totalStakers += 1
	pushint 244
	pushint 244
	int 8
	byte 0x76 // "v"
	frame_dig -2 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	int 1
	+
	itob
	byte 0x76 // "v"
	frame_dig -2 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_replace

*if33_end:
	// *if34_condition
	// examples/reti/validatorRegistry.algo.ts:1277
	// isNewStakerToProtocol
	frame_dig -5 // isNewStakerToProtocol: boolean
	bz *if34_end

	// *if34_consequent
	// examples/reti/validatorRegistry.algo.ts:1278
	// this.numStakers.value += 1
	byte 0x6e756d5374616b657273 // "numStakers"
	app_global_get
	int 1
	+
	byte 0x6e756d5374616b657273 // "numStakers"
	swap
	app_global_put

*if34_end:
	// examples/reti/validatorRegistry.algo.ts:1280
	// this.validatorList(poolKey.id).value.state.totalAlgoStaked += stakedAmountPayment.amount - mbrAmtPaid
	int 252
	dup
	int 8
	byte 0x76 // "v"
	frame_dig -2 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Amount
	frame_dig -3 // mbrAmtPaid: uint64
	-
	+
	itob
	byte 0x76 // "v"
	frame_dig -2 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:1281
	// this.totalAlgoStaked.value += stakedAmountPayment.amount - mbrAmtPaid
	byte 0x7374616b6564 // "staked"
	app_global_get
	frame_dig -1 // stakedAmountPayment: PayTxn
	gtxns Amount
	frame_dig -3 // mbrAmtPaid: uint64
	-
	+
	byte 0x7374616b6564 // "staked"
	swap
	app_global_put
	retsub

// updateStakerPoolSet(staker: Address, poolKey: ValidatorPoolKey): void
updateStakerPoolSet:
	proto 2 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// examples/reti/validatorRegistry.algo.ts:1285
	// assert(this.stakerPoolSet(staker).exists)
	byte 0x737073 // "sps"
	frame_dig -1 // staker: Address
	concat
	box_len
	swap
	pop
	assert

	// examples/reti/validatorRegistry.algo.ts:1287
	// poolSet = clone(this.stakerPoolSet(staker).value)
	byte 0x737073 // "sps"
	frame_dig -1 // staker: Address
	concat
	box_get

	// box value does not exist: this.stakerPoolSet(staker).value
	assert
	frame_bury 0 // poolSet: (uint64,uint64,uint64)[6]

	// examples/reti/validatorRegistry.algo.ts:1288
	// firstEmpty = 0
	int 0
	frame_bury 1 // firstEmpty: uint64

	// examples/reti/validatorRegistry.algo.ts:1289
	// for (let i = 0; i < this.stakerPoolSet(staker).value.length; i += 1)
	int 0
	frame_bury 2 // i: uint64

*for_7:
	// examples/reti/validatorRegistry.algo.ts:1289
	// i < this.stakerPoolSet(staker).value.length
	frame_dig 2 // i: uint64
	int 6
	<
	bz *for_7_end

	// *if35_condition
	// examples/reti/validatorRegistry.algo.ts:1290
	// poolSet[i] === poolKey
	frame_dig 0 // poolSet: (uint64,uint64,uint64)[6]
	frame_dig 2 // i: uint64
	int 24
	* // acc * typeLength
	int 24
	extract3
	frame_dig -2 // poolKey: ValidatorPoolKey
	==
	bz *if35_end

	// *if35_consequent
	// examples/reti/validatorRegistry.algo.ts:1292
	// return;
	retsub

*if35_end:
	// *if36_condition
	// examples/reti/validatorRegistry.algo.ts:1294
	// firstEmpty === 0 && poolSet[i].id === 0
	frame_dig 1 // firstEmpty: uint64
	int 0
	==
	dup
	bz *skip_and8
	frame_dig 0 // poolSet: (uint64,uint64,uint64)[6]
	frame_dig 2 // i: uint64
	int 24
	* // acc * typeLength
	int 0
	+
	int 8
	extract3
	btoi
	int 0
	==
	&&

*skip_and8:
	bz *if36_end

	// *if36_consequent
	// examples/reti/validatorRegistry.algo.ts:1295
	// firstEmpty = i + 1
	frame_dig 2 // i: uint64
	int 1
	+
	frame_bury 1 // firstEmpty: uint64

*if36_end:

*for_7_continue:
	// examples/reti/validatorRegistry.algo.ts:1289
	// i += 1
	frame_dig 2 // i: uint64
	int 1
	+
	frame_bury 2 // i: uint64
	b *for_7

*for_7_end:
	// *if37_condition
	// examples/reti/validatorRegistry.algo.ts:1298
	// firstEmpty === 0
	frame_dig 1 // firstEmpty: uint64
	int 0
	==
	bz *if37_end

	// *if37_consequent
	// No empty slot available in the staker pool set
	err

*if37_end:
	// examples/reti/validatorRegistry.algo.ts:1301
	// this.stakerPoolSet(staker).value[firstEmpty - 1] = poolKey
	frame_dig 1 // firstEmpty: uint64
	int 1
	-
	int 24
	* // acc * typeLength
	frame_dig -2 // poolKey: ValidatorPoolKey
	byte 0x737073 // "sps"
	frame_dig -1 // staker: Address
	concat
	cover 2
	box_replace
	retsub

// removeFromStakerPoolSet(staker: Address, poolKey: ValidatorPoolKey): [boolean, boolean]
//
// Removes a pool key from the staker's active pool set - fails if not found (!)
//
// @param {Address} staker - The address of the staker.
// @param {ValidatorPoolKey} poolKey - The pool key they should be stored in
//
// @return [boolean, boolean] [is the staker gone from ALL pools of the given VALIDATOR, and is staker gone from ALL pools]
removeFromStakerPoolSet:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 4

	// examples/reti/validatorRegistry.algo.ts:1314
	// inSameValidatorPoolCount = 0
	int 0
	frame_bury 0 // inSameValidatorPoolCount: uint64

	// examples/reti/validatorRegistry.algo.ts:1315
	// inAnyPoolCount = 0
	int 0
	frame_bury 1 // inAnyPoolCount: uint64

	// examples/reti/validatorRegistry.algo.ts:1316
	// found = false
	int 0
	frame_bury 2 // found: bool

	// examples/reti/validatorRegistry.algo.ts:1318
	// poolSet = clone(this.stakerPoolSet(staker).value)
	byte 0x737073 // "sps"
	frame_dig -1 // staker: Address
	concat
	box_get

	// box value does not exist: this.stakerPoolSet(staker).value
	assert
	frame_bury 3 // poolSet: (uint64,uint64,uint64)[6]

	// examples/reti/validatorRegistry.algo.ts:1319
	// for (let i = 0; i < this.stakerPoolSet(staker).value.length; i += 1)
	int 0
	frame_bury 4 // i: uint64

*for_8:
	// examples/reti/validatorRegistry.algo.ts:1319
	// i < this.stakerPoolSet(staker).value.length
	frame_dig 4 // i: uint64
	int 6
	<
	bz *for_8_end

	// *if38_condition
	// examples/reti/validatorRegistry.algo.ts:1320
	// poolSet[i].id === 0
	frame_dig 3 // poolSet: (uint64,uint64,uint64)[6]
	frame_dig 4 // i: uint64
	int 24
	* // acc * typeLength
	int 0
	+
	int 8
	extract3
	btoi
	int 0
	==
	bz *if38_end

	// *if38_consequent
	b *for_8_continue

*if38_end:
	// examples/reti/validatorRegistry.algo.ts:1323
	// inAnyPoolCount += 1
	frame_dig 1 // inAnyPoolCount: uint64
	int 1
	+
	frame_bury 1 // inAnyPoolCount: uint64

	// *if39_condition
	// examples/reti/validatorRegistry.algo.ts:1324
	// poolSet[i].id === poolKey.id
	frame_dig 3 // poolSet: (uint64,uint64,uint64)[6]
	frame_dig 4 // i: uint64
	int 24
	* // acc * typeLength
	int 0
	+
	int 8
	extract3
	btoi
	frame_dig -2 // poolKey: ValidatorPoolKey
	extract 0 8
	btoi
	==
	bz *if39_end

	// *if39_consequent
	// *if40_condition
	// examples/reti/validatorRegistry.algo.ts:1325
	// poolSet[i] === poolKey
	frame_dig 3 // poolSet: (uint64,uint64,uint64)[6]
	frame_dig 4 // i: uint64
	int 24
	* // acc * typeLength
	int 24
	extract3
	frame_dig -2 // poolKey: ValidatorPoolKey
	==
	bz *if40_else

	// *if40_consequent
	// examples/reti/validatorRegistry.algo.ts:1326
	// found = true
	int 1
	frame_bury 2 // found: bool

	// examples/reti/validatorRegistry.algo.ts:1328
	// this.stakerPoolSet(staker).value[i] = { id: 0, poolId: 0, poolAppId: 0 }
	frame_dig 4 // i: uint64
	int 24
	* // acc * typeLength
	pushbytes 0x000000000000000000000000000000000000000000000000
	byte 0x737073 // "sps"
	frame_dig -1 // staker: Address
	concat
	cover 2
	box_replace
	b *if40_end

*if40_else:
	// examples/reti/validatorRegistry.algo.ts:1330
	// inSameValidatorPoolCount += 1
	frame_dig 0 // inSameValidatorPoolCount: uint64
	int 1
	+
	frame_bury 0 // inSameValidatorPoolCount: uint64

*if40_end:

*if39_end:

*for_8_continue:
	// examples/reti/validatorRegistry.algo.ts:1319
	// i += 1
	frame_dig 4 // i: uint64
	int 1
	+
	frame_bury 4 // i: uint64
	b *for_8

*for_8_end:
	// *if41_condition
	// examples/reti/validatorRegistry.algo.ts:1334
	// !found
	frame_dig 2 // found: bool
	!
	bz *if41_end

	// *if41_consequent
	// No matching slot found when told to remove a pool from the stakers set
	err

*if41_end:
	// examples/reti/validatorRegistry.algo.ts:1338
	// return [inSameValidatorPoolCount === 0, inAnyPoolCount === 0];
	byte 0x00
	int 0
	frame_dig 0 // inSameValidatorPoolCount: uint64
	int 0
	==
	setbit
	int 1
	frame_dig 1 // inAnyPoolCount: uint64
	int 0
	==
	setbit

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 4
	retsub

// addPoolToNode(validatorId: ValidatorIdType, poolAppId: uint64, nodeNum: uint64): void
addPoolToNode:
	proto 3 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// examples/reti/validatorRegistry.algo.ts:1342
	// nodePoolAssignments = clone(this.validatorList(validatorId).value.nodePoolAssignments)
	int 900 // headOffset
	pushint 192
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	frame_bury 0 // nodePoolAssignments: ((uint64[3])[8])

	// examples/reti/validatorRegistry.algo.ts:1343
	// maxPoolsPerNodeForThisValidator = this.validatorList(validatorId).value.config.poolsPerNode as uint64
	pushint 225
	int 1
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 1 // maxPoolsPerNodeForThisValidator: uint64

	// examples/reti/validatorRegistry.algo.ts:1345
	// assert(nodeNum >= 1 && nodeNum <= MAX_NODES, 'node number not in valid range')
	frame_dig -3 // nodeNum: uint64
	int 1
	>=
	dup
	bz *skip_and9
	frame_dig -3 // nodeNum: uint64
	int 8
	<=
	&&

*skip_and9:
	// node number not in valid range
	assert

	// examples/reti/validatorRegistry.algo.ts:1347
	// for (let i = 0; i < maxPoolsPerNodeForThisValidator; i += 1)
	int 0
	frame_bury 2 // i: uint64

*for_9:
	// examples/reti/validatorRegistry.algo.ts:1347
	// i < maxPoolsPerNodeForThisValidator
	frame_dig 2 // i: uint64
	frame_dig 1 // maxPoolsPerNodeForThisValidator: uint64
	<
	bz *for_9_end

	// *if42_condition
	// examples/reti/validatorRegistry.algo.ts:1348
	// nodePoolAssignments.nodes[nodeNum - 1].poolAppIds[i] === 0
	frame_dig 0 // nodePoolAssignments: ((uint64[3])[8])
	int 0
	frame_dig -3 // nodeNum: uint64
	int 1
	-
	int 24
	* // acc * typeLength
	+
	int 0
	+
	frame_dig 2 // i: uint64
	int 8
	* // acc * typeLength
	+
	int 8
	extract3
	btoi
	int 0
	==
	bz *if42_end

	// *if42_consequent
	// examples/reti/validatorRegistry.algo.ts:1350
	// this.validatorList(validatorId).value.nodePoolAssignments.nodes[nodeNum - 1].poolAppIds[i] = poolAppId
	int 900
	frame_dig -3 // nodeNum: uint64
	int 1
	-
	int 24
	* // acc * typeLength
	+
	int 0
	+
	frame_dig 2 // i: uint64
	int 8
	* // acc * typeLength
	+
	frame_dig -2 // poolAppId: uint64
	itob
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_replace

	// examples/reti/validatorRegistry.algo.ts:1351
	// return;
	retsub

*if42_end:

*for_9_continue:
	// examples/reti/validatorRegistry.algo.ts:1347
	// i += 1
	frame_dig 2 // i: uint64
	int 1
	+
	frame_bury 2 // i: uint64
	b *for_9

*for_9_end:
	// no available space in specified node for this pool
	err
	retsub

// doesStakerMeetGating(validatorId: ValidatorIdType, valueToVerify: uint64): void
//
// Checks if a staker meets the gating requirements specified by the validator.
//
// @param {ValidatorIdType} validatorId - The id of the validator.
// @param {uint64} valueToVerify - The value to verify against the gating requirements.
// @returns {void} or asserts if requirements not met.
doesStakerMeetGating:
	proto 2 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 8

	// examples/reti/validatorRegistry.algo.ts:1365
	// type = this.validatorList(validatorId).value.config.entryGatingType
	pushint 80
	int 1
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 0 // type: uint8

	// *if43_condition
	// examples/reti/validatorRegistry.algo.ts:1366
	// type === GATING_TYPE_NONE
	frame_dig 0 // type: uint8
	int 0
	==
	bz *if43_end

	// *if43_consequent
	// examples/reti/validatorRegistry.algo.ts:1367
	// return;
	retsub

*if43_end:
	// examples/reti/validatorRegistry.algo.ts:1369
	// staker = this.txn.sender
	txn Sender
	frame_bury 1 // staker: address

	// examples/reti/validatorRegistry.algo.ts:1370
	// config = clone(this.validatorList(validatorId).value.config)
	int 0
	int 242
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	frame_bury 2 // config: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)

	// *if44_condition
	// examples/reti/validatorRegistry.algo.ts:1374
	// type === GATING_TYPE_ASSETS_CREATED_BY ||
	//       type === GATING_TYPE_ASSET_ID ||
	//       type === GATING_TYPE_CREATED_BY_NFD_ADDRESSES
	frame_dig 0 // type: uint8
	int 1
	==
	dup
	bnz *skip_or4
	frame_dig 0 // type: uint8
	int 2
	==
	||

*skip_or4:
	dup
	bnz *skip_or5
	frame_dig 0 // type: uint8
	int 3
	==
	||

*skip_or5:
	bz *if44_end

	// *if44_consequent
	// examples/reti/validatorRegistry.algo.ts:1378
	// assert(valueToVerify !== 0)
	frame_dig -2 // valueToVerify: uint64
	int 0
	!=
	assert

	// examples/reti/validatorRegistry.algo.ts:1379
	// balRequired = this.validatorList(validatorId).value.config.gatingAssetMinBalance
	pushint 145
	int 8
	byte 0x76 // "v"
	frame_dig -1 // validatorId: ValidatorIdType
	itob
	concat
	cover 2
	box_extract
	btoi
	frame_bury 3 // balRequired: uint64

	// *if45_condition
	// examples/reti/validatorRegistry.algo.ts:1380
	// balRequired === 0
	frame_dig 3 // balRequired: uint64
	int 0
	==
	bz *if45_end

	// *if45_consequent
	// examples/reti/validatorRegistry.algo.ts:1381
	// balRequired = 1
	int 1
	frame_bury 3 // balRequired: uint64

*if45_end:
	// examples/reti/validatorRegistry.algo.ts:1383
	// assert(
	//         staker.assetBalance(AssetID.fromUint64(valueToVerify)) >= balRequired,
	//         'must have required minimum balance of validator defined token to add stake'
	//       )
	frame_dig 1 // staker: address
	frame_dig -2 // valueToVerify: uint64
	asset_holding_get AssetBalance
	pop
	frame_dig 3 // balRequired: uint64
	>=

	// must have required minimum balance of validator defined token to add stake
	assert

*if44_end:
	// *if46_condition
	// examples/reti/validatorRegistry.algo.ts:1388
	// type === GATING_TYPE_ASSETS_CREATED_BY
	frame_dig 0 // type: uint8
	int 1
	==
	bz *if46_end

	// *if46_consequent
	// examples/reti/validatorRegistry.algo.ts:1389
	// assert(
	//         AssetID.fromUint64(valueToVerify).creator === config.entryGatingAddress,
	//         'specified asset must be created by creator that the validator defined as a requirement to stake'
	//       )
	frame_dig -2 // valueToVerify: uint64
	asset_params_get AssetCreator
	pop
	frame_dig 2 // config: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 81 32
	==

	// specified asset must be created by creator that the validator defined as a requirement to stake
	assert

*if46_end:
	// *if47_condition
	// examples/reti/validatorRegistry.algo.ts:1394
	// type === GATING_TYPE_ASSET_ID
	frame_dig 0 // type: uint8
	int 2
	==
	bz *if47_end

	// *if47_consequent
	// examples/reti/validatorRegistry.algo.ts:1395
	// assert(valueToVerify !== 0)
	frame_dig -2 // valueToVerify: uint64
	int 0
	!=
	assert

	// examples/reti/validatorRegistry.algo.ts:1396
	// found = false
	int 0
	frame_bury 4 // found: bool

	// examples/reti/validatorRegistry.algo.ts:1397
	// config.entryGatingAssets
	frame_dig 2 // config: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 113 32
	dup
	frame_bury 5 // copy of the array we are iterating over
	extract 0 8
	btoi
	frame_bury 6 // assetId: uint64
	int 0
	frame_bury 7 // the offset we are extracting the next element from

*forOf_0:
	// *if48_condition
	// examples/reti/validatorRegistry.algo.ts:1398
	// valueToVerify === assetId
	frame_dig -2 // valueToVerify: uint64
	frame_dig 6 // assetId: uint64
	==
	bz *if48_end

	// *if48_consequent
	// examples/reti/validatorRegistry.algo.ts:1399
	// found = true
	int 1
	frame_bury 4 // found: bool
	b *forOf_0_end

*if48_end:

*forOf_0_continue:
	// increment offset and loop if not out of bounds
	frame_dig 7 // the offset we are extracting the next element from
	int 8
	+
	dup
	int 32 // offset of last element
	<
	bz *forOf_0_end
	frame_bury 7 // the offset we are extracting the next element from
	frame_dig 5 // copy of the array we are iterating over
	frame_dig 7 // the offset we are extracting the next element from
	int 8
	extract
	btoi
	frame_bury 6 // assetId: uint64
	b *forOf_0

*forOf_0_end:
	// examples/reti/validatorRegistry.algo.ts:1403
	// assert(found, 'specified asset must be identical to the asset id defined as a requirement to stake')
	frame_dig 4 // found: bool

	// specified asset must be identical to the asset id defined as a requirement to stake
	assert

*if47_end:
	// *if49_condition
	// examples/reti/validatorRegistry.algo.ts:1405
	// type === GATING_TYPE_CREATED_BY_NFD_ADDRESSES
	frame_dig 0 // type: uint8
	int 3
	==
	bz *if49_end

	// *if49_consequent
	// examples/reti/validatorRegistry.algo.ts:1408
	// assert(
	//         this.isAddressInNFDCAAlgoList(config.entryGatingAssets[0], AssetID.fromUint64(valueToVerify).creator),
	//         'specified asset must be created by creator that is one of the linked addresses in an nfd'
	//       )
	frame_dig -2 // valueToVerify: uint64
	asset_params_get AssetCreator
	pop
	frame_dig 2 // config: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 113 8
	btoi
	callsub isAddressInNFDCAAlgoList

	// specified asset must be created by creator that is one of the linked addresses in an nfd
	assert

*if49_end:
	// *if50_condition
	// examples/reti/validatorRegistry.algo.ts:1413
	// type === GATING_TYPE_SEGMENT_OF_NFD
	frame_dig 0 // type: uint8
	pushint 4
	==
	bz *if50_end

	// *if50_consequent
	// examples/reti/validatorRegistry.algo.ts:1415
	// userOfferedNFDAppID = valueToVerify
	frame_dig -2 // valueToVerify: uint64
	frame_bury 8 // userOfferedNFDAppID: uint64

	// examples/reti/validatorRegistry.algo.ts:1416
	// assert(this.isNFDAppIDValid(userOfferedNFDAppID), 'provided NFD must be valid')
	frame_dig 8 // userOfferedNFDAppID: uint64
	callsub isNFDAppIDValid

	// provided NFD must be valid
	assert

	// examples/reti/validatorRegistry.algo.ts:1419
	// assert(
	//         rawBytes(AppID.fromUint64(userOfferedNFDAppID).globalState('i.owner.a') as Address) === rawBytes(staker) ||
	//           this.isAddressInNFDCAAlgoList(userOfferedNFDAppID, staker),
	//         "provided nfd for entry isn't owned or linked to the staker"
	//       )
	frame_dig 8 // userOfferedNFDAppID: uint64
	byte 0x692e6f776e65722e61 // "i.owner.a"
	app_global_get_ex

	// global state value does not exist: AppID.fromUint64(userOfferedNFDAppID).globalState('i.owner.a')
	assert
	frame_dig 1 // staker: address
	==
	dup
	bnz *skip_or6
	frame_dig 1 // staker: address
	frame_dig 8 // userOfferedNFDAppID: uint64
	callsub isAddressInNFDCAAlgoList
	||

*skip_or6:
	// provided nfd for entry isn't owned or linked to the staker
	assert

	// examples/reti/validatorRegistry.algo.ts:1426
	// assert(
	//         btoi(AppID.fromUint64(userOfferedNFDAppID).globalState('i.parentAppID') as bytes) ===
	//           config.entryGatingAssets[0],
	//         'specified nfd must be a segment of the nfd the validator specified as a requirement'
	//       )
	frame_dig 8 // userOfferedNFDAppID: uint64
	pushbytes 0x692e706172656e744170704944 // "i.parentAppID"
	app_global_get_ex

	// global state value does not exist: AppID.fromUint64(userOfferedNFDAppID).globalState('i.parentAppID')
	assert
	btoi
	frame_dig 2 // config: (uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)
	extract 113 8
	btoi
	==

	// specified nfd must be a segment of the nfd the validator specified as a requirement
	assert

*if50_end:
	retsub

// isNFDAppIDValid(nfdAppID: uint64): boolean
//
// Checks if the given NFD App id is valid.  Using only the App id there's no validation against the name (ie: that nfd X is name Y)
// So it's assumed for the caller, the app id alone is fine.  The name is fetched from the specified app id and the two
// together are used for validity check call to the nfd registry.
//
// @param {uint64} nfdAppID - The NFD App id to verify.
//
// @returns {boolean} - Returns true if the NFD App id is valid, otherwise false.
isNFDAppIDValid:
	proto 1 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/reti/validatorRegistry.algo.ts:1445
	// userOfferedNFDName = AppID.fromUint64(nfdAppID).globalState('i.name') as string
	frame_dig -1 // nfdAppID: uint64
	pushbytes 0x692e6e616d65 // "i.name"
	app_global_get_ex

	// global state value does not exist: AppID.fromUint64(nfdAppID).globalState('i.name')
	assert
	frame_bury 0 // userOfferedNFDName: string

	// examples/reti/validatorRegistry.algo.ts:1447
	// sendAppCall({
	//       applicationID: AppID.fromUint64(this.nfdRegistryAppId),
	//       applicationArgs: ['is_valid_nfd_appid', userOfferedNFDName, itob(nfdAppID)],
	//       applications: [AppID.fromUint64(nfdAppID)],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum

	// examples/reti/validatorRegistry.algo.ts:1448
	// applicationID: AppID.fromUint64(this.nfdRegistryAppId)
	intc 0 // TMPL_nfdRegistryAppId
	itxn_field ApplicationID

	// examples/reti/validatorRegistry.algo.ts:1449
	// applicationArgs: ['is_valid_nfd_appid', userOfferedNFDName, itob(nfdAppID)]
	byte 0x69735f76616c69645f6e66645f6170706964 // "is_valid_nfd_appid"
	itxn_field ApplicationArgs
	frame_dig 0 // userOfferedNFDName: string
	itxn_field ApplicationArgs
	frame_dig -1 // nfdAppID: uint64
	itob
	itxn_field ApplicationArgs

	// examples/reti/validatorRegistry.algo.ts:1450
	// applications: [AppID.fromUint64(nfdAppID)]
	frame_dig -1 // nfdAppID: uint64
	itxn_field Applications

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/validatorRegistry.algo.ts:1452
	// return btoi(this.itxn.lastLog) === 1;
	itxn LastLog
	btoi
	int 1
	==

	// set the subroutine return value
	frame_bury 0
	retsub

// isAddressInNFDCAAlgoList(nfdAppID: uint64, addrToFind: Address): boolean
//
// Checks if the specified address is present in an NFDs list of verified addresses.
// The NFD is assumed to have already been validated as official.
//
// @param {uint64} nfdAppID - The NFD application id.
// @param {Address} addrToFind - The address to find in the v.caAlgo.0.as property
// @return {boolean} - `true` if the address is present, `false` otherwise.
isAddressInNFDCAAlgoList:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// examples/reti/validatorRegistry.algo.ts:1464
	// sendAppCall({
	//       applicationID: AppID.fromUint64(nfdAppID),
	//       applicationArgs: ['read_property', 'v.caAlgo.0.as'],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum

	// examples/reti/validatorRegistry.algo.ts:1465
	// applicationID: AppID.fromUint64(nfdAppID)
	frame_dig -1 // nfdAppID: uint64
	itxn_field ApplicationID

	// examples/reti/validatorRegistry.algo.ts:1466
	// applicationArgs: ['read_property', 'v.caAlgo.0.as']
	pushbytes 0x726561645f70726f7065727479 // "read_property"
	itxn_field ApplicationArgs
	pushbytes 0x762e6361416c676f2e302e6173 // "v.caAlgo.0.as"
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit

	// examples/reti/validatorRegistry.algo.ts:1468
	// caAlgoData = this.itxn.lastLog
	itxn LastLog
	frame_bury 0 // caAlgoData: byte[]

	// examples/reti/validatorRegistry.algo.ts:1469
	// for (let i = 0; i < caAlgoData.length; i += 32)
	int 0
	frame_bury 1 // i: uint64

*for_10:
	// examples/reti/validatorRegistry.algo.ts:1469
	// i < caAlgoData.length
	frame_dig 1 // i: uint64
	frame_dig 0 // caAlgoData: byte[]
	len
	<
	bz *for_10_end

	// examples/reti/validatorRegistry.algo.ts:1470
	// addr = extract3(caAlgoData, i, 32)
	frame_dig 0 // caAlgoData: byte[]
	frame_dig 1 // i: uint64
	int 32
	extract3
	frame_bury 2 // addr: byte[]

	// *if51_condition
	// examples/reti/validatorRegistry.algo.ts:1471
	// addr !== rawBytes(globals.zeroAddress) && addr === rawBytes(addrToFind)
	frame_dig 2 // addr: byte[]
	global ZeroAddress
	!=
	dup
	bz *skip_and10
	frame_dig 2 // addr: byte[]
	frame_dig -2 // addrToFind: Address
	==
	&&

*skip_and10:
	bz *if51_end

	// *if51_consequent
	// examples/reti/validatorRegistry.algo.ts:1472
	// return true;
	int 1
	b *isAddressInNFDCAAlgoList*return

*if51_end:

*for_10_continue:
	// examples/reti/validatorRegistry.algo.ts:1469
	// i += 32
	frame_dig 1 // i: uint64
	int 32
	+
	frame_bury 1 // i: uint64
	b *for_10

*for_10_end:
	// examples/reti/validatorRegistry.algo.ts:1475
	// return false;
	int 0

*isAddressInNFDCAAlgoList*return:
	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 2
	retsub

// algoSaturationLevel(): uint64
//
// Returns the maximum allowed stake per validator based on a percentage of all current online stake before
// the validator is considered saturated - where rewards are diminished.
// NOTE: this function is defined twice - here and in staking pool contract.  Both must be identical.
algoSaturationLevel:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/reti/validatorRegistry.algo.ts:1484
	// online = this.getCurrentOnlineStake()
	callsub getCurrentOnlineStake
	frame_bury 0 // online: uint64

	// examples/reti/validatorRegistry.algo.ts:1486
	// return wideRatio([online, MAX_VALIDATOR_SOFT_PCT_OF_ONLINE_1DECIMAL], [1000]);
	frame_dig 0 // online: uint64
	pushint 100
	mulw
	int 0
	pushint 1000
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert

	// set the subroutine return value
	frame_bury 0
	retsub

// maxAllowedStake(): uint64
//
// Returns the MAXIMUM allowed stake per validator based on a percentage of all current online stake.
// Adding stake is completely blocked at this amount.
maxAllowedStake:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/reti/validatorRegistry.algo.ts:1494
	// online = this.getCurrentOnlineStake()
	callsub getCurrentOnlineStake
	frame_bury 0 // online: uint64

	// examples/reti/validatorRegistry.algo.ts:1496
	// return wideRatio([online, MAX_VALIDATOR_HARD_PCT_OF_ONLINE_1DECIMAL], [1000]);
	frame_dig 0 // online: uint64
	pushint 150
	mulw
	int 0
	pushint 1000
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert

	// set the subroutine return value
	frame_bury 0
	retsub

// maxAlgoAllowedPerPool(): uint64
//
// Returns the MAXIMUM allowed stake per pool and still receive incentives - we'll treat this as the 'max per pool'
maxAlgoAllowedPerPool:
	proto 0 1

	// examples/reti/validatorRegistry.algo.ts:1504
	// return 70_000_000_000_000;
	pushint 70_000_000_000_000
	retsub

// getCurrentOnlineStake(): uint64
getCurrentOnlineStake:
	proto 0 1

	// examples/reti/validatorRegistry.algo.ts:1509
	// return 2_000_000_000_000_000;
	pushint 2_000_000_000_000_000
	retsub

// minBalanceForAccount(contracts: uint64, extraPages: uint64, assets: uint64, localInts: uint64, localBytes: uint64, globalInts: uint64, globalBytes: uint64): uint64
minBalanceForAccount:
	proto 7 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/reti/validatorRegistry.algo.ts:1521
	// minBal = ALGORAND_ACCOUNT_MIN_BALANCE
	int 100000
	frame_bury 0 // minBal: uint64

	// examples/reti/validatorRegistry.algo.ts:1522
	// minBal += contracts * APPLICATION_BASE_FEE
	frame_dig 0 // minBal: uint64
	frame_dig -1 // contracts: uint64
	int 100000
	*
	+
	frame_bury 0 // minBal: uint64

	// examples/reti/validatorRegistry.algo.ts:1523
	// minBal += extraPages * APPLICATION_BASE_FEE
	frame_dig 0 // minBal: uint64
	frame_dig -2 // extraPages: uint64
	int 100000
	*
	+
	frame_bury 0 // minBal: uint64

	// examples/reti/validatorRegistry.algo.ts:1524
	// minBal += assets * ASSET_HOLDING_FEE
	frame_dig 0 // minBal: uint64
	frame_dig -3 // assets: uint64
	int 100000
	*
	+
	frame_bury 0 // minBal: uint64

	// examples/reti/validatorRegistry.algo.ts:1525
	// minBal += localInts * SSC_VALUE_UINT
	frame_dig 0 // minBal: uint64
	frame_dig -4 // localInts: uint64
	pushint 28500
	*
	+
	frame_bury 0 // minBal: uint64

	// examples/reti/validatorRegistry.algo.ts:1526
	// minBal += globalInts * SSC_VALUE_UINT
	frame_dig 0 // minBal: uint64
	frame_dig -6 // globalInts: uint64
	pushint 28500
	*
	+
	frame_bury 0 // minBal: uint64

	// examples/reti/validatorRegistry.algo.ts:1527
	// minBal += localBytes * SSC_VALUE_BYTES
	frame_dig 0 // minBal: uint64
	frame_dig -5 // localBytes: uint64
	pushint 50000
	*
	+
	frame_bury 0 // minBal: uint64

	// examples/reti/validatorRegistry.algo.ts:1528
	// minBal += globalBytes * SSC_VALUE_BYTES
	frame_dig 0 // minBal: uint64
	frame_dig -7 // globalBytes: uint64
	pushint 50000
	*
	+
	frame_bury 0 // minBal: uint64

	// examples/reti/validatorRegistry.algo.ts:1529
	// return minBal;
	frame_dig 0 // minBal: uint64

	// set the subroutine return value
	frame_bury 0
	retsub

// costForBoxStorage(totalNumBytes: uint64): uint64
costForBoxStorage:
	proto 1 1

	// examples/reti/validatorRegistry.algo.ts:1536
	// return SCBOX_PERBOX + totalNumBytes * SCBOX_PERBYTE;
	pushint 2500
	frame_dig -1 // totalNumBytes: uint64
	pushint 400
	*
	+
	retsub

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x1b5e82c6 // method "initStakingContract(uint64)void"
	pushbytes 0x79472d83 // method "loadStakingContractData(uint64,byte[])void"
	pushbytes 0x5f7acfd9 // method "finalizeStakingContract()void"
	pushbytes 0x3172ca9d // method "gas()void"
	pushbytes 0x8a87142d // method "getMbrAmounts()(uint64,uint64,uint64,uint64)"
	pushbytes 0xd1366cc3 // method "getProtocolConstraints()(uint64,uint64,uint64,uint64,uint64,uint64,uint64,uint64,uint64,uint64,uint64)"
	pushbytes 0x3b045c5c // method "getNumValidators()uint64"
	pushbytes 0x75aff61d // method "getValidatorConfig(uint64)(uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64)"
	pushbytes 0x1f2f0109 // method "getValidatorState(uint64)(uint16,uint64,uint64,uint64)"
	pushbytes 0x2fa22c4b // method "getValidatorOwnerAndManager(uint64)(address,address)"
	pushbytes 0x910e94ac // method "getPools(uint64)(uint64,uint16,uint64)[]"
	pushbytes 0x572767d1 // method "getPoolAppId(uint64,uint64)uint64"
	pushbytes 0x9b504aaf // method "getPoolInfo((uint64,uint64,uint64))(uint64,uint16,uint64)"
	pushbytes 0xfbc63178 // method "getCurMaxStakePerPool(uint64)uint64"
	pushbytes 0x24498cf4 // method "doesStakerNeedToPayMBR(address)bool"
	pushbytes 0xf846dd7a // method "getStakedPoolsForAccount(address)(uint64,uint64,uint64)[]"
	pushbytes 0x83050501 // method "getTokenPayoutRatio(uint64)(uint64[24],uint64)"
	pushbytes 0x7bbb6c8d // method "getNodePoolAssignments(uint64)((uint64[3])[8])"
	pushbytes 0xf839414a // method "getNFDRegistryID()uint64"
	pushbytes 0x0c317cfb // method "addValidator(pay,string,(uint64,address,address,uint64,uint8,address,uint64[4],uint64,uint64,uint64,uint32,uint32,address,uint64,uint64,uint8,uint64,uint64))uint64"
	pushbytes 0x3e288972 // method "changeValidatorManager(uint64,address)void"
	pushbytes 0xdd5faada // method "changeValidatorSunsetInfo(uint64,uint64,uint64)void"
	pushbytes 0x18aac7a7 // method "changeValidatorNFD(uint64,uint64,string)void"
	pushbytes 0xf99ef54d // method "changeValidatorCommissionAddress(uint64,address)void"
	pushbytes 0x10809d4d // method "changeValidatorRewardInfo(uint64,uint8,address,uint64[4],uint64,uint64)void"
	pushbytes 0xe778dd5a // method "addPool(pay,uint64,uint64)(uint64,uint64,uint64)"
	pushbytes 0xbf5259d0 // method "addStake(pay,uint64,uint64)(uint64,uint64,uint64)"
	pushbytes 0x4df8d86e // method "setTokenPayoutRatio(uint64)(uint64[24],uint64)"
	pushbytes 0x418fcefc // method "stakeUpdatedViaRewards((uint64,uint64,uint64),uint64,uint64,uint64,uint64)void"
	pushbytes 0xa2dc51b5 // method "stakeRemoved((uint64,uint64,uint64),address,uint64,uint64,bool)void"
	pushbytes 0x2873f504 // method "findPoolForStaker(uint64,address,uint64)((uint64,uint64,uint64),bool,bool)"
	pushbytes 0x0547f4fe // method "movePoolToNode(uint64,uint64,uint64)void"
	pushbytes 0xcb668358 // method "emptyTokenRewards(uint64,address)uint64"
	txna ApplicationArgs 0
	match *abi_route_initStakingContract *abi_route_loadStakingContractData *abi_route_finalizeStakingContract *abi_route_gas *abi_route_getMbrAmounts *abi_route_getProtocolConstraints *abi_route_getNumValidators *abi_route_getValidatorConfig *abi_route_getValidatorState *abi_route_getValidatorOwnerAndManager *abi_route_getPools *abi_route_getPoolAppId *abi_route_getPoolInfo *abi_route_getCurMaxStakePerPool *abi_route_doesStakerNeedToPayMBR *abi_route_getStakedPoolsForAccount *abi_route_getTokenPayoutRatio *abi_route_getNodePoolAssignments *abi_route_getNFDRegistryID *abi_route_addValidator *abi_route_changeValidatorManager *abi_route_changeValidatorSunsetInfo *abi_route_changeValidatorNFD *abi_route_changeValidatorCommissionAddress *abi_route_changeValidatorRewardInfo *abi_route_addPool *abi_route_addStake *abi_route_setTokenPayoutRatio *abi_route_stakeUpdatedViaRewards *abi_route_stakeRemoved *abi_route_findPoolForStaker *abi_route_movePoolToNode *abi_route_emptyTokenRewards

	// this contract does not implement the given ABI method for call NoOp
	err

*call_UpdateApplication:
	pushbytes 0x46f76533 // method "updateApplication()void"
	txna ApplicationArgs 0
	match *abi_route_updateApplication

	// this contract does not implement the given ABI method for call UpdateApplication
	err", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "templateVariables": { diff --git a/examples/simple/artifacts/Simple.approval.teal b/examples/simple/artifacts/Simple.approval.teal index 679847266..c36524ac2 100644 --- a/examples/simple/artifacts/Simple.approval.teal +++ b/examples/simple/artifacts/Simple.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF 0x636f756e746572 0x151f7c75 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/examples/simple/artifacts/Simple.arc32.json b/examples/simple/artifacts/Simple.arc32.json index eef488777..9ae8c2798 100644 --- a/examples/simple/artifacts/Simple.arc32.json +++ b/examples/simple/artifacts/Simple.arc32.json @@ -59,7 +59,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHhGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGIDB4NjM2Zjc1NmU3NDY1NzIgMHgxNTFmN2M3NQoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDQuMQovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIGluY3JlbWVudENvdW50ZXIoaTogdWludDY0KTogdm9pZAppbmNyZW1lbnRDb3VudGVyOgoJcHJvdG8gMSAwCgoJLy8gZXhhbXBsZXMvc2ltcGxlL3NpbXBsZS5hbGdvLnRzOjcKCS8vIHRoaXMuY291bnRlci52YWx1ZSA9IHRoaXMuY291bnRlci52YWx1ZSArIGkKCWJ5dGUgMHg2MzZmNzU2ZTc0NjU3MiAvLyAiY291bnRlciIKCWR1cAoJYXBwX2dsb2JhbF9nZXQKCWZyYW1lX2RpZyAtMSAvLyBpOiB1aW50NjQKCSsKCWFwcF9nbG9iYWxfcHV0CglyZXRzdWIKCi8vIGluY3IodWludDY0KXZvaWQKKmFiaV9yb3V0ZV9pbmNyOgoJLy8gaTogdWludDY0Cgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglidG9pCgoJLy8gZXhlY3V0ZSBpbmNyKHVpbnQ2NCl2b2lkCgljYWxsc3ViIGluY3IKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBpbmNyKGk6IHVpbnQ2NCk6IHZvaWQKaW5jcjoKCXByb3RvIDEgMAoKCS8vIGV4YW1wbGVzL3NpbXBsZS9zaW1wbGUuYWxnby50czoxMQoJLy8gdGhpcy5pbmNyZW1lbnRDb3VudGVyKGkpCglmcmFtZV9kaWcgLTEgLy8gaTogdWludDY0CgljYWxsc3ViIGluY3JlbWVudENvdW50ZXIKCXJldHN1YgoKLy8gZGVjcih1aW50NjQpdm9pZAoqYWJpX3JvdXRlX2RlY3I6CgkvLyBpOiB1aW50NjQKCXR4bmEgQXBwbGljYXRpb25BcmdzIDEKCWJ0b2kKCgkvLyBleGVjdXRlIGRlY3IodWludDY0KXZvaWQKCWNhbGxzdWIgZGVjcgoJcHVzaGludCAxCglyZXR1cm4KCi8vIGRlY3IoaTogdWludDY0KTogdm9pZApkZWNyOgoJcHJvdG8gMSAwCgoJLy8gZXhhbXBsZXMvc2ltcGxlL3NpbXBsZS5hbGdvLnRzOjE1CgkvLyB0aGlzLmNvdW50ZXIudmFsdWUgPSB0aGlzLmNvdW50ZXIudmFsdWUgLSBpCglieXRlIDB4NjM2Zjc1NmU3NDY1NzIgLy8gImNvdW50ZXIiCglkdXAKCWFwcF9nbG9iYWxfZ2V0CglmcmFtZV9kaWcgLTEgLy8gaTogdWludDY0CgktCglhcHBfZ2xvYmFsX3B1dAoJcmV0c3ViCgovLyBhZGQodWludDI1Nix1aW50MjU2KXVpbnQyNTYKKmFiaV9yb3V0ZV9hZGQ6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCWJ5dGUgMHgxNTFmN2M3NQoKCS8vIGI6IHVpbnQyNTYKCXR4bmEgQXBwbGljYXRpb25BcmdzIDIKCWR1cAoJbGVuCglwdXNoaW50IDMyCgk9PQoKCS8vIGFyZ3VtZW50IDAgKGIpIGZvciBhZGQgbXVzdCBiZSBhIHVpbnQyNTYKCWFzc2VydAoKCS8vIGE6IHVpbnQyNTYKCXR4bmEgQXBwbGljYXRpb25BcmdzIDEKCWR1cAoJbGVuCglwdXNoaW50IDMyCgk9PQoKCS8vIGFyZ3VtZW50IDEgKGEpIGZvciBhZGQgbXVzdCBiZSBhIHVpbnQyNTYKCWFzc2VydAoKCS8vIGV4ZWN1dGUgYWRkKHVpbnQyNTYsdWludDI1Nil1aW50MjU2CgljYWxsc3ViIGFkZAoJZHVwCgliaXRsZW4KCXB1c2hpbnQgMjU2Cgk8PQoKCS8vIGFkZCByZXR1cm4gdmFsdWUgb3ZlcmZsb3dlZCAyNTYgYml0cwoJYXNzZXJ0CglieXRlIDB4RkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRgoJYiYKCWR1cAoJbGVuCglkdXAKCXB1c2hpbnQgMzIKCS0KCXN3YXAKCXN1YnN0cmluZzMKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gYWRkKGE6IHVpbnQyNTYsIGI6IHVpbnQyNTYpOiB1aW50MjU2CmFkZDoKCXByb3RvIDIgMQoKCS8vIGV4YW1wbGVzL3NpbXBsZS9zaW1wbGUuYWxnby50czoxOQoJLy8gcmV0dXJuIGEgKyBiOwoJZnJhbWVfZGlnIC0xIC8vIGE6IHVpbnQyNTYKCWZyYW1lX2RpZyAtMiAvLyBiOiB1aW50MjU2CgliKwoJcmV0c3ViCgovLyBzdWIodWludDI1Nix1aW50MjU2KXVpbnQyNTYKKmFiaV9yb3V0ZV9zdWI6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCWJ5dGUgMHgxNTFmN2M3NQoKCS8vIGI6IHVpbnQyNTYKCXR4bmEgQXBwbGljYXRpb25BcmdzIDIKCWR1cAoJbGVuCglwdXNoaW50IDMyCgk9PQoKCS8vIGFyZ3VtZW50IDAgKGIpIGZvciBzdWIgbXVzdCBiZSBhIHVpbnQyNTYKCWFzc2VydAoKCS8vIGE6IHVpbnQyNTYKCXR4bmEgQXBwbGljYXRpb25BcmdzIDEKCWR1cAoJbGVuCglwdXNoaW50IDMyCgk9PQoKCS8vIGFyZ3VtZW50IDEgKGEpIGZvciBzdWIgbXVzdCBiZSBhIHVpbnQyNTYKCWFzc2VydAoKCS8vIGV4ZWN1dGUgc3ViKHVpbnQyNTYsdWludDI1Nil1aW50MjU2CgljYWxsc3ViIHN1YgoJZHVwCgliaXRsZW4KCXB1c2hpbnQgMjU2Cgk8PQoKCS8vIHN1YiByZXR1cm4gdmFsdWUgb3ZlcmZsb3dlZCAyNTYgYml0cwoJYXNzZXJ0CglieXRlIDB4RkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRgoJYiYKCWR1cAoJbGVuCglkdXAKCXB1c2hpbnQgMzIKCS0KCXN3YXAKCXN1YnN0cmluZzMKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gc3ViKGE6IHVpbnQyNTYsIGI6IHVpbnQyNTYpOiB1aW50MjU2CnN1YjoKCXByb3RvIDIgMQoKCS8vIGV4YW1wbGVzL3NpbXBsZS9zaW1wbGUuYWxnby50czoyMwoJLy8gcmV0dXJuIGEgLSBiOwoJZnJhbWVfZGlnIC0xIC8vIGE6IHVpbnQyNTYKCWZyYW1lX2RpZyAtMiAvLyBiOiB1aW50MjU2CgliLQoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg5ZmFiODYxMCAvLyBtZXRob2QgImluY3IodWludDY0KXZvaWQiCglwdXNoYnl0ZXMgMHgyZTBjNWE0NyAvLyBtZXRob2QgImRlY3IodWludDY0KXZvaWQiCglwdXNoYnl0ZXMgMHhhYzk3NmUwMiAvLyBtZXRob2QgImFkZCh1aW50MjU2LHVpbnQyNTYpdWludDI1NiIKCXB1c2hieXRlcyAweDA5MWIzMmE3IC8vIG1ldGhvZCAic3ViKHVpbnQyNTYsdWludDI1Nil1aW50MjU2IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9pbmNyICphYmlfcm91dGVfZGVjciAqYWJpX3JvdXRlX2FkZCAqYWJpX3JvdXRlX3N1YgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHhGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGIDB4NjM2Zjc1NmU3NDY1NzIgMHgxNTFmN2M3NQoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDUuMAovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIGluY3JlbWVudENvdW50ZXIoaTogdWludDY0KTogdm9pZAppbmNyZW1lbnRDb3VudGVyOgoJcHJvdG8gMSAwCgoJLy8gZXhhbXBsZXMvc2ltcGxlL3NpbXBsZS5hbGdvLnRzOjcKCS8vIHRoaXMuY291bnRlci52YWx1ZSA9IHRoaXMuY291bnRlci52YWx1ZSArIGkKCWJ5dGUgMHg2MzZmNzU2ZTc0NjU3MiAvLyAiY291bnRlciIKCWR1cAoJYXBwX2dsb2JhbF9nZXQKCWZyYW1lX2RpZyAtMSAvLyBpOiB1aW50NjQKCSsKCWFwcF9nbG9iYWxfcHV0CglyZXRzdWIKCi8vIGluY3IodWludDY0KXZvaWQKKmFiaV9yb3V0ZV9pbmNyOgoJLy8gaTogdWludDY0Cgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglidG9pCgoJLy8gZXhlY3V0ZSBpbmNyKHVpbnQ2NCl2b2lkCgljYWxsc3ViIGluY3IKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBpbmNyKGk6IHVpbnQ2NCk6IHZvaWQKaW5jcjoKCXByb3RvIDEgMAoKCS8vIGV4YW1wbGVzL3NpbXBsZS9zaW1wbGUuYWxnby50czoxMQoJLy8gdGhpcy5pbmNyZW1lbnRDb3VudGVyKGkpCglmcmFtZV9kaWcgLTEgLy8gaTogdWludDY0CgljYWxsc3ViIGluY3JlbWVudENvdW50ZXIKCXJldHN1YgoKLy8gZGVjcih1aW50NjQpdm9pZAoqYWJpX3JvdXRlX2RlY3I6CgkvLyBpOiB1aW50NjQKCXR4bmEgQXBwbGljYXRpb25BcmdzIDEKCWJ0b2kKCgkvLyBleGVjdXRlIGRlY3IodWludDY0KXZvaWQKCWNhbGxzdWIgZGVjcgoJcHVzaGludCAxCglyZXR1cm4KCi8vIGRlY3IoaTogdWludDY0KTogdm9pZApkZWNyOgoJcHJvdG8gMSAwCgoJLy8gZXhhbXBsZXMvc2ltcGxlL3NpbXBsZS5hbGdvLnRzOjE1CgkvLyB0aGlzLmNvdW50ZXIudmFsdWUgPSB0aGlzLmNvdW50ZXIudmFsdWUgLSBpCglieXRlIDB4NjM2Zjc1NmU3NDY1NzIgLy8gImNvdW50ZXIiCglkdXAKCWFwcF9nbG9iYWxfZ2V0CglmcmFtZV9kaWcgLTEgLy8gaTogdWludDY0CgktCglhcHBfZ2xvYmFsX3B1dAoJcmV0c3ViCgovLyBhZGQodWludDI1Nix1aW50MjU2KXVpbnQyNTYKKmFiaV9yb3V0ZV9hZGQ6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCWJ5dGUgMHgxNTFmN2M3NQoKCS8vIGI6IHVpbnQyNTYKCXR4bmEgQXBwbGljYXRpb25BcmdzIDIKCWR1cAoJbGVuCglwdXNoaW50IDMyCgk9PQoKCS8vIGFyZ3VtZW50IDAgKGIpIGZvciBhZGQgbXVzdCBiZSBhIHVpbnQyNTYKCWFzc2VydAoKCS8vIGE6IHVpbnQyNTYKCXR4bmEgQXBwbGljYXRpb25BcmdzIDEKCWR1cAoJbGVuCglwdXNoaW50IDMyCgk9PQoKCS8vIGFyZ3VtZW50IDEgKGEpIGZvciBhZGQgbXVzdCBiZSBhIHVpbnQyNTYKCWFzc2VydAoKCS8vIGV4ZWN1dGUgYWRkKHVpbnQyNTYsdWludDI1Nil1aW50MjU2CgljYWxsc3ViIGFkZAoJZHVwCgliaXRsZW4KCXB1c2hpbnQgMjU2Cgk8PQoKCS8vIGFkZCByZXR1cm4gdmFsdWUgb3ZlcmZsb3dlZCAyNTYgYml0cwoJYXNzZXJ0CglieXRlIDB4RkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRgoJYiYKCWR1cAoJbGVuCglkdXAKCXB1c2hpbnQgMzIKCS0KCXN3YXAKCXN1YnN0cmluZzMKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gYWRkKGE6IHVpbnQyNTYsIGI6IHVpbnQyNTYpOiB1aW50MjU2CmFkZDoKCXByb3RvIDIgMQoKCS8vIGV4YW1wbGVzL3NpbXBsZS9zaW1wbGUuYWxnby50czoxOQoJLy8gcmV0dXJuIGEgKyBiOwoJZnJhbWVfZGlnIC0xIC8vIGE6IHVpbnQyNTYKCWZyYW1lX2RpZyAtMiAvLyBiOiB1aW50MjU2CgliKwoJcmV0c3ViCgovLyBzdWIodWludDI1Nix1aW50MjU2KXVpbnQyNTYKKmFiaV9yb3V0ZV9zdWI6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCWJ5dGUgMHgxNTFmN2M3NQoKCS8vIGI6IHVpbnQyNTYKCXR4bmEgQXBwbGljYXRpb25BcmdzIDIKCWR1cAoJbGVuCglwdXNoaW50IDMyCgk9PQoKCS8vIGFyZ3VtZW50IDAgKGIpIGZvciBzdWIgbXVzdCBiZSBhIHVpbnQyNTYKCWFzc2VydAoKCS8vIGE6IHVpbnQyNTYKCXR4bmEgQXBwbGljYXRpb25BcmdzIDEKCWR1cAoJbGVuCglwdXNoaW50IDMyCgk9PQoKCS8vIGFyZ3VtZW50IDEgKGEpIGZvciBzdWIgbXVzdCBiZSBhIHVpbnQyNTYKCWFzc2VydAoKCS8vIGV4ZWN1dGUgc3ViKHVpbnQyNTYsdWludDI1Nil1aW50MjU2CgljYWxsc3ViIHN1YgoJZHVwCgliaXRsZW4KCXB1c2hpbnQgMjU2Cgk8PQoKCS8vIHN1YiByZXR1cm4gdmFsdWUgb3ZlcmZsb3dlZCAyNTYgYml0cwoJYXNzZXJ0CglieXRlIDB4RkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRgoJYiYKCWR1cAoJbGVuCglkdXAKCXB1c2hpbnQgMzIKCS0KCXN3YXAKCXN1YnN0cmluZzMKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gc3ViKGE6IHVpbnQyNTYsIGI6IHVpbnQyNTYpOiB1aW50MjU2CnN1YjoKCXByb3RvIDIgMQoKCS8vIGV4YW1wbGVzL3NpbXBsZS9zaW1wbGUuYWxnby50czoyMwoJLy8gcmV0dXJuIGEgLSBiOwoJZnJhbWVfZGlnIC0xIC8vIGE6IHVpbnQyNTYKCWZyYW1lX2RpZyAtMiAvLyBiOiB1aW50MjU2CgliLQoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg5ZmFiODYxMCAvLyBtZXRob2QgImluY3IodWludDY0KXZvaWQiCglwdXNoYnl0ZXMgMHgyZTBjNWE0NyAvLyBtZXRob2QgImRlY3IodWludDY0KXZvaWQiCglwdXNoYnl0ZXMgMHhhYzk3NmUwMiAvLyBtZXRob2QgImFkZCh1aW50MjU2LHVpbnQyNTYpdWludDI1NiIKCXB1c2hieXRlcyAweDA5MWIzMmE3IC8vIG1ldGhvZCAic3ViKHVpbnQyNTYsdWludDI1Nil1aW50MjU2IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9pbmNyICphYmlfcm91dGVfZGVjciAqYWJpX3JvdXRlX2FkZCAqYWJpX3JvdXRlX3N1YgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBleGFtcGxlcy9zaW1wbGUvc2ltcGxlLmFsZ28udHM6MjcKLy8gdGhpcy5pbmNyZW1lbnRDb3VudGVyKDEpCmJ5dGVjYmxvY2sgMHg2MzZmNzU2ZTc0NjU3MgpwdXNoaW50IDEKY2FsbHN1YiBpbmNyZW1lbnRDb3VudGVyCnB1c2hpbnQgMQpyZXR1cm4KCi8vIGluY3JlbWVudENvdW50ZXIoaTogdWludDY0KTogdm9pZAppbmNyZW1lbnRDb3VudGVyOgoJcHJvdG8gMSAwCgoJLy8gZXhhbXBsZXMvc2ltcGxlL3NpbXBsZS5hbGdvLnRzOjcKCS8vIHRoaXMuY291bnRlci52YWx1ZSA9IHRoaXMuY291bnRlci52YWx1ZSArIGkKCWJ5dGUgMHg2MzZmNzU2ZTc0NjU3MiAvLyAiY291bnRlciIKCWR1cAoJYXBwX2dsb2JhbF9nZXQKCWZyYW1lX2RpZyAtMSAvLyBpOiB1aW50NjQKCSsKCWFwcF9nbG9iYWxfcHV0CglyZXRzdWI=" }, "contract": { diff --git a/examples/simple/artifacts/Simple.arc56_draft.json b/examples/simple/artifacts/Simple.arc56_draft.json index c6b9ab38e..1f4526099 100644 --- a/examples/simple/artifacts/Simple.arc56_draft.json +++ b/examples/simple/artifacts/Simple.arc56_draft.json @@ -1305,7 +1305,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHhGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGIDB4NjM2Zjc1NmU3NDY1NzIgMHgxNTFmN2M3NQoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDQuMQovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIGluY3JlbWVudENvdW50ZXIoaTogdWludDY0KTogdm9pZAppbmNyZW1lbnRDb3VudGVyOgoJcHJvdG8gMSAwCgoJLy8gZXhhbXBsZXMvc2ltcGxlL3NpbXBsZS5hbGdvLnRzOjcKCS8vIHRoaXMuY291bnRlci52YWx1ZSA9IHRoaXMuY291bnRlci52YWx1ZSArIGkKCWJ5dGUgMHg2MzZmNzU2ZTc0NjU3MiAvLyAiY291bnRlciIKCWR1cAoJYXBwX2dsb2JhbF9nZXQKCWZyYW1lX2RpZyAtMSAvLyBpOiB1aW50NjQKCSsKCWFwcF9nbG9iYWxfcHV0CglyZXRzdWIKCi8vIGluY3IodWludDY0KXZvaWQKKmFiaV9yb3V0ZV9pbmNyOgoJLy8gaTogdWludDY0Cgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglidG9pCgoJLy8gZXhlY3V0ZSBpbmNyKHVpbnQ2NCl2b2lkCgljYWxsc3ViIGluY3IKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBpbmNyKGk6IHVpbnQ2NCk6IHZvaWQKaW5jcjoKCXByb3RvIDEgMAoKCS8vIGV4YW1wbGVzL3NpbXBsZS9zaW1wbGUuYWxnby50czoxMQoJLy8gdGhpcy5pbmNyZW1lbnRDb3VudGVyKGkpCglmcmFtZV9kaWcgLTEgLy8gaTogdWludDY0CgljYWxsc3ViIGluY3JlbWVudENvdW50ZXIKCXJldHN1YgoKLy8gZGVjcih1aW50NjQpdm9pZAoqYWJpX3JvdXRlX2RlY3I6CgkvLyBpOiB1aW50NjQKCXR4bmEgQXBwbGljYXRpb25BcmdzIDEKCWJ0b2kKCgkvLyBleGVjdXRlIGRlY3IodWludDY0KXZvaWQKCWNhbGxzdWIgZGVjcgoJcHVzaGludCAxCglyZXR1cm4KCi8vIGRlY3IoaTogdWludDY0KTogdm9pZApkZWNyOgoJcHJvdG8gMSAwCgoJLy8gZXhhbXBsZXMvc2ltcGxlL3NpbXBsZS5hbGdvLnRzOjE1CgkvLyB0aGlzLmNvdW50ZXIudmFsdWUgPSB0aGlzLmNvdW50ZXIudmFsdWUgLSBpCglieXRlIDB4NjM2Zjc1NmU3NDY1NzIgLy8gImNvdW50ZXIiCglkdXAKCWFwcF9nbG9iYWxfZ2V0CglmcmFtZV9kaWcgLTEgLy8gaTogdWludDY0CgktCglhcHBfZ2xvYmFsX3B1dAoJcmV0c3ViCgovLyBhZGQodWludDI1Nix1aW50MjU2KXVpbnQyNTYKKmFiaV9yb3V0ZV9hZGQ6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCWJ5dGUgMHgxNTFmN2M3NQoKCS8vIGI6IHVpbnQyNTYKCXR4bmEgQXBwbGljYXRpb25BcmdzIDIKCWR1cAoJbGVuCglwdXNoaW50IDMyCgk9PQoKCS8vIGFyZ3VtZW50IDAgKGIpIGZvciBhZGQgbXVzdCBiZSBhIHVpbnQyNTYKCWFzc2VydAoKCS8vIGE6IHVpbnQyNTYKCXR4bmEgQXBwbGljYXRpb25BcmdzIDEKCWR1cAoJbGVuCglwdXNoaW50IDMyCgk9PQoKCS8vIGFyZ3VtZW50IDEgKGEpIGZvciBhZGQgbXVzdCBiZSBhIHVpbnQyNTYKCWFzc2VydAoKCS8vIGV4ZWN1dGUgYWRkKHVpbnQyNTYsdWludDI1Nil1aW50MjU2CgljYWxsc3ViIGFkZAoJZHVwCgliaXRsZW4KCXB1c2hpbnQgMjU2Cgk8PQoKCS8vIGFkZCByZXR1cm4gdmFsdWUgb3ZlcmZsb3dlZCAyNTYgYml0cwoJYXNzZXJ0CglieXRlIDB4RkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRgoJYiYKCWR1cAoJbGVuCglkdXAKCXB1c2hpbnQgMzIKCS0KCXN3YXAKCXN1YnN0cmluZzMKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gYWRkKGE6IHVpbnQyNTYsIGI6IHVpbnQyNTYpOiB1aW50MjU2CmFkZDoKCXByb3RvIDIgMQoKCS8vIGV4YW1wbGVzL3NpbXBsZS9zaW1wbGUuYWxnby50czoxOQoJLy8gcmV0dXJuIGEgKyBiOwoJZnJhbWVfZGlnIC0xIC8vIGE6IHVpbnQyNTYKCWZyYW1lX2RpZyAtMiAvLyBiOiB1aW50MjU2CgliKwoJcmV0c3ViCgovLyBzdWIodWludDI1Nix1aW50MjU2KXVpbnQyNTYKKmFiaV9yb3V0ZV9zdWI6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCWJ5dGUgMHgxNTFmN2M3NQoKCS8vIGI6IHVpbnQyNTYKCXR4bmEgQXBwbGljYXRpb25BcmdzIDIKCWR1cAoJbGVuCglwdXNoaW50IDMyCgk9PQoKCS8vIGFyZ3VtZW50IDAgKGIpIGZvciBzdWIgbXVzdCBiZSBhIHVpbnQyNTYKCWFzc2VydAoKCS8vIGE6IHVpbnQyNTYKCXR4bmEgQXBwbGljYXRpb25BcmdzIDEKCWR1cAoJbGVuCglwdXNoaW50IDMyCgk9PQoKCS8vIGFyZ3VtZW50IDEgKGEpIGZvciBzdWIgbXVzdCBiZSBhIHVpbnQyNTYKCWFzc2VydAoKCS8vIGV4ZWN1dGUgc3ViKHVpbnQyNTYsdWludDI1Nil1aW50MjU2CgljYWxsc3ViIHN1YgoJZHVwCgliaXRsZW4KCXB1c2hpbnQgMjU2Cgk8PQoKCS8vIHN1YiByZXR1cm4gdmFsdWUgb3ZlcmZsb3dlZCAyNTYgYml0cwoJYXNzZXJ0CglieXRlIDB4RkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRgoJYiYKCWR1cAoJbGVuCglkdXAKCXB1c2hpbnQgMzIKCS0KCXN3YXAKCXN1YnN0cmluZzMKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gc3ViKGE6IHVpbnQyNTYsIGI6IHVpbnQyNTYpOiB1aW50MjU2CnN1YjoKCXByb3RvIDIgMQoKCS8vIGV4YW1wbGVzL3NpbXBsZS9zaW1wbGUuYWxnby50czoyMwoJLy8gcmV0dXJuIGEgLSBiOwoJZnJhbWVfZGlnIC0xIC8vIGE6IHVpbnQyNTYKCWZyYW1lX2RpZyAtMiAvLyBiOiB1aW50MjU2CgliLQoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg5ZmFiODYxMCAvLyBtZXRob2QgImluY3IodWludDY0KXZvaWQiCglwdXNoYnl0ZXMgMHgyZTBjNWE0NyAvLyBtZXRob2QgImRlY3IodWludDY0KXZvaWQiCglwdXNoYnl0ZXMgMHhhYzk3NmUwMiAvLyBtZXRob2QgImFkZCh1aW50MjU2LHVpbnQyNTYpdWludDI1NiIKCXB1c2hieXRlcyAweDA5MWIzMmE3IC8vIG1ldGhvZCAic3ViKHVpbnQyNTYsdWludDI1Nil1aW50MjU2IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9pbmNyICphYmlfcm91dGVfZGVjciAqYWJpX3JvdXRlX2FkZCAqYWJpX3JvdXRlX3N1YgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHhGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGIDB4NjM2Zjc1NmU3NDY1NzIgMHgxNTFmN2M3NQoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDUuMAovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIGluY3JlbWVudENvdW50ZXIoaTogdWludDY0KTogdm9pZAppbmNyZW1lbnRDb3VudGVyOgoJcHJvdG8gMSAwCgoJLy8gZXhhbXBsZXMvc2ltcGxlL3NpbXBsZS5hbGdvLnRzOjcKCS8vIHRoaXMuY291bnRlci52YWx1ZSA9IHRoaXMuY291bnRlci52YWx1ZSArIGkKCWJ5dGUgMHg2MzZmNzU2ZTc0NjU3MiAvLyAiY291bnRlciIKCWR1cAoJYXBwX2dsb2JhbF9nZXQKCWZyYW1lX2RpZyAtMSAvLyBpOiB1aW50NjQKCSsKCWFwcF9nbG9iYWxfcHV0CglyZXRzdWIKCi8vIGluY3IodWludDY0KXZvaWQKKmFiaV9yb3V0ZV9pbmNyOgoJLy8gaTogdWludDY0Cgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglidG9pCgoJLy8gZXhlY3V0ZSBpbmNyKHVpbnQ2NCl2b2lkCgljYWxsc3ViIGluY3IKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBpbmNyKGk6IHVpbnQ2NCk6IHZvaWQKaW5jcjoKCXByb3RvIDEgMAoKCS8vIGV4YW1wbGVzL3NpbXBsZS9zaW1wbGUuYWxnby50czoxMQoJLy8gdGhpcy5pbmNyZW1lbnRDb3VudGVyKGkpCglmcmFtZV9kaWcgLTEgLy8gaTogdWludDY0CgljYWxsc3ViIGluY3JlbWVudENvdW50ZXIKCXJldHN1YgoKLy8gZGVjcih1aW50NjQpdm9pZAoqYWJpX3JvdXRlX2RlY3I6CgkvLyBpOiB1aW50NjQKCXR4bmEgQXBwbGljYXRpb25BcmdzIDEKCWJ0b2kKCgkvLyBleGVjdXRlIGRlY3IodWludDY0KXZvaWQKCWNhbGxzdWIgZGVjcgoJcHVzaGludCAxCglyZXR1cm4KCi8vIGRlY3IoaTogdWludDY0KTogdm9pZApkZWNyOgoJcHJvdG8gMSAwCgoJLy8gZXhhbXBsZXMvc2ltcGxlL3NpbXBsZS5hbGdvLnRzOjE1CgkvLyB0aGlzLmNvdW50ZXIudmFsdWUgPSB0aGlzLmNvdW50ZXIudmFsdWUgLSBpCglieXRlIDB4NjM2Zjc1NmU3NDY1NzIgLy8gImNvdW50ZXIiCglkdXAKCWFwcF9nbG9iYWxfZ2V0CglmcmFtZV9kaWcgLTEgLy8gaTogdWludDY0CgktCglhcHBfZ2xvYmFsX3B1dAoJcmV0c3ViCgovLyBhZGQodWludDI1Nix1aW50MjU2KXVpbnQyNTYKKmFiaV9yb3V0ZV9hZGQ6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCWJ5dGUgMHgxNTFmN2M3NQoKCS8vIGI6IHVpbnQyNTYKCXR4bmEgQXBwbGljYXRpb25BcmdzIDIKCWR1cAoJbGVuCglwdXNoaW50IDMyCgk9PQoKCS8vIGFyZ3VtZW50IDAgKGIpIGZvciBhZGQgbXVzdCBiZSBhIHVpbnQyNTYKCWFzc2VydAoKCS8vIGE6IHVpbnQyNTYKCXR4bmEgQXBwbGljYXRpb25BcmdzIDEKCWR1cAoJbGVuCglwdXNoaW50IDMyCgk9PQoKCS8vIGFyZ3VtZW50IDEgKGEpIGZvciBhZGQgbXVzdCBiZSBhIHVpbnQyNTYKCWFzc2VydAoKCS8vIGV4ZWN1dGUgYWRkKHVpbnQyNTYsdWludDI1Nil1aW50MjU2CgljYWxsc3ViIGFkZAoJZHVwCgliaXRsZW4KCXB1c2hpbnQgMjU2Cgk8PQoKCS8vIGFkZCByZXR1cm4gdmFsdWUgb3ZlcmZsb3dlZCAyNTYgYml0cwoJYXNzZXJ0CglieXRlIDB4RkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRgoJYiYKCWR1cAoJbGVuCglkdXAKCXB1c2hpbnQgMzIKCS0KCXN3YXAKCXN1YnN0cmluZzMKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gYWRkKGE6IHVpbnQyNTYsIGI6IHVpbnQyNTYpOiB1aW50MjU2CmFkZDoKCXByb3RvIDIgMQoKCS8vIGV4YW1wbGVzL3NpbXBsZS9zaW1wbGUuYWxnby50czoxOQoJLy8gcmV0dXJuIGEgKyBiOwoJZnJhbWVfZGlnIC0xIC8vIGE6IHVpbnQyNTYKCWZyYW1lX2RpZyAtMiAvLyBiOiB1aW50MjU2CgliKwoJcmV0c3ViCgovLyBzdWIodWludDI1Nix1aW50MjU2KXVpbnQyNTYKKmFiaV9yb3V0ZV9zdWI6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCWJ5dGUgMHgxNTFmN2M3NQoKCS8vIGI6IHVpbnQyNTYKCXR4bmEgQXBwbGljYXRpb25BcmdzIDIKCWR1cAoJbGVuCglwdXNoaW50IDMyCgk9PQoKCS8vIGFyZ3VtZW50IDAgKGIpIGZvciBzdWIgbXVzdCBiZSBhIHVpbnQyNTYKCWFzc2VydAoKCS8vIGE6IHVpbnQyNTYKCXR4bmEgQXBwbGljYXRpb25BcmdzIDEKCWR1cAoJbGVuCglwdXNoaW50IDMyCgk9PQoKCS8vIGFyZ3VtZW50IDEgKGEpIGZvciBzdWIgbXVzdCBiZSBhIHVpbnQyNTYKCWFzc2VydAoKCS8vIGV4ZWN1dGUgc3ViKHVpbnQyNTYsdWludDI1Nil1aW50MjU2CgljYWxsc3ViIHN1YgoJZHVwCgliaXRsZW4KCXB1c2hpbnQgMjU2Cgk8PQoKCS8vIHN1YiByZXR1cm4gdmFsdWUgb3ZlcmZsb3dlZCAyNTYgYml0cwoJYXNzZXJ0CglieXRlIDB4RkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRgoJYiYKCWR1cAoJbGVuCglkdXAKCXB1c2hpbnQgMzIKCS0KCXN3YXAKCXN1YnN0cmluZzMKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gc3ViKGE6IHVpbnQyNTYsIGI6IHVpbnQyNTYpOiB1aW50MjU2CnN1YjoKCXByb3RvIDIgMQoKCS8vIGV4YW1wbGVzL3NpbXBsZS9zaW1wbGUuYWxnby50czoyMwoJLy8gcmV0dXJuIGEgLSBiOwoJZnJhbWVfZGlnIC0xIC8vIGE6IHVpbnQyNTYKCWZyYW1lX2RpZyAtMiAvLyBiOiB1aW50MjU2CgliLQoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg5ZmFiODYxMCAvLyBtZXRob2QgImluY3IodWludDY0KXZvaWQiCglwdXNoYnl0ZXMgMHgyZTBjNWE0NyAvLyBtZXRob2QgImRlY3IodWludDY0KXZvaWQiCglwdXNoYnl0ZXMgMHhhYzk3NmUwMiAvLyBtZXRob2QgImFkZCh1aW50MjU2LHVpbnQyNTYpdWludDI1NiIKCXB1c2hieXRlcyAweDA5MWIzMmE3IC8vIG1ldGhvZCAic3ViKHVpbnQyNTYsdWludDI1Nil1aW50MjU2IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9pbmNyICphYmlfcm91dGVfZGVjciAqYWJpX3JvdXRlX2FkZCAqYWJpX3JvdXRlX3N1YgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBleGFtcGxlcy9zaW1wbGUvc2ltcGxlLmFsZ28udHM6MjcKLy8gdGhpcy5pbmNyZW1lbnRDb3VudGVyKDEpCmJ5dGVjYmxvY2sgMHg2MzZmNzU2ZTc0NjU3MgpwdXNoaW50IDEKY2FsbHN1YiBpbmNyZW1lbnRDb3VudGVyCnB1c2hpbnQgMQpyZXR1cm4KCi8vIGluY3JlbWVudENvdW50ZXIoaTogdWludDY0KTogdm9pZAppbmNyZW1lbnRDb3VudGVyOgoJcHJvdG8gMSAwCgoJLy8gZXhhbXBsZXMvc2ltcGxlL3NpbXBsZS5hbGdvLnRzOjcKCS8vIHRoaXMuY291bnRlci52YWx1ZSA9IHRoaXMuY291bnRlci52YWx1ZSArIGkKCWJ5dGUgMHg2MzZmNzU2ZTc0NjU3MiAvLyAiY291bnRlciIKCWR1cAoJYXBwX2dsb2JhbF9nZXQKCWZyYW1lX2RpZyAtMSAvLyBpOiB1aW50NjQKCSsKCWFwcF9nbG9iYWxfcHV0CglyZXRzdWI=" }, "byteCode": { diff --git a/examples/tuple_in_box/tealscript_artifacts/ContactsApp.approval.teal b/examples/tuple_in_box/tealscript_artifacts/ContactsApp.approval.teal index c9b7841eb..8d0cdefca 100644 --- a/examples/tuple_in_box/tealscript_artifacts/ContactsApp.approval.teal +++ b/examples/tuple_in_box/tealscript_artifacts/ContactsApp.approval.teal @@ -2,7 +2,7 @@ intcblock 1 bytecblock 0x 0x0004 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/examples/tuple_in_box/tealscript_artifacts/ContactsApp.arc32.json b/examples/tuple_in_box/tealscript_artifacts/ContactsApp.arc32.json index 0d637fb87..334f0d78a 100644 --- a/examples/tuple_in_box/tealscript_artifacts/ContactsApp.arc32.json +++ b/examples/tuple_in_box/tealscript_artifacts/ContactsApp.arc32.json @@ -59,7 +59,7 @@ } }, "source": { - "approval": "#pragma version 10
intcblock 1
bytecblock 0x 0x0004

// This TEAL was generated by TEALScript v0.104.1
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// setMyContact(string,string)void
*abi_route_setMyContact:
	// company: string
	txna ApplicationArgs 2
	extract 2 0

	// name: string
	txna ApplicationArgs 1
	extract 2 0

	// execute setMyContact(string,string)void
	callsub setMyContact
	int 1
	return

// setMyContact(name: string, company: string): void
setMyContact:
	proto 2 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/tuple_in_box/app.algo.ts:12
	// contact: Contact = { name: name, company: company }
	byte 0x // initial head
	byte 0x // initial tail
	byte 0x0004 // initial head offset
	frame_dig -1 // name: string
	dup
	len
	itob
	extract 6 2
	swap
	concat
	callsub *process_dynamic_tuple_element
	frame_dig -2 // company: string
	dup
	len
	itob
	extract 6 2
	swap
	concat
	callsub *process_dynamic_tuple_element
	pop // pop head offset
	concat // concat head and tail
	frame_bury 0 // contact: Contact

	// examples/tuple_in_box/app.algo.ts:14
	// this.myContact.value = contact
	pushbytes 0x6d79436f6e74616374 // "myContact"
	frame_dig 0 // contact: Contact
	app_global_put

	// examples/tuple_in_box/app.algo.ts:15
	// this.contacts(this.txn.sender).value = contact
	txn Sender
	dup
	box_del
	pop
	frame_dig 0 // contact: Contact
	box_put
	retsub

// addContact(string,string,address)void
*abi_route_addContact:
	// address: address
	txna ApplicationArgs 3
	dup
	len
	pushint 32
	==

	// argument 0 (address) for addContact must be a address
	assert

	// company: string
	txna ApplicationArgs 2
	extract 2 0

	// name: string
	txna ApplicationArgs 1
	extract 2 0

	// execute addContact(string,string,address)void
	callsub addContact
	int 1
	return

// addContact(name: string, company: string, address: Address): void
addContact:
	proto 3 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/tuple_in_box/app.algo.ts:19
	// contact: Contact = { name: name, company: company }
	byte 0x // initial head
	byte 0x // initial tail
	byte 0x0004 // initial head offset
	frame_dig -1 // name: string
	dup
	len
	itob
	extract 6 2
	swap
	concat
	callsub *process_dynamic_tuple_element
	frame_dig -2 // company: string
	dup
	len
	itob
	extract 6 2
	swap
	concat
	callsub *process_dynamic_tuple_element
	pop // pop head offset
	concat // concat head and tail
	frame_bury 0 // contact: Contact

	// examples/tuple_in_box/app.algo.ts:20
	// this.contacts(address).value = contact
	frame_dig -3 // address: Address
	dup
	box_del
	pop
	frame_dig 0 // contact: Contact
	box_put
	retsub

// updateContactField(string,string,address)void
*abi_route_updateContactField:
	// address: address
	txna ApplicationArgs 3
	dup
	len
	pushint 32
	==

	// argument 0 (address) for updateContactField must be a address
	assert

	// value: string
	txna ApplicationArgs 2
	extract 2 0

	// field: string
	txna ApplicationArgs 1
	extract 2 0

	// execute updateContactField(string,string,address)void
	callsub updateContactField
	int 1
	return

// updateContactField(field: string, value: string, address: Address): void
updateContactField:
	proto 3 0

	// *if0_condition
	// examples/tuple_in_box/app.algo.ts:24
	// field === 'name'
	frame_dig -1 // field: string
	pushbytes 0x6e616d65 // "name"
	==
	bz *if0_elseif1_condition

	// *if0_consequent
	// examples/tuple_in_box/app.algo.ts:25
	// this.contacts(address).value.name = value
	frame_dig -3 // address: Address
	box_get

	// box value does not exist: this.contacts(address).value
	assert
	store 255 // full array
	pushint 0
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 1 // get type length
	* // multiply by type length
	pushint 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	frame_dig -2 // value: string
	dup
	len
	itob
	extract 6 2
	swap
	concat
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 250 // length difference
	load 251 // element head offset
	pushint 2
	+ // head ofset
	callsub *update_dynamic_head
	load 255 // full array
	frame_dig -3 // address: Address
	dup
	box_del
	pop
	swap
	box_put
	b *if0_end

*if0_elseif1_condition:
	// examples/tuple_in_box/app.algo.ts:26
	// field === 'company'
	frame_dig -1 // field: string
	pushbytes 0x636f6d70616e79 // "company"
	==
	bz *if0_else

	// *if0_elseif1_consequent
	// examples/tuple_in_box/app.algo.ts:27
	// this.contacts(address).value.company = value
	frame_dig -3 // address: Address
	box_get

	// box value does not exist: this.contacts(address).value
	assert
	store 255 // full array
	pushint 2
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 1 // get type length
	* // multiply by type length
	pushint 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	frame_dig -2 // value: string
	dup
	len
	itob
	extract 6 2
	swap
	concat
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 255 // full array
	frame_dig -3 // address: Address
	dup
	box_del
	pop
	swap
	box_put
	b *if0_end

*if0_else:
	// Invalid field
	err

*if0_end:
	retsub

// verifyContactName(string,address)void
*abi_route_verifyContactName:
	// address: address
	txna ApplicationArgs 2
	dup
	len
	pushint 32
	==

	// argument 0 (address) for verifyContactName must be a address
	assert

	// name: string
	txna ApplicationArgs 1
	extract 2 0

	// execute verifyContactName(string,address)void
	callsub verifyContactName
	int 1
	return

// verifyContactName(name: string, address: Address): void
verifyContactName:
	proto 2 0

	// examples/tuple_in_box/app.algo.ts:32
	// assert(this.contacts(address).value.name === name)
	frame_dig -2 // address: Address
	box_get

	// box value does not exist: this.contacts(address).value
	assert
	store 255 // full array
	pushint 0
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 1 // get type length
	* // multiply by type length
	pushint 2
	+ // add two for length
	extract3
	extract 2 0
	frame_dig -1 // name: string
	==
	assert
	retsub

*abi_route_createApplication:
	int 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x92ccf99b // method "setMyContact(string,string)void"
	pushbytes 0x495acbf7 // method "addContact(string,string,address)void"
	pushbytes 0xfa4e8f93 // method "updateContactField(string,string,address)void"
	pushbytes 0x8a30b87e // method "verifyContactName(string,address)void"
	txna ApplicationArgs 0
	match *abi_route_setMyContact *abi_route_addContact *abi_route_updateContactField *abi_route_verifyContactName

	// this contract does not implement the given ABI method for call NoOp
	err

*process_dynamic_tuple_element:
	proto 4 3
	frame_dig -4 // tuple head
	frame_dig -2 // head offset
	concat
	frame_bury -4 // tuple head
	frame_dig -1 // element
	dup
	len
	frame_dig -2 // head offset
	btoi
	+
	itob
	extract 6 2
	frame_bury -2 // head offset
	frame_dig -3 // tuple tail
	swap
	concat
	frame_bury -3 // tuple tail
	frame_dig -4 // tuple head
	frame_dig -3 // tuple tail
	frame_dig -2 // head offset
	retsub

*update_dynamic_head:
	proto 2 0
	frame_dig -2 // length difference
	load 255 // full array
	frame_dig -1 // dynamic array offset
	extract_uint16 // extract dynamic array offset
	load 249 // subtract head difference
	bz *subtract_head_difference
	+ // add difference to offset
	b *end_calc_new_head

*subtract_head_difference:
	swap
	- // subtract difference from offet

*end_calc_new_head:
	itob // convert to bytes
	extract 6 2 // convert to uint16
	load 255 // full array
	swap
	frame_dig -1 // offset
	swap
	replace3 // update offset
	store 255 // full array
	retsub

*get_length_difference:
	load 252 // new element
	len // length of new element
	load 253 // element length
	<
	bnz *swapped_difference
	load 252 // new element
	len // length of new element
	load 253 // element length
	int 1
	store 249 // subtract head difference
	b *get_difference

*swapped_difference:
	load 253 // element length
	load 252 // new element
	len // length of new element
	pushint 0
	store 249 // subtract head difference

*get_difference:
	- // get length difference
	store 250 // length difference
	retsub", + "approval": "#pragma version 10
intcblock 1
bytecblock 0x 0x0004

// This TEAL was generated by TEALScript v0.105.0
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// setMyContact(string,string)void
*abi_route_setMyContact:
	// company: string
	txna ApplicationArgs 2
	extract 2 0

	// name: string
	txna ApplicationArgs 1
	extract 2 0

	// execute setMyContact(string,string)void
	callsub setMyContact
	int 1
	return

// setMyContact(name: string, company: string): void
setMyContact:
	proto 2 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/tuple_in_box/app.algo.ts:12
	// contact: Contact = { name: name, company: company }
	byte 0x // initial head
	byte 0x // initial tail
	byte 0x0004 // initial head offset
	frame_dig -1 // name: string
	dup
	len
	itob
	extract 6 2
	swap
	concat
	callsub *process_dynamic_tuple_element
	frame_dig -2 // company: string
	dup
	len
	itob
	extract 6 2
	swap
	concat
	callsub *process_dynamic_tuple_element
	pop // pop head offset
	concat // concat head and tail
	frame_bury 0 // contact: Contact

	// examples/tuple_in_box/app.algo.ts:14
	// this.myContact.value = contact
	pushbytes 0x6d79436f6e74616374 // "myContact"
	frame_dig 0 // contact: Contact
	app_global_put

	// examples/tuple_in_box/app.algo.ts:15
	// this.contacts(this.txn.sender).value = contact
	txn Sender
	dup
	box_del
	pop
	frame_dig 0 // contact: Contact
	box_put
	retsub

// addContact(string,string,address)void
*abi_route_addContact:
	// address: address
	txna ApplicationArgs 3
	dup
	len
	pushint 32
	==

	// argument 0 (address) for addContact must be a address
	assert

	// company: string
	txna ApplicationArgs 2
	extract 2 0

	// name: string
	txna ApplicationArgs 1
	extract 2 0

	// execute addContact(string,string,address)void
	callsub addContact
	int 1
	return

// addContact(name: string, company: string, address: Address): void
addContact:
	proto 3 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/tuple_in_box/app.algo.ts:19
	// contact: Contact = { name: name, company: company }
	byte 0x // initial head
	byte 0x // initial tail
	byte 0x0004 // initial head offset
	frame_dig -1 // name: string
	dup
	len
	itob
	extract 6 2
	swap
	concat
	callsub *process_dynamic_tuple_element
	frame_dig -2 // company: string
	dup
	len
	itob
	extract 6 2
	swap
	concat
	callsub *process_dynamic_tuple_element
	pop // pop head offset
	concat // concat head and tail
	frame_bury 0 // contact: Contact

	// examples/tuple_in_box/app.algo.ts:20
	// this.contacts(address).value = contact
	frame_dig -3 // address: Address
	dup
	box_del
	pop
	frame_dig 0 // contact: Contact
	box_put
	retsub

// updateContactField(string,string,address)void
*abi_route_updateContactField:
	// address: address
	txna ApplicationArgs 3
	dup
	len
	pushint 32
	==

	// argument 0 (address) for updateContactField must be a address
	assert

	// value: string
	txna ApplicationArgs 2
	extract 2 0

	// field: string
	txna ApplicationArgs 1
	extract 2 0

	// execute updateContactField(string,string,address)void
	callsub updateContactField
	int 1
	return

// updateContactField(field: string, value: string, address: Address): void
updateContactField:
	proto 3 0

	// *if0_condition
	// examples/tuple_in_box/app.algo.ts:24
	// field === 'name'
	frame_dig -1 // field: string
	pushbytes 0x6e616d65 // "name"
	==
	bz *if0_elseif1_condition

	// *if0_consequent
	// examples/tuple_in_box/app.algo.ts:25
	// this.contacts(address).value.name = value
	frame_dig -3 // address: Address
	box_get

	// box value does not exist: this.contacts(address).value
	assert
	store 255 // full array
	pushint 0
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 1 // get type length
	* // multiply by type length
	pushint 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	frame_dig -2 // value: string
	dup
	len
	itob
	extract 6 2
	swap
	concat
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 250 // length difference
	load 251 // element head offset
	pushint 2
	+ // head ofset
	callsub *update_dynamic_head
	load 255 // full array
	frame_dig -3 // address: Address
	dup
	box_del
	pop
	swap
	box_put
	b *if0_end

*if0_elseif1_condition:
	// examples/tuple_in_box/app.algo.ts:26
	// field === 'company'
	frame_dig -1 // field: string
	pushbytes 0x636f6d70616e79 // "company"
	==
	bz *if0_else

	// *if0_elseif1_consequent
	// examples/tuple_in_box/app.algo.ts:27
	// this.contacts(address).value.company = value
	frame_dig -3 // address: Address
	box_get

	// box value does not exist: this.contacts(address).value
	assert
	store 255 // full array
	pushint 2
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 1 // get type length
	* // multiply by type length
	pushint 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	frame_dig -2 // value: string
	dup
	len
	itob
	extract 6 2
	swap
	concat
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 255 // full array
	frame_dig -3 // address: Address
	dup
	box_del
	pop
	swap
	box_put
	b *if0_end

*if0_else:
	// Invalid field
	err

*if0_end:
	retsub

// verifyContactName(string,address)void
*abi_route_verifyContactName:
	// address: address
	txna ApplicationArgs 2
	dup
	len
	pushint 32
	==

	// argument 0 (address) for verifyContactName must be a address
	assert

	// name: string
	txna ApplicationArgs 1
	extract 2 0

	// execute verifyContactName(string,address)void
	callsub verifyContactName
	int 1
	return

// verifyContactName(name: string, address: Address): void
verifyContactName:
	proto 2 0

	// examples/tuple_in_box/app.algo.ts:32
	// assert(this.contacts(address).value.name === name)
	frame_dig -2 // address: Address
	box_get

	// box value does not exist: this.contacts(address).value
	assert
	store 255 // full array
	pushint 0
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 1 // get type length
	* // multiply by type length
	pushint 2
	+ // add two for length
	extract3
	extract 2 0
	frame_dig -1 // name: string
	==
	assert
	retsub

*abi_route_createApplication:
	int 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x92ccf99b // method "setMyContact(string,string)void"
	pushbytes 0x495acbf7 // method "addContact(string,string,address)void"
	pushbytes 0xfa4e8f93 // method "updateContactField(string,string,address)void"
	pushbytes 0x8a30b87e // method "verifyContactName(string,address)void"
	txna ApplicationArgs 0
	match *abi_route_setMyContact *abi_route_addContact *abi_route_updateContactField *abi_route_verifyContactName

	// this contract does not implement the given ABI method for call NoOp
	err

*process_dynamic_tuple_element:
	proto 4 3
	frame_dig -4 // tuple head
	frame_dig -2 // head offset
	concat
	frame_bury -4 // tuple head
	frame_dig -1 // element
	dup
	len
	frame_dig -2 // head offset
	btoi
	+
	itob
	extract 6 2
	frame_bury -2 // head offset
	frame_dig -3 // tuple tail
	swap
	concat
	frame_bury -3 // tuple tail
	frame_dig -4 // tuple head
	frame_dig -3 // tuple tail
	frame_dig -2 // head offset
	retsub

*update_dynamic_head:
	proto 2 0
	frame_dig -2 // length difference
	load 255 // full array
	frame_dig -1 // dynamic array offset
	extract_uint16 // extract dynamic array offset
	load 249 // subtract head difference
	bz *subtract_head_difference
	+ // add difference to offset
	b *end_calc_new_head

*subtract_head_difference:
	swap
	- // subtract difference from offet

*end_calc_new_head:
	itob // convert to bytes
	extract 6 2 // convert to uint16
	load 255 // full array
	swap
	frame_dig -1 // offset
	swap
	replace3 // update offset
	store 255 // full array
	retsub

*get_length_difference:
	load 252 // new element
	len // length of new element
	load 253 // element length
	<
	bnz *swapped_difference
	load 252 // new element
	len // length of new element
	load 253 // element length
	int 1
	store 249 // subtract head difference
	b *get_difference

*swapped_difference:
	load 253 // element length
	load 252 // new element
	len // length of new element
	pushint 0
	store 249 // subtract head difference

*get_difference:
	- // get length difference
	store 250 // length difference
	retsub", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/examples/tuple_in_box/tealscript_artifacts/ContactsApp.arc56_draft.json b/examples/tuple_in_box/tealscript_artifacts/ContactsApp.arc56_draft.json index 2a74bdf79..7b3240aa0 100644 --- a/examples/tuple_in_box/tealscript_artifacts/ContactsApp.arc56_draft.json +++ b/examples/tuple_in_box/tealscript_artifacts/ContactsApp.arc56_draft.json @@ -2905,7 +2905,7 @@ } }, "source": { - "approval": "#pragma version 10
intcblock 1
bytecblock 0x 0x0004

// This TEAL was generated by TEALScript v0.104.1
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// setMyContact(string,string)void
*abi_route_setMyContact:
	// company: string
	txna ApplicationArgs 2
	extract 2 0

	// name: string
	txna ApplicationArgs 1
	extract 2 0

	// execute setMyContact(string,string)void
	callsub setMyContact
	int 1
	return

// setMyContact(name: string, company: string): void
setMyContact:
	proto 2 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/tuple_in_box/app.algo.ts:12
	// contact: Contact = { name: name, company: company }
	byte 0x // initial head
	byte 0x // initial tail
	byte 0x0004 // initial head offset
	frame_dig -1 // name: string
	dup
	len
	itob
	extract 6 2
	swap
	concat
	callsub *process_dynamic_tuple_element
	frame_dig -2 // company: string
	dup
	len
	itob
	extract 6 2
	swap
	concat
	callsub *process_dynamic_tuple_element
	pop // pop head offset
	concat // concat head and tail
	frame_bury 0 // contact: Contact

	// examples/tuple_in_box/app.algo.ts:14
	// this.myContact.value = contact
	pushbytes 0x6d79436f6e74616374 // "myContact"
	frame_dig 0 // contact: Contact
	app_global_put

	// examples/tuple_in_box/app.algo.ts:15
	// this.contacts(this.txn.sender).value = contact
	txn Sender
	dup
	box_del
	pop
	frame_dig 0 // contact: Contact
	box_put
	retsub

// addContact(string,string,address)void
*abi_route_addContact:
	// address: address
	txna ApplicationArgs 3
	dup
	len
	pushint 32
	==

	// argument 0 (address) for addContact must be a address
	assert

	// company: string
	txna ApplicationArgs 2
	extract 2 0

	// name: string
	txna ApplicationArgs 1
	extract 2 0

	// execute addContact(string,string,address)void
	callsub addContact
	int 1
	return

// addContact(name: string, company: string, address: Address): void
addContact:
	proto 3 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/tuple_in_box/app.algo.ts:19
	// contact: Contact = { name: name, company: company }
	byte 0x // initial head
	byte 0x // initial tail
	byte 0x0004 // initial head offset
	frame_dig -1 // name: string
	dup
	len
	itob
	extract 6 2
	swap
	concat
	callsub *process_dynamic_tuple_element
	frame_dig -2 // company: string
	dup
	len
	itob
	extract 6 2
	swap
	concat
	callsub *process_dynamic_tuple_element
	pop // pop head offset
	concat // concat head and tail
	frame_bury 0 // contact: Contact

	// examples/tuple_in_box/app.algo.ts:20
	// this.contacts(address).value = contact
	frame_dig -3 // address: Address
	dup
	box_del
	pop
	frame_dig 0 // contact: Contact
	box_put
	retsub

// updateContactField(string,string,address)void
*abi_route_updateContactField:
	// address: address
	txna ApplicationArgs 3
	dup
	len
	pushint 32
	==

	// argument 0 (address) for updateContactField must be a address
	assert

	// value: string
	txna ApplicationArgs 2
	extract 2 0

	// field: string
	txna ApplicationArgs 1
	extract 2 0

	// execute updateContactField(string,string,address)void
	callsub updateContactField
	int 1
	return

// updateContactField(field: string, value: string, address: Address): void
updateContactField:
	proto 3 0

	// *if0_condition
	// examples/tuple_in_box/app.algo.ts:24
	// field === 'name'
	frame_dig -1 // field: string
	pushbytes 0x6e616d65 // "name"
	==
	bz *if0_elseif1_condition

	// *if0_consequent
	// examples/tuple_in_box/app.algo.ts:25
	// this.contacts(address).value.name = value
	frame_dig -3 // address: Address
	box_get

	// box value does not exist: this.contacts(address).value
	assert
	store 255 // full array
	pushint 0
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 1 // get type length
	* // multiply by type length
	pushint 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	frame_dig -2 // value: string
	dup
	len
	itob
	extract 6 2
	swap
	concat
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 250 // length difference
	load 251 // element head offset
	pushint 2
	+ // head ofset
	callsub *update_dynamic_head
	load 255 // full array
	frame_dig -3 // address: Address
	dup
	box_del
	pop
	swap
	box_put
	b *if0_end

*if0_elseif1_condition:
	// examples/tuple_in_box/app.algo.ts:26
	// field === 'company'
	frame_dig -1 // field: string
	pushbytes 0x636f6d70616e79 // "company"
	==
	bz *if0_else

	// *if0_elseif1_consequent
	// examples/tuple_in_box/app.algo.ts:27
	// this.contacts(address).value.company = value
	frame_dig -3 // address: Address
	box_get

	// box value does not exist: this.contacts(address).value
	assert
	store 255 // full array
	pushint 2
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 1 // get type length
	* // multiply by type length
	pushint 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	frame_dig -2 // value: string
	dup
	len
	itob
	extract 6 2
	swap
	concat
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 255 // full array
	frame_dig -3 // address: Address
	dup
	box_del
	pop
	swap
	box_put
	b *if0_end

*if0_else:
	// Invalid field
	err

*if0_end:
	retsub

// verifyContactName(string,address)void
*abi_route_verifyContactName:
	// address: address
	txna ApplicationArgs 2
	dup
	len
	pushint 32
	==

	// argument 0 (address) for verifyContactName must be a address
	assert

	// name: string
	txna ApplicationArgs 1
	extract 2 0

	// execute verifyContactName(string,address)void
	callsub verifyContactName
	int 1
	return

// verifyContactName(name: string, address: Address): void
verifyContactName:
	proto 2 0

	// examples/tuple_in_box/app.algo.ts:32
	// assert(this.contacts(address).value.name === name)
	frame_dig -2 // address: Address
	box_get

	// box value does not exist: this.contacts(address).value
	assert
	store 255 // full array
	pushint 0
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 1 // get type length
	* // multiply by type length
	pushint 2
	+ // add two for length
	extract3
	extract 2 0
	frame_dig -1 // name: string
	==
	assert
	retsub

*abi_route_createApplication:
	int 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x92ccf99b // method "setMyContact(string,string)void"
	pushbytes 0x495acbf7 // method "addContact(string,string,address)void"
	pushbytes 0xfa4e8f93 // method "updateContactField(string,string,address)void"
	pushbytes 0x8a30b87e // method "verifyContactName(string,address)void"
	txna ApplicationArgs 0
	match *abi_route_setMyContact *abi_route_addContact *abi_route_updateContactField *abi_route_verifyContactName

	// this contract does not implement the given ABI method for call NoOp
	err

*process_dynamic_tuple_element:
	proto 4 3
	frame_dig -4 // tuple head
	frame_dig -2 // head offset
	concat
	frame_bury -4 // tuple head
	frame_dig -1 // element
	dup
	len
	frame_dig -2 // head offset
	btoi
	+
	itob
	extract 6 2
	frame_bury -2 // head offset
	frame_dig -3 // tuple tail
	swap
	concat
	frame_bury -3 // tuple tail
	frame_dig -4 // tuple head
	frame_dig -3 // tuple tail
	frame_dig -2 // head offset
	retsub

*update_dynamic_head:
	proto 2 0
	frame_dig -2 // length difference
	load 255 // full array
	frame_dig -1 // dynamic array offset
	extract_uint16 // extract dynamic array offset
	load 249 // subtract head difference
	bz *subtract_head_difference
	+ // add difference to offset
	b *end_calc_new_head

*subtract_head_difference:
	swap
	- // subtract difference from offet

*end_calc_new_head:
	itob // convert to bytes
	extract 6 2 // convert to uint16
	load 255 // full array
	swap
	frame_dig -1 // offset
	swap
	replace3 // update offset
	store 255 // full array
	retsub

*get_length_difference:
	load 252 // new element
	len // length of new element
	load 253 // element length
	<
	bnz *swapped_difference
	load 252 // new element
	len // length of new element
	load 253 // element length
	int 1
	store 249 // subtract head difference
	b *get_difference

*swapped_difference:
	load 253 // element length
	load 252 // new element
	len // length of new element
	pushint 0
	store 249 // subtract head difference

*get_difference:
	- // get length difference
	store 250 // length difference
	retsub", + "approval": "#pragma version 10
intcblock 1
bytecblock 0x 0x0004

// This TEAL was generated by TEALScript v0.105.0
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// setMyContact(string,string)void
*abi_route_setMyContact:
	// company: string
	txna ApplicationArgs 2
	extract 2 0

	// name: string
	txna ApplicationArgs 1
	extract 2 0

	// execute setMyContact(string,string)void
	callsub setMyContact
	int 1
	return

// setMyContact(name: string, company: string): void
setMyContact:
	proto 2 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/tuple_in_box/app.algo.ts:12
	// contact: Contact = { name: name, company: company }
	byte 0x // initial head
	byte 0x // initial tail
	byte 0x0004 // initial head offset
	frame_dig -1 // name: string
	dup
	len
	itob
	extract 6 2
	swap
	concat
	callsub *process_dynamic_tuple_element
	frame_dig -2 // company: string
	dup
	len
	itob
	extract 6 2
	swap
	concat
	callsub *process_dynamic_tuple_element
	pop // pop head offset
	concat // concat head and tail
	frame_bury 0 // contact: Contact

	// examples/tuple_in_box/app.algo.ts:14
	// this.myContact.value = contact
	pushbytes 0x6d79436f6e74616374 // "myContact"
	frame_dig 0 // contact: Contact
	app_global_put

	// examples/tuple_in_box/app.algo.ts:15
	// this.contacts(this.txn.sender).value = contact
	txn Sender
	dup
	box_del
	pop
	frame_dig 0 // contact: Contact
	box_put
	retsub

// addContact(string,string,address)void
*abi_route_addContact:
	// address: address
	txna ApplicationArgs 3
	dup
	len
	pushint 32
	==

	// argument 0 (address) for addContact must be a address
	assert

	// company: string
	txna ApplicationArgs 2
	extract 2 0

	// name: string
	txna ApplicationArgs 1
	extract 2 0

	// execute addContact(string,string,address)void
	callsub addContact
	int 1
	return

// addContact(name: string, company: string, address: Address): void
addContact:
	proto 3 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// examples/tuple_in_box/app.algo.ts:19
	// contact: Contact = { name: name, company: company }
	byte 0x // initial head
	byte 0x // initial tail
	byte 0x0004 // initial head offset
	frame_dig -1 // name: string
	dup
	len
	itob
	extract 6 2
	swap
	concat
	callsub *process_dynamic_tuple_element
	frame_dig -2 // company: string
	dup
	len
	itob
	extract 6 2
	swap
	concat
	callsub *process_dynamic_tuple_element
	pop // pop head offset
	concat // concat head and tail
	frame_bury 0 // contact: Contact

	// examples/tuple_in_box/app.algo.ts:20
	// this.contacts(address).value = contact
	frame_dig -3 // address: Address
	dup
	box_del
	pop
	frame_dig 0 // contact: Contact
	box_put
	retsub

// updateContactField(string,string,address)void
*abi_route_updateContactField:
	// address: address
	txna ApplicationArgs 3
	dup
	len
	pushint 32
	==

	// argument 0 (address) for updateContactField must be a address
	assert

	// value: string
	txna ApplicationArgs 2
	extract 2 0

	// field: string
	txna ApplicationArgs 1
	extract 2 0

	// execute updateContactField(string,string,address)void
	callsub updateContactField
	int 1
	return

// updateContactField(field: string, value: string, address: Address): void
updateContactField:
	proto 3 0

	// *if0_condition
	// examples/tuple_in_box/app.algo.ts:24
	// field === 'name'
	frame_dig -1 // field: string
	pushbytes 0x6e616d65 // "name"
	==
	bz *if0_elseif1_condition

	// *if0_consequent
	// examples/tuple_in_box/app.algo.ts:25
	// this.contacts(address).value.name = value
	frame_dig -3 // address: Address
	box_get

	// box value does not exist: this.contacts(address).value
	assert
	store 255 // full array
	pushint 0
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 1 // get type length
	* // multiply by type length
	pushint 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	frame_dig -2 // value: string
	dup
	len
	itob
	extract 6 2
	swap
	concat
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 250 // length difference
	load 251 // element head offset
	pushint 2
	+ // head ofset
	callsub *update_dynamic_head
	load 255 // full array
	frame_dig -3 // address: Address
	dup
	box_del
	pop
	swap
	box_put
	b *if0_end

*if0_elseif1_condition:
	// examples/tuple_in_box/app.algo.ts:26
	// field === 'company'
	frame_dig -1 // field: string
	pushbytes 0x636f6d70616e79 // "company"
	==
	bz *if0_else

	// *if0_elseif1_consequent
	// examples/tuple_in_box/app.algo.ts:27
	// this.contacts(address).value.company = value
	frame_dig -3 // address: Address
	box_get

	// box value does not exist: this.contacts(address).value
	assert
	store 255 // full array
	pushint 2
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 1 // get type length
	* // multiply by type length
	pushint 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	frame_dig -2 // value: string
	dup
	len
	itob
	extract 6 2
	swap
	concat
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 255 // full array
	frame_dig -3 // address: Address
	dup
	box_del
	pop
	swap
	box_put
	b *if0_end

*if0_else:
	// Invalid field
	err

*if0_end:
	retsub

// verifyContactName(string,address)void
*abi_route_verifyContactName:
	// address: address
	txna ApplicationArgs 2
	dup
	len
	pushint 32
	==

	// argument 0 (address) for verifyContactName must be a address
	assert

	// name: string
	txna ApplicationArgs 1
	extract 2 0

	// execute verifyContactName(string,address)void
	callsub verifyContactName
	int 1
	return

// verifyContactName(name: string, address: Address): void
verifyContactName:
	proto 2 0

	// examples/tuple_in_box/app.algo.ts:32
	// assert(this.contacts(address).value.name === name)
	frame_dig -2 // address: Address
	box_get

	// box value does not exist: this.contacts(address).value
	assert
	store 255 // full array
	pushint 0
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 1 // get type length
	* // multiply by type length
	pushint 2
	+ // add two for length
	extract3
	extract 2 0
	frame_dig -1 // name: string
	==
	assert
	retsub

*abi_route_createApplication:
	int 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x92ccf99b // method "setMyContact(string,string)void"
	pushbytes 0x495acbf7 // method "addContact(string,string,address)void"
	pushbytes 0xfa4e8f93 // method "updateContactField(string,string,address)void"
	pushbytes 0x8a30b87e // method "verifyContactName(string,address)void"
	txna ApplicationArgs 0
	match *abi_route_setMyContact *abi_route_addContact *abi_route_updateContactField *abi_route_verifyContactName

	// this contract does not implement the given ABI method for call NoOp
	err

*process_dynamic_tuple_element:
	proto 4 3
	frame_dig -4 // tuple head
	frame_dig -2 // head offset
	concat
	frame_bury -4 // tuple head
	frame_dig -1 // element
	dup
	len
	frame_dig -2 // head offset
	btoi
	+
	itob
	extract 6 2
	frame_bury -2 // head offset
	frame_dig -3 // tuple tail
	swap
	concat
	frame_bury -3 // tuple tail
	frame_dig -4 // tuple head
	frame_dig -3 // tuple tail
	frame_dig -2 // head offset
	retsub

*update_dynamic_head:
	proto 2 0
	frame_dig -2 // length difference
	load 255 // full array
	frame_dig -1 // dynamic array offset
	extract_uint16 // extract dynamic array offset
	load 249 // subtract head difference
	bz *subtract_head_difference
	+ // add difference to offset
	b *end_calc_new_head

*subtract_head_difference:
	swap
	- // subtract difference from offet

*end_calc_new_head:
	itob // convert to bytes
	extract 6 2 // convert to uint16
	load 255 // full array
	swap
	frame_dig -1 // offset
	swap
	replace3 // update offset
	store 255 // full array
	retsub

*get_length_difference:
	load 252 // new element
	len // length of new element
	load 253 // element length
	<
	bnz *swapped_difference
	load 252 // new element
	len // length of new element
	load 253 // element length
	int 1
	store 249 // subtract head difference
	b *get_difference

*swapped_difference:
	load 253 // element length
	load 252 // new element
	len // length of new element
	pushint 0
	store 249 // subtract head difference

*get_difference:
	- // get length difference
	store 250 // length difference
	retsub", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/package.json b/package.json index 0113a17b8..e9c8c4c6c 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "@algorandfoundation/tealscript", - "version": "0.104.1", + "version": "0.105.0", "description": "Enables Algorand smart contract development with native TypeScript syntax, tooling, and IDE support", "homepage": "https://github.com/algorandfoundation/TEALScript", "bugs": { diff --git a/src/version.ts b/src/version.ts index 0b7f2edb8..baced256a 100644 --- a/src/version.ts +++ b/src/version.ts @@ -1 +1 @@ -export const VERSION = '0.104.1'; +export const VERSION = '0.105.0'; diff --git a/tests/contracts/artifacts/A.approval.teal b/tests/contracts/artifacts/A.approval.teal index d61362fe4..00d7a3b0d 100644 --- a/tests/contracts/artifacts/A.approval.teal +++ b/tests/contracts/artifacts/A.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/A.arc32.json b/tests/contracts/artifacts/A.arc32.json index 31fb43b54..7ca841fcd 100644 --- a/tests/contracts/artifacts/A.arc32.json +++ b/tests/contracts/artifacts/A.arc32.json @@ -44,7 +44,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYSgpdm9pZAoqYWJpX3JvdXRlX2E6CgkvLyBleGVjdXRlIGEoKXZvaWQKCWNhbGxzdWIgYQoJcHVzaGludCAxCglyZXR1cm4KCi8vIGEoKTogdm9pZAphOgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6MTYKCS8vIHRoaXMuYUtleS52YWx1ZSA9IDEzMzcKCXB1c2hieXRlcyAweDYxIC8vICJhIgoJcHVzaGludCAxMzM3CglhcHBfZ2xvYmFsX3B1dAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgxZTdhYWQxYyAvLyBtZXRob2QgImEoKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2EKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYSgpdm9pZAoqYWJpX3JvdXRlX2E6CgkvLyBleGVjdXRlIGEoKXZvaWQKCWNhbGxzdWIgYQoJcHVzaGludCAxCglyZXR1cm4KCi8vIGEoKTogdm9pZAphOgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6MTYKCS8vIHRoaXMuYUtleS52YWx1ZSA9IDEzMzcKCXB1c2hieXRlcyAweDYxIC8vICJhIgoJcHVzaGludCAxMzM3CglhcHBfZ2xvYmFsX3B1dAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgxZTdhYWQxYyAvLyBtZXRob2QgImEoKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2EKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/A.arc56_draft.json b/tests/contracts/artifacts/A.arc56_draft.json index 07523b57b..34972cf06 100644 --- a/tests/contracts/artifacts/A.arc56_draft.json +++ b/tests/contracts/artifacts/A.arc56_draft.json @@ -328,7 +328,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYSgpdm9pZAoqYWJpX3JvdXRlX2E6CgkvLyBleGVjdXRlIGEoKXZvaWQKCWNhbGxzdWIgYQoJcHVzaGludCAxCglyZXR1cm4KCi8vIGEoKTogdm9pZAphOgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6MTYKCS8vIHRoaXMuYUtleS52YWx1ZSA9IDEzMzcKCXB1c2hieXRlcyAweDYxIC8vICJhIgoJcHVzaGludCAxMzM3CglhcHBfZ2xvYmFsX3B1dAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgxZTdhYWQxYyAvLyBtZXRob2QgImEoKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2EKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYSgpdm9pZAoqYWJpX3JvdXRlX2E6CgkvLyBleGVjdXRlIGEoKXZvaWQKCWNhbGxzdWIgYQoJcHVzaGludCAxCglyZXR1cm4KCi8vIGEoKTogdm9pZAphOgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6MTYKCS8vIHRoaXMuYUtleS52YWx1ZSA9IDEzMzcKCXB1c2hieXRlcyAweDYxIC8vICJhIgoJcHVzaGludCAxMzM3CglhcHBfZ2xvYmFsX3B1dAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgxZTdhYWQxYyAvLyBtZXRob2QgImEoKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2EKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestAccesStringInTuple.approval.teal b/tests/contracts/artifacts/ABITestAccesStringInTuple.approval.teal index ea6b1c640..1386d08a7 100644 --- a/tests/contracts/artifacts/ABITestAccesStringInTuple.approval.teal +++ b/tests/contracts/artifacts/ABITestAccesStringInTuple.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestAccesStringInTuple.arc32.json b/tests/contracts/artifacts/ABITestAccesStringInTuple.arc32.json index a0dccceed..21087910b 100644 --- a/tests/contracts/artifacts/ABITestAccesStringInTuple.arc32.json +++ b/tests/contracts/artifacts/ABITestAccesStringInTuple.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBhY2Nlc1N0cmluZ0luVHVwbGUoKXN0cmluZwoqYWJpX3JvdXRlX2FjY2VzU3RyaW5nSW5UdXBsZToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGFjY2VzU3RyaW5nSW5UdXBsZSgpc3RyaW5nCgljYWxsc3ViIGFjY2VzU3RyaW5nSW5UdXBsZQoJZHVwCglsZW4KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gYWNjZXNTdHJpbmdJblR1cGxlKCk6IHN0cmluZwphY2Nlc1N0cmluZ0luVHVwbGU6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJYnl0ZSAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo1NTAKCS8vIGE6IFt1aW50MTYsIHVpbnQ8OD5bXSwgc3RyaW5nLCB1aW50PDg+W11dID0gWzEsIFsyXSwgJ0hlbGxvIFdvcmxkIScsIFszXV0KCWJ5dGUgMHggLy8gaW5pdGlhbCBoZWFkCglieXRlIDB4IC8vIGluaXRpYWwgdGFpbAoJcHVzaGJ5dGVzIDB4MDAwOCAvLyBpbml0aWFsIGhlYWQgb2Zmc2V0CglwdXNoYnl0ZXMgMHgwMDAxCgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAxMDIKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDBjNDg2NTZjNmM2ZjIwNTc2ZjcyNmM2NDIxCgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwMTAzCgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcG9wIC8vIHBvcCBoZWFkIG9mZnNldAoJY29uY2F0IC8vIGNvbmNhdCBoZWFkIGFuZCB0YWlsCglmcmFtZV9idXJ5IDAgLy8gYTogW3VpbnQxNiwgdWludDw4PltdLCBzdHJpbmcsIHVpbnQ8OD5bXV0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NTUyCgkvLyBhc3NlcnQoYVsyXSA9PT0gJ0hlbGxvIFdvcmxkIScpCglmcmFtZV9kaWcgMCAvLyBhOiBbdWludDE2LCB1aW50PDg+W10sIHN0cmluZywgdWludDw4PltdXQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgNAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJdW5jb3ZlciAyCglleHRyYWN0X3VpbnQxNgoJZHVwIC8vIGR1cGxpY2F0ZSBzdGFydCBvZiBlbGVtZW50Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglzd2FwCglleHRyYWN0X3VpbnQxNiAvLyBnZXQgbnVtYmVyIG9mIGVsZW1lbnRzCglwdXNoaW50IDEgLy8gZ2V0IHR5cGUgbGVuZ3RoCgkqIC8vIG11bHRpcGx5IGJ5IHR5cGUgbGVuZ3RoCglwdXNoaW50IDIKCSsgLy8gYWRkIHR3byBmb3IgbGVuZ3RoCglleHRyYWN0MwoJZXh0cmFjdCAyIDAKCXB1c2hieXRlcyAweDQ4NjU2YzZjNmYyMDU3NmY3MjZjNjQyMSAvLyAiSGVsbG8gV29ybGQhIgoJPT0KCWFzc2VydAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo1NTQKCS8vIHJldHVybiBhWzJdOwoJZnJhbWVfZGlnIDAgLy8gYTogW3VpbnQxNiwgdWludDw4PltdLCBzdHJpbmcsIHVpbnQ8OD5bXV0KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoaW50IDQKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXVuY292ZXIgMgoJZXh0cmFjdF91aW50MTYKCWR1cCAvLyBkdXBsaWNhdGUgc3RhcnQgb2YgZWxlbWVudAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJc3dhcAoJZXh0cmFjdF91aW50MTYgLy8gZ2V0IG51bWJlciBvZiBlbGVtZW50cwoJcHVzaGludCAxIC8vIGdldCB0eXBlIGxlbmd0aAoJKiAvLyBtdWx0aXBseSBieSB0eXBlIGxlbmd0aAoJcHVzaGludCAyCgkrIC8vIGFkZCB0d28gZm9yIGxlbmd0aAoJZXh0cmFjdDMKCWV4dHJhY3QgMiAwCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDk0MmNmM2MwIC8vIG1ldGhvZCAiYWNjZXNTdHJpbmdJblR1cGxlKClzdHJpbmciCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2FjY2VzU3RyaW5nSW5UdXBsZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycgoKKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJY29uY2F0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWIKCipwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJY29uY2F0CglmcmFtZV9idXJ5IC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50CglkdXAKCWxlbgoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglidG9pCgkrCglpdG9iCglleHRyYWN0IDYgMgoJZnJhbWVfYnVyeSAtMiAvLyBoZWFkIG9mZnNldAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCXN3YXAKCWNvbmNhdAoJZnJhbWVfYnVyeSAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3Vi", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBhY2Nlc1N0cmluZ0luVHVwbGUoKXN0cmluZwoqYWJpX3JvdXRlX2FjY2VzU3RyaW5nSW5UdXBsZToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGFjY2VzU3RyaW5nSW5UdXBsZSgpc3RyaW5nCgljYWxsc3ViIGFjY2VzU3RyaW5nSW5UdXBsZQoJZHVwCglsZW4KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gYWNjZXNTdHJpbmdJblR1cGxlKCk6IHN0cmluZwphY2Nlc1N0cmluZ0luVHVwbGU6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJYnl0ZSAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo1NTAKCS8vIGE6IFt1aW50MTYsIHVpbnQ8OD5bXSwgc3RyaW5nLCB1aW50PDg+W11dID0gWzEsIFsyXSwgJ0hlbGxvIFdvcmxkIScsIFszXV0KCWJ5dGUgMHggLy8gaW5pdGlhbCBoZWFkCglieXRlIDB4IC8vIGluaXRpYWwgdGFpbAoJcHVzaGJ5dGVzIDB4MDAwOCAvLyBpbml0aWFsIGhlYWQgb2Zmc2V0CglwdXNoYnl0ZXMgMHgwMDAxCgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAxMDIKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDBjNDg2NTZjNmM2ZjIwNTc2ZjcyNmM2NDIxCgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwMTAzCgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcG9wIC8vIHBvcCBoZWFkIG9mZnNldAoJY29uY2F0IC8vIGNvbmNhdCBoZWFkIGFuZCB0YWlsCglmcmFtZV9idXJ5IDAgLy8gYTogW3VpbnQxNiwgdWludDw4PltdLCBzdHJpbmcsIHVpbnQ8OD5bXV0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NTUyCgkvLyBhc3NlcnQoYVsyXSA9PT0gJ0hlbGxvIFdvcmxkIScpCglmcmFtZV9kaWcgMCAvLyBhOiBbdWludDE2LCB1aW50PDg+W10sIHN0cmluZywgdWludDw4PltdXQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgNAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJdW5jb3ZlciAyCglleHRyYWN0X3VpbnQxNgoJZHVwIC8vIGR1cGxpY2F0ZSBzdGFydCBvZiBlbGVtZW50Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglzd2FwCglleHRyYWN0X3VpbnQxNiAvLyBnZXQgbnVtYmVyIG9mIGVsZW1lbnRzCglwdXNoaW50IDEgLy8gZ2V0IHR5cGUgbGVuZ3RoCgkqIC8vIG11bHRpcGx5IGJ5IHR5cGUgbGVuZ3RoCglwdXNoaW50IDIKCSsgLy8gYWRkIHR3byBmb3IgbGVuZ3RoCglleHRyYWN0MwoJZXh0cmFjdCAyIDAKCXB1c2hieXRlcyAweDQ4NjU2YzZjNmYyMDU3NmY3MjZjNjQyMSAvLyAiSGVsbG8gV29ybGQhIgoJPT0KCWFzc2VydAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo1NTQKCS8vIHJldHVybiBhWzJdOwoJZnJhbWVfZGlnIDAgLy8gYTogW3VpbnQxNiwgdWludDw4PltdLCBzdHJpbmcsIHVpbnQ8OD5bXV0KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoaW50IDQKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXVuY292ZXIgMgoJZXh0cmFjdF91aW50MTYKCWR1cCAvLyBkdXBsaWNhdGUgc3RhcnQgb2YgZWxlbWVudAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJc3dhcAoJZXh0cmFjdF91aW50MTYgLy8gZ2V0IG51bWJlciBvZiBlbGVtZW50cwoJcHVzaGludCAxIC8vIGdldCB0eXBlIGxlbmd0aAoJKiAvLyBtdWx0aXBseSBieSB0eXBlIGxlbmd0aAoJcHVzaGludCAyCgkrIC8vIGFkZCB0d28gZm9yIGxlbmd0aAoJZXh0cmFjdDMKCWV4dHJhY3QgMiAwCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDk0MmNmM2MwIC8vIG1ldGhvZCAiYWNjZXNTdHJpbmdJblR1cGxlKClzdHJpbmciCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2FjY2VzU3RyaW5nSW5UdXBsZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycgoKKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJY29uY2F0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWIKCipwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJY29uY2F0CglmcmFtZV9idXJ5IC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50CglkdXAKCWxlbgoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglidG9pCgkrCglpdG9iCglleHRyYWN0IDYgMgoJZnJhbWVfYnVyeSAtMiAvLyBoZWFkIG9mZnNldAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCXN3YXAKCWNvbmNhdAoJZnJhbWVfYnVyeSAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3Vi", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestAccesStringInTuple.arc56_draft.json b/tests/contracts/artifacts/ABITestAccesStringInTuple.arc56_draft.json index 6692503e0..10741a616 100644 --- a/tests/contracts/artifacts/ABITestAccesStringInTuple.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestAccesStringInTuple.arc56_draft.json @@ -1048,7 +1048,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBhY2Nlc1N0cmluZ0luVHVwbGUoKXN0cmluZwoqYWJpX3JvdXRlX2FjY2VzU3RyaW5nSW5UdXBsZToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGFjY2VzU3RyaW5nSW5UdXBsZSgpc3RyaW5nCgljYWxsc3ViIGFjY2VzU3RyaW5nSW5UdXBsZQoJZHVwCglsZW4KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gYWNjZXNTdHJpbmdJblR1cGxlKCk6IHN0cmluZwphY2Nlc1N0cmluZ0luVHVwbGU6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJYnl0ZSAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo1NTAKCS8vIGE6IFt1aW50MTYsIHVpbnQ8OD5bXSwgc3RyaW5nLCB1aW50PDg+W11dID0gWzEsIFsyXSwgJ0hlbGxvIFdvcmxkIScsIFszXV0KCWJ5dGUgMHggLy8gaW5pdGlhbCBoZWFkCglieXRlIDB4IC8vIGluaXRpYWwgdGFpbAoJcHVzaGJ5dGVzIDB4MDAwOCAvLyBpbml0aWFsIGhlYWQgb2Zmc2V0CglwdXNoYnl0ZXMgMHgwMDAxCgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAxMDIKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDBjNDg2NTZjNmM2ZjIwNTc2ZjcyNmM2NDIxCgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwMTAzCgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcG9wIC8vIHBvcCBoZWFkIG9mZnNldAoJY29uY2F0IC8vIGNvbmNhdCBoZWFkIGFuZCB0YWlsCglmcmFtZV9idXJ5IDAgLy8gYTogW3VpbnQxNiwgdWludDw4PltdLCBzdHJpbmcsIHVpbnQ8OD5bXV0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NTUyCgkvLyBhc3NlcnQoYVsyXSA9PT0gJ0hlbGxvIFdvcmxkIScpCglmcmFtZV9kaWcgMCAvLyBhOiBbdWludDE2LCB1aW50PDg+W10sIHN0cmluZywgdWludDw4PltdXQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgNAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJdW5jb3ZlciAyCglleHRyYWN0X3VpbnQxNgoJZHVwIC8vIGR1cGxpY2F0ZSBzdGFydCBvZiBlbGVtZW50Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglzd2FwCglleHRyYWN0X3VpbnQxNiAvLyBnZXQgbnVtYmVyIG9mIGVsZW1lbnRzCglwdXNoaW50IDEgLy8gZ2V0IHR5cGUgbGVuZ3RoCgkqIC8vIG11bHRpcGx5IGJ5IHR5cGUgbGVuZ3RoCglwdXNoaW50IDIKCSsgLy8gYWRkIHR3byBmb3IgbGVuZ3RoCglleHRyYWN0MwoJZXh0cmFjdCAyIDAKCXB1c2hieXRlcyAweDQ4NjU2YzZjNmYyMDU3NmY3MjZjNjQyMSAvLyAiSGVsbG8gV29ybGQhIgoJPT0KCWFzc2VydAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo1NTQKCS8vIHJldHVybiBhWzJdOwoJZnJhbWVfZGlnIDAgLy8gYTogW3VpbnQxNiwgdWludDw4PltdLCBzdHJpbmcsIHVpbnQ8OD5bXV0KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoaW50IDQKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXVuY292ZXIgMgoJZXh0cmFjdF91aW50MTYKCWR1cCAvLyBkdXBsaWNhdGUgc3RhcnQgb2YgZWxlbWVudAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJc3dhcAoJZXh0cmFjdF91aW50MTYgLy8gZ2V0IG51bWJlciBvZiBlbGVtZW50cwoJcHVzaGludCAxIC8vIGdldCB0eXBlIGxlbmd0aAoJKiAvLyBtdWx0aXBseSBieSB0eXBlIGxlbmd0aAoJcHVzaGludCAyCgkrIC8vIGFkZCB0d28gZm9yIGxlbmd0aAoJZXh0cmFjdDMKCWV4dHJhY3QgMiAwCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDk0MmNmM2MwIC8vIG1ldGhvZCAiYWNjZXNTdHJpbmdJblR1cGxlKClzdHJpbmciCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2FjY2VzU3RyaW5nSW5UdXBsZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycgoKKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJY29uY2F0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWIKCipwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJY29uY2F0CglmcmFtZV9idXJ5IC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50CglkdXAKCWxlbgoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglidG9pCgkrCglpdG9iCglleHRyYWN0IDYgMgoJZnJhbWVfYnVyeSAtMiAvLyBoZWFkIG9mZnNldAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCXN3YXAKCWNvbmNhdAoJZnJhbWVfYnVyeSAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3Vi", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBhY2Nlc1N0cmluZ0luVHVwbGUoKXN0cmluZwoqYWJpX3JvdXRlX2FjY2VzU3RyaW5nSW5UdXBsZToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGFjY2VzU3RyaW5nSW5UdXBsZSgpc3RyaW5nCgljYWxsc3ViIGFjY2VzU3RyaW5nSW5UdXBsZQoJZHVwCglsZW4KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gYWNjZXNTdHJpbmdJblR1cGxlKCk6IHN0cmluZwphY2Nlc1N0cmluZ0luVHVwbGU6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJYnl0ZSAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo1NTAKCS8vIGE6IFt1aW50MTYsIHVpbnQ8OD5bXSwgc3RyaW5nLCB1aW50PDg+W11dID0gWzEsIFsyXSwgJ0hlbGxvIFdvcmxkIScsIFszXV0KCWJ5dGUgMHggLy8gaW5pdGlhbCBoZWFkCglieXRlIDB4IC8vIGluaXRpYWwgdGFpbAoJcHVzaGJ5dGVzIDB4MDAwOCAvLyBpbml0aWFsIGhlYWQgb2Zmc2V0CglwdXNoYnl0ZXMgMHgwMDAxCgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAxMDIKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDBjNDg2NTZjNmM2ZjIwNTc2ZjcyNmM2NDIxCgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwMTAzCgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcG9wIC8vIHBvcCBoZWFkIG9mZnNldAoJY29uY2F0IC8vIGNvbmNhdCBoZWFkIGFuZCB0YWlsCglmcmFtZV9idXJ5IDAgLy8gYTogW3VpbnQxNiwgdWludDw4PltdLCBzdHJpbmcsIHVpbnQ8OD5bXV0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NTUyCgkvLyBhc3NlcnQoYVsyXSA9PT0gJ0hlbGxvIFdvcmxkIScpCglmcmFtZV9kaWcgMCAvLyBhOiBbdWludDE2LCB1aW50PDg+W10sIHN0cmluZywgdWludDw4PltdXQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgNAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJdW5jb3ZlciAyCglleHRyYWN0X3VpbnQxNgoJZHVwIC8vIGR1cGxpY2F0ZSBzdGFydCBvZiBlbGVtZW50Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglzd2FwCglleHRyYWN0X3VpbnQxNiAvLyBnZXQgbnVtYmVyIG9mIGVsZW1lbnRzCglwdXNoaW50IDEgLy8gZ2V0IHR5cGUgbGVuZ3RoCgkqIC8vIG11bHRpcGx5IGJ5IHR5cGUgbGVuZ3RoCglwdXNoaW50IDIKCSsgLy8gYWRkIHR3byBmb3IgbGVuZ3RoCglleHRyYWN0MwoJZXh0cmFjdCAyIDAKCXB1c2hieXRlcyAweDQ4NjU2YzZjNmYyMDU3NmY3MjZjNjQyMSAvLyAiSGVsbG8gV29ybGQhIgoJPT0KCWFzc2VydAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo1NTQKCS8vIHJldHVybiBhWzJdOwoJZnJhbWVfZGlnIDAgLy8gYTogW3VpbnQxNiwgdWludDw4PltdLCBzdHJpbmcsIHVpbnQ8OD5bXV0KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoaW50IDQKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXVuY292ZXIgMgoJZXh0cmFjdF91aW50MTYKCWR1cCAvLyBkdXBsaWNhdGUgc3RhcnQgb2YgZWxlbWVudAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJc3dhcAoJZXh0cmFjdF91aW50MTYgLy8gZ2V0IG51bWJlciBvZiBlbGVtZW50cwoJcHVzaGludCAxIC8vIGdldCB0eXBlIGxlbmd0aAoJKiAvLyBtdWx0aXBseSBieSB0eXBlIGxlbmd0aAoJcHVzaGludCAyCgkrIC8vIGFkZCB0d28gZm9yIGxlbmd0aAoJZXh0cmFjdDMKCWV4dHJhY3QgMiAwCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDk0MmNmM2MwIC8vIG1ldGhvZCAiYWNjZXNTdHJpbmdJblR1cGxlKClzdHJpbmciCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2FjY2VzU3RyaW5nSW5UdXBsZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycgoKKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJY29uY2F0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWIKCipwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJY29uY2F0CglmcmFtZV9idXJ5IC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50CglkdXAKCWxlbgoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglidG9pCgkrCglpdG9iCglleHRyYWN0IDYgMgoJZnJhbWVfYnVyeSAtMiAvLyBoZWFkIG9mZnNldAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCXN3YXAKCWNvbmNhdAoJZnJhbWVfYnVyeSAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3Vi", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestAccessDynamicArrayElementInTuple.approval.teal b/tests/contracts/artifacts/ABITestAccessDynamicArrayElementInTuple.approval.teal index 00bb77757..e6acfc4af 100644 --- a/tests/contracts/artifacts/ABITestAccessDynamicArrayElementInTuple.approval.teal +++ b/tests/contracts/artifacts/ABITestAccessDynamicArrayElementInTuple.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestAccessDynamicArrayElementInTuple.arc32.json b/tests/contracts/artifacts/ABITestAccessDynamicArrayElementInTuple.arc32.json index 0ec302884..5b3aa522a 100644 --- a/tests/contracts/artifacts/ABITestAccessDynamicArrayElementInTuple.arc32.json +++ b/tests/contracts/artifacts/ABITestAccessDynamicArrayElementInTuple.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBhY2Nlc3NEeW5hbWljQXJyYXlFbGVtZW50SW5UdXBsZSgpdWludDgKKmFiaV9yb3V0ZV9hY2Nlc3NEeW5hbWljQXJyYXlFbGVtZW50SW5UdXBsZToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGFjY2Vzc0R5bmFtaWNBcnJheUVsZW1lbnRJblR1cGxlKCl1aW50OAoJY2FsbHN1YiBhY2Nlc3NEeW5hbWljQXJyYXlFbGVtZW50SW5UdXBsZQoJaXRvYgoJZHVwCgliaXRsZW4KCXB1c2hpbnQgOAoJPD0KCgkvLyBhY2Nlc3NEeW5hbWljQXJyYXlFbGVtZW50SW5UdXBsZSByZXR1cm4gdmFsdWUgb3ZlcmZsb3dlZCA4IGJpdHMKCWFzc2VydAoJZXh0cmFjdCA3IDEKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gYWNjZXNzRHluYW1pY0FycmF5RWxlbWVudEluVHVwbGUoKTogdWludDw4PgphY2Nlc3NEeW5hbWljQXJyYXlFbGVtZW50SW5UdXBsZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjY3NAoJLy8gYTogW3VpbnQxNiwgdWludDw4PltdXSA9IFsxMSwgWzIyLCAzMywgNDRdXQoJYnl0ZSAweCAvLyBpbml0aWFsIGhlYWQKCWJ5dGUgMHggLy8gaW5pdGlhbCB0YWlsCglwdXNoYnl0ZXMgMHgwMDA0IC8vIGluaXRpYWwgaGVhZCBvZmZzZXQKCXB1c2hieXRlcyAweDAwMGIKCWNhbGxzdWIgKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMDMxNjIxMmMKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50Cglwb3AgLy8gcG9wIGhlYWQgb2Zmc2V0Cgljb25jYXQgLy8gY29uY2F0IGhlYWQgYW5kIHRhaWwKCWZyYW1lX2J1cnkgMCAvLyBhOiBbdWludDE2LCB1aW50PDg+W11dCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjY3NgoJLy8gcmV0dXJuIGFbMV1bMV07CglmcmFtZV9kaWcgMCAvLyBhOiBbdWludDE2LCB1aW50PDg+W11dCglzdG9yZSAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJcHVzaGludCAyCglleHRyYWN0X3VpbnQxNgoJcHVzaGludCAxIC8vIGFjYyAqIHR5cGVMZW5ndGgKCSsKCXB1c2hpbnQgMgoJKyAvLyBhZGQgdHdvIGZvciBsZW5ndGgKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXN3YXAKCXB1c2hpbnQgMQoJZXh0cmFjdDMKCWJ0b2kKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZjhlNTE3Y2UgLy8gbWV0aG9kICJhY2Nlc3NEeW5hbWljQXJyYXlFbGVtZW50SW5UdXBsZSgpdWludDgiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2FjY2Vzc0R5bmFtaWNBcnJheUVsZW1lbnRJblR1cGxlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJyCgoqcHJvY2Vzc19zdGF0aWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50Cgljb25jYXQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCXJldHN1YgoKKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50OgoJcHJvdG8gNCAzCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0Cgljb25jYXQKCWZyYW1lX2J1cnkgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0xIC8vIGVsZW1lbnQKCWR1cAoJbGVuCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCWJ0b2kKCSsKCWl0b2IKCWV4dHJhY3QgNiAyCglmcmFtZV9idXJ5IC0yIC8vIGhlYWQgb2Zmc2V0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJc3dhcAoJY29uY2F0CglmcmFtZV9idXJ5IC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBhY2Nlc3NEeW5hbWljQXJyYXlFbGVtZW50SW5UdXBsZSgpdWludDgKKmFiaV9yb3V0ZV9hY2Nlc3NEeW5hbWljQXJyYXlFbGVtZW50SW5UdXBsZToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGFjY2Vzc0R5bmFtaWNBcnJheUVsZW1lbnRJblR1cGxlKCl1aW50OAoJY2FsbHN1YiBhY2Nlc3NEeW5hbWljQXJyYXlFbGVtZW50SW5UdXBsZQoJaXRvYgoJZHVwCgliaXRsZW4KCXB1c2hpbnQgOAoJPD0KCgkvLyBhY2Nlc3NEeW5hbWljQXJyYXlFbGVtZW50SW5UdXBsZSByZXR1cm4gdmFsdWUgb3ZlcmZsb3dlZCA4IGJpdHMKCWFzc2VydAoJZXh0cmFjdCA3IDEKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gYWNjZXNzRHluYW1pY0FycmF5RWxlbWVudEluVHVwbGUoKTogdWludDw4PgphY2Nlc3NEeW5hbWljQXJyYXlFbGVtZW50SW5UdXBsZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjY3NAoJLy8gYTogW3VpbnQxNiwgdWludDw4PltdXSA9IFsxMSwgWzIyLCAzMywgNDRdXQoJYnl0ZSAweCAvLyBpbml0aWFsIGhlYWQKCWJ5dGUgMHggLy8gaW5pdGlhbCB0YWlsCglwdXNoYnl0ZXMgMHgwMDA0IC8vIGluaXRpYWwgaGVhZCBvZmZzZXQKCXB1c2hieXRlcyAweDAwMGIKCWNhbGxzdWIgKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMDMxNjIxMmMKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50Cglwb3AgLy8gcG9wIGhlYWQgb2Zmc2V0Cgljb25jYXQgLy8gY29uY2F0IGhlYWQgYW5kIHRhaWwKCWZyYW1lX2J1cnkgMCAvLyBhOiBbdWludDE2LCB1aW50PDg+W11dCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjY3NgoJLy8gcmV0dXJuIGFbMV1bMV07CglmcmFtZV9kaWcgMCAvLyBhOiBbdWludDE2LCB1aW50PDg+W11dCglzdG9yZSAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJcHVzaGludCAyCglleHRyYWN0X3VpbnQxNgoJcHVzaGludCAxIC8vIGFjYyAqIHR5cGVMZW5ndGgKCSsKCXB1c2hpbnQgMgoJKyAvLyBhZGQgdHdvIGZvciBsZW5ndGgKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXN3YXAKCXB1c2hpbnQgMQoJZXh0cmFjdDMKCWJ0b2kKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZjhlNTE3Y2UgLy8gbWV0aG9kICJhY2Nlc3NEeW5hbWljQXJyYXlFbGVtZW50SW5UdXBsZSgpdWludDgiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2FjY2Vzc0R5bmFtaWNBcnJheUVsZW1lbnRJblR1cGxlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJyCgoqcHJvY2Vzc19zdGF0aWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50Cgljb25jYXQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCXJldHN1YgoKKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50OgoJcHJvdG8gNCAzCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0Cgljb25jYXQKCWZyYW1lX2J1cnkgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0xIC8vIGVsZW1lbnQKCWR1cAoJbGVuCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCWJ0b2kKCSsKCWl0b2IKCWV4dHJhY3QgNiAyCglmcmFtZV9idXJ5IC0yIC8vIGhlYWQgb2Zmc2V0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJc3dhcAoJY29uY2F0CglmcmFtZV9idXJ5IC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestAccessDynamicArrayElementInTuple.arc56_draft.json b/tests/contracts/artifacts/ABITestAccessDynamicArrayElementInTuple.arc56_draft.json index f0ca52163..899718176 100644 --- a/tests/contracts/artifacts/ABITestAccessDynamicArrayElementInTuple.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestAccessDynamicArrayElementInTuple.arc56_draft.json @@ -820,7 +820,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBhY2Nlc3NEeW5hbWljQXJyYXlFbGVtZW50SW5UdXBsZSgpdWludDgKKmFiaV9yb3V0ZV9hY2Nlc3NEeW5hbWljQXJyYXlFbGVtZW50SW5UdXBsZToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGFjY2Vzc0R5bmFtaWNBcnJheUVsZW1lbnRJblR1cGxlKCl1aW50OAoJY2FsbHN1YiBhY2Nlc3NEeW5hbWljQXJyYXlFbGVtZW50SW5UdXBsZQoJaXRvYgoJZHVwCgliaXRsZW4KCXB1c2hpbnQgOAoJPD0KCgkvLyBhY2Nlc3NEeW5hbWljQXJyYXlFbGVtZW50SW5UdXBsZSByZXR1cm4gdmFsdWUgb3ZlcmZsb3dlZCA4IGJpdHMKCWFzc2VydAoJZXh0cmFjdCA3IDEKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gYWNjZXNzRHluYW1pY0FycmF5RWxlbWVudEluVHVwbGUoKTogdWludDw4PgphY2Nlc3NEeW5hbWljQXJyYXlFbGVtZW50SW5UdXBsZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjY3NAoJLy8gYTogW3VpbnQxNiwgdWludDw4PltdXSA9IFsxMSwgWzIyLCAzMywgNDRdXQoJYnl0ZSAweCAvLyBpbml0aWFsIGhlYWQKCWJ5dGUgMHggLy8gaW5pdGlhbCB0YWlsCglwdXNoYnl0ZXMgMHgwMDA0IC8vIGluaXRpYWwgaGVhZCBvZmZzZXQKCXB1c2hieXRlcyAweDAwMGIKCWNhbGxzdWIgKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMDMxNjIxMmMKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50Cglwb3AgLy8gcG9wIGhlYWQgb2Zmc2V0Cgljb25jYXQgLy8gY29uY2F0IGhlYWQgYW5kIHRhaWwKCWZyYW1lX2J1cnkgMCAvLyBhOiBbdWludDE2LCB1aW50PDg+W11dCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjY3NgoJLy8gcmV0dXJuIGFbMV1bMV07CglmcmFtZV9kaWcgMCAvLyBhOiBbdWludDE2LCB1aW50PDg+W11dCglzdG9yZSAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJcHVzaGludCAyCglleHRyYWN0X3VpbnQxNgoJcHVzaGludCAxIC8vIGFjYyAqIHR5cGVMZW5ndGgKCSsKCXB1c2hpbnQgMgoJKyAvLyBhZGQgdHdvIGZvciBsZW5ndGgKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXN3YXAKCXB1c2hpbnQgMQoJZXh0cmFjdDMKCWJ0b2kKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZjhlNTE3Y2UgLy8gbWV0aG9kICJhY2Nlc3NEeW5hbWljQXJyYXlFbGVtZW50SW5UdXBsZSgpdWludDgiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2FjY2Vzc0R5bmFtaWNBcnJheUVsZW1lbnRJblR1cGxlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJyCgoqcHJvY2Vzc19zdGF0aWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50Cgljb25jYXQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCXJldHN1YgoKKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50OgoJcHJvdG8gNCAzCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0Cgljb25jYXQKCWZyYW1lX2J1cnkgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0xIC8vIGVsZW1lbnQKCWR1cAoJbGVuCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCWJ0b2kKCSsKCWl0b2IKCWV4dHJhY3QgNiAyCglmcmFtZV9idXJ5IC0yIC8vIGhlYWQgb2Zmc2V0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJc3dhcAoJY29uY2F0CglmcmFtZV9idXJ5IC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBhY2Nlc3NEeW5hbWljQXJyYXlFbGVtZW50SW5UdXBsZSgpdWludDgKKmFiaV9yb3V0ZV9hY2Nlc3NEeW5hbWljQXJyYXlFbGVtZW50SW5UdXBsZToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGFjY2Vzc0R5bmFtaWNBcnJheUVsZW1lbnRJblR1cGxlKCl1aW50OAoJY2FsbHN1YiBhY2Nlc3NEeW5hbWljQXJyYXlFbGVtZW50SW5UdXBsZQoJaXRvYgoJZHVwCgliaXRsZW4KCXB1c2hpbnQgOAoJPD0KCgkvLyBhY2Nlc3NEeW5hbWljQXJyYXlFbGVtZW50SW5UdXBsZSByZXR1cm4gdmFsdWUgb3ZlcmZsb3dlZCA4IGJpdHMKCWFzc2VydAoJZXh0cmFjdCA3IDEKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gYWNjZXNzRHluYW1pY0FycmF5RWxlbWVudEluVHVwbGUoKTogdWludDw4PgphY2Nlc3NEeW5hbWljQXJyYXlFbGVtZW50SW5UdXBsZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjY3NAoJLy8gYTogW3VpbnQxNiwgdWludDw4PltdXSA9IFsxMSwgWzIyLCAzMywgNDRdXQoJYnl0ZSAweCAvLyBpbml0aWFsIGhlYWQKCWJ5dGUgMHggLy8gaW5pdGlhbCB0YWlsCglwdXNoYnl0ZXMgMHgwMDA0IC8vIGluaXRpYWwgaGVhZCBvZmZzZXQKCXB1c2hieXRlcyAweDAwMGIKCWNhbGxzdWIgKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMDMxNjIxMmMKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50Cglwb3AgLy8gcG9wIGhlYWQgb2Zmc2V0Cgljb25jYXQgLy8gY29uY2F0IGhlYWQgYW5kIHRhaWwKCWZyYW1lX2J1cnkgMCAvLyBhOiBbdWludDE2LCB1aW50PDg+W11dCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjY3NgoJLy8gcmV0dXJuIGFbMV1bMV07CglmcmFtZV9kaWcgMCAvLyBhOiBbdWludDE2LCB1aW50PDg+W11dCglzdG9yZSAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJcHVzaGludCAyCglleHRyYWN0X3VpbnQxNgoJcHVzaGludCAxIC8vIGFjYyAqIHR5cGVMZW5ndGgKCSsKCXB1c2hpbnQgMgoJKyAvLyBhZGQgdHdvIGZvciBsZW5ndGgKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXN3YXAKCXB1c2hpbnQgMQoJZXh0cmFjdDMKCWJ0b2kKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZjhlNTE3Y2UgLy8gbWV0aG9kICJhY2Nlc3NEeW5hbWljQXJyYXlFbGVtZW50SW5UdXBsZSgpdWludDgiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2FjY2Vzc0R5bmFtaWNBcnJheUVsZW1lbnRJblR1cGxlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJyCgoqcHJvY2Vzc19zdGF0aWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50Cgljb25jYXQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCXJldHN1YgoKKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50OgoJcHJvdG8gNCAzCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0Cgljb25jYXQKCWZyYW1lX2J1cnkgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0xIC8vIGVsZW1lbnQKCWR1cAoJbGVuCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCWJ0b2kKCSsKCWl0b2IKCWV4dHJhY3QgNiAyCglmcmFtZV9idXJ5IC0yIC8vIGhlYWQgb2Zmc2V0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJc3dhcAoJY29uY2F0CglmcmFtZV9idXJ5IC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestAccessDynamicArrayInMiddleOfTuple.approval.teal b/tests/contracts/artifacts/ABITestAccessDynamicArrayInMiddleOfTuple.approval.teal index bccfae4cf..8f73f2f80 100644 --- a/tests/contracts/artifacts/ABITestAccessDynamicArrayInMiddleOfTuple.approval.teal +++ b/tests/contracts/artifacts/ABITestAccessDynamicArrayInMiddleOfTuple.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestAccessDynamicArrayInMiddleOfTuple.arc32.json b/tests/contracts/artifacts/ABITestAccessDynamicArrayInMiddleOfTuple.arc32.json index 16ba66df2..3b573b13a 100644 --- a/tests/contracts/artifacts/ABITestAccessDynamicArrayInMiddleOfTuple.arc32.json +++ b/tests/contracts/artifacts/ABITestAccessDynamicArrayInMiddleOfTuple.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBhY2Nlc3NEeW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGUoKXVpbnQ4W10KKmFiaV9yb3V0ZV9hY2Nlc3NEeW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBhY2Nlc3NEeW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGUoKXVpbnQ4W10KCWNhbGxzdWIgYWNjZXNzRHluYW1pY0FycmF5SW5NaWRkbGVPZlR1cGxlCglkdXAKCWxlbgoJaXRvYgoJZXh0cmFjdCA2IDIKCXN3YXAKCWNvbmNhdAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBhY2Nlc3NEeW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGUoKTogdWludDw4PltdCmFjY2Vzc0R5bmFtaWNBcnJheUluTWlkZGxlT2ZUdXBsZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjY2NgoJLy8gYTogW3VpbnQxNiwgdWludDw4PltdLCB1aW50MTZdID0gWzEsIFsyXSwgM10KCWJ5dGUgMHggLy8gaW5pdGlhbCBoZWFkCglieXRlIDB4IC8vIGluaXRpYWwgdGFpbAoJcHVzaGJ5dGVzIDB4MDAwNiAvLyBpbml0aWFsIGhlYWQgb2Zmc2V0CglwdXNoYnl0ZXMgMHgwMDAxCgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAxMDIKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAzCgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50Cglwb3AgLy8gcG9wIGhlYWQgb2Zmc2V0Cgljb25jYXQgLy8gY29uY2F0IGhlYWQgYW5kIHRhaWwKCWZyYW1lX2J1cnkgMCAvLyBhOiBbdWludDE2LCB1aW50PDg+W10sIHVpbnQxNl0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NjY4CgkvLyByZXR1cm4gYVsxXTsKCWZyYW1lX2RpZyAwIC8vIGE6IFt1aW50MTYsIHVpbnQ8OD5bXSwgdWludDE2XQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgMgoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJdW5jb3ZlciAyCglleHRyYWN0X3VpbnQxNgoJZHVwIC8vIGR1cGxpY2F0ZSBzdGFydCBvZiBlbGVtZW50Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglzd2FwCglleHRyYWN0X3VpbnQxNiAvLyBnZXQgbnVtYmVyIG9mIGVsZW1lbnRzCglwdXNoaW50IDEgLy8gZ2V0IHR5cGUgbGVuZ3RoCgkqIC8vIG11bHRpcGx5IGJ5IHR5cGUgbGVuZ3RoCglwdXNoaW50IDIKCSsgLy8gYWRkIHR3byBmb3IgbGVuZ3RoCglleHRyYWN0MwoJZXh0cmFjdCAyIDAKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MmZmMzgyZGUgLy8gbWV0aG9kICJhY2Nlc3NEeW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGUoKXVpbnQ4W10iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2FjY2Vzc0R5bmFtaWNBcnJheUluTWlkZGxlT2ZUdXBsZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycgoKKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJY29uY2F0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWIKCipwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJY29uY2F0CglmcmFtZV9idXJ5IC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50CglkdXAKCWxlbgoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglidG9pCgkrCglpdG9iCglleHRyYWN0IDYgMgoJZnJhbWVfYnVyeSAtMiAvLyBoZWFkIG9mZnNldAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCXN3YXAKCWNvbmNhdAoJZnJhbWVfYnVyeSAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3Vi", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBhY2Nlc3NEeW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGUoKXVpbnQ4W10KKmFiaV9yb3V0ZV9hY2Nlc3NEeW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBhY2Nlc3NEeW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGUoKXVpbnQ4W10KCWNhbGxzdWIgYWNjZXNzRHluYW1pY0FycmF5SW5NaWRkbGVPZlR1cGxlCglkdXAKCWxlbgoJaXRvYgoJZXh0cmFjdCA2IDIKCXN3YXAKCWNvbmNhdAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBhY2Nlc3NEeW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGUoKTogdWludDw4PltdCmFjY2Vzc0R5bmFtaWNBcnJheUluTWlkZGxlT2ZUdXBsZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjY2NgoJLy8gYTogW3VpbnQxNiwgdWludDw4PltdLCB1aW50MTZdID0gWzEsIFsyXSwgM10KCWJ5dGUgMHggLy8gaW5pdGlhbCBoZWFkCglieXRlIDB4IC8vIGluaXRpYWwgdGFpbAoJcHVzaGJ5dGVzIDB4MDAwNiAvLyBpbml0aWFsIGhlYWQgb2Zmc2V0CglwdXNoYnl0ZXMgMHgwMDAxCgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAxMDIKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAzCgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50Cglwb3AgLy8gcG9wIGhlYWQgb2Zmc2V0Cgljb25jYXQgLy8gY29uY2F0IGhlYWQgYW5kIHRhaWwKCWZyYW1lX2J1cnkgMCAvLyBhOiBbdWludDE2LCB1aW50PDg+W10sIHVpbnQxNl0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NjY4CgkvLyByZXR1cm4gYVsxXTsKCWZyYW1lX2RpZyAwIC8vIGE6IFt1aW50MTYsIHVpbnQ8OD5bXSwgdWludDE2XQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgMgoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJdW5jb3ZlciAyCglleHRyYWN0X3VpbnQxNgoJZHVwIC8vIGR1cGxpY2F0ZSBzdGFydCBvZiBlbGVtZW50Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglzd2FwCglleHRyYWN0X3VpbnQxNiAvLyBnZXQgbnVtYmVyIG9mIGVsZW1lbnRzCglwdXNoaW50IDEgLy8gZ2V0IHR5cGUgbGVuZ3RoCgkqIC8vIG11bHRpcGx5IGJ5IHR5cGUgbGVuZ3RoCglwdXNoaW50IDIKCSsgLy8gYWRkIHR3byBmb3IgbGVuZ3RoCglleHRyYWN0MwoJZXh0cmFjdCAyIDAKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MmZmMzgyZGUgLy8gbWV0aG9kICJhY2Nlc3NEeW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGUoKXVpbnQ4W10iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2FjY2Vzc0R5bmFtaWNBcnJheUluTWlkZGxlT2ZUdXBsZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycgoKKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJY29uY2F0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWIKCipwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJY29uY2F0CglmcmFtZV9idXJ5IC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50CglkdXAKCWxlbgoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglidG9pCgkrCglpdG9iCglleHRyYWN0IDYgMgoJZnJhbWVfYnVyeSAtMiAvLyBoZWFkIG9mZnNldAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCXN3YXAKCWNvbmNhdAoJZnJhbWVfYnVyeSAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3Vi", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestAccessDynamicArrayInMiddleOfTuple.arc56_draft.json b/tests/contracts/artifacts/ABITestAccessDynamicArrayInMiddleOfTuple.arc56_draft.json index 96f4e2bfd..01ba6ee80 100644 --- a/tests/contracts/artifacts/ABITestAccessDynamicArrayInMiddleOfTuple.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestAccessDynamicArrayInMiddleOfTuple.arc56_draft.json @@ -852,7 +852,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBhY2Nlc3NEeW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGUoKXVpbnQ4W10KKmFiaV9yb3V0ZV9hY2Nlc3NEeW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBhY2Nlc3NEeW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGUoKXVpbnQ4W10KCWNhbGxzdWIgYWNjZXNzRHluYW1pY0FycmF5SW5NaWRkbGVPZlR1cGxlCglkdXAKCWxlbgoJaXRvYgoJZXh0cmFjdCA2IDIKCXN3YXAKCWNvbmNhdAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBhY2Nlc3NEeW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGUoKTogdWludDw4PltdCmFjY2Vzc0R5bmFtaWNBcnJheUluTWlkZGxlT2ZUdXBsZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjY2NgoJLy8gYTogW3VpbnQxNiwgdWludDw4PltdLCB1aW50MTZdID0gWzEsIFsyXSwgM10KCWJ5dGUgMHggLy8gaW5pdGlhbCBoZWFkCglieXRlIDB4IC8vIGluaXRpYWwgdGFpbAoJcHVzaGJ5dGVzIDB4MDAwNiAvLyBpbml0aWFsIGhlYWQgb2Zmc2V0CglwdXNoYnl0ZXMgMHgwMDAxCgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAxMDIKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAzCgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50Cglwb3AgLy8gcG9wIGhlYWQgb2Zmc2V0Cgljb25jYXQgLy8gY29uY2F0IGhlYWQgYW5kIHRhaWwKCWZyYW1lX2J1cnkgMCAvLyBhOiBbdWludDE2LCB1aW50PDg+W10sIHVpbnQxNl0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NjY4CgkvLyByZXR1cm4gYVsxXTsKCWZyYW1lX2RpZyAwIC8vIGE6IFt1aW50MTYsIHVpbnQ8OD5bXSwgdWludDE2XQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgMgoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJdW5jb3ZlciAyCglleHRyYWN0X3VpbnQxNgoJZHVwIC8vIGR1cGxpY2F0ZSBzdGFydCBvZiBlbGVtZW50Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglzd2FwCglleHRyYWN0X3VpbnQxNiAvLyBnZXQgbnVtYmVyIG9mIGVsZW1lbnRzCglwdXNoaW50IDEgLy8gZ2V0IHR5cGUgbGVuZ3RoCgkqIC8vIG11bHRpcGx5IGJ5IHR5cGUgbGVuZ3RoCglwdXNoaW50IDIKCSsgLy8gYWRkIHR3byBmb3IgbGVuZ3RoCglleHRyYWN0MwoJZXh0cmFjdCAyIDAKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MmZmMzgyZGUgLy8gbWV0aG9kICJhY2Nlc3NEeW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGUoKXVpbnQ4W10iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2FjY2Vzc0R5bmFtaWNBcnJheUluTWlkZGxlT2ZUdXBsZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycgoKKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJY29uY2F0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWIKCipwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJY29uY2F0CglmcmFtZV9idXJ5IC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50CglkdXAKCWxlbgoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglidG9pCgkrCglpdG9iCglleHRyYWN0IDYgMgoJZnJhbWVfYnVyeSAtMiAvLyBoZWFkIG9mZnNldAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCXN3YXAKCWNvbmNhdAoJZnJhbWVfYnVyeSAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3Vi", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBhY2Nlc3NEeW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGUoKXVpbnQ4W10KKmFiaV9yb3V0ZV9hY2Nlc3NEeW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBhY2Nlc3NEeW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGUoKXVpbnQ4W10KCWNhbGxzdWIgYWNjZXNzRHluYW1pY0FycmF5SW5NaWRkbGVPZlR1cGxlCglkdXAKCWxlbgoJaXRvYgoJZXh0cmFjdCA2IDIKCXN3YXAKCWNvbmNhdAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBhY2Nlc3NEeW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGUoKTogdWludDw4PltdCmFjY2Vzc0R5bmFtaWNBcnJheUluTWlkZGxlT2ZUdXBsZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjY2NgoJLy8gYTogW3VpbnQxNiwgdWludDw4PltdLCB1aW50MTZdID0gWzEsIFsyXSwgM10KCWJ5dGUgMHggLy8gaW5pdGlhbCBoZWFkCglieXRlIDB4IC8vIGluaXRpYWwgdGFpbAoJcHVzaGJ5dGVzIDB4MDAwNiAvLyBpbml0aWFsIGhlYWQgb2Zmc2V0CglwdXNoYnl0ZXMgMHgwMDAxCgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAxMDIKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAzCgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50Cglwb3AgLy8gcG9wIGhlYWQgb2Zmc2V0Cgljb25jYXQgLy8gY29uY2F0IGhlYWQgYW5kIHRhaWwKCWZyYW1lX2J1cnkgMCAvLyBhOiBbdWludDE2LCB1aW50PDg+W10sIHVpbnQxNl0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NjY4CgkvLyByZXR1cm4gYVsxXTsKCWZyYW1lX2RpZyAwIC8vIGE6IFt1aW50MTYsIHVpbnQ8OD5bXSwgdWludDE2XQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgMgoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJdW5jb3ZlciAyCglleHRyYWN0X3VpbnQxNgoJZHVwIC8vIGR1cGxpY2F0ZSBzdGFydCBvZiBlbGVtZW50Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglzd2FwCglleHRyYWN0X3VpbnQxNiAvLyBnZXQgbnVtYmVyIG9mIGVsZW1lbnRzCglwdXNoaW50IDEgLy8gZ2V0IHR5cGUgbGVuZ3RoCgkqIC8vIG11bHRpcGx5IGJ5IHR5cGUgbGVuZ3RoCglwdXNoaW50IDIKCSsgLy8gYWRkIHR3byBmb3IgbGVuZ3RoCglleHRyYWN0MwoJZXh0cmFjdCAyIDAKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MmZmMzgyZGUgLy8gbWV0aG9kICJhY2Nlc3NEeW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGUoKXVpbnQ4W10iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2FjY2Vzc0R5bmFtaWNBcnJheUluTWlkZGxlT2ZUdXBsZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycgoKKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJY29uY2F0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWIKCipwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJY29uY2F0CglmcmFtZV9idXJ5IC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50CglkdXAKCWxlbgoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglidG9pCgkrCglpdG9iCglleHRyYWN0IDYgMgoJZnJhbWVfYnVyeSAtMiAvLyBoZWFkIG9mZnNldAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCXN3YXAKCWNvbmNhdAoJZnJhbWVfYnVyeSAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3Vi", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestAccessDynamicStringArray.approval.teal b/tests/contracts/artifacts/ABITestAccessDynamicStringArray.approval.teal index 595a8a08f..e1c253092 100644 --- a/tests/contracts/artifacts/ABITestAccessDynamicStringArray.approval.teal +++ b/tests/contracts/artifacts/ABITestAccessDynamicStringArray.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestAccessDynamicStringArray.arc32.json b/tests/contracts/artifacts/ABITestAccessDynamicStringArray.arc32.json index b76ce0f0f..1c171a322 100644 --- a/tests/contracts/artifacts/ABITestAccessDynamicStringArray.arc32.json +++ b/tests/contracts/artifacts/ABITestAccessDynamicStringArray.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBhY2Nlc3NEeW5hbWljU3RyaW5nQXJyYXkoKXN0cmluZwoqYWJpX3JvdXRlX2FjY2Vzc0R5bmFtaWNTdHJpbmdBcnJheToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGFjY2Vzc0R5bmFtaWNTdHJpbmdBcnJheSgpc3RyaW5nCgljYWxsc3ViIGFjY2Vzc0R5bmFtaWNTdHJpbmdBcnJheQoJZHVwCglsZW4KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gYWNjZXNzRHluYW1pY1N0cmluZ0FycmF5KCk6IHN0cmluZwphY2Nlc3NEeW5hbWljU3RyaW5nQXJyYXk6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJYnl0ZSAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo3MTAKCS8vIGE6IHN0cmluZ1tdID0gWydIZWxsbycsICdXb3JsZCcsICchJ10KCWJ5dGUgMHggLy8gaW5pdGlhbCBoZWFkCglieXRlIDB4IC8vIGluaXRpYWwgdGFpbAoJcHVzaGJ5dGVzIDB4MDAwNiAvLyBpbml0aWFsIGhlYWQgb2Zmc2V0CglwdXNoYnl0ZXMgMHgwMDA1NDg2NTZjNmM2ZgoJY2FsbHN1YiAqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMDU1NzZmNzI2YzY0CgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwMTIxCgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcG9wIC8vIHBvcCBoZWFkIG9mZnNldAoJY29uY2F0IC8vIGNvbmNhdCBoZWFkIGFuZCB0YWlsCglwdXNoYnl0ZXMgMHgwMDAzCglzd2FwCgljb25jYXQKCWZyYW1lX2J1cnkgMCAvLyBhOiBzdHJpbmdbXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo3MTIKCS8vIHJldHVybiBhWzFdOwoJZnJhbWVfZGlnIDAgLy8gYTogc3RyaW5nW10KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoaW50IDQKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXVuY292ZXIgMgoJZXh0cmFjdF91aW50MTYKCXB1c2hpbnQgMgoJKyAvLyBhZGQgdHdvIGZvciBsZW5ndGgKCWR1cCAvLyBkdXBsaWNhdGUgc3RhcnQgb2YgZWxlbWVudAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJc3dhcAoJZXh0cmFjdF91aW50MTYgLy8gZ2V0IG51bWJlciBvZiBlbGVtZW50cwoJcHVzaGludCAxIC8vIGdldCB0eXBlIGxlbmd0aAoJKiAvLyBtdWx0aXBseSBieSB0eXBlIGxlbmd0aAoJcHVzaGludCAyCgkrIC8vIGFkZCB0d28gZm9yIGxlbmd0aAoJZXh0cmFjdDMKCWV4dHJhY3QgMiAwCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGY4NGJhNGJmIC8vIG1ldGhvZCAiYWNjZXNzRHluYW1pY1N0cmluZ0FycmF5KClzdHJpbmciCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2FjY2Vzc0R5bmFtaWNTdHJpbmdBcnJheQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycgoKKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50OgoJcHJvdG8gNCAzCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0Cgljb25jYXQKCWZyYW1lX2J1cnkgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0xIC8vIGVsZW1lbnQKCWR1cAoJbGVuCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCWJ0b2kKCSsKCWl0b2IKCWV4dHJhY3QgNiAyCglmcmFtZV9idXJ5IC0yIC8vIGhlYWQgb2Zmc2V0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJc3dhcAoJY29uY2F0CglmcmFtZV9idXJ5IC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBhY2Nlc3NEeW5hbWljU3RyaW5nQXJyYXkoKXN0cmluZwoqYWJpX3JvdXRlX2FjY2Vzc0R5bmFtaWNTdHJpbmdBcnJheToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGFjY2Vzc0R5bmFtaWNTdHJpbmdBcnJheSgpc3RyaW5nCgljYWxsc3ViIGFjY2Vzc0R5bmFtaWNTdHJpbmdBcnJheQoJZHVwCglsZW4KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gYWNjZXNzRHluYW1pY1N0cmluZ0FycmF5KCk6IHN0cmluZwphY2Nlc3NEeW5hbWljU3RyaW5nQXJyYXk6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJYnl0ZSAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo3MTAKCS8vIGE6IHN0cmluZ1tdID0gWydIZWxsbycsICdXb3JsZCcsICchJ10KCWJ5dGUgMHggLy8gaW5pdGlhbCBoZWFkCglieXRlIDB4IC8vIGluaXRpYWwgdGFpbAoJcHVzaGJ5dGVzIDB4MDAwNiAvLyBpbml0aWFsIGhlYWQgb2Zmc2V0CglwdXNoYnl0ZXMgMHgwMDA1NDg2NTZjNmM2ZgoJY2FsbHN1YiAqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMDU1NzZmNzI2YzY0CgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwMTIxCgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcG9wIC8vIHBvcCBoZWFkIG9mZnNldAoJY29uY2F0IC8vIGNvbmNhdCBoZWFkIGFuZCB0YWlsCglwdXNoYnl0ZXMgMHgwMDAzCglzd2FwCgljb25jYXQKCWZyYW1lX2J1cnkgMCAvLyBhOiBzdHJpbmdbXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo3MTIKCS8vIHJldHVybiBhWzFdOwoJZnJhbWVfZGlnIDAgLy8gYTogc3RyaW5nW10KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoaW50IDQKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXVuY292ZXIgMgoJZXh0cmFjdF91aW50MTYKCXB1c2hpbnQgMgoJKyAvLyBhZGQgdHdvIGZvciBsZW5ndGgKCWR1cCAvLyBkdXBsaWNhdGUgc3RhcnQgb2YgZWxlbWVudAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJc3dhcAoJZXh0cmFjdF91aW50MTYgLy8gZ2V0IG51bWJlciBvZiBlbGVtZW50cwoJcHVzaGludCAxIC8vIGdldCB0eXBlIGxlbmd0aAoJKiAvLyBtdWx0aXBseSBieSB0eXBlIGxlbmd0aAoJcHVzaGludCAyCgkrIC8vIGFkZCB0d28gZm9yIGxlbmd0aAoJZXh0cmFjdDMKCWV4dHJhY3QgMiAwCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGY4NGJhNGJmIC8vIG1ldGhvZCAiYWNjZXNzRHluYW1pY1N0cmluZ0FycmF5KClzdHJpbmciCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2FjY2Vzc0R5bmFtaWNTdHJpbmdBcnJheQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycgoKKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50OgoJcHJvdG8gNCAzCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0Cgljb25jYXQKCWZyYW1lX2J1cnkgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0xIC8vIGVsZW1lbnQKCWR1cAoJbGVuCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCWJ0b2kKCSsKCWl0b2IKCWV4dHJhY3QgNiAyCglmcmFtZV9idXJ5IC0yIC8vIGhlYWQgb2Zmc2V0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJc3dhcAoJY29uY2F0CglmcmFtZV9idXJ5IC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestAccessDynamicStringArray.arc56_draft.json b/tests/contracts/artifacts/ABITestAccessDynamicStringArray.arc56_draft.json index db2c541a0..626b0e59c 100644 --- a/tests/contracts/artifacts/ABITestAccessDynamicStringArray.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestAccessDynamicStringArray.arc56_draft.json @@ -846,7 +846,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBhY2Nlc3NEeW5hbWljU3RyaW5nQXJyYXkoKXN0cmluZwoqYWJpX3JvdXRlX2FjY2Vzc0R5bmFtaWNTdHJpbmdBcnJheToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGFjY2Vzc0R5bmFtaWNTdHJpbmdBcnJheSgpc3RyaW5nCgljYWxsc3ViIGFjY2Vzc0R5bmFtaWNTdHJpbmdBcnJheQoJZHVwCglsZW4KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gYWNjZXNzRHluYW1pY1N0cmluZ0FycmF5KCk6IHN0cmluZwphY2Nlc3NEeW5hbWljU3RyaW5nQXJyYXk6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJYnl0ZSAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo3MTAKCS8vIGE6IHN0cmluZ1tdID0gWydIZWxsbycsICdXb3JsZCcsICchJ10KCWJ5dGUgMHggLy8gaW5pdGlhbCBoZWFkCglieXRlIDB4IC8vIGluaXRpYWwgdGFpbAoJcHVzaGJ5dGVzIDB4MDAwNiAvLyBpbml0aWFsIGhlYWQgb2Zmc2V0CglwdXNoYnl0ZXMgMHgwMDA1NDg2NTZjNmM2ZgoJY2FsbHN1YiAqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMDU1NzZmNzI2YzY0CgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwMTIxCgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcG9wIC8vIHBvcCBoZWFkIG9mZnNldAoJY29uY2F0IC8vIGNvbmNhdCBoZWFkIGFuZCB0YWlsCglwdXNoYnl0ZXMgMHgwMDAzCglzd2FwCgljb25jYXQKCWZyYW1lX2J1cnkgMCAvLyBhOiBzdHJpbmdbXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo3MTIKCS8vIHJldHVybiBhWzFdOwoJZnJhbWVfZGlnIDAgLy8gYTogc3RyaW5nW10KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoaW50IDQKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXVuY292ZXIgMgoJZXh0cmFjdF91aW50MTYKCXB1c2hpbnQgMgoJKyAvLyBhZGQgdHdvIGZvciBsZW5ndGgKCWR1cCAvLyBkdXBsaWNhdGUgc3RhcnQgb2YgZWxlbWVudAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJc3dhcAoJZXh0cmFjdF91aW50MTYgLy8gZ2V0IG51bWJlciBvZiBlbGVtZW50cwoJcHVzaGludCAxIC8vIGdldCB0eXBlIGxlbmd0aAoJKiAvLyBtdWx0aXBseSBieSB0eXBlIGxlbmd0aAoJcHVzaGludCAyCgkrIC8vIGFkZCB0d28gZm9yIGxlbmd0aAoJZXh0cmFjdDMKCWV4dHJhY3QgMiAwCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGY4NGJhNGJmIC8vIG1ldGhvZCAiYWNjZXNzRHluYW1pY1N0cmluZ0FycmF5KClzdHJpbmciCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2FjY2Vzc0R5bmFtaWNTdHJpbmdBcnJheQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycgoKKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50OgoJcHJvdG8gNCAzCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0Cgljb25jYXQKCWZyYW1lX2J1cnkgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0xIC8vIGVsZW1lbnQKCWR1cAoJbGVuCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCWJ0b2kKCSsKCWl0b2IKCWV4dHJhY3QgNiAyCglmcmFtZV9idXJ5IC0yIC8vIGhlYWQgb2Zmc2V0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJc3dhcAoJY29uY2F0CglmcmFtZV9idXJ5IC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBhY2Nlc3NEeW5hbWljU3RyaW5nQXJyYXkoKXN0cmluZwoqYWJpX3JvdXRlX2FjY2Vzc0R5bmFtaWNTdHJpbmdBcnJheToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGFjY2Vzc0R5bmFtaWNTdHJpbmdBcnJheSgpc3RyaW5nCgljYWxsc3ViIGFjY2Vzc0R5bmFtaWNTdHJpbmdBcnJheQoJZHVwCglsZW4KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gYWNjZXNzRHluYW1pY1N0cmluZ0FycmF5KCk6IHN0cmluZwphY2Nlc3NEeW5hbWljU3RyaW5nQXJyYXk6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJYnl0ZSAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo3MTAKCS8vIGE6IHN0cmluZ1tdID0gWydIZWxsbycsICdXb3JsZCcsICchJ10KCWJ5dGUgMHggLy8gaW5pdGlhbCBoZWFkCglieXRlIDB4IC8vIGluaXRpYWwgdGFpbAoJcHVzaGJ5dGVzIDB4MDAwNiAvLyBpbml0aWFsIGhlYWQgb2Zmc2V0CglwdXNoYnl0ZXMgMHgwMDA1NDg2NTZjNmM2ZgoJY2FsbHN1YiAqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMDU1NzZmNzI2YzY0CgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwMTIxCgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcG9wIC8vIHBvcCBoZWFkIG9mZnNldAoJY29uY2F0IC8vIGNvbmNhdCBoZWFkIGFuZCB0YWlsCglwdXNoYnl0ZXMgMHgwMDAzCglzd2FwCgljb25jYXQKCWZyYW1lX2J1cnkgMCAvLyBhOiBzdHJpbmdbXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo3MTIKCS8vIHJldHVybiBhWzFdOwoJZnJhbWVfZGlnIDAgLy8gYTogc3RyaW5nW10KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoaW50IDQKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXVuY292ZXIgMgoJZXh0cmFjdF91aW50MTYKCXB1c2hpbnQgMgoJKyAvLyBhZGQgdHdvIGZvciBsZW5ndGgKCWR1cCAvLyBkdXBsaWNhdGUgc3RhcnQgb2YgZWxlbWVudAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJc3dhcAoJZXh0cmFjdF91aW50MTYgLy8gZ2V0IG51bWJlciBvZiBlbGVtZW50cwoJcHVzaGludCAxIC8vIGdldCB0eXBlIGxlbmd0aAoJKiAvLyBtdWx0aXBseSBieSB0eXBlIGxlbmd0aAoJcHVzaGludCAyCgkrIC8vIGFkZCB0d28gZm9yIGxlbmd0aAoJZXh0cmFjdDMKCWV4dHJhY3QgMiAwCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGY4NGJhNGJmIC8vIG1ldGhvZCAiYWNjZXNzRHluYW1pY1N0cmluZ0FycmF5KClzdHJpbmciCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2FjY2Vzc0R5bmFtaWNTdHJpbmdBcnJheQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycgoKKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50OgoJcHJvdG8gNCAzCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0Cgljb25jYXQKCWZyYW1lX2J1cnkgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0xIC8vIGVsZW1lbnQKCWR1cAoJbGVuCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCWJ0b2kKCSsKCWl0b2IKCWV4dHJhY3QgNiAyCglmcmFtZV9idXJ5IC0yIC8vIGhlYWQgb2Zmc2V0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJc3dhcAoJY29uY2F0CglmcmFtZV9idXJ5IC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestAccessStaticArrayInBoxInVariable.approval.teal b/tests/contracts/artifacts/ABITestAccessStaticArrayInBoxInVariable.approval.teal index e56455e80..a6ef46194 100644 --- a/tests/contracts/artifacts/ABITestAccessStaticArrayInBoxInVariable.approval.teal +++ b/tests/contracts/artifacts/ABITestAccessStaticArrayInBoxInVariable.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x7374616b657273 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestAccessStaticArrayInBoxInVariable.arc32.json b/tests/contracts/artifacts/ABITestAccessStaticArrayInBoxInVariable.arc32.json index dc56a2e54..c7292d2e4 100644 --- a/tests/contracts/artifacts/ABITestAccessStaticArrayInBoxInVariable.arc32.json +++ b/tests/contracts/artifacts/ABITestAccessStaticArrayInBoxInVariable.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg3Mzc0NjE2YjY1NzI3MwoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDQuMQovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIGFjY2Vzc1N0YXRpY0FycmF5SW5Cb3hJblZhcmlhYmxlKCl1aW50NjQKKmFiaV9yb3V0ZV9hY2Nlc3NTdGF0aWNBcnJheUluQm94SW5WYXJpYWJsZToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGFjY2Vzc1N0YXRpY0FycmF5SW5Cb3hJblZhcmlhYmxlKCl1aW50NjQKCWNhbGxzdWIgYWNjZXNzU3RhdGljQXJyYXlJbkJveEluVmFyaWFibGUKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gYWNjZXNzU3RhdGljQXJyYXlJbkJveEluVmFyaWFibGUoKTogdWludDY0CmFjY2Vzc1N0YXRpY0FycmF5SW5Cb3hJblZhcmlhYmxlOgoJcHJvdG8gMCAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE1MTYKCS8vIHRoaXMuYktleS5jcmVhdGUoKQoJYnl0ZSAweDczNzQ2MTZiNjU3MjczIC8vICJzdGFrZXJzIgoJcHVzaGludCAxMjAKCWJveF9jcmVhdGUKCXBvcAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNTE3CgkvLyB2YWwgPSB0aGlzLmJLZXkudmFsdWVbaV0KCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNTE5CgkvLyB2YWwudTY0ID0gMQoJYnl0ZSAweDczNzQ2MTZiNjU3MjczIC8vICJzdGFrZXJzIgoJcHVzaGludCAwCglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDAxCglib3hfcmVwbGFjZQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNTIxCgkvLyByZXR1cm4gdmFsLnU2NDsKCWJ5dGUgMHg3Mzc0NjE2YjY1NzI3MyAvLyAic3Rha2VycyIKCXB1c2hpbnQgMAoJcHVzaGludCA4Cglib3hfZXh0cmFjdAoJYnRvaQoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhjZThhMDBiOCAvLyBtZXRob2QgImFjY2Vzc1N0YXRpY0FycmF5SW5Cb3hJblZhcmlhYmxlKCl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2FjY2Vzc1N0YXRpY0FycmF5SW5Cb3hJblZhcmlhYmxlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg3Mzc0NjE2YjY1NzI3MwoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDUuMAovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIGFjY2Vzc1N0YXRpY0FycmF5SW5Cb3hJblZhcmlhYmxlKCl1aW50NjQKKmFiaV9yb3V0ZV9hY2Nlc3NTdGF0aWNBcnJheUluQm94SW5WYXJpYWJsZToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGFjY2Vzc1N0YXRpY0FycmF5SW5Cb3hJblZhcmlhYmxlKCl1aW50NjQKCWNhbGxzdWIgYWNjZXNzU3RhdGljQXJyYXlJbkJveEluVmFyaWFibGUKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gYWNjZXNzU3RhdGljQXJyYXlJbkJveEluVmFyaWFibGUoKTogdWludDY0CmFjY2Vzc1N0YXRpY0FycmF5SW5Cb3hJblZhcmlhYmxlOgoJcHJvdG8gMCAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE1MTYKCS8vIHRoaXMuYktleS5jcmVhdGUoKQoJYnl0ZSAweDczNzQ2MTZiNjU3MjczIC8vICJzdGFrZXJzIgoJcHVzaGludCAxMjAKCWJveF9jcmVhdGUKCXBvcAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNTE3CgkvLyB2YWwgPSB0aGlzLmJLZXkudmFsdWVbaV0KCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNTE5CgkvLyB2YWwudTY0ID0gMQoJYnl0ZSAweDczNzQ2MTZiNjU3MjczIC8vICJzdGFrZXJzIgoJcHVzaGludCAwCglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDAxCglib3hfcmVwbGFjZQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNTIxCgkvLyByZXR1cm4gdmFsLnU2NDsKCWJ5dGUgMHg3Mzc0NjE2YjY1NzI3MyAvLyAic3Rha2VycyIKCXB1c2hpbnQgMAoJcHVzaGludCA4Cglib3hfZXh0cmFjdAoJYnRvaQoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhjZThhMDBiOCAvLyBtZXRob2QgImFjY2Vzc1N0YXRpY0FycmF5SW5Cb3hJblZhcmlhYmxlKCl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2FjY2Vzc1N0YXRpY0FycmF5SW5Cb3hJblZhcmlhYmxlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestAccessStaticArrayInBoxInVariable.arc56_draft.json b/tests/contracts/artifacts/ABITestAccessStaticArrayInBoxInVariable.arc56_draft.json index 804eddbc3..8af32f8f3 100644 --- a/tests/contracts/artifacts/ABITestAccessStaticArrayInBoxInVariable.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestAccessStaticArrayInBoxInVariable.arc56_draft.json @@ -480,7 +480,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg3Mzc0NjE2YjY1NzI3MwoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDQuMQovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIGFjY2Vzc1N0YXRpY0FycmF5SW5Cb3hJblZhcmlhYmxlKCl1aW50NjQKKmFiaV9yb3V0ZV9hY2Nlc3NTdGF0aWNBcnJheUluQm94SW5WYXJpYWJsZToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGFjY2Vzc1N0YXRpY0FycmF5SW5Cb3hJblZhcmlhYmxlKCl1aW50NjQKCWNhbGxzdWIgYWNjZXNzU3RhdGljQXJyYXlJbkJveEluVmFyaWFibGUKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gYWNjZXNzU3RhdGljQXJyYXlJbkJveEluVmFyaWFibGUoKTogdWludDY0CmFjY2Vzc1N0YXRpY0FycmF5SW5Cb3hJblZhcmlhYmxlOgoJcHJvdG8gMCAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE1MTYKCS8vIHRoaXMuYktleS5jcmVhdGUoKQoJYnl0ZSAweDczNzQ2MTZiNjU3MjczIC8vICJzdGFrZXJzIgoJcHVzaGludCAxMjAKCWJveF9jcmVhdGUKCXBvcAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNTE3CgkvLyB2YWwgPSB0aGlzLmJLZXkudmFsdWVbaV0KCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNTE5CgkvLyB2YWwudTY0ID0gMQoJYnl0ZSAweDczNzQ2MTZiNjU3MjczIC8vICJzdGFrZXJzIgoJcHVzaGludCAwCglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDAxCglib3hfcmVwbGFjZQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNTIxCgkvLyByZXR1cm4gdmFsLnU2NDsKCWJ5dGUgMHg3Mzc0NjE2YjY1NzI3MyAvLyAic3Rha2VycyIKCXB1c2hpbnQgMAoJcHVzaGludCA4Cglib3hfZXh0cmFjdAoJYnRvaQoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhjZThhMDBiOCAvLyBtZXRob2QgImFjY2Vzc1N0YXRpY0FycmF5SW5Cb3hJblZhcmlhYmxlKCl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2FjY2Vzc1N0YXRpY0FycmF5SW5Cb3hJblZhcmlhYmxlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg3Mzc0NjE2YjY1NzI3MwoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDUuMAovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIGFjY2Vzc1N0YXRpY0FycmF5SW5Cb3hJblZhcmlhYmxlKCl1aW50NjQKKmFiaV9yb3V0ZV9hY2Nlc3NTdGF0aWNBcnJheUluQm94SW5WYXJpYWJsZToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGFjY2Vzc1N0YXRpY0FycmF5SW5Cb3hJblZhcmlhYmxlKCl1aW50NjQKCWNhbGxzdWIgYWNjZXNzU3RhdGljQXJyYXlJbkJveEluVmFyaWFibGUKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gYWNjZXNzU3RhdGljQXJyYXlJbkJveEluVmFyaWFibGUoKTogdWludDY0CmFjY2Vzc1N0YXRpY0FycmF5SW5Cb3hJblZhcmlhYmxlOgoJcHJvdG8gMCAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE1MTYKCS8vIHRoaXMuYktleS5jcmVhdGUoKQoJYnl0ZSAweDczNzQ2MTZiNjU3MjczIC8vICJzdGFrZXJzIgoJcHVzaGludCAxMjAKCWJveF9jcmVhdGUKCXBvcAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNTE3CgkvLyB2YWwgPSB0aGlzLmJLZXkudmFsdWVbaV0KCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNTE5CgkvLyB2YWwudTY0ID0gMQoJYnl0ZSAweDczNzQ2MTZiNjU3MjczIC8vICJzdGFrZXJzIgoJcHVzaGludCAwCglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDAxCglib3hfcmVwbGFjZQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNTIxCgkvLyByZXR1cm4gdmFsLnU2NDsKCWJ5dGUgMHg3Mzc0NjE2YjY1NzI3MyAvLyAic3Rha2VycyIKCXB1c2hpbnQgMAoJcHVzaGludCA4Cglib3hfZXh0cmFjdAoJYnRvaQoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhjZThhMDBiOCAvLyBtZXRob2QgImFjY2Vzc1N0YXRpY0FycmF5SW5Cb3hJblZhcmlhYmxlKCl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2FjY2Vzc1N0YXRpY0FycmF5SW5Cb3hJblZhcmlhYmxlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestAngularCasting.approval.teal b/tests/contracts/artifacts/ABITestAngularCasting.approval.teal index 1ee655428..96319051c 100644 --- a/tests/contracts/artifacts/ABITestAngularCasting.approval.teal +++ b/tests/contracts/artifacts/ABITestAngularCasting.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestAngularCasting.arc32.json b/tests/contracts/artifacts/ABITestAngularCasting.arc32.json index 2a7192713..e3c4f735f 100644 --- a/tests/contracts/artifacts/ABITestAngularCasting.arc32.json +++ b/tests/contracts/artifacts/ABITestAngularCasting.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYW5ndWxhckNhc3RpbmcoKXVpbnQyNTYKKmFiaV9yb3V0ZV9hbmd1bGFyQ2FzdGluZzoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGFuZ3VsYXJDYXN0aW5nKCl1aW50MjU2CgljYWxsc3ViIGFuZ3VsYXJDYXN0aW5nCglkdXAKCWJpdGxlbgoJcHVzaGludCAyNTYKCTw9CgoJLy8gYW5ndWxhckNhc3RpbmcgcmV0dXJuIHZhbHVlIG92ZXJmbG93ZWQgMjU2IGJpdHMKCWFzc2VydAoJcHVzaGJ5dGVzIDB4RkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRgoJYiYKCWR1cAoJbGVuCglkdXAKCXB1c2hpbnQgMzIKCS0KCXN3YXAKCXN1YnN0cmluZzMKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gYW5ndWxhckNhc3RpbmcoKTogdWludDI1Ngphbmd1bGFyQ2FzdGluZzoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglwdXNoYnl0ZXMgMHgKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTAzMwoJLy8geCA9IDx1aW50MjU2PjEzMzcKCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDA1MzkKCWZyYW1lX2J1cnkgMCAvLyB4OiB1aW50MjU2CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEwMzUKCS8vIHJldHVybiB4OwoJZnJhbWVfZGlnIDAgLy8geDogdWludDI1NgoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgxNzZlNTdkZiAvLyBtZXRob2QgImFuZ3VsYXJDYXN0aW5nKCl1aW50MjU2IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9hbmd1bGFyQ2FzdGluZwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYW5ndWxhckNhc3RpbmcoKXVpbnQyNTYKKmFiaV9yb3V0ZV9hbmd1bGFyQ2FzdGluZzoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGFuZ3VsYXJDYXN0aW5nKCl1aW50MjU2CgljYWxsc3ViIGFuZ3VsYXJDYXN0aW5nCglkdXAKCWJpdGxlbgoJcHVzaGludCAyNTYKCTw9CgoJLy8gYW5ndWxhckNhc3RpbmcgcmV0dXJuIHZhbHVlIG92ZXJmbG93ZWQgMjU2IGJpdHMKCWFzc2VydAoJcHVzaGJ5dGVzIDB4RkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRgoJYiYKCWR1cAoJbGVuCglkdXAKCXB1c2hpbnQgMzIKCS0KCXN3YXAKCXN1YnN0cmluZzMKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gYW5ndWxhckNhc3RpbmcoKTogdWludDI1Ngphbmd1bGFyQ2FzdGluZzoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglwdXNoYnl0ZXMgMHgKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTAzMwoJLy8geCA9IDx1aW50MjU2PjEzMzcKCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDA1MzkKCWZyYW1lX2J1cnkgMCAvLyB4OiB1aW50MjU2CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEwMzUKCS8vIHJldHVybiB4OwoJZnJhbWVfZGlnIDAgLy8geDogdWludDI1NgoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgxNzZlNTdkZiAvLyBtZXRob2QgImFuZ3VsYXJDYXN0aW5nKCl1aW50MjU2IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9hbmd1bGFyQ2FzdGluZwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestAngularCasting.arc56_draft.json b/tests/contracts/artifacts/ABITestAngularCasting.arc56_draft.json index 0ea63686f..dcf7801cd 100644 --- a/tests/contracts/artifacts/ABITestAngularCasting.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestAngularCasting.arc56_draft.json @@ -530,7 +530,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYW5ndWxhckNhc3RpbmcoKXVpbnQyNTYKKmFiaV9yb3V0ZV9hbmd1bGFyQ2FzdGluZzoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGFuZ3VsYXJDYXN0aW5nKCl1aW50MjU2CgljYWxsc3ViIGFuZ3VsYXJDYXN0aW5nCglkdXAKCWJpdGxlbgoJcHVzaGludCAyNTYKCTw9CgoJLy8gYW5ndWxhckNhc3RpbmcgcmV0dXJuIHZhbHVlIG92ZXJmbG93ZWQgMjU2IGJpdHMKCWFzc2VydAoJcHVzaGJ5dGVzIDB4RkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRgoJYiYKCWR1cAoJbGVuCglkdXAKCXB1c2hpbnQgMzIKCS0KCXN3YXAKCXN1YnN0cmluZzMKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gYW5ndWxhckNhc3RpbmcoKTogdWludDI1Ngphbmd1bGFyQ2FzdGluZzoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglwdXNoYnl0ZXMgMHgKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTAzMwoJLy8geCA9IDx1aW50MjU2PjEzMzcKCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDA1MzkKCWZyYW1lX2J1cnkgMCAvLyB4OiB1aW50MjU2CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEwMzUKCS8vIHJldHVybiB4OwoJZnJhbWVfZGlnIDAgLy8geDogdWludDI1NgoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgxNzZlNTdkZiAvLyBtZXRob2QgImFuZ3VsYXJDYXN0aW5nKCl1aW50MjU2IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9hbmd1bGFyQ2FzdGluZwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYW5ndWxhckNhc3RpbmcoKXVpbnQyNTYKKmFiaV9yb3V0ZV9hbmd1bGFyQ2FzdGluZzoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGFuZ3VsYXJDYXN0aW5nKCl1aW50MjU2CgljYWxsc3ViIGFuZ3VsYXJDYXN0aW5nCglkdXAKCWJpdGxlbgoJcHVzaGludCAyNTYKCTw9CgoJLy8gYW5ndWxhckNhc3RpbmcgcmV0dXJuIHZhbHVlIG92ZXJmbG93ZWQgMjU2IGJpdHMKCWFzc2VydAoJcHVzaGJ5dGVzIDB4RkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRgoJYiYKCWR1cAoJbGVuCglkdXAKCXB1c2hpbnQgMzIKCS0KCXN3YXAKCXN1YnN0cmluZzMKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gYW5ndWxhckNhc3RpbmcoKTogdWludDI1Ngphbmd1bGFyQ2FzdGluZzoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglwdXNoYnl0ZXMgMHgKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTAzMwoJLy8geCA9IDx1aW50MjU2PjEzMzcKCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDA1MzkKCWZyYW1lX2J1cnkgMCAvLyB4OiB1aW50MjU2CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEwMzUKCS8vIHJldHVybiB4OwoJZnJhbWVfZGlnIDAgLy8geDogdWludDI1NgoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgxNzZlNTdkZiAvLyBtZXRob2QgImFuZ3VsYXJDYXN0aW5nKCl1aW50MjU2IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9hbmd1bGFyQ2FzdGluZwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestArrayInMethodCall.approval.teal b/tests/contracts/artifacts/ABITestArrayInMethodCall.approval.teal index 9f923a4f6..1833e5cf0 100644 --- a/tests/contracts/artifacts/ABITestArrayInMethodCall.approval.teal +++ b/tests/contracts/artifacts/ABITestArrayInMethodCall.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestArrayInMethodCall.arc32.json b/tests/contracts/artifacts/ABITestArrayInMethodCall.arc32.json index 7ffd1ea2a..099491c37 100644 --- a/tests/contracts/artifacts/ABITestArrayInMethodCall.arc32.json +++ b/tests/contracts/artifacts/ABITestArrayInMethodCall.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYXJyYXlJbk1ldGhvZENhbGwoKXZvaWQKKmFiaV9yb3V0ZV9hcnJheUluTWV0aG9kQ2FsbDoKCS8vIGV4ZWN1dGUgYXJyYXlJbk1ldGhvZENhbGwoKXZvaWQKCWNhbGxzdWIgYXJyYXlJbk1ldGhvZENhbGwKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBhcnJheUluTWV0aG9kQ2FsbCgpOiB2b2lkCmFycmF5SW5NZXRob2RDYWxsOgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzOTMKCS8vIHNlbmRNZXRob2RDYWxsPFtbdWludDY0LCB1aW50NjRdLCBBZGRyZXNzLCB1aW50NjQsIGJvb2xlYW5dLCB2b2lkPih7CgkvLyAgICAgICBhcHBsaWNhdGlvbklEOiBBcHBJRC5mcm9tVWludDY0KDApLAoJLy8gICAgICAgbmFtZTogJ2ZvbycsCgkvLyAgICAgICBtZXRob2RBcmdzOiBbWzEsIDJdLCB0aGlzLnR4bi5zZW5kZXIsIDMsIGZhbHNlXSwKCS8vICAgICB9KQoJaXR4bl9iZWdpbgoJcHVzaGludCA2IC8vIGFwcGwKCWl0eG5fZmllbGQgVHlwZUVudW0KCXB1c2hieXRlcyAweDY5YTU0NThkIC8vIG1ldGhvZCAiZm9vKCh1aW50NjQsdWludDY0KSxhZGRyZXNzLHVpbnQ2NCxib29sKXZvaWQiCglpdHhuX2ZpZWxkIEFwcGxpY2F0aW9uQXJncwoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMzk0CgkvLyBhcHBsaWNhdGlvbklEOiBBcHBJRC5mcm9tVWludDY0KDApCglwdXNoaW50IDAKCWl0eG5fZmllbGQgQXBwbGljYXRpb25JRAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMzk2CgkvLyBtZXRob2RBcmdzOiBbWzEsIDJdLCB0aGlzLnR4bi5zZW5kZXIsIDMsIGZhbHNlXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMTAwMDAwMDAwMDAwMDAwMDIKCWl0eG5fZmllbGQgQXBwbGljYXRpb25BcmdzCgl0eG4gU2VuZGVyCglpdHhuX2ZpZWxkIEFwcGxpY2F0aW9uQXJncwoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMwoJaXR4bl9maWVsZCBBcHBsaWNhdGlvbkFyZ3MKCXB1c2hpbnQgMAoJcHVzaGJ5dGVzIDB4MDAKCXB1c2hpbnQgMAoJdW5jb3ZlciAyCglzZXRiaXQKCWl0eG5fZmllbGQgQXBwbGljYXRpb25BcmdzCgoJLy8gRmVlIGZpZWxkIG5vdCBzZXQsIGRlZmF1bHRpbmcgdG8gMAoJcHVzaGludCAwCglpdHhuX2ZpZWxkIEZlZQoKCS8vIFN1Ym1pdCBpbm5lciB0cmFuc2FjdGlvbgoJaXR4bl9zdWJtaXQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YmUxNWNmMTAgLy8gbWV0aG9kICJhcnJheUluTWV0aG9kQ2FsbCgpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfYXJyYXlJbk1ldGhvZENhbGwKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYXJyYXlJbk1ldGhvZENhbGwoKXZvaWQKKmFiaV9yb3V0ZV9hcnJheUluTWV0aG9kQ2FsbDoKCS8vIGV4ZWN1dGUgYXJyYXlJbk1ldGhvZENhbGwoKXZvaWQKCWNhbGxzdWIgYXJyYXlJbk1ldGhvZENhbGwKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBhcnJheUluTWV0aG9kQ2FsbCgpOiB2b2lkCmFycmF5SW5NZXRob2RDYWxsOgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzOTMKCS8vIHNlbmRNZXRob2RDYWxsPFtbdWludDY0LCB1aW50NjRdLCBBZGRyZXNzLCB1aW50NjQsIGJvb2xlYW5dLCB2b2lkPih7CgkvLyAgICAgICBhcHBsaWNhdGlvbklEOiBBcHBJRC5mcm9tVWludDY0KDApLAoJLy8gICAgICAgbmFtZTogJ2ZvbycsCgkvLyAgICAgICBtZXRob2RBcmdzOiBbWzEsIDJdLCB0aGlzLnR4bi5zZW5kZXIsIDMsIGZhbHNlXSwKCS8vICAgICB9KQoJaXR4bl9iZWdpbgoJcHVzaGludCA2IC8vIGFwcGwKCWl0eG5fZmllbGQgVHlwZUVudW0KCXB1c2hieXRlcyAweDY5YTU0NThkIC8vIG1ldGhvZCAiZm9vKCh1aW50NjQsdWludDY0KSxhZGRyZXNzLHVpbnQ2NCxib29sKXZvaWQiCglpdHhuX2ZpZWxkIEFwcGxpY2F0aW9uQXJncwoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMzk0CgkvLyBhcHBsaWNhdGlvbklEOiBBcHBJRC5mcm9tVWludDY0KDApCglwdXNoaW50IDAKCWl0eG5fZmllbGQgQXBwbGljYXRpb25JRAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMzk2CgkvLyBtZXRob2RBcmdzOiBbWzEsIDJdLCB0aGlzLnR4bi5zZW5kZXIsIDMsIGZhbHNlXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMTAwMDAwMDAwMDAwMDAwMDIKCWl0eG5fZmllbGQgQXBwbGljYXRpb25BcmdzCgl0eG4gU2VuZGVyCglpdHhuX2ZpZWxkIEFwcGxpY2F0aW9uQXJncwoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMwoJaXR4bl9maWVsZCBBcHBsaWNhdGlvbkFyZ3MKCXB1c2hpbnQgMAoJcHVzaGJ5dGVzIDB4MDAKCXB1c2hpbnQgMAoJdW5jb3ZlciAyCglzZXRiaXQKCWl0eG5fZmllbGQgQXBwbGljYXRpb25BcmdzCgoJLy8gRmVlIGZpZWxkIG5vdCBzZXQsIGRlZmF1bHRpbmcgdG8gMAoJcHVzaGludCAwCglpdHhuX2ZpZWxkIEZlZQoKCS8vIFN1Ym1pdCBpbm5lciB0cmFuc2FjdGlvbgoJaXR4bl9zdWJtaXQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YmUxNWNmMTAgLy8gbWV0aG9kICJhcnJheUluTWV0aG9kQ2FsbCgpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfYXJyYXlJbk1ldGhvZENhbGwKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestArrayInMethodCall.arc56_draft.json b/tests/contracts/artifacts/ABITestArrayInMethodCall.arc56_draft.json index ea4c3f227..f04727ad9 100644 --- a/tests/contracts/artifacts/ABITestArrayInMethodCall.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestArrayInMethodCall.arc56_draft.json @@ -499,7 +499,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYXJyYXlJbk1ldGhvZENhbGwoKXZvaWQKKmFiaV9yb3V0ZV9hcnJheUluTWV0aG9kQ2FsbDoKCS8vIGV4ZWN1dGUgYXJyYXlJbk1ldGhvZENhbGwoKXZvaWQKCWNhbGxzdWIgYXJyYXlJbk1ldGhvZENhbGwKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBhcnJheUluTWV0aG9kQ2FsbCgpOiB2b2lkCmFycmF5SW5NZXRob2RDYWxsOgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzOTMKCS8vIHNlbmRNZXRob2RDYWxsPFtbdWludDY0LCB1aW50NjRdLCBBZGRyZXNzLCB1aW50NjQsIGJvb2xlYW5dLCB2b2lkPih7CgkvLyAgICAgICBhcHBsaWNhdGlvbklEOiBBcHBJRC5mcm9tVWludDY0KDApLAoJLy8gICAgICAgbmFtZTogJ2ZvbycsCgkvLyAgICAgICBtZXRob2RBcmdzOiBbWzEsIDJdLCB0aGlzLnR4bi5zZW5kZXIsIDMsIGZhbHNlXSwKCS8vICAgICB9KQoJaXR4bl9iZWdpbgoJcHVzaGludCA2IC8vIGFwcGwKCWl0eG5fZmllbGQgVHlwZUVudW0KCXB1c2hieXRlcyAweDY5YTU0NThkIC8vIG1ldGhvZCAiZm9vKCh1aW50NjQsdWludDY0KSxhZGRyZXNzLHVpbnQ2NCxib29sKXZvaWQiCglpdHhuX2ZpZWxkIEFwcGxpY2F0aW9uQXJncwoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMzk0CgkvLyBhcHBsaWNhdGlvbklEOiBBcHBJRC5mcm9tVWludDY0KDApCglwdXNoaW50IDAKCWl0eG5fZmllbGQgQXBwbGljYXRpb25JRAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMzk2CgkvLyBtZXRob2RBcmdzOiBbWzEsIDJdLCB0aGlzLnR4bi5zZW5kZXIsIDMsIGZhbHNlXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMTAwMDAwMDAwMDAwMDAwMDIKCWl0eG5fZmllbGQgQXBwbGljYXRpb25BcmdzCgl0eG4gU2VuZGVyCglpdHhuX2ZpZWxkIEFwcGxpY2F0aW9uQXJncwoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMwoJaXR4bl9maWVsZCBBcHBsaWNhdGlvbkFyZ3MKCXB1c2hpbnQgMAoJcHVzaGJ5dGVzIDB4MDAKCXB1c2hpbnQgMAoJdW5jb3ZlciAyCglzZXRiaXQKCWl0eG5fZmllbGQgQXBwbGljYXRpb25BcmdzCgoJLy8gRmVlIGZpZWxkIG5vdCBzZXQsIGRlZmF1bHRpbmcgdG8gMAoJcHVzaGludCAwCglpdHhuX2ZpZWxkIEZlZQoKCS8vIFN1Ym1pdCBpbm5lciB0cmFuc2FjdGlvbgoJaXR4bl9zdWJtaXQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YmUxNWNmMTAgLy8gbWV0aG9kICJhcnJheUluTWV0aG9kQ2FsbCgpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfYXJyYXlJbk1ldGhvZENhbGwKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYXJyYXlJbk1ldGhvZENhbGwoKXZvaWQKKmFiaV9yb3V0ZV9hcnJheUluTWV0aG9kQ2FsbDoKCS8vIGV4ZWN1dGUgYXJyYXlJbk1ldGhvZENhbGwoKXZvaWQKCWNhbGxzdWIgYXJyYXlJbk1ldGhvZENhbGwKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBhcnJheUluTWV0aG9kQ2FsbCgpOiB2b2lkCmFycmF5SW5NZXRob2RDYWxsOgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzOTMKCS8vIHNlbmRNZXRob2RDYWxsPFtbdWludDY0LCB1aW50NjRdLCBBZGRyZXNzLCB1aW50NjQsIGJvb2xlYW5dLCB2b2lkPih7CgkvLyAgICAgICBhcHBsaWNhdGlvbklEOiBBcHBJRC5mcm9tVWludDY0KDApLAoJLy8gICAgICAgbmFtZTogJ2ZvbycsCgkvLyAgICAgICBtZXRob2RBcmdzOiBbWzEsIDJdLCB0aGlzLnR4bi5zZW5kZXIsIDMsIGZhbHNlXSwKCS8vICAgICB9KQoJaXR4bl9iZWdpbgoJcHVzaGludCA2IC8vIGFwcGwKCWl0eG5fZmllbGQgVHlwZUVudW0KCXB1c2hieXRlcyAweDY5YTU0NThkIC8vIG1ldGhvZCAiZm9vKCh1aW50NjQsdWludDY0KSxhZGRyZXNzLHVpbnQ2NCxib29sKXZvaWQiCglpdHhuX2ZpZWxkIEFwcGxpY2F0aW9uQXJncwoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMzk0CgkvLyBhcHBsaWNhdGlvbklEOiBBcHBJRC5mcm9tVWludDY0KDApCglwdXNoaW50IDAKCWl0eG5fZmllbGQgQXBwbGljYXRpb25JRAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMzk2CgkvLyBtZXRob2RBcmdzOiBbWzEsIDJdLCB0aGlzLnR4bi5zZW5kZXIsIDMsIGZhbHNlXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMTAwMDAwMDAwMDAwMDAwMDIKCWl0eG5fZmllbGQgQXBwbGljYXRpb25BcmdzCgl0eG4gU2VuZGVyCglpdHhuX2ZpZWxkIEFwcGxpY2F0aW9uQXJncwoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMwoJaXR4bl9maWVsZCBBcHBsaWNhdGlvbkFyZ3MKCXB1c2hpbnQgMAoJcHVzaGJ5dGVzIDB4MDAKCXB1c2hpbnQgMAoJdW5jb3ZlciAyCglzZXRiaXQKCWl0eG5fZmllbGQgQXBwbGljYXRpb25BcmdzCgoJLy8gRmVlIGZpZWxkIG5vdCBzZXQsIGRlZmF1bHRpbmcgdG8gMAoJcHVzaGludCAwCglpdHhuX2ZpZWxkIEZlZQoKCS8vIFN1Ym1pdCBpbm5lciB0cmFuc2FjdGlvbgoJaXR4bl9zdWJtaXQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YmUxNWNmMTAgLy8gbWV0aG9kICJhcnJheUluTWV0aG9kQ2FsbCgpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfYXJyYXlJbk1ldGhvZENhbGwKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestArrayInObjectInState.approval.teal b/tests/contracts/artifacts/ABITestArrayInObjectInState.approval.teal index 77da8a5da..063133f5d 100644 --- a/tests/contracts/artifacts/ABITestArrayInObjectInState.approval.teal +++ b/tests/contracts/artifacts/ABITestArrayInObjectInState.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestArrayInObjectInState.arc32.json b/tests/contracts/artifacts/ABITestArrayInObjectInState.arc32.json index 61cc3f067..0ae0e6c8b 100644 --- a/tests/contracts/artifacts/ABITestArrayInObjectInState.arc32.json +++ b/tests/contracts/artifacts/ABITestArrayInObjectInState.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYXJyYXlJbk9iamVjdEluU3RhdGUoKXVpbnQ2NAoqYWJpX3JvdXRlX2FycmF5SW5PYmplY3RJblN0YXRlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgYXJyYXlJbk9iamVjdEluU3RhdGUoKXVpbnQ2NAoJY2FsbHN1YiBhcnJheUluT2JqZWN0SW5TdGF0ZQoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBhcnJheUluT2JqZWN0SW5TdGF0ZSgpOiB1aW50NjQKYXJyYXlJbk9iamVjdEluU3RhdGU6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTA3OAoJLy8gdGhpcy5nTWFwKHRoaXMudHhuLnNlbmRlcikudmFsdWUgPSB7IGJhcjogWzEsIDJdIH0KCXR4biBTZW5kZXIKCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDEwMDAwMDAwMDAwMDAwMDAyCglhcHBfZ2xvYmFsX3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMDc5CgkvLyB0aGlzLmdNYXAodGhpcy50eG4uc2VuZGVyKS52YWx1ZS5iYXJbMV0gPSAzCgl0eG4gU2VuZGVyCglhcHBfZ2xvYmFsX2dldAoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMwoJcmVwbGFjZTIgOAoJdHhuIFNlbmRlcgoJc3dhcAoJYXBwX2dsb2JhbF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTA4MAoJLy8gcmV0dXJuIHRoaXMuZ01hcCh0aGlzLnR4bi5zZW5kZXIpLnZhbHVlLmJhclsxXTsKCXR4biBTZW5kZXIKCWFwcF9nbG9iYWxfZ2V0CglleHRyYWN0IDggOAoJYnRvaQoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgzNTAyOThhOCAvLyBtZXRob2QgImFycmF5SW5PYmplY3RJblN0YXRlKCl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2FycmF5SW5PYmplY3RJblN0YXRlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYXJyYXlJbk9iamVjdEluU3RhdGUoKXVpbnQ2NAoqYWJpX3JvdXRlX2FycmF5SW5PYmplY3RJblN0YXRlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgYXJyYXlJbk9iamVjdEluU3RhdGUoKXVpbnQ2NAoJY2FsbHN1YiBhcnJheUluT2JqZWN0SW5TdGF0ZQoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBhcnJheUluT2JqZWN0SW5TdGF0ZSgpOiB1aW50NjQKYXJyYXlJbk9iamVjdEluU3RhdGU6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTA3OAoJLy8gdGhpcy5nTWFwKHRoaXMudHhuLnNlbmRlcikudmFsdWUgPSB7IGJhcjogWzEsIDJdIH0KCXR4biBTZW5kZXIKCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDEwMDAwMDAwMDAwMDAwMDAyCglhcHBfZ2xvYmFsX3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMDc5CgkvLyB0aGlzLmdNYXAodGhpcy50eG4uc2VuZGVyKS52YWx1ZS5iYXJbMV0gPSAzCgl0eG4gU2VuZGVyCglhcHBfZ2xvYmFsX2dldAoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMwoJcmVwbGFjZTIgOAoJdHhuIFNlbmRlcgoJc3dhcAoJYXBwX2dsb2JhbF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTA4MAoJLy8gcmV0dXJuIHRoaXMuZ01hcCh0aGlzLnR4bi5zZW5kZXIpLnZhbHVlLmJhclsxXTsKCXR4biBTZW5kZXIKCWFwcF9nbG9iYWxfZ2V0CglleHRyYWN0IDggOAoJYnRvaQoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgzNTAyOThhOCAvLyBtZXRob2QgImFycmF5SW5PYmplY3RJblN0YXRlKCl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2FycmF5SW5PYmplY3RJblN0YXRlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestArrayInObjectInState.arc56_draft.json b/tests/contracts/artifacts/ABITestArrayInObjectInState.arc56_draft.json index 8b5712cdf..f9e9e77a8 100644 --- a/tests/contracts/artifacts/ABITestArrayInObjectInState.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestArrayInObjectInState.arc56_draft.json @@ -473,7 +473,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYXJyYXlJbk9iamVjdEluU3RhdGUoKXVpbnQ2NAoqYWJpX3JvdXRlX2FycmF5SW5PYmplY3RJblN0YXRlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgYXJyYXlJbk9iamVjdEluU3RhdGUoKXVpbnQ2NAoJY2FsbHN1YiBhcnJheUluT2JqZWN0SW5TdGF0ZQoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBhcnJheUluT2JqZWN0SW5TdGF0ZSgpOiB1aW50NjQKYXJyYXlJbk9iamVjdEluU3RhdGU6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTA3OAoJLy8gdGhpcy5nTWFwKHRoaXMudHhuLnNlbmRlcikudmFsdWUgPSB7IGJhcjogWzEsIDJdIH0KCXR4biBTZW5kZXIKCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDEwMDAwMDAwMDAwMDAwMDAyCglhcHBfZ2xvYmFsX3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMDc5CgkvLyB0aGlzLmdNYXAodGhpcy50eG4uc2VuZGVyKS52YWx1ZS5iYXJbMV0gPSAzCgl0eG4gU2VuZGVyCglhcHBfZ2xvYmFsX2dldAoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMwoJcmVwbGFjZTIgOAoJdHhuIFNlbmRlcgoJc3dhcAoJYXBwX2dsb2JhbF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTA4MAoJLy8gcmV0dXJuIHRoaXMuZ01hcCh0aGlzLnR4bi5zZW5kZXIpLnZhbHVlLmJhclsxXTsKCXR4biBTZW5kZXIKCWFwcF9nbG9iYWxfZ2V0CglleHRyYWN0IDggOAoJYnRvaQoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgzNTAyOThhOCAvLyBtZXRob2QgImFycmF5SW5PYmplY3RJblN0YXRlKCl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2FycmF5SW5PYmplY3RJblN0YXRlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYXJyYXlJbk9iamVjdEluU3RhdGUoKXVpbnQ2NAoqYWJpX3JvdXRlX2FycmF5SW5PYmplY3RJblN0YXRlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgYXJyYXlJbk9iamVjdEluU3RhdGUoKXVpbnQ2NAoJY2FsbHN1YiBhcnJheUluT2JqZWN0SW5TdGF0ZQoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBhcnJheUluT2JqZWN0SW5TdGF0ZSgpOiB1aW50NjQKYXJyYXlJbk9iamVjdEluU3RhdGU6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTA3OAoJLy8gdGhpcy5nTWFwKHRoaXMudHhuLnNlbmRlcikudmFsdWUgPSB7IGJhcjogWzEsIDJdIH0KCXR4biBTZW5kZXIKCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDEwMDAwMDAwMDAwMDAwMDAyCglhcHBfZ2xvYmFsX3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMDc5CgkvLyB0aGlzLmdNYXAodGhpcy50eG4uc2VuZGVyKS52YWx1ZS5iYXJbMV0gPSAzCgl0eG4gU2VuZGVyCglhcHBfZ2xvYmFsX2dldAoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMwoJcmVwbGFjZTIgOAoJdHhuIFNlbmRlcgoJc3dhcAoJYXBwX2dsb2JhbF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTA4MAoJLy8gcmV0dXJuIHRoaXMuZ01hcCh0aGlzLnR4bi5zZW5kZXIpLnZhbHVlLmJhclsxXTsKCXR4biBTZW5kZXIKCWFwcF9nbG9iYWxfZ2V0CglleHRyYWN0IDggOAoJYnRvaQoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgzNTAyOThhOCAvLyBtZXRob2QgImFycmF5SW5PYmplY3RJblN0YXRlKCl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2FycmF5SW5PYmplY3RJblN0YXRlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestArrayInTuple.approval.teal b/tests/contracts/artifacts/ABITestArrayInTuple.approval.teal index e9b76976d..e23d78794 100644 --- a/tests/contracts/artifacts/ABITestArrayInTuple.approval.teal +++ b/tests/contracts/artifacts/ABITestArrayInTuple.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestArrayInTuple.arc32.json b/tests/contracts/artifacts/ABITestArrayInTuple.arc32.json index c5294ee68..522d9e7b8 100644 --- a/tests/contracts/artifacts/ABITestArrayInTuple.arc32.json +++ b/tests/contracts/artifacts/ABITestArrayInTuple.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYXJyYXlJblR1cGxlKCl1aW50NjQKKmFiaV9yb3V0ZV9hcnJheUluVHVwbGU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBhcnJheUluVHVwbGUoKXVpbnQ2NAoJY2FsbHN1YiBhcnJheUluVHVwbGUKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gYXJyYXlJblR1cGxlKCk6IHVpbnQ2NAphcnJheUluVHVwbGU6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjI2NQoJLy8gYTogW3VpbnQ2NCwgdWludDE2LCBTdGF0aWNBcnJheTx1aW50NjQsIDI+LCB1aW50MTZdID0gWzExLCAyMiwgWzMzLCA0NF0sIDU1XQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwYjAwMTYwMDAwMDAwMDAwMDAwMDIxMDAwMDAwMDAwMDAwMDAyYzAwMzcKCWZyYW1lX2J1cnkgMCAvLyBhOiBbdWludDY0LCB1aW50MTYsIFN0YXRpY0FycmF5PHVpbnQ2NCwgMj4sIHVpbnQxNl0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MjY3CgkvLyByZXR1cm4gYVsyXVsxXTsKCWZyYW1lX2RpZyAwIC8vIGE6IFt1aW50NjQsIHVpbnQxNiwgU3RhdGljQXJyYXk8dWludDY0LCAyPiwgdWludDE2XQoJZXh0cmFjdCAxOCA4CglidG9pCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDY3N2Q2M2Q5IC8vIG1ldGhvZCAiYXJyYXlJblR1cGxlKCl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2FycmF5SW5UdXBsZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYXJyYXlJblR1cGxlKCl1aW50NjQKKmFiaV9yb3V0ZV9hcnJheUluVHVwbGU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBhcnJheUluVHVwbGUoKXVpbnQ2NAoJY2FsbHN1YiBhcnJheUluVHVwbGUKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gYXJyYXlJblR1cGxlKCk6IHVpbnQ2NAphcnJheUluVHVwbGU6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjI2NQoJLy8gYTogW3VpbnQ2NCwgdWludDE2LCBTdGF0aWNBcnJheTx1aW50NjQsIDI+LCB1aW50MTZdID0gWzExLCAyMiwgWzMzLCA0NF0sIDU1XQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwYjAwMTYwMDAwMDAwMDAwMDAwMDIxMDAwMDAwMDAwMDAwMDAyYzAwMzcKCWZyYW1lX2J1cnkgMCAvLyBhOiBbdWludDY0LCB1aW50MTYsIFN0YXRpY0FycmF5PHVpbnQ2NCwgMj4sIHVpbnQxNl0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MjY3CgkvLyByZXR1cm4gYVsyXVsxXTsKCWZyYW1lX2RpZyAwIC8vIGE6IFt1aW50NjQsIHVpbnQxNiwgU3RhdGljQXJyYXk8dWludDY0LCAyPiwgdWludDE2XQoJZXh0cmFjdCAxOCA4CglidG9pCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDY3N2Q2M2Q5IC8vIG1ldGhvZCAiYXJyYXlJblR1cGxlKCl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2FycmF5SW5UdXBsZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestArrayInTuple.arc56_draft.json b/tests/contracts/artifacts/ABITestArrayInTuple.arc56_draft.json index ece329858..f840c2c46 100644 --- a/tests/contracts/artifacts/ABITestArrayInTuple.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestArrayInTuple.arc56_draft.json @@ -414,7 +414,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYXJyYXlJblR1cGxlKCl1aW50NjQKKmFiaV9yb3V0ZV9hcnJheUluVHVwbGU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBhcnJheUluVHVwbGUoKXVpbnQ2NAoJY2FsbHN1YiBhcnJheUluVHVwbGUKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gYXJyYXlJblR1cGxlKCk6IHVpbnQ2NAphcnJheUluVHVwbGU6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjI2NQoJLy8gYTogW3VpbnQ2NCwgdWludDE2LCBTdGF0aWNBcnJheTx1aW50NjQsIDI+LCB1aW50MTZdID0gWzExLCAyMiwgWzMzLCA0NF0sIDU1XQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwYjAwMTYwMDAwMDAwMDAwMDAwMDIxMDAwMDAwMDAwMDAwMDAyYzAwMzcKCWZyYW1lX2J1cnkgMCAvLyBhOiBbdWludDY0LCB1aW50MTYsIFN0YXRpY0FycmF5PHVpbnQ2NCwgMj4sIHVpbnQxNl0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MjY3CgkvLyByZXR1cm4gYVsyXVsxXTsKCWZyYW1lX2RpZyAwIC8vIGE6IFt1aW50NjQsIHVpbnQxNiwgU3RhdGljQXJyYXk8dWludDY0LCAyPiwgdWludDE2XQoJZXh0cmFjdCAxOCA4CglidG9pCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDY3N2Q2M2Q5IC8vIG1ldGhvZCAiYXJyYXlJblR1cGxlKCl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2FycmF5SW5UdXBsZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYXJyYXlJblR1cGxlKCl1aW50NjQKKmFiaV9yb3V0ZV9hcnJheUluVHVwbGU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBhcnJheUluVHVwbGUoKXVpbnQ2NAoJY2FsbHN1YiBhcnJheUluVHVwbGUKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gYXJyYXlJblR1cGxlKCk6IHVpbnQ2NAphcnJheUluVHVwbGU6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjI2NQoJLy8gYTogW3VpbnQ2NCwgdWludDE2LCBTdGF0aWNBcnJheTx1aW50NjQsIDI+LCB1aW50MTZdID0gWzExLCAyMiwgWzMzLCA0NF0sIDU1XQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwYjAwMTYwMDAwMDAwMDAwMDAwMDIxMDAwMDAwMDAwMDAwMDAyYzAwMzcKCWZyYW1lX2J1cnkgMCAvLyBhOiBbdWludDY0LCB1aW50MTYsIFN0YXRpY0FycmF5PHVpbnQ2NCwgMj4sIHVpbnQxNl0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MjY3CgkvLyByZXR1cm4gYVsyXVsxXTsKCWZyYW1lX2RpZyAwIC8vIGE6IFt1aW50NjQsIHVpbnQxNiwgU3RhdGljQXJyYXk8dWludDY0LCAyPiwgdWludDE2XQoJZXh0cmFjdCAxOCA4CglidG9pCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDY3N2Q2M2Q5IC8vIG1ldGhvZCAiYXJyYXlJblR1cGxlKCl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2FycmF5SW5UdXBsZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestArrayLength.approval.teal b/tests/contracts/artifacts/ABITestArrayLength.approval.teal index df90df42f..c75676177 100644 --- a/tests/contracts/artifacts/ABITestArrayLength.approval.teal +++ b/tests/contracts/artifacts/ABITestArrayLength.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestArrayLength.arc32.json b/tests/contracts/artifacts/ABITestArrayLength.arc32.json index 8707a3d2c..f97150cb9 100644 --- a/tests/contracts/artifacts/ABITestArrayLength.arc32.json +++ b/tests/contracts/artifacts/ABITestArrayLength.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYXJyYXlMZW5ndGgoKXVpbnQ2NAoqYWJpX3JvdXRlX2FycmF5TGVuZ3RoOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgYXJyYXlMZW5ndGgoKXVpbnQ2NAoJY2FsbHN1YiBhcnJheUxlbmd0aAoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBhcnJheUxlbmd0aCgpOiB1aW50NjQKYXJyYXlMZW5ndGg6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjczNQoJLy8gYTogdWludDw4PltdID0gWzExLCAyMiwgMzMsIDQ0LCA1NV0KCXB1c2hieXRlcyAweDBiMTYyMTJjMzcKCWZyYW1lX2J1cnkgMCAvLyBhOiB1aW50PDg+W10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NzM3CgkvLyByZXR1cm4gYS5sZW5ndGg7CglmcmFtZV9kaWcgMCAvLyBhOiB1aW50PDg+W10KCWxlbgoJcHVzaGludCAxCgkvCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDlkNDUyYzc1IC8vIG1ldGhvZCAiYXJyYXlMZW5ndGgoKXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfYXJyYXlMZW5ndGgKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYXJyYXlMZW5ndGgoKXVpbnQ2NAoqYWJpX3JvdXRlX2FycmF5TGVuZ3RoOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgYXJyYXlMZW5ndGgoKXVpbnQ2NAoJY2FsbHN1YiBhcnJheUxlbmd0aAoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBhcnJheUxlbmd0aCgpOiB1aW50NjQKYXJyYXlMZW5ndGg6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjczNQoJLy8gYTogdWludDw4PltdID0gWzExLCAyMiwgMzMsIDQ0LCA1NV0KCXB1c2hieXRlcyAweDBiMTYyMTJjMzcKCWZyYW1lX2J1cnkgMCAvLyBhOiB1aW50PDg+W10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NzM3CgkvLyByZXR1cm4gYS5sZW5ndGg7CglmcmFtZV9kaWcgMCAvLyBhOiB1aW50PDg+W10KCWxlbgoJcHVzaGludCAxCgkvCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDlkNDUyYzc1IC8vIG1ldGhvZCAiYXJyYXlMZW5ndGgoKXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfYXJyYXlMZW5ndGgKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestArrayLength.arc56_draft.json b/tests/contracts/artifacts/ABITestArrayLength.arc56_draft.json index 25f82c483..0c91858f3 100644 --- a/tests/contracts/artifacts/ABITestArrayLength.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestArrayLength.arc56_draft.json @@ -397,7 +397,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYXJyYXlMZW5ndGgoKXVpbnQ2NAoqYWJpX3JvdXRlX2FycmF5TGVuZ3RoOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgYXJyYXlMZW5ndGgoKXVpbnQ2NAoJY2FsbHN1YiBhcnJheUxlbmd0aAoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBhcnJheUxlbmd0aCgpOiB1aW50NjQKYXJyYXlMZW5ndGg6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjczNQoJLy8gYTogdWludDw4PltdID0gWzExLCAyMiwgMzMsIDQ0LCA1NV0KCXB1c2hieXRlcyAweDBiMTYyMTJjMzcKCWZyYW1lX2J1cnkgMCAvLyBhOiB1aW50PDg+W10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NzM3CgkvLyByZXR1cm4gYS5sZW5ndGg7CglmcmFtZV9kaWcgMCAvLyBhOiB1aW50PDg+W10KCWxlbgoJcHVzaGludCAxCgkvCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDlkNDUyYzc1IC8vIG1ldGhvZCAiYXJyYXlMZW5ndGgoKXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfYXJyYXlMZW5ndGgKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYXJyYXlMZW5ndGgoKXVpbnQ2NAoqYWJpX3JvdXRlX2FycmF5TGVuZ3RoOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgYXJyYXlMZW5ndGgoKXVpbnQ2NAoJY2FsbHN1YiBhcnJheUxlbmd0aAoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBhcnJheUxlbmd0aCgpOiB1aW50NjQKYXJyYXlMZW5ndGg6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjczNQoJLy8gYTogdWludDw4PltdID0gWzExLCAyMiwgMzMsIDQ0LCA1NV0KCXB1c2hieXRlcyAweDBiMTYyMTJjMzcKCWZyYW1lX2J1cnkgMCAvLyBhOiB1aW50PDg+W10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NzM3CgkvLyByZXR1cm4gYS5sZW5ndGg7CglmcmFtZV9kaWcgMCAvLyBhOiB1aW50PDg+W10KCWxlbgoJcHVzaGludCAxCgkvCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDlkNDUyYzc1IC8vIG1ldGhvZCAiYXJyYXlMZW5ndGgoKXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfYXJyYXlMZW5ndGgKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestArrayPop.approval.teal b/tests/contracts/artifacts/ABITestArrayPop.approval.teal index 15cf329b2..f441f088f 100644 --- a/tests/contracts/artifacts/ABITestArrayPop.approval.teal +++ b/tests/contracts/artifacts/ABITestArrayPop.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestArrayPop.arc32.json b/tests/contracts/artifacts/ABITestArrayPop.arc32.json index 288e49856..8063ac78c 100644 --- a/tests/contracts/artifacts/ABITestArrayPop.arc32.json +++ b/tests/contracts/artifacts/ABITestArrayPop.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYXJyYXlQb3AoKXVpbnQxNltdCiphYmlfcm91dGVfYXJyYXlQb3A6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBhcnJheVBvcCgpdWludDE2W10KCWNhbGxzdWIgYXJyYXlQb3AKCWR1cAoJbGVuCglwdXNoaW50IDIKCS8KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gYXJyYXlQb3AoKTogdWludDE2W10KYXJyYXlQb3A6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQzOQoJLy8gYTogdWludDE2W10gPSBbMSwgMiwgM10KCXB1c2hieXRlcyAweDAwMDEwMDAyMDAwMwoJZnJhbWVfYnVyeSAwIC8vIGE6IHVpbnQxNltdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQ0MQoJLy8gYS5wb3AoKQoJZnJhbWVfZGlnIDAgLy8gYTogdWludDE2W10KCWR1cAoJbGVuCglwdXNoaW50IDIKCS0KCXB1c2hpbnQgMAoJc3dhcAoJZXh0cmFjdDMKCWZyYW1lX2J1cnkgMCAvLyBhOiB1aW50MTZbXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo0NDMKCS8vIHJldHVybiBhOwoJZnJhbWVfZGlnIDAgLy8gYTogdWludDE2W10KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MzBkNzcwMDYgLy8gbWV0aG9kICJhcnJheVBvcCgpdWludDE2W10iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2FycmF5UG9wCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYXJyYXlQb3AoKXVpbnQxNltdCiphYmlfcm91dGVfYXJyYXlQb3A6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBhcnJheVBvcCgpdWludDE2W10KCWNhbGxzdWIgYXJyYXlQb3AKCWR1cAoJbGVuCglwdXNoaW50IDIKCS8KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gYXJyYXlQb3AoKTogdWludDE2W10KYXJyYXlQb3A6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQzOQoJLy8gYTogdWludDE2W10gPSBbMSwgMiwgM10KCXB1c2hieXRlcyAweDAwMDEwMDAyMDAwMwoJZnJhbWVfYnVyeSAwIC8vIGE6IHVpbnQxNltdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQ0MQoJLy8gYS5wb3AoKQoJZnJhbWVfZGlnIDAgLy8gYTogdWludDE2W10KCWR1cAoJbGVuCglwdXNoaW50IDIKCS0KCXB1c2hpbnQgMAoJc3dhcAoJZXh0cmFjdDMKCWZyYW1lX2J1cnkgMCAvLyBhOiB1aW50MTZbXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo0NDMKCS8vIHJldHVybiBhOwoJZnJhbWVfZGlnIDAgLy8gYTogdWludDE2W10KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MzBkNzcwMDYgLy8gbWV0aG9kICJhcnJheVBvcCgpdWludDE2W10iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2FycmF5UG9wCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestArrayPop.arc56_draft.json b/tests/contracts/artifacts/ABITestArrayPop.arc56_draft.json index bb916be3b..1ee8568f1 100644 --- a/tests/contracts/artifacts/ABITestArrayPop.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestArrayPop.arc56_draft.json @@ -495,7 +495,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYXJyYXlQb3AoKXVpbnQxNltdCiphYmlfcm91dGVfYXJyYXlQb3A6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBhcnJheVBvcCgpdWludDE2W10KCWNhbGxzdWIgYXJyYXlQb3AKCWR1cAoJbGVuCglwdXNoaW50IDIKCS8KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gYXJyYXlQb3AoKTogdWludDE2W10KYXJyYXlQb3A6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQzOQoJLy8gYTogdWludDE2W10gPSBbMSwgMiwgM10KCXB1c2hieXRlcyAweDAwMDEwMDAyMDAwMwoJZnJhbWVfYnVyeSAwIC8vIGE6IHVpbnQxNltdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQ0MQoJLy8gYS5wb3AoKQoJZnJhbWVfZGlnIDAgLy8gYTogdWludDE2W10KCWR1cAoJbGVuCglwdXNoaW50IDIKCS0KCXB1c2hpbnQgMAoJc3dhcAoJZXh0cmFjdDMKCWZyYW1lX2J1cnkgMCAvLyBhOiB1aW50MTZbXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo0NDMKCS8vIHJldHVybiBhOwoJZnJhbWVfZGlnIDAgLy8gYTogdWludDE2W10KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MzBkNzcwMDYgLy8gbWV0aG9kICJhcnJheVBvcCgpdWludDE2W10iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2FycmF5UG9wCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYXJyYXlQb3AoKXVpbnQxNltdCiphYmlfcm91dGVfYXJyYXlQb3A6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBhcnJheVBvcCgpdWludDE2W10KCWNhbGxzdWIgYXJyYXlQb3AKCWR1cAoJbGVuCglwdXNoaW50IDIKCS8KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gYXJyYXlQb3AoKTogdWludDE2W10KYXJyYXlQb3A6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQzOQoJLy8gYTogdWludDE2W10gPSBbMSwgMiwgM10KCXB1c2hieXRlcyAweDAwMDEwMDAyMDAwMwoJZnJhbWVfYnVyeSAwIC8vIGE6IHVpbnQxNltdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQ0MQoJLy8gYS5wb3AoKQoJZnJhbWVfZGlnIDAgLy8gYTogdWludDE2W10KCWR1cAoJbGVuCglwdXNoaW50IDIKCS0KCXB1c2hpbnQgMAoJc3dhcAoJZXh0cmFjdDMKCWZyYW1lX2J1cnkgMCAvLyBhOiB1aW50MTZbXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo0NDMKCS8vIHJldHVybiBhOwoJZnJhbWVfZGlnIDAgLy8gYTogdWludDE2W10KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MzBkNzcwMDYgLy8gbWV0aG9kICJhcnJheVBvcCgpdWludDE2W10iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2FycmF5UG9wCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestArrayPopValue.approval.teal b/tests/contracts/artifacts/ABITestArrayPopValue.approval.teal index 1b0f7400c..89e70c4a5 100644 --- a/tests/contracts/artifacts/ABITestArrayPopValue.approval.teal +++ b/tests/contracts/artifacts/ABITestArrayPopValue.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestArrayPopValue.arc32.json b/tests/contracts/artifacts/ABITestArrayPopValue.arc32.json index 13eda685a..f05a1f3b4 100644 --- a/tests/contracts/artifacts/ABITestArrayPopValue.arc32.json +++ b/tests/contracts/artifacts/ABITestArrayPopValue.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBhcnJheVBvcFZhbHVlKCl1aW50MTYKKmFiaV9yb3V0ZV9hcnJheVBvcFZhbHVlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgYXJyYXlQb3BWYWx1ZSgpdWludDE2CgljYWxsc3ViIGFycmF5UG9wVmFsdWUKCWl0b2IKCWR1cAoJYml0bGVuCglwdXNoaW50IDE2Cgk8PQoKCS8vIGFycmF5UG9wVmFsdWUgcmV0dXJuIHZhbHVlIG92ZXJmbG93ZWQgMTYgYml0cwoJYXNzZXJ0CglleHRyYWN0IDYgMgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBhcnJheVBvcFZhbHVlKCk6IHVpbnQxNgphcnJheVBvcFZhbHVlOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCWJ5dGUgMHgKCWR1cAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo0NDkKCS8vIGE6IHVpbnQxNltdID0gWzEsIDIsIDNdCglwdXNoYnl0ZXMgMHgwMDAxMDAwMjAwMDMKCWZyYW1lX2J1cnkgMCAvLyBhOiB1aW50MTZbXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo0NTEKCS8vIHYgPSBhLnBvcCgpIQoJZnJhbWVfZGlnIDAgLy8gYTogdWludDE2W10KCWR1cAoJbGVuCglwdXNoaW50IDIKCS0KCXB1c2hpbnQgMAoJc3dhcAoJZXh0cmFjdDMKCWR1cAoJbGVuCglwdXNoaW50IDIKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCgljb3ZlciAyCglleHRyYWN0MwoJc3dhcAoJZnJhbWVfYnVyeSAwIC8vIGE6IHVpbnQxNltdCglidG9pCglmcmFtZV9idXJ5IDEgLy8gdjogdWludDE2CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQ1MwoJLy8gcmV0dXJuIHY7CglmcmFtZV9kaWcgMSAvLyB2OiB1aW50MTYKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCgkvLyBwb3AgYWxsIGxvY2FsIHZhcmlhYmxlcyBmcm9tIHRoZSBzdGFjawoJcG9wbiAxCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDE4MGQzZmI0IC8vIG1ldGhvZCAiYXJyYXlQb3BWYWx1ZSgpdWludDE2IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9hcnJheVBvcFZhbHVlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBhcnJheVBvcFZhbHVlKCl1aW50MTYKKmFiaV9yb3V0ZV9hcnJheVBvcFZhbHVlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgYXJyYXlQb3BWYWx1ZSgpdWludDE2CgljYWxsc3ViIGFycmF5UG9wVmFsdWUKCWl0b2IKCWR1cAoJYml0bGVuCglwdXNoaW50IDE2Cgk8PQoKCS8vIGFycmF5UG9wVmFsdWUgcmV0dXJuIHZhbHVlIG92ZXJmbG93ZWQgMTYgYml0cwoJYXNzZXJ0CglleHRyYWN0IDYgMgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBhcnJheVBvcFZhbHVlKCk6IHVpbnQxNgphcnJheVBvcFZhbHVlOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCWJ5dGUgMHgKCWR1cAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo0NDkKCS8vIGE6IHVpbnQxNltdID0gWzEsIDIsIDNdCglwdXNoYnl0ZXMgMHgwMDAxMDAwMjAwMDMKCWZyYW1lX2J1cnkgMCAvLyBhOiB1aW50MTZbXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo0NTEKCS8vIHYgPSBhLnBvcCgpIQoJZnJhbWVfZGlnIDAgLy8gYTogdWludDE2W10KCWR1cAoJbGVuCglwdXNoaW50IDIKCS0KCXB1c2hpbnQgMAoJc3dhcAoJZXh0cmFjdDMKCWR1cAoJbGVuCglwdXNoaW50IDIKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCgljb3ZlciAyCglleHRyYWN0MwoJc3dhcAoJZnJhbWVfYnVyeSAwIC8vIGE6IHVpbnQxNltdCglidG9pCglmcmFtZV9idXJ5IDEgLy8gdjogdWludDE2CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQ1MwoJLy8gcmV0dXJuIHY7CglmcmFtZV9kaWcgMSAvLyB2OiB1aW50MTYKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCgkvLyBwb3AgYWxsIGxvY2FsIHZhcmlhYmxlcyBmcm9tIHRoZSBzdGFjawoJcG9wbiAxCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDE4MGQzZmI0IC8vIG1ldGhvZCAiYXJyYXlQb3BWYWx1ZSgpdWludDE2IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9hcnJheVBvcFZhbHVlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestArrayPopValue.arc56_draft.json b/tests/contracts/artifacts/ABITestArrayPopValue.arc56_draft.json index 994a2066f..af82d36fc 100644 --- a/tests/contracts/artifacts/ABITestArrayPopValue.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestArrayPopValue.arc56_draft.json @@ -580,7 +580,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBhcnJheVBvcFZhbHVlKCl1aW50MTYKKmFiaV9yb3V0ZV9hcnJheVBvcFZhbHVlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgYXJyYXlQb3BWYWx1ZSgpdWludDE2CgljYWxsc3ViIGFycmF5UG9wVmFsdWUKCWl0b2IKCWR1cAoJYml0bGVuCglwdXNoaW50IDE2Cgk8PQoKCS8vIGFycmF5UG9wVmFsdWUgcmV0dXJuIHZhbHVlIG92ZXJmbG93ZWQgMTYgYml0cwoJYXNzZXJ0CglleHRyYWN0IDYgMgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBhcnJheVBvcFZhbHVlKCk6IHVpbnQxNgphcnJheVBvcFZhbHVlOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCWJ5dGUgMHgKCWR1cAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo0NDkKCS8vIGE6IHVpbnQxNltdID0gWzEsIDIsIDNdCglwdXNoYnl0ZXMgMHgwMDAxMDAwMjAwMDMKCWZyYW1lX2J1cnkgMCAvLyBhOiB1aW50MTZbXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo0NTEKCS8vIHYgPSBhLnBvcCgpIQoJZnJhbWVfZGlnIDAgLy8gYTogdWludDE2W10KCWR1cAoJbGVuCglwdXNoaW50IDIKCS0KCXB1c2hpbnQgMAoJc3dhcAoJZXh0cmFjdDMKCWR1cAoJbGVuCglwdXNoaW50IDIKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCgljb3ZlciAyCglleHRyYWN0MwoJc3dhcAoJZnJhbWVfYnVyeSAwIC8vIGE6IHVpbnQxNltdCglidG9pCglmcmFtZV9idXJ5IDEgLy8gdjogdWludDE2CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQ1MwoJLy8gcmV0dXJuIHY7CglmcmFtZV9kaWcgMSAvLyB2OiB1aW50MTYKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCgkvLyBwb3AgYWxsIGxvY2FsIHZhcmlhYmxlcyBmcm9tIHRoZSBzdGFjawoJcG9wbiAxCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDE4MGQzZmI0IC8vIG1ldGhvZCAiYXJyYXlQb3BWYWx1ZSgpdWludDE2IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9hcnJheVBvcFZhbHVlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBhcnJheVBvcFZhbHVlKCl1aW50MTYKKmFiaV9yb3V0ZV9hcnJheVBvcFZhbHVlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgYXJyYXlQb3BWYWx1ZSgpdWludDE2CgljYWxsc3ViIGFycmF5UG9wVmFsdWUKCWl0b2IKCWR1cAoJYml0bGVuCglwdXNoaW50IDE2Cgk8PQoKCS8vIGFycmF5UG9wVmFsdWUgcmV0dXJuIHZhbHVlIG92ZXJmbG93ZWQgMTYgYml0cwoJYXNzZXJ0CglleHRyYWN0IDYgMgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBhcnJheVBvcFZhbHVlKCk6IHVpbnQxNgphcnJheVBvcFZhbHVlOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCWJ5dGUgMHgKCWR1cAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo0NDkKCS8vIGE6IHVpbnQxNltdID0gWzEsIDIsIDNdCglwdXNoYnl0ZXMgMHgwMDAxMDAwMjAwMDMKCWZyYW1lX2J1cnkgMCAvLyBhOiB1aW50MTZbXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo0NTEKCS8vIHYgPSBhLnBvcCgpIQoJZnJhbWVfZGlnIDAgLy8gYTogdWludDE2W10KCWR1cAoJbGVuCglwdXNoaW50IDIKCS0KCXB1c2hpbnQgMAoJc3dhcAoJZXh0cmFjdDMKCWR1cAoJbGVuCglwdXNoaW50IDIKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCgljb3ZlciAyCglleHRyYWN0MwoJc3dhcAoJZnJhbWVfYnVyeSAwIC8vIGE6IHVpbnQxNltdCglidG9pCglmcmFtZV9idXJ5IDEgLy8gdjogdWludDE2CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQ1MwoJLy8gcmV0dXJuIHY7CglmcmFtZV9kaWcgMSAvLyB2OiB1aW50MTYKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCgkvLyBwb3AgYWxsIGxvY2FsIHZhcmlhYmxlcyBmcm9tIHRoZSBzdGFjawoJcG9wbiAxCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDE4MGQzZmI0IC8vIG1ldGhvZCAiYXJyYXlQb3BWYWx1ZSgpdWludDE2IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9hcnJheVBvcFZhbHVlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestArrayPush.approval.teal b/tests/contracts/artifacts/ABITestArrayPush.approval.teal index 0626a6455..5e0502c95 100644 --- a/tests/contracts/artifacts/ABITestArrayPush.approval.teal +++ b/tests/contracts/artifacts/ABITestArrayPush.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestArrayPush.arc32.json b/tests/contracts/artifacts/ABITestArrayPush.arc32.json index c3c8c6e27..5a6a9daab 100644 --- a/tests/contracts/artifacts/ABITestArrayPush.arc32.json +++ b/tests/contracts/artifacts/ABITestArrayPush.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYXJyYXlQdXNoKCl1aW50MTZbXQoqYWJpX3JvdXRlX2FycmF5UHVzaDoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGFycmF5UHVzaCgpdWludDE2W10KCWNhbGxzdWIgYXJyYXlQdXNoCglkdXAKCWxlbgoJcHVzaGludCAyCgkvCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGFycmF5UHVzaCgpOiB1aW50MTZbXQphcnJheVB1c2g6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQyOQoJLy8gYTogdWludDE2W10gPSBbMSwgMl0KCXB1c2hieXRlcyAweDAwMDEwMDAyCglmcmFtZV9idXJ5IDAgLy8gYTogdWludDE2W10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NDMxCgkvLyBhLnB1c2goMyBhcyB1aW50MTYpCglmcmFtZV9kaWcgMCAvLyBhOiB1aW50MTZbXQoJcHVzaGJ5dGVzIDB4MDAwMwoJY29uY2F0CglmcmFtZV9idXJ5IDAgLy8gYTogdWludDE2W10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NDMzCgkvLyByZXR1cm4gYTsKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGY2YzUwZWJkIC8vIG1ldGhvZCAiYXJyYXlQdXNoKCl1aW50MTZbXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfYXJyYXlQdXNoCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYXJyYXlQdXNoKCl1aW50MTZbXQoqYWJpX3JvdXRlX2FycmF5UHVzaDoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGFycmF5UHVzaCgpdWludDE2W10KCWNhbGxzdWIgYXJyYXlQdXNoCglkdXAKCWxlbgoJcHVzaGludCAyCgkvCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGFycmF5UHVzaCgpOiB1aW50MTZbXQphcnJheVB1c2g6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQyOQoJLy8gYTogdWludDE2W10gPSBbMSwgMl0KCXB1c2hieXRlcyAweDAwMDEwMDAyCglmcmFtZV9idXJ5IDAgLy8gYTogdWludDE2W10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NDMxCgkvLyBhLnB1c2goMyBhcyB1aW50MTYpCglmcmFtZV9kaWcgMCAvLyBhOiB1aW50MTZbXQoJcHVzaGJ5dGVzIDB4MDAwMwoJY29uY2F0CglmcmFtZV9idXJ5IDAgLy8gYTogdWludDE2W10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NDMzCgkvLyByZXR1cm4gYTsKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGY2YzUwZWJkIC8vIG1ldGhvZCAiYXJyYXlQdXNoKCl1aW50MTZbXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfYXJyYXlQdXNoCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestArrayPush.arc56_draft.json b/tests/contracts/artifacts/ABITestArrayPush.arc56_draft.json index cd3250694..1e47fd274 100644 --- a/tests/contracts/artifacts/ABITestArrayPush.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestArrayPush.arc56_draft.json @@ -459,7 +459,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYXJyYXlQdXNoKCl1aW50MTZbXQoqYWJpX3JvdXRlX2FycmF5UHVzaDoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGFycmF5UHVzaCgpdWludDE2W10KCWNhbGxzdWIgYXJyYXlQdXNoCglkdXAKCWxlbgoJcHVzaGludCAyCgkvCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGFycmF5UHVzaCgpOiB1aW50MTZbXQphcnJheVB1c2g6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQyOQoJLy8gYTogdWludDE2W10gPSBbMSwgMl0KCXB1c2hieXRlcyAweDAwMDEwMDAyCglmcmFtZV9idXJ5IDAgLy8gYTogdWludDE2W10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NDMxCgkvLyBhLnB1c2goMyBhcyB1aW50MTYpCglmcmFtZV9kaWcgMCAvLyBhOiB1aW50MTZbXQoJcHVzaGJ5dGVzIDB4MDAwMwoJY29uY2F0CglmcmFtZV9idXJ5IDAgLy8gYTogdWludDE2W10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NDMzCgkvLyByZXR1cm4gYTsKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGY2YzUwZWJkIC8vIG1ldGhvZCAiYXJyYXlQdXNoKCl1aW50MTZbXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfYXJyYXlQdXNoCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYXJyYXlQdXNoKCl1aW50MTZbXQoqYWJpX3JvdXRlX2FycmF5UHVzaDoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGFycmF5UHVzaCgpdWludDE2W10KCWNhbGxzdWIgYXJyYXlQdXNoCglkdXAKCWxlbgoJcHVzaGludCAyCgkvCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGFycmF5UHVzaCgpOiB1aW50MTZbXQphcnJheVB1c2g6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQyOQoJLy8gYTogdWludDE2W10gPSBbMSwgMl0KCXB1c2hieXRlcyAweDAwMDEwMDAyCglmcmFtZV9idXJ5IDAgLy8gYTogdWludDE2W10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NDMxCgkvLyBhLnB1c2goMyBhcyB1aW50MTYpCglmcmFtZV9kaWcgMCAvLyBhOiB1aW50MTZbXQoJcHVzaGJ5dGVzIDB4MDAwMwoJY29uY2F0CglmcmFtZV9idXJ5IDAgLy8gYTogdWludDE2W10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NDMzCgkvLyByZXR1cm4gYTsKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGY2YzUwZWJkIC8vIG1ldGhvZCAiYXJyYXlQdXNoKCl1aW50MTZbXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfYXJyYXlQdXNoCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestArrayRef.approval.teal b/tests/contracts/artifacts/ABITestArrayRef.approval.teal index 656f6027b..720cb5d16 100644 --- a/tests/contracts/artifacts/ABITestArrayRef.approval.teal +++ b/tests/contracts/artifacts/ABITestArrayRef.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestArrayRef.arc32.json b/tests/contracts/artifacts/ABITestArrayRef.arc32.json index 5f1560a74..eef8db4ed 100644 --- a/tests/contracts/artifacts/ABITestArrayRef.arc32.json +++ b/tests/contracts/artifacts/ABITestArrayRef.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYXJyYXlSZWYoKXVpbnQ4W10KKmFiaV9yb3V0ZV9hcnJheVJlZjoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGFycmF5UmVmKCl1aW50OFtdCgljYWxsc3ViIGFycmF5UmVmCglkdXAKCWxlbgoJaXRvYgoJZXh0cmFjdCA2IDIKCXN3YXAKCWNvbmNhdAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBhcnJheVJlZigpOiB1aW50PDg+W10KYXJyYXlSZWY6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjc1MAoJLy8gYTogdWludDw4PltdID0gWzEsIDIsIDNdCglwdXNoYnl0ZXMgMHgwMTAyMDMKCWZyYW1lX2J1cnkgMCAvLyBhOiB1aW50PDg+W10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NzUzCgkvLyBiWzFdID0gNCBhcyB1aW50PDg+CglmcmFtZV9kaWcgMCAvLyBhOiB1aW50PDg+W10KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoYnl0ZXMgMHgwNAoJcmVwbGFjZTIgMQoJZnJhbWVfYnVyeSAwIC8vIGI6IHVpbnQ8OD5bXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo3NTUKCS8vIHJldHVybiBhOwoJZnJhbWVfZGlnIDAgLy8gYTogdWludDw4PltdCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDAzZTExMzJkIC8vIG1ldGhvZCAiYXJyYXlSZWYoKXVpbnQ4W10iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2FycmF5UmVmCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYXJyYXlSZWYoKXVpbnQ4W10KKmFiaV9yb3V0ZV9hcnJheVJlZjoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGFycmF5UmVmKCl1aW50OFtdCgljYWxsc3ViIGFycmF5UmVmCglkdXAKCWxlbgoJaXRvYgoJZXh0cmFjdCA2IDIKCXN3YXAKCWNvbmNhdAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBhcnJheVJlZigpOiB1aW50PDg+W10KYXJyYXlSZWY6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjc1MAoJLy8gYTogdWludDw4PltdID0gWzEsIDIsIDNdCglwdXNoYnl0ZXMgMHgwMTAyMDMKCWZyYW1lX2J1cnkgMCAvLyBhOiB1aW50PDg+W10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NzUzCgkvLyBiWzFdID0gNCBhcyB1aW50PDg+CglmcmFtZV9kaWcgMCAvLyBhOiB1aW50PDg+W10KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoYnl0ZXMgMHgwNAoJcmVwbGFjZTIgMQoJZnJhbWVfYnVyeSAwIC8vIGI6IHVpbnQ8OD5bXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo3NTUKCS8vIHJldHVybiBhOwoJZnJhbWVfZGlnIDAgLy8gYTogdWludDw4PltdCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDAzZTExMzJkIC8vIG1ldGhvZCAiYXJyYXlSZWYoKXVpbnQ4W10iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2FycmF5UmVmCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestArrayRef.arc56_draft.json b/tests/contracts/artifacts/ABITestArrayRef.arc56_draft.json index b62194498..66047c0be 100644 --- a/tests/contracts/artifacts/ABITestArrayRef.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestArrayRef.arc56_draft.json @@ -459,7 +459,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYXJyYXlSZWYoKXVpbnQ4W10KKmFiaV9yb3V0ZV9hcnJheVJlZjoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGFycmF5UmVmKCl1aW50OFtdCgljYWxsc3ViIGFycmF5UmVmCglkdXAKCWxlbgoJaXRvYgoJZXh0cmFjdCA2IDIKCXN3YXAKCWNvbmNhdAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBhcnJheVJlZigpOiB1aW50PDg+W10KYXJyYXlSZWY6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjc1MAoJLy8gYTogdWludDw4PltdID0gWzEsIDIsIDNdCglwdXNoYnl0ZXMgMHgwMTAyMDMKCWZyYW1lX2J1cnkgMCAvLyBhOiB1aW50PDg+W10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NzUzCgkvLyBiWzFdID0gNCBhcyB1aW50PDg+CglmcmFtZV9kaWcgMCAvLyBhOiB1aW50PDg+W10KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoYnl0ZXMgMHgwNAoJcmVwbGFjZTIgMQoJZnJhbWVfYnVyeSAwIC8vIGI6IHVpbnQ8OD5bXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo3NTUKCS8vIHJldHVybiBhOwoJZnJhbWVfZGlnIDAgLy8gYTogdWludDw4PltdCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDAzZTExMzJkIC8vIG1ldGhvZCAiYXJyYXlSZWYoKXVpbnQ4W10iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2FycmF5UmVmCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYXJyYXlSZWYoKXVpbnQ4W10KKmFiaV9yb3V0ZV9hcnJheVJlZjoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGFycmF5UmVmKCl1aW50OFtdCgljYWxsc3ViIGFycmF5UmVmCglkdXAKCWxlbgoJaXRvYgoJZXh0cmFjdCA2IDIKCXN3YXAKCWNvbmNhdAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBhcnJheVJlZigpOiB1aW50PDg+W10KYXJyYXlSZWY6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjc1MAoJLy8gYTogdWludDw4PltdID0gWzEsIDIsIDNdCglwdXNoYnl0ZXMgMHgwMTAyMDMKCWZyYW1lX2J1cnkgMCAvLyBhOiB1aW50PDg+W10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NzUzCgkvLyBiWzFdID0gNCBhcyB1aW50PDg+CglmcmFtZV9kaWcgMCAvLyBhOiB1aW50PDg+W10KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoYnl0ZXMgMHgwNAoJcmVwbGFjZTIgMQoJZnJhbWVfYnVyeSAwIC8vIGI6IHVpbnQ8OD5bXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo3NTUKCS8vIHJldHVybiBhOwoJZnJhbWVfZGlnIDAgLy8gYTogdWludDw4PltdCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDAzZTExMzJkIC8vIG1ldGhvZCAiYXJyYXlSZWYoKXVpbnQ4W10iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2FycmF5UmVmCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestArraySplice.approval.teal b/tests/contracts/artifacts/ABITestArraySplice.approval.teal index 87832bbca..ac15b800b 100644 --- a/tests/contracts/artifacts/ABITestArraySplice.approval.teal +++ b/tests/contracts/artifacts/ABITestArraySplice.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestArraySplice.arc32.json b/tests/contracts/artifacts/ABITestArraySplice.arc32.json index 122c9ad2f..522fafcf1 100644 --- a/tests/contracts/artifacts/ABITestArraySplice.arc32.json +++ b/tests/contracts/artifacts/ABITestArraySplice.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYXJyYXlTcGxpY2UoKXVpbnQ2NFtdCiphYmlfcm91dGVfYXJyYXlTcGxpY2U6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBhcnJheVNwbGljZSgpdWludDY0W10KCWNhbGxzdWIgYXJyYXlTcGxpY2UKCWR1cAoJbGVuCglwdXNoaW50IDgKCS8KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gYXJyYXlTcGxpY2UoKTogdWludDY0W10KYXJyYXlTcGxpY2U6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQ1OQoJLy8gYTogdWludDY0W10gPSBbMSwgMiwgM10KCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDEwMDAwMDAwMDAwMDAwMDAyMDAwMDAwMDAwMDAwMDAwMwoJZnJhbWVfYnVyeSAwIC8vIGE6IHVpbnQ2NFtdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQ2MQoJLy8gYS5zcGxpY2UoMSwgMSkKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQ2NFtdCglwdXNoaW50IDEKCXB1c2hpbnQgOAoJc3RvcmUgMjQ3IC8vIHNwbGljZSBzdGFydAoJcHVzaGludCAxNgoJc3RvcmUgMjQ2IC8vIHNwbGljZSBieXRlIGxlbmd0aAoJZnJhbWVfZGlnIDAgLy8gYTogdWludDY0W10KCXB1c2hpbnQgMAoJbG9hZCAyNDcgLy8gc3BsaWNlIHN0YXJ0CglzdWJzdHJpbmczCglmcmFtZV9kaWcgMCAvLyBhOiB1aW50NjRbXQoJZHVwCglsZW4KCWxvYWQgMjQ3IC8vIHNwbGljZSBzdGFydAoJbG9hZCAyNDYgLy8gc3BsaWNlIGJ5dGUgbGVuZ3RoCgkrCglwdXNoaW50IDgKCS0KCXN3YXAKCXN1YnN0cmluZzMKCWNvbmNhdAoJZnJhbWVfYnVyeSAwIC8vIGE6IHVpbnQ2NFtdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQ2MwoJLy8gcmV0dXJuIGE7CglmcmFtZV9kaWcgMCAvLyBhOiB1aW50NjRbXQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg5NDYzYTRhYyAvLyBtZXRob2QgImFycmF5U3BsaWNlKCl1aW50NjRbXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfYXJyYXlTcGxpY2UKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYXJyYXlTcGxpY2UoKXVpbnQ2NFtdCiphYmlfcm91dGVfYXJyYXlTcGxpY2U6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBhcnJheVNwbGljZSgpdWludDY0W10KCWNhbGxzdWIgYXJyYXlTcGxpY2UKCWR1cAoJbGVuCglwdXNoaW50IDgKCS8KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gYXJyYXlTcGxpY2UoKTogdWludDY0W10KYXJyYXlTcGxpY2U6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQ1OQoJLy8gYTogdWludDY0W10gPSBbMSwgMiwgM10KCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDEwMDAwMDAwMDAwMDAwMDAyMDAwMDAwMDAwMDAwMDAwMwoJZnJhbWVfYnVyeSAwIC8vIGE6IHVpbnQ2NFtdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQ2MQoJLy8gYS5zcGxpY2UoMSwgMSkKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQ2NFtdCglwdXNoaW50IDEKCXB1c2hpbnQgOAoJc3RvcmUgMjQ3IC8vIHNwbGljZSBzdGFydAoJcHVzaGludCAxNgoJc3RvcmUgMjQ2IC8vIHNwbGljZSBieXRlIGxlbmd0aAoJZnJhbWVfZGlnIDAgLy8gYTogdWludDY0W10KCXB1c2hpbnQgMAoJbG9hZCAyNDcgLy8gc3BsaWNlIHN0YXJ0CglzdWJzdHJpbmczCglmcmFtZV9kaWcgMCAvLyBhOiB1aW50NjRbXQoJZHVwCglsZW4KCWxvYWQgMjQ3IC8vIHNwbGljZSBzdGFydAoJbG9hZCAyNDYgLy8gc3BsaWNlIGJ5dGUgbGVuZ3RoCgkrCglwdXNoaW50IDgKCS0KCXN3YXAKCXN1YnN0cmluZzMKCWNvbmNhdAoJZnJhbWVfYnVyeSAwIC8vIGE6IHVpbnQ2NFtdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQ2MwoJLy8gcmV0dXJuIGE7CglmcmFtZV9kaWcgMCAvLyBhOiB1aW50NjRbXQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg5NDYzYTRhYyAvLyBtZXRob2QgImFycmF5U3BsaWNlKCl1aW50NjRbXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfYXJyYXlTcGxpY2UKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestArraySplice.arc56_draft.json b/tests/contracts/artifacts/ABITestArraySplice.arc56_draft.json index 4d4196b53..1e0fe27b9 100644 --- a/tests/contracts/artifacts/ABITestArraySplice.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestArraySplice.arc56_draft.json @@ -614,7 +614,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYXJyYXlTcGxpY2UoKXVpbnQ2NFtdCiphYmlfcm91dGVfYXJyYXlTcGxpY2U6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBhcnJheVNwbGljZSgpdWludDY0W10KCWNhbGxzdWIgYXJyYXlTcGxpY2UKCWR1cAoJbGVuCglwdXNoaW50IDgKCS8KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gYXJyYXlTcGxpY2UoKTogdWludDY0W10KYXJyYXlTcGxpY2U6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQ1OQoJLy8gYTogdWludDY0W10gPSBbMSwgMiwgM10KCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDEwMDAwMDAwMDAwMDAwMDAyMDAwMDAwMDAwMDAwMDAwMwoJZnJhbWVfYnVyeSAwIC8vIGE6IHVpbnQ2NFtdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQ2MQoJLy8gYS5zcGxpY2UoMSwgMSkKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQ2NFtdCglwdXNoaW50IDEKCXB1c2hpbnQgOAoJc3RvcmUgMjQ3IC8vIHNwbGljZSBzdGFydAoJcHVzaGludCAxNgoJc3RvcmUgMjQ2IC8vIHNwbGljZSBieXRlIGxlbmd0aAoJZnJhbWVfZGlnIDAgLy8gYTogdWludDY0W10KCXB1c2hpbnQgMAoJbG9hZCAyNDcgLy8gc3BsaWNlIHN0YXJ0CglzdWJzdHJpbmczCglmcmFtZV9kaWcgMCAvLyBhOiB1aW50NjRbXQoJZHVwCglsZW4KCWxvYWQgMjQ3IC8vIHNwbGljZSBzdGFydAoJbG9hZCAyNDYgLy8gc3BsaWNlIGJ5dGUgbGVuZ3RoCgkrCglwdXNoaW50IDgKCS0KCXN3YXAKCXN1YnN0cmluZzMKCWNvbmNhdAoJZnJhbWVfYnVyeSAwIC8vIGE6IHVpbnQ2NFtdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQ2MwoJLy8gcmV0dXJuIGE7CglmcmFtZV9kaWcgMCAvLyBhOiB1aW50NjRbXQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg5NDYzYTRhYyAvLyBtZXRob2QgImFycmF5U3BsaWNlKCl1aW50NjRbXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfYXJyYXlTcGxpY2UKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYXJyYXlTcGxpY2UoKXVpbnQ2NFtdCiphYmlfcm91dGVfYXJyYXlTcGxpY2U6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBhcnJheVNwbGljZSgpdWludDY0W10KCWNhbGxzdWIgYXJyYXlTcGxpY2UKCWR1cAoJbGVuCglwdXNoaW50IDgKCS8KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gYXJyYXlTcGxpY2UoKTogdWludDY0W10KYXJyYXlTcGxpY2U6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQ1OQoJLy8gYTogdWludDY0W10gPSBbMSwgMiwgM10KCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDEwMDAwMDAwMDAwMDAwMDAyMDAwMDAwMDAwMDAwMDAwMwoJZnJhbWVfYnVyeSAwIC8vIGE6IHVpbnQ2NFtdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQ2MQoJLy8gYS5zcGxpY2UoMSwgMSkKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQ2NFtdCglwdXNoaW50IDEKCXB1c2hpbnQgOAoJc3RvcmUgMjQ3IC8vIHNwbGljZSBzdGFydAoJcHVzaGludCAxNgoJc3RvcmUgMjQ2IC8vIHNwbGljZSBieXRlIGxlbmd0aAoJZnJhbWVfZGlnIDAgLy8gYTogdWludDY0W10KCXB1c2hpbnQgMAoJbG9hZCAyNDcgLy8gc3BsaWNlIHN0YXJ0CglzdWJzdHJpbmczCglmcmFtZV9kaWcgMCAvLyBhOiB1aW50NjRbXQoJZHVwCglsZW4KCWxvYWQgMjQ3IC8vIHNwbGljZSBzdGFydAoJbG9hZCAyNDYgLy8gc3BsaWNlIGJ5dGUgbGVuZ3RoCgkrCglwdXNoaW50IDgKCS0KCXN3YXAKCXN1YnN0cmluZzMKCWNvbmNhdAoJZnJhbWVfYnVyeSAwIC8vIGE6IHVpbnQ2NFtdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQ2MwoJLy8gcmV0dXJuIGE7CglmcmFtZV9kaWcgMCAvLyBhOiB1aW50NjRbXQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg5NDYzYTRhYyAvLyBtZXRob2QgImFycmF5U3BsaWNlKCl1aW50NjRbXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfYXJyYXlTcGxpY2UKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestArraySpliceValue.approval.teal b/tests/contracts/artifacts/ABITestArraySpliceValue.approval.teal index 80b21aa51..998c3d783 100644 --- a/tests/contracts/artifacts/ABITestArraySpliceValue.approval.teal +++ b/tests/contracts/artifacts/ABITestArraySpliceValue.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestArraySpliceValue.arc32.json b/tests/contracts/artifacts/ABITestArraySpliceValue.arc32.json index 409a57a4c..35dae5fa1 100644 --- a/tests/contracts/artifacts/ABITestArraySpliceValue.arc32.json +++ b/tests/contracts/artifacts/ABITestArraySpliceValue.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBhcnJheVNwbGljZVZhbHVlKCl1aW50MTZbXQoqYWJpX3JvdXRlX2FycmF5U3BsaWNlVmFsdWU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBhcnJheVNwbGljZVZhbHVlKCl1aW50MTZbXQoJY2FsbHN1YiBhcnJheVNwbGljZVZhbHVlCglkdXAKCWxlbgoJcHVzaGludCAyCgkvCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGFycmF5U3BsaWNlVmFsdWUoKTogdWludDE2W10KYXJyYXlTcGxpY2VWYWx1ZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXBuIDMKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NDY5CgkvLyBhOiB1aW50MTZbXSA9IFsxLCAyLCAzLCA0LCA1LCA2LCA3LCA4LCA5LCAxMF0KCXB1c2hieXRlcyAweDAwMDEwMDAyMDAwMzAwMDQwMDA1MDAwNjAwMDcwMDA4MDAwOTAwMGEKCWZyYW1lX2J1cnkgMCAvLyBhOiB1aW50MTZbXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo0NzEKCS8vIGkgPSBidG9pKGl0b2IoMSkpCglwdXNoaW50IDEKCWZyYW1lX2J1cnkgMSAvLyBpOiB1aW50NjQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NDcyCgkvLyBsID0gYnRvaShpdG9iKDcpKQoJcHVzaGludCA3CglmcmFtZV9idXJ5IDIgLy8gbDogdWludDY0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQ3MwoJLy8gdiA9IGEuc3BsaWNlKGksIGwpCglmcmFtZV9kaWcgMCAvLyBhOiB1aW50MTZbXQoJcHVzaGludCA3IC8vIGw6IHVpbnQ2NAoJcHVzaGludCAyCglzdG9yZSAyNDcgLy8gc3BsaWNlIHN0YXJ0CglwdXNoaW50IDE2CglzdG9yZSAyNDYgLy8gc3BsaWNlIGJ5dGUgbGVuZ3RoCglmcmFtZV9kaWcgMCAvLyBhOiB1aW50MTZbXQoJcHVzaGludCAwCglsb2FkIDI0NyAvLyBzcGxpY2Ugc3RhcnQKCXN1YnN0cmluZzMKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCglkdXAKCWxlbgoJbG9hZCAyNDcgLy8gc3BsaWNlIHN0YXJ0Cglsb2FkIDI0NiAvLyBzcGxpY2UgYnl0ZSBsZW5ndGgKCSsKCXB1c2hpbnQgMgoJLQoJc3dhcAoJc3Vic3RyaW5nMwoJY29uY2F0CglmcmFtZV9kaWcgMCAvLyBhOiB1aW50MTZbXQoJbG9hZCAyNDcgLy8gc3BsaWNlIHN0YXJ0Cglsb2FkIDI0NiAvLyBzcGxpY2UgYnl0ZSBsZW5ndGgKCXB1c2hpbnQgMgoJLQoJZXh0cmFjdDMKCXN3YXAKCWZyYW1lX2J1cnkgMCAvLyBhOiB1aW50MTZbXQoJZnJhbWVfYnVyeSAzIC8vIHY6IHVpbnQxNltdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQ3NQoJLy8gcmV0dXJuIHY7CglmcmFtZV9kaWcgMyAvLyB2OiB1aW50MTZbXQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoKCS8vIHBvcCBhbGwgbG9jYWwgdmFyaWFibGVzIGZyb20gdGhlIHN0YWNrCglwb3BuIDMKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4NzI5NTY3YmMgLy8gbWV0aG9kICJhcnJheVNwbGljZVZhbHVlKCl1aW50MTZbXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfYXJyYXlTcGxpY2VWYWx1ZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBhcnJheVNwbGljZVZhbHVlKCl1aW50MTZbXQoqYWJpX3JvdXRlX2FycmF5U3BsaWNlVmFsdWU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBhcnJheVNwbGljZVZhbHVlKCl1aW50MTZbXQoJY2FsbHN1YiBhcnJheVNwbGljZVZhbHVlCglkdXAKCWxlbgoJcHVzaGludCAyCgkvCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGFycmF5U3BsaWNlVmFsdWUoKTogdWludDE2W10KYXJyYXlTcGxpY2VWYWx1ZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXBuIDMKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NDY5CgkvLyBhOiB1aW50MTZbXSA9IFsxLCAyLCAzLCA0LCA1LCA2LCA3LCA4LCA5LCAxMF0KCXB1c2hieXRlcyAweDAwMDEwMDAyMDAwMzAwMDQwMDA1MDAwNjAwMDcwMDA4MDAwOTAwMGEKCWZyYW1lX2J1cnkgMCAvLyBhOiB1aW50MTZbXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo0NzEKCS8vIGkgPSBidG9pKGl0b2IoMSkpCglwdXNoaW50IDEKCWZyYW1lX2J1cnkgMSAvLyBpOiB1aW50NjQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NDcyCgkvLyBsID0gYnRvaShpdG9iKDcpKQoJcHVzaGludCA3CglmcmFtZV9idXJ5IDIgLy8gbDogdWludDY0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQ3MwoJLy8gdiA9IGEuc3BsaWNlKGksIGwpCglmcmFtZV9kaWcgMCAvLyBhOiB1aW50MTZbXQoJcHVzaGludCA3IC8vIGw6IHVpbnQ2NAoJcHVzaGludCAyCglzdG9yZSAyNDcgLy8gc3BsaWNlIHN0YXJ0CglwdXNoaW50IDE2CglzdG9yZSAyNDYgLy8gc3BsaWNlIGJ5dGUgbGVuZ3RoCglmcmFtZV9kaWcgMCAvLyBhOiB1aW50MTZbXQoJcHVzaGludCAwCglsb2FkIDI0NyAvLyBzcGxpY2Ugc3RhcnQKCXN1YnN0cmluZzMKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCglkdXAKCWxlbgoJbG9hZCAyNDcgLy8gc3BsaWNlIHN0YXJ0Cglsb2FkIDI0NiAvLyBzcGxpY2UgYnl0ZSBsZW5ndGgKCSsKCXB1c2hpbnQgMgoJLQoJc3dhcAoJc3Vic3RyaW5nMwoJY29uY2F0CglmcmFtZV9kaWcgMCAvLyBhOiB1aW50MTZbXQoJbG9hZCAyNDcgLy8gc3BsaWNlIHN0YXJ0Cglsb2FkIDI0NiAvLyBzcGxpY2UgYnl0ZSBsZW5ndGgKCXB1c2hpbnQgMgoJLQoJZXh0cmFjdDMKCXN3YXAKCWZyYW1lX2J1cnkgMCAvLyBhOiB1aW50MTZbXQoJZnJhbWVfYnVyeSAzIC8vIHY6IHVpbnQxNltdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQ3NQoJLy8gcmV0dXJuIHY7CglmcmFtZV9kaWcgMyAvLyB2OiB1aW50MTZbXQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoKCS8vIHBvcCBhbGwgbG9jYWwgdmFyaWFibGVzIGZyb20gdGhlIHN0YWNrCglwb3BuIDMKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4NzI5NTY3YmMgLy8gbWV0aG9kICJhcnJheVNwbGljZVZhbHVlKCl1aW50MTZbXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfYXJyYXlTcGxpY2VWYWx1ZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestArraySpliceValue.arc56_draft.json b/tests/contracts/artifacts/ABITestArraySpliceValue.arc56_draft.json index 3df553cba..fd448c4ef 100644 --- a/tests/contracts/artifacts/ABITestArraySpliceValue.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestArraySpliceValue.arc56_draft.json @@ -728,7 +728,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBhcnJheVNwbGljZVZhbHVlKCl1aW50MTZbXQoqYWJpX3JvdXRlX2FycmF5U3BsaWNlVmFsdWU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBhcnJheVNwbGljZVZhbHVlKCl1aW50MTZbXQoJY2FsbHN1YiBhcnJheVNwbGljZVZhbHVlCglkdXAKCWxlbgoJcHVzaGludCAyCgkvCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGFycmF5U3BsaWNlVmFsdWUoKTogdWludDE2W10KYXJyYXlTcGxpY2VWYWx1ZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXBuIDMKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NDY5CgkvLyBhOiB1aW50MTZbXSA9IFsxLCAyLCAzLCA0LCA1LCA2LCA3LCA4LCA5LCAxMF0KCXB1c2hieXRlcyAweDAwMDEwMDAyMDAwMzAwMDQwMDA1MDAwNjAwMDcwMDA4MDAwOTAwMGEKCWZyYW1lX2J1cnkgMCAvLyBhOiB1aW50MTZbXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo0NzEKCS8vIGkgPSBidG9pKGl0b2IoMSkpCglwdXNoaW50IDEKCWZyYW1lX2J1cnkgMSAvLyBpOiB1aW50NjQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NDcyCgkvLyBsID0gYnRvaShpdG9iKDcpKQoJcHVzaGludCA3CglmcmFtZV9idXJ5IDIgLy8gbDogdWludDY0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQ3MwoJLy8gdiA9IGEuc3BsaWNlKGksIGwpCglmcmFtZV9kaWcgMCAvLyBhOiB1aW50MTZbXQoJcHVzaGludCA3IC8vIGw6IHVpbnQ2NAoJcHVzaGludCAyCglzdG9yZSAyNDcgLy8gc3BsaWNlIHN0YXJ0CglwdXNoaW50IDE2CglzdG9yZSAyNDYgLy8gc3BsaWNlIGJ5dGUgbGVuZ3RoCglmcmFtZV9kaWcgMCAvLyBhOiB1aW50MTZbXQoJcHVzaGludCAwCglsb2FkIDI0NyAvLyBzcGxpY2Ugc3RhcnQKCXN1YnN0cmluZzMKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCglkdXAKCWxlbgoJbG9hZCAyNDcgLy8gc3BsaWNlIHN0YXJ0Cglsb2FkIDI0NiAvLyBzcGxpY2UgYnl0ZSBsZW5ndGgKCSsKCXB1c2hpbnQgMgoJLQoJc3dhcAoJc3Vic3RyaW5nMwoJY29uY2F0CglmcmFtZV9kaWcgMCAvLyBhOiB1aW50MTZbXQoJbG9hZCAyNDcgLy8gc3BsaWNlIHN0YXJ0Cglsb2FkIDI0NiAvLyBzcGxpY2UgYnl0ZSBsZW5ndGgKCXB1c2hpbnQgMgoJLQoJZXh0cmFjdDMKCXN3YXAKCWZyYW1lX2J1cnkgMCAvLyBhOiB1aW50MTZbXQoJZnJhbWVfYnVyeSAzIC8vIHY6IHVpbnQxNltdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQ3NQoJLy8gcmV0dXJuIHY7CglmcmFtZV9kaWcgMyAvLyB2OiB1aW50MTZbXQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoKCS8vIHBvcCBhbGwgbG9jYWwgdmFyaWFibGVzIGZyb20gdGhlIHN0YWNrCglwb3BuIDMKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4NzI5NTY3YmMgLy8gbWV0aG9kICJhcnJheVNwbGljZVZhbHVlKCl1aW50MTZbXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfYXJyYXlTcGxpY2VWYWx1ZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBhcnJheVNwbGljZVZhbHVlKCl1aW50MTZbXQoqYWJpX3JvdXRlX2FycmF5U3BsaWNlVmFsdWU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBhcnJheVNwbGljZVZhbHVlKCl1aW50MTZbXQoJY2FsbHN1YiBhcnJheVNwbGljZVZhbHVlCglkdXAKCWxlbgoJcHVzaGludCAyCgkvCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGFycmF5U3BsaWNlVmFsdWUoKTogdWludDE2W10KYXJyYXlTcGxpY2VWYWx1ZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXBuIDMKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NDY5CgkvLyBhOiB1aW50MTZbXSA9IFsxLCAyLCAzLCA0LCA1LCA2LCA3LCA4LCA5LCAxMF0KCXB1c2hieXRlcyAweDAwMDEwMDAyMDAwMzAwMDQwMDA1MDAwNjAwMDcwMDA4MDAwOTAwMGEKCWZyYW1lX2J1cnkgMCAvLyBhOiB1aW50MTZbXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo0NzEKCS8vIGkgPSBidG9pKGl0b2IoMSkpCglwdXNoaW50IDEKCWZyYW1lX2J1cnkgMSAvLyBpOiB1aW50NjQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NDcyCgkvLyBsID0gYnRvaShpdG9iKDcpKQoJcHVzaGludCA3CglmcmFtZV9idXJ5IDIgLy8gbDogdWludDY0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQ3MwoJLy8gdiA9IGEuc3BsaWNlKGksIGwpCglmcmFtZV9kaWcgMCAvLyBhOiB1aW50MTZbXQoJcHVzaGludCA3IC8vIGw6IHVpbnQ2NAoJcHVzaGludCAyCglzdG9yZSAyNDcgLy8gc3BsaWNlIHN0YXJ0CglwdXNoaW50IDE2CglzdG9yZSAyNDYgLy8gc3BsaWNlIGJ5dGUgbGVuZ3RoCglmcmFtZV9kaWcgMCAvLyBhOiB1aW50MTZbXQoJcHVzaGludCAwCglsb2FkIDI0NyAvLyBzcGxpY2Ugc3RhcnQKCXN1YnN0cmluZzMKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCglkdXAKCWxlbgoJbG9hZCAyNDcgLy8gc3BsaWNlIHN0YXJ0Cglsb2FkIDI0NiAvLyBzcGxpY2UgYnl0ZSBsZW5ndGgKCSsKCXB1c2hpbnQgMgoJLQoJc3dhcAoJc3Vic3RyaW5nMwoJY29uY2F0CglmcmFtZV9kaWcgMCAvLyBhOiB1aW50MTZbXQoJbG9hZCAyNDcgLy8gc3BsaWNlIHN0YXJ0Cglsb2FkIDI0NiAvLyBzcGxpY2UgYnl0ZSBsZW5ndGgKCXB1c2hpbnQgMgoJLQoJZXh0cmFjdDMKCXN3YXAKCWZyYW1lX2J1cnkgMCAvLyBhOiB1aW50MTZbXQoJZnJhbWVfYnVyeSAzIC8vIHY6IHVpbnQxNltdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQ3NQoJLy8gcmV0dXJuIHY7CglmcmFtZV9kaWcgMyAvLyB2OiB1aW50MTZbXQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoKCS8vIHBvcCBhbGwgbG9jYWwgdmFyaWFibGVzIGZyb20gdGhlIHN0YWNrCglwb3BuIDMKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4NzI5NTY3YmMgLy8gbWV0aG9kICJhcnJheVNwbGljZVZhbHVlKCl1aW50MTZbXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfYXJyYXlTcGxpY2VWYWx1ZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestBiggerByteCasting.approval.teal b/tests/contracts/artifacts/ABITestBiggerByteCasting.approval.teal index 0283ca5bf..0030d76ff 100644 --- a/tests/contracts/artifacts/ABITestBiggerByteCasting.approval.teal +++ b/tests/contracts/artifacts/ABITestBiggerByteCasting.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestBiggerByteCasting.arc32.json b/tests/contracts/artifacts/ABITestBiggerByteCasting.arc32.json index 7d896c5a9..00ff09fd6 100644 --- a/tests/contracts/artifacts/ABITestBiggerByteCasting.arc32.json +++ b/tests/contracts/artifacts/ABITestBiggerByteCasting.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYmlnZ2VyQnl0ZUNhc3RpbmcoYnl0ZVsyXSlieXRlWzRdCiphYmlfcm91dGVfYmlnZ2VyQnl0ZUNhc3Rpbmc6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gYTogYnl0ZVsyXQoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJZHVwCglsZW4KCXB1c2hpbnQgMgoJPT0KCgkvLyBhcmd1bWVudCAwIChhKSBmb3IgYmlnZ2VyQnl0ZUNhc3RpbmcgbXVzdCBiZSBhIGJ5dGVbMl0KCWFzc2VydAoKCS8vIGV4ZWN1dGUgYmlnZ2VyQnl0ZUNhc3RpbmcoYnl0ZVsyXSlieXRlWzRdCgljYWxsc3ViIGJpZ2dlckJ5dGVDYXN0aW5nCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGJpZ2dlckJ5dGVDYXN0aW5nKGE6IGJ5dGVzPDI+KTogYnl0ZXM8ND4KYmlnZ2VyQnl0ZUNhc3Rpbmc6Cglwcm90byAxIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTIwNwoJLy8gcmV0dXJuIDxieXRlczw0Pj5hOwoJZnJhbWVfZGlnIC0xIC8vIGE6IGJ5dGVzPDI+CglwdXNoYnl0ZXMgMHgwMDAwCgljb25jYXQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZjRjMzY2YzAgLy8gbWV0aG9kICJiaWdnZXJCeXRlQ2FzdGluZyhieXRlWzJdKWJ5dGVbNF0iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2JpZ2dlckJ5dGVDYXN0aW5nCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYmlnZ2VyQnl0ZUNhc3RpbmcoYnl0ZVsyXSlieXRlWzRdCiphYmlfcm91dGVfYmlnZ2VyQnl0ZUNhc3Rpbmc6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gYTogYnl0ZVsyXQoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJZHVwCglsZW4KCXB1c2hpbnQgMgoJPT0KCgkvLyBhcmd1bWVudCAwIChhKSBmb3IgYmlnZ2VyQnl0ZUNhc3RpbmcgbXVzdCBiZSBhIGJ5dGVbMl0KCWFzc2VydAoKCS8vIGV4ZWN1dGUgYmlnZ2VyQnl0ZUNhc3RpbmcoYnl0ZVsyXSlieXRlWzRdCgljYWxsc3ViIGJpZ2dlckJ5dGVDYXN0aW5nCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGJpZ2dlckJ5dGVDYXN0aW5nKGE6IGJ5dGVzPDI+KTogYnl0ZXM8ND4KYmlnZ2VyQnl0ZUNhc3Rpbmc6Cglwcm90byAxIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTIwNwoJLy8gcmV0dXJuIDxieXRlczw0Pj5hOwoJZnJhbWVfZGlnIC0xIC8vIGE6IGJ5dGVzPDI+CglwdXNoYnl0ZXMgMHgwMDAwCgljb25jYXQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZjRjMzY2YzAgLy8gbWV0aG9kICJiaWdnZXJCeXRlQ2FzdGluZyhieXRlWzJdKWJ5dGVbNF0iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2JpZ2dlckJ5dGVDYXN0aW5nCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestBiggerByteCasting.arc56_draft.json b/tests/contracts/artifacts/ABITestBiggerByteCasting.arc56_draft.json index 809a3dce2..3023ab494 100644 --- a/tests/contracts/artifacts/ABITestBiggerByteCasting.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestBiggerByteCasting.arc56_draft.json @@ -399,7 +399,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYmlnZ2VyQnl0ZUNhc3RpbmcoYnl0ZVsyXSlieXRlWzRdCiphYmlfcm91dGVfYmlnZ2VyQnl0ZUNhc3Rpbmc6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gYTogYnl0ZVsyXQoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJZHVwCglsZW4KCXB1c2hpbnQgMgoJPT0KCgkvLyBhcmd1bWVudCAwIChhKSBmb3IgYmlnZ2VyQnl0ZUNhc3RpbmcgbXVzdCBiZSBhIGJ5dGVbMl0KCWFzc2VydAoKCS8vIGV4ZWN1dGUgYmlnZ2VyQnl0ZUNhc3RpbmcoYnl0ZVsyXSlieXRlWzRdCgljYWxsc3ViIGJpZ2dlckJ5dGVDYXN0aW5nCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGJpZ2dlckJ5dGVDYXN0aW5nKGE6IGJ5dGVzPDI+KTogYnl0ZXM8ND4KYmlnZ2VyQnl0ZUNhc3Rpbmc6Cglwcm90byAxIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTIwNwoJLy8gcmV0dXJuIDxieXRlczw0Pj5hOwoJZnJhbWVfZGlnIC0xIC8vIGE6IGJ5dGVzPDI+CglwdXNoYnl0ZXMgMHgwMDAwCgljb25jYXQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZjRjMzY2YzAgLy8gbWV0aG9kICJiaWdnZXJCeXRlQ2FzdGluZyhieXRlWzJdKWJ5dGVbNF0iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2JpZ2dlckJ5dGVDYXN0aW5nCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYmlnZ2VyQnl0ZUNhc3RpbmcoYnl0ZVsyXSlieXRlWzRdCiphYmlfcm91dGVfYmlnZ2VyQnl0ZUNhc3Rpbmc6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gYTogYnl0ZVsyXQoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJZHVwCglsZW4KCXB1c2hpbnQgMgoJPT0KCgkvLyBhcmd1bWVudCAwIChhKSBmb3IgYmlnZ2VyQnl0ZUNhc3RpbmcgbXVzdCBiZSBhIGJ5dGVbMl0KCWFzc2VydAoKCS8vIGV4ZWN1dGUgYmlnZ2VyQnl0ZUNhc3RpbmcoYnl0ZVsyXSlieXRlWzRdCgljYWxsc3ViIGJpZ2dlckJ5dGVDYXN0aW5nCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGJpZ2dlckJ5dGVDYXN0aW5nKGE6IGJ5dGVzPDI+KTogYnl0ZXM8ND4KYmlnZ2VyQnl0ZUNhc3Rpbmc6Cglwcm90byAxIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTIwNwoJLy8gcmV0dXJuIDxieXRlczw0Pj5hOwoJZnJhbWVfZGlnIC0xIC8vIGE6IGJ5dGVzPDI+CglwdXNoYnl0ZXMgMHgwMDAwCgljb25jYXQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZjRjMzY2YzAgLy8gbWV0aG9kICJiaWdnZXJCeXRlQ2FzdGluZyhieXRlWzJdKWJ5dGVbNF0iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2JpZ2dlckJ5dGVDYXN0aW5nCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestBoolFirstInTuple.approval.teal b/tests/contracts/artifacts/ABITestBoolFirstInTuple.approval.teal index 24b98654d..af9258650 100644 --- a/tests/contracts/artifacts/ABITestBoolFirstInTuple.approval.teal +++ b/tests/contracts/artifacts/ABITestBoolFirstInTuple.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestBoolFirstInTuple.arc32.json b/tests/contracts/artifacts/ABITestBoolFirstInTuple.arc32.json index bfb50a1d3..83b9746b9 100644 --- a/tests/contracts/artifacts/ABITestBoolFirstInTuple.arc32.json +++ b/tests/contracts/artifacts/ABITestBoolFirstInTuple.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYm9vbEZpcnN0SW5UdXBsZSgpKGJvb2wsdWludDY0LHVpbnQ2NCkKKmFiaV9yb3V0ZV9ib29sRmlyc3RJblR1cGxlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgYm9vbEZpcnN0SW5UdXBsZSgpKGJvb2wsdWludDY0LHVpbnQ2NCkKCWNhbGxzdWIgYm9vbEZpcnN0SW5UdXBsZQoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBib29sRmlyc3RJblR1cGxlKCk6IFtib29sZWFuLCB1aW50NjQsIHVpbnQ2NF0KYm9vbEZpcnN0SW5UdXBsZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglwdXNoYnl0ZXMgMHgKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTU4MgoJLy8gYTogW2Jvb2xlYW4sIHVpbnQ2NCwgdWludDY0XSA9IFt0cnVlLCAxLCAyXQoJcHVzaGJ5dGVzIDB4MDAKCXB1c2hpbnQgMAoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDEKCWNvbmNhdAoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMgoJY29uY2F0CglmcmFtZV9idXJ5IDAgLy8gYTogW2Jvb2xlYW4sIHVpbnQ2NCwgdWludDY0XQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNTg0CgkvLyByZXR1cm4gYTsKCWZyYW1lX2RpZyAwIC8vIGE6IFtib29sZWFuLCB1aW50NjQsIHVpbnQ2NF0KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YTI3MzE4ZDUgLy8gbWV0aG9kICJib29sRmlyc3RJblR1cGxlKCkoYm9vbCx1aW50NjQsdWludDY0KSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfYm9vbEZpcnN0SW5UdXBsZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYm9vbEZpcnN0SW5UdXBsZSgpKGJvb2wsdWludDY0LHVpbnQ2NCkKKmFiaV9yb3V0ZV9ib29sRmlyc3RJblR1cGxlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgYm9vbEZpcnN0SW5UdXBsZSgpKGJvb2wsdWludDY0LHVpbnQ2NCkKCWNhbGxzdWIgYm9vbEZpcnN0SW5UdXBsZQoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBib29sRmlyc3RJblR1cGxlKCk6IFtib29sZWFuLCB1aW50NjQsIHVpbnQ2NF0KYm9vbEZpcnN0SW5UdXBsZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglwdXNoYnl0ZXMgMHgKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTU4MgoJLy8gYTogW2Jvb2xlYW4sIHVpbnQ2NCwgdWludDY0XSA9IFt0cnVlLCAxLCAyXQoJcHVzaGJ5dGVzIDB4MDAKCXB1c2hpbnQgMAoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDEKCWNvbmNhdAoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMgoJY29uY2F0CglmcmFtZV9idXJ5IDAgLy8gYTogW2Jvb2xlYW4sIHVpbnQ2NCwgdWludDY0XQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNTg0CgkvLyByZXR1cm4gYTsKCWZyYW1lX2RpZyAwIC8vIGE6IFtib29sZWFuLCB1aW50NjQsIHVpbnQ2NF0KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YTI3MzE4ZDUgLy8gbWV0aG9kICJib29sRmlyc3RJblR1cGxlKCkoYm9vbCx1aW50NjQsdWludDY0KSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfYm9vbEZpcnN0SW5UdXBsZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestBoolFirstInTuple.arc56_draft.json b/tests/contracts/artifacts/ABITestBoolFirstInTuple.arc56_draft.json index bbc4b59fe..645b91a75 100644 --- a/tests/contracts/artifacts/ABITestBoolFirstInTuple.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestBoolFirstInTuple.arc56_draft.json @@ -433,7 +433,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYm9vbEZpcnN0SW5UdXBsZSgpKGJvb2wsdWludDY0LHVpbnQ2NCkKKmFiaV9yb3V0ZV9ib29sRmlyc3RJblR1cGxlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgYm9vbEZpcnN0SW5UdXBsZSgpKGJvb2wsdWludDY0LHVpbnQ2NCkKCWNhbGxzdWIgYm9vbEZpcnN0SW5UdXBsZQoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBib29sRmlyc3RJblR1cGxlKCk6IFtib29sZWFuLCB1aW50NjQsIHVpbnQ2NF0KYm9vbEZpcnN0SW5UdXBsZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglwdXNoYnl0ZXMgMHgKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTU4MgoJLy8gYTogW2Jvb2xlYW4sIHVpbnQ2NCwgdWludDY0XSA9IFt0cnVlLCAxLCAyXQoJcHVzaGJ5dGVzIDB4MDAKCXB1c2hpbnQgMAoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDEKCWNvbmNhdAoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMgoJY29uY2F0CglmcmFtZV9idXJ5IDAgLy8gYTogW2Jvb2xlYW4sIHVpbnQ2NCwgdWludDY0XQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNTg0CgkvLyByZXR1cm4gYTsKCWZyYW1lX2RpZyAwIC8vIGE6IFtib29sZWFuLCB1aW50NjQsIHVpbnQ2NF0KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YTI3MzE4ZDUgLy8gbWV0aG9kICJib29sRmlyc3RJblR1cGxlKCkoYm9vbCx1aW50NjQsdWludDY0KSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfYm9vbEZpcnN0SW5UdXBsZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYm9vbEZpcnN0SW5UdXBsZSgpKGJvb2wsdWludDY0LHVpbnQ2NCkKKmFiaV9yb3V0ZV9ib29sRmlyc3RJblR1cGxlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgYm9vbEZpcnN0SW5UdXBsZSgpKGJvb2wsdWludDY0LHVpbnQ2NCkKCWNhbGxzdWIgYm9vbEZpcnN0SW5UdXBsZQoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBib29sRmlyc3RJblR1cGxlKCk6IFtib29sZWFuLCB1aW50NjQsIHVpbnQ2NF0KYm9vbEZpcnN0SW5UdXBsZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglwdXNoYnl0ZXMgMHgKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTU4MgoJLy8gYTogW2Jvb2xlYW4sIHVpbnQ2NCwgdWludDY0XSA9IFt0cnVlLCAxLCAyXQoJcHVzaGJ5dGVzIDB4MDAKCXB1c2hpbnQgMAoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDEKCWNvbmNhdAoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMgoJY29uY2F0CglmcmFtZV9idXJ5IDAgLy8gYTogW2Jvb2xlYW4sIHVpbnQ2NCwgdWludDY0XQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNTg0CgkvLyByZXR1cm4gYTsKCWZyYW1lX2RpZyAwIC8vIGE6IFtib29sZWFuLCB1aW50NjQsIHVpbnQ2NF0KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YTI3MzE4ZDUgLy8gbWV0aG9kICJib29sRmlyc3RJblR1cGxlKCkoYm9vbCx1aW50NjQsdWludDY0KSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfYm9vbEZpcnN0SW5UdXBsZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestBoolInNestedTuple.approval.teal b/tests/contracts/artifacts/ABITestBoolInNestedTuple.approval.teal index 67b8d1ffe..1ee86932e 100644 --- a/tests/contracts/artifacts/ABITestBoolInNestedTuple.approval.teal +++ b/tests/contracts/artifacts/ABITestBoolInNestedTuple.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x00 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestBoolInNestedTuple.arc32.json b/tests/contracts/artifacts/ABITestBoolInNestedTuple.arc32.json index 8904661cb..f72856f8b 100644 --- a/tests/contracts/artifacts/ABITestBoolInNestedTuple.arc32.json +++ b/tests/contracts/artifacts/ABITestBoolInNestedTuple.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgwMAoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDQuMQovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIGJvb2xJbk5lc3RlZFR1cGxlKClib29sCiphYmlfcm91dGVfYm9vbEluTmVzdGVkVHVwbGU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBib29sSW5OZXN0ZWRUdXBsZSgpYm9vbAoJY2FsbHN1YiBib29sSW5OZXN0ZWRUdXBsZQoJYnl0ZSAweDAwCglwdXNoaW50IDAKCXVuY292ZXIgMgoJc2V0Yml0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGJvb2xJbk5lc3RlZFR1cGxlKCk6IGJvb2xlYW4KYm9vbEluTmVzdGVkVHVwbGU6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0NDIKCS8vIGE6IFtbdWludDY0LCB1aW50NjQsIHVpbnQ2NF0sIGJvb2xlYW4sIGJvb2xlYW5dID0gW1swLCAwLCAwXSwgdHJ1ZSwgZmFsc2VdCglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAKCWJ5dGUgMHgwMAoJcHVzaGludCAwCglwdXNoaW50IDEKCXNldGJpdAoJcHVzaGludCAxCglwdXNoaW50IDAKCXNldGJpdAoJY29uY2F0CglmcmFtZV9idXJ5IDAgLy8gYTogW1t1aW50NjQsIHVpbnQ2NCwgdWludDY0XSwgYm9vbGVhbiwgYm9vbGVhbl0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTQ0NAoJLy8gYVsxXSA9IGZhbHNlCglmcmFtZV9kaWcgMCAvLyBhOiBbW3VpbnQ2NCwgdWludDY0LCB1aW50NjRdLCBib29sZWFuLCBib29sZWFuXQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgMTkyCglwdXNoaW50IDAKCXNldGJpdAoJZnJhbWVfYnVyeSAwIC8vIGE6IFtbdWludDY0LCB1aW50NjQsIHVpbnQ2NF0sIGJvb2xlYW4sIGJvb2xlYW5dCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0NDUKCS8vIGFbMl0gPSB0cnVlCglmcmFtZV9kaWcgMCAvLyBhOiBbW3VpbnQ2NCwgdWludDY0LCB1aW50NjRdLCBib29sZWFuLCBib29sZWFuXQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgMTkzCglwdXNoaW50IDEKCXNldGJpdAoJZnJhbWVfYnVyeSAwIC8vIGE6IFtbdWludDY0LCB1aW50NjQsIHVpbnQ2NF0sIGJvb2xlYW4sIGJvb2xlYW5dCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0NDcKCS8vIHJldHVybiBhWzJdOwoJZnJhbWVfZGlnIDAgLy8gYTogW1t1aW50NjQsIHVpbnQ2NCwgdWludDY0XSwgYm9vbGVhbiwgYm9vbGVhbl0KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoaW50IDE5MwoJZ2V0Yml0CgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDM4Y2VmNTk4IC8vIG1ldGhvZCAiYm9vbEluTmVzdGVkVHVwbGUoKWJvb2wiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2Jvb2xJbk5lc3RlZFR1cGxlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgwMAoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDUuMAovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIGJvb2xJbk5lc3RlZFR1cGxlKClib29sCiphYmlfcm91dGVfYm9vbEluTmVzdGVkVHVwbGU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBib29sSW5OZXN0ZWRUdXBsZSgpYm9vbAoJY2FsbHN1YiBib29sSW5OZXN0ZWRUdXBsZQoJYnl0ZSAweDAwCglwdXNoaW50IDAKCXVuY292ZXIgMgoJc2V0Yml0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGJvb2xJbk5lc3RlZFR1cGxlKCk6IGJvb2xlYW4KYm9vbEluTmVzdGVkVHVwbGU6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0NDIKCS8vIGE6IFtbdWludDY0LCB1aW50NjQsIHVpbnQ2NF0sIGJvb2xlYW4sIGJvb2xlYW5dID0gW1swLCAwLCAwXSwgdHJ1ZSwgZmFsc2VdCglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAKCWJ5dGUgMHgwMAoJcHVzaGludCAwCglwdXNoaW50IDEKCXNldGJpdAoJcHVzaGludCAxCglwdXNoaW50IDAKCXNldGJpdAoJY29uY2F0CglmcmFtZV9idXJ5IDAgLy8gYTogW1t1aW50NjQsIHVpbnQ2NCwgdWludDY0XSwgYm9vbGVhbiwgYm9vbGVhbl0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTQ0NAoJLy8gYVsxXSA9IGZhbHNlCglmcmFtZV9kaWcgMCAvLyBhOiBbW3VpbnQ2NCwgdWludDY0LCB1aW50NjRdLCBib29sZWFuLCBib29sZWFuXQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgMTkyCglwdXNoaW50IDAKCXNldGJpdAoJZnJhbWVfYnVyeSAwIC8vIGE6IFtbdWludDY0LCB1aW50NjQsIHVpbnQ2NF0sIGJvb2xlYW4sIGJvb2xlYW5dCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0NDUKCS8vIGFbMl0gPSB0cnVlCglmcmFtZV9kaWcgMCAvLyBhOiBbW3VpbnQ2NCwgdWludDY0LCB1aW50NjRdLCBib29sZWFuLCBib29sZWFuXQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgMTkzCglwdXNoaW50IDEKCXNldGJpdAoJZnJhbWVfYnVyeSAwIC8vIGE6IFtbdWludDY0LCB1aW50NjQsIHVpbnQ2NF0sIGJvb2xlYW4sIGJvb2xlYW5dCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0NDcKCS8vIHJldHVybiBhWzJdOwoJZnJhbWVfZGlnIDAgLy8gYTogW1t1aW50NjQsIHVpbnQ2NCwgdWludDY0XSwgYm9vbGVhbiwgYm9vbGVhbl0KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoaW50IDE5MwoJZ2V0Yml0CgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDM4Y2VmNTk4IC8vIG1ldGhvZCAiYm9vbEluTmVzdGVkVHVwbGUoKWJvb2wiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2Jvb2xJbk5lc3RlZFR1cGxlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestBoolInNestedTuple.arc56_draft.json b/tests/contracts/artifacts/ABITestBoolInNestedTuple.arc56_draft.json index 7a7658e1a..14726bcbd 100644 --- a/tests/contracts/artifacts/ABITestBoolInNestedTuple.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestBoolInNestedTuple.arc56_draft.json @@ -635,7 +635,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgwMAoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDQuMQovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIGJvb2xJbk5lc3RlZFR1cGxlKClib29sCiphYmlfcm91dGVfYm9vbEluTmVzdGVkVHVwbGU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBib29sSW5OZXN0ZWRUdXBsZSgpYm9vbAoJY2FsbHN1YiBib29sSW5OZXN0ZWRUdXBsZQoJYnl0ZSAweDAwCglwdXNoaW50IDAKCXVuY292ZXIgMgoJc2V0Yml0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGJvb2xJbk5lc3RlZFR1cGxlKCk6IGJvb2xlYW4KYm9vbEluTmVzdGVkVHVwbGU6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0NDIKCS8vIGE6IFtbdWludDY0LCB1aW50NjQsIHVpbnQ2NF0sIGJvb2xlYW4sIGJvb2xlYW5dID0gW1swLCAwLCAwXSwgdHJ1ZSwgZmFsc2VdCglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAKCWJ5dGUgMHgwMAoJcHVzaGludCAwCglwdXNoaW50IDEKCXNldGJpdAoJcHVzaGludCAxCglwdXNoaW50IDAKCXNldGJpdAoJY29uY2F0CglmcmFtZV9idXJ5IDAgLy8gYTogW1t1aW50NjQsIHVpbnQ2NCwgdWludDY0XSwgYm9vbGVhbiwgYm9vbGVhbl0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTQ0NAoJLy8gYVsxXSA9IGZhbHNlCglmcmFtZV9kaWcgMCAvLyBhOiBbW3VpbnQ2NCwgdWludDY0LCB1aW50NjRdLCBib29sZWFuLCBib29sZWFuXQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgMTkyCglwdXNoaW50IDAKCXNldGJpdAoJZnJhbWVfYnVyeSAwIC8vIGE6IFtbdWludDY0LCB1aW50NjQsIHVpbnQ2NF0sIGJvb2xlYW4sIGJvb2xlYW5dCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0NDUKCS8vIGFbMl0gPSB0cnVlCglmcmFtZV9kaWcgMCAvLyBhOiBbW3VpbnQ2NCwgdWludDY0LCB1aW50NjRdLCBib29sZWFuLCBib29sZWFuXQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgMTkzCglwdXNoaW50IDEKCXNldGJpdAoJZnJhbWVfYnVyeSAwIC8vIGE6IFtbdWludDY0LCB1aW50NjQsIHVpbnQ2NF0sIGJvb2xlYW4sIGJvb2xlYW5dCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0NDcKCS8vIHJldHVybiBhWzJdOwoJZnJhbWVfZGlnIDAgLy8gYTogW1t1aW50NjQsIHVpbnQ2NCwgdWludDY0XSwgYm9vbGVhbiwgYm9vbGVhbl0KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoaW50IDE5MwoJZ2V0Yml0CgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDM4Y2VmNTk4IC8vIG1ldGhvZCAiYm9vbEluTmVzdGVkVHVwbGUoKWJvb2wiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2Jvb2xJbk5lc3RlZFR1cGxlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgwMAoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDUuMAovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIGJvb2xJbk5lc3RlZFR1cGxlKClib29sCiphYmlfcm91dGVfYm9vbEluTmVzdGVkVHVwbGU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBib29sSW5OZXN0ZWRUdXBsZSgpYm9vbAoJY2FsbHN1YiBib29sSW5OZXN0ZWRUdXBsZQoJYnl0ZSAweDAwCglwdXNoaW50IDAKCXVuY292ZXIgMgoJc2V0Yml0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGJvb2xJbk5lc3RlZFR1cGxlKCk6IGJvb2xlYW4KYm9vbEluTmVzdGVkVHVwbGU6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0NDIKCS8vIGE6IFtbdWludDY0LCB1aW50NjQsIHVpbnQ2NF0sIGJvb2xlYW4sIGJvb2xlYW5dID0gW1swLCAwLCAwXSwgdHJ1ZSwgZmFsc2VdCglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAKCWJ5dGUgMHgwMAoJcHVzaGludCAwCglwdXNoaW50IDEKCXNldGJpdAoJcHVzaGludCAxCglwdXNoaW50IDAKCXNldGJpdAoJY29uY2F0CglmcmFtZV9idXJ5IDAgLy8gYTogW1t1aW50NjQsIHVpbnQ2NCwgdWludDY0XSwgYm9vbGVhbiwgYm9vbGVhbl0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTQ0NAoJLy8gYVsxXSA9IGZhbHNlCglmcmFtZV9kaWcgMCAvLyBhOiBbW3VpbnQ2NCwgdWludDY0LCB1aW50NjRdLCBib29sZWFuLCBib29sZWFuXQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgMTkyCglwdXNoaW50IDAKCXNldGJpdAoJZnJhbWVfYnVyeSAwIC8vIGE6IFtbdWludDY0LCB1aW50NjQsIHVpbnQ2NF0sIGJvb2xlYW4sIGJvb2xlYW5dCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0NDUKCS8vIGFbMl0gPSB0cnVlCglmcmFtZV9kaWcgMCAvLyBhOiBbW3VpbnQ2NCwgdWludDY0LCB1aW50NjRdLCBib29sZWFuLCBib29sZWFuXQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgMTkzCglwdXNoaW50IDEKCXNldGJpdAoJZnJhbWVfYnVyeSAwIC8vIGE6IFtbdWludDY0LCB1aW50NjQsIHVpbnQ2NF0sIGJvb2xlYW4sIGJvb2xlYW5dCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0NDcKCS8vIHJldHVybiBhWzJdOwoJZnJhbWVfZGlnIDAgLy8gYTogW1t1aW50NjQsIHVpbnQ2NCwgdWludDY0XSwgYm9vbGVhbiwgYm9vbGVhbl0KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoaW50IDE5MwoJZ2V0Yml0CgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDM4Y2VmNTk4IC8vIG1ldGhvZCAiYm9vbEluTmVzdGVkVHVwbGUoKWJvb2wiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2Jvb2xJbk5lc3RlZFR1cGxlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestBoolInObj.approval.teal b/tests/contracts/artifacts/ABITestBoolInObj.approval.teal index 78d301032..7c1942723 100644 --- a/tests/contracts/artifacts/ABITestBoolInObj.approval.teal +++ b/tests/contracts/artifacts/ABITestBoolInObj.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 intcblock 1 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestBoolInObj.arc32.json b/tests/contracts/artifacts/ABITestBoolInObj.arc32.json index 29f2e81cb..0490b087a 100644 --- a/tests/contracts/artifacts/ABITestBoolInObj.arc32.json +++ b/tests/contracts/artifacts/ABITestBoolInObj.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmludGNibG9jayAxCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYm9vbEluT2JqKCl2b2lkCiphYmlfcm91dGVfYm9vbEluT2JqOgoJLy8gZXhlY3V0ZSBib29sSW5PYmooKXZvaWQKCWNhbGxzdWIgYm9vbEluT2JqCglpbnQgMQoJcmV0dXJuCgovLyBib29sSW5PYmooKTogdm9pZApib29sSW5PYmo6Cglwcm90byAwIDAKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEyMjUKCS8vIHg6IHsgZm9vOiBib29sZWFuOyBiYXI6IGJvb2xlYW47IGJhejogYm9vbGVhbiB9ID0geyBmb286IHRydWUsIGJhcjogdHJ1ZSwgYmF6OiB0cnVlIH0KCXB1c2hieXRlcyAweDAwCglwdXNoaW50IDAKCWludCAxCglzZXRiaXQKCWludCAxCglkdXAKCXNldGJpdAoJcHVzaGludCAyCglpbnQgMQoJc2V0Yml0CglmcmFtZV9idXJ5IDAgLy8geDogeyBmb286IGJvb2xlYW47IGJhcjogYm9vbGVhbjsgYmF6OiBib29sZWFuIH0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTIyNgoJLy8geC5iYXIgPSBmYWxzZQoJZnJhbWVfZGlnIDAgLy8geDogeyBmb286IGJvb2xlYW47IGJhcjogYm9vbGVhbjsgYmF6OiBib29sZWFuIH0KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglpbnQgMQoJcHVzaGludCAwCglzZXRiaXQKCWZyYW1lX2J1cnkgMCAvLyB4OiB7IGZvbzogYm9vbGVhbjsgYmFyOiBib29sZWFuOyBiYXo6IGJvb2xlYW4gfQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjI3CgkvLyBhc3NlcnRzKHguZm9vID09PSB0cnVlLCB4LmJhciA9PT0gZmFsc2UsIHguYmF6ID09PSB0cnVlKQoJZnJhbWVfZGlnIDAgLy8geDogeyBmb286IGJvb2xlYW47IGJhcjogYm9vbGVhbjsgYmF6OiBib29sZWFuIH0KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoaW50IDAKCWdldGJpdAoJaW50IDEKCT09CgoJLy8gYXNzZXJ0cyBmYWlsZWQ6IGFzc2VydHMoeC5mb28gPT09IHRydWUsIHguYmFyID09PSBmYWxzZSwgeC5iYXogPT09IHRydWUpCglhc3NlcnQKCWZyYW1lX2RpZyAwIC8vIHg6IHsgZm9vOiBib29sZWFuOyBiYXI6IGJvb2xlYW47IGJhejogYm9vbGVhbiB9CglzdG9yZSAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJaW50IDEKCWdldGJpdAoJcHVzaGludCAwCgk9PQoKCS8vIGFzc2VydHMgZmFpbGVkOiBhc3NlcnRzKHguZm9vID09PSB0cnVlLCB4LmJhciA9PT0gZmFsc2UsIHguYmF6ID09PSB0cnVlKQoJYXNzZXJ0CglmcmFtZV9kaWcgMCAvLyB4OiB7IGZvbzogYm9vbGVhbjsgYmFyOiBib29sZWFuOyBiYXo6IGJvb2xlYW4gfQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgMgoJZ2V0Yml0CglpbnQgMQoJPT0KCgkvLyBhc3NlcnRzIGZhaWxlZDogYXNzZXJ0cyh4LmZvbyA9PT0gdHJ1ZSwgeC5iYXIgPT09IGZhbHNlLCB4LmJheiA9PT0gdHJ1ZSkKCWFzc2VydAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGU2N2M4ZmNiIC8vIG1ldGhvZCAiYm9vbEluT2JqKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9ib29sSW5PYmoKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmludGNibG9jayAxCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYm9vbEluT2JqKCl2b2lkCiphYmlfcm91dGVfYm9vbEluT2JqOgoJLy8gZXhlY3V0ZSBib29sSW5PYmooKXZvaWQKCWNhbGxzdWIgYm9vbEluT2JqCglpbnQgMQoJcmV0dXJuCgovLyBib29sSW5PYmooKTogdm9pZApib29sSW5PYmo6Cglwcm90byAwIDAKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEyMjUKCS8vIHg6IHsgZm9vOiBib29sZWFuOyBiYXI6IGJvb2xlYW47IGJhejogYm9vbGVhbiB9ID0geyBmb286IHRydWUsIGJhcjogdHJ1ZSwgYmF6OiB0cnVlIH0KCXB1c2hieXRlcyAweDAwCglwdXNoaW50IDAKCWludCAxCglzZXRiaXQKCWludCAxCglkdXAKCXNldGJpdAoJcHVzaGludCAyCglpbnQgMQoJc2V0Yml0CglmcmFtZV9idXJ5IDAgLy8geDogeyBmb286IGJvb2xlYW47IGJhcjogYm9vbGVhbjsgYmF6OiBib29sZWFuIH0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTIyNgoJLy8geC5iYXIgPSBmYWxzZQoJZnJhbWVfZGlnIDAgLy8geDogeyBmb286IGJvb2xlYW47IGJhcjogYm9vbGVhbjsgYmF6OiBib29sZWFuIH0KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglpbnQgMQoJcHVzaGludCAwCglzZXRiaXQKCWZyYW1lX2J1cnkgMCAvLyB4OiB7IGZvbzogYm9vbGVhbjsgYmFyOiBib29sZWFuOyBiYXo6IGJvb2xlYW4gfQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjI3CgkvLyBhc3NlcnRzKHguZm9vID09PSB0cnVlLCB4LmJhciA9PT0gZmFsc2UsIHguYmF6ID09PSB0cnVlKQoJZnJhbWVfZGlnIDAgLy8geDogeyBmb286IGJvb2xlYW47IGJhcjogYm9vbGVhbjsgYmF6OiBib29sZWFuIH0KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoaW50IDAKCWdldGJpdAoJaW50IDEKCT09CgoJLy8gYXNzZXJ0cyBmYWlsZWQ6IGFzc2VydHMoeC5mb28gPT09IHRydWUsIHguYmFyID09PSBmYWxzZSwgeC5iYXogPT09IHRydWUpCglhc3NlcnQKCWZyYW1lX2RpZyAwIC8vIHg6IHsgZm9vOiBib29sZWFuOyBiYXI6IGJvb2xlYW47IGJhejogYm9vbGVhbiB9CglzdG9yZSAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJaW50IDEKCWdldGJpdAoJcHVzaGludCAwCgk9PQoKCS8vIGFzc2VydHMgZmFpbGVkOiBhc3NlcnRzKHguZm9vID09PSB0cnVlLCB4LmJhciA9PT0gZmFsc2UsIHguYmF6ID09PSB0cnVlKQoJYXNzZXJ0CglmcmFtZV9kaWcgMCAvLyB4OiB7IGZvbzogYm9vbGVhbjsgYmFyOiBib29sZWFuOyBiYXo6IGJvb2xlYW4gfQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgMgoJZ2V0Yml0CglpbnQgMQoJPT0KCgkvLyBhc3NlcnRzIGZhaWxlZDogYXNzZXJ0cyh4LmZvbyA9PT0gdHJ1ZSwgeC5iYXIgPT09IGZhbHNlLCB4LmJheiA9PT0gdHJ1ZSkKCWFzc2VydAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGU2N2M4ZmNiIC8vIG1ldGhvZCAiYm9vbEluT2JqKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9ib29sSW5PYmoKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestBoolInObj.arc56_draft.json b/tests/contracts/artifacts/ABITestBoolInObj.arc56_draft.json index 119b88621..1f5bd6a77 100644 --- a/tests/contracts/artifacts/ABITestBoolInObj.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestBoolInObj.arc56_draft.json @@ -640,7 +640,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmludGNibG9jayAxCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYm9vbEluT2JqKCl2b2lkCiphYmlfcm91dGVfYm9vbEluT2JqOgoJLy8gZXhlY3V0ZSBib29sSW5PYmooKXZvaWQKCWNhbGxzdWIgYm9vbEluT2JqCglpbnQgMQoJcmV0dXJuCgovLyBib29sSW5PYmooKTogdm9pZApib29sSW5PYmo6Cglwcm90byAwIDAKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEyMjUKCS8vIHg6IHsgZm9vOiBib29sZWFuOyBiYXI6IGJvb2xlYW47IGJhejogYm9vbGVhbiB9ID0geyBmb286IHRydWUsIGJhcjogdHJ1ZSwgYmF6OiB0cnVlIH0KCXB1c2hieXRlcyAweDAwCglwdXNoaW50IDAKCWludCAxCglzZXRiaXQKCWludCAxCglkdXAKCXNldGJpdAoJcHVzaGludCAyCglpbnQgMQoJc2V0Yml0CglmcmFtZV9idXJ5IDAgLy8geDogeyBmb286IGJvb2xlYW47IGJhcjogYm9vbGVhbjsgYmF6OiBib29sZWFuIH0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTIyNgoJLy8geC5iYXIgPSBmYWxzZQoJZnJhbWVfZGlnIDAgLy8geDogeyBmb286IGJvb2xlYW47IGJhcjogYm9vbGVhbjsgYmF6OiBib29sZWFuIH0KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglpbnQgMQoJcHVzaGludCAwCglzZXRiaXQKCWZyYW1lX2J1cnkgMCAvLyB4OiB7IGZvbzogYm9vbGVhbjsgYmFyOiBib29sZWFuOyBiYXo6IGJvb2xlYW4gfQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjI3CgkvLyBhc3NlcnRzKHguZm9vID09PSB0cnVlLCB4LmJhciA9PT0gZmFsc2UsIHguYmF6ID09PSB0cnVlKQoJZnJhbWVfZGlnIDAgLy8geDogeyBmb286IGJvb2xlYW47IGJhcjogYm9vbGVhbjsgYmF6OiBib29sZWFuIH0KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoaW50IDAKCWdldGJpdAoJaW50IDEKCT09CgoJLy8gYXNzZXJ0cyBmYWlsZWQ6IGFzc2VydHMoeC5mb28gPT09IHRydWUsIHguYmFyID09PSBmYWxzZSwgeC5iYXogPT09IHRydWUpCglhc3NlcnQKCWZyYW1lX2RpZyAwIC8vIHg6IHsgZm9vOiBib29sZWFuOyBiYXI6IGJvb2xlYW47IGJhejogYm9vbGVhbiB9CglzdG9yZSAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJaW50IDEKCWdldGJpdAoJcHVzaGludCAwCgk9PQoKCS8vIGFzc2VydHMgZmFpbGVkOiBhc3NlcnRzKHguZm9vID09PSB0cnVlLCB4LmJhciA9PT0gZmFsc2UsIHguYmF6ID09PSB0cnVlKQoJYXNzZXJ0CglmcmFtZV9kaWcgMCAvLyB4OiB7IGZvbzogYm9vbGVhbjsgYmFyOiBib29sZWFuOyBiYXo6IGJvb2xlYW4gfQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgMgoJZ2V0Yml0CglpbnQgMQoJPT0KCgkvLyBhc3NlcnRzIGZhaWxlZDogYXNzZXJ0cyh4LmZvbyA9PT0gdHJ1ZSwgeC5iYXIgPT09IGZhbHNlLCB4LmJheiA9PT0gdHJ1ZSkKCWFzc2VydAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGU2N2M4ZmNiIC8vIG1ldGhvZCAiYm9vbEluT2JqKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9ib29sSW5PYmoKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmludGNibG9jayAxCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYm9vbEluT2JqKCl2b2lkCiphYmlfcm91dGVfYm9vbEluT2JqOgoJLy8gZXhlY3V0ZSBib29sSW5PYmooKXZvaWQKCWNhbGxzdWIgYm9vbEluT2JqCglpbnQgMQoJcmV0dXJuCgovLyBib29sSW5PYmooKTogdm9pZApib29sSW5PYmo6Cglwcm90byAwIDAKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEyMjUKCS8vIHg6IHsgZm9vOiBib29sZWFuOyBiYXI6IGJvb2xlYW47IGJhejogYm9vbGVhbiB9ID0geyBmb286IHRydWUsIGJhcjogdHJ1ZSwgYmF6OiB0cnVlIH0KCXB1c2hieXRlcyAweDAwCglwdXNoaW50IDAKCWludCAxCglzZXRiaXQKCWludCAxCglkdXAKCXNldGJpdAoJcHVzaGludCAyCglpbnQgMQoJc2V0Yml0CglmcmFtZV9idXJ5IDAgLy8geDogeyBmb286IGJvb2xlYW47IGJhcjogYm9vbGVhbjsgYmF6OiBib29sZWFuIH0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTIyNgoJLy8geC5iYXIgPSBmYWxzZQoJZnJhbWVfZGlnIDAgLy8geDogeyBmb286IGJvb2xlYW47IGJhcjogYm9vbGVhbjsgYmF6OiBib29sZWFuIH0KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglpbnQgMQoJcHVzaGludCAwCglzZXRiaXQKCWZyYW1lX2J1cnkgMCAvLyB4OiB7IGZvbzogYm9vbGVhbjsgYmFyOiBib29sZWFuOyBiYXo6IGJvb2xlYW4gfQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjI3CgkvLyBhc3NlcnRzKHguZm9vID09PSB0cnVlLCB4LmJhciA9PT0gZmFsc2UsIHguYmF6ID09PSB0cnVlKQoJZnJhbWVfZGlnIDAgLy8geDogeyBmb286IGJvb2xlYW47IGJhcjogYm9vbGVhbjsgYmF6OiBib29sZWFuIH0KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoaW50IDAKCWdldGJpdAoJaW50IDEKCT09CgoJLy8gYXNzZXJ0cyBmYWlsZWQ6IGFzc2VydHMoeC5mb28gPT09IHRydWUsIHguYmFyID09PSBmYWxzZSwgeC5iYXogPT09IHRydWUpCglhc3NlcnQKCWZyYW1lX2RpZyAwIC8vIHg6IHsgZm9vOiBib29sZWFuOyBiYXI6IGJvb2xlYW47IGJhejogYm9vbGVhbiB9CglzdG9yZSAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJaW50IDEKCWdldGJpdAoJcHVzaGludCAwCgk9PQoKCS8vIGFzc2VydHMgZmFpbGVkOiBhc3NlcnRzKHguZm9vID09PSB0cnVlLCB4LmJhciA9PT0gZmFsc2UsIHguYmF6ID09PSB0cnVlKQoJYXNzZXJ0CglmcmFtZV9kaWcgMCAvLyB4OiB7IGZvbzogYm9vbGVhbjsgYmFyOiBib29sZWFuOyBiYXo6IGJvb2xlYW4gfQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgMgoJZ2V0Yml0CglpbnQgMQoJPT0KCgkvLyBhc3NlcnRzIGZhaWxlZDogYXNzZXJ0cyh4LmZvbyA9PT0gdHJ1ZSwgeC5iYXIgPT09IGZhbHNlLCB4LmJheiA9PT0gdHJ1ZSkKCWFzc2VydAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGU2N2M4ZmNiIC8vIG1ldGhvZCAiYm9vbEluT2JqKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9ib29sSW5PYmoKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestBoolTuple.approval.teal b/tests/contracts/artifacts/ABITestBoolTuple.approval.teal index c90aaa16a..3550bd721 100644 --- a/tests/contracts/artifacts/ABITestBoolTuple.approval.teal +++ b/tests/contracts/artifacts/ABITestBoolTuple.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestBoolTuple.arc32.json b/tests/contracts/artifacts/ABITestBoolTuple.arc32.json index 1786fdd93..21771db17 100644 --- a/tests/contracts/artifacts/ABITestBoolTuple.arc32.json +++ b/tests/contracts/artifacts/ABITestBoolTuple.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYm9vbFR1cGxlKCkoYm9vbCxib29sLGJvb2wsYm9vbCxib29sLGJvb2wsYm9vbCxib29sLGJvb2wpCiphYmlfcm91dGVfYm9vbFR1cGxlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgYm9vbFR1cGxlKCkoYm9vbCxib29sLGJvb2wsYm9vbCxib29sLGJvb2wsYm9vbCxib29sLGJvb2wpCgljYWxsc3ViIGJvb2xUdXBsZQoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBib29sVHVwbGUoKTogW2Jvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW5dCmJvb2xUdXBsZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglwdXNoYnl0ZXMgMHgKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6ODc5CgkvLyBhOiBbYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbl0gPSBbCgkvLyAgICAgICB0cnVlLAoJLy8gICAgICAgZmFsc2UsCgkvLyAgICAgICB0cnVlLAoJLy8gICAgICAgdHJ1ZSwKCS8vICAgICAgIGZhbHNlLAoJLy8gICAgICAgZmFsc2UsCgkvLyAgICAgICB0cnVlLAoJLy8gICAgICAgZmFsc2UsCgkvLyAgICAgICBmYWxzZSwKCS8vICAgICBdCglwdXNoYnl0ZXMgMHgwMDAwCglwdXNoaW50IDAKCXB1c2hpbnQgMQoJc2V0Yml0CglwdXNoaW50IDEKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDIKCXB1c2hpbnQgMQoJc2V0Yml0CglwdXNoaW50IDMKCXB1c2hpbnQgMQoJc2V0Yml0CglwdXNoaW50IDQKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDUKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDYKCXB1c2hpbnQgMQoJc2V0Yml0CglwdXNoaW50IDcKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDgKCXB1c2hpbnQgMAoJc2V0Yml0CglmcmFtZV9idXJ5IDAgLy8gYTogW2Jvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW5dCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjg5MQoJLy8gcmV0dXJuIGE7CglmcmFtZV9kaWcgMCAvLyBhOiBbYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbl0KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZDQ1OTNhZmUgLy8gbWV0aG9kICJib29sVHVwbGUoKShib29sLGJvb2wsYm9vbCxib29sLGJvb2wsYm9vbCxib29sLGJvb2wsYm9vbCkiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2Jvb2xUdXBsZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYm9vbFR1cGxlKCkoYm9vbCxib29sLGJvb2wsYm9vbCxib29sLGJvb2wsYm9vbCxib29sLGJvb2wpCiphYmlfcm91dGVfYm9vbFR1cGxlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgYm9vbFR1cGxlKCkoYm9vbCxib29sLGJvb2wsYm9vbCxib29sLGJvb2wsYm9vbCxib29sLGJvb2wpCgljYWxsc3ViIGJvb2xUdXBsZQoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBib29sVHVwbGUoKTogW2Jvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW5dCmJvb2xUdXBsZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglwdXNoYnl0ZXMgMHgKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6ODc5CgkvLyBhOiBbYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbl0gPSBbCgkvLyAgICAgICB0cnVlLAoJLy8gICAgICAgZmFsc2UsCgkvLyAgICAgICB0cnVlLAoJLy8gICAgICAgdHJ1ZSwKCS8vICAgICAgIGZhbHNlLAoJLy8gICAgICAgZmFsc2UsCgkvLyAgICAgICB0cnVlLAoJLy8gICAgICAgZmFsc2UsCgkvLyAgICAgICBmYWxzZSwKCS8vICAgICBdCglwdXNoYnl0ZXMgMHgwMDAwCglwdXNoaW50IDAKCXB1c2hpbnQgMQoJc2V0Yml0CglwdXNoaW50IDEKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDIKCXB1c2hpbnQgMQoJc2V0Yml0CglwdXNoaW50IDMKCXB1c2hpbnQgMQoJc2V0Yml0CglwdXNoaW50IDQKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDUKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDYKCXB1c2hpbnQgMQoJc2V0Yml0CglwdXNoaW50IDcKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDgKCXB1c2hpbnQgMAoJc2V0Yml0CglmcmFtZV9idXJ5IDAgLy8gYTogW2Jvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW5dCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjg5MQoJLy8gcmV0dXJuIGE7CglmcmFtZV9kaWcgMCAvLyBhOiBbYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbl0KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZDQ1OTNhZmUgLy8gbWV0aG9kICJib29sVHVwbGUoKShib29sLGJvb2wsYm9vbCxib29sLGJvb2wsYm9vbCxib29sLGJvb2wsYm9vbCkiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2Jvb2xUdXBsZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestBoolTuple.arc56_draft.json b/tests/contracts/artifacts/ABITestBoolTuple.arc56_draft.json index 2fc84ef71..00619a11a 100644 --- a/tests/contracts/artifacts/ABITestBoolTuple.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestBoolTuple.arc56_draft.json @@ -572,7 +572,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYm9vbFR1cGxlKCkoYm9vbCxib29sLGJvb2wsYm9vbCxib29sLGJvb2wsYm9vbCxib29sLGJvb2wpCiphYmlfcm91dGVfYm9vbFR1cGxlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgYm9vbFR1cGxlKCkoYm9vbCxib29sLGJvb2wsYm9vbCxib29sLGJvb2wsYm9vbCxib29sLGJvb2wpCgljYWxsc3ViIGJvb2xUdXBsZQoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBib29sVHVwbGUoKTogW2Jvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW5dCmJvb2xUdXBsZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglwdXNoYnl0ZXMgMHgKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6ODc5CgkvLyBhOiBbYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbl0gPSBbCgkvLyAgICAgICB0cnVlLAoJLy8gICAgICAgZmFsc2UsCgkvLyAgICAgICB0cnVlLAoJLy8gICAgICAgdHJ1ZSwKCS8vICAgICAgIGZhbHNlLAoJLy8gICAgICAgZmFsc2UsCgkvLyAgICAgICB0cnVlLAoJLy8gICAgICAgZmFsc2UsCgkvLyAgICAgICBmYWxzZSwKCS8vICAgICBdCglwdXNoYnl0ZXMgMHgwMDAwCglwdXNoaW50IDAKCXB1c2hpbnQgMQoJc2V0Yml0CglwdXNoaW50IDEKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDIKCXB1c2hpbnQgMQoJc2V0Yml0CglwdXNoaW50IDMKCXB1c2hpbnQgMQoJc2V0Yml0CglwdXNoaW50IDQKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDUKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDYKCXB1c2hpbnQgMQoJc2V0Yml0CglwdXNoaW50IDcKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDgKCXB1c2hpbnQgMAoJc2V0Yml0CglmcmFtZV9idXJ5IDAgLy8gYTogW2Jvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW5dCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjg5MQoJLy8gcmV0dXJuIGE7CglmcmFtZV9kaWcgMCAvLyBhOiBbYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbl0KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZDQ1OTNhZmUgLy8gbWV0aG9kICJib29sVHVwbGUoKShib29sLGJvb2wsYm9vbCxib29sLGJvb2wsYm9vbCxib29sLGJvb2wsYm9vbCkiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2Jvb2xUdXBsZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYm9vbFR1cGxlKCkoYm9vbCxib29sLGJvb2wsYm9vbCxib29sLGJvb2wsYm9vbCxib29sLGJvb2wpCiphYmlfcm91dGVfYm9vbFR1cGxlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgYm9vbFR1cGxlKCkoYm9vbCxib29sLGJvb2wsYm9vbCxib29sLGJvb2wsYm9vbCxib29sLGJvb2wpCgljYWxsc3ViIGJvb2xUdXBsZQoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBib29sVHVwbGUoKTogW2Jvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW5dCmJvb2xUdXBsZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglwdXNoYnl0ZXMgMHgKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6ODc5CgkvLyBhOiBbYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbl0gPSBbCgkvLyAgICAgICB0cnVlLAoJLy8gICAgICAgZmFsc2UsCgkvLyAgICAgICB0cnVlLAoJLy8gICAgICAgdHJ1ZSwKCS8vICAgICAgIGZhbHNlLAoJLy8gICAgICAgZmFsc2UsCgkvLyAgICAgICB0cnVlLAoJLy8gICAgICAgZmFsc2UsCgkvLyAgICAgICBmYWxzZSwKCS8vICAgICBdCglwdXNoYnl0ZXMgMHgwMDAwCglwdXNoaW50IDAKCXB1c2hpbnQgMQoJc2V0Yml0CglwdXNoaW50IDEKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDIKCXB1c2hpbnQgMQoJc2V0Yml0CglwdXNoaW50IDMKCXB1c2hpbnQgMQoJc2V0Yml0CglwdXNoaW50IDQKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDUKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDYKCXB1c2hpbnQgMQoJc2V0Yml0CglwdXNoaW50IDcKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDgKCXB1c2hpbnQgMAoJc2V0Yml0CglmcmFtZV9idXJ5IDAgLy8gYTogW2Jvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW5dCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjg5MQoJLy8gcmV0dXJuIGE7CglmcmFtZV9kaWcgMCAvLyBhOiBbYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbl0KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZDQ1OTNhZmUgLy8gbWV0aG9kICJib29sVHVwbGUoKShib29sLGJvb2wsYm9vbCxib29sLGJvb2wsYm9vbCxib29sLGJvb2wsYm9vbCkiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2Jvb2xUdXBsZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestBoolTupleAccess.approval.teal b/tests/contracts/artifacts/ABITestBoolTupleAccess.approval.teal index a2c391cd2..8c7fc3a48 100644 --- a/tests/contracts/artifacts/ABITestBoolTupleAccess.approval.teal +++ b/tests/contracts/artifacts/ABITestBoolTupleAccess.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 intcblock 0 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestBoolTupleAccess.arc32.json b/tests/contracts/artifacts/ABITestBoolTupleAccess.arc32.json index 3d05a1a2c..43f961f77 100644 --- a/tests/contracts/artifacts/ABITestBoolTupleAccess.arc32.json +++ b/tests/contracts/artifacts/ABITestBoolTupleAccess.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmludGNibG9jayAwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYm9vbFR1cGxlQWNjZXNzKClib29sCiphYmlfcm91dGVfYm9vbFR1cGxlQWNjZXNzOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgYm9vbFR1cGxlQWNjZXNzKClib29sCgljYWxsc3ViIGJvb2xUdXBsZUFjY2VzcwoJcHVzaGJ5dGVzIDB4MDAKCWludCAwCgl1bmNvdmVyIDIKCXNldGJpdAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBib29sVHVwbGVBY2Nlc3MoKTogYm9vbGVhbgpib29sVHVwbGVBY2Nlc3M6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjkwNQoJLy8gYTogW2Jvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW5dID0gWwoJLy8gICAgICAgZmFsc2UsCgkvLyAgICAgICBmYWxzZSwKCS8vICAgICAgIGZhbHNlLAoJLy8gICAgICAgZmFsc2UsCgkvLyAgICAgICBmYWxzZSwKCS8vICAgICAgIGZhbHNlLAoJLy8gICAgICAgZmFsc2UsCgkvLyAgICAgICBmYWxzZSwKCS8vICAgICAgIHRydWUsCgkvLyAgICAgXQoJcHVzaGJ5dGVzIDB4MDAwMAoJaW50IDAKCWR1cAoJc2V0Yml0CglwdXNoaW50IDEKCWludCAwCglzZXRiaXQKCXB1c2hpbnQgMgoJaW50IDAKCXNldGJpdAoJcHVzaGludCAzCglpbnQgMAoJc2V0Yml0CglwdXNoaW50IDQKCWludCAwCglzZXRiaXQKCXB1c2hpbnQgNQoJaW50IDAKCXNldGJpdAoJcHVzaGludCA2CglpbnQgMAoJc2V0Yml0CglwdXNoaW50IDcKCWludCAwCglzZXRiaXQKCXB1c2hpbnQgOAoJcHVzaGludCAxCglzZXRiaXQKCWZyYW1lX2J1cnkgMCAvLyBhOiBbYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbl0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6OTE3CgkvLyByZXR1cm4gYVs4XTsKCWZyYW1lX2RpZyAwIC8vIGE6IFtib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuXQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgOAoJZ2V0Yml0CgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGM4ZjI1ZWQxIC8vIG1ldGhvZCAiYm9vbFR1cGxlQWNjZXNzKClib29sIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9ib29sVHVwbGVBY2Nlc3MKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmludGNibG9jayAwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYm9vbFR1cGxlQWNjZXNzKClib29sCiphYmlfcm91dGVfYm9vbFR1cGxlQWNjZXNzOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgYm9vbFR1cGxlQWNjZXNzKClib29sCgljYWxsc3ViIGJvb2xUdXBsZUFjY2VzcwoJcHVzaGJ5dGVzIDB4MDAKCWludCAwCgl1bmNvdmVyIDIKCXNldGJpdAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBib29sVHVwbGVBY2Nlc3MoKTogYm9vbGVhbgpib29sVHVwbGVBY2Nlc3M6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjkwNQoJLy8gYTogW2Jvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW5dID0gWwoJLy8gICAgICAgZmFsc2UsCgkvLyAgICAgICBmYWxzZSwKCS8vICAgICAgIGZhbHNlLAoJLy8gICAgICAgZmFsc2UsCgkvLyAgICAgICBmYWxzZSwKCS8vICAgICAgIGZhbHNlLAoJLy8gICAgICAgZmFsc2UsCgkvLyAgICAgICBmYWxzZSwKCS8vICAgICAgIHRydWUsCgkvLyAgICAgXQoJcHVzaGJ5dGVzIDB4MDAwMAoJaW50IDAKCWR1cAoJc2V0Yml0CglwdXNoaW50IDEKCWludCAwCglzZXRiaXQKCXB1c2hpbnQgMgoJaW50IDAKCXNldGJpdAoJcHVzaGludCAzCglpbnQgMAoJc2V0Yml0CglwdXNoaW50IDQKCWludCAwCglzZXRiaXQKCXB1c2hpbnQgNQoJaW50IDAKCXNldGJpdAoJcHVzaGludCA2CglpbnQgMAoJc2V0Yml0CglwdXNoaW50IDcKCWludCAwCglzZXRiaXQKCXB1c2hpbnQgOAoJcHVzaGludCAxCglzZXRiaXQKCWZyYW1lX2J1cnkgMCAvLyBhOiBbYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbl0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6OTE3CgkvLyByZXR1cm4gYVs4XTsKCWZyYW1lX2RpZyAwIC8vIGE6IFtib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuXQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgOAoJZ2V0Yml0CgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGM4ZjI1ZWQxIC8vIG1ldGhvZCAiYm9vbFR1cGxlQWNjZXNzKClib29sIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9ib29sVHVwbGVBY2Nlc3MKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestBoolTupleAccess.arc56_draft.json b/tests/contracts/artifacts/ABITestBoolTupleAccess.arc56_draft.json index 4515fe055..af81a3446 100644 --- a/tests/contracts/artifacts/ABITestBoolTupleAccess.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestBoolTupleAccess.arc56_draft.json @@ -643,7 +643,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmludGNibG9jayAwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYm9vbFR1cGxlQWNjZXNzKClib29sCiphYmlfcm91dGVfYm9vbFR1cGxlQWNjZXNzOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgYm9vbFR1cGxlQWNjZXNzKClib29sCgljYWxsc3ViIGJvb2xUdXBsZUFjY2VzcwoJcHVzaGJ5dGVzIDB4MDAKCWludCAwCgl1bmNvdmVyIDIKCXNldGJpdAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBib29sVHVwbGVBY2Nlc3MoKTogYm9vbGVhbgpib29sVHVwbGVBY2Nlc3M6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjkwNQoJLy8gYTogW2Jvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW5dID0gWwoJLy8gICAgICAgZmFsc2UsCgkvLyAgICAgICBmYWxzZSwKCS8vICAgICAgIGZhbHNlLAoJLy8gICAgICAgZmFsc2UsCgkvLyAgICAgICBmYWxzZSwKCS8vICAgICAgIGZhbHNlLAoJLy8gICAgICAgZmFsc2UsCgkvLyAgICAgICBmYWxzZSwKCS8vICAgICAgIHRydWUsCgkvLyAgICAgXQoJcHVzaGJ5dGVzIDB4MDAwMAoJaW50IDAKCWR1cAoJc2V0Yml0CglwdXNoaW50IDEKCWludCAwCglzZXRiaXQKCXB1c2hpbnQgMgoJaW50IDAKCXNldGJpdAoJcHVzaGludCAzCglpbnQgMAoJc2V0Yml0CglwdXNoaW50IDQKCWludCAwCglzZXRiaXQKCXB1c2hpbnQgNQoJaW50IDAKCXNldGJpdAoJcHVzaGludCA2CglpbnQgMAoJc2V0Yml0CglwdXNoaW50IDcKCWludCAwCglzZXRiaXQKCXB1c2hpbnQgOAoJcHVzaGludCAxCglzZXRiaXQKCWZyYW1lX2J1cnkgMCAvLyBhOiBbYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbl0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6OTE3CgkvLyByZXR1cm4gYVs4XTsKCWZyYW1lX2RpZyAwIC8vIGE6IFtib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuXQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgOAoJZ2V0Yml0CgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGM4ZjI1ZWQxIC8vIG1ldGhvZCAiYm9vbFR1cGxlQWNjZXNzKClib29sIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9ib29sVHVwbGVBY2Nlc3MKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmludGNibG9jayAwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYm9vbFR1cGxlQWNjZXNzKClib29sCiphYmlfcm91dGVfYm9vbFR1cGxlQWNjZXNzOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgYm9vbFR1cGxlQWNjZXNzKClib29sCgljYWxsc3ViIGJvb2xUdXBsZUFjY2VzcwoJcHVzaGJ5dGVzIDB4MDAKCWludCAwCgl1bmNvdmVyIDIKCXNldGJpdAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBib29sVHVwbGVBY2Nlc3MoKTogYm9vbGVhbgpib29sVHVwbGVBY2Nlc3M6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjkwNQoJLy8gYTogW2Jvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW5dID0gWwoJLy8gICAgICAgZmFsc2UsCgkvLyAgICAgICBmYWxzZSwKCS8vICAgICAgIGZhbHNlLAoJLy8gICAgICAgZmFsc2UsCgkvLyAgICAgICBmYWxzZSwKCS8vICAgICAgIGZhbHNlLAoJLy8gICAgICAgZmFsc2UsCgkvLyAgICAgICBmYWxzZSwKCS8vICAgICAgIHRydWUsCgkvLyAgICAgXQoJcHVzaGJ5dGVzIDB4MDAwMAoJaW50IDAKCWR1cAoJc2V0Yml0CglwdXNoaW50IDEKCWludCAwCglzZXRiaXQKCXB1c2hpbnQgMgoJaW50IDAKCXNldGJpdAoJcHVzaGludCAzCglpbnQgMAoJc2V0Yml0CglwdXNoaW50IDQKCWludCAwCglzZXRiaXQKCXB1c2hpbnQgNQoJaW50IDAKCXNldGJpdAoJcHVzaGludCA2CglpbnQgMAoJc2V0Yml0CglwdXNoaW50IDcKCWludCAwCglzZXRiaXQKCXB1c2hpbnQgOAoJcHVzaGludCAxCglzZXRiaXQKCWZyYW1lX2J1cnkgMCAvLyBhOiBbYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbl0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6OTE3CgkvLyByZXR1cm4gYVs4XTsKCWZyYW1lX2RpZyAwIC8vIGE6IFtib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuXQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgOAoJZ2V0Yml0CgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGM4ZjI1ZWQxIC8vIG1ldGhvZCAiYm9vbFR1cGxlQWNjZXNzKClib29sIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9ib29sVHVwbGVBY2Nlc3MKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestBoolTupleUpdate.approval.teal b/tests/contracts/artifacts/ABITestBoolTupleUpdate.approval.teal index f4a71efc5..3f47a3459 100644 --- a/tests/contracts/artifacts/ABITestBoolTupleUpdate.approval.teal +++ b/tests/contracts/artifacts/ABITestBoolTupleUpdate.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 intcblock 1 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestBoolTupleUpdate.arc32.json b/tests/contracts/artifacts/ABITestBoolTupleUpdate.arc32.json index 4b96b470c..7fdb0ca22 100644 --- a/tests/contracts/artifacts/ABITestBoolTupleUpdate.arc32.json +++ b/tests/contracts/artifacts/ABITestBoolTupleUpdate.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmludGNibG9jayAxCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYm9vbFR1cGxlVXBkYXRlKCkoYm9vbCxib29sLGJvb2wsYm9vbCxib29sLGJvb2wsYm9vbCxib29sLGJvb2wpCiphYmlfcm91dGVfYm9vbFR1cGxlVXBkYXRlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgYm9vbFR1cGxlVXBkYXRlKCkoYm9vbCxib29sLGJvb2wsYm9vbCxib29sLGJvb2wsYm9vbCxib29sLGJvb2wpCgljYWxsc3ViIGJvb2xUdXBsZVVwZGF0ZQoJY29uY2F0Cglsb2cKCWludCAxCglyZXR1cm4KCi8vIGJvb2xUdXBsZVVwZGF0ZSgpOiBbYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbl0KYm9vbFR1cGxlVXBkYXRlOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo5NjcKCS8vIGE6IFtib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuXSA9IFsKCS8vICAgICAgIHRydWUsCgkvLyAgICAgICBmYWxzZSwKCS8vICAgICAgIHRydWUsCgkvLyAgICAgICB0cnVlLAoJLy8gICAgICAgZmFsc2UsCgkvLyAgICAgICBmYWxzZSwKCS8vICAgICAgIHRydWUsCgkvLyAgICAgICBmYWxzZSwKCS8vICAgICAgIGZhbHNlLAoJLy8gICAgIF0KCXB1c2hieXRlcyAweDAwMDAKCXB1c2hpbnQgMAoJaW50IDEKCXNldGJpdAoJaW50IDEKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDIKCWludCAxCglzZXRiaXQKCXB1c2hpbnQgMwoJaW50IDEKCXNldGJpdAoJcHVzaGludCA0CglwdXNoaW50IDAKCXNldGJpdAoJcHVzaGludCA1CglwdXNoaW50IDAKCXNldGJpdAoJcHVzaGludCA2CglpbnQgMQoJc2V0Yml0CglwdXNoaW50IDcKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDgKCXB1c2hpbnQgMAoJc2V0Yml0CglmcmFtZV9idXJ5IDAgLy8gYTogW2Jvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW5dCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjk3OQoJLy8gYVs4XSA9IHRydWUKCWZyYW1lX2RpZyAwIC8vIGE6IFtib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuXQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgOAoJaW50IDEKCXNldGJpdAoJZnJhbWVfYnVyeSAwIC8vIGE6IFtib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo5ODAKCS8vIHJldHVybiBhOwoJZnJhbWVfZGlnIDAgLy8gYTogW2Jvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW5dCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MmExOGJiN2QgLy8gbWV0aG9kICJib29sVHVwbGVVcGRhdGUoKShib29sLGJvb2wsYm9vbCxib29sLGJvb2wsYm9vbCxib29sLGJvb2wsYm9vbCkiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2Jvb2xUdXBsZVVwZGF0ZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmludGNibG9jayAxCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYm9vbFR1cGxlVXBkYXRlKCkoYm9vbCxib29sLGJvb2wsYm9vbCxib29sLGJvb2wsYm9vbCxib29sLGJvb2wpCiphYmlfcm91dGVfYm9vbFR1cGxlVXBkYXRlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgYm9vbFR1cGxlVXBkYXRlKCkoYm9vbCxib29sLGJvb2wsYm9vbCxib29sLGJvb2wsYm9vbCxib29sLGJvb2wpCgljYWxsc3ViIGJvb2xUdXBsZVVwZGF0ZQoJY29uY2F0Cglsb2cKCWludCAxCglyZXR1cm4KCi8vIGJvb2xUdXBsZVVwZGF0ZSgpOiBbYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbl0KYm9vbFR1cGxlVXBkYXRlOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo5NjcKCS8vIGE6IFtib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuXSA9IFsKCS8vICAgICAgIHRydWUsCgkvLyAgICAgICBmYWxzZSwKCS8vICAgICAgIHRydWUsCgkvLyAgICAgICB0cnVlLAoJLy8gICAgICAgZmFsc2UsCgkvLyAgICAgICBmYWxzZSwKCS8vICAgICAgIHRydWUsCgkvLyAgICAgICBmYWxzZSwKCS8vICAgICAgIGZhbHNlLAoJLy8gICAgIF0KCXB1c2hieXRlcyAweDAwMDAKCXB1c2hpbnQgMAoJaW50IDEKCXNldGJpdAoJaW50IDEKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDIKCWludCAxCglzZXRiaXQKCXB1c2hpbnQgMwoJaW50IDEKCXNldGJpdAoJcHVzaGludCA0CglwdXNoaW50IDAKCXNldGJpdAoJcHVzaGludCA1CglwdXNoaW50IDAKCXNldGJpdAoJcHVzaGludCA2CglpbnQgMQoJc2V0Yml0CglwdXNoaW50IDcKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDgKCXB1c2hpbnQgMAoJc2V0Yml0CglmcmFtZV9idXJ5IDAgLy8gYTogW2Jvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW5dCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjk3OQoJLy8gYVs4XSA9IHRydWUKCWZyYW1lX2RpZyAwIC8vIGE6IFtib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuXQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgOAoJaW50IDEKCXNldGJpdAoJZnJhbWVfYnVyeSAwIC8vIGE6IFtib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo5ODAKCS8vIHJldHVybiBhOwoJZnJhbWVfZGlnIDAgLy8gYTogW2Jvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW5dCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MmExOGJiN2QgLy8gbWV0aG9kICJib29sVHVwbGVVcGRhdGUoKShib29sLGJvb2wsYm9vbCxib29sLGJvb2wsYm9vbCxib29sLGJvb2wsYm9vbCkiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2Jvb2xUdXBsZVVwZGF0ZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestBoolTupleUpdate.arc56_draft.json b/tests/contracts/artifacts/ABITestBoolTupleUpdate.arc56_draft.json index 97fa3e5c5..435e3e942 100644 --- a/tests/contracts/artifacts/ABITestBoolTupleUpdate.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestBoolTupleUpdate.arc56_draft.json @@ -636,7 +636,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmludGNibG9jayAxCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYm9vbFR1cGxlVXBkYXRlKCkoYm9vbCxib29sLGJvb2wsYm9vbCxib29sLGJvb2wsYm9vbCxib29sLGJvb2wpCiphYmlfcm91dGVfYm9vbFR1cGxlVXBkYXRlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgYm9vbFR1cGxlVXBkYXRlKCkoYm9vbCxib29sLGJvb2wsYm9vbCxib29sLGJvb2wsYm9vbCxib29sLGJvb2wpCgljYWxsc3ViIGJvb2xUdXBsZVVwZGF0ZQoJY29uY2F0Cglsb2cKCWludCAxCglyZXR1cm4KCi8vIGJvb2xUdXBsZVVwZGF0ZSgpOiBbYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbl0KYm9vbFR1cGxlVXBkYXRlOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo5NjcKCS8vIGE6IFtib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuXSA9IFsKCS8vICAgICAgIHRydWUsCgkvLyAgICAgICBmYWxzZSwKCS8vICAgICAgIHRydWUsCgkvLyAgICAgICB0cnVlLAoJLy8gICAgICAgZmFsc2UsCgkvLyAgICAgICBmYWxzZSwKCS8vICAgICAgIHRydWUsCgkvLyAgICAgICBmYWxzZSwKCS8vICAgICAgIGZhbHNlLAoJLy8gICAgIF0KCXB1c2hieXRlcyAweDAwMDAKCXB1c2hpbnQgMAoJaW50IDEKCXNldGJpdAoJaW50IDEKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDIKCWludCAxCglzZXRiaXQKCXB1c2hpbnQgMwoJaW50IDEKCXNldGJpdAoJcHVzaGludCA0CglwdXNoaW50IDAKCXNldGJpdAoJcHVzaGludCA1CglwdXNoaW50IDAKCXNldGJpdAoJcHVzaGludCA2CglpbnQgMQoJc2V0Yml0CglwdXNoaW50IDcKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDgKCXB1c2hpbnQgMAoJc2V0Yml0CglmcmFtZV9idXJ5IDAgLy8gYTogW2Jvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW5dCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjk3OQoJLy8gYVs4XSA9IHRydWUKCWZyYW1lX2RpZyAwIC8vIGE6IFtib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuXQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgOAoJaW50IDEKCXNldGJpdAoJZnJhbWVfYnVyeSAwIC8vIGE6IFtib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo5ODAKCS8vIHJldHVybiBhOwoJZnJhbWVfZGlnIDAgLy8gYTogW2Jvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW5dCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MmExOGJiN2QgLy8gbWV0aG9kICJib29sVHVwbGVVcGRhdGUoKShib29sLGJvb2wsYm9vbCxib29sLGJvb2wsYm9vbCxib29sLGJvb2wsYm9vbCkiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2Jvb2xUdXBsZVVwZGF0ZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmludGNibG9jayAxCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYm9vbFR1cGxlVXBkYXRlKCkoYm9vbCxib29sLGJvb2wsYm9vbCxib29sLGJvb2wsYm9vbCxib29sLGJvb2wpCiphYmlfcm91dGVfYm9vbFR1cGxlVXBkYXRlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgYm9vbFR1cGxlVXBkYXRlKCkoYm9vbCxib29sLGJvb2wsYm9vbCxib29sLGJvb2wsYm9vbCxib29sLGJvb2wpCgljYWxsc3ViIGJvb2xUdXBsZVVwZGF0ZQoJY29uY2F0Cglsb2cKCWludCAxCglyZXR1cm4KCi8vIGJvb2xUdXBsZVVwZGF0ZSgpOiBbYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbiwgYm9vbGVhbl0KYm9vbFR1cGxlVXBkYXRlOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo5NjcKCS8vIGE6IFtib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuXSA9IFsKCS8vICAgICAgIHRydWUsCgkvLyAgICAgICBmYWxzZSwKCS8vICAgICAgIHRydWUsCgkvLyAgICAgICB0cnVlLAoJLy8gICAgICAgZmFsc2UsCgkvLyAgICAgICBmYWxzZSwKCS8vICAgICAgIHRydWUsCgkvLyAgICAgICBmYWxzZSwKCS8vICAgICAgIGZhbHNlLAoJLy8gICAgIF0KCXB1c2hieXRlcyAweDAwMDAKCXB1c2hpbnQgMAoJaW50IDEKCXNldGJpdAoJaW50IDEKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDIKCWludCAxCglzZXRiaXQKCXB1c2hpbnQgMwoJaW50IDEKCXNldGJpdAoJcHVzaGludCA0CglwdXNoaW50IDAKCXNldGJpdAoJcHVzaGludCA1CglwdXNoaW50IDAKCXNldGJpdAoJcHVzaGludCA2CglpbnQgMQoJc2V0Yml0CglwdXNoaW50IDcKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDgKCXB1c2hpbnQgMAoJc2V0Yml0CglmcmFtZV9idXJ5IDAgLy8gYTogW2Jvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW5dCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjk3OQoJLy8gYVs4XSA9IHRydWUKCWZyYW1lX2RpZyAwIC8vIGE6IFtib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuXQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgOAoJaW50IDEKCXNldGJpdAoJZnJhbWVfYnVyeSAwIC8vIGE6IFtib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuLCBib29sZWFuXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo5ODAKCS8vIHJldHVybiBhOwoJZnJhbWVfZGlnIDAgLy8gYTogW2Jvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW4sIGJvb2xlYW5dCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MmExOGJiN2QgLy8gbWV0aG9kICJib29sVHVwbGVVcGRhdGUoKShib29sLGJvb2wsYm9vbCxib29sLGJvb2wsYm9vbCxib29sLGJvb2wsYm9vbCkiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2Jvb2xUdXBsZVVwZGF0ZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestBooleanArgAndReturn.approval.teal b/tests/contracts/artifacts/ABITestBooleanArgAndReturn.approval.teal index 437fea5f4..0cef310b1 100644 --- a/tests/contracts/artifacts/ABITestBooleanArgAndReturn.approval.teal +++ b/tests/contracts/artifacts/ABITestBooleanArgAndReturn.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestBooleanArgAndReturn.arc32.json b/tests/contracts/artifacts/ABITestBooleanArgAndReturn.arc32.json index afae2ed3c..6b29dc4ac 100644 --- a/tests/contracts/artifacts/ABITestBooleanArgAndReturn.arc32.json +++ b/tests/contracts/artifacts/ABITestBooleanArgAndReturn.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYm9vbGVhbkFyZ0FuZFJldHVybihib29sKWJvb2wKKmFiaV9yb3V0ZV9ib29sZWFuQXJnQW5kUmV0dXJuOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGE6IGJvb2wKCXR4bmEgQXBwbGljYXRpb25BcmdzIDEKCWR1cAoJbGVuCglwdXNoaW50IDEKCT09CgoJLy8gYXJndW1lbnQgMCAoYSkgZm9yIGJvb2xlYW5BcmdBbmRSZXR1cm4gbXVzdCBiZSBhIGJvb2wKCWFzc2VydAoJcHVzaGludCAwCglnZXRiaXQKCgkvLyBleGVjdXRlIGJvb2xlYW5BcmdBbmRSZXR1cm4oYm9vbClib29sCgljYWxsc3ViIGJvb2xlYW5BcmdBbmRSZXR1cm4KCXB1c2hieXRlcyAweDAwCglwdXNoaW50IDAKCXVuY292ZXIgMgoJc2V0Yml0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGJvb2xlYW5BcmdBbmRSZXR1cm4oYTogYm9vbGVhbik6IGJvb2xlYW4KYm9vbGVhbkFyZ0FuZFJldHVybjoKCXByb3RvIDEgMQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4NzMKCS8vIHJldHVybiBhOwoJZnJhbWVfZGlnIC0xIC8vIGE6IGJvb2xlYW4KCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZjRkMGU1MmUgLy8gbWV0aG9kICJib29sZWFuQXJnQW5kUmV0dXJuKGJvb2wpYm9vbCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfYm9vbGVhbkFyZ0FuZFJldHVybgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYm9vbGVhbkFyZ0FuZFJldHVybihib29sKWJvb2wKKmFiaV9yb3V0ZV9ib29sZWFuQXJnQW5kUmV0dXJuOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGE6IGJvb2wKCXR4bmEgQXBwbGljYXRpb25BcmdzIDEKCWR1cAoJbGVuCglwdXNoaW50IDEKCT09CgoJLy8gYXJndW1lbnQgMCAoYSkgZm9yIGJvb2xlYW5BcmdBbmRSZXR1cm4gbXVzdCBiZSBhIGJvb2wKCWFzc2VydAoJcHVzaGludCAwCglnZXRiaXQKCgkvLyBleGVjdXRlIGJvb2xlYW5BcmdBbmRSZXR1cm4oYm9vbClib29sCgljYWxsc3ViIGJvb2xlYW5BcmdBbmRSZXR1cm4KCXB1c2hieXRlcyAweDAwCglwdXNoaW50IDAKCXVuY292ZXIgMgoJc2V0Yml0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGJvb2xlYW5BcmdBbmRSZXR1cm4oYTogYm9vbGVhbik6IGJvb2xlYW4KYm9vbGVhbkFyZ0FuZFJldHVybjoKCXByb3RvIDEgMQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4NzMKCS8vIHJldHVybiBhOwoJZnJhbWVfZGlnIC0xIC8vIGE6IGJvb2xlYW4KCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZjRkMGU1MmUgLy8gbWV0aG9kICJib29sZWFuQXJnQW5kUmV0dXJuKGJvb2wpYm9vbCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfYm9vbGVhbkFyZ0FuZFJldHVybgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestBooleanArgAndReturn.arc56_draft.json b/tests/contracts/artifacts/ABITestBooleanArgAndReturn.arc56_draft.json index 9c604a09e..600a39e70 100644 --- a/tests/contracts/artifacts/ABITestBooleanArgAndReturn.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestBooleanArgAndReturn.arc56_draft.json @@ -429,7 +429,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYm9vbGVhbkFyZ0FuZFJldHVybihib29sKWJvb2wKKmFiaV9yb3V0ZV9ib29sZWFuQXJnQW5kUmV0dXJuOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGE6IGJvb2wKCXR4bmEgQXBwbGljYXRpb25BcmdzIDEKCWR1cAoJbGVuCglwdXNoaW50IDEKCT09CgoJLy8gYXJndW1lbnQgMCAoYSkgZm9yIGJvb2xlYW5BcmdBbmRSZXR1cm4gbXVzdCBiZSBhIGJvb2wKCWFzc2VydAoJcHVzaGludCAwCglnZXRiaXQKCgkvLyBleGVjdXRlIGJvb2xlYW5BcmdBbmRSZXR1cm4oYm9vbClib29sCgljYWxsc3ViIGJvb2xlYW5BcmdBbmRSZXR1cm4KCXB1c2hieXRlcyAweDAwCglwdXNoaW50IDAKCXVuY292ZXIgMgoJc2V0Yml0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGJvb2xlYW5BcmdBbmRSZXR1cm4oYTogYm9vbGVhbik6IGJvb2xlYW4KYm9vbGVhbkFyZ0FuZFJldHVybjoKCXByb3RvIDEgMQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4NzMKCS8vIHJldHVybiBhOwoJZnJhbWVfZGlnIC0xIC8vIGE6IGJvb2xlYW4KCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZjRkMGU1MmUgLy8gbWV0aG9kICJib29sZWFuQXJnQW5kUmV0dXJuKGJvb2wpYm9vbCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfYm9vbGVhbkFyZ0FuZFJldHVybgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYm9vbGVhbkFyZ0FuZFJldHVybihib29sKWJvb2wKKmFiaV9yb3V0ZV9ib29sZWFuQXJnQW5kUmV0dXJuOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGE6IGJvb2wKCXR4bmEgQXBwbGljYXRpb25BcmdzIDEKCWR1cAoJbGVuCglwdXNoaW50IDEKCT09CgoJLy8gYXJndW1lbnQgMCAoYSkgZm9yIGJvb2xlYW5BcmdBbmRSZXR1cm4gbXVzdCBiZSBhIGJvb2wKCWFzc2VydAoJcHVzaGludCAwCglnZXRiaXQKCgkvLyBleGVjdXRlIGJvb2xlYW5BcmdBbmRSZXR1cm4oYm9vbClib29sCgljYWxsc3ViIGJvb2xlYW5BcmdBbmRSZXR1cm4KCXB1c2hieXRlcyAweDAwCglwdXNoaW50IDAKCXVuY292ZXIgMgoJc2V0Yml0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGJvb2xlYW5BcmdBbmRSZXR1cm4oYTogYm9vbGVhbik6IGJvb2xlYW4KYm9vbGVhbkFyZ0FuZFJldHVybjoKCXByb3RvIDEgMQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4NzMKCS8vIHJldHVybiBhOwoJZnJhbWVfZGlnIC0xIC8vIGE6IGJvb2xlYW4KCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZjRkMGU1MmUgLy8gbWV0aG9kICJib29sZWFuQXJnQW5kUmV0dXJuKGJvb2wpYm9vbCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfYm9vbGVhbkFyZ0FuZFJldHVybgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestBooleanLastInObj.approval.teal b/tests/contracts/artifacts/ABITestBooleanLastInObj.approval.teal index b42d99336..fc53619b6 100644 --- a/tests/contracts/artifacts/ABITestBooleanLastInObj.approval.teal +++ b/tests/contracts/artifacts/ABITestBooleanLastInObj.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestBooleanLastInObj.arc32.json b/tests/contracts/artifacts/ABITestBooleanLastInObj.arc32.json index 55c27a7b5..9e2b6e596 100644 --- a/tests/contracts/artifacts/ABITestBooleanLastInObj.arc32.json +++ b/tests/contracts/artifacts/ABITestBooleanLastInObj.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYm9vbGVhbkxhc3RJbk9iaigpKHVpbnQ2NCxib29sKQoqYWJpX3JvdXRlX2Jvb2xlYW5MYXN0SW5PYmo6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBib29sZWFuTGFzdEluT2JqKCkodWludDY0LGJvb2wpCgljYWxsc3ViIGJvb2xlYW5MYXN0SW5PYmoKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gYm9vbGVhbkxhc3RJbk9iaigpOiB7IG46IHVpbnQ2NDsgYjogYm9vbGVhbiB9CmJvb2xlYW5MYXN0SW5PYmo6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTI2NQoJLy8gcmV0dXJuIHsKCS8vICAgICAgIG46IDEsCgkvLyAgICAgICBiOiBmYWxzZSwKCS8vICAgICB9OwoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMQoJcHVzaGJ5dGVzIDB4MDAKCXB1c2hpbnQgMAoJcHVzaGludCAwCglzZXRiaXQKCWNvbmNhdAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg2NmM4OTBjYSAvLyBtZXRob2QgImJvb2xlYW5MYXN0SW5PYmooKSh1aW50NjQsYm9vbCkiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2Jvb2xlYW5MYXN0SW5PYmoKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYm9vbGVhbkxhc3RJbk9iaigpKHVpbnQ2NCxib29sKQoqYWJpX3JvdXRlX2Jvb2xlYW5MYXN0SW5PYmo6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBib29sZWFuTGFzdEluT2JqKCkodWludDY0LGJvb2wpCgljYWxsc3ViIGJvb2xlYW5MYXN0SW5PYmoKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gYm9vbGVhbkxhc3RJbk9iaigpOiB7IG46IHVpbnQ2NDsgYjogYm9vbGVhbiB9CmJvb2xlYW5MYXN0SW5PYmo6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTI2NQoJLy8gcmV0dXJuIHsKCS8vICAgICAgIG46IDEsCgkvLyAgICAgICBiOiBmYWxzZSwKCS8vICAgICB9OwoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMQoJcHVzaGJ5dGVzIDB4MDAKCXB1c2hpbnQgMAoJcHVzaGludCAwCglzZXRiaXQKCWNvbmNhdAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg2NmM4OTBjYSAvLyBtZXRob2QgImJvb2xlYW5MYXN0SW5PYmooKSh1aW50NjQsYm9vbCkiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2Jvb2xlYW5MYXN0SW5PYmoKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestBooleanLastInObj.arc56_draft.json b/tests/contracts/artifacts/ABITestBooleanLastInObj.arc56_draft.json index 9b388d485..160aece32 100644 --- a/tests/contracts/artifacts/ABITestBooleanLastInObj.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestBooleanLastInObj.arc56_draft.json @@ -390,7 +390,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYm9vbGVhbkxhc3RJbk9iaigpKHVpbnQ2NCxib29sKQoqYWJpX3JvdXRlX2Jvb2xlYW5MYXN0SW5PYmo6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBib29sZWFuTGFzdEluT2JqKCkodWludDY0LGJvb2wpCgljYWxsc3ViIGJvb2xlYW5MYXN0SW5PYmoKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gYm9vbGVhbkxhc3RJbk9iaigpOiB7IG46IHVpbnQ2NDsgYjogYm9vbGVhbiB9CmJvb2xlYW5MYXN0SW5PYmo6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTI2NQoJLy8gcmV0dXJuIHsKCS8vICAgICAgIG46IDEsCgkvLyAgICAgICBiOiBmYWxzZSwKCS8vICAgICB9OwoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMQoJcHVzaGJ5dGVzIDB4MDAKCXB1c2hpbnQgMAoJcHVzaGludCAwCglzZXRiaXQKCWNvbmNhdAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg2NmM4OTBjYSAvLyBtZXRob2QgImJvb2xlYW5MYXN0SW5PYmooKSh1aW50NjQsYm9vbCkiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2Jvb2xlYW5MYXN0SW5PYmoKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYm9vbGVhbkxhc3RJbk9iaigpKHVpbnQ2NCxib29sKQoqYWJpX3JvdXRlX2Jvb2xlYW5MYXN0SW5PYmo6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBib29sZWFuTGFzdEluT2JqKCkodWludDY0LGJvb2wpCgljYWxsc3ViIGJvb2xlYW5MYXN0SW5PYmoKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gYm9vbGVhbkxhc3RJbk9iaigpOiB7IG46IHVpbnQ2NDsgYjogYm9vbGVhbiB9CmJvb2xlYW5MYXN0SW5PYmo6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTI2NQoJLy8gcmV0dXJuIHsKCS8vICAgICAgIG46IDEsCgkvLyAgICAgICBiOiBmYWxzZSwKCS8vICAgICB9OwoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMQoJcHVzaGJ5dGVzIDB4MDAKCXB1c2hpbnQgMAoJcHVzaGludCAwCglzZXRiaXQKCWNvbmNhdAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg2NmM4OTBjYSAvLyBtZXRob2QgImJvb2xlYW5MYXN0SW5PYmooKSh1aW50NjQsYm9vbCkiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2Jvb2xlYW5MYXN0SW5PYmoKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestBytesCasting.approval.teal b/tests/contracts/artifacts/ABITestBytesCasting.approval.teal index 4bb9cfb8c..76eb5964a 100644 --- a/tests/contracts/artifacts/ABITestBytesCasting.approval.teal +++ b/tests/contracts/artifacts/ABITestBytesCasting.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestBytesCasting.arc32.json b/tests/contracts/artifacts/ABITestBytesCasting.arc32.json index dab28db99..cfcea198b 100644 --- a/tests/contracts/artifacts/ABITestBytesCasting.arc32.json +++ b/tests/contracts/artifacts/ABITestBytesCasting.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYnl0ZXNDYXN0aW5nKGJ5dGVbXSlieXRlWzJdCiphYmlfcm91dGVfYnl0ZXNDYXN0aW5nOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGE6IGJ5dGVbXQoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJZXh0cmFjdCAyIDAKCgkvLyBleGVjdXRlIGJ5dGVzQ2FzdGluZyhieXRlW10pYnl0ZVsyXQoJY2FsbHN1YiBieXRlc0Nhc3RpbmcKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gYnl0ZXNDYXN0aW5nKGE6IGJ5dGVzKTogYnl0ZXM8Mj4KYnl0ZXNDYXN0aW5nOgoJcHJvdG8gMSAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEyMDEKCS8vIHJldHVybiA8Ynl0ZXM8Mj4+YTsKCWZyYW1lX2RpZyAtMSAvLyBhOiBieXRlcwoJcHVzaGJ5dGVzIDB4MDAwMAoJY29uY2F0CglkdXAKCWV4dHJhY3QgMiAwCglwdXNoYnl0ZXMgMHgKCWI9PQoJYXNzZXJ0CglleHRyYWN0IDAgMgoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg5Nzg5Yzc1YiAvLyBtZXRob2QgImJ5dGVzQ2FzdGluZyhieXRlW10pYnl0ZVsyXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfYnl0ZXNDYXN0aW5nCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYnl0ZXNDYXN0aW5nKGJ5dGVbXSlieXRlWzJdCiphYmlfcm91dGVfYnl0ZXNDYXN0aW5nOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGE6IGJ5dGVbXQoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJZXh0cmFjdCAyIDAKCgkvLyBleGVjdXRlIGJ5dGVzQ2FzdGluZyhieXRlW10pYnl0ZVsyXQoJY2FsbHN1YiBieXRlc0Nhc3RpbmcKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gYnl0ZXNDYXN0aW5nKGE6IGJ5dGVzKTogYnl0ZXM8Mj4KYnl0ZXNDYXN0aW5nOgoJcHJvdG8gMSAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEyMDEKCS8vIHJldHVybiA8Ynl0ZXM8Mj4+YTsKCWZyYW1lX2RpZyAtMSAvLyBhOiBieXRlcwoJcHVzaGJ5dGVzIDB4MDAwMAoJY29uY2F0CglkdXAKCWV4dHJhY3QgMiAwCglwdXNoYnl0ZXMgMHgKCWI9PQoJYXNzZXJ0CglleHRyYWN0IDAgMgoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg5Nzg5Yzc1YiAvLyBtZXRob2QgImJ5dGVzQ2FzdGluZyhieXRlW10pYnl0ZVsyXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfYnl0ZXNDYXN0aW5nCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestBytesCasting.arc56_draft.json b/tests/contracts/artifacts/ABITestBytesCasting.arc56_draft.json index b6d678893..7fd966868 100644 --- a/tests/contracts/artifacts/ABITestBytesCasting.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestBytesCasting.arc56_draft.json @@ -418,7 +418,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYnl0ZXNDYXN0aW5nKGJ5dGVbXSlieXRlWzJdCiphYmlfcm91dGVfYnl0ZXNDYXN0aW5nOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGE6IGJ5dGVbXQoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJZXh0cmFjdCAyIDAKCgkvLyBleGVjdXRlIGJ5dGVzQ2FzdGluZyhieXRlW10pYnl0ZVsyXQoJY2FsbHN1YiBieXRlc0Nhc3RpbmcKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gYnl0ZXNDYXN0aW5nKGE6IGJ5dGVzKTogYnl0ZXM8Mj4KYnl0ZXNDYXN0aW5nOgoJcHJvdG8gMSAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEyMDEKCS8vIHJldHVybiA8Ynl0ZXM8Mj4+YTsKCWZyYW1lX2RpZyAtMSAvLyBhOiBieXRlcwoJcHVzaGJ5dGVzIDB4MDAwMAoJY29uY2F0CglkdXAKCWV4dHJhY3QgMiAwCglwdXNoYnl0ZXMgMHgKCWI9PQoJYXNzZXJ0CglleHRyYWN0IDAgMgoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg5Nzg5Yzc1YiAvLyBtZXRob2QgImJ5dGVzQ2FzdGluZyhieXRlW10pYnl0ZVsyXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfYnl0ZXNDYXN0aW5nCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYnl0ZXNDYXN0aW5nKGJ5dGVbXSlieXRlWzJdCiphYmlfcm91dGVfYnl0ZXNDYXN0aW5nOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGE6IGJ5dGVbXQoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJZXh0cmFjdCAyIDAKCgkvLyBleGVjdXRlIGJ5dGVzQ2FzdGluZyhieXRlW10pYnl0ZVsyXQoJY2FsbHN1YiBieXRlc0Nhc3RpbmcKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gYnl0ZXNDYXN0aW5nKGE6IGJ5dGVzKTogYnl0ZXM8Mj4KYnl0ZXNDYXN0aW5nOgoJcHJvdG8gMSAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEyMDEKCS8vIHJldHVybiA8Ynl0ZXM8Mj4+YTsKCWZyYW1lX2RpZyAtMSAvLyBhOiBieXRlcwoJcHVzaGJ5dGVzIDB4MDAwMAoJY29uY2F0CglkdXAKCWV4dHJhY3QgMiAwCglwdXNoYnl0ZXMgMHgKCWI9PQoJYXNzZXJ0CglleHRyYWN0IDAgMgoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg5Nzg5Yzc1YiAvLyBtZXRob2QgImJ5dGVzQ2FzdGluZyhieXRlW10pYnl0ZVsyXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfYnl0ZXNDYXN0aW5nCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestBytesReturn.approval.teal b/tests/contracts/artifacts/ABITestBytesReturn.approval.teal index 8e2a9d726..3ca764cc3 100644 --- a/tests/contracts/artifacts/ABITestBytesReturn.approval.teal +++ b/tests/contracts/artifacts/ABITestBytesReturn.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestBytesReturn.arc32.json b/tests/contracts/artifacts/ABITestBytesReturn.arc32.json index d40b5e3f2..7dd8be560 100644 --- a/tests/contracts/artifacts/ABITestBytesReturn.arc32.json +++ b/tests/contracts/artifacts/ABITestBytesReturn.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYnl0ZXNSZXR1cm4oKWJ5dGVbXQoqYWJpX3JvdXRlX2J5dGVzUmV0dXJuOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgYnl0ZXNSZXR1cm4oKWJ5dGVbXQoJY2FsbHN1YiBieXRlc1JldHVybgoJZHVwCglsZW4KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gYnl0ZXNSZXR1cm4oKTogYnl0ZXMKYnl0ZXNSZXR1cm46Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTEyNgoJLy8gcmV0dXJuICdmb28nOwoJcHVzaGJ5dGVzIDB4NjY2ZjZmIC8vICJmb28iCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDIwOGJjZjk3IC8vIG1ldGhvZCAiYnl0ZXNSZXR1cm4oKWJ5dGVbXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfYnl0ZXNSZXR1cm4KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYnl0ZXNSZXR1cm4oKWJ5dGVbXQoqYWJpX3JvdXRlX2J5dGVzUmV0dXJuOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgYnl0ZXNSZXR1cm4oKWJ5dGVbXQoJY2FsbHN1YiBieXRlc1JldHVybgoJZHVwCglsZW4KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gYnl0ZXNSZXR1cm4oKTogYnl0ZXMKYnl0ZXNSZXR1cm46Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTEyNgoJLy8gcmV0dXJuICdmb28nOwoJcHVzaGJ5dGVzIDB4NjY2ZjZmIC8vICJmb28iCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDIwOGJjZjk3IC8vIG1ldGhvZCAiYnl0ZXNSZXR1cm4oKWJ5dGVbXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfYnl0ZXNSZXR1cm4KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestBytesReturn.arc56_draft.json b/tests/contracts/artifacts/ABITestBytesReturn.arc56_draft.json index a811a157e..54d50a787 100644 --- a/tests/contracts/artifacts/ABITestBytesReturn.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestBytesReturn.arc56_draft.json @@ -378,7 +378,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYnl0ZXNSZXR1cm4oKWJ5dGVbXQoqYWJpX3JvdXRlX2J5dGVzUmV0dXJuOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgYnl0ZXNSZXR1cm4oKWJ5dGVbXQoJY2FsbHN1YiBieXRlc1JldHVybgoJZHVwCglsZW4KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gYnl0ZXNSZXR1cm4oKTogYnl0ZXMKYnl0ZXNSZXR1cm46Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTEyNgoJLy8gcmV0dXJuICdmb28nOwoJcHVzaGJ5dGVzIDB4NjY2ZjZmIC8vICJmb28iCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDIwOGJjZjk3IC8vIG1ldGhvZCAiYnl0ZXNSZXR1cm4oKWJ5dGVbXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfYnl0ZXNSZXR1cm4KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYnl0ZXNSZXR1cm4oKWJ5dGVbXQoqYWJpX3JvdXRlX2J5dGVzUmV0dXJuOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgYnl0ZXNSZXR1cm4oKWJ5dGVbXQoJY2FsbHN1YiBieXRlc1JldHVybgoJZHVwCglsZW4KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gYnl0ZXNSZXR1cm4oKTogYnl0ZXMKYnl0ZXNSZXR1cm46Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTEyNgoJLy8gcmV0dXJuICdmb28nOwoJcHVzaGJ5dGVzIDB4NjY2ZjZmIC8vICJmb28iCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDIwOGJjZjk3IC8vIG1ldGhvZCAiYnl0ZXNSZXR1cm4oKWJ5dGVbXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfYnl0ZXNSZXR1cm4KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestCastBytesFunction.approval.teal b/tests/contracts/artifacts/ABITestCastBytesFunction.approval.teal index d4de63d37..33d751926 100644 --- a/tests/contracts/artifacts/ABITestCastBytesFunction.approval.teal +++ b/tests/contracts/artifacts/ABITestCastBytesFunction.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestCastBytesFunction.arc32.json b/tests/contracts/artifacts/ABITestCastBytesFunction.arc32.json index 6e56ab730..9c27e3b5e 100644 --- a/tests/contracts/artifacts/ABITestCastBytesFunction.arc32.json +++ b/tests/contracts/artifacts/ABITestCastBytesFunction.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gY2FzdEJ5dGVzRnVuY3Rpb24oKXVpbnQ4WzNdCiphYmlfcm91dGVfY2FzdEJ5dGVzRnVuY3Rpb246CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBjYXN0Qnl0ZXNGdW5jdGlvbigpdWludDhbM10KCWNhbGxzdWIgY2FzdEJ5dGVzRnVuY3Rpb24KCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gY2FzdEJ5dGVzRnVuY3Rpb24oKTogU3RhdGljQXJyYXk8dWludDw4PiwgMz4KY2FzdEJ5dGVzRnVuY3Rpb246Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTA0NwoJLy8gcmV0dXJuIGNhc3RCeXRlczxTdGF0aWNBcnJheTx1aW50PDg+LCAzPj4oaGV4KCcweDAxMDIwMycpKTsKCXB1c2hieXRlcyAweDAxMDIwMwoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgzZDM2MTdmZCAvLyBtZXRob2QgImNhc3RCeXRlc0Z1bmN0aW9uKCl1aW50OFszXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY2FzdEJ5dGVzRnVuY3Rpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gY2FzdEJ5dGVzRnVuY3Rpb24oKXVpbnQ4WzNdCiphYmlfcm91dGVfY2FzdEJ5dGVzRnVuY3Rpb246CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBjYXN0Qnl0ZXNGdW5jdGlvbigpdWludDhbM10KCWNhbGxzdWIgY2FzdEJ5dGVzRnVuY3Rpb24KCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gY2FzdEJ5dGVzRnVuY3Rpb24oKTogU3RhdGljQXJyYXk8dWludDw4PiwgMz4KY2FzdEJ5dGVzRnVuY3Rpb246Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTA0NwoJLy8gcmV0dXJuIGNhc3RCeXRlczxTdGF0aWNBcnJheTx1aW50PDg+LCAzPj4oaGV4KCcweDAxMDIwMycpKTsKCXB1c2hieXRlcyAweDAxMDIwMwoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgzZDM2MTdmZCAvLyBtZXRob2QgImNhc3RCeXRlc0Z1bmN0aW9uKCl1aW50OFszXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY2FzdEJ5dGVzRnVuY3Rpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestCastBytesFunction.arc56_draft.json b/tests/contracts/artifacts/ABITestCastBytesFunction.arc56_draft.json index 59a943abd..aaf7352ea 100644 --- a/tests/contracts/artifacts/ABITestCastBytesFunction.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestCastBytesFunction.arc56_draft.json @@ -334,7 +334,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gY2FzdEJ5dGVzRnVuY3Rpb24oKXVpbnQ4WzNdCiphYmlfcm91dGVfY2FzdEJ5dGVzRnVuY3Rpb246CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBjYXN0Qnl0ZXNGdW5jdGlvbigpdWludDhbM10KCWNhbGxzdWIgY2FzdEJ5dGVzRnVuY3Rpb24KCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gY2FzdEJ5dGVzRnVuY3Rpb24oKTogU3RhdGljQXJyYXk8dWludDw4PiwgMz4KY2FzdEJ5dGVzRnVuY3Rpb246Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTA0NwoJLy8gcmV0dXJuIGNhc3RCeXRlczxTdGF0aWNBcnJheTx1aW50PDg+LCAzPj4oaGV4KCcweDAxMDIwMycpKTsKCXB1c2hieXRlcyAweDAxMDIwMwoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgzZDM2MTdmZCAvLyBtZXRob2QgImNhc3RCeXRlc0Z1bmN0aW9uKCl1aW50OFszXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY2FzdEJ5dGVzRnVuY3Rpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gY2FzdEJ5dGVzRnVuY3Rpb24oKXVpbnQ4WzNdCiphYmlfcm91dGVfY2FzdEJ5dGVzRnVuY3Rpb246CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBjYXN0Qnl0ZXNGdW5jdGlvbigpdWludDhbM10KCWNhbGxzdWIgY2FzdEJ5dGVzRnVuY3Rpb24KCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gY2FzdEJ5dGVzRnVuY3Rpb24oKTogU3RhdGljQXJyYXk8dWludDw4PiwgMz4KY2FzdEJ5dGVzRnVuY3Rpb246Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTA0NwoJLy8gcmV0dXJuIGNhc3RCeXRlczxTdGF0aWNBcnJheTx1aW50PDg+LCAzPj4oaGV4KCcweDAxMDIwMycpKTsKCXB1c2hieXRlcyAweDAxMDIwMwoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgzZDM2MTdmZCAvLyBtZXRob2QgImNhc3RCeXRlc0Z1bmN0aW9uKCl1aW50OFszXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY2FzdEJ5dGVzRnVuY3Rpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestChainedPropertyAfterTuple.approval.teal b/tests/contracts/artifacts/ABITestChainedPropertyAfterTuple.approval.teal index 973646b8b..de9457df4 100644 --- a/tests/contracts/artifacts/ABITestChainedPropertyAfterTuple.approval.teal +++ b/tests/contracts/artifacts/ABITestChainedPropertyAfterTuple.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestChainedPropertyAfterTuple.arc32.json b/tests/contracts/artifacts/ABITestChainedPropertyAfterTuple.arc32.json index fff0319a7..f0717715b 100644 --- a/tests/contracts/artifacts/ABITestChainedPropertyAfterTuple.arc32.json +++ b/tests/contracts/artifacts/ABITestChainedPropertyAfterTuple.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gY2hhaW5lZFByb3BlcnR5QWZ0ZXJUdXBsZSh1aW50NjQpdm9pZAoqYWJpX3JvdXRlX2NoYWluZWRQcm9wZXJ0eUFmdGVyVHVwbGU6CgkvLyBhc2E6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJYnRvaQoKCS8vIGV4ZWN1dGUgY2hhaW5lZFByb3BlcnR5QWZ0ZXJUdXBsZSh1aW50NjQpdm9pZAoJY2FsbHN1YiBjaGFpbmVkUHJvcGVydHlBZnRlclR1cGxlCglwdXNoaW50IDEKCXJldHVybgoKLy8gY2hhaW5lZFByb3BlcnR5QWZ0ZXJUdXBsZShhc2E6IEFzc2V0SUQpOiB2b2lkCmNoYWluZWRQcm9wZXJ0eUFmdGVyVHVwbGU6Cglwcm90byAxIDAKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjExNzMKCS8vIG86IFQ3ID0geyBmb286IHRoaXMuYXBwLmFkZHJlc3MgfQoJZ2xvYmFsIEN1cnJlbnRBcHBsaWNhdGlvbkFkZHJlc3MKCWZyYW1lX2J1cnkgMCAvLyBvOiBUNwoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMTc1CgkvLyBhc3NlcnQoIW8uZm9vLmlzT3B0ZWRJblRvQXNzZXQoYXNhKSkKCWZyYW1lX2RpZyAwIC8vIG86IFQ3CglleHRyYWN0IDAgMzIKCWZyYW1lX2RpZyAtMSAvLyBhc2E6IEFzc2V0SUQKCWFzc2V0X2hvbGRpbmdfZ2V0IEFzc2V0QmFsYW5jZQoJc3dhcAoJcG9wCgkhCglhc3NlcnQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MmZmZWJmNDcgLy8gbWV0aG9kICJjaGFpbmVkUHJvcGVydHlBZnRlclR1cGxlKHVpbnQ2NCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jaGFpbmVkUHJvcGVydHlBZnRlclR1cGxlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gY2hhaW5lZFByb3BlcnR5QWZ0ZXJUdXBsZSh1aW50NjQpdm9pZAoqYWJpX3JvdXRlX2NoYWluZWRQcm9wZXJ0eUFmdGVyVHVwbGU6CgkvLyBhc2E6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJYnRvaQoKCS8vIGV4ZWN1dGUgY2hhaW5lZFByb3BlcnR5QWZ0ZXJUdXBsZSh1aW50NjQpdm9pZAoJY2FsbHN1YiBjaGFpbmVkUHJvcGVydHlBZnRlclR1cGxlCglwdXNoaW50IDEKCXJldHVybgoKLy8gY2hhaW5lZFByb3BlcnR5QWZ0ZXJUdXBsZShhc2E6IEFzc2V0SUQpOiB2b2lkCmNoYWluZWRQcm9wZXJ0eUFmdGVyVHVwbGU6Cglwcm90byAxIDAKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjExNzMKCS8vIG86IFQ3ID0geyBmb286IHRoaXMuYXBwLmFkZHJlc3MgfQoJZ2xvYmFsIEN1cnJlbnRBcHBsaWNhdGlvbkFkZHJlc3MKCWZyYW1lX2J1cnkgMCAvLyBvOiBUNwoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMTc1CgkvLyBhc3NlcnQoIW8uZm9vLmlzT3B0ZWRJblRvQXNzZXQoYXNhKSkKCWZyYW1lX2RpZyAwIC8vIG86IFQ3CglleHRyYWN0IDAgMzIKCWZyYW1lX2RpZyAtMSAvLyBhc2E6IEFzc2V0SUQKCWFzc2V0X2hvbGRpbmdfZ2V0IEFzc2V0QmFsYW5jZQoJc3dhcAoJcG9wCgkhCglhc3NlcnQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MmZmZWJmNDcgLy8gbWV0aG9kICJjaGFpbmVkUHJvcGVydHlBZnRlclR1cGxlKHVpbnQ2NCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jaGFpbmVkUHJvcGVydHlBZnRlclR1cGxlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestChainedPropertyAfterTuple.arc56_draft.json b/tests/contracts/artifacts/ABITestChainedPropertyAfterTuple.arc56_draft.json index dac9daa19..3706115c3 100644 --- a/tests/contracts/artifacts/ABITestChainedPropertyAfterTuple.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestChainedPropertyAfterTuple.arc56_draft.json @@ -403,7 +403,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gY2hhaW5lZFByb3BlcnR5QWZ0ZXJUdXBsZSh1aW50NjQpdm9pZAoqYWJpX3JvdXRlX2NoYWluZWRQcm9wZXJ0eUFmdGVyVHVwbGU6CgkvLyBhc2E6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJYnRvaQoKCS8vIGV4ZWN1dGUgY2hhaW5lZFByb3BlcnR5QWZ0ZXJUdXBsZSh1aW50NjQpdm9pZAoJY2FsbHN1YiBjaGFpbmVkUHJvcGVydHlBZnRlclR1cGxlCglwdXNoaW50IDEKCXJldHVybgoKLy8gY2hhaW5lZFByb3BlcnR5QWZ0ZXJUdXBsZShhc2E6IEFzc2V0SUQpOiB2b2lkCmNoYWluZWRQcm9wZXJ0eUFmdGVyVHVwbGU6Cglwcm90byAxIDAKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjExNzMKCS8vIG86IFQ3ID0geyBmb286IHRoaXMuYXBwLmFkZHJlc3MgfQoJZ2xvYmFsIEN1cnJlbnRBcHBsaWNhdGlvbkFkZHJlc3MKCWZyYW1lX2J1cnkgMCAvLyBvOiBUNwoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMTc1CgkvLyBhc3NlcnQoIW8uZm9vLmlzT3B0ZWRJblRvQXNzZXQoYXNhKSkKCWZyYW1lX2RpZyAwIC8vIG86IFQ3CglleHRyYWN0IDAgMzIKCWZyYW1lX2RpZyAtMSAvLyBhc2E6IEFzc2V0SUQKCWFzc2V0X2hvbGRpbmdfZ2V0IEFzc2V0QmFsYW5jZQoJc3dhcAoJcG9wCgkhCglhc3NlcnQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MmZmZWJmNDcgLy8gbWV0aG9kICJjaGFpbmVkUHJvcGVydHlBZnRlclR1cGxlKHVpbnQ2NCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jaGFpbmVkUHJvcGVydHlBZnRlclR1cGxlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gY2hhaW5lZFByb3BlcnR5QWZ0ZXJUdXBsZSh1aW50NjQpdm9pZAoqYWJpX3JvdXRlX2NoYWluZWRQcm9wZXJ0eUFmdGVyVHVwbGU6CgkvLyBhc2E6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJYnRvaQoKCS8vIGV4ZWN1dGUgY2hhaW5lZFByb3BlcnR5QWZ0ZXJUdXBsZSh1aW50NjQpdm9pZAoJY2FsbHN1YiBjaGFpbmVkUHJvcGVydHlBZnRlclR1cGxlCglwdXNoaW50IDEKCXJldHVybgoKLy8gY2hhaW5lZFByb3BlcnR5QWZ0ZXJUdXBsZShhc2E6IEFzc2V0SUQpOiB2b2lkCmNoYWluZWRQcm9wZXJ0eUFmdGVyVHVwbGU6Cglwcm90byAxIDAKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjExNzMKCS8vIG86IFQ3ID0geyBmb286IHRoaXMuYXBwLmFkZHJlc3MgfQoJZ2xvYmFsIEN1cnJlbnRBcHBsaWNhdGlvbkFkZHJlc3MKCWZyYW1lX2J1cnkgMCAvLyBvOiBUNwoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMTc1CgkvLyBhc3NlcnQoIW8uZm9vLmlzT3B0ZWRJblRvQXNzZXQoYXNhKSkKCWZyYW1lX2RpZyAwIC8vIG86IFQ3CglleHRyYWN0IDAgMzIKCWZyYW1lX2RpZyAtMSAvLyBhc2E6IEFzc2V0SUQKCWFzc2V0X2hvbGRpbmdfZ2V0IEFzc2V0QmFsYW5jZQoJc3dhcAoJcG9wCgkhCglhc3NlcnQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MmZmZWJmNDcgLy8gbWV0aG9kICJjaGFpbmVkUHJvcGVydHlBZnRlclR1cGxlKHVpbnQ2NCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jaGFpbmVkUHJvcGVydHlBZnRlclR1cGxlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestCustomTypes.approval.teal b/tests/contracts/artifacts/ABITestCustomTypes.approval.teal index 18e52e2b0..74278a4cc 100644 --- a/tests/contracts/artifacts/ABITestCustomTypes.approval.teal +++ b/tests/contracts/artifacts/ABITestCustomTypes.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x000c48656c6c6f20576f726c6421 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestCustomTypes.arc32.json b/tests/contracts/artifacts/ABITestCustomTypes.arc32.json index d814a0171..6008de1d4 100644 --- a/tests/contracts/artifacts/ABITestCustomTypes.arc32.json +++ b/tests/contracts/artifacts/ABITestCustomTypes.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgwMDBjNDg2NTZjNmM2ZjIwNTc2ZjcyNmM2NDIxIDB4CgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gY3VzdG9tVHlwZXMoKXN0cmluZwoqYWJpX3JvdXRlX2N1c3RvbVR5cGVzOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgY3VzdG9tVHlwZXMoKXN0cmluZwoJY2FsbHN1YiBjdXN0b21UeXBlcwoJZHVwCglsZW4KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gY3VzdG9tVHlwZXMoKTogc3RyaW5nCmN1c3RvbVR5cGVzOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCWJ5dGUgMHgKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NjMyCgkvLyBhYTogQ3VzdG9tVHlwZSA9IHsKCS8vICAgICAgIGZvbzogMSwKCS8vICAgICAgIGJhcjogJ0hpPycsCgkvLyAgICAgfQoJYnl0ZSAweCAvLyBpbml0aWFsIGhlYWQKCWJ5dGUgMHggLy8gaW5pdGlhbCB0YWlsCglwdXNoYnl0ZXMgMHgwMDA0IC8vIGluaXRpYWwgaGVhZCBvZmZzZXQKCXB1c2hieXRlcyAweDAwMDEKCWNhbGxzdWIgKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMDM0ODY5M2YKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50Cglwb3AgLy8gcG9wIGhlYWQgb2Zmc2V0Cgljb25jYXQgLy8gY29uY2F0IGhlYWQgYW5kIHRhaWwKCWZyYW1lX2J1cnkgMCAvLyBhYTogQ3VzdG9tVHlwZQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo2MzcKCS8vIGFhLmJhciA9ICdIZWxsbyBXb3JsZCEnCglmcmFtZV9kaWcgMCAvLyBhYTogQ3VzdG9tVHlwZQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgMgoJZHVwCglzdG9yZSAyNTEgLy8gZWxlbWVudCBoZWFkIG9mZnNldAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJdW5jb3ZlciAyCglleHRyYWN0X3VpbnQxNgoJZHVwCglzdG9yZSAyNTQgLy8gZWxlbWVudCBzdGFydAoJZHVwIC8vIGR1cGxpY2F0ZSBzdGFydCBvZiBlbGVtZW50Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglzd2FwCglleHRyYWN0X3VpbnQxNiAvLyBnZXQgbnVtYmVyIG9mIGVsZW1lbnRzCglwdXNoaW50IDEgLy8gZ2V0IHR5cGUgbGVuZ3RoCgkqIC8vIG11bHRpcGx5IGJ5IHR5cGUgbGVuZ3RoCglwdXNoaW50IDIKCSsgLy8gYWRkIHR3byBmb3IgbGVuZ3RoCglzdG9yZSAyNTMgLy8gZWxlbWVudCBsZW5ndGgKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgMAoJbG9hZCAyNTQgLy8gZWxlbWVudCBzdGFydAoJc3Vic3RyaW5nMwoJYnl0ZSAweDAwMGM0ODY1NmM2YzZmMjA1NzZmNzI2YzY0MjEKCWR1cAoJc3RvcmUgMjUyIC8vIG5ldyBlbGVtZW50Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NCAvLyBlbGVtZW50IHN0YXJ0Cglsb2FkIDI1MyAvLyBlbGVtZW50IGxlbmd0aAoJKyAvLyBnZXQgZW5kIG9mIEVsZW1lbnQKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWxlbgoJc3Vic3RyaW5nMwoJY29uY2F0Cgljb25jYXQKCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5CgljYWxsc3ViICpnZXRfbGVuZ3RoX2RpZmZlcmVuY2UKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWZyYW1lX2J1cnkgMCAvLyBhYTogQ3VzdG9tVHlwZQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo2MzkKCS8vIHJldHVybiBhYS5iYXI7CglmcmFtZV9kaWcgMCAvLyBhYTogQ3VzdG9tVHlwZQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgMgoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJdW5jb3ZlciAyCglleHRyYWN0X3VpbnQxNgoJZHVwIC8vIGR1cGxpY2F0ZSBzdGFydCBvZiBlbGVtZW50Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglzd2FwCglleHRyYWN0X3VpbnQxNiAvLyBnZXQgbnVtYmVyIG9mIGVsZW1lbnRzCglwdXNoaW50IDEgLy8gZ2V0IHR5cGUgbGVuZ3RoCgkqIC8vIG11bHRpcGx5IGJ5IHR5cGUgbGVuZ3RoCglwdXNoaW50IDIKCSsgLy8gYWRkIHR3byBmb3IgbGVuZ3RoCglleHRyYWN0MwoJZXh0cmFjdCAyIDAKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YTQ2Mzg2YzcgLy8gbWV0aG9kICJjdXN0b21UeXBlcygpc3RyaW5nIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jdXN0b21UeXBlcwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycgoKKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJY29uY2F0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWIKCipwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJY29uY2F0CglmcmFtZV9idXJ5IC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50CglkdXAKCWxlbgoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglidG9pCgkrCglpdG9iCglleHRyYWN0IDYgMgoJZnJhbWVfYnVyeSAtMiAvLyBoZWFkIG9mZnNldAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCXN3YXAKCWNvbmNhdAoJZnJhbWVfYnVyeSAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3ViCgoqZ2V0X2xlbmd0aF9kaWZmZXJlbmNlOgoJbG9hZCAyNTIgLy8gbmV3IGVsZW1lbnQKCWxlbiAvLyBsZW5ndGggb2YgbmV3IGVsZW1lbnQKCWxvYWQgMjUzIC8vIGVsZW1lbnQgbGVuZ3RoCgk8CglibnogKnN3YXBwZWRfZGlmZmVyZW5jZQoJbG9hZCAyNTIgLy8gbmV3IGVsZW1lbnQKCWxlbiAvLyBsZW5ndGggb2YgbmV3IGVsZW1lbnQKCWxvYWQgMjUzIC8vIGVsZW1lbnQgbGVuZ3RoCglwdXNoaW50IDEKCXN0b3JlIDI0OSAvLyBzdWJ0cmFjdCBoZWFkIGRpZmZlcmVuY2UKCWIgKmdldF9kaWZmZXJlbmNlCgoqc3dhcHBlZF9kaWZmZXJlbmNlOgoJbG9hZCAyNTMgLy8gZWxlbWVudCBsZW5ndGgKCWxvYWQgMjUyIC8vIG5ldyBlbGVtZW50CglsZW4gLy8gbGVuZ3RoIG9mIG5ldyBlbGVtZW50CglwdXNoaW50IDAKCXN0b3JlIDI0OSAvLyBzdWJ0cmFjdCBoZWFkIGRpZmZlcmVuY2UKCipnZXRfZGlmZmVyZW5jZToKCS0gLy8gZ2V0IGxlbmd0aCBkaWZmZXJlbmNlCglzdG9yZSAyNTAgLy8gbGVuZ3RoIGRpZmZlcmVuY2UKCXJldHN1Yg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgwMDBjNDg2NTZjNmM2ZjIwNTc2ZjcyNmM2NDIxIDB4CgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gY3VzdG9tVHlwZXMoKXN0cmluZwoqYWJpX3JvdXRlX2N1c3RvbVR5cGVzOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgY3VzdG9tVHlwZXMoKXN0cmluZwoJY2FsbHN1YiBjdXN0b21UeXBlcwoJZHVwCglsZW4KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gY3VzdG9tVHlwZXMoKTogc3RyaW5nCmN1c3RvbVR5cGVzOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCWJ5dGUgMHgKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NjMyCgkvLyBhYTogQ3VzdG9tVHlwZSA9IHsKCS8vICAgICAgIGZvbzogMSwKCS8vICAgICAgIGJhcjogJ0hpPycsCgkvLyAgICAgfQoJYnl0ZSAweCAvLyBpbml0aWFsIGhlYWQKCWJ5dGUgMHggLy8gaW5pdGlhbCB0YWlsCglwdXNoYnl0ZXMgMHgwMDA0IC8vIGluaXRpYWwgaGVhZCBvZmZzZXQKCXB1c2hieXRlcyAweDAwMDEKCWNhbGxzdWIgKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMDM0ODY5M2YKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50Cglwb3AgLy8gcG9wIGhlYWQgb2Zmc2V0Cgljb25jYXQgLy8gY29uY2F0IGhlYWQgYW5kIHRhaWwKCWZyYW1lX2J1cnkgMCAvLyBhYTogQ3VzdG9tVHlwZQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo2MzcKCS8vIGFhLmJhciA9ICdIZWxsbyBXb3JsZCEnCglmcmFtZV9kaWcgMCAvLyBhYTogQ3VzdG9tVHlwZQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgMgoJZHVwCglzdG9yZSAyNTEgLy8gZWxlbWVudCBoZWFkIG9mZnNldAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJdW5jb3ZlciAyCglleHRyYWN0X3VpbnQxNgoJZHVwCglzdG9yZSAyNTQgLy8gZWxlbWVudCBzdGFydAoJZHVwIC8vIGR1cGxpY2F0ZSBzdGFydCBvZiBlbGVtZW50Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglzd2FwCglleHRyYWN0X3VpbnQxNiAvLyBnZXQgbnVtYmVyIG9mIGVsZW1lbnRzCglwdXNoaW50IDEgLy8gZ2V0IHR5cGUgbGVuZ3RoCgkqIC8vIG11bHRpcGx5IGJ5IHR5cGUgbGVuZ3RoCglwdXNoaW50IDIKCSsgLy8gYWRkIHR3byBmb3IgbGVuZ3RoCglzdG9yZSAyNTMgLy8gZWxlbWVudCBsZW5ndGgKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgMAoJbG9hZCAyNTQgLy8gZWxlbWVudCBzdGFydAoJc3Vic3RyaW5nMwoJYnl0ZSAweDAwMGM0ODY1NmM2YzZmMjA1NzZmNzI2YzY0MjEKCWR1cAoJc3RvcmUgMjUyIC8vIG5ldyBlbGVtZW50Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NCAvLyBlbGVtZW50IHN0YXJ0Cglsb2FkIDI1MyAvLyBlbGVtZW50IGxlbmd0aAoJKyAvLyBnZXQgZW5kIG9mIEVsZW1lbnQKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWxlbgoJc3Vic3RyaW5nMwoJY29uY2F0Cgljb25jYXQKCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5CgljYWxsc3ViICpnZXRfbGVuZ3RoX2RpZmZlcmVuY2UKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWZyYW1lX2J1cnkgMCAvLyBhYTogQ3VzdG9tVHlwZQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo2MzkKCS8vIHJldHVybiBhYS5iYXI7CglmcmFtZV9kaWcgMCAvLyBhYTogQ3VzdG9tVHlwZQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgMgoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJdW5jb3ZlciAyCglleHRyYWN0X3VpbnQxNgoJZHVwIC8vIGR1cGxpY2F0ZSBzdGFydCBvZiBlbGVtZW50Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglzd2FwCglleHRyYWN0X3VpbnQxNiAvLyBnZXQgbnVtYmVyIG9mIGVsZW1lbnRzCglwdXNoaW50IDEgLy8gZ2V0IHR5cGUgbGVuZ3RoCgkqIC8vIG11bHRpcGx5IGJ5IHR5cGUgbGVuZ3RoCglwdXNoaW50IDIKCSsgLy8gYWRkIHR3byBmb3IgbGVuZ3RoCglleHRyYWN0MwoJZXh0cmFjdCAyIDAKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YTQ2Mzg2YzcgLy8gbWV0aG9kICJjdXN0b21UeXBlcygpc3RyaW5nIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jdXN0b21UeXBlcwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycgoKKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJY29uY2F0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWIKCipwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJY29uY2F0CglmcmFtZV9idXJ5IC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50CglkdXAKCWxlbgoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglidG9pCgkrCglpdG9iCglleHRyYWN0IDYgMgoJZnJhbWVfYnVyeSAtMiAvLyBoZWFkIG9mZnNldAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCXN3YXAKCWNvbmNhdAoJZnJhbWVfYnVyeSAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3ViCgoqZ2V0X2xlbmd0aF9kaWZmZXJlbmNlOgoJbG9hZCAyNTIgLy8gbmV3IGVsZW1lbnQKCWxlbiAvLyBsZW5ndGggb2YgbmV3IGVsZW1lbnQKCWxvYWQgMjUzIC8vIGVsZW1lbnQgbGVuZ3RoCgk8CglibnogKnN3YXBwZWRfZGlmZmVyZW5jZQoJbG9hZCAyNTIgLy8gbmV3IGVsZW1lbnQKCWxlbiAvLyBsZW5ndGggb2YgbmV3IGVsZW1lbnQKCWxvYWQgMjUzIC8vIGVsZW1lbnQgbGVuZ3RoCglwdXNoaW50IDEKCXN0b3JlIDI0OSAvLyBzdWJ0cmFjdCBoZWFkIGRpZmZlcmVuY2UKCWIgKmdldF9kaWZmZXJlbmNlCgoqc3dhcHBlZF9kaWZmZXJlbmNlOgoJbG9hZCAyNTMgLy8gZWxlbWVudCBsZW5ndGgKCWxvYWQgMjUyIC8vIG5ldyBlbGVtZW50CglsZW4gLy8gbGVuZ3RoIG9mIG5ldyBlbGVtZW50CglwdXNoaW50IDAKCXN0b3JlIDI0OSAvLyBzdWJ0cmFjdCBoZWFkIGRpZmZlcmVuY2UKCipnZXRfZGlmZmVyZW5jZToKCS0gLy8gZ2V0IGxlbmd0aCBkaWZmZXJlbmNlCglzdG9yZSAyNTAgLy8gbGVuZ3RoIGRpZmZlcmVuY2UKCXJldHN1Yg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestCustomTypes.arc56_draft.json b/tests/contracts/artifacts/ABITestCustomTypes.arc56_draft.json index de1dd984e..4fbb142be 100644 --- a/tests/contracts/artifacts/ABITestCustomTypes.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestCustomTypes.arc56_draft.json @@ -1318,7 +1318,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgwMDBjNDg2NTZjNmM2ZjIwNTc2ZjcyNmM2NDIxIDB4CgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gY3VzdG9tVHlwZXMoKXN0cmluZwoqYWJpX3JvdXRlX2N1c3RvbVR5cGVzOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgY3VzdG9tVHlwZXMoKXN0cmluZwoJY2FsbHN1YiBjdXN0b21UeXBlcwoJZHVwCglsZW4KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gY3VzdG9tVHlwZXMoKTogc3RyaW5nCmN1c3RvbVR5cGVzOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCWJ5dGUgMHgKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NjMyCgkvLyBhYTogQ3VzdG9tVHlwZSA9IHsKCS8vICAgICAgIGZvbzogMSwKCS8vICAgICAgIGJhcjogJ0hpPycsCgkvLyAgICAgfQoJYnl0ZSAweCAvLyBpbml0aWFsIGhlYWQKCWJ5dGUgMHggLy8gaW5pdGlhbCB0YWlsCglwdXNoYnl0ZXMgMHgwMDA0IC8vIGluaXRpYWwgaGVhZCBvZmZzZXQKCXB1c2hieXRlcyAweDAwMDEKCWNhbGxzdWIgKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMDM0ODY5M2YKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50Cglwb3AgLy8gcG9wIGhlYWQgb2Zmc2V0Cgljb25jYXQgLy8gY29uY2F0IGhlYWQgYW5kIHRhaWwKCWZyYW1lX2J1cnkgMCAvLyBhYTogQ3VzdG9tVHlwZQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo2MzcKCS8vIGFhLmJhciA9ICdIZWxsbyBXb3JsZCEnCglmcmFtZV9kaWcgMCAvLyBhYTogQ3VzdG9tVHlwZQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgMgoJZHVwCglzdG9yZSAyNTEgLy8gZWxlbWVudCBoZWFkIG9mZnNldAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJdW5jb3ZlciAyCglleHRyYWN0X3VpbnQxNgoJZHVwCglzdG9yZSAyNTQgLy8gZWxlbWVudCBzdGFydAoJZHVwIC8vIGR1cGxpY2F0ZSBzdGFydCBvZiBlbGVtZW50Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglzd2FwCglleHRyYWN0X3VpbnQxNiAvLyBnZXQgbnVtYmVyIG9mIGVsZW1lbnRzCglwdXNoaW50IDEgLy8gZ2V0IHR5cGUgbGVuZ3RoCgkqIC8vIG11bHRpcGx5IGJ5IHR5cGUgbGVuZ3RoCglwdXNoaW50IDIKCSsgLy8gYWRkIHR3byBmb3IgbGVuZ3RoCglzdG9yZSAyNTMgLy8gZWxlbWVudCBsZW5ndGgKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgMAoJbG9hZCAyNTQgLy8gZWxlbWVudCBzdGFydAoJc3Vic3RyaW5nMwoJYnl0ZSAweDAwMGM0ODY1NmM2YzZmMjA1NzZmNzI2YzY0MjEKCWR1cAoJc3RvcmUgMjUyIC8vIG5ldyBlbGVtZW50Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NCAvLyBlbGVtZW50IHN0YXJ0Cglsb2FkIDI1MyAvLyBlbGVtZW50IGxlbmd0aAoJKyAvLyBnZXQgZW5kIG9mIEVsZW1lbnQKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWxlbgoJc3Vic3RyaW5nMwoJY29uY2F0Cgljb25jYXQKCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5CgljYWxsc3ViICpnZXRfbGVuZ3RoX2RpZmZlcmVuY2UKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWZyYW1lX2J1cnkgMCAvLyBhYTogQ3VzdG9tVHlwZQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo2MzkKCS8vIHJldHVybiBhYS5iYXI7CglmcmFtZV9kaWcgMCAvLyBhYTogQ3VzdG9tVHlwZQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgMgoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJdW5jb3ZlciAyCglleHRyYWN0X3VpbnQxNgoJZHVwIC8vIGR1cGxpY2F0ZSBzdGFydCBvZiBlbGVtZW50Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglzd2FwCglleHRyYWN0X3VpbnQxNiAvLyBnZXQgbnVtYmVyIG9mIGVsZW1lbnRzCglwdXNoaW50IDEgLy8gZ2V0IHR5cGUgbGVuZ3RoCgkqIC8vIG11bHRpcGx5IGJ5IHR5cGUgbGVuZ3RoCglwdXNoaW50IDIKCSsgLy8gYWRkIHR3byBmb3IgbGVuZ3RoCglleHRyYWN0MwoJZXh0cmFjdCAyIDAKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YTQ2Mzg2YzcgLy8gbWV0aG9kICJjdXN0b21UeXBlcygpc3RyaW5nIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jdXN0b21UeXBlcwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycgoKKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJY29uY2F0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWIKCipwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJY29uY2F0CglmcmFtZV9idXJ5IC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50CglkdXAKCWxlbgoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglidG9pCgkrCglpdG9iCglleHRyYWN0IDYgMgoJZnJhbWVfYnVyeSAtMiAvLyBoZWFkIG9mZnNldAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCXN3YXAKCWNvbmNhdAoJZnJhbWVfYnVyeSAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3ViCgoqZ2V0X2xlbmd0aF9kaWZmZXJlbmNlOgoJbG9hZCAyNTIgLy8gbmV3IGVsZW1lbnQKCWxlbiAvLyBsZW5ndGggb2YgbmV3IGVsZW1lbnQKCWxvYWQgMjUzIC8vIGVsZW1lbnQgbGVuZ3RoCgk8CglibnogKnN3YXBwZWRfZGlmZmVyZW5jZQoJbG9hZCAyNTIgLy8gbmV3IGVsZW1lbnQKCWxlbiAvLyBsZW5ndGggb2YgbmV3IGVsZW1lbnQKCWxvYWQgMjUzIC8vIGVsZW1lbnQgbGVuZ3RoCglwdXNoaW50IDEKCXN0b3JlIDI0OSAvLyBzdWJ0cmFjdCBoZWFkIGRpZmZlcmVuY2UKCWIgKmdldF9kaWZmZXJlbmNlCgoqc3dhcHBlZF9kaWZmZXJlbmNlOgoJbG9hZCAyNTMgLy8gZWxlbWVudCBsZW5ndGgKCWxvYWQgMjUyIC8vIG5ldyBlbGVtZW50CglsZW4gLy8gbGVuZ3RoIG9mIG5ldyBlbGVtZW50CglwdXNoaW50IDAKCXN0b3JlIDI0OSAvLyBzdWJ0cmFjdCBoZWFkIGRpZmZlcmVuY2UKCipnZXRfZGlmZmVyZW5jZToKCS0gLy8gZ2V0IGxlbmd0aCBkaWZmZXJlbmNlCglzdG9yZSAyNTAgLy8gbGVuZ3RoIGRpZmZlcmVuY2UKCXJldHN1Yg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgwMDBjNDg2NTZjNmM2ZjIwNTc2ZjcyNmM2NDIxIDB4CgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gY3VzdG9tVHlwZXMoKXN0cmluZwoqYWJpX3JvdXRlX2N1c3RvbVR5cGVzOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgY3VzdG9tVHlwZXMoKXN0cmluZwoJY2FsbHN1YiBjdXN0b21UeXBlcwoJZHVwCglsZW4KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gY3VzdG9tVHlwZXMoKTogc3RyaW5nCmN1c3RvbVR5cGVzOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCWJ5dGUgMHgKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NjMyCgkvLyBhYTogQ3VzdG9tVHlwZSA9IHsKCS8vICAgICAgIGZvbzogMSwKCS8vICAgICAgIGJhcjogJ0hpPycsCgkvLyAgICAgfQoJYnl0ZSAweCAvLyBpbml0aWFsIGhlYWQKCWJ5dGUgMHggLy8gaW5pdGlhbCB0YWlsCglwdXNoYnl0ZXMgMHgwMDA0IC8vIGluaXRpYWwgaGVhZCBvZmZzZXQKCXB1c2hieXRlcyAweDAwMDEKCWNhbGxzdWIgKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMDM0ODY5M2YKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50Cglwb3AgLy8gcG9wIGhlYWQgb2Zmc2V0Cgljb25jYXQgLy8gY29uY2F0IGhlYWQgYW5kIHRhaWwKCWZyYW1lX2J1cnkgMCAvLyBhYTogQ3VzdG9tVHlwZQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo2MzcKCS8vIGFhLmJhciA9ICdIZWxsbyBXb3JsZCEnCglmcmFtZV9kaWcgMCAvLyBhYTogQ3VzdG9tVHlwZQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgMgoJZHVwCglzdG9yZSAyNTEgLy8gZWxlbWVudCBoZWFkIG9mZnNldAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJdW5jb3ZlciAyCglleHRyYWN0X3VpbnQxNgoJZHVwCglzdG9yZSAyNTQgLy8gZWxlbWVudCBzdGFydAoJZHVwIC8vIGR1cGxpY2F0ZSBzdGFydCBvZiBlbGVtZW50Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglzd2FwCglleHRyYWN0X3VpbnQxNiAvLyBnZXQgbnVtYmVyIG9mIGVsZW1lbnRzCglwdXNoaW50IDEgLy8gZ2V0IHR5cGUgbGVuZ3RoCgkqIC8vIG11bHRpcGx5IGJ5IHR5cGUgbGVuZ3RoCglwdXNoaW50IDIKCSsgLy8gYWRkIHR3byBmb3IgbGVuZ3RoCglzdG9yZSAyNTMgLy8gZWxlbWVudCBsZW5ndGgKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgMAoJbG9hZCAyNTQgLy8gZWxlbWVudCBzdGFydAoJc3Vic3RyaW5nMwoJYnl0ZSAweDAwMGM0ODY1NmM2YzZmMjA1NzZmNzI2YzY0MjEKCWR1cAoJc3RvcmUgMjUyIC8vIG5ldyBlbGVtZW50Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NCAvLyBlbGVtZW50IHN0YXJ0Cglsb2FkIDI1MyAvLyBlbGVtZW50IGxlbmd0aAoJKyAvLyBnZXQgZW5kIG9mIEVsZW1lbnQKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWxlbgoJc3Vic3RyaW5nMwoJY29uY2F0Cgljb25jYXQKCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5CgljYWxsc3ViICpnZXRfbGVuZ3RoX2RpZmZlcmVuY2UKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWZyYW1lX2J1cnkgMCAvLyBhYTogQ3VzdG9tVHlwZQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo2MzkKCS8vIHJldHVybiBhYS5iYXI7CglmcmFtZV9kaWcgMCAvLyBhYTogQ3VzdG9tVHlwZQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgMgoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJdW5jb3ZlciAyCglleHRyYWN0X3VpbnQxNgoJZHVwIC8vIGR1cGxpY2F0ZSBzdGFydCBvZiBlbGVtZW50Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglzd2FwCglleHRyYWN0X3VpbnQxNiAvLyBnZXQgbnVtYmVyIG9mIGVsZW1lbnRzCglwdXNoaW50IDEgLy8gZ2V0IHR5cGUgbGVuZ3RoCgkqIC8vIG11bHRpcGx5IGJ5IHR5cGUgbGVuZ3RoCglwdXNoaW50IDIKCSsgLy8gYWRkIHR3byBmb3IgbGVuZ3RoCglleHRyYWN0MwoJZXh0cmFjdCAyIDAKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YTQ2Mzg2YzcgLy8gbWV0aG9kICJjdXN0b21UeXBlcygpc3RyaW5nIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jdXN0b21UeXBlcwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycgoKKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJY29uY2F0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWIKCipwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJY29uY2F0CglmcmFtZV9idXJ5IC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50CglkdXAKCWxlbgoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglidG9pCgkrCglpdG9iCglleHRyYWN0IDYgMgoJZnJhbWVfYnVyeSAtMiAvLyBoZWFkIG9mZnNldAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCXN3YXAKCWNvbmNhdAoJZnJhbWVfYnVyeSAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3ViCgoqZ2V0X2xlbmd0aF9kaWZmZXJlbmNlOgoJbG9hZCAyNTIgLy8gbmV3IGVsZW1lbnQKCWxlbiAvLyBsZW5ndGggb2YgbmV3IGVsZW1lbnQKCWxvYWQgMjUzIC8vIGVsZW1lbnQgbGVuZ3RoCgk8CglibnogKnN3YXBwZWRfZGlmZmVyZW5jZQoJbG9hZCAyNTIgLy8gbmV3IGVsZW1lbnQKCWxlbiAvLyBsZW5ndGggb2YgbmV3IGVsZW1lbnQKCWxvYWQgMjUzIC8vIGVsZW1lbnQgbGVuZ3RoCglwdXNoaW50IDEKCXN0b3JlIDI0OSAvLyBzdWJ0cmFjdCBoZWFkIGRpZmZlcmVuY2UKCWIgKmdldF9kaWZmZXJlbmNlCgoqc3dhcHBlZF9kaWZmZXJlbmNlOgoJbG9hZCAyNTMgLy8gZWxlbWVudCBsZW5ndGgKCWxvYWQgMjUyIC8vIG5ldyBlbGVtZW50CglsZW4gLy8gbGVuZ3RoIG9mIG5ldyBlbGVtZW50CglwdXNoaW50IDAKCXN0b3JlIDI0OSAvLyBzdWJ0cmFjdCBoZWFkIGRpZmZlcmVuY2UKCipnZXRfZGlmZmVyZW5jZToKCS0gLy8gZ2V0IGxlbmd0aCBkaWZmZXJlbmNlCglzdG9yZSAyNTAgLy8gbGVuZ3RoIGRpZmZlcmVuY2UKCXJldHN1Yg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestDisgusting.approval.teal b/tests/contracts/artifacts/ABITestDisgusting.approval.teal index 5566020a5..9163d27f5 100644 --- a/tests/contracts/artifacts/ABITestDisgusting.approval.teal +++ b/tests/contracts/artifacts/ABITestDisgusting.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestDisgusting.arc32.json b/tests/contracts/artifacts/ABITestDisgusting.arc32.json index 08efdf6fd..2c53abcd7 100644 --- a/tests/contracts/artifacts/ABITestDisgusting.arc32.json +++ b/tests/contracts/artifacts/ABITestDisgusting.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZGlzZ3VzdGluZygpdWludDY0CiphYmlfcm91dGVfZGlzZ3VzdGluZzoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGRpc2d1c3RpbmcoKXVpbnQ2NAoJY2FsbHN1YiBkaXNndXN0aW5nCglpdG9iCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGRpc2d1c3RpbmcoKTogdWludDY0CmRpc2d1c3Rpbmc6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjMwNAoJLy8gYTogU3RhdGljQXJyYXk8CgkvLyAgICAgICBbU3RhdGljQXJyYXk8dWludDE2LCAyPiwgdWludDY0LCBbdWludDE2LCB1aW50NjRdLCBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50NjQsIDI+LCAyPl0sCgkvLyAgICAgICAyCgkvLyAgICAgPiA9IFsKCS8vICAgICAgIFsKCS8vICAgICAgICAgWzExLCAyMl0sCgkvLyAgICAgICAgIDMzLAoJLy8gICAgICAgICBbNDQsIDU1XSwKCS8vICAgICAgICAgWwoJLy8gICAgICAgICAgIFs2NiwgNzddLAoJLy8gICAgICAgICAgIFs4OCwgOTldLAoJLy8gICAgICAgICBdLAoJLy8gICAgICAgXSwKCS8vICAgICAgIFsKCS8vICAgICAgICAgWzExMSwgMjIyXSwKCS8vICAgICAgICAgMzMzLAoJLy8gICAgICAgICBbNDQ0LCA1NTVdLAoJLy8gICAgICAgICBbCgkvLyAgICAgICAgICAgWzY2NiwgNzc3XSwKCS8vICAgICAgICAgICBbODg4LCA5OTldLAoJLy8gICAgICAgICBdLAoJLy8gICAgICAgXSwKCS8vICAgICBdCglwdXNoYnl0ZXMgMHgwMDBiMDAxNjAwMDAwMDAwMDAwMDAwMjEwMDJjMDAwMDAwMDAwMDAwMDAzNzAwMDAwMDAwMDAwMDAwNDIwMDAwMDAwMDAwMDAwMDRkMDAwMDAwMDAwMDAwMDA1ODAwMDAwMDAwMDAwMDAwNjMwMDZmMDBkZTAwMDAwMDAwMDAwMDAxNGQwMWJjMDAwMDAwMDAwMDAwMDIyYjAwMDAwMDAwMDAwMDAyOWEwMDAwMDAwMDAwMDAwMzA5MDAwMDAwMDAwMDAwMDM3ODAwMDAwMDAwMDAwMDAzZTcKCWZyYW1lX2J1cnkgMCAvLyBhOiBTdGF0aWNBcnJheTwgICAgICAgW1N0YXRpY0FycmF5PHVpbnQxNiwgMj4sIHVpbnQ2NCwgW3VpbnQxNiwgdWludDY0XSwgU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDY0LCAyPiwgMj5dLCAgICAgICAyICAgICA+CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjMyOAoJLy8gYVsxXVszXVsxXSA9IFs4ODg4LCA5OTk5XQoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8ICAgICAgIFtTdGF0aWNBcnJheTx1aW50MTYsIDI+LCB1aW50NjQsIFt1aW50MTYsIHVpbnQ2NF0sIFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQ2NCwgMj4sIDI+XSwgICAgICAgMiAgICAgPgoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMjJiODAwMDAwMDAwMDAwMDI3MGYKCXJlcGxhY2UyIDkyCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8ICAgICAgIFtTdGF0aWNBcnJheTx1aW50MTYsIDI+LCB1aW50NjQsIFt1aW50MTYsIHVpbnQ2NF0sIFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQ2NCwgMj4sIDI+XSwgICAgICAgMiAgICAgPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czozMjkKCS8vIHJldHVybiBhWzFdWzNdWzFdWzBdOwoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8ICAgICAgIFtTdGF0aWNBcnJheTx1aW50MTYsIDI+LCB1aW50NjQsIFt1aW50MTYsIHVpbnQ2NF0sIFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQ2NCwgMj4sIDI+XSwgICAgICAgMiAgICAgPgoJZXh0cmFjdCA5MiA4CglidG9pCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDFiNmM5NjhlIC8vIG1ldGhvZCAiZGlzZ3VzdGluZygpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9kaXNndXN0aW5nCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZGlzZ3VzdGluZygpdWludDY0CiphYmlfcm91dGVfZGlzZ3VzdGluZzoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGRpc2d1c3RpbmcoKXVpbnQ2NAoJY2FsbHN1YiBkaXNndXN0aW5nCglpdG9iCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGRpc2d1c3RpbmcoKTogdWludDY0CmRpc2d1c3Rpbmc6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjMwNAoJLy8gYTogU3RhdGljQXJyYXk8CgkvLyAgICAgICBbU3RhdGljQXJyYXk8dWludDE2LCAyPiwgdWludDY0LCBbdWludDE2LCB1aW50NjRdLCBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50NjQsIDI+LCAyPl0sCgkvLyAgICAgICAyCgkvLyAgICAgPiA9IFsKCS8vICAgICAgIFsKCS8vICAgICAgICAgWzExLCAyMl0sCgkvLyAgICAgICAgIDMzLAoJLy8gICAgICAgICBbNDQsIDU1XSwKCS8vICAgICAgICAgWwoJLy8gICAgICAgICAgIFs2NiwgNzddLAoJLy8gICAgICAgICAgIFs4OCwgOTldLAoJLy8gICAgICAgICBdLAoJLy8gICAgICAgXSwKCS8vICAgICAgIFsKCS8vICAgICAgICAgWzExMSwgMjIyXSwKCS8vICAgICAgICAgMzMzLAoJLy8gICAgICAgICBbNDQ0LCA1NTVdLAoJLy8gICAgICAgICBbCgkvLyAgICAgICAgICAgWzY2NiwgNzc3XSwKCS8vICAgICAgICAgICBbODg4LCA5OTldLAoJLy8gICAgICAgICBdLAoJLy8gICAgICAgXSwKCS8vICAgICBdCglwdXNoYnl0ZXMgMHgwMDBiMDAxNjAwMDAwMDAwMDAwMDAwMjEwMDJjMDAwMDAwMDAwMDAwMDAzNzAwMDAwMDAwMDAwMDAwNDIwMDAwMDAwMDAwMDAwMDRkMDAwMDAwMDAwMDAwMDA1ODAwMDAwMDAwMDAwMDAwNjMwMDZmMDBkZTAwMDAwMDAwMDAwMDAxNGQwMWJjMDAwMDAwMDAwMDAwMDIyYjAwMDAwMDAwMDAwMDAyOWEwMDAwMDAwMDAwMDAwMzA5MDAwMDAwMDAwMDAwMDM3ODAwMDAwMDAwMDAwMDAzZTcKCWZyYW1lX2J1cnkgMCAvLyBhOiBTdGF0aWNBcnJheTwgICAgICAgW1N0YXRpY0FycmF5PHVpbnQxNiwgMj4sIHVpbnQ2NCwgW3VpbnQxNiwgdWludDY0XSwgU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDY0LCAyPiwgMj5dLCAgICAgICAyICAgICA+CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjMyOAoJLy8gYVsxXVszXVsxXSA9IFs4ODg4LCA5OTk5XQoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8ICAgICAgIFtTdGF0aWNBcnJheTx1aW50MTYsIDI+LCB1aW50NjQsIFt1aW50MTYsIHVpbnQ2NF0sIFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQ2NCwgMj4sIDI+XSwgICAgICAgMiAgICAgPgoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMjJiODAwMDAwMDAwMDAwMDI3MGYKCXJlcGxhY2UyIDkyCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8ICAgICAgIFtTdGF0aWNBcnJheTx1aW50MTYsIDI+LCB1aW50NjQsIFt1aW50MTYsIHVpbnQ2NF0sIFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQ2NCwgMj4sIDI+XSwgICAgICAgMiAgICAgPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czozMjkKCS8vIHJldHVybiBhWzFdWzNdWzFdWzBdOwoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8ICAgICAgIFtTdGF0aWNBcnJheTx1aW50MTYsIDI+LCB1aW50NjQsIFt1aW50MTYsIHVpbnQ2NF0sIFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQ2NCwgMj4sIDI+XSwgICAgICAgMiAgICAgPgoJZXh0cmFjdCA5MiA4CglidG9pCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDFiNmM5NjhlIC8vIG1ldGhvZCAiZGlzZ3VzdGluZygpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9kaXNndXN0aW5nCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestDisgusting.arc56_draft.json b/tests/contracts/artifacts/ABITestDisgusting.arc56_draft.json index 3429dc6b5..37c10cfdf 100644 --- a/tests/contracts/artifacts/ABITestDisgusting.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestDisgusting.arc56_draft.json @@ -542,7 +542,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZGlzZ3VzdGluZygpdWludDY0CiphYmlfcm91dGVfZGlzZ3VzdGluZzoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGRpc2d1c3RpbmcoKXVpbnQ2NAoJY2FsbHN1YiBkaXNndXN0aW5nCglpdG9iCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGRpc2d1c3RpbmcoKTogdWludDY0CmRpc2d1c3Rpbmc6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjMwNAoJLy8gYTogU3RhdGljQXJyYXk8CgkvLyAgICAgICBbU3RhdGljQXJyYXk8dWludDE2LCAyPiwgdWludDY0LCBbdWludDE2LCB1aW50NjRdLCBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50NjQsIDI+LCAyPl0sCgkvLyAgICAgICAyCgkvLyAgICAgPiA9IFsKCS8vICAgICAgIFsKCS8vICAgICAgICAgWzExLCAyMl0sCgkvLyAgICAgICAgIDMzLAoJLy8gICAgICAgICBbNDQsIDU1XSwKCS8vICAgICAgICAgWwoJLy8gICAgICAgICAgIFs2NiwgNzddLAoJLy8gICAgICAgICAgIFs4OCwgOTldLAoJLy8gICAgICAgICBdLAoJLy8gICAgICAgXSwKCS8vICAgICAgIFsKCS8vICAgICAgICAgWzExMSwgMjIyXSwKCS8vICAgICAgICAgMzMzLAoJLy8gICAgICAgICBbNDQ0LCA1NTVdLAoJLy8gICAgICAgICBbCgkvLyAgICAgICAgICAgWzY2NiwgNzc3XSwKCS8vICAgICAgICAgICBbODg4LCA5OTldLAoJLy8gICAgICAgICBdLAoJLy8gICAgICAgXSwKCS8vICAgICBdCglwdXNoYnl0ZXMgMHgwMDBiMDAxNjAwMDAwMDAwMDAwMDAwMjEwMDJjMDAwMDAwMDAwMDAwMDAzNzAwMDAwMDAwMDAwMDAwNDIwMDAwMDAwMDAwMDAwMDRkMDAwMDAwMDAwMDAwMDA1ODAwMDAwMDAwMDAwMDAwNjMwMDZmMDBkZTAwMDAwMDAwMDAwMDAxNGQwMWJjMDAwMDAwMDAwMDAwMDIyYjAwMDAwMDAwMDAwMDAyOWEwMDAwMDAwMDAwMDAwMzA5MDAwMDAwMDAwMDAwMDM3ODAwMDAwMDAwMDAwMDAzZTcKCWZyYW1lX2J1cnkgMCAvLyBhOiBTdGF0aWNBcnJheTwgICAgICAgW1N0YXRpY0FycmF5PHVpbnQxNiwgMj4sIHVpbnQ2NCwgW3VpbnQxNiwgdWludDY0XSwgU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDY0LCAyPiwgMj5dLCAgICAgICAyICAgICA+CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjMyOAoJLy8gYVsxXVszXVsxXSA9IFs4ODg4LCA5OTk5XQoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8ICAgICAgIFtTdGF0aWNBcnJheTx1aW50MTYsIDI+LCB1aW50NjQsIFt1aW50MTYsIHVpbnQ2NF0sIFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQ2NCwgMj4sIDI+XSwgICAgICAgMiAgICAgPgoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMjJiODAwMDAwMDAwMDAwMDI3MGYKCXJlcGxhY2UyIDkyCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8ICAgICAgIFtTdGF0aWNBcnJheTx1aW50MTYsIDI+LCB1aW50NjQsIFt1aW50MTYsIHVpbnQ2NF0sIFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQ2NCwgMj4sIDI+XSwgICAgICAgMiAgICAgPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czozMjkKCS8vIHJldHVybiBhWzFdWzNdWzFdWzBdOwoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8ICAgICAgIFtTdGF0aWNBcnJheTx1aW50MTYsIDI+LCB1aW50NjQsIFt1aW50MTYsIHVpbnQ2NF0sIFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQ2NCwgMj4sIDI+XSwgICAgICAgMiAgICAgPgoJZXh0cmFjdCA5MiA4CglidG9pCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDFiNmM5NjhlIC8vIG1ldGhvZCAiZGlzZ3VzdGluZygpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9kaXNndXN0aW5nCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZGlzZ3VzdGluZygpdWludDY0CiphYmlfcm91dGVfZGlzZ3VzdGluZzoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGRpc2d1c3RpbmcoKXVpbnQ2NAoJY2FsbHN1YiBkaXNndXN0aW5nCglpdG9iCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGRpc2d1c3RpbmcoKTogdWludDY0CmRpc2d1c3Rpbmc6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjMwNAoJLy8gYTogU3RhdGljQXJyYXk8CgkvLyAgICAgICBbU3RhdGljQXJyYXk8dWludDE2LCAyPiwgdWludDY0LCBbdWludDE2LCB1aW50NjRdLCBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50NjQsIDI+LCAyPl0sCgkvLyAgICAgICAyCgkvLyAgICAgPiA9IFsKCS8vICAgICAgIFsKCS8vICAgICAgICAgWzExLCAyMl0sCgkvLyAgICAgICAgIDMzLAoJLy8gICAgICAgICBbNDQsIDU1XSwKCS8vICAgICAgICAgWwoJLy8gICAgICAgICAgIFs2NiwgNzddLAoJLy8gICAgICAgICAgIFs4OCwgOTldLAoJLy8gICAgICAgICBdLAoJLy8gICAgICAgXSwKCS8vICAgICAgIFsKCS8vICAgICAgICAgWzExMSwgMjIyXSwKCS8vICAgICAgICAgMzMzLAoJLy8gICAgICAgICBbNDQ0LCA1NTVdLAoJLy8gICAgICAgICBbCgkvLyAgICAgICAgICAgWzY2NiwgNzc3XSwKCS8vICAgICAgICAgICBbODg4LCA5OTldLAoJLy8gICAgICAgICBdLAoJLy8gICAgICAgXSwKCS8vICAgICBdCglwdXNoYnl0ZXMgMHgwMDBiMDAxNjAwMDAwMDAwMDAwMDAwMjEwMDJjMDAwMDAwMDAwMDAwMDAzNzAwMDAwMDAwMDAwMDAwNDIwMDAwMDAwMDAwMDAwMDRkMDAwMDAwMDAwMDAwMDA1ODAwMDAwMDAwMDAwMDAwNjMwMDZmMDBkZTAwMDAwMDAwMDAwMDAxNGQwMWJjMDAwMDAwMDAwMDAwMDIyYjAwMDAwMDAwMDAwMDAyOWEwMDAwMDAwMDAwMDAwMzA5MDAwMDAwMDAwMDAwMDM3ODAwMDAwMDAwMDAwMDAzZTcKCWZyYW1lX2J1cnkgMCAvLyBhOiBTdGF0aWNBcnJheTwgICAgICAgW1N0YXRpY0FycmF5PHVpbnQxNiwgMj4sIHVpbnQ2NCwgW3VpbnQxNiwgdWludDY0XSwgU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDY0LCAyPiwgMj5dLCAgICAgICAyICAgICA+CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjMyOAoJLy8gYVsxXVszXVsxXSA9IFs4ODg4LCA5OTk5XQoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8ICAgICAgIFtTdGF0aWNBcnJheTx1aW50MTYsIDI+LCB1aW50NjQsIFt1aW50MTYsIHVpbnQ2NF0sIFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQ2NCwgMj4sIDI+XSwgICAgICAgMiAgICAgPgoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMjJiODAwMDAwMDAwMDAwMDI3MGYKCXJlcGxhY2UyIDkyCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8ICAgICAgIFtTdGF0aWNBcnJheTx1aW50MTYsIDI+LCB1aW50NjQsIFt1aW50MTYsIHVpbnQ2NF0sIFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQ2NCwgMj4sIDI+XSwgICAgICAgMiAgICAgPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czozMjkKCS8vIHJldHVybiBhWzFdWzNdWzFdWzBdOwoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8ICAgICAgIFtTdGF0aWNBcnJheTx1aW50MTYsIDI+LCB1aW50NjQsIFt1aW50MTYsIHVpbnQ2NF0sIFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQ2NCwgMj4sIDI+XSwgICAgICAgMiAgICAgPgoJZXh0cmFjdCA5MiA4CglidG9pCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDFiNmM5NjhlIC8vIG1ldGhvZCAiZGlzZ3VzdGluZygpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9kaXNndXN0aW5nCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestDynamicAccessOfDynamicElementInStaticArray.approval.teal b/tests/contracts/artifacts/ABITestDynamicAccessOfDynamicElementInStaticArray.approval.teal index a2c68f82d..d99be8a31 100644 --- a/tests/contracts/artifacts/ABITestDynamicAccessOfDynamicElementInStaticArray.approval.teal +++ b/tests/contracts/artifacts/ABITestDynamicAccessOfDynamicElementInStaticArray.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestDynamicAccessOfDynamicElementInStaticArray.arc32.json b/tests/contracts/artifacts/ABITestDynamicAccessOfDynamicElementInStaticArray.arc32.json index 1b0e9fc61..18b785103 100644 --- a/tests/contracts/artifacts/ABITestDynamicAccessOfDynamicElementInStaticArray.arc32.json +++ b/tests/contracts/artifacts/ABITestDynamicAccessOfDynamicElementInStaticArray.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZHluYW1pY0FjY2Vzc09mRHluYW1pY0VsZW1lbnRJblN0YXRpY0FycmF5KHN0cmluZ1szXSlzdHJpbmcKKmFiaV9yb3V0ZV9keW5hbWljQWNjZXNzT2ZEeW5hbWljRWxlbWVudEluU3RhdGljQXJyYXk6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gYTogc3RyaW5nWzNdCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCgoJLy8gZXhlY3V0ZSBkeW5hbWljQWNjZXNzT2ZEeW5hbWljRWxlbWVudEluU3RhdGljQXJyYXkoc3RyaW5nWzNdKXN0cmluZwoJY2FsbHN1YiBkeW5hbWljQWNjZXNzT2ZEeW5hbWljRWxlbWVudEluU3RhdGljQXJyYXkKCWR1cAoJbGVuCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGR5bmFtaWNBY2Nlc3NPZkR5bmFtaWNFbGVtZW50SW5TdGF0aWNBcnJheShhOiBTdGF0aWNBcnJheTxzdHJpbmcsIDM+KTogc3RyaW5nCmR5bmFtaWNBY2Nlc3NPZkR5bmFtaWNFbGVtZW50SW5TdGF0aWNBcnJheToKCXByb3RvIDEgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglwdXNoYnl0ZXMgMHgKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NjUxCgkvLyBpID0gYnRvaShpdG9iKDEpKQoJcHVzaGludCAxCglmcmFtZV9idXJ5IDAgLy8gaTogdWludDY0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjY1MgoJLy8gcmV0dXJuIGFbaV07CglmcmFtZV9kaWcgLTEgLy8gYTogU3RhdGljQXJyYXk8c3RyaW5nLCAzPgoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgMCAvLyBpbml0aWFsIG9mZnNldAoJZnJhbWVfZGlnIDAgLy8gaTogdWludDY0CglwdXNoaW50IDIKCSogLy8gYWNjICogMgoJKwoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJdW5jb3ZlciAyCglleHRyYWN0X3VpbnQxNgoJZHVwIC8vIGR1cGxpY2F0ZSBzdGFydCBvZiBlbGVtZW50Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglzd2FwCglleHRyYWN0X3VpbnQxNiAvLyBnZXQgbnVtYmVyIG9mIGVsZW1lbnRzCglwdXNoaW50IDEgLy8gZ2V0IHR5cGUgbGVuZ3RoCgkqIC8vIG11bHRpcGx5IGJ5IHR5cGUgbGVuZ3RoCglwdXNoaW50IDIKCSsgLy8gYWRkIHR3byBmb3IgbGVuZ3RoCglleHRyYWN0MwoJZXh0cmFjdCAyIDAKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4NWFhMGYzMTYgLy8gbWV0aG9kICJkeW5hbWljQWNjZXNzT2ZEeW5hbWljRWxlbWVudEluU3RhdGljQXJyYXkoc3RyaW5nWzNdKXN0cmluZyIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfZHluYW1pY0FjY2Vzc09mRHluYW1pY0VsZW1lbnRJblN0YXRpY0FycmF5CgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZHluYW1pY0FjY2Vzc09mRHluYW1pY0VsZW1lbnRJblN0YXRpY0FycmF5KHN0cmluZ1szXSlzdHJpbmcKKmFiaV9yb3V0ZV9keW5hbWljQWNjZXNzT2ZEeW5hbWljRWxlbWVudEluU3RhdGljQXJyYXk6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gYTogc3RyaW5nWzNdCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCgoJLy8gZXhlY3V0ZSBkeW5hbWljQWNjZXNzT2ZEeW5hbWljRWxlbWVudEluU3RhdGljQXJyYXkoc3RyaW5nWzNdKXN0cmluZwoJY2FsbHN1YiBkeW5hbWljQWNjZXNzT2ZEeW5hbWljRWxlbWVudEluU3RhdGljQXJyYXkKCWR1cAoJbGVuCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGR5bmFtaWNBY2Nlc3NPZkR5bmFtaWNFbGVtZW50SW5TdGF0aWNBcnJheShhOiBTdGF0aWNBcnJheTxzdHJpbmcsIDM+KTogc3RyaW5nCmR5bmFtaWNBY2Nlc3NPZkR5bmFtaWNFbGVtZW50SW5TdGF0aWNBcnJheToKCXByb3RvIDEgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglwdXNoYnl0ZXMgMHgKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NjUxCgkvLyBpID0gYnRvaShpdG9iKDEpKQoJcHVzaGludCAxCglmcmFtZV9idXJ5IDAgLy8gaTogdWludDY0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjY1MgoJLy8gcmV0dXJuIGFbaV07CglmcmFtZV9kaWcgLTEgLy8gYTogU3RhdGljQXJyYXk8c3RyaW5nLCAzPgoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgMCAvLyBpbml0aWFsIG9mZnNldAoJZnJhbWVfZGlnIDAgLy8gaTogdWludDY0CglwdXNoaW50IDIKCSogLy8gYWNjICogMgoJKwoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJdW5jb3ZlciAyCglleHRyYWN0X3VpbnQxNgoJZHVwIC8vIGR1cGxpY2F0ZSBzdGFydCBvZiBlbGVtZW50Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglzd2FwCglleHRyYWN0X3VpbnQxNiAvLyBnZXQgbnVtYmVyIG9mIGVsZW1lbnRzCglwdXNoaW50IDEgLy8gZ2V0IHR5cGUgbGVuZ3RoCgkqIC8vIG11bHRpcGx5IGJ5IHR5cGUgbGVuZ3RoCglwdXNoaW50IDIKCSsgLy8gYWRkIHR3byBmb3IgbGVuZ3RoCglleHRyYWN0MwoJZXh0cmFjdCAyIDAKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4NWFhMGYzMTYgLy8gbWV0aG9kICJkeW5hbWljQWNjZXNzT2ZEeW5hbWljRWxlbWVudEluU3RhdGljQXJyYXkoc3RyaW5nWzNdKXN0cmluZyIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfZHluYW1pY0FjY2Vzc09mRHluYW1pY0VsZW1lbnRJblN0YXRpY0FycmF5CgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestDynamicAccessOfDynamicElementInStaticArray.arc56_draft.json b/tests/contracts/artifacts/ABITestDynamicAccessOfDynamicElementInStaticArray.arc56_draft.json index 2adf81ca1..7d7aca3f0 100644 --- a/tests/contracts/artifacts/ABITestDynamicAccessOfDynamicElementInStaticArray.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestDynamicAccessOfDynamicElementInStaticArray.arc56_draft.json @@ -573,7 +573,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZHluYW1pY0FjY2Vzc09mRHluYW1pY0VsZW1lbnRJblN0YXRpY0FycmF5KHN0cmluZ1szXSlzdHJpbmcKKmFiaV9yb3V0ZV9keW5hbWljQWNjZXNzT2ZEeW5hbWljRWxlbWVudEluU3RhdGljQXJyYXk6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gYTogc3RyaW5nWzNdCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCgoJLy8gZXhlY3V0ZSBkeW5hbWljQWNjZXNzT2ZEeW5hbWljRWxlbWVudEluU3RhdGljQXJyYXkoc3RyaW5nWzNdKXN0cmluZwoJY2FsbHN1YiBkeW5hbWljQWNjZXNzT2ZEeW5hbWljRWxlbWVudEluU3RhdGljQXJyYXkKCWR1cAoJbGVuCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGR5bmFtaWNBY2Nlc3NPZkR5bmFtaWNFbGVtZW50SW5TdGF0aWNBcnJheShhOiBTdGF0aWNBcnJheTxzdHJpbmcsIDM+KTogc3RyaW5nCmR5bmFtaWNBY2Nlc3NPZkR5bmFtaWNFbGVtZW50SW5TdGF0aWNBcnJheToKCXByb3RvIDEgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglwdXNoYnl0ZXMgMHgKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NjUxCgkvLyBpID0gYnRvaShpdG9iKDEpKQoJcHVzaGludCAxCglmcmFtZV9idXJ5IDAgLy8gaTogdWludDY0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjY1MgoJLy8gcmV0dXJuIGFbaV07CglmcmFtZV9kaWcgLTEgLy8gYTogU3RhdGljQXJyYXk8c3RyaW5nLCAzPgoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgMCAvLyBpbml0aWFsIG9mZnNldAoJZnJhbWVfZGlnIDAgLy8gaTogdWludDY0CglwdXNoaW50IDIKCSogLy8gYWNjICogMgoJKwoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJdW5jb3ZlciAyCglleHRyYWN0X3VpbnQxNgoJZHVwIC8vIGR1cGxpY2F0ZSBzdGFydCBvZiBlbGVtZW50Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglzd2FwCglleHRyYWN0X3VpbnQxNiAvLyBnZXQgbnVtYmVyIG9mIGVsZW1lbnRzCglwdXNoaW50IDEgLy8gZ2V0IHR5cGUgbGVuZ3RoCgkqIC8vIG11bHRpcGx5IGJ5IHR5cGUgbGVuZ3RoCglwdXNoaW50IDIKCSsgLy8gYWRkIHR3byBmb3IgbGVuZ3RoCglleHRyYWN0MwoJZXh0cmFjdCAyIDAKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4NWFhMGYzMTYgLy8gbWV0aG9kICJkeW5hbWljQWNjZXNzT2ZEeW5hbWljRWxlbWVudEluU3RhdGljQXJyYXkoc3RyaW5nWzNdKXN0cmluZyIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfZHluYW1pY0FjY2Vzc09mRHluYW1pY0VsZW1lbnRJblN0YXRpY0FycmF5CgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZHluYW1pY0FjY2Vzc09mRHluYW1pY0VsZW1lbnRJblN0YXRpY0FycmF5KHN0cmluZ1szXSlzdHJpbmcKKmFiaV9yb3V0ZV9keW5hbWljQWNjZXNzT2ZEeW5hbWljRWxlbWVudEluU3RhdGljQXJyYXk6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gYTogc3RyaW5nWzNdCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCgoJLy8gZXhlY3V0ZSBkeW5hbWljQWNjZXNzT2ZEeW5hbWljRWxlbWVudEluU3RhdGljQXJyYXkoc3RyaW5nWzNdKXN0cmluZwoJY2FsbHN1YiBkeW5hbWljQWNjZXNzT2ZEeW5hbWljRWxlbWVudEluU3RhdGljQXJyYXkKCWR1cAoJbGVuCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGR5bmFtaWNBY2Nlc3NPZkR5bmFtaWNFbGVtZW50SW5TdGF0aWNBcnJheShhOiBTdGF0aWNBcnJheTxzdHJpbmcsIDM+KTogc3RyaW5nCmR5bmFtaWNBY2Nlc3NPZkR5bmFtaWNFbGVtZW50SW5TdGF0aWNBcnJheToKCXByb3RvIDEgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglwdXNoYnl0ZXMgMHgKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NjUxCgkvLyBpID0gYnRvaShpdG9iKDEpKQoJcHVzaGludCAxCglmcmFtZV9idXJ5IDAgLy8gaTogdWludDY0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjY1MgoJLy8gcmV0dXJuIGFbaV07CglmcmFtZV9kaWcgLTEgLy8gYTogU3RhdGljQXJyYXk8c3RyaW5nLCAzPgoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgMCAvLyBpbml0aWFsIG9mZnNldAoJZnJhbWVfZGlnIDAgLy8gaTogdWludDY0CglwdXNoaW50IDIKCSogLy8gYWNjICogMgoJKwoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJdW5jb3ZlciAyCglleHRyYWN0X3VpbnQxNgoJZHVwIC8vIGR1cGxpY2F0ZSBzdGFydCBvZiBlbGVtZW50Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglzd2FwCglleHRyYWN0X3VpbnQxNiAvLyBnZXQgbnVtYmVyIG9mIGVsZW1lbnRzCglwdXNoaW50IDEgLy8gZ2V0IHR5cGUgbGVuZ3RoCgkqIC8vIG11bHRpcGx5IGJ5IHR5cGUgbGVuZ3RoCglwdXNoaW50IDIKCSsgLy8gYWRkIHR3byBmb3IgbGVuZ3RoCglleHRyYWN0MwoJZXh0cmFjdCAyIDAKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4NWFhMGYzMTYgLy8gbWV0aG9kICJkeW5hbWljQWNjZXNzT2ZEeW5hbWljRWxlbWVudEluU3RhdGljQXJyYXkoc3RyaW5nWzNdKXN0cmluZyIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfZHluYW1pY0FjY2Vzc09mRHluYW1pY0VsZW1lbnRJblN0YXRpY0FycmF5CgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestDynamicArray.approval.teal b/tests/contracts/artifacts/ABITestDynamicArray.approval.teal index 3c2244809..fb72d2ecc 100644 --- a/tests/contracts/artifacts/ABITestDynamicArray.approval.teal +++ b/tests/contracts/artifacts/ABITestDynamicArray.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestDynamicArray.arc32.json b/tests/contracts/artifacts/ABITestDynamicArray.arc32.json index e0c645370..5e31ce4fe 100644 --- a/tests/contracts/artifacts/ABITestDynamicArray.arc32.json +++ b/tests/contracts/artifacts/ABITestDynamicArray.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZHluYW1pY0FycmF5KCl1aW50NjQKKmFiaV9yb3V0ZV9keW5hbWljQXJyYXk6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBkeW5hbWljQXJyYXkoKXVpbnQ2NAoJY2FsbHN1YiBkeW5hbWljQXJyYXkKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gZHluYW1pY0FycmF5KCk6IHVpbnQ2NApkeW5hbWljQXJyYXk6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjM0OAoJLy8gYTogdWludDY0W10gPSBbMTEsIDIyLCAzM10KCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMGIwMDAwMDAwMDAwMDAwMDE2MDAwMDAwMDAwMDAwMDAyMQoJZnJhbWVfYnVyeSAwIC8vIGE6IHVpbnQ2NFtdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjM1MAoJLy8gcmV0dXJuIGFbMV07CglmcmFtZV9kaWcgMCAvLyBhOiB1aW50NjRbXQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWV4dHJhY3QgOCA4CglidG9pCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGJkZmU2NjBlIC8vIG1ldGhvZCAiZHluYW1pY0FycmF5KCl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2R5bmFtaWNBcnJheQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZHluYW1pY0FycmF5KCl1aW50NjQKKmFiaV9yb3V0ZV9keW5hbWljQXJyYXk6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBkeW5hbWljQXJyYXkoKXVpbnQ2NAoJY2FsbHN1YiBkeW5hbWljQXJyYXkKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gZHluYW1pY0FycmF5KCk6IHVpbnQ2NApkeW5hbWljQXJyYXk6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjM0OAoJLy8gYTogdWludDY0W10gPSBbMTEsIDIyLCAzM10KCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMGIwMDAwMDAwMDAwMDAwMDE2MDAwMDAwMDAwMDAwMDAyMQoJZnJhbWVfYnVyeSAwIC8vIGE6IHVpbnQ2NFtdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjM1MAoJLy8gcmV0dXJuIGFbMV07CglmcmFtZV9kaWcgMCAvLyBhOiB1aW50NjRbXQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWV4dHJhY3QgOCA4CglidG9pCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGJkZmU2NjBlIC8vIG1ldGhvZCAiZHluYW1pY0FycmF5KCl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2R5bmFtaWNBcnJheQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestDynamicArray.arc56_draft.json b/tests/contracts/artifacts/ABITestDynamicArray.arc56_draft.json index 66c8bbece..6f0681e04 100644 --- a/tests/contracts/artifacts/ABITestDynamicArray.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestDynamicArray.arc56_draft.json @@ -426,7 +426,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZHluYW1pY0FycmF5KCl1aW50NjQKKmFiaV9yb3V0ZV9keW5hbWljQXJyYXk6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBkeW5hbWljQXJyYXkoKXVpbnQ2NAoJY2FsbHN1YiBkeW5hbWljQXJyYXkKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gZHluYW1pY0FycmF5KCk6IHVpbnQ2NApkeW5hbWljQXJyYXk6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjM0OAoJLy8gYTogdWludDY0W10gPSBbMTEsIDIyLCAzM10KCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMGIwMDAwMDAwMDAwMDAwMDE2MDAwMDAwMDAwMDAwMDAyMQoJZnJhbWVfYnVyeSAwIC8vIGE6IHVpbnQ2NFtdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjM1MAoJLy8gcmV0dXJuIGFbMV07CglmcmFtZV9kaWcgMCAvLyBhOiB1aW50NjRbXQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWV4dHJhY3QgOCA4CglidG9pCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGJkZmU2NjBlIC8vIG1ldGhvZCAiZHluYW1pY0FycmF5KCl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2R5bmFtaWNBcnJheQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZHluYW1pY0FycmF5KCl1aW50NjQKKmFiaV9yb3V0ZV9keW5hbWljQXJyYXk6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBkeW5hbWljQXJyYXkoKXVpbnQ2NAoJY2FsbHN1YiBkeW5hbWljQXJyYXkKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gZHluYW1pY0FycmF5KCk6IHVpbnQ2NApkeW5hbWljQXJyYXk6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjM0OAoJLy8gYTogdWludDY0W10gPSBbMTEsIDIyLCAzM10KCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMGIwMDAwMDAwMDAwMDAwMDE2MDAwMDAwMDAwMDAwMDAyMQoJZnJhbWVfYnVyeSAwIC8vIGE6IHVpbnQ2NFtdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjM1MAoJLy8gcmV0dXJuIGFbMV07CglmcmFtZV9kaWcgMCAvLyBhOiB1aW50NjRbXQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWV4dHJhY3QgOCA4CglidG9pCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGJkZmU2NjBlIC8vIG1ldGhvZCAiZHluYW1pY0FycmF5KCl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2R5bmFtaWNBcnJheQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestDynamicArrayArg.approval.teal b/tests/contracts/artifacts/ABITestDynamicArrayArg.approval.teal index fa70a316f..19ba67667 100644 --- a/tests/contracts/artifacts/ABITestDynamicArrayArg.approval.teal +++ b/tests/contracts/artifacts/ABITestDynamicArrayArg.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestDynamicArrayArg.arc32.json b/tests/contracts/artifacts/ABITestDynamicArrayArg.arc32.json index 6add48705..ea2164a53 100644 --- a/tests/contracts/artifacts/ABITestDynamicArrayArg.arc32.json +++ b/tests/contracts/artifacts/ABITestDynamicArrayArg.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZHluYW1pY0FycmF5QXJnKHVpbnQ2NFtdKXVpbnQ2NAoqYWJpX3JvdXRlX2R5bmFtaWNBcnJheUFyZzoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBhOiB1aW50NjRbXQoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJZXh0cmFjdCAyIDAKCgkvLyBleGVjdXRlIGR5bmFtaWNBcnJheUFyZyh1aW50NjRbXSl1aW50NjQKCWNhbGxzdWIgZHluYW1pY0FycmF5QXJnCglpdG9iCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGR5bmFtaWNBcnJheUFyZyhhOiB1aW50NjRbXSk6IHVpbnQ2NApkeW5hbWljQXJyYXlBcmc6Cglwcm90byAxIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MzYzCgkvLyByZXR1cm4gYVsxXTsKCWZyYW1lX2RpZyAtMSAvLyBhOiB1aW50NjRbXQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWV4dHJhY3QgOCA4CglidG9pCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGFhYzQ0Yzc5IC8vIG1ldGhvZCAiZHluYW1pY0FycmF5QXJnKHVpbnQ2NFtdKXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfZHluYW1pY0FycmF5QXJnCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZHluYW1pY0FycmF5QXJnKHVpbnQ2NFtdKXVpbnQ2NAoqYWJpX3JvdXRlX2R5bmFtaWNBcnJheUFyZzoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBhOiB1aW50NjRbXQoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJZXh0cmFjdCAyIDAKCgkvLyBleGVjdXRlIGR5bmFtaWNBcnJheUFyZyh1aW50NjRbXSl1aW50NjQKCWNhbGxzdWIgZHluYW1pY0FycmF5QXJnCglpdG9iCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGR5bmFtaWNBcnJheUFyZyhhOiB1aW50NjRbXSk6IHVpbnQ2NApkeW5hbWljQXJyYXlBcmc6Cglwcm90byAxIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MzYzCgkvLyByZXR1cm4gYVsxXTsKCWZyYW1lX2RpZyAtMSAvLyBhOiB1aW50NjRbXQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWV4dHJhY3QgOCA4CglidG9pCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGFhYzQ0Yzc5IC8vIG1ldGhvZCAiZHluYW1pY0FycmF5QXJnKHVpbnQ2NFtdKXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfZHluYW1pY0FycmF5QXJnCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestDynamicArrayArg.arc56_draft.json b/tests/contracts/artifacts/ABITestDynamicArrayArg.arc56_draft.json index 1840a90a8..e18b78235 100644 --- a/tests/contracts/artifacts/ABITestDynamicArrayArg.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestDynamicArrayArg.arc56_draft.json @@ -393,7 +393,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZHluYW1pY0FycmF5QXJnKHVpbnQ2NFtdKXVpbnQ2NAoqYWJpX3JvdXRlX2R5bmFtaWNBcnJheUFyZzoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBhOiB1aW50NjRbXQoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJZXh0cmFjdCAyIDAKCgkvLyBleGVjdXRlIGR5bmFtaWNBcnJheUFyZyh1aW50NjRbXSl1aW50NjQKCWNhbGxzdWIgZHluYW1pY0FycmF5QXJnCglpdG9iCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGR5bmFtaWNBcnJheUFyZyhhOiB1aW50NjRbXSk6IHVpbnQ2NApkeW5hbWljQXJyYXlBcmc6Cglwcm90byAxIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MzYzCgkvLyByZXR1cm4gYVsxXTsKCWZyYW1lX2RpZyAtMSAvLyBhOiB1aW50NjRbXQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWV4dHJhY3QgOCA4CglidG9pCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGFhYzQ0Yzc5IC8vIG1ldGhvZCAiZHluYW1pY0FycmF5QXJnKHVpbnQ2NFtdKXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfZHluYW1pY0FycmF5QXJnCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZHluYW1pY0FycmF5QXJnKHVpbnQ2NFtdKXVpbnQ2NAoqYWJpX3JvdXRlX2R5bmFtaWNBcnJheUFyZzoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBhOiB1aW50NjRbXQoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJZXh0cmFjdCAyIDAKCgkvLyBleGVjdXRlIGR5bmFtaWNBcnJheUFyZyh1aW50NjRbXSl1aW50NjQKCWNhbGxzdWIgZHluYW1pY0FycmF5QXJnCglpdG9iCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGR5bmFtaWNBcnJheUFyZyhhOiB1aW50NjRbXSk6IHVpbnQ2NApkeW5hbWljQXJyYXlBcmc6Cglwcm90byAxIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MzYzCgkvLyByZXR1cm4gYVsxXTsKCWZyYW1lX2RpZyAtMSAvLyBhOiB1aW50NjRbXQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWV4dHJhY3QgOCA4CglidG9pCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGFhYzQ0Yzc5IC8vIG1ldGhvZCAiZHluYW1pY0FycmF5QXJnKHVpbnQ2NFtdKXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfZHluYW1pY0FycmF5QXJnCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestDynamicArrayElements.approval.teal b/tests/contracts/artifacts/ABITestDynamicArrayElements.approval.teal index 57be7869f..b2de4a251 100644 --- a/tests/contracts/artifacts/ABITestDynamicArrayElements.approval.teal +++ b/tests/contracts/artifacts/ABITestDynamicArrayElements.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestDynamicArrayElements.arc32.json b/tests/contracts/artifacts/ABITestDynamicArrayElements.arc32.json index 3c66ae0ba..b22601a4c 100644 --- a/tests/contracts/artifacts/ABITestDynamicArrayElements.arc32.json +++ b/tests/contracts/artifacts/ABITestDynamicArrayElements.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBkeW5hbWljQXJyYXlFbGVtZW50cygpdWludDE2W10KKmFiaV9yb3V0ZV9keW5hbWljQXJyYXlFbGVtZW50czoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGR5bmFtaWNBcnJheUVsZW1lbnRzKCl1aW50MTZbXQoJY2FsbHN1YiBkeW5hbWljQXJyYXlFbGVtZW50cwoJZHVwCglsZW4KCXB1c2hpbnQgMgoJLwoJaXRvYgoJZXh0cmFjdCA2IDIKCXN3YXAKCWNvbmNhdAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBkeW5hbWljQXJyYXlFbGVtZW50cygpOiB1aW50MTZbXQpkeW5hbWljQXJyYXlFbGVtZW50czoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NDgxCgkvLyBhOiB1aW50MTZbXSA9IFsxLCAyLCAzXQoJcHVzaGJ5dGVzIDB4MDAwMTAwMDIwMDAzCglmcmFtZV9idXJ5IDAgLy8gYTogdWludDE2W10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NDgyCgkvLyBuZXdBOiB1aW50MTZbXSA9IFthWzBdLCBhWzFdLCBhWzJdXQoJZnJhbWVfZGlnIDAgLy8gYTogdWludDE2W10KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglleHRyYWN0IDAgMgoJYnRvaQoJaXRvYgoJZXh0cmFjdCA2IDIKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCglzdG9yZSAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJZXh0cmFjdCAyIDIKCWJ0b2kKCWl0b2IKCWV4dHJhY3QgNiAyCgljb25jYXQKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCglzdG9yZSAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJZXh0cmFjdCA0IDIKCWJ0b2kKCWl0b2IKCWV4dHJhY3QgNiAyCgljb25jYXQKCWZyYW1lX2J1cnkgMSAvLyBuZXdBOiB1aW50MTZbXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo0ODQKCS8vIHJldHVybiBuZXdBOwoJZnJhbWVfZGlnIDEgLy8gbmV3QTogdWludDE2W10KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCgkvLyBwb3AgYWxsIGxvY2FsIHZhcmlhYmxlcyBmcm9tIHRoZSBzdGFjawoJcG9wbiAxCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGI0ZGNiNzVlIC8vIG1ldGhvZCAiZHluYW1pY0FycmF5RWxlbWVudHMoKXVpbnQxNltdIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9keW5hbWljQXJyYXlFbGVtZW50cwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBkeW5hbWljQXJyYXlFbGVtZW50cygpdWludDE2W10KKmFiaV9yb3V0ZV9keW5hbWljQXJyYXlFbGVtZW50czoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGR5bmFtaWNBcnJheUVsZW1lbnRzKCl1aW50MTZbXQoJY2FsbHN1YiBkeW5hbWljQXJyYXlFbGVtZW50cwoJZHVwCglsZW4KCXB1c2hpbnQgMgoJLwoJaXRvYgoJZXh0cmFjdCA2IDIKCXN3YXAKCWNvbmNhdAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBkeW5hbWljQXJyYXlFbGVtZW50cygpOiB1aW50MTZbXQpkeW5hbWljQXJyYXlFbGVtZW50czoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NDgxCgkvLyBhOiB1aW50MTZbXSA9IFsxLCAyLCAzXQoJcHVzaGJ5dGVzIDB4MDAwMTAwMDIwMDAzCglmcmFtZV9idXJ5IDAgLy8gYTogdWludDE2W10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NDgyCgkvLyBuZXdBOiB1aW50MTZbXSA9IFthWzBdLCBhWzFdLCBhWzJdXQoJZnJhbWVfZGlnIDAgLy8gYTogdWludDE2W10KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglleHRyYWN0IDAgMgoJYnRvaQoJaXRvYgoJZXh0cmFjdCA2IDIKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCglzdG9yZSAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJZXh0cmFjdCAyIDIKCWJ0b2kKCWl0b2IKCWV4dHJhY3QgNiAyCgljb25jYXQKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCglzdG9yZSAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJZXh0cmFjdCA0IDIKCWJ0b2kKCWl0b2IKCWV4dHJhY3QgNiAyCgljb25jYXQKCWZyYW1lX2J1cnkgMSAvLyBuZXdBOiB1aW50MTZbXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo0ODQKCS8vIHJldHVybiBuZXdBOwoJZnJhbWVfZGlnIDEgLy8gbmV3QTogdWludDE2W10KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCgkvLyBwb3AgYWxsIGxvY2FsIHZhcmlhYmxlcyBmcm9tIHRoZSBzdGFjawoJcG9wbiAxCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGI0ZGNiNzVlIC8vIG1ldGhvZCAiZHluYW1pY0FycmF5RWxlbWVudHMoKXVpbnQxNltdIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9keW5hbWljQXJyYXlFbGVtZW50cwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestDynamicArrayElements.arc56_draft.json b/tests/contracts/artifacts/ABITestDynamicArrayElements.arc56_draft.json index c47c805d3..eb6f3ddf3 100644 --- a/tests/contracts/artifacts/ABITestDynamicArrayElements.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestDynamicArrayElements.arc56_draft.json @@ -642,7 +642,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBkeW5hbWljQXJyYXlFbGVtZW50cygpdWludDE2W10KKmFiaV9yb3V0ZV9keW5hbWljQXJyYXlFbGVtZW50czoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGR5bmFtaWNBcnJheUVsZW1lbnRzKCl1aW50MTZbXQoJY2FsbHN1YiBkeW5hbWljQXJyYXlFbGVtZW50cwoJZHVwCglsZW4KCXB1c2hpbnQgMgoJLwoJaXRvYgoJZXh0cmFjdCA2IDIKCXN3YXAKCWNvbmNhdAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBkeW5hbWljQXJyYXlFbGVtZW50cygpOiB1aW50MTZbXQpkeW5hbWljQXJyYXlFbGVtZW50czoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NDgxCgkvLyBhOiB1aW50MTZbXSA9IFsxLCAyLCAzXQoJcHVzaGJ5dGVzIDB4MDAwMTAwMDIwMDAzCglmcmFtZV9idXJ5IDAgLy8gYTogdWludDE2W10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NDgyCgkvLyBuZXdBOiB1aW50MTZbXSA9IFthWzBdLCBhWzFdLCBhWzJdXQoJZnJhbWVfZGlnIDAgLy8gYTogdWludDE2W10KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglleHRyYWN0IDAgMgoJYnRvaQoJaXRvYgoJZXh0cmFjdCA2IDIKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCglzdG9yZSAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJZXh0cmFjdCAyIDIKCWJ0b2kKCWl0b2IKCWV4dHJhY3QgNiAyCgljb25jYXQKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCglzdG9yZSAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJZXh0cmFjdCA0IDIKCWJ0b2kKCWl0b2IKCWV4dHJhY3QgNiAyCgljb25jYXQKCWZyYW1lX2J1cnkgMSAvLyBuZXdBOiB1aW50MTZbXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo0ODQKCS8vIHJldHVybiBuZXdBOwoJZnJhbWVfZGlnIDEgLy8gbmV3QTogdWludDE2W10KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCgkvLyBwb3AgYWxsIGxvY2FsIHZhcmlhYmxlcyBmcm9tIHRoZSBzdGFjawoJcG9wbiAxCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGI0ZGNiNzVlIC8vIG1ldGhvZCAiZHluYW1pY0FycmF5RWxlbWVudHMoKXVpbnQxNltdIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9keW5hbWljQXJyYXlFbGVtZW50cwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBkeW5hbWljQXJyYXlFbGVtZW50cygpdWludDE2W10KKmFiaV9yb3V0ZV9keW5hbWljQXJyYXlFbGVtZW50czoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGR5bmFtaWNBcnJheUVsZW1lbnRzKCl1aW50MTZbXQoJY2FsbHN1YiBkeW5hbWljQXJyYXlFbGVtZW50cwoJZHVwCglsZW4KCXB1c2hpbnQgMgoJLwoJaXRvYgoJZXh0cmFjdCA2IDIKCXN3YXAKCWNvbmNhdAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBkeW5hbWljQXJyYXlFbGVtZW50cygpOiB1aW50MTZbXQpkeW5hbWljQXJyYXlFbGVtZW50czoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NDgxCgkvLyBhOiB1aW50MTZbXSA9IFsxLCAyLCAzXQoJcHVzaGJ5dGVzIDB4MDAwMTAwMDIwMDAzCglmcmFtZV9idXJ5IDAgLy8gYTogdWludDE2W10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NDgyCgkvLyBuZXdBOiB1aW50MTZbXSA9IFthWzBdLCBhWzFdLCBhWzJdXQoJZnJhbWVfZGlnIDAgLy8gYTogdWludDE2W10KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglleHRyYWN0IDAgMgoJYnRvaQoJaXRvYgoJZXh0cmFjdCA2IDIKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCglzdG9yZSAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJZXh0cmFjdCAyIDIKCWJ0b2kKCWl0b2IKCWV4dHJhY3QgNiAyCgljb25jYXQKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCglzdG9yZSAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJZXh0cmFjdCA0IDIKCWJ0b2kKCWl0b2IKCWV4dHJhY3QgNiAyCgljb25jYXQKCWZyYW1lX2J1cnkgMSAvLyBuZXdBOiB1aW50MTZbXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo0ODQKCS8vIHJldHVybiBuZXdBOwoJZnJhbWVfZGlnIDEgLy8gbmV3QTogdWludDE2W10KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCgkvLyBwb3AgYWxsIGxvY2FsIHZhcmlhYmxlcyBmcm9tIHRoZSBzdGFjawoJcG9wbiAxCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGI0ZGNiNzVlIC8vIG1ldGhvZCAiZHluYW1pY0FycmF5RWxlbWVudHMoKXVpbnQxNltdIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9keW5hbWljQXJyYXlFbGVtZW50cwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestDynamicArrayInMiddleOfTuple.approval.teal b/tests/contracts/artifacts/ABITestDynamicArrayInMiddleOfTuple.approval.teal index a797cddc5..555d9d16c 100644 --- a/tests/contracts/artifacts/ABITestDynamicArrayInMiddleOfTuple.approval.teal +++ b/tests/contracts/artifacts/ABITestDynamicArrayInMiddleOfTuple.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestDynamicArrayInMiddleOfTuple.arc32.json b/tests/contracts/artifacts/ABITestDynamicArrayInMiddleOfTuple.arc32.json index 99b1fccad..dba2a288b 100644 --- a/tests/contracts/artifacts/ABITestDynamicArrayInMiddleOfTuple.arc32.json +++ b/tests/contracts/artifacts/ABITestDynamicArrayInMiddleOfTuple.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBkeW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGUoKSh1aW50MTYsdWludDhbXSx1aW50MTYpCiphYmlfcm91dGVfZHluYW1pY0FycmF5SW5NaWRkbGVPZlR1cGxlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgZHluYW1pY0FycmF5SW5NaWRkbGVPZlR1cGxlKCkodWludDE2LHVpbnQ4W10sdWludDE2KQoJY2FsbHN1YiBkeW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGUKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gZHluYW1pY0FycmF5SW5NaWRkbGVPZlR1cGxlKCk6IFt1aW50MTYsIHVpbnQ8OD5bXSwgdWludDE2XQpkeW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGU6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJYnl0ZSAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo2NTgKCS8vIGE6IFt1aW50MTYsIHVpbnQ8OD5bXSwgdWludDE2XSA9IFsxLCBbMl0sIDNdCglieXRlIDB4IC8vIGluaXRpYWwgaGVhZAoJYnl0ZSAweCAvLyBpbml0aWFsIHRhaWwKCXB1c2hieXRlcyAweDAwMDYgLy8gaW5pdGlhbCBoZWFkIG9mZnNldAoJcHVzaGJ5dGVzIDB4MDAwMQoJY2FsbHN1YiAqcHJvY2Vzc19zdGF0aWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwMTAyCgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwMwoJY2FsbHN1YiAqcHJvY2Vzc19zdGF0aWNfdHVwbGVfZWxlbWVudAoJcG9wIC8vIHBvcCBoZWFkIG9mZnNldAoJY29uY2F0IC8vIGNvbmNhdCBoZWFkIGFuZCB0YWlsCglmcmFtZV9idXJ5IDAgLy8gYTogW3VpbnQxNiwgdWludDw4PltdLCB1aW50MTZdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjY2MAoJLy8gcmV0dXJuIGE7CglmcmFtZV9kaWcgMCAvLyBhOiBbdWludDE2LCB1aW50PDg+W10sIHVpbnQxNl0KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YWNiZjJlNzMgLy8gbWV0aG9kICJkeW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGUoKSh1aW50MTYsdWludDhbXSx1aW50MTYpIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9keW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGUKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnIKCipwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50OgoJcHJvdG8gNCAzCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0xIC8vIGVsZW1lbnQKCWNvbmNhdAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3ViCgoqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCWNvbmNhdAoJZnJhbWVfYnVyeSAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJZHVwCglsZW4KCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJYnRvaQoJKwoJaXRvYgoJZXh0cmFjdCA2IDIKCWZyYW1lX2J1cnkgLTIgLy8gaGVhZCBvZmZzZXQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglzd2FwCgljb25jYXQKCWZyYW1lX2J1cnkgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCXJldHN1Yg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBkeW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGUoKSh1aW50MTYsdWludDhbXSx1aW50MTYpCiphYmlfcm91dGVfZHluYW1pY0FycmF5SW5NaWRkbGVPZlR1cGxlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgZHluYW1pY0FycmF5SW5NaWRkbGVPZlR1cGxlKCkodWludDE2LHVpbnQ4W10sdWludDE2KQoJY2FsbHN1YiBkeW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGUKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gZHluYW1pY0FycmF5SW5NaWRkbGVPZlR1cGxlKCk6IFt1aW50MTYsIHVpbnQ8OD5bXSwgdWludDE2XQpkeW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGU6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJYnl0ZSAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo2NTgKCS8vIGE6IFt1aW50MTYsIHVpbnQ8OD5bXSwgdWludDE2XSA9IFsxLCBbMl0sIDNdCglieXRlIDB4IC8vIGluaXRpYWwgaGVhZAoJYnl0ZSAweCAvLyBpbml0aWFsIHRhaWwKCXB1c2hieXRlcyAweDAwMDYgLy8gaW5pdGlhbCBoZWFkIG9mZnNldAoJcHVzaGJ5dGVzIDB4MDAwMQoJY2FsbHN1YiAqcHJvY2Vzc19zdGF0aWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwMTAyCgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwMwoJY2FsbHN1YiAqcHJvY2Vzc19zdGF0aWNfdHVwbGVfZWxlbWVudAoJcG9wIC8vIHBvcCBoZWFkIG9mZnNldAoJY29uY2F0IC8vIGNvbmNhdCBoZWFkIGFuZCB0YWlsCglmcmFtZV9idXJ5IDAgLy8gYTogW3VpbnQxNiwgdWludDw4PltdLCB1aW50MTZdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjY2MAoJLy8gcmV0dXJuIGE7CglmcmFtZV9kaWcgMCAvLyBhOiBbdWludDE2LCB1aW50PDg+W10sIHVpbnQxNl0KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YWNiZjJlNzMgLy8gbWV0aG9kICJkeW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGUoKSh1aW50MTYsdWludDhbXSx1aW50MTYpIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9keW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGUKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnIKCipwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50OgoJcHJvdG8gNCAzCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0xIC8vIGVsZW1lbnQKCWNvbmNhdAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3ViCgoqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCWNvbmNhdAoJZnJhbWVfYnVyeSAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJZHVwCglsZW4KCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJYnRvaQoJKwoJaXRvYgoJZXh0cmFjdCA2IDIKCWZyYW1lX2J1cnkgLTIgLy8gaGVhZCBvZmZzZXQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglzd2FwCgljb25jYXQKCWZyYW1lX2J1cnkgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCXJldHN1Yg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestDynamicArrayInMiddleOfTuple.arc56_draft.json b/tests/contracts/artifacts/ABITestDynamicArrayInMiddleOfTuple.arc56_draft.json index 213466d0c..fb818d8b6 100644 --- a/tests/contracts/artifacts/ABITestDynamicArrayInMiddleOfTuple.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestDynamicArrayInMiddleOfTuple.arc56_draft.json @@ -686,7 +686,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBkeW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGUoKSh1aW50MTYsdWludDhbXSx1aW50MTYpCiphYmlfcm91dGVfZHluYW1pY0FycmF5SW5NaWRkbGVPZlR1cGxlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgZHluYW1pY0FycmF5SW5NaWRkbGVPZlR1cGxlKCkodWludDE2LHVpbnQ4W10sdWludDE2KQoJY2FsbHN1YiBkeW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGUKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gZHluYW1pY0FycmF5SW5NaWRkbGVPZlR1cGxlKCk6IFt1aW50MTYsIHVpbnQ8OD5bXSwgdWludDE2XQpkeW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGU6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJYnl0ZSAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo2NTgKCS8vIGE6IFt1aW50MTYsIHVpbnQ8OD5bXSwgdWludDE2XSA9IFsxLCBbMl0sIDNdCglieXRlIDB4IC8vIGluaXRpYWwgaGVhZAoJYnl0ZSAweCAvLyBpbml0aWFsIHRhaWwKCXB1c2hieXRlcyAweDAwMDYgLy8gaW5pdGlhbCBoZWFkIG9mZnNldAoJcHVzaGJ5dGVzIDB4MDAwMQoJY2FsbHN1YiAqcHJvY2Vzc19zdGF0aWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwMTAyCgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwMwoJY2FsbHN1YiAqcHJvY2Vzc19zdGF0aWNfdHVwbGVfZWxlbWVudAoJcG9wIC8vIHBvcCBoZWFkIG9mZnNldAoJY29uY2F0IC8vIGNvbmNhdCBoZWFkIGFuZCB0YWlsCglmcmFtZV9idXJ5IDAgLy8gYTogW3VpbnQxNiwgdWludDw4PltdLCB1aW50MTZdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjY2MAoJLy8gcmV0dXJuIGE7CglmcmFtZV9kaWcgMCAvLyBhOiBbdWludDE2LCB1aW50PDg+W10sIHVpbnQxNl0KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YWNiZjJlNzMgLy8gbWV0aG9kICJkeW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGUoKSh1aW50MTYsdWludDhbXSx1aW50MTYpIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9keW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGUKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnIKCipwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50OgoJcHJvdG8gNCAzCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0xIC8vIGVsZW1lbnQKCWNvbmNhdAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3ViCgoqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCWNvbmNhdAoJZnJhbWVfYnVyeSAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJZHVwCglsZW4KCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJYnRvaQoJKwoJaXRvYgoJZXh0cmFjdCA2IDIKCWZyYW1lX2J1cnkgLTIgLy8gaGVhZCBvZmZzZXQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglzd2FwCgljb25jYXQKCWZyYW1lX2J1cnkgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCXJldHN1Yg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBkeW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGUoKSh1aW50MTYsdWludDhbXSx1aW50MTYpCiphYmlfcm91dGVfZHluYW1pY0FycmF5SW5NaWRkbGVPZlR1cGxlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgZHluYW1pY0FycmF5SW5NaWRkbGVPZlR1cGxlKCkodWludDE2LHVpbnQ4W10sdWludDE2KQoJY2FsbHN1YiBkeW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGUKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gZHluYW1pY0FycmF5SW5NaWRkbGVPZlR1cGxlKCk6IFt1aW50MTYsIHVpbnQ8OD5bXSwgdWludDE2XQpkeW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGU6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJYnl0ZSAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo2NTgKCS8vIGE6IFt1aW50MTYsIHVpbnQ8OD5bXSwgdWludDE2XSA9IFsxLCBbMl0sIDNdCglieXRlIDB4IC8vIGluaXRpYWwgaGVhZAoJYnl0ZSAweCAvLyBpbml0aWFsIHRhaWwKCXB1c2hieXRlcyAweDAwMDYgLy8gaW5pdGlhbCBoZWFkIG9mZnNldAoJcHVzaGJ5dGVzIDB4MDAwMQoJY2FsbHN1YiAqcHJvY2Vzc19zdGF0aWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwMTAyCgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwMwoJY2FsbHN1YiAqcHJvY2Vzc19zdGF0aWNfdHVwbGVfZWxlbWVudAoJcG9wIC8vIHBvcCBoZWFkIG9mZnNldAoJY29uY2F0IC8vIGNvbmNhdCBoZWFkIGFuZCB0YWlsCglmcmFtZV9idXJ5IDAgLy8gYTogW3VpbnQxNiwgdWludDw4PltdLCB1aW50MTZdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjY2MAoJLy8gcmV0dXJuIGE7CglmcmFtZV9kaWcgMCAvLyBhOiBbdWludDE2LCB1aW50PDg+W10sIHVpbnQxNl0KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YWNiZjJlNzMgLy8gbWV0aG9kICJkeW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGUoKSh1aW50MTYsdWludDhbXSx1aW50MTYpIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9keW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGUKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnIKCipwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50OgoJcHJvdG8gNCAzCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0xIC8vIGVsZW1lbnQKCWNvbmNhdAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3ViCgoqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCWNvbmNhdAoJZnJhbWVfYnVyeSAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJZHVwCglsZW4KCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJYnRvaQoJKwoJaXRvYgoJZXh0cmFjdCA2IDIKCWZyYW1lX2J1cnkgLTIgLy8gaGVhZCBvZmZzZXQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglzd2FwCgljb25jYXQKCWZyYW1lX2J1cnkgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCXJldHN1Yg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestDynamicArrayIteration.approval.teal b/tests/contracts/artifacts/ABITestDynamicArrayIteration.approval.teal index 6dbbbb2be..4d8c76669 100644 --- a/tests/contracts/artifacts/ABITestDynamicArrayIteration.approval.teal +++ b/tests/contracts/artifacts/ABITestDynamicArrayIteration.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestDynamicArrayIteration.arc32.json b/tests/contracts/artifacts/ABITestDynamicArrayIteration.arc32.json index 4becc3e88..39e087dd7 100644 --- a/tests/contracts/artifacts/ABITestDynamicArrayIteration.arc32.json +++ b/tests/contracts/artifacts/ABITestDynamicArrayIteration.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBkeW5hbWljQXJyYXlJdGVyYXRpb24oKXN0cmluZwoqYWJpX3JvdXRlX2R5bmFtaWNBcnJheUl0ZXJhdGlvbjoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGR5bmFtaWNBcnJheUl0ZXJhdGlvbigpc3RyaW5nCgljYWxsc3ViIGR5bmFtaWNBcnJheUl0ZXJhdGlvbgoJZHVwCglsZW4KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gZHluYW1pY0FycmF5SXRlcmF0aW9uKCk6IHN0cmluZwpkeW5hbWljQXJyYXlJdGVyYXRpb246Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJYnl0ZSAweAoJZHVwbiAyCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE2MDAKCS8vIGE6IHN0cmluZ1tdID0gWydIZWxsbyAnLCAnV29ybGQnLCAnISddCglieXRlIDB4IC8vIGluaXRpYWwgaGVhZAoJYnl0ZSAweCAvLyBpbml0aWFsIHRhaWwKCXB1c2hieXRlcyAweDAwMDYgLy8gaW5pdGlhbCBoZWFkIG9mZnNldAoJcHVzaGJ5dGVzIDB4MDAwNjQ4NjU2YzZjNmYyMAoJY2FsbHN1YiAqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMDU1NzZmNzI2YzY0CgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwMTIxCgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcG9wIC8vIHBvcCBoZWFkIG9mZnNldAoJY29uY2F0IC8vIGNvbmNhdCBoZWFkIGFuZCB0YWlsCglwdXNoYnl0ZXMgMHgwMDAzCglzd2FwCgljb25jYXQKCWZyYW1lX2J1cnkgMCAvLyBhOiBzdHJpbmdbXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNjAxCgkvLyBtZXNzYWdlID0gJycKCWJ5dGUgMHggLy8gIiIKCWZyYW1lX2J1cnkgMSAvLyBtZXNzYWdlOiBieXRlW10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTYwMwoJLy8gZm9yIChsZXQgaSA9IDA7IGkgPCBhLmxlbmd0aDsgaSArPSAxKQoJcHVzaGludCAwCglmcmFtZV9idXJ5IDIgLy8gaTogdWludDY0CgoqZm9yXzA6CgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTYwMwoJLy8gaSA8IGEubGVuZ3RoCglmcmFtZV9kaWcgMiAvLyBpOiB1aW50NjQKCWZyYW1lX2RpZyAwIC8vIGE6IHN0cmluZ1tdCglwdXNoaW50IDAKCWV4dHJhY3RfdWludDE2Cgk8CglieiAqZm9yXzBfZW5kCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE2MDQKCS8vIG1lc3NhZ2UgKz0gYVtpXQoJZnJhbWVfZGlnIDEgLy8gbWVzc2FnZTogYnl0ZVtdCglmcmFtZV9kaWcgMCAvLyBhOiBzdHJpbmdbXQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgMCAvLyBpbml0aWFsIG9mZnNldAoJZnJhbWVfZGlnIDIgLy8gaTogdWludDY0CglwdXNoaW50IDIKCSogLy8gYWNjICogMgoJKwoJcHVzaGludCAyCgkrIC8vIGFkZCB0d28gZm9yIGxlbmd0aAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJdW5jb3ZlciAyCglleHRyYWN0X3VpbnQxNgoJcHVzaGludCAyCgkrIC8vIGFkZCB0d28gZm9yIGxlbmd0aAoJZHVwIC8vIGR1cGxpY2F0ZSBzdGFydCBvZiBlbGVtZW50Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglzd2FwCglleHRyYWN0X3VpbnQxNiAvLyBnZXQgbnVtYmVyIG9mIGVsZW1lbnRzCglwdXNoaW50IDEgLy8gZ2V0IHR5cGUgbGVuZ3RoCgkqIC8vIG11bHRpcGx5IGJ5IHR5cGUgbGVuZ3RoCglwdXNoaW50IDIKCSsgLy8gYWRkIHR3byBmb3IgbGVuZ3RoCglleHRyYWN0MwoJZXh0cmFjdCAyIDAKCWNvbmNhdAoJZnJhbWVfYnVyeSAxIC8vIG1lc3NhZ2U6IGJ5dGVbXQoKKmZvcl8wX2NvbnRpbnVlOgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE2MDMKCS8vIGkgKz0gMQoJZnJhbWVfZGlnIDIgLy8gaTogdWludDY0CglwdXNoaW50IDEKCSsKCWZyYW1lX2J1cnkgMiAvLyBpOiB1aW50NjQKCWIgKmZvcl8wCgoqZm9yXzBfZW5kOgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE2MDcKCS8vIHJldHVybiBtZXNzYWdlOwoJZnJhbWVfZGlnIDEgLy8gbWVzc2FnZTogYnl0ZVtdCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCgoJLy8gcG9wIGFsbCBsb2NhbCB2YXJpYWJsZXMgZnJvbSB0aGUgc3RhY2sKCXBvcG4gMgoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhhOTU3YzVlZCAvLyBtZXRob2QgImR5bmFtaWNBcnJheUl0ZXJhdGlvbigpc3RyaW5nIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9keW5hbWljQXJyYXlJdGVyYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnIKCipwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJY29uY2F0CglmcmFtZV9idXJ5IC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50CglkdXAKCWxlbgoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglidG9pCgkrCglpdG9iCglleHRyYWN0IDYgMgoJZnJhbWVfYnVyeSAtMiAvLyBoZWFkIG9mZnNldAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCXN3YXAKCWNvbmNhdAoJZnJhbWVfYnVyeSAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3Vi", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBkeW5hbWljQXJyYXlJdGVyYXRpb24oKXN0cmluZwoqYWJpX3JvdXRlX2R5bmFtaWNBcnJheUl0ZXJhdGlvbjoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGR5bmFtaWNBcnJheUl0ZXJhdGlvbigpc3RyaW5nCgljYWxsc3ViIGR5bmFtaWNBcnJheUl0ZXJhdGlvbgoJZHVwCglsZW4KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gZHluYW1pY0FycmF5SXRlcmF0aW9uKCk6IHN0cmluZwpkeW5hbWljQXJyYXlJdGVyYXRpb246Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJYnl0ZSAweAoJZHVwbiAyCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE2MDAKCS8vIGE6IHN0cmluZ1tdID0gWydIZWxsbyAnLCAnV29ybGQnLCAnISddCglieXRlIDB4IC8vIGluaXRpYWwgaGVhZAoJYnl0ZSAweCAvLyBpbml0aWFsIHRhaWwKCXB1c2hieXRlcyAweDAwMDYgLy8gaW5pdGlhbCBoZWFkIG9mZnNldAoJcHVzaGJ5dGVzIDB4MDAwNjQ4NjU2YzZjNmYyMAoJY2FsbHN1YiAqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMDU1NzZmNzI2YzY0CgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwMTIxCgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcG9wIC8vIHBvcCBoZWFkIG9mZnNldAoJY29uY2F0IC8vIGNvbmNhdCBoZWFkIGFuZCB0YWlsCglwdXNoYnl0ZXMgMHgwMDAzCglzd2FwCgljb25jYXQKCWZyYW1lX2J1cnkgMCAvLyBhOiBzdHJpbmdbXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNjAxCgkvLyBtZXNzYWdlID0gJycKCWJ5dGUgMHggLy8gIiIKCWZyYW1lX2J1cnkgMSAvLyBtZXNzYWdlOiBieXRlW10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTYwMwoJLy8gZm9yIChsZXQgaSA9IDA7IGkgPCBhLmxlbmd0aDsgaSArPSAxKQoJcHVzaGludCAwCglmcmFtZV9idXJ5IDIgLy8gaTogdWludDY0CgoqZm9yXzA6CgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTYwMwoJLy8gaSA8IGEubGVuZ3RoCglmcmFtZV9kaWcgMiAvLyBpOiB1aW50NjQKCWZyYW1lX2RpZyAwIC8vIGE6IHN0cmluZ1tdCglwdXNoaW50IDAKCWV4dHJhY3RfdWludDE2Cgk8CglieiAqZm9yXzBfZW5kCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE2MDQKCS8vIG1lc3NhZ2UgKz0gYVtpXQoJZnJhbWVfZGlnIDEgLy8gbWVzc2FnZTogYnl0ZVtdCglmcmFtZV9kaWcgMCAvLyBhOiBzdHJpbmdbXQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgMCAvLyBpbml0aWFsIG9mZnNldAoJZnJhbWVfZGlnIDIgLy8gaTogdWludDY0CglwdXNoaW50IDIKCSogLy8gYWNjICogMgoJKwoJcHVzaGludCAyCgkrIC8vIGFkZCB0d28gZm9yIGxlbmd0aAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJdW5jb3ZlciAyCglleHRyYWN0X3VpbnQxNgoJcHVzaGludCAyCgkrIC8vIGFkZCB0d28gZm9yIGxlbmd0aAoJZHVwIC8vIGR1cGxpY2F0ZSBzdGFydCBvZiBlbGVtZW50Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglzd2FwCglleHRyYWN0X3VpbnQxNiAvLyBnZXQgbnVtYmVyIG9mIGVsZW1lbnRzCglwdXNoaW50IDEgLy8gZ2V0IHR5cGUgbGVuZ3RoCgkqIC8vIG11bHRpcGx5IGJ5IHR5cGUgbGVuZ3RoCglwdXNoaW50IDIKCSsgLy8gYWRkIHR3byBmb3IgbGVuZ3RoCglleHRyYWN0MwoJZXh0cmFjdCAyIDAKCWNvbmNhdAoJZnJhbWVfYnVyeSAxIC8vIG1lc3NhZ2U6IGJ5dGVbXQoKKmZvcl8wX2NvbnRpbnVlOgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE2MDMKCS8vIGkgKz0gMQoJZnJhbWVfZGlnIDIgLy8gaTogdWludDY0CglwdXNoaW50IDEKCSsKCWZyYW1lX2J1cnkgMiAvLyBpOiB1aW50NjQKCWIgKmZvcl8wCgoqZm9yXzBfZW5kOgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE2MDcKCS8vIHJldHVybiBtZXNzYWdlOwoJZnJhbWVfZGlnIDEgLy8gbWVzc2FnZTogYnl0ZVtdCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCgoJLy8gcG9wIGFsbCBsb2NhbCB2YXJpYWJsZXMgZnJvbSB0aGUgc3RhY2sKCXBvcG4gMgoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhhOTU3YzVlZCAvLyBtZXRob2QgImR5bmFtaWNBcnJheUl0ZXJhdGlvbigpc3RyaW5nIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9keW5hbWljQXJyYXlJdGVyYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnIKCipwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJY29uY2F0CglmcmFtZV9idXJ5IC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50CglkdXAKCWxlbgoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglidG9pCgkrCglpdG9iCglleHRyYWN0IDYgMgoJZnJhbWVfYnVyeSAtMiAvLyBoZWFkIG9mZnNldAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCXN3YXAKCWNvbmNhdAoJZnJhbWVfYnVyeSAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3Vi", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestDynamicArrayIteration.arc56_draft.json b/tests/contracts/artifacts/ABITestDynamicArrayIteration.arc56_draft.json index 8633dded5..bb999a938 100644 --- a/tests/contracts/artifacts/ABITestDynamicArrayIteration.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestDynamicArrayIteration.arc56_draft.json @@ -1058,7 +1058,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBkeW5hbWljQXJyYXlJdGVyYXRpb24oKXN0cmluZwoqYWJpX3JvdXRlX2R5bmFtaWNBcnJheUl0ZXJhdGlvbjoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGR5bmFtaWNBcnJheUl0ZXJhdGlvbigpc3RyaW5nCgljYWxsc3ViIGR5bmFtaWNBcnJheUl0ZXJhdGlvbgoJZHVwCglsZW4KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gZHluYW1pY0FycmF5SXRlcmF0aW9uKCk6IHN0cmluZwpkeW5hbWljQXJyYXlJdGVyYXRpb246Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJYnl0ZSAweAoJZHVwbiAyCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE2MDAKCS8vIGE6IHN0cmluZ1tdID0gWydIZWxsbyAnLCAnV29ybGQnLCAnISddCglieXRlIDB4IC8vIGluaXRpYWwgaGVhZAoJYnl0ZSAweCAvLyBpbml0aWFsIHRhaWwKCXB1c2hieXRlcyAweDAwMDYgLy8gaW5pdGlhbCBoZWFkIG9mZnNldAoJcHVzaGJ5dGVzIDB4MDAwNjQ4NjU2YzZjNmYyMAoJY2FsbHN1YiAqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMDU1NzZmNzI2YzY0CgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwMTIxCgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcG9wIC8vIHBvcCBoZWFkIG9mZnNldAoJY29uY2F0IC8vIGNvbmNhdCBoZWFkIGFuZCB0YWlsCglwdXNoYnl0ZXMgMHgwMDAzCglzd2FwCgljb25jYXQKCWZyYW1lX2J1cnkgMCAvLyBhOiBzdHJpbmdbXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNjAxCgkvLyBtZXNzYWdlID0gJycKCWJ5dGUgMHggLy8gIiIKCWZyYW1lX2J1cnkgMSAvLyBtZXNzYWdlOiBieXRlW10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTYwMwoJLy8gZm9yIChsZXQgaSA9IDA7IGkgPCBhLmxlbmd0aDsgaSArPSAxKQoJcHVzaGludCAwCglmcmFtZV9idXJ5IDIgLy8gaTogdWludDY0CgoqZm9yXzA6CgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTYwMwoJLy8gaSA8IGEubGVuZ3RoCglmcmFtZV9kaWcgMiAvLyBpOiB1aW50NjQKCWZyYW1lX2RpZyAwIC8vIGE6IHN0cmluZ1tdCglwdXNoaW50IDAKCWV4dHJhY3RfdWludDE2Cgk8CglieiAqZm9yXzBfZW5kCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE2MDQKCS8vIG1lc3NhZ2UgKz0gYVtpXQoJZnJhbWVfZGlnIDEgLy8gbWVzc2FnZTogYnl0ZVtdCglmcmFtZV9kaWcgMCAvLyBhOiBzdHJpbmdbXQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgMCAvLyBpbml0aWFsIG9mZnNldAoJZnJhbWVfZGlnIDIgLy8gaTogdWludDY0CglwdXNoaW50IDIKCSogLy8gYWNjICogMgoJKwoJcHVzaGludCAyCgkrIC8vIGFkZCB0d28gZm9yIGxlbmd0aAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJdW5jb3ZlciAyCglleHRyYWN0X3VpbnQxNgoJcHVzaGludCAyCgkrIC8vIGFkZCB0d28gZm9yIGxlbmd0aAoJZHVwIC8vIGR1cGxpY2F0ZSBzdGFydCBvZiBlbGVtZW50Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglzd2FwCglleHRyYWN0X3VpbnQxNiAvLyBnZXQgbnVtYmVyIG9mIGVsZW1lbnRzCglwdXNoaW50IDEgLy8gZ2V0IHR5cGUgbGVuZ3RoCgkqIC8vIG11bHRpcGx5IGJ5IHR5cGUgbGVuZ3RoCglwdXNoaW50IDIKCSsgLy8gYWRkIHR3byBmb3IgbGVuZ3RoCglleHRyYWN0MwoJZXh0cmFjdCAyIDAKCWNvbmNhdAoJZnJhbWVfYnVyeSAxIC8vIG1lc3NhZ2U6IGJ5dGVbXQoKKmZvcl8wX2NvbnRpbnVlOgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE2MDMKCS8vIGkgKz0gMQoJZnJhbWVfZGlnIDIgLy8gaTogdWludDY0CglwdXNoaW50IDEKCSsKCWZyYW1lX2J1cnkgMiAvLyBpOiB1aW50NjQKCWIgKmZvcl8wCgoqZm9yXzBfZW5kOgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE2MDcKCS8vIHJldHVybiBtZXNzYWdlOwoJZnJhbWVfZGlnIDEgLy8gbWVzc2FnZTogYnl0ZVtdCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCgoJLy8gcG9wIGFsbCBsb2NhbCB2YXJpYWJsZXMgZnJvbSB0aGUgc3RhY2sKCXBvcG4gMgoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhhOTU3YzVlZCAvLyBtZXRob2QgImR5bmFtaWNBcnJheUl0ZXJhdGlvbigpc3RyaW5nIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9keW5hbWljQXJyYXlJdGVyYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnIKCipwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJY29uY2F0CglmcmFtZV9idXJ5IC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50CglkdXAKCWxlbgoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglidG9pCgkrCglpdG9iCglleHRyYWN0IDYgMgoJZnJhbWVfYnVyeSAtMiAvLyBoZWFkIG9mZnNldAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCXN3YXAKCWNvbmNhdAoJZnJhbWVfYnVyeSAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3Vi", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBkeW5hbWljQXJyYXlJdGVyYXRpb24oKXN0cmluZwoqYWJpX3JvdXRlX2R5bmFtaWNBcnJheUl0ZXJhdGlvbjoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGR5bmFtaWNBcnJheUl0ZXJhdGlvbigpc3RyaW5nCgljYWxsc3ViIGR5bmFtaWNBcnJheUl0ZXJhdGlvbgoJZHVwCglsZW4KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gZHluYW1pY0FycmF5SXRlcmF0aW9uKCk6IHN0cmluZwpkeW5hbWljQXJyYXlJdGVyYXRpb246Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJYnl0ZSAweAoJZHVwbiAyCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE2MDAKCS8vIGE6IHN0cmluZ1tdID0gWydIZWxsbyAnLCAnV29ybGQnLCAnISddCglieXRlIDB4IC8vIGluaXRpYWwgaGVhZAoJYnl0ZSAweCAvLyBpbml0aWFsIHRhaWwKCXB1c2hieXRlcyAweDAwMDYgLy8gaW5pdGlhbCBoZWFkIG9mZnNldAoJcHVzaGJ5dGVzIDB4MDAwNjQ4NjU2YzZjNmYyMAoJY2FsbHN1YiAqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMDU1NzZmNzI2YzY0CgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwMTIxCgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcG9wIC8vIHBvcCBoZWFkIG9mZnNldAoJY29uY2F0IC8vIGNvbmNhdCBoZWFkIGFuZCB0YWlsCglwdXNoYnl0ZXMgMHgwMDAzCglzd2FwCgljb25jYXQKCWZyYW1lX2J1cnkgMCAvLyBhOiBzdHJpbmdbXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNjAxCgkvLyBtZXNzYWdlID0gJycKCWJ5dGUgMHggLy8gIiIKCWZyYW1lX2J1cnkgMSAvLyBtZXNzYWdlOiBieXRlW10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTYwMwoJLy8gZm9yIChsZXQgaSA9IDA7IGkgPCBhLmxlbmd0aDsgaSArPSAxKQoJcHVzaGludCAwCglmcmFtZV9idXJ5IDIgLy8gaTogdWludDY0CgoqZm9yXzA6CgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTYwMwoJLy8gaSA8IGEubGVuZ3RoCglmcmFtZV9kaWcgMiAvLyBpOiB1aW50NjQKCWZyYW1lX2RpZyAwIC8vIGE6IHN0cmluZ1tdCglwdXNoaW50IDAKCWV4dHJhY3RfdWludDE2Cgk8CglieiAqZm9yXzBfZW5kCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE2MDQKCS8vIG1lc3NhZ2UgKz0gYVtpXQoJZnJhbWVfZGlnIDEgLy8gbWVzc2FnZTogYnl0ZVtdCglmcmFtZV9kaWcgMCAvLyBhOiBzdHJpbmdbXQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgMCAvLyBpbml0aWFsIG9mZnNldAoJZnJhbWVfZGlnIDIgLy8gaTogdWludDY0CglwdXNoaW50IDIKCSogLy8gYWNjICogMgoJKwoJcHVzaGludCAyCgkrIC8vIGFkZCB0d28gZm9yIGxlbmd0aAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJdW5jb3ZlciAyCglleHRyYWN0X3VpbnQxNgoJcHVzaGludCAyCgkrIC8vIGFkZCB0d28gZm9yIGxlbmd0aAoJZHVwIC8vIGR1cGxpY2F0ZSBzdGFydCBvZiBlbGVtZW50Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglzd2FwCglleHRyYWN0X3VpbnQxNiAvLyBnZXQgbnVtYmVyIG9mIGVsZW1lbnRzCglwdXNoaW50IDEgLy8gZ2V0IHR5cGUgbGVuZ3RoCgkqIC8vIG11bHRpcGx5IGJ5IHR5cGUgbGVuZ3RoCglwdXNoaW50IDIKCSsgLy8gYWRkIHR3byBmb3IgbGVuZ3RoCglleHRyYWN0MwoJZXh0cmFjdCAyIDAKCWNvbmNhdAoJZnJhbWVfYnVyeSAxIC8vIG1lc3NhZ2U6IGJ5dGVbXQoKKmZvcl8wX2NvbnRpbnVlOgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE2MDMKCS8vIGkgKz0gMQoJZnJhbWVfZGlnIDIgLy8gaTogdWludDY0CglwdXNoaW50IDEKCSsKCWZyYW1lX2J1cnkgMiAvLyBpOiB1aW50NjQKCWIgKmZvcl8wCgoqZm9yXzBfZW5kOgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE2MDcKCS8vIHJldHVybiBtZXNzYWdlOwoJZnJhbWVfZGlnIDEgLy8gbWVzc2FnZTogYnl0ZVtdCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCgoJLy8gcG9wIGFsbCBsb2NhbCB2YXJpYWJsZXMgZnJvbSB0aGUgc3RhY2sKCXBvcG4gMgoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhhOTU3YzVlZCAvLyBtZXRob2QgImR5bmFtaWNBcnJheUl0ZXJhdGlvbigpc3RyaW5nIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9keW5hbWljQXJyYXlJdGVyYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnIKCipwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJY29uY2F0CglmcmFtZV9idXJ5IC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50CglkdXAKCWxlbgoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglidG9pCgkrCglpdG9iCglleHRyYWN0IDYgMgoJZnJhbWVfYnVyeSAtMiAvLyBoZWFkIG9mZnNldAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCXN3YXAKCWNvbmNhdAoJZnJhbWVfYnVyeSAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3Vi", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestDynamicArrayLength.approval.teal b/tests/contracts/artifacts/ABITestDynamicArrayLength.approval.teal index 5c8860cb6..e402c1df9 100644 --- a/tests/contracts/artifacts/ABITestDynamicArrayLength.approval.teal +++ b/tests/contracts/artifacts/ABITestDynamicArrayLength.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestDynamicArrayLength.arc32.json b/tests/contracts/artifacts/ABITestDynamicArrayLength.arc32.json index 7b7037497..8107e87c8 100644 --- a/tests/contracts/artifacts/ABITestDynamicArrayLength.arc32.json +++ b/tests/contracts/artifacts/ABITestDynamicArrayLength.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBkeW5hbWljQXJyYXlMZW5ndGgoKXVpbnQ2NAoqYWJpX3JvdXRlX2R5bmFtaWNBcnJheUxlbmd0aDoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGR5bmFtaWNBcnJheUxlbmd0aCgpdWludDY0CgljYWxsc3ViIGR5bmFtaWNBcnJheUxlbmd0aAoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBkeW5hbWljQXJyYXlMZW5ndGgoKTogdWludDY0CmR5bmFtaWNBcnJheUxlbmd0aDoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTU5MAoJLy8gbzogeyBhOiB1aW50NjQ7IGI6IHVpbnQ2NFtdIH0gPSB7IGE6IDEsIGI6IFsxLCAyLCAzXSB9CglieXRlIDB4IC8vIGluaXRpYWwgaGVhZAoJYnl0ZSAweCAvLyBpbml0aWFsIHRhaWwKCXB1c2hieXRlcyAweDAwMGEgLy8gaW5pdGlhbCBoZWFkIG9mZnNldAoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMQoJY2FsbHN1YiAqcHJvY2Vzc19zdGF0aWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwMzAwMDAwMDAwMDAwMDAwMDEwMDAwMDAwMDAwMDAwMDAyMDAwMDAwMDAwMDAwMDAwMwoJY2FsbHN1YiAqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQKCXBvcCAvLyBwb3AgaGVhZCBvZmZzZXQKCWNvbmNhdCAvLyBjb25jYXQgaGVhZCBhbmQgdGFpbAoJZnJhbWVfYnVyeSAwIC8vIG86IHsgYTogdWludDY0OyBiOiB1aW50NjRbXSB9CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE1OTIKCS8vIGE6IHN0cmluZ1tdID0gWydIZWxsbycsICdXb3JsZCcsICchJ10KCWJ5dGUgMHggLy8gaW5pdGlhbCBoZWFkCglieXRlIDB4IC8vIGluaXRpYWwgdGFpbAoJcHVzaGJ5dGVzIDB4MDAwNiAvLyBpbml0aWFsIGhlYWQgb2Zmc2V0CglwdXNoYnl0ZXMgMHgwMDA1NDg2NTZjNmM2ZgoJY2FsbHN1YiAqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMDU1NzZmNzI2YzY0CgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwMTIxCgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcG9wIC8vIHBvcCBoZWFkIG9mZnNldAoJY29uY2F0IC8vIGNvbmNhdCBoZWFkIGFuZCB0YWlsCglwdXNoYnl0ZXMgMHgwMDAzCglzd2FwCgljb25jYXQKCWZyYW1lX2J1cnkgMSAvLyBhOiBzdHJpbmdbXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNTk0CgkvLyByZXR1cm4gYS5sZW5ndGggKyBvLmIubGVuZ3RoOwoJZnJhbWVfZGlnIDEgLy8gYTogc3RyaW5nW10KCXB1c2hpbnQgMAoJZXh0cmFjdF91aW50MTYKCWZyYW1lX2RpZyAwIC8vIG86IHsgYTogdWludDY0OyBiOiB1aW50NjRbXSB9CglzdG9yZSAyNTUgLy8gZnVsbCBhcnJheQoJcHVzaGludCA4Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cgl1bmNvdmVyIDIKCWV4dHJhY3RfdWludDE2CglkdXAgLy8gZHVwbGljYXRlIHN0YXJ0IG9mIGVsZW1lbnQKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXN3YXAKCWV4dHJhY3RfdWludDE2IC8vIGdldCBudW1iZXIgb2YgZWxlbWVudHMKCXB1c2hpbnQgOCAvLyBnZXQgdHlwZSBsZW5ndGgKCSogLy8gbXVsdGlwbHkgYnkgdHlwZSBsZW5ndGgKCXB1c2hpbnQgMgoJKyAvLyBhZGQgdHdvIGZvciBsZW5ndGgKCWV4dHJhY3QzCglleHRyYWN0IDIgMAoJbGVuCglwdXNoaW50IDgKCS8KCSsKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCgkvLyBwb3AgYWxsIGxvY2FsIHZhcmlhYmxlcyBmcm9tIHRoZSBzdGFjawoJcG9wbiAxCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGRmM2U2MGYxIC8vIG1ldGhvZCAiZHluYW1pY0FycmF5TGVuZ3RoKCl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2R5bmFtaWNBcnJheUxlbmd0aAoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycgoKKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJY29uY2F0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWIKCipwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJY29uY2F0CglmcmFtZV9idXJ5IC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50CglkdXAKCWxlbgoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglidG9pCgkrCglpdG9iCglleHRyYWN0IDYgMgoJZnJhbWVfYnVyeSAtMiAvLyBoZWFkIG9mZnNldAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCXN3YXAKCWNvbmNhdAoJZnJhbWVfYnVyeSAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3Vi", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBkeW5hbWljQXJyYXlMZW5ndGgoKXVpbnQ2NAoqYWJpX3JvdXRlX2R5bmFtaWNBcnJheUxlbmd0aDoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGR5bmFtaWNBcnJheUxlbmd0aCgpdWludDY0CgljYWxsc3ViIGR5bmFtaWNBcnJheUxlbmd0aAoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBkeW5hbWljQXJyYXlMZW5ndGgoKTogdWludDY0CmR5bmFtaWNBcnJheUxlbmd0aDoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTU5MAoJLy8gbzogeyBhOiB1aW50NjQ7IGI6IHVpbnQ2NFtdIH0gPSB7IGE6IDEsIGI6IFsxLCAyLCAzXSB9CglieXRlIDB4IC8vIGluaXRpYWwgaGVhZAoJYnl0ZSAweCAvLyBpbml0aWFsIHRhaWwKCXB1c2hieXRlcyAweDAwMGEgLy8gaW5pdGlhbCBoZWFkIG9mZnNldAoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMQoJY2FsbHN1YiAqcHJvY2Vzc19zdGF0aWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwMzAwMDAwMDAwMDAwMDAwMDEwMDAwMDAwMDAwMDAwMDAyMDAwMDAwMDAwMDAwMDAwMwoJY2FsbHN1YiAqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQKCXBvcCAvLyBwb3AgaGVhZCBvZmZzZXQKCWNvbmNhdCAvLyBjb25jYXQgaGVhZCBhbmQgdGFpbAoJZnJhbWVfYnVyeSAwIC8vIG86IHsgYTogdWludDY0OyBiOiB1aW50NjRbXSB9CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE1OTIKCS8vIGE6IHN0cmluZ1tdID0gWydIZWxsbycsICdXb3JsZCcsICchJ10KCWJ5dGUgMHggLy8gaW5pdGlhbCBoZWFkCglieXRlIDB4IC8vIGluaXRpYWwgdGFpbAoJcHVzaGJ5dGVzIDB4MDAwNiAvLyBpbml0aWFsIGhlYWQgb2Zmc2V0CglwdXNoYnl0ZXMgMHgwMDA1NDg2NTZjNmM2ZgoJY2FsbHN1YiAqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMDU1NzZmNzI2YzY0CgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwMTIxCgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcG9wIC8vIHBvcCBoZWFkIG9mZnNldAoJY29uY2F0IC8vIGNvbmNhdCBoZWFkIGFuZCB0YWlsCglwdXNoYnl0ZXMgMHgwMDAzCglzd2FwCgljb25jYXQKCWZyYW1lX2J1cnkgMSAvLyBhOiBzdHJpbmdbXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNTk0CgkvLyByZXR1cm4gYS5sZW5ndGggKyBvLmIubGVuZ3RoOwoJZnJhbWVfZGlnIDEgLy8gYTogc3RyaW5nW10KCXB1c2hpbnQgMAoJZXh0cmFjdF91aW50MTYKCWZyYW1lX2RpZyAwIC8vIG86IHsgYTogdWludDY0OyBiOiB1aW50NjRbXSB9CglzdG9yZSAyNTUgLy8gZnVsbCBhcnJheQoJcHVzaGludCA4Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cgl1bmNvdmVyIDIKCWV4dHJhY3RfdWludDE2CglkdXAgLy8gZHVwbGljYXRlIHN0YXJ0IG9mIGVsZW1lbnQKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXN3YXAKCWV4dHJhY3RfdWludDE2IC8vIGdldCBudW1iZXIgb2YgZWxlbWVudHMKCXB1c2hpbnQgOCAvLyBnZXQgdHlwZSBsZW5ndGgKCSogLy8gbXVsdGlwbHkgYnkgdHlwZSBsZW5ndGgKCXB1c2hpbnQgMgoJKyAvLyBhZGQgdHdvIGZvciBsZW5ndGgKCWV4dHJhY3QzCglleHRyYWN0IDIgMAoJbGVuCglwdXNoaW50IDgKCS8KCSsKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCgkvLyBwb3AgYWxsIGxvY2FsIHZhcmlhYmxlcyBmcm9tIHRoZSBzdGFjawoJcG9wbiAxCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGRmM2U2MGYxIC8vIG1ldGhvZCAiZHluYW1pY0FycmF5TGVuZ3RoKCl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2R5bmFtaWNBcnJheUxlbmd0aAoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycgoKKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJY29uY2F0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWIKCipwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJY29uY2F0CglmcmFtZV9idXJ5IC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50CglkdXAKCWxlbgoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglidG9pCgkrCglpdG9iCglleHRyYWN0IDYgMgoJZnJhbWVfYnVyeSAtMiAvLyBoZWFkIG9mZnNldAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCXN3YXAKCWNvbmNhdAoJZnJhbWVfYnVyeSAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3Vi", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestDynamicArrayLength.arc56_draft.json b/tests/contracts/artifacts/ABITestDynamicArrayLength.arc56_draft.json index c6cceb388..0e4c3693f 100644 --- a/tests/contracts/artifacts/ABITestDynamicArrayLength.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestDynamicArrayLength.arc56_draft.json @@ -1032,7 +1032,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBkeW5hbWljQXJyYXlMZW5ndGgoKXVpbnQ2NAoqYWJpX3JvdXRlX2R5bmFtaWNBcnJheUxlbmd0aDoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGR5bmFtaWNBcnJheUxlbmd0aCgpdWludDY0CgljYWxsc3ViIGR5bmFtaWNBcnJheUxlbmd0aAoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBkeW5hbWljQXJyYXlMZW5ndGgoKTogdWludDY0CmR5bmFtaWNBcnJheUxlbmd0aDoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTU5MAoJLy8gbzogeyBhOiB1aW50NjQ7IGI6IHVpbnQ2NFtdIH0gPSB7IGE6IDEsIGI6IFsxLCAyLCAzXSB9CglieXRlIDB4IC8vIGluaXRpYWwgaGVhZAoJYnl0ZSAweCAvLyBpbml0aWFsIHRhaWwKCXB1c2hieXRlcyAweDAwMGEgLy8gaW5pdGlhbCBoZWFkIG9mZnNldAoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMQoJY2FsbHN1YiAqcHJvY2Vzc19zdGF0aWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwMzAwMDAwMDAwMDAwMDAwMDEwMDAwMDAwMDAwMDAwMDAyMDAwMDAwMDAwMDAwMDAwMwoJY2FsbHN1YiAqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQKCXBvcCAvLyBwb3AgaGVhZCBvZmZzZXQKCWNvbmNhdCAvLyBjb25jYXQgaGVhZCBhbmQgdGFpbAoJZnJhbWVfYnVyeSAwIC8vIG86IHsgYTogdWludDY0OyBiOiB1aW50NjRbXSB9CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE1OTIKCS8vIGE6IHN0cmluZ1tdID0gWydIZWxsbycsICdXb3JsZCcsICchJ10KCWJ5dGUgMHggLy8gaW5pdGlhbCBoZWFkCglieXRlIDB4IC8vIGluaXRpYWwgdGFpbAoJcHVzaGJ5dGVzIDB4MDAwNiAvLyBpbml0aWFsIGhlYWQgb2Zmc2V0CglwdXNoYnl0ZXMgMHgwMDA1NDg2NTZjNmM2ZgoJY2FsbHN1YiAqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMDU1NzZmNzI2YzY0CgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwMTIxCgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcG9wIC8vIHBvcCBoZWFkIG9mZnNldAoJY29uY2F0IC8vIGNvbmNhdCBoZWFkIGFuZCB0YWlsCglwdXNoYnl0ZXMgMHgwMDAzCglzd2FwCgljb25jYXQKCWZyYW1lX2J1cnkgMSAvLyBhOiBzdHJpbmdbXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNTk0CgkvLyByZXR1cm4gYS5sZW5ndGggKyBvLmIubGVuZ3RoOwoJZnJhbWVfZGlnIDEgLy8gYTogc3RyaW5nW10KCXB1c2hpbnQgMAoJZXh0cmFjdF91aW50MTYKCWZyYW1lX2RpZyAwIC8vIG86IHsgYTogdWludDY0OyBiOiB1aW50NjRbXSB9CglzdG9yZSAyNTUgLy8gZnVsbCBhcnJheQoJcHVzaGludCA4Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cgl1bmNvdmVyIDIKCWV4dHJhY3RfdWludDE2CglkdXAgLy8gZHVwbGljYXRlIHN0YXJ0IG9mIGVsZW1lbnQKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXN3YXAKCWV4dHJhY3RfdWludDE2IC8vIGdldCBudW1iZXIgb2YgZWxlbWVudHMKCXB1c2hpbnQgOCAvLyBnZXQgdHlwZSBsZW5ndGgKCSogLy8gbXVsdGlwbHkgYnkgdHlwZSBsZW5ndGgKCXB1c2hpbnQgMgoJKyAvLyBhZGQgdHdvIGZvciBsZW5ndGgKCWV4dHJhY3QzCglleHRyYWN0IDIgMAoJbGVuCglwdXNoaW50IDgKCS8KCSsKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCgkvLyBwb3AgYWxsIGxvY2FsIHZhcmlhYmxlcyBmcm9tIHRoZSBzdGFjawoJcG9wbiAxCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGRmM2U2MGYxIC8vIG1ldGhvZCAiZHluYW1pY0FycmF5TGVuZ3RoKCl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2R5bmFtaWNBcnJheUxlbmd0aAoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycgoKKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJY29uY2F0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWIKCipwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJY29uY2F0CglmcmFtZV9idXJ5IC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50CglkdXAKCWxlbgoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglidG9pCgkrCglpdG9iCglleHRyYWN0IDYgMgoJZnJhbWVfYnVyeSAtMiAvLyBoZWFkIG9mZnNldAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCXN3YXAKCWNvbmNhdAoJZnJhbWVfYnVyeSAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3Vi", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBkeW5hbWljQXJyYXlMZW5ndGgoKXVpbnQ2NAoqYWJpX3JvdXRlX2R5bmFtaWNBcnJheUxlbmd0aDoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGR5bmFtaWNBcnJheUxlbmd0aCgpdWludDY0CgljYWxsc3ViIGR5bmFtaWNBcnJheUxlbmd0aAoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBkeW5hbWljQXJyYXlMZW5ndGgoKTogdWludDY0CmR5bmFtaWNBcnJheUxlbmd0aDoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTU5MAoJLy8gbzogeyBhOiB1aW50NjQ7IGI6IHVpbnQ2NFtdIH0gPSB7IGE6IDEsIGI6IFsxLCAyLCAzXSB9CglieXRlIDB4IC8vIGluaXRpYWwgaGVhZAoJYnl0ZSAweCAvLyBpbml0aWFsIHRhaWwKCXB1c2hieXRlcyAweDAwMGEgLy8gaW5pdGlhbCBoZWFkIG9mZnNldAoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMQoJY2FsbHN1YiAqcHJvY2Vzc19zdGF0aWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwMzAwMDAwMDAwMDAwMDAwMDEwMDAwMDAwMDAwMDAwMDAyMDAwMDAwMDAwMDAwMDAwMwoJY2FsbHN1YiAqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQKCXBvcCAvLyBwb3AgaGVhZCBvZmZzZXQKCWNvbmNhdCAvLyBjb25jYXQgaGVhZCBhbmQgdGFpbAoJZnJhbWVfYnVyeSAwIC8vIG86IHsgYTogdWludDY0OyBiOiB1aW50NjRbXSB9CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE1OTIKCS8vIGE6IHN0cmluZ1tdID0gWydIZWxsbycsICdXb3JsZCcsICchJ10KCWJ5dGUgMHggLy8gaW5pdGlhbCBoZWFkCglieXRlIDB4IC8vIGluaXRpYWwgdGFpbAoJcHVzaGJ5dGVzIDB4MDAwNiAvLyBpbml0aWFsIGhlYWQgb2Zmc2V0CglwdXNoYnl0ZXMgMHgwMDA1NDg2NTZjNmM2ZgoJY2FsbHN1YiAqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMDU1NzZmNzI2YzY0CgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwMTIxCgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcG9wIC8vIHBvcCBoZWFkIG9mZnNldAoJY29uY2F0IC8vIGNvbmNhdCBoZWFkIGFuZCB0YWlsCglwdXNoYnl0ZXMgMHgwMDAzCglzd2FwCgljb25jYXQKCWZyYW1lX2J1cnkgMSAvLyBhOiBzdHJpbmdbXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNTk0CgkvLyByZXR1cm4gYS5sZW5ndGggKyBvLmIubGVuZ3RoOwoJZnJhbWVfZGlnIDEgLy8gYTogc3RyaW5nW10KCXB1c2hpbnQgMAoJZXh0cmFjdF91aW50MTYKCWZyYW1lX2RpZyAwIC8vIG86IHsgYTogdWludDY0OyBiOiB1aW50NjRbXSB9CglzdG9yZSAyNTUgLy8gZnVsbCBhcnJheQoJcHVzaGludCA4Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cgl1bmNvdmVyIDIKCWV4dHJhY3RfdWludDE2CglkdXAgLy8gZHVwbGljYXRlIHN0YXJ0IG9mIGVsZW1lbnQKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXN3YXAKCWV4dHJhY3RfdWludDE2IC8vIGdldCBudW1iZXIgb2YgZWxlbWVudHMKCXB1c2hpbnQgOCAvLyBnZXQgdHlwZSBsZW5ndGgKCSogLy8gbXVsdGlwbHkgYnkgdHlwZSBsZW5ndGgKCXB1c2hpbnQgMgoJKyAvLyBhZGQgdHdvIGZvciBsZW5ndGgKCWV4dHJhY3QzCglleHRyYWN0IDIgMAoJbGVuCglwdXNoaW50IDgKCS8KCSsKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCgkvLyBwb3AgYWxsIGxvY2FsIHZhcmlhYmxlcyBmcm9tIHRoZSBzdGFjawoJcG9wbiAxCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGRmM2U2MGYxIC8vIG1ldGhvZCAiZHluYW1pY0FycmF5TGVuZ3RoKCl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2R5bmFtaWNBcnJheUxlbmd0aAoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycgoKKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJY29uY2F0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWIKCipwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJY29uY2F0CglmcmFtZV9idXJ5IC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50CglkdXAKCWxlbgoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglidG9pCgkrCglpdG9iCglleHRyYWN0IDYgMgoJZnJhbWVfYnVyeSAtMiAvLyBoZWFkIG9mZnNldAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCXN3YXAKCWNvbmNhdAoJZnJhbWVfYnVyeSAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3Vi", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestDynamicBoolArray.approval.teal b/tests/contracts/artifacts/ABITestDynamicBoolArray.approval.teal index c843608f7..93b5cdd97 100644 --- a/tests/contracts/artifacts/ABITestDynamicBoolArray.approval.teal +++ b/tests/contracts/artifacts/ABITestDynamicBoolArray.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestDynamicBoolArray.arc32.json b/tests/contracts/artifacts/ABITestDynamicBoolArray.arc32.json index d55fd49ed..5c19587b9 100644 --- a/tests/contracts/artifacts/ABITestDynamicBoolArray.arc32.json +++ b/tests/contracts/artifacts/ABITestDynamicBoolArray.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZHluYW1pY0Jvb2xBcnJheSgpYm9vbFtdCiphYmlfcm91dGVfZHluYW1pY0Jvb2xBcnJheToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGR5bmFtaWNCb29sQXJyYXkoKWJvb2xbXQoJY2FsbHN1YiBkeW5hbWljQm9vbEFycmF5Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGR5bmFtaWNCb29sQXJyYXkoKTogYm9vbGVhbltdCmR5bmFtaWNCb29sQXJyYXk6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjkzMQoJLy8gYTogYm9vbGVhbltdID0gW3RydWUsIGZhbHNlLCB0cnVlLCB0cnVlLCBmYWxzZSwgZmFsc2UsIHRydWUsIGZhbHNlLCBmYWxzZV0KCXB1c2hieXRlcyAweDAwMDkKCXB1c2hieXRlcyAweDAwMDAKCXB1c2hpbnQgMAoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hpbnQgMQoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgMgoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hpbnQgMwoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hpbnQgNAoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgNQoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgNgoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hpbnQgNwoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgOAoJcHVzaGludCAwCglzZXRiaXQKCWNvbmNhdAoJZnJhbWVfYnVyeSAwIC8vIGE6IGJvb2xlYW5bXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo5MzMKCS8vIHJldHVybiBhOwoJZnJhbWVfZGlnIDAgLy8gYTogYm9vbGVhbltdCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDM1NDJkMGQ1IC8vIG1ldGhvZCAiZHluYW1pY0Jvb2xBcnJheSgpYm9vbFtdIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9keW5hbWljQm9vbEFycmF5CgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZHluYW1pY0Jvb2xBcnJheSgpYm9vbFtdCiphYmlfcm91dGVfZHluYW1pY0Jvb2xBcnJheToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGR5bmFtaWNCb29sQXJyYXkoKWJvb2xbXQoJY2FsbHN1YiBkeW5hbWljQm9vbEFycmF5Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGR5bmFtaWNCb29sQXJyYXkoKTogYm9vbGVhbltdCmR5bmFtaWNCb29sQXJyYXk6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjkzMQoJLy8gYTogYm9vbGVhbltdID0gW3RydWUsIGZhbHNlLCB0cnVlLCB0cnVlLCBmYWxzZSwgZmFsc2UsIHRydWUsIGZhbHNlLCBmYWxzZV0KCXB1c2hieXRlcyAweDAwMDkKCXB1c2hieXRlcyAweDAwMDAKCXB1c2hpbnQgMAoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hpbnQgMQoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgMgoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hpbnQgMwoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hpbnQgNAoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgNQoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgNgoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hpbnQgNwoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgOAoJcHVzaGludCAwCglzZXRiaXQKCWNvbmNhdAoJZnJhbWVfYnVyeSAwIC8vIGE6IGJvb2xlYW5bXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo5MzMKCS8vIHJldHVybiBhOwoJZnJhbWVfZGlnIDAgLy8gYTogYm9vbGVhbltdCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDM1NDJkMGQ1IC8vIG1ldGhvZCAiZHluYW1pY0Jvb2xBcnJheSgpYm9vbFtdIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9keW5hbWljQm9vbEFycmF5CgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestDynamicBoolArray.arc56_draft.json b/tests/contracts/artifacts/ABITestDynamicBoolArray.arc56_draft.json index 8b5e8ca6c..eeb798f2b 100644 --- a/tests/contracts/artifacts/ABITestDynamicBoolArray.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestDynamicBoolArray.arc56_draft.json @@ -589,7 +589,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZHluYW1pY0Jvb2xBcnJheSgpYm9vbFtdCiphYmlfcm91dGVfZHluYW1pY0Jvb2xBcnJheToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGR5bmFtaWNCb29sQXJyYXkoKWJvb2xbXQoJY2FsbHN1YiBkeW5hbWljQm9vbEFycmF5Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGR5bmFtaWNCb29sQXJyYXkoKTogYm9vbGVhbltdCmR5bmFtaWNCb29sQXJyYXk6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjkzMQoJLy8gYTogYm9vbGVhbltdID0gW3RydWUsIGZhbHNlLCB0cnVlLCB0cnVlLCBmYWxzZSwgZmFsc2UsIHRydWUsIGZhbHNlLCBmYWxzZV0KCXB1c2hieXRlcyAweDAwMDkKCXB1c2hieXRlcyAweDAwMDAKCXB1c2hpbnQgMAoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hpbnQgMQoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgMgoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hpbnQgMwoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hpbnQgNAoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgNQoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgNgoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hpbnQgNwoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgOAoJcHVzaGludCAwCglzZXRiaXQKCWNvbmNhdAoJZnJhbWVfYnVyeSAwIC8vIGE6IGJvb2xlYW5bXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo5MzMKCS8vIHJldHVybiBhOwoJZnJhbWVfZGlnIDAgLy8gYTogYm9vbGVhbltdCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDM1NDJkMGQ1IC8vIG1ldGhvZCAiZHluYW1pY0Jvb2xBcnJheSgpYm9vbFtdIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9keW5hbWljQm9vbEFycmF5CgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZHluYW1pY0Jvb2xBcnJheSgpYm9vbFtdCiphYmlfcm91dGVfZHluYW1pY0Jvb2xBcnJheToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGR5bmFtaWNCb29sQXJyYXkoKWJvb2xbXQoJY2FsbHN1YiBkeW5hbWljQm9vbEFycmF5Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGR5bmFtaWNCb29sQXJyYXkoKTogYm9vbGVhbltdCmR5bmFtaWNCb29sQXJyYXk6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjkzMQoJLy8gYTogYm9vbGVhbltdID0gW3RydWUsIGZhbHNlLCB0cnVlLCB0cnVlLCBmYWxzZSwgZmFsc2UsIHRydWUsIGZhbHNlLCBmYWxzZV0KCXB1c2hieXRlcyAweDAwMDkKCXB1c2hieXRlcyAweDAwMDAKCXB1c2hpbnQgMAoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hpbnQgMQoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgMgoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hpbnQgMwoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hpbnQgNAoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgNQoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgNgoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hpbnQgNwoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgOAoJcHVzaGludCAwCglzZXRiaXQKCWNvbmNhdAoJZnJhbWVfYnVyeSAwIC8vIGE6IGJvb2xlYW5bXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo5MzMKCS8vIHJldHVybiBhOwoJZnJhbWVfZGlnIDAgLy8gYTogYm9vbGVhbltdCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDM1NDJkMGQ1IC8vIG1ldGhvZCAiZHluYW1pY0Jvb2xBcnJheSgpYm9vbFtdIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9keW5hbWljQm9vbEFycmF5CgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestDynamicBoolArrayAccess.approval.teal b/tests/contracts/artifacts/ABITestDynamicBoolArrayAccess.approval.teal index a74ae487b..870d85bec 100644 --- a/tests/contracts/artifacts/ABITestDynamicBoolArrayAccess.approval.teal +++ b/tests/contracts/artifacts/ABITestDynamicBoolArrayAccess.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestDynamicBoolArrayAccess.arc32.json b/tests/contracts/artifacts/ABITestDynamicBoolArrayAccess.arc32.json index 08b1f77e1..6c6f72c81 100644 --- a/tests/contracts/artifacts/ABITestDynamicBoolArrayAccess.arc32.json +++ b/tests/contracts/artifacts/ABITestDynamicBoolArrayAccess.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZHluYW1pY0Jvb2xBcnJheUFjY2VzcygpYm9vbAoqYWJpX3JvdXRlX2R5bmFtaWNCb29sQXJyYXlBY2Nlc3M6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBkeW5hbWljQm9vbEFycmF5QWNjZXNzKClib29sCgljYWxsc3ViIGR5bmFtaWNCb29sQXJyYXlBY2Nlc3MKCXB1c2hieXRlcyAweDAwCglwdXNoaW50IDAKCXVuY292ZXIgMgoJc2V0Yml0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGR5bmFtaWNCb29sQXJyYXlBY2Nlc3MoKTogYm9vbGVhbgpkeW5hbWljQm9vbEFycmF5QWNjZXNzOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo5MzkKCS8vIGE6IGJvb2xlYW5bXSA9IFt0cnVlLCBmYWxzZSwgdHJ1ZSwgdHJ1ZSwgZmFsc2UsIGZhbHNlLCB0cnVlLCBmYWxzZSwgZmFsc2VdCglwdXNoYnl0ZXMgMHgwMDA5CglwdXNoYnl0ZXMgMHgwMDAwCglwdXNoaW50IDAKCXB1c2hpbnQgMQoJc2V0Yml0CglwdXNoaW50IDEKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDIKCXB1c2hpbnQgMQoJc2V0Yml0CglwdXNoaW50IDMKCXB1c2hpbnQgMQoJc2V0Yml0CglwdXNoaW50IDQKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDUKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDYKCXB1c2hpbnQgMQoJc2V0Yml0CglwdXNoaW50IDcKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDgKCXB1c2hpbnQgMAoJc2V0Yml0Cgljb25jYXQKCWZyYW1lX2J1cnkgMCAvLyBhOiBib29sZWFuW10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6OTQxCgkvLyByZXR1cm4gYVs4XTsKCWZyYW1lX2RpZyAwIC8vIGE6IGJvb2xlYW5bXQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgOAoJZ2V0Yml0CgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDhlYzgwMjQ5IC8vIG1ldGhvZCAiZHluYW1pY0Jvb2xBcnJheUFjY2VzcygpYm9vbCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfZHluYW1pY0Jvb2xBcnJheUFjY2VzcwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZHluYW1pY0Jvb2xBcnJheUFjY2VzcygpYm9vbAoqYWJpX3JvdXRlX2R5bmFtaWNCb29sQXJyYXlBY2Nlc3M6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBkeW5hbWljQm9vbEFycmF5QWNjZXNzKClib29sCgljYWxsc3ViIGR5bmFtaWNCb29sQXJyYXlBY2Nlc3MKCXB1c2hieXRlcyAweDAwCglwdXNoaW50IDAKCXVuY292ZXIgMgoJc2V0Yml0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGR5bmFtaWNCb29sQXJyYXlBY2Nlc3MoKTogYm9vbGVhbgpkeW5hbWljQm9vbEFycmF5QWNjZXNzOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo5MzkKCS8vIGE6IGJvb2xlYW5bXSA9IFt0cnVlLCBmYWxzZSwgdHJ1ZSwgdHJ1ZSwgZmFsc2UsIGZhbHNlLCB0cnVlLCBmYWxzZSwgZmFsc2VdCglwdXNoYnl0ZXMgMHgwMDA5CglwdXNoYnl0ZXMgMHgwMDAwCglwdXNoaW50IDAKCXB1c2hpbnQgMQoJc2V0Yml0CglwdXNoaW50IDEKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDIKCXB1c2hpbnQgMQoJc2V0Yml0CglwdXNoaW50IDMKCXB1c2hpbnQgMQoJc2V0Yml0CglwdXNoaW50IDQKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDUKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDYKCXB1c2hpbnQgMQoJc2V0Yml0CglwdXNoaW50IDcKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDgKCXB1c2hpbnQgMAoJc2V0Yml0Cgljb25jYXQKCWZyYW1lX2J1cnkgMCAvLyBhOiBib29sZWFuW10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6OTQxCgkvLyByZXR1cm4gYVs4XTsKCWZyYW1lX2RpZyAwIC8vIGE6IGJvb2xlYW5bXQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgOAoJZ2V0Yml0CgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDhlYzgwMjQ5IC8vIG1ldGhvZCAiZHluYW1pY0Jvb2xBcnJheUFjY2VzcygpYm9vbCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfZHluYW1pY0Jvb2xBcnJheUFjY2VzcwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestDynamicBoolArrayAccess.arc56_draft.json b/tests/contracts/artifacts/ABITestDynamicBoolArrayAccess.arc56_draft.json index ff8c68ca1..6660c17b9 100644 --- a/tests/contracts/artifacts/ABITestDynamicBoolArrayAccess.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestDynamicBoolArrayAccess.arc56_draft.json @@ -652,7 +652,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZHluYW1pY0Jvb2xBcnJheUFjY2VzcygpYm9vbAoqYWJpX3JvdXRlX2R5bmFtaWNCb29sQXJyYXlBY2Nlc3M6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBkeW5hbWljQm9vbEFycmF5QWNjZXNzKClib29sCgljYWxsc3ViIGR5bmFtaWNCb29sQXJyYXlBY2Nlc3MKCXB1c2hieXRlcyAweDAwCglwdXNoaW50IDAKCXVuY292ZXIgMgoJc2V0Yml0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGR5bmFtaWNCb29sQXJyYXlBY2Nlc3MoKTogYm9vbGVhbgpkeW5hbWljQm9vbEFycmF5QWNjZXNzOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo5MzkKCS8vIGE6IGJvb2xlYW5bXSA9IFt0cnVlLCBmYWxzZSwgdHJ1ZSwgdHJ1ZSwgZmFsc2UsIGZhbHNlLCB0cnVlLCBmYWxzZSwgZmFsc2VdCglwdXNoYnl0ZXMgMHgwMDA5CglwdXNoYnl0ZXMgMHgwMDAwCglwdXNoaW50IDAKCXB1c2hpbnQgMQoJc2V0Yml0CglwdXNoaW50IDEKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDIKCXB1c2hpbnQgMQoJc2V0Yml0CglwdXNoaW50IDMKCXB1c2hpbnQgMQoJc2V0Yml0CglwdXNoaW50IDQKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDUKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDYKCXB1c2hpbnQgMQoJc2V0Yml0CglwdXNoaW50IDcKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDgKCXB1c2hpbnQgMAoJc2V0Yml0Cgljb25jYXQKCWZyYW1lX2J1cnkgMCAvLyBhOiBib29sZWFuW10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6OTQxCgkvLyByZXR1cm4gYVs4XTsKCWZyYW1lX2RpZyAwIC8vIGE6IGJvb2xlYW5bXQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgOAoJZ2V0Yml0CgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDhlYzgwMjQ5IC8vIG1ldGhvZCAiZHluYW1pY0Jvb2xBcnJheUFjY2VzcygpYm9vbCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfZHluYW1pY0Jvb2xBcnJheUFjY2VzcwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZHluYW1pY0Jvb2xBcnJheUFjY2VzcygpYm9vbAoqYWJpX3JvdXRlX2R5bmFtaWNCb29sQXJyYXlBY2Nlc3M6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBkeW5hbWljQm9vbEFycmF5QWNjZXNzKClib29sCgljYWxsc3ViIGR5bmFtaWNCb29sQXJyYXlBY2Nlc3MKCXB1c2hieXRlcyAweDAwCglwdXNoaW50IDAKCXVuY292ZXIgMgoJc2V0Yml0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGR5bmFtaWNCb29sQXJyYXlBY2Nlc3MoKTogYm9vbGVhbgpkeW5hbWljQm9vbEFycmF5QWNjZXNzOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo5MzkKCS8vIGE6IGJvb2xlYW5bXSA9IFt0cnVlLCBmYWxzZSwgdHJ1ZSwgdHJ1ZSwgZmFsc2UsIGZhbHNlLCB0cnVlLCBmYWxzZSwgZmFsc2VdCglwdXNoYnl0ZXMgMHgwMDA5CglwdXNoYnl0ZXMgMHgwMDAwCglwdXNoaW50IDAKCXB1c2hpbnQgMQoJc2V0Yml0CglwdXNoaW50IDEKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDIKCXB1c2hpbnQgMQoJc2V0Yml0CglwdXNoaW50IDMKCXB1c2hpbnQgMQoJc2V0Yml0CglwdXNoaW50IDQKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDUKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDYKCXB1c2hpbnQgMQoJc2V0Yml0CglwdXNoaW50IDcKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDgKCXB1c2hpbnQgMAoJc2V0Yml0Cgljb25jYXQKCWZyYW1lX2J1cnkgMCAvLyBhOiBib29sZWFuW10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6OTQxCgkvLyByZXR1cm4gYVs4XTsKCWZyYW1lX2RpZyAwIC8vIGE6IGJvb2xlYW5bXQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgOAoJZ2V0Yml0CgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDhlYzgwMjQ5IC8vIG1ldGhvZCAiZHluYW1pY0Jvb2xBcnJheUFjY2VzcygpYm9vbCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfZHluYW1pY0Jvb2xBcnJheUFjY2VzcwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestDynamicBoolArrayUpdate.approval.teal b/tests/contracts/artifacts/ABITestDynamicBoolArrayUpdate.approval.teal index 7f2ef9763..82a902a70 100644 --- a/tests/contracts/artifacts/ABITestDynamicBoolArrayUpdate.approval.teal +++ b/tests/contracts/artifacts/ABITestDynamicBoolArrayUpdate.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 intcblock 1 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestDynamicBoolArrayUpdate.arc32.json b/tests/contracts/artifacts/ABITestDynamicBoolArrayUpdate.arc32.json index 144a15e92..610d300bb 100644 --- a/tests/contracts/artifacts/ABITestDynamicBoolArrayUpdate.arc32.json +++ b/tests/contracts/artifacts/ABITestDynamicBoolArrayUpdate.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmludGNibG9jayAxCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZHluYW1pY0Jvb2xBcnJheVVwZGF0ZSgpYm9vbFtdCiphYmlfcm91dGVfZHluYW1pY0Jvb2xBcnJheVVwZGF0ZToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGR5bmFtaWNCb29sQXJyYXlVcGRhdGUoKWJvb2xbXQoJY2FsbHN1YiBkeW5hbWljQm9vbEFycmF5VXBkYXRlCgljb25jYXQKCWxvZwoJaW50IDEKCXJldHVybgoKLy8gZHluYW1pY0Jvb2xBcnJheVVwZGF0ZSgpOiBib29sZWFuW10KZHluYW1pY0Jvb2xBcnJheVVwZGF0ZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglwdXNoYnl0ZXMgMHgKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6OTU3CgkvLyBhOiBib29sZWFuW10gPSBbdHJ1ZSwgZmFsc2UsIHRydWUsIHRydWUsIGZhbHNlLCBmYWxzZSwgdHJ1ZSwgZmFsc2UsIGZhbHNlXQoJcHVzaGJ5dGVzIDB4MDAwOQoJcHVzaGJ5dGVzIDB4MDAwMAoJcHVzaGludCAwCglpbnQgMQoJc2V0Yml0CglpbnQgMQoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgMgoJaW50IDEKCXNldGJpdAoJcHVzaGludCAzCglpbnQgMQoJc2V0Yml0CglwdXNoaW50IDQKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDUKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDYKCWludCAxCglzZXRiaXQKCXB1c2hpbnQgNwoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgOAoJcHVzaGludCAwCglzZXRiaXQKCWNvbmNhdAoJZnJhbWVfYnVyeSAwIC8vIGE6IGJvb2xlYW5bXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo5NTkKCS8vIGFbOF0gPSB0cnVlCglmcmFtZV9kaWcgMCAvLyBhOiBib29sZWFuW10KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoaW50IDI0CglpbnQgMQoJc2V0Yml0CglmcmFtZV9idXJ5IDAgLy8gYTogYm9vbGVhbltdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjk2MQoJLy8gcmV0dXJuIGE7CglmcmFtZV9kaWcgMCAvLyBhOiBib29sZWFuW10KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCWludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhkNzE5NjBhNiAvLyBtZXRob2QgImR5bmFtaWNCb29sQXJyYXlVcGRhdGUoKWJvb2xbXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfZHluYW1pY0Jvb2xBcnJheVVwZGF0ZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmludGNibG9jayAxCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZHluYW1pY0Jvb2xBcnJheVVwZGF0ZSgpYm9vbFtdCiphYmlfcm91dGVfZHluYW1pY0Jvb2xBcnJheVVwZGF0ZToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGR5bmFtaWNCb29sQXJyYXlVcGRhdGUoKWJvb2xbXQoJY2FsbHN1YiBkeW5hbWljQm9vbEFycmF5VXBkYXRlCgljb25jYXQKCWxvZwoJaW50IDEKCXJldHVybgoKLy8gZHluYW1pY0Jvb2xBcnJheVVwZGF0ZSgpOiBib29sZWFuW10KZHluYW1pY0Jvb2xBcnJheVVwZGF0ZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglwdXNoYnl0ZXMgMHgKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6OTU3CgkvLyBhOiBib29sZWFuW10gPSBbdHJ1ZSwgZmFsc2UsIHRydWUsIHRydWUsIGZhbHNlLCBmYWxzZSwgdHJ1ZSwgZmFsc2UsIGZhbHNlXQoJcHVzaGJ5dGVzIDB4MDAwOQoJcHVzaGJ5dGVzIDB4MDAwMAoJcHVzaGludCAwCglpbnQgMQoJc2V0Yml0CglpbnQgMQoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgMgoJaW50IDEKCXNldGJpdAoJcHVzaGludCAzCglpbnQgMQoJc2V0Yml0CglwdXNoaW50IDQKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDUKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDYKCWludCAxCglzZXRiaXQKCXB1c2hpbnQgNwoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgOAoJcHVzaGludCAwCglzZXRiaXQKCWNvbmNhdAoJZnJhbWVfYnVyeSAwIC8vIGE6IGJvb2xlYW5bXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo5NTkKCS8vIGFbOF0gPSB0cnVlCglmcmFtZV9kaWcgMCAvLyBhOiBib29sZWFuW10KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoaW50IDI0CglpbnQgMQoJc2V0Yml0CglmcmFtZV9idXJ5IDAgLy8gYTogYm9vbGVhbltdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjk2MQoJLy8gcmV0dXJuIGE7CglmcmFtZV9kaWcgMCAvLyBhOiBib29sZWFuW10KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCWludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhkNzE5NjBhNiAvLyBtZXRob2QgImR5bmFtaWNCb29sQXJyYXlVcGRhdGUoKWJvb2xbXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfZHluYW1pY0Jvb2xBcnJheVVwZGF0ZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestDynamicBoolArrayUpdate.arc56_draft.json b/tests/contracts/artifacts/ABITestDynamicBoolArrayUpdate.arc56_draft.json index 32c2028f8..bdd811683 100644 --- a/tests/contracts/artifacts/ABITestDynamicBoolArrayUpdate.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestDynamicBoolArrayUpdate.arc56_draft.json @@ -653,7 +653,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmludGNibG9jayAxCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZHluYW1pY0Jvb2xBcnJheVVwZGF0ZSgpYm9vbFtdCiphYmlfcm91dGVfZHluYW1pY0Jvb2xBcnJheVVwZGF0ZToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGR5bmFtaWNCb29sQXJyYXlVcGRhdGUoKWJvb2xbXQoJY2FsbHN1YiBkeW5hbWljQm9vbEFycmF5VXBkYXRlCgljb25jYXQKCWxvZwoJaW50IDEKCXJldHVybgoKLy8gZHluYW1pY0Jvb2xBcnJheVVwZGF0ZSgpOiBib29sZWFuW10KZHluYW1pY0Jvb2xBcnJheVVwZGF0ZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglwdXNoYnl0ZXMgMHgKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6OTU3CgkvLyBhOiBib29sZWFuW10gPSBbdHJ1ZSwgZmFsc2UsIHRydWUsIHRydWUsIGZhbHNlLCBmYWxzZSwgdHJ1ZSwgZmFsc2UsIGZhbHNlXQoJcHVzaGJ5dGVzIDB4MDAwOQoJcHVzaGJ5dGVzIDB4MDAwMAoJcHVzaGludCAwCglpbnQgMQoJc2V0Yml0CglpbnQgMQoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgMgoJaW50IDEKCXNldGJpdAoJcHVzaGludCAzCglpbnQgMQoJc2V0Yml0CglwdXNoaW50IDQKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDUKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDYKCWludCAxCglzZXRiaXQKCXB1c2hpbnQgNwoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgOAoJcHVzaGludCAwCglzZXRiaXQKCWNvbmNhdAoJZnJhbWVfYnVyeSAwIC8vIGE6IGJvb2xlYW5bXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo5NTkKCS8vIGFbOF0gPSB0cnVlCglmcmFtZV9kaWcgMCAvLyBhOiBib29sZWFuW10KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoaW50IDI0CglpbnQgMQoJc2V0Yml0CglmcmFtZV9idXJ5IDAgLy8gYTogYm9vbGVhbltdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjk2MQoJLy8gcmV0dXJuIGE7CglmcmFtZV9kaWcgMCAvLyBhOiBib29sZWFuW10KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCWludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhkNzE5NjBhNiAvLyBtZXRob2QgImR5bmFtaWNCb29sQXJyYXlVcGRhdGUoKWJvb2xbXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfZHluYW1pY0Jvb2xBcnJheVVwZGF0ZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmludGNibG9jayAxCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZHluYW1pY0Jvb2xBcnJheVVwZGF0ZSgpYm9vbFtdCiphYmlfcm91dGVfZHluYW1pY0Jvb2xBcnJheVVwZGF0ZToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGR5bmFtaWNCb29sQXJyYXlVcGRhdGUoKWJvb2xbXQoJY2FsbHN1YiBkeW5hbWljQm9vbEFycmF5VXBkYXRlCgljb25jYXQKCWxvZwoJaW50IDEKCXJldHVybgoKLy8gZHluYW1pY0Jvb2xBcnJheVVwZGF0ZSgpOiBib29sZWFuW10KZHluYW1pY0Jvb2xBcnJheVVwZGF0ZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglwdXNoYnl0ZXMgMHgKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6OTU3CgkvLyBhOiBib29sZWFuW10gPSBbdHJ1ZSwgZmFsc2UsIHRydWUsIHRydWUsIGZhbHNlLCBmYWxzZSwgdHJ1ZSwgZmFsc2UsIGZhbHNlXQoJcHVzaGJ5dGVzIDB4MDAwOQoJcHVzaGJ5dGVzIDB4MDAwMAoJcHVzaGludCAwCglpbnQgMQoJc2V0Yml0CglpbnQgMQoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgMgoJaW50IDEKCXNldGJpdAoJcHVzaGludCAzCglpbnQgMQoJc2V0Yml0CglwdXNoaW50IDQKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDUKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDYKCWludCAxCglzZXRiaXQKCXB1c2hpbnQgNwoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgOAoJcHVzaGludCAwCglzZXRiaXQKCWNvbmNhdAoJZnJhbWVfYnVyeSAwIC8vIGE6IGJvb2xlYW5bXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo5NTkKCS8vIGFbOF0gPSB0cnVlCglmcmFtZV9kaWcgMCAvLyBhOiBib29sZWFuW10KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoaW50IDI0CglpbnQgMQoJc2V0Yml0CglmcmFtZV9idXJ5IDAgLy8gYTogYm9vbGVhbltdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjk2MQoJLy8gcmV0dXJuIGE7CglmcmFtZV9kaWcgMCAvLyBhOiBib29sZWFuW10KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCWludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhkNzE5NjBhNiAvLyBtZXRob2QgImR5bmFtaWNCb29sQXJyYXlVcGRhdGUoKWJvb2xbXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfZHluYW1pY0Jvb2xBcnJheVVwZGF0ZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestDynamicTupleArray.approval.teal b/tests/contracts/artifacts/ABITestDynamicTupleArray.approval.teal index 3aecfd496..4839a8cb5 100644 --- a/tests/contracts/artifacts/ABITestDynamicTupleArray.approval.teal +++ b/tests/contracts/artifacts/ABITestDynamicTupleArray.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestDynamicTupleArray.arc32.json b/tests/contracts/artifacts/ABITestDynamicTupleArray.arc32.json index 14535a1b9..81725b279 100644 --- a/tests/contracts/artifacts/ABITestDynamicTupleArray.arc32.json +++ b/tests/contracts/artifacts/ABITestDynamicTupleArray.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZHluYW1pY1R1cGxlQXJyYXkoKXVpbnQ2NAoqYWJpX3JvdXRlX2R5bmFtaWNUdXBsZUFycmF5OgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgZHluYW1pY1R1cGxlQXJyYXkoKXVpbnQ2NAoJY2FsbHN1YiBkeW5hbWljVHVwbGVBcnJheQoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBkeW5hbWljVHVwbGVBcnJheSgpOiB1aW50NjQKZHluYW1pY1R1cGxlQXJyYXk6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjM3OQoJLy8gYTogW3VpbnQxNiwgdWludDY0XVtdID0gWwoJLy8gICAgICAgWzExLCAyMl0sCgkvLyAgICAgICBbMzMsIDQ0XSwKCS8vICAgICBdCglwdXNoYnl0ZXMgMHgwMDBiMDAwMDAwMDAwMDAwMDAxNjAwMjEwMDAwMDAwMDAwMDAwMDJjCglmcmFtZV9idXJ5IDAgLy8gYTogW3VpbnQxNiwgdWludDY0XVtdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjM4NAoJLy8gcmV0dXJuIGFbMV1bMV07CglmcmFtZV9kaWcgMCAvLyBhOiBbdWludDE2LCB1aW50NjRdW10KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglleHRyYWN0IDEyIDgKCWJ0b2kKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MTBjNTc1MTAgLy8gbWV0aG9kICJkeW5hbWljVHVwbGVBcnJheSgpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9keW5hbWljVHVwbGVBcnJheQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZHluYW1pY1R1cGxlQXJyYXkoKXVpbnQ2NAoqYWJpX3JvdXRlX2R5bmFtaWNUdXBsZUFycmF5OgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgZHluYW1pY1R1cGxlQXJyYXkoKXVpbnQ2NAoJY2FsbHN1YiBkeW5hbWljVHVwbGVBcnJheQoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBkeW5hbWljVHVwbGVBcnJheSgpOiB1aW50NjQKZHluYW1pY1R1cGxlQXJyYXk6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjM3OQoJLy8gYTogW3VpbnQxNiwgdWludDY0XVtdID0gWwoJLy8gICAgICAgWzExLCAyMl0sCgkvLyAgICAgICBbMzMsIDQ0XSwKCS8vICAgICBdCglwdXNoYnl0ZXMgMHgwMDBiMDAwMDAwMDAwMDAwMDAxNjAwMjEwMDAwMDAwMDAwMDAwMDJjCglmcmFtZV9idXJ5IDAgLy8gYTogW3VpbnQxNiwgdWludDY0XVtdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjM4NAoJLy8gcmV0dXJuIGFbMV1bMV07CglmcmFtZV9kaWcgMCAvLyBhOiBbdWludDE2LCB1aW50NjRdW10KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglleHRyYWN0IDEyIDgKCWJ0b2kKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MTBjNTc1MTAgLy8gbWV0aG9kICJkeW5hbWljVHVwbGVBcnJheSgpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9keW5hbWljVHVwbGVBcnJheQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestDynamicTupleArray.arc56_draft.json b/tests/contracts/artifacts/ABITestDynamicTupleArray.arc56_draft.json index 132abe638..e6bb1520c 100644 --- a/tests/contracts/artifacts/ABITestDynamicTupleArray.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestDynamicTupleArray.arc56_draft.json @@ -422,7 +422,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZHluYW1pY1R1cGxlQXJyYXkoKXVpbnQ2NAoqYWJpX3JvdXRlX2R5bmFtaWNUdXBsZUFycmF5OgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgZHluYW1pY1R1cGxlQXJyYXkoKXVpbnQ2NAoJY2FsbHN1YiBkeW5hbWljVHVwbGVBcnJheQoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBkeW5hbWljVHVwbGVBcnJheSgpOiB1aW50NjQKZHluYW1pY1R1cGxlQXJyYXk6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjM3OQoJLy8gYTogW3VpbnQxNiwgdWludDY0XVtdID0gWwoJLy8gICAgICAgWzExLCAyMl0sCgkvLyAgICAgICBbMzMsIDQ0XSwKCS8vICAgICBdCglwdXNoYnl0ZXMgMHgwMDBiMDAwMDAwMDAwMDAwMDAxNjAwMjEwMDAwMDAwMDAwMDAwMDJjCglmcmFtZV9idXJ5IDAgLy8gYTogW3VpbnQxNiwgdWludDY0XVtdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjM4NAoJLy8gcmV0dXJuIGFbMV1bMV07CglmcmFtZV9kaWcgMCAvLyBhOiBbdWludDE2LCB1aW50NjRdW10KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglleHRyYWN0IDEyIDgKCWJ0b2kKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MTBjNTc1MTAgLy8gbWV0aG9kICJkeW5hbWljVHVwbGVBcnJheSgpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9keW5hbWljVHVwbGVBcnJheQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZHluYW1pY1R1cGxlQXJyYXkoKXVpbnQ2NAoqYWJpX3JvdXRlX2R5bmFtaWNUdXBsZUFycmF5OgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgZHluYW1pY1R1cGxlQXJyYXkoKXVpbnQ2NAoJY2FsbHN1YiBkeW5hbWljVHVwbGVBcnJheQoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBkeW5hbWljVHVwbGVBcnJheSgpOiB1aW50NjQKZHluYW1pY1R1cGxlQXJyYXk6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjM3OQoJLy8gYTogW3VpbnQxNiwgdWludDY0XVtdID0gWwoJLy8gICAgICAgWzExLCAyMl0sCgkvLyAgICAgICBbMzMsIDQ0XSwKCS8vICAgICBdCglwdXNoYnl0ZXMgMHgwMDBiMDAwMDAwMDAwMDAwMDAxNjAwMjEwMDAwMDAwMDAwMDAwMDJjCglmcmFtZV9idXJ5IDAgLy8gYTogW3VpbnQxNiwgdWludDY0XVtdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjM4NAoJLy8gcmV0dXJuIGFbMV1bMV07CglmcmFtZV9kaWcgMCAvLyBhOiBbdWludDE2LCB1aW50NjRdW10KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglleHRyYWN0IDEyIDgKCWJ0b2kKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MTBjNTc1MTAgLy8gbWV0aG9kICJkeW5hbWljVHVwbGVBcnJheSgpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9keW5hbWljVHVwbGVBcnJheQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestEmptyDynamicArray.approval.teal b/tests/contracts/artifacts/ABITestEmptyDynamicArray.approval.teal index 08016536c..60758b65a 100644 --- a/tests/contracts/artifacts/ABITestEmptyDynamicArray.approval.teal +++ b/tests/contracts/artifacts/ABITestEmptyDynamicArray.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestEmptyDynamicArray.arc32.json b/tests/contracts/artifacts/ABITestEmptyDynamicArray.arc32.json index b8a63b910..390ceea43 100644 --- a/tests/contracts/artifacts/ABITestEmptyDynamicArray.arc32.json +++ b/tests/contracts/artifacts/ABITestEmptyDynamicArray.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZW1wdHlEeW5hbWljQXJyYXkoKXVpbnQ2NFtdCiphYmlfcm91dGVfZW1wdHlEeW5hbWljQXJyYXk6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBlbXB0eUR5bmFtaWNBcnJheSgpdWludDY0W10KCWNhbGxzdWIgZW1wdHlEeW5hbWljQXJyYXkKCWR1cAoJbGVuCglwdXNoaW50IDgKCS8KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gZW1wdHlEeW5hbWljQXJyYXkoKTogdWludDY0W10KZW1wdHlEeW5hbWljQXJyYXk6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6ODY4CgkvLyByZXR1cm4gW107CglwdXNoYnl0ZXMgMHgKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YzVhMjg5NmQgLy8gbWV0aG9kICJlbXB0eUR5bmFtaWNBcnJheSgpdWludDY0W10iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2VtcHR5RHluYW1pY0FycmF5CgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZW1wdHlEeW5hbWljQXJyYXkoKXVpbnQ2NFtdCiphYmlfcm91dGVfZW1wdHlEeW5hbWljQXJyYXk6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBlbXB0eUR5bmFtaWNBcnJheSgpdWludDY0W10KCWNhbGxzdWIgZW1wdHlEeW5hbWljQXJyYXkKCWR1cAoJbGVuCglwdXNoaW50IDgKCS8KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gZW1wdHlEeW5hbWljQXJyYXkoKTogdWludDY0W10KZW1wdHlEeW5hbWljQXJyYXk6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6ODY4CgkvLyByZXR1cm4gW107CglwdXNoYnl0ZXMgMHgKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YzVhMjg5NmQgLy8gbWV0aG9kICJlbXB0eUR5bmFtaWNBcnJheSgpdWludDY0W10iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2VtcHR5RHluYW1pY0FycmF5CgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestEmptyDynamicArray.arc56_draft.json b/tests/contracts/artifacts/ABITestEmptyDynamicArray.arc56_draft.json index 0225668c8..3dfee61de 100644 --- a/tests/contracts/artifacts/ABITestEmptyDynamicArray.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestEmptyDynamicArray.arc56_draft.json @@ -390,7 +390,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZW1wdHlEeW5hbWljQXJyYXkoKXVpbnQ2NFtdCiphYmlfcm91dGVfZW1wdHlEeW5hbWljQXJyYXk6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBlbXB0eUR5bmFtaWNBcnJheSgpdWludDY0W10KCWNhbGxzdWIgZW1wdHlEeW5hbWljQXJyYXkKCWR1cAoJbGVuCglwdXNoaW50IDgKCS8KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gZW1wdHlEeW5hbWljQXJyYXkoKTogdWludDY0W10KZW1wdHlEeW5hbWljQXJyYXk6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6ODY4CgkvLyByZXR1cm4gW107CglwdXNoYnl0ZXMgMHgKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YzVhMjg5NmQgLy8gbWV0aG9kICJlbXB0eUR5bmFtaWNBcnJheSgpdWludDY0W10iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2VtcHR5RHluYW1pY0FycmF5CgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZW1wdHlEeW5hbWljQXJyYXkoKXVpbnQ2NFtdCiphYmlfcm91dGVfZW1wdHlEeW5hbWljQXJyYXk6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBlbXB0eUR5bmFtaWNBcnJheSgpdWludDY0W10KCWNhbGxzdWIgZW1wdHlEeW5hbWljQXJyYXkKCWR1cAoJbGVuCglwdXNoaW50IDgKCS8KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gZW1wdHlEeW5hbWljQXJyYXkoKTogdWludDY0W10KZW1wdHlEeW5hbWljQXJyYXk6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6ODY4CgkvLyByZXR1cm4gW107CglwdXNoYnl0ZXMgMHgKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YzVhMjg5NmQgLy8gbWV0aG9kICJlbXB0eUR5bmFtaWNBcnJheSgpdWludDY0W10iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2VtcHR5RHluYW1pY0FycmF5CgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestEmptyStaticArray.approval.teal b/tests/contracts/artifacts/ABITestEmptyStaticArray.approval.teal index 7e773197f..a93d1e25e 100644 --- a/tests/contracts/artifacts/ABITestEmptyStaticArray.approval.teal +++ b/tests/contracts/artifacts/ABITestEmptyStaticArray.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestEmptyStaticArray.arc32.json b/tests/contracts/artifacts/ABITestEmptyStaticArray.arc32.json index c40b4b89b..f58a0f604 100644 --- a/tests/contracts/artifacts/ABITestEmptyStaticArray.arc32.json +++ b/tests/contracts/artifacts/ABITestEmptyStaticArray.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZW1wdHlTdGF0aWNBcnJheSgpdWludDE2WzNdCiphYmlfcm91dGVfZW1wdHlTdGF0aWNBcnJheToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGVtcHR5U3RhdGljQXJyYXkoKXVpbnQxNlszXQoJY2FsbHN1YiBlbXB0eVN0YXRpY0FycmF5Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGVtcHR5U3RhdGljQXJyYXkoKTogU3RhdGljQXJyYXk8dWludDE2LCAzPgplbXB0eVN0YXRpY0FycmF5OgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4NDIKCS8vIGE6IFN0YXRpY0FycmF5PHVpbnQxNiwgMz4gPSBbXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8dWludDE2LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4NDQKCS8vIHJldHVybiBhOwoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8dWludDE2LCAzPgoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhiNjg4NDFhOCAvLyBtZXRob2QgImVtcHR5U3RhdGljQXJyYXkoKXVpbnQxNlszXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfZW1wdHlTdGF0aWNBcnJheQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZW1wdHlTdGF0aWNBcnJheSgpdWludDE2WzNdCiphYmlfcm91dGVfZW1wdHlTdGF0aWNBcnJheToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGVtcHR5U3RhdGljQXJyYXkoKXVpbnQxNlszXQoJY2FsbHN1YiBlbXB0eVN0YXRpY0FycmF5Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGVtcHR5U3RhdGljQXJyYXkoKTogU3RhdGljQXJyYXk8dWludDE2LCAzPgplbXB0eVN0YXRpY0FycmF5OgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4NDIKCS8vIGE6IFN0YXRpY0FycmF5PHVpbnQxNiwgMz4gPSBbXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8dWludDE2LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4NDQKCS8vIHJldHVybiBhOwoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8dWludDE2LCAzPgoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhiNjg4NDFhOCAvLyBtZXRob2QgImVtcHR5U3RhdGljQXJyYXkoKXVpbnQxNlszXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfZW1wdHlTdGF0aWNBcnJheQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestEmptyStaticArray.arc56_draft.json b/tests/contracts/artifacts/ABITestEmptyStaticArray.arc56_draft.json index c5b6f27df..6df82ff30 100644 --- a/tests/contracts/artifacts/ABITestEmptyStaticArray.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestEmptyStaticArray.arc56_draft.json @@ -369,7 +369,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZW1wdHlTdGF0aWNBcnJheSgpdWludDE2WzNdCiphYmlfcm91dGVfZW1wdHlTdGF0aWNBcnJheToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGVtcHR5U3RhdGljQXJyYXkoKXVpbnQxNlszXQoJY2FsbHN1YiBlbXB0eVN0YXRpY0FycmF5Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGVtcHR5U3RhdGljQXJyYXkoKTogU3RhdGljQXJyYXk8dWludDE2LCAzPgplbXB0eVN0YXRpY0FycmF5OgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4NDIKCS8vIGE6IFN0YXRpY0FycmF5PHVpbnQxNiwgMz4gPSBbXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8dWludDE2LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4NDQKCS8vIHJldHVybiBhOwoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8dWludDE2LCAzPgoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhiNjg4NDFhOCAvLyBtZXRob2QgImVtcHR5U3RhdGljQXJyYXkoKXVpbnQxNlszXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfZW1wdHlTdGF0aWNBcnJheQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZW1wdHlTdGF0aWNBcnJheSgpdWludDE2WzNdCiphYmlfcm91dGVfZW1wdHlTdGF0aWNBcnJheToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGVtcHR5U3RhdGljQXJyYXkoKXVpbnQxNlszXQoJY2FsbHN1YiBlbXB0eVN0YXRpY0FycmF5Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGVtcHR5U3RhdGljQXJyYXkoKTogU3RhdGljQXJyYXk8dWludDE2LCAzPgplbXB0eVN0YXRpY0FycmF5OgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4NDIKCS8vIGE6IFN0YXRpY0FycmF5PHVpbnQxNiwgMz4gPSBbXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8dWludDE2LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4NDQKCS8vIHJldHVybiBhOwoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8dWludDE2LCAzPgoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhiNjg4NDFhOCAvLyBtZXRob2QgImVtcHR5U3RhdGljQXJyYXkoKXVpbnQxNlszXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfZW1wdHlTdGF0aWNBcnJheQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestExtractUint.approval.teal b/tests/contracts/artifacts/ABITestExtractUint.approval.teal index 6182802ee..078d50cb3 100644 --- a/tests/contracts/artifacts/ABITestExtractUint.approval.teal +++ b/tests/contracts/artifacts/ABITestExtractUint.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestExtractUint.arc32.json b/tests/contracts/artifacts/ABITestExtractUint.arc32.json index a3d11b4c0..78aea9af7 100644 --- a/tests/contracts/artifacts/ABITestExtractUint.arc32.json +++ b/tests/contracts/artifacts/ABITestExtractUint.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZXh0cmFjdFVpbnQodWludDY0KXVpbnQ4CiphYmlfcm91dGVfZXh0cmFjdFVpbnQ6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gYXJnOiB1aW50NjQKCXR4bmEgQXBwbGljYXRpb25BcmdzIDEKCWJ0b2kKCgkvLyBleGVjdXRlIGV4dHJhY3RVaW50KHVpbnQ2NCl1aW50OAoJY2FsbHN1YiBleHRyYWN0VWludAoJaXRvYgoJZHVwCgliaXRsZW4KCXB1c2hpbnQgOAoJPD0KCgkvLyBleHRyYWN0VWludCByZXR1cm4gdmFsdWUgb3ZlcmZsb3dlZCA4IGJpdHMKCWFzc2VydAoJZXh0cmFjdCA3IDEKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gZXh0cmFjdFVpbnQoYXJnOiB1aW50NjQpOiB1aW50PDg+CmV4dHJhY3RVaW50OgoJcHJvdG8gMSAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMTE5CgkvLyB4ID0gPHVpbnQ8OD4+YXJnCglmcmFtZV9kaWcgLTEgLy8gYXJnOiB1aW50NjQKCWZyYW1lX2J1cnkgMCAvLyB4OiB1bnNhZmUgdWludDgKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTEyMAoJLy8gcmV0dXJuIHg7CglmcmFtZV9kaWcgMCAvLyB4OiB1bnNhZmUgdWludDgKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4M2IzZjZiNzkgLy8gbWV0aG9kICJleHRyYWN0VWludCh1aW50NjQpdWludDgiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2V4dHJhY3RVaW50CgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZXh0cmFjdFVpbnQodWludDY0KXVpbnQ4CiphYmlfcm91dGVfZXh0cmFjdFVpbnQ6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gYXJnOiB1aW50NjQKCXR4bmEgQXBwbGljYXRpb25BcmdzIDEKCWJ0b2kKCgkvLyBleGVjdXRlIGV4dHJhY3RVaW50KHVpbnQ2NCl1aW50OAoJY2FsbHN1YiBleHRyYWN0VWludAoJaXRvYgoJZHVwCgliaXRsZW4KCXB1c2hpbnQgOAoJPD0KCgkvLyBleHRyYWN0VWludCByZXR1cm4gdmFsdWUgb3ZlcmZsb3dlZCA4IGJpdHMKCWFzc2VydAoJZXh0cmFjdCA3IDEKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gZXh0cmFjdFVpbnQoYXJnOiB1aW50NjQpOiB1aW50PDg+CmV4dHJhY3RVaW50OgoJcHJvdG8gMSAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMTE5CgkvLyB4ID0gPHVpbnQ8OD4+YXJnCglmcmFtZV9kaWcgLTEgLy8gYXJnOiB1aW50NjQKCWZyYW1lX2J1cnkgMCAvLyB4OiB1bnNhZmUgdWludDgKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTEyMAoJLy8gcmV0dXJuIHg7CglmcmFtZV9kaWcgMCAvLyB4OiB1bnNhZmUgdWludDgKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4M2IzZjZiNzkgLy8gbWV0aG9kICJleHRyYWN0VWludCh1aW50NjQpdWludDgiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2V4dHJhY3RVaW50CgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestExtractUint.arc56_draft.json b/tests/contracts/artifacts/ABITestExtractUint.arc56_draft.json index 71f3e7b37..306a84e9f 100644 --- a/tests/contracts/artifacts/ABITestExtractUint.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestExtractUint.arc56_draft.json @@ -437,7 +437,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZXh0cmFjdFVpbnQodWludDY0KXVpbnQ4CiphYmlfcm91dGVfZXh0cmFjdFVpbnQ6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gYXJnOiB1aW50NjQKCXR4bmEgQXBwbGljYXRpb25BcmdzIDEKCWJ0b2kKCgkvLyBleGVjdXRlIGV4dHJhY3RVaW50KHVpbnQ2NCl1aW50OAoJY2FsbHN1YiBleHRyYWN0VWludAoJaXRvYgoJZHVwCgliaXRsZW4KCXB1c2hpbnQgOAoJPD0KCgkvLyBleHRyYWN0VWludCByZXR1cm4gdmFsdWUgb3ZlcmZsb3dlZCA4IGJpdHMKCWFzc2VydAoJZXh0cmFjdCA3IDEKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gZXh0cmFjdFVpbnQoYXJnOiB1aW50NjQpOiB1aW50PDg+CmV4dHJhY3RVaW50OgoJcHJvdG8gMSAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMTE5CgkvLyB4ID0gPHVpbnQ8OD4+YXJnCglmcmFtZV9kaWcgLTEgLy8gYXJnOiB1aW50NjQKCWZyYW1lX2J1cnkgMCAvLyB4OiB1bnNhZmUgdWludDgKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTEyMAoJLy8gcmV0dXJuIHg7CglmcmFtZV9kaWcgMCAvLyB4OiB1bnNhZmUgdWludDgKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4M2IzZjZiNzkgLy8gbWV0aG9kICJleHRyYWN0VWludCh1aW50NjQpdWludDgiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2V4dHJhY3RVaW50CgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZXh0cmFjdFVpbnQodWludDY0KXVpbnQ4CiphYmlfcm91dGVfZXh0cmFjdFVpbnQ6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gYXJnOiB1aW50NjQKCXR4bmEgQXBwbGljYXRpb25BcmdzIDEKCWJ0b2kKCgkvLyBleGVjdXRlIGV4dHJhY3RVaW50KHVpbnQ2NCl1aW50OAoJY2FsbHN1YiBleHRyYWN0VWludAoJaXRvYgoJZHVwCgliaXRsZW4KCXB1c2hpbnQgOAoJPD0KCgkvLyBleHRyYWN0VWludCByZXR1cm4gdmFsdWUgb3ZlcmZsb3dlZCA4IGJpdHMKCWFzc2VydAoJZXh0cmFjdCA3IDEKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gZXh0cmFjdFVpbnQoYXJnOiB1aW50NjQpOiB1aW50PDg+CmV4dHJhY3RVaW50OgoJcHJvdG8gMSAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMTE5CgkvLyB4ID0gPHVpbnQ8OD4+YXJnCglmcmFtZV9kaWcgLTEgLy8gYXJnOiB1aW50NjQKCWZyYW1lX2J1cnkgMCAvLyB4OiB1bnNhZmUgdWludDgKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTEyMAoJLy8gcmV0dXJuIHg7CglmcmFtZV9kaWcgMCAvLyB4OiB1bnNhZmUgdWludDgKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4M2IzZjZiNzkgLy8gbWV0aG9kICJleHRyYWN0VWludCh1aW50NjQpdWludDgiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2V4dHJhY3RVaW50CgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestForEachReturn.approval.teal b/tests/contracts/artifacts/ABITestForEachReturn.approval.teal index 7df01854d..2142c3223 100644 --- a/tests/contracts/artifacts/ABITestForEachReturn.approval.teal +++ b/tests/contracts/artifacts/ABITestForEachReturn.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestForEachReturn.arc32.json b/tests/contracts/artifacts/ABITestForEachReturn.arc32.json index 64ab98778..5d2aa8adc 100644 --- a/tests/contracts/artifacts/ABITestForEachReturn.arc32.json +++ b/tests/contracts/artifacts/ABITestForEachReturn.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBmb3JFYWNoUmV0dXJuKCl1aW50NjQKKmFiaV9yb3V0ZV9mb3JFYWNoUmV0dXJuOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgZm9yRWFjaFJldHVybigpdWludDY0CgljYWxsc3ViIGZvckVhY2hSZXR1cm4KCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gZm9yRWFjaFJldHVybigpOiB1aW50NjQKZm9yRWFjaFJldHVybjoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXBuIDQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTM3MgoJLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPiA9IFsxLCAyLCAzXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMTAwMDAwMDAwMDAwMDAwMDIwMDAwMDAwMDAwMDAwMDAzCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMzczCgkvLyBzdW0gPSAwCglwdXNoaW50IDAKCWZyYW1lX2J1cnkgMSAvLyBzdW06IHVpbnQ2NAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMzc1CgkvLyBhLmZvckVhY2gKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCWR1cAoJZnJhbWVfYnVyeSAyIC8vIGNvcHkgb2YgdGhlIGFycmF5IHdlIGFyZSBpdGVyYXRpbmcgb3ZlcgoJZXh0cmFjdCAwIDgKCWJ0b2kKCWZyYW1lX2J1cnkgMyAvLyB2OiB1aW50NjQKCXB1c2hpbnQgMAoJZnJhbWVfYnVyeSA0IC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCgoqZm9yRWFjaF8wOgoJLy8gKmlmMF9jb25kaXRpb24KCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMzc2CgkvLyBzdW0gPiAyCglmcmFtZV9kaWcgMSAvLyBzdW06IHVpbnQ2NAoJcHVzaGludCAyCgk+CglieiAqaWYwX2VuZAoKCS8vICppZjBfY29uc2VxdWVudAoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzNzYKCS8vIHJldHVybjsKCWIgKmZvckVhY2hfMF9lbmQKCippZjBfZW5kOgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzNzcKCS8vIHN1bSArPSB2CglmcmFtZV9kaWcgMSAvLyBzdW06IHVpbnQ2NAoJZnJhbWVfZGlnIDMgLy8gdjogdWludDY0CgkrCglmcmFtZV9idXJ5IDEgLy8gc3VtOiB1aW50NjQKCgkvLyBpbmNyZW1lbnQgb2Zmc2V0IGFuZCBsb29wIGlmIG5vdCBvdXQgb2YgYm91bmRzCglmcmFtZV9kaWcgNCAvLyB0aGUgb2Zmc2V0IHdlIGFyZSBleHRyYWN0aW5nIHRoZSBuZXh0IGVsZW1lbnQgZnJvbQoJcHVzaGludCA4CgkrCglkdXAKCXB1c2hpbnQgMjQgLy8gb2Zmc2V0IG9mIGxhc3QgZWxlbWVudAoJPAoJYnogKmZvckVhY2hfMF9lbmQKCWZyYW1lX2J1cnkgNCAvLyB0aGUgb2Zmc2V0IHdlIGFyZSBleHRyYWN0aW5nIHRoZSBuZXh0IGVsZW1lbnQgZnJvbQoJZnJhbWVfZGlnIDIgLy8gY29weSBvZiB0aGUgYXJyYXkgd2UgYXJlIGl0ZXJhdGluZyBvdmVyCglmcmFtZV9kaWcgNCAvLyB0aGUgb2Zmc2V0IHdlIGFyZSBleHRyYWN0aW5nIHRoZSBuZXh0IGVsZW1lbnQgZnJvbQoJcHVzaGludCA4CglleHRyYWN0CglidG9pCglmcmFtZV9idXJ5IDMgLy8gdjogdWludDY0CgliICpmb3JFYWNoXzAKCipmb3JFYWNoXzBfZW5kOgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzNzkKCS8vIHJldHVybiBzdW07CglmcmFtZV9kaWcgMSAvLyBzdW06IHVpbnQ2NAoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoKCS8vIHBvcCBhbGwgbG9jYWwgdmFyaWFibGVzIGZyb20gdGhlIHN0YWNrCglwb3BuIDQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZTBlNjc4MjcgLy8gbWV0aG9kICJmb3JFYWNoUmV0dXJuKCl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2ZvckVhY2hSZXR1cm4KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBmb3JFYWNoUmV0dXJuKCl1aW50NjQKKmFiaV9yb3V0ZV9mb3JFYWNoUmV0dXJuOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgZm9yRWFjaFJldHVybigpdWludDY0CgljYWxsc3ViIGZvckVhY2hSZXR1cm4KCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gZm9yRWFjaFJldHVybigpOiB1aW50NjQKZm9yRWFjaFJldHVybjoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXBuIDQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTM3MgoJLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPiA9IFsxLCAyLCAzXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMTAwMDAwMDAwMDAwMDAwMDIwMDAwMDAwMDAwMDAwMDAzCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMzczCgkvLyBzdW0gPSAwCglwdXNoaW50IDAKCWZyYW1lX2J1cnkgMSAvLyBzdW06IHVpbnQ2NAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMzc1CgkvLyBhLmZvckVhY2gKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCWR1cAoJZnJhbWVfYnVyeSAyIC8vIGNvcHkgb2YgdGhlIGFycmF5IHdlIGFyZSBpdGVyYXRpbmcgb3ZlcgoJZXh0cmFjdCAwIDgKCWJ0b2kKCWZyYW1lX2J1cnkgMyAvLyB2OiB1aW50NjQKCXB1c2hpbnQgMAoJZnJhbWVfYnVyeSA0IC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCgoqZm9yRWFjaF8wOgoJLy8gKmlmMF9jb25kaXRpb24KCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMzc2CgkvLyBzdW0gPiAyCglmcmFtZV9kaWcgMSAvLyBzdW06IHVpbnQ2NAoJcHVzaGludCAyCgk+CglieiAqaWYwX2VuZAoKCS8vICppZjBfY29uc2VxdWVudAoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzNzYKCS8vIHJldHVybjsKCWIgKmZvckVhY2hfMF9lbmQKCippZjBfZW5kOgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzNzcKCS8vIHN1bSArPSB2CglmcmFtZV9kaWcgMSAvLyBzdW06IHVpbnQ2NAoJZnJhbWVfZGlnIDMgLy8gdjogdWludDY0CgkrCglmcmFtZV9idXJ5IDEgLy8gc3VtOiB1aW50NjQKCgkvLyBpbmNyZW1lbnQgb2Zmc2V0IGFuZCBsb29wIGlmIG5vdCBvdXQgb2YgYm91bmRzCglmcmFtZV9kaWcgNCAvLyB0aGUgb2Zmc2V0IHdlIGFyZSBleHRyYWN0aW5nIHRoZSBuZXh0IGVsZW1lbnQgZnJvbQoJcHVzaGludCA4CgkrCglkdXAKCXB1c2hpbnQgMjQgLy8gb2Zmc2V0IG9mIGxhc3QgZWxlbWVudAoJPAoJYnogKmZvckVhY2hfMF9lbmQKCWZyYW1lX2J1cnkgNCAvLyB0aGUgb2Zmc2V0IHdlIGFyZSBleHRyYWN0aW5nIHRoZSBuZXh0IGVsZW1lbnQgZnJvbQoJZnJhbWVfZGlnIDIgLy8gY29weSBvZiB0aGUgYXJyYXkgd2UgYXJlIGl0ZXJhdGluZyBvdmVyCglmcmFtZV9kaWcgNCAvLyB0aGUgb2Zmc2V0IHdlIGFyZSBleHRyYWN0aW5nIHRoZSBuZXh0IGVsZW1lbnQgZnJvbQoJcHVzaGludCA4CglleHRyYWN0CglidG9pCglmcmFtZV9idXJ5IDMgLy8gdjogdWludDY0CgliICpmb3JFYWNoXzAKCipmb3JFYWNoXzBfZW5kOgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzNzkKCS8vIHJldHVybiBzdW07CglmcmFtZV9kaWcgMSAvLyBzdW06IHVpbnQ2NAoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoKCS8vIHBvcCBhbGwgbG9jYWwgdmFyaWFibGVzIGZyb20gdGhlIHN0YWNrCglwb3BuIDQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZTBlNjc4MjcgLy8gbWV0aG9kICJmb3JFYWNoUmV0dXJuKCl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2ZvckVhY2hSZXR1cm4KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestForEachReturn.arc56_draft.json b/tests/contracts/artifacts/ABITestForEachReturn.arc56_draft.json index 04b5e0ef9..a6a1ebdca 100644 --- a/tests/contracts/artifacts/ABITestForEachReturn.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestForEachReturn.arc56_draft.json @@ -687,7 +687,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBmb3JFYWNoUmV0dXJuKCl1aW50NjQKKmFiaV9yb3V0ZV9mb3JFYWNoUmV0dXJuOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgZm9yRWFjaFJldHVybigpdWludDY0CgljYWxsc3ViIGZvckVhY2hSZXR1cm4KCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gZm9yRWFjaFJldHVybigpOiB1aW50NjQKZm9yRWFjaFJldHVybjoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXBuIDQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTM3MgoJLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPiA9IFsxLCAyLCAzXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMTAwMDAwMDAwMDAwMDAwMDIwMDAwMDAwMDAwMDAwMDAzCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMzczCgkvLyBzdW0gPSAwCglwdXNoaW50IDAKCWZyYW1lX2J1cnkgMSAvLyBzdW06IHVpbnQ2NAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMzc1CgkvLyBhLmZvckVhY2gKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCWR1cAoJZnJhbWVfYnVyeSAyIC8vIGNvcHkgb2YgdGhlIGFycmF5IHdlIGFyZSBpdGVyYXRpbmcgb3ZlcgoJZXh0cmFjdCAwIDgKCWJ0b2kKCWZyYW1lX2J1cnkgMyAvLyB2OiB1aW50NjQKCXB1c2hpbnQgMAoJZnJhbWVfYnVyeSA0IC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCgoqZm9yRWFjaF8wOgoJLy8gKmlmMF9jb25kaXRpb24KCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMzc2CgkvLyBzdW0gPiAyCglmcmFtZV9kaWcgMSAvLyBzdW06IHVpbnQ2NAoJcHVzaGludCAyCgk+CglieiAqaWYwX2VuZAoKCS8vICppZjBfY29uc2VxdWVudAoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzNzYKCS8vIHJldHVybjsKCWIgKmZvckVhY2hfMF9lbmQKCippZjBfZW5kOgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzNzcKCS8vIHN1bSArPSB2CglmcmFtZV9kaWcgMSAvLyBzdW06IHVpbnQ2NAoJZnJhbWVfZGlnIDMgLy8gdjogdWludDY0CgkrCglmcmFtZV9idXJ5IDEgLy8gc3VtOiB1aW50NjQKCgkvLyBpbmNyZW1lbnQgb2Zmc2V0IGFuZCBsb29wIGlmIG5vdCBvdXQgb2YgYm91bmRzCglmcmFtZV9kaWcgNCAvLyB0aGUgb2Zmc2V0IHdlIGFyZSBleHRyYWN0aW5nIHRoZSBuZXh0IGVsZW1lbnQgZnJvbQoJcHVzaGludCA4CgkrCglkdXAKCXB1c2hpbnQgMjQgLy8gb2Zmc2V0IG9mIGxhc3QgZWxlbWVudAoJPAoJYnogKmZvckVhY2hfMF9lbmQKCWZyYW1lX2J1cnkgNCAvLyB0aGUgb2Zmc2V0IHdlIGFyZSBleHRyYWN0aW5nIHRoZSBuZXh0IGVsZW1lbnQgZnJvbQoJZnJhbWVfZGlnIDIgLy8gY29weSBvZiB0aGUgYXJyYXkgd2UgYXJlIGl0ZXJhdGluZyBvdmVyCglmcmFtZV9kaWcgNCAvLyB0aGUgb2Zmc2V0IHdlIGFyZSBleHRyYWN0aW5nIHRoZSBuZXh0IGVsZW1lbnQgZnJvbQoJcHVzaGludCA4CglleHRyYWN0CglidG9pCglmcmFtZV9idXJ5IDMgLy8gdjogdWludDY0CgliICpmb3JFYWNoXzAKCipmb3JFYWNoXzBfZW5kOgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzNzkKCS8vIHJldHVybiBzdW07CglmcmFtZV9kaWcgMSAvLyBzdW06IHVpbnQ2NAoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoKCS8vIHBvcCBhbGwgbG9jYWwgdmFyaWFibGVzIGZyb20gdGhlIHN0YWNrCglwb3BuIDQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZTBlNjc4MjcgLy8gbWV0aG9kICJmb3JFYWNoUmV0dXJuKCl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2ZvckVhY2hSZXR1cm4KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBmb3JFYWNoUmV0dXJuKCl1aW50NjQKKmFiaV9yb3V0ZV9mb3JFYWNoUmV0dXJuOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgZm9yRWFjaFJldHVybigpdWludDY0CgljYWxsc3ViIGZvckVhY2hSZXR1cm4KCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gZm9yRWFjaFJldHVybigpOiB1aW50NjQKZm9yRWFjaFJldHVybjoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXBuIDQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTM3MgoJLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPiA9IFsxLCAyLCAzXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMTAwMDAwMDAwMDAwMDAwMDIwMDAwMDAwMDAwMDAwMDAzCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMzczCgkvLyBzdW0gPSAwCglwdXNoaW50IDAKCWZyYW1lX2J1cnkgMSAvLyBzdW06IHVpbnQ2NAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMzc1CgkvLyBhLmZvckVhY2gKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCWR1cAoJZnJhbWVfYnVyeSAyIC8vIGNvcHkgb2YgdGhlIGFycmF5IHdlIGFyZSBpdGVyYXRpbmcgb3ZlcgoJZXh0cmFjdCAwIDgKCWJ0b2kKCWZyYW1lX2J1cnkgMyAvLyB2OiB1aW50NjQKCXB1c2hpbnQgMAoJZnJhbWVfYnVyeSA0IC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCgoqZm9yRWFjaF8wOgoJLy8gKmlmMF9jb25kaXRpb24KCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMzc2CgkvLyBzdW0gPiAyCglmcmFtZV9kaWcgMSAvLyBzdW06IHVpbnQ2NAoJcHVzaGludCAyCgk+CglieiAqaWYwX2VuZAoKCS8vICppZjBfY29uc2VxdWVudAoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzNzYKCS8vIHJldHVybjsKCWIgKmZvckVhY2hfMF9lbmQKCippZjBfZW5kOgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzNzcKCS8vIHN1bSArPSB2CglmcmFtZV9kaWcgMSAvLyBzdW06IHVpbnQ2NAoJZnJhbWVfZGlnIDMgLy8gdjogdWludDY0CgkrCglmcmFtZV9idXJ5IDEgLy8gc3VtOiB1aW50NjQKCgkvLyBpbmNyZW1lbnQgb2Zmc2V0IGFuZCBsb29wIGlmIG5vdCBvdXQgb2YgYm91bmRzCglmcmFtZV9kaWcgNCAvLyB0aGUgb2Zmc2V0IHdlIGFyZSBleHRyYWN0aW5nIHRoZSBuZXh0IGVsZW1lbnQgZnJvbQoJcHVzaGludCA4CgkrCglkdXAKCXB1c2hpbnQgMjQgLy8gb2Zmc2V0IG9mIGxhc3QgZWxlbWVudAoJPAoJYnogKmZvckVhY2hfMF9lbmQKCWZyYW1lX2J1cnkgNCAvLyB0aGUgb2Zmc2V0IHdlIGFyZSBleHRyYWN0aW5nIHRoZSBuZXh0IGVsZW1lbnQgZnJvbQoJZnJhbWVfZGlnIDIgLy8gY29weSBvZiB0aGUgYXJyYXkgd2UgYXJlIGl0ZXJhdGluZyBvdmVyCglmcmFtZV9kaWcgNCAvLyB0aGUgb2Zmc2V0IHdlIGFyZSBleHRyYWN0aW5nIHRoZSBuZXh0IGVsZW1lbnQgZnJvbQoJcHVzaGludCA4CglleHRyYWN0CglidG9pCglmcmFtZV9idXJ5IDMgLy8gdjogdWludDY0CgliICpmb3JFYWNoXzAKCipmb3JFYWNoXzBfZW5kOgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzNzkKCS8vIHJldHVybiBzdW07CglmcmFtZV9kaWcgMSAvLyBzdW06IHVpbnQ2NAoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoKCS8vIHBvcCBhbGwgbG9jYWwgdmFyaWFibGVzIGZyb20gdGhlIHN0YWNrCglwb3BuIDQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZTBlNjc4MjcgLy8gbWV0aG9kICJmb3JFYWNoUmV0dXJuKCl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2ZvckVhY2hSZXR1cm4KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestForOfBreak.approval.teal b/tests/contracts/artifacts/ABITestForOfBreak.approval.teal index 260bdbc9f..ec692f96f 100644 --- a/tests/contracts/artifacts/ABITestForOfBreak.approval.teal +++ b/tests/contracts/artifacts/ABITestForOfBreak.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestForOfBreak.arc32.json b/tests/contracts/artifacts/ABITestForOfBreak.arc32.json index 2d1ab4e86..7c0b4862d 100644 --- a/tests/contracts/artifacts/ABITestForOfBreak.arc32.json +++ b/tests/contracts/artifacts/ABITestForOfBreak.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBmb3JPZkJyZWFrKCl1aW50NjQKKmFiaV9yb3V0ZV9mb3JPZkJyZWFrOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgZm9yT2ZCcmVhaygpdWludDY0CgljYWxsc3ViIGZvck9mQnJlYWsKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gZm9yT2ZCcmVhaygpOiB1aW50NjQKZm9yT2ZCcmVhazoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXBuIDQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTQ5OAoJLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPiA9IFsxLCAyLCAzXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMTAwMDAwMDAwMDAwMDAwMDIwMDAwMDAwMDAwMDAwMDAzCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNDk5CgkvLyBzdW0gPSAwCglwdXNoaW50IDAKCWZyYW1lX2J1cnkgMSAvLyBzdW06IHVpbnQ2NAoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoJZHVwCglmcmFtZV9idXJ5IDIgLy8gY29weSBvZiB0aGUgYXJyYXkgd2UgYXJlIGl0ZXJhdGluZyBvdmVyCglleHRyYWN0IDAgOAoJYnRvaQoJZnJhbWVfYnVyeSAzIC8vIHY6IHVpbnQ2NAoJcHVzaGludCAwCglmcmFtZV9idXJ5IDQgLy8gdGhlIG9mZnNldCB3ZSBhcmUgZXh0cmFjdGluZyB0aGUgbmV4dCBlbGVtZW50IGZyb20KCipmb3JPZl8wOgoJLy8gKmlmMF9jb25kaXRpb24KCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNTA0CgkvLyBzdW0gPiAyCglmcmFtZV9kaWcgMSAvLyBzdW06IHVpbnQ2NAoJcHVzaGludCAyCgk+CglieiAqaWYwX2VuZAoKCS8vICppZjBfY29uc2VxdWVudAoJYiAqZm9yT2ZfMF9lbmQKCippZjBfZW5kOgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE1MDUKCS8vIHN1bSArPSB2CglmcmFtZV9kaWcgMSAvLyBzdW06IHVpbnQ2NAoJZnJhbWVfZGlnIDMgLy8gdjogdWludDY0CgkrCglmcmFtZV9idXJ5IDEgLy8gc3VtOiB1aW50NjQKCipmb3JPZl8wX2NvbnRpbnVlOgoJLy8gaW5jcmVtZW50IG9mZnNldCBhbmQgbG9vcCBpZiBub3Qgb3V0IG9mIGJvdW5kcwoJZnJhbWVfZGlnIDQgLy8gdGhlIG9mZnNldCB3ZSBhcmUgZXh0cmFjdGluZyB0aGUgbmV4dCBlbGVtZW50IGZyb20KCXB1c2hpbnQgOAoJKwoJZHVwCglwdXNoaW50IDI0IC8vIG9mZnNldCBvZiBsYXN0IGVsZW1lbnQKCTwKCWJ6ICpmb3JPZl8wX2VuZAoJZnJhbWVfYnVyeSA0IC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglmcmFtZV9kaWcgMiAvLyBjb3B5IG9mIHRoZSBhcnJheSB3ZSBhcmUgaXRlcmF0aW5nIG92ZXIKCWZyYW1lX2RpZyA0IC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglwdXNoaW50IDgKCWV4dHJhY3QKCWJ0b2kKCWZyYW1lX2J1cnkgMyAvLyB2OiB1aW50NjQKCWIgKmZvck9mXzAKCipmb3JPZl8wX2VuZDoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNTA3CgkvLyByZXR1cm4gc3VtOwoJZnJhbWVfZGlnIDEgLy8gc3VtOiB1aW50NjQKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCgkvLyBwb3AgYWxsIGxvY2FsIHZhcmlhYmxlcyBmcm9tIHRoZSBzdGFjawoJcG9wbiA0CglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGM5YzYwZGZkIC8vIG1ldGhvZCAiZm9yT2ZCcmVhaygpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9mb3JPZkJyZWFrCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBmb3JPZkJyZWFrKCl1aW50NjQKKmFiaV9yb3V0ZV9mb3JPZkJyZWFrOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgZm9yT2ZCcmVhaygpdWludDY0CgljYWxsc3ViIGZvck9mQnJlYWsKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gZm9yT2ZCcmVhaygpOiB1aW50NjQKZm9yT2ZCcmVhazoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXBuIDQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTQ5OAoJLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPiA9IFsxLCAyLCAzXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMTAwMDAwMDAwMDAwMDAwMDIwMDAwMDAwMDAwMDAwMDAzCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNDk5CgkvLyBzdW0gPSAwCglwdXNoaW50IDAKCWZyYW1lX2J1cnkgMSAvLyBzdW06IHVpbnQ2NAoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoJZHVwCglmcmFtZV9idXJ5IDIgLy8gY29weSBvZiB0aGUgYXJyYXkgd2UgYXJlIGl0ZXJhdGluZyBvdmVyCglleHRyYWN0IDAgOAoJYnRvaQoJZnJhbWVfYnVyeSAzIC8vIHY6IHVpbnQ2NAoJcHVzaGludCAwCglmcmFtZV9idXJ5IDQgLy8gdGhlIG9mZnNldCB3ZSBhcmUgZXh0cmFjdGluZyB0aGUgbmV4dCBlbGVtZW50IGZyb20KCipmb3JPZl8wOgoJLy8gKmlmMF9jb25kaXRpb24KCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNTA0CgkvLyBzdW0gPiAyCglmcmFtZV9kaWcgMSAvLyBzdW06IHVpbnQ2NAoJcHVzaGludCAyCgk+CglieiAqaWYwX2VuZAoKCS8vICppZjBfY29uc2VxdWVudAoJYiAqZm9yT2ZfMF9lbmQKCippZjBfZW5kOgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE1MDUKCS8vIHN1bSArPSB2CglmcmFtZV9kaWcgMSAvLyBzdW06IHVpbnQ2NAoJZnJhbWVfZGlnIDMgLy8gdjogdWludDY0CgkrCglmcmFtZV9idXJ5IDEgLy8gc3VtOiB1aW50NjQKCipmb3JPZl8wX2NvbnRpbnVlOgoJLy8gaW5jcmVtZW50IG9mZnNldCBhbmQgbG9vcCBpZiBub3Qgb3V0IG9mIGJvdW5kcwoJZnJhbWVfZGlnIDQgLy8gdGhlIG9mZnNldCB3ZSBhcmUgZXh0cmFjdGluZyB0aGUgbmV4dCBlbGVtZW50IGZyb20KCXB1c2hpbnQgOAoJKwoJZHVwCglwdXNoaW50IDI0IC8vIG9mZnNldCBvZiBsYXN0IGVsZW1lbnQKCTwKCWJ6ICpmb3JPZl8wX2VuZAoJZnJhbWVfYnVyeSA0IC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglmcmFtZV9kaWcgMiAvLyBjb3B5IG9mIHRoZSBhcnJheSB3ZSBhcmUgaXRlcmF0aW5nIG92ZXIKCWZyYW1lX2RpZyA0IC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglwdXNoaW50IDgKCWV4dHJhY3QKCWJ0b2kKCWZyYW1lX2J1cnkgMyAvLyB2OiB1aW50NjQKCWIgKmZvck9mXzAKCipmb3JPZl8wX2VuZDoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNTA3CgkvLyByZXR1cm4gc3VtOwoJZnJhbWVfZGlnIDEgLy8gc3VtOiB1aW50NjQKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCgkvLyBwb3AgYWxsIGxvY2FsIHZhcmlhYmxlcyBmcm9tIHRoZSBzdGFjawoJcG9wbiA0CglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGM5YzYwZGZkIC8vIG1ldGhvZCAiZm9yT2ZCcmVhaygpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9mb3JPZkJyZWFrCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestForOfBreak.arc56_draft.json b/tests/contracts/artifacts/ABITestForOfBreak.arc56_draft.json index 700a7f378..657c16a2c 100644 --- a/tests/contracts/artifacts/ABITestForOfBreak.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestForOfBreak.arc56_draft.json @@ -687,7 +687,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBmb3JPZkJyZWFrKCl1aW50NjQKKmFiaV9yb3V0ZV9mb3JPZkJyZWFrOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgZm9yT2ZCcmVhaygpdWludDY0CgljYWxsc3ViIGZvck9mQnJlYWsKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gZm9yT2ZCcmVhaygpOiB1aW50NjQKZm9yT2ZCcmVhazoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXBuIDQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTQ5OAoJLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPiA9IFsxLCAyLCAzXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMTAwMDAwMDAwMDAwMDAwMDIwMDAwMDAwMDAwMDAwMDAzCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNDk5CgkvLyBzdW0gPSAwCglwdXNoaW50IDAKCWZyYW1lX2J1cnkgMSAvLyBzdW06IHVpbnQ2NAoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoJZHVwCglmcmFtZV9idXJ5IDIgLy8gY29weSBvZiB0aGUgYXJyYXkgd2UgYXJlIGl0ZXJhdGluZyBvdmVyCglleHRyYWN0IDAgOAoJYnRvaQoJZnJhbWVfYnVyeSAzIC8vIHY6IHVpbnQ2NAoJcHVzaGludCAwCglmcmFtZV9idXJ5IDQgLy8gdGhlIG9mZnNldCB3ZSBhcmUgZXh0cmFjdGluZyB0aGUgbmV4dCBlbGVtZW50IGZyb20KCipmb3JPZl8wOgoJLy8gKmlmMF9jb25kaXRpb24KCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNTA0CgkvLyBzdW0gPiAyCglmcmFtZV9kaWcgMSAvLyBzdW06IHVpbnQ2NAoJcHVzaGludCAyCgk+CglieiAqaWYwX2VuZAoKCS8vICppZjBfY29uc2VxdWVudAoJYiAqZm9yT2ZfMF9lbmQKCippZjBfZW5kOgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE1MDUKCS8vIHN1bSArPSB2CglmcmFtZV9kaWcgMSAvLyBzdW06IHVpbnQ2NAoJZnJhbWVfZGlnIDMgLy8gdjogdWludDY0CgkrCglmcmFtZV9idXJ5IDEgLy8gc3VtOiB1aW50NjQKCipmb3JPZl8wX2NvbnRpbnVlOgoJLy8gaW5jcmVtZW50IG9mZnNldCBhbmQgbG9vcCBpZiBub3Qgb3V0IG9mIGJvdW5kcwoJZnJhbWVfZGlnIDQgLy8gdGhlIG9mZnNldCB3ZSBhcmUgZXh0cmFjdGluZyB0aGUgbmV4dCBlbGVtZW50IGZyb20KCXB1c2hpbnQgOAoJKwoJZHVwCglwdXNoaW50IDI0IC8vIG9mZnNldCBvZiBsYXN0IGVsZW1lbnQKCTwKCWJ6ICpmb3JPZl8wX2VuZAoJZnJhbWVfYnVyeSA0IC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglmcmFtZV9kaWcgMiAvLyBjb3B5IG9mIHRoZSBhcnJheSB3ZSBhcmUgaXRlcmF0aW5nIG92ZXIKCWZyYW1lX2RpZyA0IC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglwdXNoaW50IDgKCWV4dHJhY3QKCWJ0b2kKCWZyYW1lX2J1cnkgMyAvLyB2OiB1aW50NjQKCWIgKmZvck9mXzAKCipmb3JPZl8wX2VuZDoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNTA3CgkvLyByZXR1cm4gc3VtOwoJZnJhbWVfZGlnIDEgLy8gc3VtOiB1aW50NjQKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCgkvLyBwb3AgYWxsIGxvY2FsIHZhcmlhYmxlcyBmcm9tIHRoZSBzdGFjawoJcG9wbiA0CglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGM5YzYwZGZkIC8vIG1ldGhvZCAiZm9yT2ZCcmVhaygpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9mb3JPZkJyZWFrCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBmb3JPZkJyZWFrKCl1aW50NjQKKmFiaV9yb3V0ZV9mb3JPZkJyZWFrOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgZm9yT2ZCcmVhaygpdWludDY0CgljYWxsc3ViIGZvck9mQnJlYWsKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gZm9yT2ZCcmVhaygpOiB1aW50NjQKZm9yT2ZCcmVhazoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXBuIDQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTQ5OAoJLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPiA9IFsxLCAyLCAzXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMTAwMDAwMDAwMDAwMDAwMDIwMDAwMDAwMDAwMDAwMDAzCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNDk5CgkvLyBzdW0gPSAwCglwdXNoaW50IDAKCWZyYW1lX2J1cnkgMSAvLyBzdW06IHVpbnQ2NAoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoJZHVwCglmcmFtZV9idXJ5IDIgLy8gY29weSBvZiB0aGUgYXJyYXkgd2UgYXJlIGl0ZXJhdGluZyBvdmVyCglleHRyYWN0IDAgOAoJYnRvaQoJZnJhbWVfYnVyeSAzIC8vIHY6IHVpbnQ2NAoJcHVzaGludCAwCglmcmFtZV9idXJ5IDQgLy8gdGhlIG9mZnNldCB3ZSBhcmUgZXh0cmFjdGluZyB0aGUgbmV4dCBlbGVtZW50IGZyb20KCipmb3JPZl8wOgoJLy8gKmlmMF9jb25kaXRpb24KCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNTA0CgkvLyBzdW0gPiAyCglmcmFtZV9kaWcgMSAvLyBzdW06IHVpbnQ2NAoJcHVzaGludCAyCgk+CglieiAqaWYwX2VuZAoKCS8vICppZjBfY29uc2VxdWVudAoJYiAqZm9yT2ZfMF9lbmQKCippZjBfZW5kOgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE1MDUKCS8vIHN1bSArPSB2CglmcmFtZV9kaWcgMSAvLyBzdW06IHVpbnQ2NAoJZnJhbWVfZGlnIDMgLy8gdjogdWludDY0CgkrCglmcmFtZV9idXJ5IDEgLy8gc3VtOiB1aW50NjQKCipmb3JPZl8wX2NvbnRpbnVlOgoJLy8gaW5jcmVtZW50IG9mZnNldCBhbmQgbG9vcCBpZiBub3Qgb3V0IG9mIGJvdW5kcwoJZnJhbWVfZGlnIDQgLy8gdGhlIG9mZnNldCB3ZSBhcmUgZXh0cmFjdGluZyB0aGUgbmV4dCBlbGVtZW50IGZyb20KCXB1c2hpbnQgOAoJKwoJZHVwCglwdXNoaW50IDI0IC8vIG9mZnNldCBvZiBsYXN0IGVsZW1lbnQKCTwKCWJ6ICpmb3JPZl8wX2VuZAoJZnJhbWVfYnVyeSA0IC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglmcmFtZV9kaWcgMiAvLyBjb3B5IG9mIHRoZSBhcnJheSB3ZSBhcmUgaXRlcmF0aW5nIG92ZXIKCWZyYW1lX2RpZyA0IC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglwdXNoaW50IDgKCWV4dHJhY3QKCWJ0b2kKCWZyYW1lX2J1cnkgMyAvLyB2OiB1aW50NjQKCWIgKmZvck9mXzAKCipmb3JPZl8wX2VuZDoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNTA3CgkvLyByZXR1cm4gc3VtOwoJZnJhbWVfZGlnIDEgLy8gc3VtOiB1aW50NjQKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCgkvLyBwb3AgYWxsIGxvY2FsIHZhcmlhYmxlcyBmcm9tIHRoZSBzdGFjawoJcG9wbiA0CglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGM5YzYwZGZkIC8vIG1ldGhvZCAiZm9yT2ZCcmVhaygpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9mb3JPZkJyZWFrCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestForOfContinue.approval.teal b/tests/contracts/artifacts/ABITestForOfContinue.approval.teal index 91cc38f29..bf82858a2 100644 --- a/tests/contracts/artifacts/ABITestForOfContinue.approval.teal +++ b/tests/contracts/artifacts/ABITestForOfContinue.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestForOfContinue.arc32.json b/tests/contracts/artifacts/ABITestForOfContinue.arc32.json index 6cf7e2149..edf249f77 100644 --- a/tests/contracts/artifacts/ABITestForOfContinue.arc32.json +++ b/tests/contracts/artifacts/ABITestForOfContinue.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBmb3JPZkNvbnRpbnVlKCl1aW50NjQKKmFiaV9yb3V0ZV9mb3JPZkNvbnRpbnVlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgZm9yT2ZDb250aW51ZSgpdWludDY0CgljYWxsc3ViIGZvck9mQ29udGludWUKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gZm9yT2ZDb250aW51ZSgpOiB1aW50NjQKZm9yT2ZDb250aW51ZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXBuIDQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTQ4MwoJLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPiA9IFsxLCAyLCAzXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMTAwMDAwMDAwMDAwMDAwMDIwMDAwMDAwMDAwMDAwMDAzCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNDg0CgkvLyBzdW0gPSAwCglwdXNoaW50IDAKCWZyYW1lX2J1cnkgMSAvLyBzdW06IHVpbnQ2NAoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoJZHVwCglmcmFtZV9idXJ5IDIgLy8gY29weSBvZiB0aGUgYXJyYXkgd2UgYXJlIGl0ZXJhdGluZyBvdmVyCglleHRyYWN0IDAgOAoJYnRvaQoJZnJhbWVfYnVyeSAzIC8vIHY6IHVpbnQ2NAoJcHVzaGludCAwCglmcmFtZV9idXJ5IDQgLy8gdGhlIG9mZnNldCB3ZSBhcmUgZXh0cmFjdGluZyB0aGUgbmV4dCBlbGVtZW50IGZyb20KCipmb3JPZl8wOgoJLy8gKmlmMF9jb25kaXRpb24KCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNDg5CgkvLyBzdW0gPiAyCglmcmFtZV9kaWcgMSAvLyBzdW06IHVpbnQ2NAoJcHVzaGludCAyCgk+CglieiAqaWYwX2VuZAoKCS8vICppZjBfY29uc2VxdWVudAoJYiAqZm9yT2ZfMF9jb250aW51ZQoKKmlmMF9lbmQ6CgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTQ5MAoJLy8gc3VtICs9IHYKCWZyYW1lX2RpZyAxIC8vIHN1bTogdWludDY0CglmcmFtZV9kaWcgMyAvLyB2OiB1aW50NjQKCSsKCWZyYW1lX2J1cnkgMSAvLyBzdW06IHVpbnQ2NAoKKmZvck9mXzBfY29udGludWU6CgkvLyBpbmNyZW1lbnQgb2Zmc2V0IGFuZCBsb29wIGlmIG5vdCBvdXQgb2YgYm91bmRzCglmcmFtZV9kaWcgNCAvLyB0aGUgb2Zmc2V0IHdlIGFyZSBleHRyYWN0aW5nIHRoZSBuZXh0IGVsZW1lbnQgZnJvbQoJcHVzaGludCA4CgkrCglkdXAKCXB1c2hpbnQgMjQgLy8gb2Zmc2V0IG9mIGxhc3QgZWxlbWVudAoJPAoJYnogKmZvck9mXzBfZW5kCglmcmFtZV9idXJ5IDQgLy8gdGhlIG9mZnNldCB3ZSBhcmUgZXh0cmFjdGluZyB0aGUgbmV4dCBlbGVtZW50IGZyb20KCWZyYW1lX2RpZyAyIC8vIGNvcHkgb2YgdGhlIGFycmF5IHdlIGFyZSBpdGVyYXRpbmcgb3ZlcgoJZnJhbWVfZGlnIDQgLy8gdGhlIG9mZnNldCB3ZSBhcmUgZXh0cmFjdGluZyB0aGUgbmV4dCBlbGVtZW50IGZyb20KCXB1c2hpbnQgOAoJZXh0cmFjdAoJYnRvaQoJZnJhbWVfYnVyeSAzIC8vIHY6IHVpbnQ2NAoJYiAqZm9yT2ZfMAoKKmZvck9mXzBfZW5kOgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0OTIKCS8vIHJldHVybiBzdW07CglmcmFtZV9kaWcgMSAvLyBzdW06IHVpbnQ2NAoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoKCS8vIHBvcCBhbGwgbG9jYWwgdmFyaWFibGVzIGZyb20gdGhlIHN0YWNrCglwb3BuIDQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4N2IxMjFlZTMgLy8gbWV0aG9kICJmb3JPZkNvbnRpbnVlKCl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2Zvck9mQ29udGludWUKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBmb3JPZkNvbnRpbnVlKCl1aW50NjQKKmFiaV9yb3V0ZV9mb3JPZkNvbnRpbnVlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgZm9yT2ZDb250aW51ZSgpdWludDY0CgljYWxsc3ViIGZvck9mQ29udGludWUKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gZm9yT2ZDb250aW51ZSgpOiB1aW50NjQKZm9yT2ZDb250aW51ZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXBuIDQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTQ4MwoJLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPiA9IFsxLCAyLCAzXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMTAwMDAwMDAwMDAwMDAwMDIwMDAwMDAwMDAwMDAwMDAzCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNDg0CgkvLyBzdW0gPSAwCglwdXNoaW50IDAKCWZyYW1lX2J1cnkgMSAvLyBzdW06IHVpbnQ2NAoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoJZHVwCglmcmFtZV9idXJ5IDIgLy8gY29weSBvZiB0aGUgYXJyYXkgd2UgYXJlIGl0ZXJhdGluZyBvdmVyCglleHRyYWN0IDAgOAoJYnRvaQoJZnJhbWVfYnVyeSAzIC8vIHY6IHVpbnQ2NAoJcHVzaGludCAwCglmcmFtZV9idXJ5IDQgLy8gdGhlIG9mZnNldCB3ZSBhcmUgZXh0cmFjdGluZyB0aGUgbmV4dCBlbGVtZW50IGZyb20KCipmb3JPZl8wOgoJLy8gKmlmMF9jb25kaXRpb24KCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNDg5CgkvLyBzdW0gPiAyCglmcmFtZV9kaWcgMSAvLyBzdW06IHVpbnQ2NAoJcHVzaGludCAyCgk+CglieiAqaWYwX2VuZAoKCS8vICppZjBfY29uc2VxdWVudAoJYiAqZm9yT2ZfMF9jb250aW51ZQoKKmlmMF9lbmQ6CgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTQ5MAoJLy8gc3VtICs9IHYKCWZyYW1lX2RpZyAxIC8vIHN1bTogdWludDY0CglmcmFtZV9kaWcgMyAvLyB2OiB1aW50NjQKCSsKCWZyYW1lX2J1cnkgMSAvLyBzdW06IHVpbnQ2NAoKKmZvck9mXzBfY29udGludWU6CgkvLyBpbmNyZW1lbnQgb2Zmc2V0IGFuZCBsb29wIGlmIG5vdCBvdXQgb2YgYm91bmRzCglmcmFtZV9kaWcgNCAvLyB0aGUgb2Zmc2V0IHdlIGFyZSBleHRyYWN0aW5nIHRoZSBuZXh0IGVsZW1lbnQgZnJvbQoJcHVzaGludCA4CgkrCglkdXAKCXB1c2hpbnQgMjQgLy8gb2Zmc2V0IG9mIGxhc3QgZWxlbWVudAoJPAoJYnogKmZvck9mXzBfZW5kCglmcmFtZV9idXJ5IDQgLy8gdGhlIG9mZnNldCB3ZSBhcmUgZXh0cmFjdGluZyB0aGUgbmV4dCBlbGVtZW50IGZyb20KCWZyYW1lX2RpZyAyIC8vIGNvcHkgb2YgdGhlIGFycmF5IHdlIGFyZSBpdGVyYXRpbmcgb3ZlcgoJZnJhbWVfZGlnIDQgLy8gdGhlIG9mZnNldCB3ZSBhcmUgZXh0cmFjdGluZyB0aGUgbmV4dCBlbGVtZW50IGZyb20KCXB1c2hpbnQgOAoJZXh0cmFjdAoJYnRvaQoJZnJhbWVfYnVyeSAzIC8vIHY6IHVpbnQ2NAoJYiAqZm9yT2ZfMAoKKmZvck9mXzBfZW5kOgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0OTIKCS8vIHJldHVybiBzdW07CglmcmFtZV9kaWcgMSAvLyBzdW06IHVpbnQ2NAoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoKCS8vIHBvcCBhbGwgbG9jYWwgdmFyaWFibGVzIGZyb20gdGhlIHN0YWNrCglwb3BuIDQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4N2IxMjFlZTMgLy8gbWV0aG9kICJmb3JPZkNvbnRpbnVlKCl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2Zvck9mQ29udGludWUKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestForOfContinue.arc56_draft.json b/tests/contracts/artifacts/ABITestForOfContinue.arc56_draft.json index e72b99db1..6c12c407d 100644 --- a/tests/contracts/artifacts/ABITestForOfContinue.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestForOfContinue.arc56_draft.json @@ -687,7 +687,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBmb3JPZkNvbnRpbnVlKCl1aW50NjQKKmFiaV9yb3V0ZV9mb3JPZkNvbnRpbnVlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgZm9yT2ZDb250aW51ZSgpdWludDY0CgljYWxsc3ViIGZvck9mQ29udGludWUKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gZm9yT2ZDb250aW51ZSgpOiB1aW50NjQKZm9yT2ZDb250aW51ZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXBuIDQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTQ4MwoJLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPiA9IFsxLCAyLCAzXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMTAwMDAwMDAwMDAwMDAwMDIwMDAwMDAwMDAwMDAwMDAzCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNDg0CgkvLyBzdW0gPSAwCglwdXNoaW50IDAKCWZyYW1lX2J1cnkgMSAvLyBzdW06IHVpbnQ2NAoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoJZHVwCglmcmFtZV9idXJ5IDIgLy8gY29weSBvZiB0aGUgYXJyYXkgd2UgYXJlIGl0ZXJhdGluZyBvdmVyCglleHRyYWN0IDAgOAoJYnRvaQoJZnJhbWVfYnVyeSAzIC8vIHY6IHVpbnQ2NAoJcHVzaGludCAwCglmcmFtZV9idXJ5IDQgLy8gdGhlIG9mZnNldCB3ZSBhcmUgZXh0cmFjdGluZyB0aGUgbmV4dCBlbGVtZW50IGZyb20KCipmb3JPZl8wOgoJLy8gKmlmMF9jb25kaXRpb24KCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNDg5CgkvLyBzdW0gPiAyCglmcmFtZV9kaWcgMSAvLyBzdW06IHVpbnQ2NAoJcHVzaGludCAyCgk+CglieiAqaWYwX2VuZAoKCS8vICppZjBfY29uc2VxdWVudAoJYiAqZm9yT2ZfMF9jb250aW51ZQoKKmlmMF9lbmQ6CgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTQ5MAoJLy8gc3VtICs9IHYKCWZyYW1lX2RpZyAxIC8vIHN1bTogdWludDY0CglmcmFtZV9kaWcgMyAvLyB2OiB1aW50NjQKCSsKCWZyYW1lX2J1cnkgMSAvLyBzdW06IHVpbnQ2NAoKKmZvck9mXzBfY29udGludWU6CgkvLyBpbmNyZW1lbnQgb2Zmc2V0IGFuZCBsb29wIGlmIG5vdCBvdXQgb2YgYm91bmRzCglmcmFtZV9kaWcgNCAvLyB0aGUgb2Zmc2V0IHdlIGFyZSBleHRyYWN0aW5nIHRoZSBuZXh0IGVsZW1lbnQgZnJvbQoJcHVzaGludCA4CgkrCglkdXAKCXB1c2hpbnQgMjQgLy8gb2Zmc2V0IG9mIGxhc3QgZWxlbWVudAoJPAoJYnogKmZvck9mXzBfZW5kCglmcmFtZV9idXJ5IDQgLy8gdGhlIG9mZnNldCB3ZSBhcmUgZXh0cmFjdGluZyB0aGUgbmV4dCBlbGVtZW50IGZyb20KCWZyYW1lX2RpZyAyIC8vIGNvcHkgb2YgdGhlIGFycmF5IHdlIGFyZSBpdGVyYXRpbmcgb3ZlcgoJZnJhbWVfZGlnIDQgLy8gdGhlIG9mZnNldCB3ZSBhcmUgZXh0cmFjdGluZyB0aGUgbmV4dCBlbGVtZW50IGZyb20KCXB1c2hpbnQgOAoJZXh0cmFjdAoJYnRvaQoJZnJhbWVfYnVyeSAzIC8vIHY6IHVpbnQ2NAoJYiAqZm9yT2ZfMAoKKmZvck9mXzBfZW5kOgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0OTIKCS8vIHJldHVybiBzdW07CglmcmFtZV9kaWcgMSAvLyBzdW06IHVpbnQ2NAoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoKCS8vIHBvcCBhbGwgbG9jYWwgdmFyaWFibGVzIGZyb20gdGhlIHN0YWNrCglwb3BuIDQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4N2IxMjFlZTMgLy8gbWV0aG9kICJmb3JPZkNvbnRpbnVlKCl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2Zvck9mQ29udGludWUKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBmb3JPZkNvbnRpbnVlKCl1aW50NjQKKmFiaV9yb3V0ZV9mb3JPZkNvbnRpbnVlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgZm9yT2ZDb250aW51ZSgpdWludDY0CgljYWxsc3ViIGZvck9mQ29udGludWUKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gZm9yT2ZDb250aW51ZSgpOiB1aW50NjQKZm9yT2ZDb250aW51ZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXBuIDQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTQ4MwoJLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPiA9IFsxLCAyLCAzXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMTAwMDAwMDAwMDAwMDAwMDIwMDAwMDAwMDAwMDAwMDAzCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNDg0CgkvLyBzdW0gPSAwCglwdXNoaW50IDAKCWZyYW1lX2J1cnkgMSAvLyBzdW06IHVpbnQ2NAoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoJZHVwCglmcmFtZV9idXJ5IDIgLy8gY29weSBvZiB0aGUgYXJyYXkgd2UgYXJlIGl0ZXJhdGluZyBvdmVyCglleHRyYWN0IDAgOAoJYnRvaQoJZnJhbWVfYnVyeSAzIC8vIHY6IHVpbnQ2NAoJcHVzaGludCAwCglmcmFtZV9idXJ5IDQgLy8gdGhlIG9mZnNldCB3ZSBhcmUgZXh0cmFjdGluZyB0aGUgbmV4dCBlbGVtZW50IGZyb20KCipmb3JPZl8wOgoJLy8gKmlmMF9jb25kaXRpb24KCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNDg5CgkvLyBzdW0gPiAyCglmcmFtZV9kaWcgMSAvLyBzdW06IHVpbnQ2NAoJcHVzaGludCAyCgk+CglieiAqaWYwX2VuZAoKCS8vICppZjBfY29uc2VxdWVudAoJYiAqZm9yT2ZfMF9jb250aW51ZQoKKmlmMF9lbmQ6CgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTQ5MAoJLy8gc3VtICs9IHYKCWZyYW1lX2RpZyAxIC8vIHN1bTogdWludDY0CglmcmFtZV9kaWcgMyAvLyB2OiB1aW50NjQKCSsKCWZyYW1lX2J1cnkgMSAvLyBzdW06IHVpbnQ2NAoKKmZvck9mXzBfY29udGludWU6CgkvLyBpbmNyZW1lbnQgb2Zmc2V0IGFuZCBsb29wIGlmIG5vdCBvdXQgb2YgYm91bmRzCglmcmFtZV9kaWcgNCAvLyB0aGUgb2Zmc2V0IHdlIGFyZSBleHRyYWN0aW5nIHRoZSBuZXh0IGVsZW1lbnQgZnJvbQoJcHVzaGludCA4CgkrCglkdXAKCXB1c2hpbnQgMjQgLy8gb2Zmc2V0IG9mIGxhc3QgZWxlbWVudAoJPAoJYnogKmZvck9mXzBfZW5kCglmcmFtZV9idXJ5IDQgLy8gdGhlIG9mZnNldCB3ZSBhcmUgZXh0cmFjdGluZyB0aGUgbmV4dCBlbGVtZW50IGZyb20KCWZyYW1lX2RpZyAyIC8vIGNvcHkgb2YgdGhlIGFycmF5IHdlIGFyZSBpdGVyYXRpbmcgb3ZlcgoJZnJhbWVfZGlnIDQgLy8gdGhlIG9mZnNldCB3ZSBhcmUgZXh0cmFjdGluZyB0aGUgbmV4dCBlbGVtZW50IGZyb20KCXB1c2hpbnQgOAoJZXh0cmFjdAoJYnRvaQoJZnJhbWVfYnVyeSAzIC8vIHY6IHVpbnQ2NAoJYiAqZm9yT2ZfMAoKKmZvck9mXzBfZW5kOgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0OTIKCS8vIHJldHVybiBzdW07CglmcmFtZV9kaWcgMSAvLyBzdW06IHVpbnQ2NAoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoKCS8vIHBvcCBhbGwgbG9jYWwgdmFyaWFibGVzIGZyb20gdGhlIHN0YWNrCglwb3BuIDQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4N2IxMjFlZTMgLy8gbWV0aG9kICJmb3JPZkNvbnRpbnVlKCl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2Zvck9mQ29udGludWUKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestGlobalMethodInChain.approval.teal b/tests/contracts/artifacts/ABITestGlobalMethodInChain.approval.teal index 278be18ae..8b73c407a 100644 --- a/tests/contracts/artifacts/ABITestGlobalMethodInChain.approval.teal +++ b/tests/contracts/artifacts/ABITestGlobalMethodInChain.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestGlobalMethodInChain.arc32.json b/tests/contracts/artifacts/ABITestGlobalMethodInChain.arc32.json index 26712cf55..9b690740e 100644 --- a/tests/contracts/artifacts/ABITestGlobalMethodInChain.arc32.json +++ b/tests/contracts/artifacts/ABITestGlobalMethodInChain.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZ2xvYmFsTWV0aG9kSW5DaGFpbigpdWludDgKKmFiaV9yb3V0ZV9nbG9iYWxNZXRob2RJbkNoYWluOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgZ2xvYmFsTWV0aG9kSW5DaGFpbigpdWludDgKCWNhbGxzdWIgZ2xvYmFsTWV0aG9kSW5DaGFpbgoJaXRvYgoJZHVwCgliaXRsZW4KCXB1c2hpbnQgOAoJPD0KCgkvLyBnbG9iYWxNZXRob2RJbkNoYWluIHJldHVybiB2YWx1ZSBvdmVyZmxvd2VkIDggYml0cwoJYXNzZXJ0CglleHRyYWN0IDcgMQoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBnbG9iYWxNZXRob2RJbkNoYWluKCk6IHVpbnQ8OD4KZ2xvYmFsTWV0aG9kSW5DaGFpbjoKCXByb3RvIDAgMQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMDYxCgkvLyByZXR1cm4gY2FzdEJ5dGVzPFQxPihoZXgoJzB4MDAnKSkuYmFyOwoJcHVzaGludCAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGFlZmJiYWNiIC8vIG1ldGhvZCAiZ2xvYmFsTWV0aG9kSW5DaGFpbigpdWludDgiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2dsb2JhbE1ldGhvZEluQ2hhaW4KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZ2xvYmFsTWV0aG9kSW5DaGFpbigpdWludDgKKmFiaV9yb3V0ZV9nbG9iYWxNZXRob2RJbkNoYWluOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgZ2xvYmFsTWV0aG9kSW5DaGFpbigpdWludDgKCWNhbGxzdWIgZ2xvYmFsTWV0aG9kSW5DaGFpbgoJaXRvYgoJZHVwCgliaXRsZW4KCXB1c2hpbnQgOAoJPD0KCgkvLyBnbG9iYWxNZXRob2RJbkNoYWluIHJldHVybiB2YWx1ZSBvdmVyZmxvd2VkIDggYml0cwoJYXNzZXJ0CglleHRyYWN0IDcgMQoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBnbG9iYWxNZXRob2RJbkNoYWluKCk6IHVpbnQ8OD4KZ2xvYmFsTWV0aG9kSW5DaGFpbjoKCXByb3RvIDAgMQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMDYxCgkvLyByZXR1cm4gY2FzdEJ5dGVzPFQxPihoZXgoJzB4MDAnKSkuYmFyOwoJcHVzaGludCAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGFlZmJiYWNiIC8vIG1ldGhvZCAiZ2xvYmFsTWV0aG9kSW5DaGFpbigpdWludDgiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2dsb2JhbE1ldGhvZEluQ2hhaW4KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestGlobalMethodInChain.arc56_draft.json b/tests/contracts/artifacts/ABITestGlobalMethodInChain.arc56_draft.json index df4e8329b..2253f0313 100644 --- a/tests/contracts/artifacts/ABITestGlobalMethodInChain.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestGlobalMethodInChain.arc56_draft.json @@ -384,7 +384,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZ2xvYmFsTWV0aG9kSW5DaGFpbigpdWludDgKKmFiaV9yb3V0ZV9nbG9iYWxNZXRob2RJbkNoYWluOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgZ2xvYmFsTWV0aG9kSW5DaGFpbigpdWludDgKCWNhbGxzdWIgZ2xvYmFsTWV0aG9kSW5DaGFpbgoJaXRvYgoJZHVwCgliaXRsZW4KCXB1c2hpbnQgOAoJPD0KCgkvLyBnbG9iYWxNZXRob2RJbkNoYWluIHJldHVybiB2YWx1ZSBvdmVyZmxvd2VkIDggYml0cwoJYXNzZXJ0CglleHRyYWN0IDcgMQoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBnbG9iYWxNZXRob2RJbkNoYWluKCk6IHVpbnQ8OD4KZ2xvYmFsTWV0aG9kSW5DaGFpbjoKCXByb3RvIDAgMQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMDYxCgkvLyByZXR1cm4gY2FzdEJ5dGVzPFQxPihoZXgoJzB4MDAnKSkuYmFyOwoJcHVzaGludCAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGFlZmJiYWNiIC8vIG1ldGhvZCAiZ2xvYmFsTWV0aG9kSW5DaGFpbigpdWludDgiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2dsb2JhbE1ldGhvZEluQ2hhaW4KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZ2xvYmFsTWV0aG9kSW5DaGFpbigpdWludDgKKmFiaV9yb3V0ZV9nbG9iYWxNZXRob2RJbkNoYWluOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgZ2xvYmFsTWV0aG9kSW5DaGFpbigpdWludDgKCWNhbGxzdWIgZ2xvYmFsTWV0aG9kSW5DaGFpbgoJaXRvYgoJZHVwCgliaXRsZW4KCXB1c2hpbnQgOAoJPD0KCgkvLyBnbG9iYWxNZXRob2RJbkNoYWluIHJldHVybiB2YWx1ZSBvdmVyZmxvd2VkIDggYml0cwoJYXNzZXJ0CglleHRyYWN0IDcgMQoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBnbG9iYWxNZXRob2RJbkNoYWluKCk6IHVpbnQ8OD4KZ2xvYmFsTWV0aG9kSW5DaGFpbjoKCXByb3RvIDAgMQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMDYxCgkvLyByZXR1cm4gY2FzdEJ5dGVzPFQxPihoZXgoJzB4MDAnKSkuYmFyOwoJcHVzaGludCAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGFlZmJiYWNiIC8vIG1ldGhvZCAiZ2xvYmFsTWV0aG9kSW5DaGFpbigpdWludDgiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2dsb2JhbE1ldGhvZEluQ2hhaW4KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestLargeNestedStaticForEachInBox.approval.teal b/tests/contracts/artifacts/ABITestLargeNestedStaticForEachInBox.approval.teal index 90ed27375..59268147c 100644 --- a/tests/contracts/artifacts/ABITestLargeNestedStaticForEachInBox.approval.teal +++ b/tests/contracts/artifacts/ABITestLargeNestedStaticForEachInBox.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x624b6579 0x0a8101 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestLargeNestedStaticForEachInBox.arc32.json b/tests/contracts/artifacts/ABITestLargeNestedStaticForEachInBox.arc32.json index 1c93c41f4..1aa99be37 100644 --- a/tests/contracts/artifacts/ABITestLargeNestedStaticForEachInBox.arc32.json +++ b/tests/contracts/artifacts/ABITestLargeNestedStaticForEachInBox.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2MjRiNjU3OSAweDBhODEwMSAweAoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDQuMQovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIGxhcmdlTmVzdGVkU3RhdGljRm9yRWFjaEluQm94KCl1aW50NjQKKmFiaV9yb3V0ZV9sYXJnZU5lc3RlZFN0YXRpY0ZvckVhY2hJbkJveDoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGxhcmdlTmVzdGVkU3RhdGljRm9yRWFjaEluQm94KCl1aW50NjQKCWNhbGxzdWIgbGFyZ2VOZXN0ZWRTdGF0aWNGb3JFYWNoSW5Cb3gKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gbGFyZ2VOZXN0ZWRTdGF0aWNGb3JFYWNoSW5Cb3goKTogdWludDY0CmxhcmdlTmVzdGVkU3RhdGljRm9yRWFjaEluQm94OgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCWJ5dGUgMHgKCWR1cG4gNAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMzU4CgkvLyBpbmNyZWFzZU9wY29kZUJ1ZGdldCgpCglpdHhuX2JlZ2luCglwdXNoaW50IDYgLy8gYXBwbAoJaXR4bl9maWVsZCBUeXBlRW51bQoJcHVzaGludCAwCglpdHhuX2ZpZWxkIEZlZQoJYnl0ZSAweDBhODEwMSAvLyAjcHJhZ21hIHZlcnNpb24gMTA7IGludCAxCglkdXAKCWl0eG5fZmllbGQgQXBwcm92YWxQcm9ncmFtCglpdHhuX2ZpZWxkIENsZWFyU3RhdGVQcm9ncmFtCglwdXNoaW50IDUgLy8gRGVsZXRlQXBwbGljYXRpb24KCWl0eG5fZmllbGQgT25Db21wbGV0aW9uCglpdHhuX3N1Ym1pdAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMzU5CgkvLyB0aGlzLmJLZXkuY3JlYXRlKCkKCWJ5dGUgMHg2MjRiNjU3OSAvLyAiYktleSIKCXB1c2hpbnQgNDE5MgoJYm94X2NyZWF0ZQoJcG9wCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzNjAKCS8vIHN1bSA9IDAKCXB1c2hpbnQgMAoJZnJhbWVfYnVyeSAwIC8vIHN1bTogdWludDY0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzNjIKCS8vIHRoaXMuYktleS52YWx1ZVsxXS5mb3JFYWNoCglwdXNoaW50IDMyIC8vIGhlYWRPZmZzZXQKCXB1c2hpbnQgNDE2MAoJYnl0ZSAweDYyNGI2NTc5IC8vICJiS2V5IgoJZnJhbWVfYnVyeSAxIC8vIGtleSBmb3IgdGhlIGJveCB0aGF0IGNvbnRhaW5zIHRoZSBhcnJheSB3ZSBhcmUgaXRlcmF0aW5nIG92ZXIKCXN3YXAKCWR1cAoJZnJhbWVfYnVyeSAyIC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCgkrCglmcmFtZV9idXJ5IDMgLy8gdGhlIG9mZnNldCBvZiB0aGUgbGFzdCBlbGVtZW50CglieXRlIDB4NjI0YjY1NzkgLy8gImJLZXkiIC8vIGtleSBmb3IgdGhlIGJveCB0aGF0IGNvbnRhaW5zIHRoZSBhcnJheSB3ZSBhcmUgaXRlcmF0aW5nIG92ZXIKCWZyYW1lX2RpZyAyIC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglwdXNoaW50IDY0Cglib3hfZXh0cmFjdAoJZnJhbWVfYnVyeSA0IC8vIHY6IHVpbnQ1MTIKCipmb3JFYWNoXzA6CgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTM2MwoJLy8gc3VtICs9IDEKCWZyYW1lX2RpZyAwIC8vIHN1bTogdWludDY0CglwdXNoaW50IDEKCSsKCWZyYW1lX2J1cnkgMCAvLyBzdW06IHVpbnQ2NAoKCS8vIGluY3JlbWVudCBvZmZzZXQgYW5kIGxvb3AgaWYgbm90IG91dCBvZiBib3VuZHMKCWZyYW1lX2RpZyAyIC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglwdXNoaW50IDY0CgkrCglkdXAKCWZyYW1lX2RpZyAzIC8vIHRoZSBvZmZzZXQgb2YgdGhlIGxhc3QgZWxlbWVudAoJPAoJYnogKmZvckVhY2hfMF9lbmQKCWZyYW1lX2J1cnkgMiAvLyB0aGUgb2Zmc2V0IHdlIGFyZSBleHRyYWN0aW5nIHRoZSBuZXh0IGVsZW1lbnQgZnJvbQoJYnl0ZSAweDYyNGI2NTc5IC8vICJiS2V5IiAvLyBrZXkgZm9yIHRoZSBib3ggdGhhdCBjb250YWlucyB0aGUgYXJyYXkgd2UgYXJlIGl0ZXJhdGluZyBvdmVyCglmcmFtZV9kaWcgMiAvLyB0aGUgb2Zmc2V0IHdlIGFyZSBleHRyYWN0aW5nIHRoZSBuZXh0IGVsZW1lbnQgZnJvbQoJcHVzaGludCA2NAoJYm94X2V4dHJhY3QKCWZyYW1lX2J1cnkgNCAvLyB2OiB1aW50NTEyCgliICpmb3JFYWNoXzAKCipmb3JFYWNoXzBfZW5kOgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzNjYKCS8vIHJldHVybiBzdW07CglmcmFtZV9kaWcgMCAvLyBzdW06IHVpbnQ2NAoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoKCS8vIHBvcCBhbGwgbG9jYWwgdmFyaWFibGVzIGZyb20gdGhlIHN0YWNrCglwb3BuIDQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZDk0NTAyNjAgLy8gbWV0aG9kICJsYXJnZU5lc3RlZFN0YXRpY0ZvckVhY2hJbkJveCgpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9sYXJnZU5lc3RlZFN0YXRpY0ZvckVhY2hJbkJveAoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2MjRiNjU3OSAweDBhODEwMSAweAoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDUuMAovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIGxhcmdlTmVzdGVkU3RhdGljRm9yRWFjaEluQm94KCl1aW50NjQKKmFiaV9yb3V0ZV9sYXJnZU5lc3RlZFN0YXRpY0ZvckVhY2hJbkJveDoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGxhcmdlTmVzdGVkU3RhdGljRm9yRWFjaEluQm94KCl1aW50NjQKCWNhbGxzdWIgbGFyZ2VOZXN0ZWRTdGF0aWNGb3JFYWNoSW5Cb3gKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gbGFyZ2VOZXN0ZWRTdGF0aWNGb3JFYWNoSW5Cb3goKTogdWludDY0CmxhcmdlTmVzdGVkU3RhdGljRm9yRWFjaEluQm94OgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCWJ5dGUgMHgKCWR1cG4gNAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMzU4CgkvLyBpbmNyZWFzZU9wY29kZUJ1ZGdldCgpCglpdHhuX2JlZ2luCglwdXNoaW50IDYgLy8gYXBwbAoJaXR4bl9maWVsZCBUeXBlRW51bQoJcHVzaGludCAwCglpdHhuX2ZpZWxkIEZlZQoJYnl0ZSAweDBhODEwMSAvLyAjcHJhZ21hIHZlcnNpb24gMTA7IGludCAxCglkdXAKCWl0eG5fZmllbGQgQXBwcm92YWxQcm9ncmFtCglpdHhuX2ZpZWxkIENsZWFyU3RhdGVQcm9ncmFtCglwdXNoaW50IDUgLy8gRGVsZXRlQXBwbGljYXRpb24KCWl0eG5fZmllbGQgT25Db21wbGV0aW9uCglpdHhuX3N1Ym1pdAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMzU5CgkvLyB0aGlzLmJLZXkuY3JlYXRlKCkKCWJ5dGUgMHg2MjRiNjU3OSAvLyAiYktleSIKCXB1c2hpbnQgNDE5MgoJYm94X2NyZWF0ZQoJcG9wCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzNjAKCS8vIHN1bSA9IDAKCXB1c2hpbnQgMAoJZnJhbWVfYnVyeSAwIC8vIHN1bTogdWludDY0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzNjIKCS8vIHRoaXMuYktleS52YWx1ZVsxXS5mb3JFYWNoCglwdXNoaW50IDMyIC8vIGhlYWRPZmZzZXQKCXB1c2hpbnQgNDE2MAoJYnl0ZSAweDYyNGI2NTc5IC8vICJiS2V5IgoJZnJhbWVfYnVyeSAxIC8vIGtleSBmb3IgdGhlIGJveCB0aGF0IGNvbnRhaW5zIHRoZSBhcnJheSB3ZSBhcmUgaXRlcmF0aW5nIG92ZXIKCXN3YXAKCWR1cAoJZnJhbWVfYnVyeSAyIC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCgkrCglmcmFtZV9idXJ5IDMgLy8gdGhlIG9mZnNldCBvZiB0aGUgbGFzdCBlbGVtZW50CglieXRlIDB4NjI0YjY1NzkgLy8gImJLZXkiIC8vIGtleSBmb3IgdGhlIGJveCB0aGF0IGNvbnRhaW5zIHRoZSBhcnJheSB3ZSBhcmUgaXRlcmF0aW5nIG92ZXIKCWZyYW1lX2RpZyAyIC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglwdXNoaW50IDY0Cglib3hfZXh0cmFjdAoJZnJhbWVfYnVyeSA0IC8vIHY6IHVpbnQ1MTIKCipmb3JFYWNoXzA6CgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTM2MwoJLy8gc3VtICs9IDEKCWZyYW1lX2RpZyAwIC8vIHN1bTogdWludDY0CglwdXNoaW50IDEKCSsKCWZyYW1lX2J1cnkgMCAvLyBzdW06IHVpbnQ2NAoKCS8vIGluY3JlbWVudCBvZmZzZXQgYW5kIGxvb3AgaWYgbm90IG91dCBvZiBib3VuZHMKCWZyYW1lX2RpZyAyIC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglwdXNoaW50IDY0CgkrCglkdXAKCWZyYW1lX2RpZyAzIC8vIHRoZSBvZmZzZXQgb2YgdGhlIGxhc3QgZWxlbWVudAoJPAoJYnogKmZvckVhY2hfMF9lbmQKCWZyYW1lX2J1cnkgMiAvLyB0aGUgb2Zmc2V0IHdlIGFyZSBleHRyYWN0aW5nIHRoZSBuZXh0IGVsZW1lbnQgZnJvbQoJYnl0ZSAweDYyNGI2NTc5IC8vICJiS2V5IiAvLyBrZXkgZm9yIHRoZSBib3ggdGhhdCBjb250YWlucyB0aGUgYXJyYXkgd2UgYXJlIGl0ZXJhdGluZyBvdmVyCglmcmFtZV9kaWcgMiAvLyB0aGUgb2Zmc2V0IHdlIGFyZSBleHRyYWN0aW5nIHRoZSBuZXh0IGVsZW1lbnQgZnJvbQoJcHVzaGludCA2NAoJYm94X2V4dHJhY3QKCWZyYW1lX2J1cnkgNCAvLyB2OiB1aW50NTEyCgliICpmb3JFYWNoXzAKCipmb3JFYWNoXzBfZW5kOgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzNjYKCS8vIHJldHVybiBzdW07CglmcmFtZV9kaWcgMCAvLyBzdW06IHVpbnQ2NAoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoKCS8vIHBvcCBhbGwgbG9jYWwgdmFyaWFibGVzIGZyb20gdGhlIHN0YWNrCglwb3BuIDQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZDk0NTAyNjAgLy8gbWV0aG9kICJsYXJnZU5lc3RlZFN0YXRpY0ZvckVhY2hJbkJveCgpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9sYXJnZU5lc3RlZFN0YXRpY0ZvckVhY2hJbkJveAoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestLargeNestedStaticForEachInBox.arc56_draft.json b/tests/contracts/artifacts/ABITestLargeNestedStaticForEachInBox.arc56_draft.json index c716f8b09..9e3a3999d 100644 --- a/tests/contracts/artifacts/ABITestLargeNestedStaticForEachInBox.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestLargeNestedStaticForEachInBox.arc56_draft.json @@ -803,7 +803,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2MjRiNjU3OSAweDBhODEwMSAweAoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDQuMQovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIGxhcmdlTmVzdGVkU3RhdGljRm9yRWFjaEluQm94KCl1aW50NjQKKmFiaV9yb3V0ZV9sYXJnZU5lc3RlZFN0YXRpY0ZvckVhY2hJbkJveDoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGxhcmdlTmVzdGVkU3RhdGljRm9yRWFjaEluQm94KCl1aW50NjQKCWNhbGxzdWIgbGFyZ2VOZXN0ZWRTdGF0aWNGb3JFYWNoSW5Cb3gKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gbGFyZ2VOZXN0ZWRTdGF0aWNGb3JFYWNoSW5Cb3goKTogdWludDY0CmxhcmdlTmVzdGVkU3RhdGljRm9yRWFjaEluQm94OgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCWJ5dGUgMHgKCWR1cG4gNAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMzU4CgkvLyBpbmNyZWFzZU9wY29kZUJ1ZGdldCgpCglpdHhuX2JlZ2luCglwdXNoaW50IDYgLy8gYXBwbAoJaXR4bl9maWVsZCBUeXBlRW51bQoJcHVzaGludCAwCglpdHhuX2ZpZWxkIEZlZQoJYnl0ZSAweDBhODEwMSAvLyAjcHJhZ21hIHZlcnNpb24gMTA7IGludCAxCglkdXAKCWl0eG5fZmllbGQgQXBwcm92YWxQcm9ncmFtCglpdHhuX2ZpZWxkIENsZWFyU3RhdGVQcm9ncmFtCglwdXNoaW50IDUgLy8gRGVsZXRlQXBwbGljYXRpb24KCWl0eG5fZmllbGQgT25Db21wbGV0aW9uCglpdHhuX3N1Ym1pdAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMzU5CgkvLyB0aGlzLmJLZXkuY3JlYXRlKCkKCWJ5dGUgMHg2MjRiNjU3OSAvLyAiYktleSIKCXB1c2hpbnQgNDE5MgoJYm94X2NyZWF0ZQoJcG9wCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzNjAKCS8vIHN1bSA9IDAKCXB1c2hpbnQgMAoJZnJhbWVfYnVyeSAwIC8vIHN1bTogdWludDY0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzNjIKCS8vIHRoaXMuYktleS52YWx1ZVsxXS5mb3JFYWNoCglwdXNoaW50IDMyIC8vIGhlYWRPZmZzZXQKCXB1c2hpbnQgNDE2MAoJYnl0ZSAweDYyNGI2NTc5IC8vICJiS2V5IgoJZnJhbWVfYnVyeSAxIC8vIGtleSBmb3IgdGhlIGJveCB0aGF0IGNvbnRhaW5zIHRoZSBhcnJheSB3ZSBhcmUgaXRlcmF0aW5nIG92ZXIKCXN3YXAKCWR1cAoJZnJhbWVfYnVyeSAyIC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCgkrCglmcmFtZV9idXJ5IDMgLy8gdGhlIG9mZnNldCBvZiB0aGUgbGFzdCBlbGVtZW50CglieXRlIDB4NjI0YjY1NzkgLy8gImJLZXkiIC8vIGtleSBmb3IgdGhlIGJveCB0aGF0IGNvbnRhaW5zIHRoZSBhcnJheSB3ZSBhcmUgaXRlcmF0aW5nIG92ZXIKCWZyYW1lX2RpZyAyIC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglwdXNoaW50IDY0Cglib3hfZXh0cmFjdAoJZnJhbWVfYnVyeSA0IC8vIHY6IHVpbnQ1MTIKCipmb3JFYWNoXzA6CgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTM2MwoJLy8gc3VtICs9IDEKCWZyYW1lX2RpZyAwIC8vIHN1bTogdWludDY0CglwdXNoaW50IDEKCSsKCWZyYW1lX2J1cnkgMCAvLyBzdW06IHVpbnQ2NAoKCS8vIGluY3JlbWVudCBvZmZzZXQgYW5kIGxvb3AgaWYgbm90IG91dCBvZiBib3VuZHMKCWZyYW1lX2RpZyAyIC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglwdXNoaW50IDY0CgkrCglkdXAKCWZyYW1lX2RpZyAzIC8vIHRoZSBvZmZzZXQgb2YgdGhlIGxhc3QgZWxlbWVudAoJPAoJYnogKmZvckVhY2hfMF9lbmQKCWZyYW1lX2J1cnkgMiAvLyB0aGUgb2Zmc2V0IHdlIGFyZSBleHRyYWN0aW5nIHRoZSBuZXh0IGVsZW1lbnQgZnJvbQoJYnl0ZSAweDYyNGI2NTc5IC8vICJiS2V5IiAvLyBrZXkgZm9yIHRoZSBib3ggdGhhdCBjb250YWlucyB0aGUgYXJyYXkgd2UgYXJlIGl0ZXJhdGluZyBvdmVyCglmcmFtZV9kaWcgMiAvLyB0aGUgb2Zmc2V0IHdlIGFyZSBleHRyYWN0aW5nIHRoZSBuZXh0IGVsZW1lbnQgZnJvbQoJcHVzaGludCA2NAoJYm94X2V4dHJhY3QKCWZyYW1lX2J1cnkgNCAvLyB2OiB1aW50NTEyCgliICpmb3JFYWNoXzAKCipmb3JFYWNoXzBfZW5kOgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzNjYKCS8vIHJldHVybiBzdW07CglmcmFtZV9kaWcgMCAvLyBzdW06IHVpbnQ2NAoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoKCS8vIHBvcCBhbGwgbG9jYWwgdmFyaWFibGVzIGZyb20gdGhlIHN0YWNrCglwb3BuIDQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZDk0NTAyNjAgLy8gbWV0aG9kICJsYXJnZU5lc3RlZFN0YXRpY0ZvckVhY2hJbkJveCgpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9sYXJnZU5lc3RlZFN0YXRpY0ZvckVhY2hJbkJveAoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2MjRiNjU3OSAweDBhODEwMSAweAoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDUuMAovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIGxhcmdlTmVzdGVkU3RhdGljRm9yRWFjaEluQm94KCl1aW50NjQKKmFiaV9yb3V0ZV9sYXJnZU5lc3RlZFN0YXRpY0ZvckVhY2hJbkJveDoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIGxhcmdlTmVzdGVkU3RhdGljRm9yRWFjaEluQm94KCl1aW50NjQKCWNhbGxzdWIgbGFyZ2VOZXN0ZWRTdGF0aWNGb3JFYWNoSW5Cb3gKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gbGFyZ2VOZXN0ZWRTdGF0aWNGb3JFYWNoSW5Cb3goKTogdWludDY0CmxhcmdlTmVzdGVkU3RhdGljRm9yRWFjaEluQm94OgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCWJ5dGUgMHgKCWR1cG4gNAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMzU4CgkvLyBpbmNyZWFzZU9wY29kZUJ1ZGdldCgpCglpdHhuX2JlZ2luCglwdXNoaW50IDYgLy8gYXBwbAoJaXR4bl9maWVsZCBUeXBlRW51bQoJcHVzaGludCAwCglpdHhuX2ZpZWxkIEZlZQoJYnl0ZSAweDBhODEwMSAvLyAjcHJhZ21hIHZlcnNpb24gMTA7IGludCAxCglkdXAKCWl0eG5fZmllbGQgQXBwcm92YWxQcm9ncmFtCglpdHhuX2ZpZWxkIENsZWFyU3RhdGVQcm9ncmFtCglwdXNoaW50IDUgLy8gRGVsZXRlQXBwbGljYXRpb24KCWl0eG5fZmllbGQgT25Db21wbGV0aW9uCglpdHhuX3N1Ym1pdAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMzU5CgkvLyB0aGlzLmJLZXkuY3JlYXRlKCkKCWJ5dGUgMHg2MjRiNjU3OSAvLyAiYktleSIKCXB1c2hpbnQgNDE5MgoJYm94X2NyZWF0ZQoJcG9wCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzNjAKCS8vIHN1bSA9IDAKCXB1c2hpbnQgMAoJZnJhbWVfYnVyeSAwIC8vIHN1bTogdWludDY0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzNjIKCS8vIHRoaXMuYktleS52YWx1ZVsxXS5mb3JFYWNoCglwdXNoaW50IDMyIC8vIGhlYWRPZmZzZXQKCXB1c2hpbnQgNDE2MAoJYnl0ZSAweDYyNGI2NTc5IC8vICJiS2V5IgoJZnJhbWVfYnVyeSAxIC8vIGtleSBmb3IgdGhlIGJveCB0aGF0IGNvbnRhaW5zIHRoZSBhcnJheSB3ZSBhcmUgaXRlcmF0aW5nIG92ZXIKCXN3YXAKCWR1cAoJZnJhbWVfYnVyeSAyIC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCgkrCglmcmFtZV9idXJ5IDMgLy8gdGhlIG9mZnNldCBvZiB0aGUgbGFzdCBlbGVtZW50CglieXRlIDB4NjI0YjY1NzkgLy8gImJLZXkiIC8vIGtleSBmb3IgdGhlIGJveCB0aGF0IGNvbnRhaW5zIHRoZSBhcnJheSB3ZSBhcmUgaXRlcmF0aW5nIG92ZXIKCWZyYW1lX2RpZyAyIC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglwdXNoaW50IDY0Cglib3hfZXh0cmFjdAoJZnJhbWVfYnVyeSA0IC8vIHY6IHVpbnQ1MTIKCipmb3JFYWNoXzA6CgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTM2MwoJLy8gc3VtICs9IDEKCWZyYW1lX2RpZyAwIC8vIHN1bTogdWludDY0CglwdXNoaW50IDEKCSsKCWZyYW1lX2J1cnkgMCAvLyBzdW06IHVpbnQ2NAoKCS8vIGluY3JlbWVudCBvZmZzZXQgYW5kIGxvb3AgaWYgbm90IG91dCBvZiBib3VuZHMKCWZyYW1lX2RpZyAyIC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglwdXNoaW50IDY0CgkrCglkdXAKCWZyYW1lX2RpZyAzIC8vIHRoZSBvZmZzZXQgb2YgdGhlIGxhc3QgZWxlbWVudAoJPAoJYnogKmZvckVhY2hfMF9lbmQKCWZyYW1lX2J1cnkgMiAvLyB0aGUgb2Zmc2V0IHdlIGFyZSBleHRyYWN0aW5nIHRoZSBuZXh0IGVsZW1lbnQgZnJvbQoJYnl0ZSAweDYyNGI2NTc5IC8vICJiS2V5IiAvLyBrZXkgZm9yIHRoZSBib3ggdGhhdCBjb250YWlucyB0aGUgYXJyYXkgd2UgYXJlIGl0ZXJhdGluZyBvdmVyCglmcmFtZV9kaWcgMiAvLyB0aGUgb2Zmc2V0IHdlIGFyZSBleHRyYWN0aW5nIHRoZSBuZXh0IGVsZW1lbnQgZnJvbQoJcHVzaGludCA2NAoJYm94X2V4dHJhY3QKCWZyYW1lX2J1cnkgNCAvLyB2OiB1aW50NTEyCgliICpmb3JFYWNoXzAKCipmb3JFYWNoXzBfZW5kOgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzNjYKCS8vIHJldHVybiBzdW07CglmcmFtZV9kaWcgMCAvLyBzdW06IHVpbnQ2NAoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoKCS8vIHBvcCBhbGwgbG9jYWwgdmFyaWFibGVzIGZyb20gdGhlIHN0YWNrCglwb3BuIDQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZDk0NTAyNjAgLy8gbWV0aG9kICJsYXJnZU5lc3RlZFN0YXRpY0ZvckVhY2hJbkJveCgpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9sYXJnZU5lc3RlZFN0YXRpY0ZvckVhY2hJbkJveAoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestLargeNestedStaticForOfInBox.approval.teal b/tests/contracts/artifacts/ABITestLargeNestedStaticForOfInBox.approval.teal index a0dbb60e7..689b1fe1d 100644 --- a/tests/contracts/artifacts/ABITestLargeNestedStaticForOfInBox.approval.teal +++ b/tests/contracts/artifacts/ABITestLargeNestedStaticForOfInBox.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x624b6579 0x0a8101 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestLargeNestedStaticForOfInBox.arc32.json b/tests/contracts/artifacts/ABITestLargeNestedStaticForOfInBox.arc32.json index 7d5ff98db..c8887af31 100644 --- a/tests/contracts/artifacts/ABITestLargeNestedStaticForOfInBox.arc32.json +++ b/tests/contracts/artifacts/ABITestLargeNestedStaticForOfInBox.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2MjRiNjU3OSAweDBhODEwMSAweAoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDQuMQovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIGxhcmdlTmVzdGVkU3RhdGljRm9yT2ZJbkJveCgpdWludDY0CiphYmlfcm91dGVfbGFyZ2VOZXN0ZWRTdGF0aWNGb3JPZkluQm94OgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgbGFyZ2VOZXN0ZWRTdGF0aWNGb3JPZkluQm94KCl1aW50NjQKCWNhbGxzdWIgbGFyZ2VOZXN0ZWRTdGF0aWNGb3JPZkluQm94CglpdG9iCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGxhcmdlTmVzdGVkU3RhdGljRm9yT2ZJbkJveCgpOiB1aW50NjQKbGFyZ2VOZXN0ZWRTdGF0aWNGb3JPZkluQm94OgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCWJ5dGUgMHgKCWR1cG4gNAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNDY4CgkvLyBpbmNyZWFzZU9wY29kZUJ1ZGdldCgpCglpdHhuX2JlZ2luCglwdXNoaW50IDYgLy8gYXBwbAoJaXR4bl9maWVsZCBUeXBlRW51bQoJcHVzaGludCAwCglpdHhuX2ZpZWxkIEZlZQoJYnl0ZSAweDBhODEwMSAvLyAjcHJhZ21hIHZlcnNpb24gMTA7IGludCAxCglkdXAKCWl0eG5fZmllbGQgQXBwcm92YWxQcm9ncmFtCglpdHhuX2ZpZWxkIENsZWFyU3RhdGVQcm9ncmFtCglwdXNoaW50IDUgLy8gRGVsZXRlQXBwbGljYXRpb24KCWl0eG5fZmllbGQgT25Db21wbGV0aW9uCglpdHhuX3N1Ym1pdAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNDY5CgkvLyB0aGlzLmJLZXkuY3JlYXRlKCkKCWJ5dGUgMHg2MjRiNjU3OSAvLyAiYktleSIKCXB1c2hpbnQgNDE5MgoJYm94X2NyZWF0ZQoJcG9wCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0NzAKCS8vIHN1bSA9IDAKCXB1c2hpbnQgMAoJZnJhbWVfYnVyeSAwIC8vIHN1bTogdWludDY0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0NzMKCS8vIHRoaXMuYktleS52YWx1ZVsxXQoJcHVzaGludCAzMiAvLyBoZWFkT2Zmc2V0CglwdXNoaW50IDQxNjAKCWJ5dGUgMHg2MjRiNjU3OSAvLyAiYktleSIKCWZyYW1lX2J1cnkgMSAvLyBrZXkgZm9yIHRoZSBib3ggdGhhdCBjb250YWlucyB0aGUgYXJyYXkgd2UgYXJlIGl0ZXJhdGluZyBvdmVyCglzd2FwCglkdXAKCWZyYW1lX2J1cnkgMiAvLyB0aGUgb2Zmc2V0IHdlIGFyZSBleHRyYWN0aW5nIHRoZSBuZXh0IGVsZW1lbnQgZnJvbQoJKwoJZnJhbWVfYnVyeSAzIC8vIHRoZSBvZmZzZXQgb2YgdGhlIGxhc3QgZWxlbWVudAoJYnl0ZSAweDYyNGI2NTc5IC8vICJiS2V5IiAvLyBrZXkgZm9yIHRoZSBib3ggdGhhdCBjb250YWlucyB0aGUgYXJyYXkgd2UgYXJlIGl0ZXJhdGluZyBvdmVyCglmcmFtZV9kaWcgMiAvLyB0aGUgb2Zmc2V0IHdlIGFyZSBleHRyYWN0aW5nIHRoZSBuZXh0IGVsZW1lbnQgZnJvbQoJcHVzaGludCA2NAoJYm94X2V4dHJhY3QKCWZyYW1lX2J1cnkgNCAvLyB2OiB1aW50NTEyCgoqZm9yT2ZfMDoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNDc0CgkvLyBzdW0gKz0gMQoJZnJhbWVfZGlnIDAgLy8gc3VtOiB1aW50NjQKCXB1c2hpbnQgMQoJKwoJZnJhbWVfYnVyeSAwIC8vIHN1bTogdWludDY0CgoqZm9yT2ZfMF9jb250aW51ZToKCS8vIGluY3JlbWVudCBvZmZzZXQgYW5kIGxvb3AgaWYgbm90IG91dCBvZiBib3VuZHMKCWZyYW1lX2RpZyAyIC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglwdXNoaW50IDY0CgkrCglkdXAKCWZyYW1lX2RpZyAzIC8vIHRoZSBvZmZzZXQgb2YgdGhlIGxhc3QgZWxlbWVudAoJPAoJYnogKmZvck9mXzBfZW5kCglmcmFtZV9idXJ5IDIgLy8gdGhlIG9mZnNldCB3ZSBhcmUgZXh0cmFjdGluZyB0aGUgbmV4dCBlbGVtZW50IGZyb20KCWJ5dGUgMHg2MjRiNjU3OSAvLyAiYktleSIgLy8ga2V5IGZvciB0aGUgYm94IHRoYXQgY29udGFpbnMgdGhlIGFycmF5IHdlIGFyZSBpdGVyYXRpbmcgb3ZlcgoJZnJhbWVfZGlnIDIgLy8gdGhlIG9mZnNldCB3ZSBhcmUgZXh0cmFjdGluZyB0aGUgbmV4dCBlbGVtZW50IGZyb20KCXB1c2hpbnQgNjQKCWJveF9leHRyYWN0CglmcmFtZV9idXJ5IDQgLy8gdjogdWludDUxMgoJYiAqZm9yT2ZfMAoKKmZvck9mXzBfZW5kOgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0NzcKCS8vIHJldHVybiBzdW07CglmcmFtZV9kaWcgMCAvLyBzdW06IHVpbnQ2NAoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoKCS8vIHBvcCBhbGwgbG9jYWwgdmFyaWFibGVzIGZyb20gdGhlIHN0YWNrCglwb3BuIDQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MWY2YTczMzEgLy8gbWV0aG9kICJsYXJnZU5lc3RlZFN0YXRpY0Zvck9mSW5Cb3goKXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfbGFyZ2VOZXN0ZWRTdGF0aWNGb3JPZkluQm94CgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2MjRiNjU3OSAweDBhODEwMSAweAoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDUuMAovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIGxhcmdlTmVzdGVkU3RhdGljRm9yT2ZJbkJveCgpdWludDY0CiphYmlfcm91dGVfbGFyZ2VOZXN0ZWRTdGF0aWNGb3JPZkluQm94OgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgbGFyZ2VOZXN0ZWRTdGF0aWNGb3JPZkluQm94KCl1aW50NjQKCWNhbGxzdWIgbGFyZ2VOZXN0ZWRTdGF0aWNGb3JPZkluQm94CglpdG9iCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGxhcmdlTmVzdGVkU3RhdGljRm9yT2ZJbkJveCgpOiB1aW50NjQKbGFyZ2VOZXN0ZWRTdGF0aWNGb3JPZkluQm94OgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCWJ5dGUgMHgKCWR1cG4gNAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNDY4CgkvLyBpbmNyZWFzZU9wY29kZUJ1ZGdldCgpCglpdHhuX2JlZ2luCglwdXNoaW50IDYgLy8gYXBwbAoJaXR4bl9maWVsZCBUeXBlRW51bQoJcHVzaGludCAwCglpdHhuX2ZpZWxkIEZlZQoJYnl0ZSAweDBhODEwMSAvLyAjcHJhZ21hIHZlcnNpb24gMTA7IGludCAxCglkdXAKCWl0eG5fZmllbGQgQXBwcm92YWxQcm9ncmFtCglpdHhuX2ZpZWxkIENsZWFyU3RhdGVQcm9ncmFtCglwdXNoaW50IDUgLy8gRGVsZXRlQXBwbGljYXRpb24KCWl0eG5fZmllbGQgT25Db21wbGV0aW9uCglpdHhuX3N1Ym1pdAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNDY5CgkvLyB0aGlzLmJLZXkuY3JlYXRlKCkKCWJ5dGUgMHg2MjRiNjU3OSAvLyAiYktleSIKCXB1c2hpbnQgNDE5MgoJYm94X2NyZWF0ZQoJcG9wCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0NzAKCS8vIHN1bSA9IDAKCXB1c2hpbnQgMAoJZnJhbWVfYnVyeSAwIC8vIHN1bTogdWludDY0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0NzMKCS8vIHRoaXMuYktleS52YWx1ZVsxXQoJcHVzaGludCAzMiAvLyBoZWFkT2Zmc2V0CglwdXNoaW50IDQxNjAKCWJ5dGUgMHg2MjRiNjU3OSAvLyAiYktleSIKCWZyYW1lX2J1cnkgMSAvLyBrZXkgZm9yIHRoZSBib3ggdGhhdCBjb250YWlucyB0aGUgYXJyYXkgd2UgYXJlIGl0ZXJhdGluZyBvdmVyCglzd2FwCglkdXAKCWZyYW1lX2J1cnkgMiAvLyB0aGUgb2Zmc2V0IHdlIGFyZSBleHRyYWN0aW5nIHRoZSBuZXh0IGVsZW1lbnQgZnJvbQoJKwoJZnJhbWVfYnVyeSAzIC8vIHRoZSBvZmZzZXQgb2YgdGhlIGxhc3QgZWxlbWVudAoJYnl0ZSAweDYyNGI2NTc5IC8vICJiS2V5IiAvLyBrZXkgZm9yIHRoZSBib3ggdGhhdCBjb250YWlucyB0aGUgYXJyYXkgd2UgYXJlIGl0ZXJhdGluZyBvdmVyCglmcmFtZV9kaWcgMiAvLyB0aGUgb2Zmc2V0IHdlIGFyZSBleHRyYWN0aW5nIHRoZSBuZXh0IGVsZW1lbnQgZnJvbQoJcHVzaGludCA2NAoJYm94X2V4dHJhY3QKCWZyYW1lX2J1cnkgNCAvLyB2OiB1aW50NTEyCgoqZm9yT2ZfMDoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNDc0CgkvLyBzdW0gKz0gMQoJZnJhbWVfZGlnIDAgLy8gc3VtOiB1aW50NjQKCXB1c2hpbnQgMQoJKwoJZnJhbWVfYnVyeSAwIC8vIHN1bTogdWludDY0CgoqZm9yT2ZfMF9jb250aW51ZToKCS8vIGluY3JlbWVudCBvZmZzZXQgYW5kIGxvb3AgaWYgbm90IG91dCBvZiBib3VuZHMKCWZyYW1lX2RpZyAyIC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglwdXNoaW50IDY0CgkrCglkdXAKCWZyYW1lX2RpZyAzIC8vIHRoZSBvZmZzZXQgb2YgdGhlIGxhc3QgZWxlbWVudAoJPAoJYnogKmZvck9mXzBfZW5kCglmcmFtZV9idXJ5IDIgLy8gdGhlIG9mZnNldCB3ZSBhcmUgZXh0cmFjdGluZyB0aGUgbmV4dCBlbGVtZW50IGZyb20KCWJ5dGUgMHg2MjRiNjU3OSAvLyAiYktleSIgLy8ga2V5IGZvciB0aGUgYm94IHRoYXQgY29udGFpbnMgdGhlIGFycmF5IHdlIGFyZSBpdGVyYXRpbmcgb3ZlcgoJZnJhbWVfZGlnIDIgLy8gdGhlIG9mZnNldCB3ZSBhcmUgZXh0cmFjdGluZyB0aGUgbmV4dCBlbGVtZW50IGZyb20KCXB1c2hpbnQgNjQKCWJveF9leHRyYWN0CglmcmFtZV9idXJ5IDQgLy8gdjogdWludDUxMgoJYiAqZm9yT2ZfMAoKKmZvck9mXzBfZW5kOgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0NzcKCS8vIHJldHVybiBzdW07CglmcmFtZV9kaWcgMCAvLyBzdW06IHVpbnQ2NAoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoKCS8vIHBvcCBhbGwgbG9jYWwgdmFyaWFibGVzIGZyb20gdGhlIHN0YWNrCglwb3BuIDQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MWY2YTczMzEgLy8gbWV0aG9kICJsYXJnZU5lc3RlZFN0YXRpY0Zvck9mSW5Cb3goKXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfbGFyZ2VOZXN0ZWRTdGF0aWNGb3JPZkluQm94CgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestLargeNestedStaticForOfInBox.arc56_draft.json b/tests/contracts/artifacts/ABITestLargeNestedStaticForOfInBox.arc56_draft.json index 0f229f5a5..c355ff291 100644 --- a/tests/contracts/artifacts/ABITestLargeNestedStaticForOfInBox.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestLargeNestedStaticForOfInBox.arc56_draft.json @@ -803,7 +803,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2MjRiNjU3OSAweDBhODEwMSAweAoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDQuMQovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIGxhcmdlTmVzdGVkU3RhdGljRm9yT2ZJbkJveCgpdWludDY0CiphYmlfcm91dGVfbGFyZ2VOZXN0ZWRTdGF0aWNGb3JPZkluQm94OgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgbGFyZ2VOZXN0ZWRTdGF0aWNGb3JPZkluQm94KCl1aW50NjQKCWNhbGxzdWIgbGFyZ2VOZXN0ZWRTdGF0aWNGb3JPZkluQm94CglpdG9iCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGxhcmdlTmVzdGVkU3RhdGljRm9yT2ZJbkJveCgpOiB1aW50NjQKbGFyZ2VOZXN0ZWRTdGF0aWNGb3JPZkluQm94OgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCWJ5dGUgMHgKCWR1cG4gNAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNDY4CgkvLyBpbmNyZWFzZU9wY29kZUJ1ZGdldCgpCglpdHhuX2JlZ2luCglwdXNoaW50IDYgLy8gYXBwbAoJaXR4bl9maWVsZCBUeXBlRW51bQoJcHVzaGludCAwCglpdHhuX2ZpZWxkIEZlZQoJYnl0ZSAweDBhODEwMSAvLyAjcHJhZ21hIHZlcnNpb24gMTA7IGludCAxCglkdXAKCWl0eG5fZmllbGQgQXBwcm92YWxQcm9ncmFtCglpdHhuX2ZpZWxkIENsZWFyU3RhdGVQcm9ncmFtCglwdXNoaW50IDUgLy8gRGVsZXRlQXBwbGljYXRpb24KCWl0eG5fZmllbGQgT25Db21wbGV0aW9uCglpdHhuX3N1Ym1pdAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNDY5CgkvLyB0aGlzLmJLZXkuY3JlYXRlKCkKCWJ5dGUgMHg2MjRiNjU3OSAvLyAiYktleSIKCXB1c2hpbnQgNDE5MgoJYm94X2NyZWF0ZQoJcG9wCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0NzAKCS8vIHN1bSA9IDAKCXB1c2hpbnQgMAoJZnJhbWVfYnVyeSAwIC8vIHN1bTogdWludDY0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0NzMKCS8vIHRoaXMuYktleS52YWx1ZVsxXQoJcHVzaGludCAzMiAvLyBoZWFkT2Zmc2V0CglwdXNoaW50IDQxNjAKCWJ5dGUgMHg2MjRiNjU3OSAvLyAiYktleSIKCWZyYW1lX2J1cnkgMSAvLyBrZXkgZm9yIHRoZSBib3ggdGhhdCBjb250YWlucyB0aGUgYXJyYXkgd2UgYXJlIGl0ZXJhdGluZyBvdmVyCglzd2FwCglkdXAKCWZyYW1lX2J1cnkgMiAvLyB0aGUgb2Zmc2V0IHdlIGFyZSBleHRyYWN0aW5nIHRoZSBuZXh0IGVsZW1lbnQgZnJvbQoJKwoJZnJhbWVfYnVyeSAzIC8vIHRoZSBvZmZzZXQgb2YgdGhlIGxhc3QgZWxlbWVudAoJYnl0ZSAweDYyNGI2NTc5IC8vICJiS2V5IiAvLyBrZXkgZm9yIHRoZSBib3ggdGhhdCBjb250YWlucyB0aGUgYXJyYXkgd2UgYXJlIGl0ZXJhdGluZyBvdmVyCglmcmFtZV9kaWcgMiAvLyB0aGUgb2Zmc2V0IHdlIGFyZSBleHRyYWN0aW5nIHRoZSBuZXh0IGVsZW1lbnQgZnJvbQoJcHVzaGludCA2NAoJYm94X2V4dHJhY3QKCWZyYW1lX2J1cnkgNCAvLyB2OiB1aW50NTEyCgoqZm9yT2ZfMDoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNDc0CgkvLyBzdW0gKz0gMQoJZnJhbWVfZGlnIDAgLy8gc3VtOiB1aW50NjQKCXB1c2hpbnQgMQoJKwoJZnJhbWVfYnVyeSAwIC8vIHN1bTogdWludDY0CgoqZm9yT2ZfMF9jb250aW51ZToKCS8vIGluY3JlbWVudCBvZmZzZXQgYW5kIGxvb3AgaWYgbm90IG91dCBvZiBib3VuZHMKCWZyYW1lX2RpZyAyIC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglwdXNoaW50IDY0CgkrCglkdXAKCWZyYW1lX2RpZyAzIC8vIHRoZSBvZmZzZXQgb2YgdGhlIGxhc3QgZWxlbWVudAoJPAoJYnogKmZvck9mXzBfZW5kCglmcmFtZV9idXJ5IDIgLy8gdGhlIG9mZnNldCB3ZSBhcmUgZXh0cmFjdGluZyB0aGUgbmV4dCBlbGVtZW50IGZyb20KCWJ5dGUgMHg2MjRiNjU3OSAvLyAiYktleSIgLy8ga2V5IGZvciB0aGUgYm94IHRoYXQgY29udGFpbnMgdGhlIGFycmF5IHdlIGFyZSBpdGVyYXRpbmcgb3ZlcgoJZnJhbWVfZGlnIDIgLy8gdGhlIG9mZnNldCB3ZSBhcmUgZXh0cmFjdGluZyB0aGUgbmV4dCBlbGVtZW50IGZyb20KCXB1c2hpbnQgNjQKCWJveF9leHRyYWN0CglmcmFtZV9idXJ5IDQgLy8gdjogdWludDUxMgoJYiAqZm9yT2ZfMAoKKmZvck9mXzBfZW5kOgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0NzcKCS8vIHJldHVybiBzdW07CglmcmFtZV9kaWcgMCAvLyBzdW06IHVpbnQ2NAoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoKCS8vIHBvcCBhbGwgbG9jYWwgdmFyaWFibGVzIGZyb20gdGhlIHN0YWNrCglwb3BuIDQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MWY2YTczMzEgLy8gbWV0aG9kICJsYXJnZU5lc3RlZFN0YXRpY0Zvck9mSW5Cb3goKXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfbGFyZ2VOZXN0ZWRTdGF0aWNGb3JPZkluQm94CgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2MjRiNjU3OSAweDBhODEwMSAweAoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDUuMAovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIGxhcmdlTmVzdGVkU3RhdGljRm9yT2ZJbkJveCgpdWludDY0CiphYmlfcm91dGVfbGFyZ2VOZXN0ZWRTdGF0aWNGb3JPZkluQm94OgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgbGFyZ2VOZXN0ZWRTdGF0aWNGb3JPZkluQm94KCl1aW50NjQKCWNhbGxzdWIgbGFyZ2VOZXN0ZWRTdGF0aWNGb3JPZkluQm94CglpdG9iCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGxhcmdlTmVzdGVkU3RhdGljRm9yT2ZJbkJveCgpOiB1aW50NjQKbGFyZ2VOZXN0ZWRTdGF0aWNGb3JPZkluQm94OgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCWJ5dGUgMHgKCWR1cG4gNAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNDY4CgkvLyBpbmNyZWFzZU9wY29kZUJ1ZGdldCgpCglpdHhuX2JlZ2luCglwdXNoaW50IDYgLy8gYXBwbAoJaXR4bl9maWVsZCBUeXBlRW51bQoJcHVzaGludCAwCglpdHhuX2ZpZWxkIEZlZQoJYnl0ZSAweDBhODEwMSAvLyAjcHJhZ21hIHZlcnNpb24gMTA7IGludCAxCglkdXAKCWl0eG5fZmllbGQgQXBwcm92YWxQcm9ncmFtCglpdHhuX2ZpZWxkIENsZWFyU3RhdGVQcm9ncmFtCglwdXNoaW50IDUgLy8gRGVsZXRlQXBwbGljYXRpb24KCWl0eG5fZmllbGQgT25Db21wbGV0aW9uCglpdHhuX3N1Ym1pdAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNDY5CgkvLyB0aGlzLmJLZXkuY3JlYXRlKCkKCWJ5dGUgMHg2MjRiNjU3OSAvLyAiYktleSIKCXB1c2hpbnQgNDE5MgoJYm94X2NyZWF0ZQoJcG9wCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0NzAKCS8vIHN1bSA9IDAKCXB1c2hpbnQgMAoJZnJhbWVfYnVyeSAwIC8vIHN1bTogdWludDY0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0NzMKCS8vIHRoaXMuYktleS52YWx1ZVsxXQoJcHVzaGludCAzMiAvLyBoZWFkT2Zmc2V0CglwdXNoaW50IDQxNjAKCWJ5dGUgMHg2MjRiNjU3OSAvLyAiYktleSIKCWZyYW1lX2J1cnkgMSAvLyBrZXkgZm9yIHRoZSBib3ggdGhhdCBjb250YWlucyB0aGUgYXJyYXkgd2UgYXJlIGl0ZXJhdGluZyBvdmVyCglzd2FwCglkdXAKCWZyYW1lX2J1cnkgMiAvLyB0aGUgb2Zmc2V0IHdlIGFyZSBleHRyYWN0aW5nIHRoZSBuZXh0IGVsZW1lbnQgZnJvbQoJKwoJZnJhbWVfYnVyeSAzIC8vIHRoZSBvZmZzZXQgb2YgdGhlIGxhc3QgZWxlbWVudAoJYnl0ZSAweDYyNGI2NTc5IC8vICJiS2V5IiAvLyBrZXkgZm9yIHRoZSBib3ggdGhhdCBjb250YWlucyB0aGUgYXJyYXkgd2UgYXJlIGl0ZXJhdGluZyBvdmVyCglmcmFtZV9kaWcgMiAvLyB0aGUgb2Zmc2V0IHdlIGFyZSBleHRyYWN0aW5nIHRoZSBuZXh0IGVsZW1lbnQgZnJvbQoJcHVzaGludCA2NAoJYm94X2V4dHJhY3QKCWZyYW1lX2J1cnkgNCAvLyB2OiB1aW50NTEyCgoqZm9yT2ZfMDoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNDc0CgkvLyBzdW0gKz0gMQoJZnJhbWVfZGlnIDAgLy8gc3VtOiB1aW50NjQKCXB1c2hpbnQgMQoJKwoJZnJhbWVfYnVyeSAwIC8vIHN1bTogdWludDY0CgoqZm9yT2ZfMF9jb250aW51ZToKCS8vIGluY3JlbWVudCBvZmZzZXQgYW5kIGxvb3AgaWYgbm90IG91dCBvZiBib3VuZHMKCWZyYW1lX2RpZyAyIC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglwdXNoaW50IDY0CgkrCglkdXAKCWZyYW1lX2RpZyAzIC8vIHRoZSBvZmZzZXQgb2YgdGhlIGxhc3QgZWxlbWVudAoJPAoJYnogKmZvck9mXzBfZW5kCglmcmFtZV9idXJ5IDIgLy8gdGhlIG9mZnNldCB3ZSBhcmUgZXh0cmFjdGluZyB0aGUgbmV4dCBlbGVtZW50IGZyb20KCWJ5dGUgMHg2MjRiNjU3OSAvLyAiYktleSIgLy8ga2V5IGZvciB0aGUgYm94IHRoYXQgY29udGFpbnMgdGhlIGFycmF5IHdlIGFyZSBpdGVyYXRpbmcgb3ZlcgoJZnJhbWVfZGlnIDIgLy8gdGhlIG9mZnNldCB3ZSBhcmUgZXh0cmFjdGluZyB0aGUgbmV4dCBlbGVtZW50IGZyb20KCXB1c2hpbnQgNjQKCWJveF9leHRyYWN0CglmcmFtZV9idXJ5IDQgLy8gdjogdWludDUxMgoJYiAqZm9yT2ZfMAoKKmZvck9mXzBfZW5kOgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0NzcKCS8vIHJldHVybiBzdW07CglmcmFtZV9kaWcgMCAvLyBzdW06IHVpbnQ2NAoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoKCS8vIHBvcCBhbGwgbG9jYWwgdmFyaWFibGVzIGZyb20gdGhlIHN0YWNrCglwb3BuIDQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MWY2YTczMzEgLy8gbWV0aG9kICJsYXJnZU5lc3RlZFN0YXRpY0Zvck9mSW5Cb3goKXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfbGFyZ2VOZXN0ZWRTdGF0aWNGb3JPZkluQm94CgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestMaxUfixed.approval.teal b/tests/contracts/artifacts/ABITestMaxUfixed.approval.teal index 322d0e454..0370841d6 100644 --- a/tests/contracts/artifacts/ABITestMaxUfixed.approval.teal +++ b/tests/contracts/artifacts/ABITestMaxUfixed.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestMaxUfixed.arc32.json b/tests/contracts/artifacts/ABITestMaxUfixed.arc32.json index b08f8ef92..c0a8f84f5 100644 --- a/tests/contracts/artifacts/ABITestMaxUfixed.arc32.json +++ b/tests/contracts/artifacts/ABITestMaxUfixed.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gbWF4VWZpeGVkKCl1Zml4ZWQ2NHgyCiphYmlfcm91dGVfbWF4VWZpeGVkOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgbWF4VWZpeGVkKCl1Zml4ZWQ2NHgyCgljYWxsc3ViIG1heFVmaXhlZAoJaXRvYgoJZXh0cmFjdCAwIDgKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gbWF4VWZpeGVkKCk6IHVmaXhlZDw2NCwgMj4KbWF4VWZpeGVkOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMTQyCgkvLyB1NjRtYXg6IHVmaXhlZDw2NCwgMj4gPSAxMi4zNAoJcHVzaGludCAxMjM0CglmcmFtZV9idXJ5IDAgLy8gdTY0bWF4OiB1Zml4ZWQ8NjQsIDI+CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjExNDQKCS8vIHJldHVybiB1NjRtYXg7CglmcmFtZV9kaWcgMCAvLyB1NjRtYXg6IHVmaXhlZDw2NCwgMj4KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4NTRlZDNkMmUgLy8gbWV0aG9kICJtYXhVZml4ZWQoKXVmaXhlZDY0eDIiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX21heFVmaXhlZAoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gbWF4VWZpeGVkKCl1Zml4ZWQ2NHgyCiphYmlfcm91dGVfbWF4VWZpeGVkOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgbWF4VWZpeGVkKCl1Zml4ZWQ2NHgyCgljYWxsc3ViIG1heFVmaXhlZAoJaXRvYgoJZXh0cmFjdCAwIDgKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gbWF4VWZpeGVkKCk6IHVmaXhlZDw2NCwgMj4KbWF4VWZpeGVkOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMTQyCgkvLyB1NjRtYXg6IHVmaXhlZDw2NCwgMj4gPSAxMi4zNAoJcHVzaGludCAxMjM0CglmcmFtZV9idXJ5IDAgLy8gdTY0bWF4OiB1Zml4ZWQ8NjQsIDI+CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjExNDQKCS8vIHJldHVybiB1NjRtYXg7CglmcmFtZV9kaWcgMCAvLyB1NjRtYXg6IHVmaXhlZDw2NCwgMj4KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4NTRlZDNkMmUgLy8gbWV0aG9kICJtYXhVZml4ZWQoKXVmaXhlZDY0eDIiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX21heFVmaXhlZAoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestMaxUfixed.arc56_draft.json b/tests/contracts/artifacts/ABITestMaxUfixed.arc56_draft.json index 251771b78..a9ead0058 100644 --- a/tests/contracts/artifacts/ABITestMaxUfixed.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestMaxUfixed.arc56_draft.json @@ -380,7 +380,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gbWF4VWZpeGVkKCl1Zml4ZWQ2NHgyCiphYmlfcm91dGVfbWF4VWZpeGVkOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgbWF4VWZpeGVkKCl1Zml4ZWQ2NHgyCgljYWxsc3ViIG1heFVmaXhlZAoJaXRvYgoJZXh0cmFjdCAwIDgKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gbWF4VWZpeGVkKCk6IHVmaXhlZDw2NCwgMj4KbWF4VWZpeGVkOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMTQyCgkvLyB1NjRtYXg6IHVmaXhlZDw2NCwgMj4gPSAxMi4zNAoJcHVzaGludCAxMjM0CglmcmFtZV9idXJ5IDAgLy8gdTY0bWF4OiB1Zml4ZWQ8NjQsIDI+CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjExNDQKCS8vIHJldHVybiB1NjRtYXg7CglmcmFtZV9kaWcgMCAvLyB1NjRtYXg6IHVmaXhlZDw2NCwgMj4KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4NTRlZDNkMmUgLy8gbWV0aG9kICJtYXhVZml4ZWQoKXVmaXhlZDY0eDIiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX21heFVmaXhlZAoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gbWF4VWZpeGVkKCl1Zml4ZWQ2NHgyCiphYmlfcm91dGVfbWF4VWZpeGVkOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgbWF4VWZpeGVkKCl1Zml4ZWQ2NHgyCgljYWxsc3ViIG1heFVmaXhlZAoJaXRvYgoJZXh0cmFjdCAwIDgKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gbWF4VWZpeGVkKCk6IHVmaXhlZDw2NCwgMj4KbWF4VWZpeGVkOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMTQyCgkvLyB1NjRtYXg6IHVmaXhlZDw2NCwgMj4gPSAxMi4zNAoJcHVzaGludCAxMjM0CglmcmFtZV9idXJ5IDAgLy8gdTY0bWF4OiB1Zml4ZWQ8NjQsIDI+CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjExNDQKCS8vIHJldHVybiB1NjRtYXg7CglmcmFtZV9kaWcgMCAvLyB1NjRtYXg6IHVmaXhlZDw2NCwgMj4KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4NTRlZDNkMmUgLy8gbWV0aG9kICJtYXhVZml4ZWQoKXVmaXhlZDY0eDIiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX21heFVmaXhlZAoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestMixedStaticArrayElements.approval.teal b/tests/contracts/artifacts/ABITestMixedStaticArrayElements.approval.teal index 3a84e624a..4da3a3272 100644 --- a/tests/contracts/artifacts/ABITestMixedStaticArrayElements.approval.teal +++ b/tests/contracts/artifacts/ABITestMixedStaticArrayElements.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestMixedStaticArrayElements.arc32.json b/tests/contracts/artifacts/ABITestMixedStaticArrayElements.arc32.json index 80c2e7c35..400219946 100644 --- a/tests/contracts/artifacts/ABITestMixedStaticArrayElements.arc32.json +++ b/tests/contracts/artifacts/ABITestMixedStaticArrayElements.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBtaXhlZFN0YXRpY0FycmF5RWxlbWVudHMoKXVpbnQ2NAoqYWJpX3JvdXRlX21peGVkU3RhdGljQXJyYXlFbGVtZW50czoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIG1peGVkU3RhdGljQXJyYXlFbGVtZW50cygpdWludDY0CgljYWxsc3ViIG1peGVkU3RhdGljQXJyYXlFbGVtZW50cwoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBtaXhlZFN0YXRpY0FycmF5RWxlbWVudHMoKTogdWludDY0Cm1peGVkU3RhdGljQXJyYXlFbGVtZW50czoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXBuIDMKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NDQKCS8vIG4xID0gYnRvaShpdG9iKDMpKQoJcHVzaGludCAzCglmcmFtZV9idXJ5IDAgLy8gbjE6IHVpbnQ2NAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo0NQoJLy8gbjIgPSBidG9pKGl0b2IoNCkpCglwdXNoaW50IDQKCWZyYW1lX2J1cnkgMSAvLyBuMjogdWludDY0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQ2CgkvLyBuMyA9IGJ0b2koaXRvYig1KSkKCXB1c2hpbnQgNQoJZnJhbWVfYnVyeSAyIC8vIG4zOiB1aW50NjQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NDcKCS8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgOT4gPSBbMCwgMSwgMiwgbjEsIG4yLCBuMywgNiwgNywgOF0KCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAxMDAwMDAwMDAwMDAwMDAwMgoJZnJhbWVfZGlnIDAgLy8gbjE6IHVpbnQ2NAoJaXRvYgoJY29uY2F0CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDA0Cgljb25jYXQKCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDUKCWNvbmNhdAoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwNgoJY29uY2F0CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDA3Cgljb25jYXQKCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDgKCWNvbmNhdAoJZnJhbWVfYnVyeSAzIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgOT4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NDkKCS8vIHJldHVybiBhWzFdICsgYVs0XSArIGFbN107CglmcmFtZV9kaWcgMyAvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDk+CglleHRyYWN0IDggOAoJYnRvaQoJZnJhbWVfZGlnIDMgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCA5PgoJZXh0cmFjdCAzMiA4CglidG9pCgkrCglmcmFtZV9kaWcgMyAvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDk+CglleHRyYWN0IDU2IDgKCWJ0b2kKCSsKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCgkvLyBwb3AgYWxsIGxvY2FsIHZhcmlhYmxlcyBmcm9tIHRoZSBzdGFjawoJcG9wbiAzCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDg2OWRlZWJjIC8vIG1ldGhvZCAibWl4ZWRTdGF0aWNBcnJheUVsZW1lbnRzKCl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX21peGVkU3RhdGljQXJyYXlFbGVtZW50cwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBtaXhlZFN0YXRpY0FycmF5RWxlbWVudHMoKXVpbnQ2NAoqYWJpX3JvdXRlX21peGVkU3RhdGljQXJyYXlFbGVtZW50czoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIG1peGVkU3RhdGljQXJyYXlFbGVtZW50cygpdWludDY0CgljYWxsc3ViIG1peGVkU3RhdGljQXJyYXlFbGVtZW50cwoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBtaXhlZFN0YXRpY0FycmF5RWxlbWVudHMoKTogdWludDY0Cm1peGVkU3RhdGljQXJyYXlFbGVtZW50czoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXBuIDMKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NDQKCS8vIG4xID0gYnRvaShpdG9iKDMpKQoJcHVzaGludCAzCglmcmFtZV9idXJ5IDAgLy8gbjE6IHVpbnQ2NAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo0NQoJLy8gbjIgPSBidG9pKGl0b2IoNCkpCglwdXNoaW50IDQKCWZyYW1lX2J1cnkgMSAvLyBuMjogdWludDY0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQ2CgkvLyBuMyA9IGJ0b2koaXRvYig1KSkKCXB1c2hpbnQgNQoJZnJhbWVfYnVyeSAyIC8vIG4zOiB1aW50NjQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NDcKCS8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgOT4gPSBbMCwgMSwgMiwgbjEsIG4yLCBuMywgNiwgNywgOF0KCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAxMDAwMDAwMDAwMDAwMDAwMgoJZnJhbWVfZGlnIDAgLy8gbjE6IHVpbnQ2NAoJaXRvYgoJY29uY2F0CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDA0Cgljb25jYXQKCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDUKCWNvbmNhdAoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwNgoJY29uY2F0CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDA3Cgljb25jYXQKCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDgKCWNvbmNhdAoJZnJhbWVfYnVyeSAzIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgOT4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NDkKCS8vIHJldHVybiBhWzFdICsgYVs0XSArIGFbN107CglmcmFtZV9kaWcgMyAvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDk+CglleHRyYWN0IDggOAoJYnRvaQoJZnJhbWVfZGlnIDMgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCA5PgoJZXh0cmFjdCAzMiA4CglidG9pCgkrCglmcmFtZV9kaWcgMyAvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDk+CglleHRyYWN0IDU2IDgKCWJ0b2kKCSsKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCgkvLyBwb3AgYWxsIGxvY2FsIHZhcmlhYmxlcyBmcm9tIHRoZSBzdGFjawoJcG9wbiAzCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDg2OWRlZWJjIC8vIG1ldGhvZCAibWl4ZWRTdGF0aWNBcnJheUVsZW1lbnRzKCl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX21peGVkU3RhdGljQXJyYXlFbGVtZW50cwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestMixedStaticArrayElements.arc56_draft.json b/tests/contracts/artifacts/ABITestMixedStaticArrayElements.arc56_draft.json index bbfdf1af8..5ada87871 100644 --- a/tests/contracts/artifacts/ABITestMixedStaticArrayElements.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestMixedStaticArrayElements.arc56_draft.json @@ -682,7 +682,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBtaXhlZFN0YXRpY0FycmF5RWxlbWVudHMoKXVpbnQ2NAoqYWJpX3JvdXRlX21peGVkU3RhdGljQXJyYXlFbGVtZW50czoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIG1peGVkU3RhdGljQXJyYXlFbGVtZW50cygpdWludDY0CgljYWxsc3ViIG1peGVkU3RhdGljQXJyYXlFbGVtZW50cwoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBtaXhlZFN0YXRpY0FycmF5RWxlbWVudHMoKTogdWludDY0Cm1peGVkU3RhdGljQXJyYXlFbGVtZW50czoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXBuIDMKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NDQKCS8vIG4xID0gYnRvaShpdG9iKDMpKQoJcHVzaGludCAzCglmcmFtZV9idXJ5IDAgLy8gbjE6IHVpbnQ2NAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo0NQoJLy8gbjIgPSBidG9pKGl0b2IoNCkpCglwdXNoaW50IDQKCWZyYW1lX2J1cnkgMSAvLyBuMjogdWludDY0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQ2CgkvLyBuMyA9IGJ0b2koaXRvYig1KSkKCXB1c2hpbnQgNQoJZnJhbWVfYnVyeSAyIC8vIG4zOiB1aW50NjQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NDcKCS8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgOT4gPSBbMCwgMSwgMiwgbjEsIG4yLCBuMywgNiwgNywgOF0KCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAxMDAwMDAwMDAwMDAwMDAwMgoJZnJhbWVfZGlnIDAgLy8gbjE6IHVpbnQ2NAoJaXRvYgoJY29uY2F0CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDA0Cgljb25jYXQKCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDUKCWNvbmNhdAoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwNgoJY29uY2F0CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDA3Cgljb25jYXQKCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDgKCWNvbmNhdAoJZnJhbWVfYnVyeSAzIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgOT4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NDkKCS8vIHJldHVybiBhWzFdICsgYVs0XSArIGFbN107CglmcmFtZV9kaWcgMyAvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDk+CglleHRyYWN0IDggOAoJYnRvaQoJZnJhbWVfZGlnIDMgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCA5PgoJZXh0cmFjdCAzMiA4CglidG9pCgkrCglmcmFtZV9kaWcgMyAvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDk+CglleHRyYWN0IDU2IDgKCWJ0b2kKCSsKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCgkvLyBwb3AgYWxsIGxvY2FsIHZhcmlhYmxlcyBmcm9tIHRoZSBzdGFjawoJcG9wbiAzCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDg2OWRlZWJjIC8vIG1ldGhvZCAibWl4ZWRTdGF0aWNBcnJheUVsZW1lbnRzKCl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX21peGVkU3RhdGljQXJyYXlFbGVtZW50cwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBtaXhlZFN0YXRpY0FycmF5RWxlbWVudHMoKXVpbnQ2NAoqYWJpX3JvdXRlX21peGVkU3RhdGljQXJyYXlFbGVtZW50czoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIG1peGVkU3RhdGljQXJyYXlFbGVtZW50cygpdWludDY0CgljYWxsc3ViIG1peGVkU3RhdGljQXJyYXlFbGVtZW50cwoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBtaXhlZFN0YXRpY0FycmF5RWxlbWVudHMoKTogdWludDY0Cm1peGVkU3RhdGljQXJyYXlFbGVtZW50czoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXBuIDMKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NDQKCS8vIG4xID0gYnRvaShpdG9iKDMpKQoJcHVzaGludCAzCglmcmFtZV9idXJ5IDAgLy8gbjE6IHVpbnQ2NAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo0NQoJLy8gbjIgPSBidG9pKGl0b2IoNCkpCglwdXNoaW50IDQKCWZyYW1lX2J1cnkgMSAvLyBuMjogdWludDY0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQ2CgkvLyBuMyA9IGJ0b2koaXRvYig1KSkKCXB1c2hpbnQgNQoJZnJhbWVfYnVyeSAyIC8vIG4zOiB1aW50NjQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NDcKCS8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgOT4gPSBbMCwgMSwgMiwgbjEsIG4yLCBuMywgNiwgNywgOF0KCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAxMDAwMDAwMDAwMDAwMDAwMgoJZnJhbWVfZGlnIDAgLy8gbjE6IHVpbnQ2NAoJaXRvYgoJY29uY2F0CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDA0Cgljb25jYXQKCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDUKCWNvbmNhdAoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwNgoJY29uY2F0CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDA3Cgljb25jYXQKCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDgKCWNvbmNhdAoJZnJhbWVfYnVyeSAzIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgOT4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NDkKCS8vIHJldHVybiBhWzFdICsgYVs0XSArIGFbN107CglmcmFtZV9kaWcgMyAvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDk+CglleHRyYWN0IDggOAoJYnRvaQoJZnJhbWVfZGlnIDMgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCA5PgoJZXh0cmFjdCAzMiA4CglidG9pCgkrCglmcmFtZV9kaWcgMyAvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDk+CglleHRyYWN0IDU2IDgKCWJ0b2kKCSsKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCgkvLyBwb3AgYWxsIGxvY2FsIHZhcmlhYmxlcyBmcm9tIHRoZSBzdGFjawoJcG9wbiAzCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDg2OWRlZWJjIC8vIG1ldGhvZCAibWl4ZWRTdGF0aWNBcnJheUVsZW1lbnRzKCl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX21peGVkU3RhdGljQXJyYXlFbGVtZW50cwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestMultiBytesTuple.approval.teal b/tests/contracts/artifacts/ABITestMultiBytesTuple.approval.teal index 119fff866..5588212b5 100644 --- a/tests/contracts/artifacts/ABITestMultiBytesTuple.approval.teal +++ b/tests/contracts/artifacts/ABITestMultiBytesTuple.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestMultiBytesTuple.arc32.json b/tests/contracts/artifacts/ABITestMultiBytesTuple.arc32.json index 164437aa7..f088b6d4e 100644 --- a/tests/contracts/artifacts/ABITestMultiBytesTuple.arc32.json +++ b/tests/contracts/artifacts/ABITestMultiBytesTuple.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBtdWx0aUJ5dGVzVHVwbGUoKShieXRlW10sYnl0ZVtdKQoqYWJpX3JvdXRlX211bHRpQnl0ZXNUdXBsZToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIG11bHRpQnl0ZXNUdXBsZSgpKGJ5dGVbXSxieXRlW10pCgljYWxsc3ViIG11bHRpQnl0ZXNUdXBsZQoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBtdWx0aUJ5dGVzVHVwbGUoKTogW2J5dGVzLCBieXRlc10KbXVsdGlCeXRlc1R1cGxlOgoJcHJvdG8gMCAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEyMTkKCS8vIHJldHVybiBbaGV4KCcweDAxJyksIGhleCgnMHgwMicpXTsKCWJ5dGUgMHggLy8gaW5pdGlhbCBoZWFkCglieXRlIDB4IC8vIGluaXRpYWwgdGFpbAoJcHVzaGJ5dGVzIDB4MDAwNCAvLyBpbml0aWFsIGhlYWQgb2Zmc2V0CglwdXNoYnl0ZXMgMHgwMDAxMDEKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAxMDIKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50Cglwb3AgLy8gcG9wIGhlYWQgb2Zmc2V0Cgljb25jYXQgLy8gY29uY2F0IGhlYWQgYW5kIHRhaWwKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4N2JmZDkzNTcgLy8gbWV0aG9kICJtdWx0aUJ5dGVzVHVwbGUoKShieXRlW10sYnl0ZVtdKSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfbXVsdGlCeXRlc1R1cGxlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJyCgoqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCWNvbmNhdAoJZnJhbWVfYnVyeSAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJZHVwCglsZW4KCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJYnRvaQoJKwoJaXRvYgoJZXh0cmFjdCA2IDIKCWZyYW1lX2J1cnkgLTIgLy8gaGVhZCBvZmZzZXQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglzd2FwCgljb25jYXQKCWZyYW1lX2J1cnkgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCXJldHN1Yg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBtdWx0aUJ5dGVzVHVwbGUoKShieXRlW10sYnl0ZVtdKQoqYWJpX3JvdXRlX211bHRpQnl0ZXNUdXBsZToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIG11bHRpQnl0ZXNUdXBsZSgpKGJ5dGVbXSxieXRlW10pCgljYWxsc3ViIG11bHRpQnl0ZXNUdXBsZQoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBtdWx0aUJ5dGVzVHVwbGUoKTogW2J5dGVzLCBieXRlc10KbXVsdGlCeXRlc1R1cGxlOgoJcHJvdG8gMCAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEyMTkKCS8vIHJldHVybiBbaGV4KCcweDAxJyksIGhleCgnMHgwMicpXTsKCWJ5dGUgMHggLy8gaW5pdGlhbCBoZWFkCglieXRlIDB4IC8vIGluaXRpYWwgdGFpbAoJcHVzaGJ5dGVzIDB4MDAwNCAvLyBpbml0aWFsIGhlYWQgb2Zmc2V0CglwdXNoYnl0ZXMgMHgwMDAxMDEKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAxMDIKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50Cglwb3AgLy8gcG9wIGhlYWQgb2Zmc2V0Cgljb25jYXQgLy8gY29uY2F0IGhlYWQgYW5kIHRhaWwKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4N2JmZDkzNTcgLy8gbWV0aG9kICJtdWx0aUJ5dGVzVHVwbGUoKShieXRlW10sYnl0ZVtdKSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfbXVsdGlCeXRlc1R1cGxlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJyCgoqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCWNvbmNhdAoJZnJhbWVfYnVyeSAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJZHVwCglsZW4KCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJYnRvaQoJKwoJaXRvYgoJZXh0cmFjdCA2IDIKCWZyYW1lX2J1cnkgLTIgLy8gaGVhZCBvZmZzZXQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglzd2FwCgljb25jYXQKCWZyYW1lX2J1cnkgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCXJldHN1Yg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestMultiBytesTuple.arc56_draft.json b/tests/contracts/artifacts/ABITestMultiBytesTuple.arc56_draft.json index 07d061c94..1a9897487 100644 --- a/tests/contracts/artifacts/ABITestMultiBytesTuple.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestMultiBytesTuple.arc56_draft.json @@ -581,7 +581,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBtdWx0aUJ5dGVzVHVwbGUoKShieXRlW10sYnl0ZVtdKQoqYWJpX3JvdXRlX211bHRpQnl0ZXNUdXBsZToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIG11bHRpQnl0ZXNUdXBsZSgpKGJ5dGVbXSxieXRlW10pCgljYWxsc3ViIG11bHRpQnl0ZXNUdXBsZQoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBtdWx0aUJ5dGVzVHVwbGUoKTogW2J5dGVzLCBieXRlc10KbXVsdGlCeXRlc1R1cGxlOgoJcHJvdG8gMCAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEyMTkKCS8vIHJldHVybiBbaGV4KCcweDAxJyksIGhleCgnMHgwMicpXTsKCWJ5dGUgMHggLy8gaW5pdGlhbCBoZWFkCglieXRlIDB4IC8vIGluaXRpYWwgdGFpbAoJcHVzaGJ5dGVzIDB4MDAwNCAvLyBpbml0aWFsIGhlYWQgb2Zmc2V0CglwdXNoYnl0ZXMgMHgwMDAxMDEKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAxMDIKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50Cglwb3AgLy8gcG9wIGhlYWQgb2Zmc2V0Cgljb25jYXQgLy8gY29uY2F0IGhlYWQgYW5kIHRhaWwKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4N2JmZDkzNTcgLy8gbWV0aG9kICJtdWx0aUJ5dGVzVHVwbGUoKShieXRlW10sYnl0ZVtdKSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfbXVsdGlCeXRlc1R1cGxlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJyCgoqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCWNvbmNhdAoJZnJhbWVfYnVyeSAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJZHVwCglsZW4KCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJYnRvaQoJKwoJaXRvYgoJZXh0cmFjdCA2IDIKCWZyYW1lX2J1cnkgLTIgLy8gaGVhZCBvZmZzZXQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglzd2FwCgljb25jYXQKCWZyYW1lX2J1cnkgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCXJldHN1Yg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBtdWx0aUJ5dGVzVHVwbGUoKShieXRlW10sYnl0ZVtdKQoqYWJpX3JvdXRlX211bHRpQnl0ZXNUdXBsZToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIG11bHRpQnl0ZXNUdXBsZSgpKGJ5dGVbXSxieXRlW10pCgljYWxsc3ViIG11bHRpQnl0ZXNUdXBsZQoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBtdWx0aUJ5dGVzVHVwbGUoKTogW2J5dGVzLCBieXRlc10KbXVsdGlCeXRlc1R1cGxlOgoJcHJvdG8gMCAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEyMTkKCS8vIHJldHVybiBbaGV4KCcweDAxJyksIGhleCgnMHgwMicpXTsKCWJ5dGUgMHggLy8gaW5pdGlhbCBoZWFkCglieXRlIDB4IC8vIGluaXRpYWwgdGFpbAoJcHVzaGJ5dGVzIDB4MDAwNCAvLyBpbml0aWFsIGhlYWQgb2Zmc2V0CglwdXNoYnl0ZXMgMHgwMDAxMDEKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAxMDIKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50Cglwb3AgLy8gcG9wIGhlYWQgb2Zmc2V0Cgljb25jYXQgLy8gY29uY2F0IGhlYWQgYW5kIHRhaWwKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4N2JmZDkzNTcgLy8gbWV0aG9kICJtdWx0aUJ5dGVzVHVwbGUoKShieXRlW10sYnl0ZVtdKSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfbXVsdGlCeXRlc1R1cGxlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJyCgoqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCWNvbmNhdAoJZnJhbWVfYnVyeSAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJZHVwCglsZW4KCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJYnRvaQoJKwoJaXRvYgoJZXh0cmFjdCA2IDIKCWZyYW1lX2J1cnkgLTIgLy8gaGVhZCBvZmZzZXQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglzd2FwCgljb25jYXQKCWZyYW1lX2J1cnkgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCXJldHN1Yg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestMultiNestedArrayRef.approval.teal b/tests/contracts/artifacts/ABITestMultiNestedArrayRef.approval.teal index 8bbc142c4..cd93d4211 100644 --- a/tests/contracts/artifacts/ABITestMultiNestedArrayRef.approval.teal +++ b/tests/contracts/artifacts/ABITestMultiNestedArrayRef.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestMultiNestedArrayRef.arc32.json b/tests/contracts/artifacts/ABITestMultiNestedArrayRef.arc32.json index 01349e907..274a44c8a 100644 --- a/tests/contracts/artifacts/ABITestMultiNestedArrayRef.arc32.json +++ b/tests/contracts/artifacts/ABITestMultiNestedArrayRef.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gbXVsdGlOZXN0ZWRBcnJheVJlZigpdWludDhbMl1bMl1bMl0KKmFiaV9yb3V0ZV9tdWx0aU5lc3RlZEFycmF5UmVmOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgbXVsdGlOZXN0ZWRBcnJheVJlZigpdWludDhbMl1bMl1bMl0KCWNhbGxzdWIgbXVsdGlOZXN0ZWRBcnJheVJlZgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBtdWx0aU5lc3RlZEFycmF5UmVmKCk6IFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQ8OD4sIDI+LCAyPiwgMj4KbXVsdGlOZXN0ZWRBcnJheVJlZjoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglwdXNoYnl0ZXMgMHgKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NzkzCgkvLyBhOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50PDg+LCAyPiwgMj4sIDI+ID0gWwoJLy8gICAgICAgWwoJLy8gICAgICAgICBbMSwgMl0sCgkvLyAgICAgICAgIFszLCA0XSwKCS8vICAgICAgIF0sCgkvLyAgICAgICBbCgkvLyAgICAgICAgIFs1LCA2XSwKCS8vICAgICAgICAgWzcsIDhdLAoJLy8gICAgICAgXSwKCS8vICAgICBdCglwdXNoYnl0ZXMgMHgwMTAyMDMwNDA1MDYwNzA4CglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDw4PiwgMj4sIDI+LCAyPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4MDQKCS8vIGIgPSBhWzFdCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6ODA1CgkvLyBjID0gYlsxXQoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjgwNwoJLy8gY1sxXSA9IDkgYXMgdWludDw4PgoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDw4PiwgMj4sIDI+LCAyPgoJcHVzaGJ5dGVzIDB4MDkKCXJlcGxhY2UyIDcKCWZyYW1lX2J1cnkgMCAvLyBjOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50PDg+LCAyPiwgMj4sIDI+CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjgwOQoJLy8gcmV0dXJuIGE7CglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50PDg+LCAyPiwgMj4sIDI+CgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDNkNjQwNWRmIC8vIG1ldGhvZCAibXVsdGlOZXN0ZWRBcnJheVJlZigpdWludDhbMl1bMl1bMl0iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX211bHRpTmVzdGVkQXJyYXlSZWYKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gbXVsdGlOZXN0ZWRBcnJheVJlZigpdWludDhbMl1bMl1bMl0KKmFiaV9yb3V0ZV9tdWx0aU5lc3RlZEFycmF5UmVmOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgbXVsdGlOZXN0ZWRBcnJheVJlZigpdWludDhbMl1bMl1bMl0KCWNhbGxzdWIgbXVsdGlOZXN0ZWRBcnJheVJlZgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBtdWx0aU5lc3RlZEFycmF5UmVmKCk6IFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQ8OD4sIDI+LCAyPiwgMj4KbXVsdGlOZXN0ZWRBcnJheVJlZjoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglwdXNoYnl0ZXMgMHgKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NzkzCgkvLyBhOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50PDg+LCAyPiwgMj4sIDI+ID0gWwoJLy8gICAgICAgWwoJLy8gICAgICAgICBbMSwgMl0sCgkvLyAgICAgICAgIFszLCA0XSwKCS8vICAgICAgIF0sCgkvLyAgICAgICBbCgkvLyAgICAgICAgIFs1LCA2XSwKCS8vICAgICAgICAgWzcsIDhdLAoJLy8gICAgICAgXSwKCS8vICAgICBdCglwdXNoYnl0ZXMgMHgwMTAyMDMwNDA1MDYwNzA4CglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDw4PiwgMj4sIDI+LCAyPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4MDQKCS8vIGIgPSBhWzFdCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6ODA1CgkvLyBjID0gYlsxXQoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjgwNwoJLy8gY1sxXSA9IDkgYXMgdWludDw4PgoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDw4PiwgMj4sIDI+LCAyPgoJcHVzaGJ5dGVzIDB4MDkKCXJlcGxhY2UyIDcKCWZyYW1lX2J1cnkgMCAvLyBjOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50PDg+LCAyPiwgMj4sIDI+CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjgwOQoJLy8gcmV0dXJuIGE7CglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50PDg+LCAyPiwgMj4sIDI+CgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDNkNjQwNWRmIC8vIG1ldGhvZCAibXVsdGlOZXN0ZWRBcnJheVJlZigpdWludDhbMl1bMl1bMl0iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX211bHRpTmVzdGVkQXJyYXlSZWYKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestMultiNestedArrayRef.arc56_draft.json b/tests/contracts/artifacts/ABITestMultiNestedArrayRef.arc56_draft.json index e970da334..d801bccc6 100644 --- a/tests/contracts/artifacts/ABITestMultiNestedArrayRef.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestMultiNestedArrayRef.arc56_draft.json @@ -404,7 +404,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gbXVsdGlOZXN0ZWRBcnJheVJlZigpdWludDhbMl1bMl1bMl0KKmFiaV9yb3V0ZV9tdWx0aU5lc3RlZEFycmF5UmVmOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgbXVsdGlOZXN0ZWRBcnJheVJlZigpdWludDhbMl1bMl1bMl0KCWNhbGxzdWIgbXVsdGlOZXN0ZWRBcnJheVJlZgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBtdWx0aU5lc3RlZEFycmF5UmVmKCk6IFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQ8OD4sIDI+LCAyPiwgMj4KbXVsdGlOZXN0ZWRBcnJheVJlZjoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglwdXNoYnl0ZXMgMHgKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NzkzCgkvLyBhOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50PDg+LCAyPiwgMj4sIDI+ID0gWwoJLy8gICAgICAgWwoJLy8gICAgICAgICBbMSwgMl0sCgkvLyAgICAgICAgIFszLCA0XSwKCS8vICAgICAgIF0sCgkvLyAgICAgICBbCgkvLyAgICAgICAgIFs1LCA2XSwKCS8vICAgICAgICAgWzcsIDhdLAoJLy8gICAgICAgXSwKCS8vICAgICBdCglwdXNoYnl0ZXMgMHgwMTAyMDMwNDA1MDYwNzA4CglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDw4PiwgMj4sIDI+LCAyPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4MDQKCS8vIGIgPSBhWzFdCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6ODA1CgkvLyBjID0gYlsxXQoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjgwNwoJLy8gY1sxXSA9IDkgYXMgdWludDw4PgoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDw4PiwgMj4sIDI+LCAyPgoJcHVzaGJ5dGVzIDB4MDkKCXJlcGxhY2UyIDcKCWZyYW1lX2J1cnkgMCAvLyBjOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50PDg+LCAyPiwgMj4sIDI+CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjgwOQoJLy8gcmV0dXJuIGE7CglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50PDg+LCAyPiwgMj4sIDI+CgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDNkNjQwNWRmIC8vIG1ldGhvZCAibXVsdGlOZXN0ZWRBcnJheVJlZigpdWludDhbMl1bMl1bMl0iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX211bHRpTmVzdGVkQXJyYXlSZWYKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gbXVsdGlOZXN0ZWRBcnJheVJlZigpdWludDhbMl1bMl1bMl0KKmFiaV9yb3V0ZV9tdWx0aU5lc3RlZEFycmF5UmVmOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgbXVsdGlOZXN0ZWRBcnJheVJlZigpdWludDhbMl1bMl1bMl0KCWNhbGxzdWIgbXVsdGlOZXN0ZWRBcnJheVJlZgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBtdWx0aU5lc3RlZEFycmF5UmVmKCk6IFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQ8OD4sIDI+LCAyPiwgMj4KbXVsdGlOZXN0ZWRBcnJheVJlZjoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglwdXNoYnl0ZXMgMHgKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NzkzCgkvLyBhOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50PDg+LCAyPiwgMj4sIDI+ID0gWwoJLy8gICAgICAgWwoJLy8gICAgICAgICBbMSwgMl0sCgkvLyAgICAgICAgIFszLCA0XSwKCS8vICAgICAgIF0sCgkvLyAgICAgICBbCgkvLyAgICAgICAgIFs1LCA2XSwKCS8vICAgICAgICAgWzcsIDhdLAoJLy8gICAgICAgXSwKCS8vICAgICBdCglwdXNoYnl0ZXMgMHgwMTAyMDMwNDA1MDYwNzA4CglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDw4PiwgMj4sIDI+LCAyPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4MDQKCS8vIGIgPSBhWzFdCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6ODA1CgkvLyBjID0gYlsxXQoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjgwNwoJLy8gY1sxXSA9IDkgYXMgdWludDw4PgoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDw4PiwgMj4sIDI+LCAyPgoJcHVzaGJ5dGVzIDB4MDkKCXJlcGxhY2UyIDcKCWZyYW1lX2J1cnkgMCAvLyBjOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50PDg+LCAyPiwgMj4sIDI+CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjgwOQoJLy8gcmV0dXJuIGE7CglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50PDg+LCAyPiwgMj4sIDI+CgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDNkNjQwNWRmIC8vIG1ldGhvZCAibXVsdGlOZXN0ZWRBcnJheVJlZigpdWludDhbMl1bMl1bMl0iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX211bHRpTmVzdGVkQXJyYXlSZWYKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestNamedTuple.approval.teal b/tests/contracts/artifacts/ABITestNamedTuple.approval.teal index f5af93d1e..cfa0db5af 100644 --- a/tests/contracts/artifacts/ABITestNamedTuple.approval.teal +++ b/tests/contracts/artifacts/ABITestNamedTuple.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestNamedTuple.arc32.json b/tests/contracts/artifacts/ABITestNamedTuple.arc32.json index 64c360017..0b3883810 100644 --- a/tests/contracts/artifacts/ABITestNamedTuple.arc32.json +++ b/tests/contracts/artifacts/ABITestNamedTuple.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBuYW1lZFR1cGxlKClzdHJpbmcKKmFiaV9yb3V0ZV9uYW1lZFR1cGxlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgbmFtZWRUdXBsZSgpc3RyaW5nCgljYWxsc3ViIG5hbWVkVHVwbGUKCWR1cAoJbGVuCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIG5hbWVkVHVwbGUoKTogc3RyaW5nCm5hbWVkVHVwbGU6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJYnl0ZSAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo2MDIKCS8vIGE6IHsKCS8vICAgICAgIGZvbzogdWludDE2OwoJLy8gICAgICAgYmFyOiBzdHJpbmc7CgkvLyAgICAgfSA9IHsKCS8vICAgICAgIGZvbzogMSwKCS8vICAgICAgIGJhcjogJ0hlbGxvIFdvcmxkIScsCgkvLyAgICAgfQoJYnl0ZSAweCAvLyBpbml0aWFsIGhlYWQKCWJ5dGUgMHggLy8gaW5pdGlhbCB0YWlsCglwdXNoYnl0ZXMgMHgwMDA0IC8vIGluaXRpYWwgaGVhZCBvZmZzZXQKCXB1c2hieXRlcyAweDAwMDEKCWNhbGxzdWIgKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMGM0ODY1NmM2YzZmMjA1NzZmNzI2YzY0MjEKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50Cglwb3AgLy8gcG9wIGhlYWQgb2Zmc2V0Cgljb25jYXQgLy8gY29uY2F0IGhlYWQgYW5kIHRhaWwKCWZyYW1lX2J1cnkgMCAvLyBhOiB7ICAgICAgIGZvbzogdWludDE2OyAgICAgICBiYXI6IHN0cmluZzsgICAgIH0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NjEwCgkvLyByZXR1cm4gYS5iYXI7CglmcmFtZV9kaWcgMCAvLyBhOiB7ICAgICAgIGZvbzogdWludDE2OyAgICAgICBiYXI6IHN0cmluZzsgICAgIH0KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoaW50IDIKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXVuY292ZXIgMgoJZXh0cmFjdF91aW50MTYKCWR1cCAvLyBkdXBsaWNhdGUgc3RhcnQgb2YgZWxlbWVudAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJc3dhcAoJZXh0cmFjdF91aW50MTYgLy8gZ2V0IG51bWJlciBvZiBlbGVtZW50cwoJcHVzaGludCAxIC8vIGdldCB0eXBlIGxlbmd0aAoJKiAvLyBtdWx0aXBseSBieSB0eXBlIGxlbmd0aAoJcHVzaGludCAyCgkrIC8vIGFkZCB0d28gZm9yIGxlbmd0aAoJZXh0cmFjdDMKCWV4dHJhY3QgMiAwCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGE3NTY1MDUzIC8vIG1ldGhvZCAibmFtZWRUdXBsZSgpc3RyaW5nIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9uYW1lZFR1cGxlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJyCgoqcHJvY2Vzc19zdGF0aWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50Cgljb25jYXQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCXJldHN1YgoKKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50OgoJcHJvdG8gNCAzCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0Cgljb25jYXQKCWZyYW1lX2J1cnkgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0xIC8vIGVsZW1lbnQKCWR1cAoJbGVuCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCWJ0b2kKCSsKCWl0b2IKCWV4dHJhY3QgNiAyCglmcmFtZV9idXJ5IC0yIC8vIGhlYWQgb2Zmc2V0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJc3dhcAoJY29uY2F0CglmcmFtZV9idXJ5IC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBuYW1lZFR1cGxlKClzdHJpbmcKKmFiaV9yb3V0ZV9uYW1lZFR1cGxlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgbmFtZWRUdXBsZSgpc3RyaW5nCgljYWxsc3ViIG5hbWVkVHVwbGUKCWR1cAoJbGVuCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIG5hbWVkVHVwbGUoKTogc3RyaW5nCm5hbWVkVHVwbGU6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJYnl0ZSAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo2MDIKCS8vIGE6IHsKCS8vICAgICAgIGZvbzogdWludDE2OwoJLy8gICAgICAgYmFyOiBzdHJpbmc7CgkvLyAgICAgfSA9IHsKCS8vICAgICAgIGZvbzogMSwKCS8vICAgICAgIGJhcjogJ0hlbGxvIFdvcmxkIScsCgkvLyAgICAgfQoJYnl0ZSAweCAvLyBpbml0aWFsIGhlYWQKCWJ5dGUgMHggLy8gaW5pdGlhbCB0YWlsCglwdXNoYnl0ZXMgMHgwMDA0IC8vIGluaXRpYWwgaGVhZCBvZmZzZXQKCXB1c2hieXRlcyAweDAwMDEKCWNhbGxzdWIgKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMGM0ODY1NmM2YzZmMjA1NzZmNzI2YzY0MjEKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50Cglwb3AgLy8gcG9wIGhlYWQgb2Zmc2V0Cgljb25jYXQgLy8gY29uY2F0IGhlYWQgYW5kIHRhaWwKCWZyYW1lX2J1cnkgMCAvLyBhOiB7ICAgICAgIGZvbzogdWludDE2OyAgICAgICBiYXI6IHN0cmluZzsgICAgIH0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NjEwCgkvLyByZXR1cm4gYS5iYXI7CglmcmFtZV9kaWcgMCAvLyBhOiB7ICAgICAgIGZvbzogdWludDE2OyAgICAgICBiYXI6IHN0cmluZzsgICAgIH0KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoaW50IDIKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXVuY292ZXIgMgoJZXh0cmFjdF91aW50MTYKCWR1cCAvLyBkdXBsaWNhdGUgc3RhcnQgb2YgZWxlbWVudAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJc3dhcAoJZXh0cmFjdF91aW50MTYgLy8gZ2V0IG51bWJlciBvZiBlbGVtZW50cwoJcHVzaGludCAxIC8vIGdldCB0eXBlIGxlbmd0aAoJKiAvLyBtdWx0aXBseSBieSB0eXBlIGxlbmd0aAoJcHVzaGludCAyCgkrIC8vIGFkZCB0d28gZm9yIGxlbmd0aAoJZXh0cmFjdDMKCWV4dHJhY3QgMiAwCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGE3NTY1MDUzIC8vIG1ldGhvZCAibmFtZWRUdXBsZSgpc3RyaW5nIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9uYW1lZFR1cGxlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJyCgoqcHJvY2Vzc19zdGF0aWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50Cgljb25jYXQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCXJldHN1YgoKKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50OgoJcHJvdG8gNCAzCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0Cgljb25jYXQKCWZyYW1lX2J1cnkgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0xIC8vIGVsZW1lbnQKCWR1cAoJbGVuCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCWJ0b2kKCSsKCWl0b2IKCWV4dHJhY3QgNiAyCglmcmFtZV9idXJ5IC0yIC8vIGhlYWQgb2Zmc2V0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJc3dhcAoJY29uY2F0CglmcmFtZV9idXJ5IC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestNamedTuple.arc56_draft.json b/tests/contracts/artifacts/ABITestNamedTuple.arc56_draft.json index 9f7007c09..bd65f3a86 100644 --- a/tests/contracts/artifacts/ABITestNamedTuple.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestNamedTuple.arc56_draft.json @@ -844,7 +844,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBuYW1lZFR1cGxlKClzdHJpbmcKKmFiaV9yb3V0ZV9uYW1lZFR1cGxlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgbmFtZWRUdXBsZSgpc3RyaW5nCgljYWxsc3ViIG5hbWVkVHVwbGUKCWR1cAoJbGVuCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIG5hbWVkVHVwbGUoKTogc3RyaW5nCm5hbWVkVHVwbGU6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJYnl0ZSAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo2MDIKCS8vIGE6IHsKCS8vICAgICAgIGZvbzogdWludDE2OwoJLy8gICAgICAgYmFyOiBzdHJpbmc7CgkvLyAgICAgfSA9IHsKCS8vICAgICAgIGZvbzogMSwKCS8vICAgICAgIGJhcjogJ0hlbGxvIFdvcmxkIScsCgkvLyAgICAgfQoJYnl0ZSAweCAvLyBpbml0aWFsIGhlYWQKCWJ5dGUgMHggLy8gaW5pdGlhbCB0YWlsCglwdXNoYnl0ZXMgMHgwMDA0IC8vIGluaXRpYWwgaGVhZCBvZmZzZXQKCXB1c2hieXRlcyAweDAwMDEKCWNhbGxzdWIgKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMGM0ODY1NmM2YzZmMjA1NzZmNzI2YzY0MjEKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50Cglwb3AgLy8gcG9wIGhlYWQgb2Zmc2V0Cgljb25jYXQgLy8gY29uY2F0IGhlYWQgYW5kIHRhaWwKCWZyYW1lX2J1cnkgMCAvLyBhOiB7ICAgICAgIGZvbzogdWludDE2OyAgICAgICBiYXI6IHN0cmluZzsgICAgIH0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NjEwCgkvLyByZXR1cm4gYS5iYXI7CglmcmFtZV9kaWcgMCAvLyBhOiB7ICAgICAgIGZvbzogdWludDE2OyAgICAgICBiYXI6IHN0cmluZzsgICAgIH0KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoaW50IDIKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXVuY292ZXIgMgoJZXh0cmFjdF91aW50MTYKCWR1cCAvLyBkdXBsaWNhdGUgc3RhcnQgb2YgZWxlbWVudAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJc3dhcAoJZXh0cmFjdF91aW50MTYgLy8gZ2V0IG51bWJlciBvZiBlbGVtZW50cwoJcHVzaGludCAxIC8vIGdldCB0eXBlIGxlbmd0aAoJKiAvLyBtdWx0aXBseSBieSB0eXBlIGxlbmd0aAoJcHVzaGludCAyCgkrIC8vIGFkZCB0d28gZm9yIGxlbmd0aAoJZXh0cmFjdDMKCWV4dHJhY3QgMiAwCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGE3NTY1MDUzIC8vIG1ldGhvZCAibmFtZWRUdXBsZSgpc3RyaW5nIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9uYW1lZFR1cGxlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJyCgoqcHJvY2Vzc19zdGF0aWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50Cgljb25jYXQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCXJldHN1YgoKKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50OgoJcHJvdG8gNCAzCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0Cgljb25jYXQKCWZyYW1lX2J1cnkgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0xIC8vIGVsZW1lbnQKCWR1cAoJbGVuCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCWJ0b2kKCSsKCWl0b2IKCWV4dHJhY3QgNiAyCglmcmFtZV9idXJ5IC0yIC8vIGhlYWQgb2Zmc2V0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJc3dhcAoJY29uY2F0CglmcmFtZV9idXJ5IC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBuYW1lZFR1cGxlKClzdHJpbmcKKmFiaV9yb3V0ZV9uYW1lZFR1cGxlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgbmFtZWRUdXBsZSgpc3RyaW5nCgljYWxsc3ViIG5hbWVkVHVwbGUKCWR1cAoJbGVuCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIG5hbWVkVHVwbGUoKTogc3RyaW5nCm5hbWVkVHVwbGU6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJYnl0ZSAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo2MDIKCS8vIGE6IHsKCS8vICAgICAgIGZvbzogdWludDE2OwoJLy8gICAgICAgYmFyOiBzdHJpbmc7CgkvLyAgICAgfSA9IHsKCS8vICAgICAgIGZvbzogMSwKCS8vICAgICAgIGJhcjogJ0hlbGxvIFdvcmxkIScsCgkvLyAgICAgfQoJYnl0ZSAweCAvLyBpbml0aWFsIGhlYWQKCWJ5dGUgMHggLy8gaW5pdGlhbCB0YWlsCglwdXNoYnl0ZXMgMHgwMDA0IC8vIGluaXRpYWwgaGVhZCBvZmZzZXQKCXB1c2hieXRlcyAweDAwMDEKCWNhbGxzdWIgKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMGM0ODY1NmM2YzZmMjA1NzZmNzI2YzY0MjEKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50Cglwb3AgLy8gcG9wIGhlYWQgb2Zmc2V0Cgljb25jYXQgLy8gY29uY2F0IGhlYWQgYW5kIHRhaWwKCWZyYW1lX2J1cnkgMCAvLyBhOiB7ICAgICAgIGZvbzogdWludDE2OyAgICAgICBiYXI6IHN0cmluZzsgICAgIH0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NjEwCgkvLyByZXR1cm4gYS5iYXI7CglmcmFtZV9kaWcgMCAvLyBhOiB7ICAgICAgIGZvbzogdWludDE2OyAgICAgICBiYXI6IHN0cmluZzsgICAgIH0KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoaW50IDIKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXVuY292ZXIgMgoJZXh0cmFjdF91aW50MTYKCWR1cCAvLyBkdXBsaWNhdGUgc3RhcnQgb2YgZWxlbWVudAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJc3dhcAoJZXh0cmFjdF91aW50MTYgLy8gZ2V0IG51bWJlciBvZiBlbGVtZW50cwoJcHVzaGludCAxIC8vIGdldCB0eXBlIGxlbmd0aAoJKiAvLyBtdWx0aXBseSBieSB0eXBlIGxlbmd0aAoJcHVzaGludCAyCgkrIC8vIGFkZCB0d28gZm9yIGxlbmd0aAoJZXh0cmFjdDMKCWV4dHJhY3QgMiAwCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGE3NTY1MDUzIC8vIG1ldGhvZCAibmFtZWRUdXBsZSgpc3RyaW5nIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9uYW1lZFR1cGxlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJyCgoqcHJvY2Vzc19zdGF0aWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50Cgljb25jYXQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCXJldHN1YgoKKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50OgoJcHJvdG8gNCAzCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0Cgljb25jYXQKCWZyYW1lX2J1cnkgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0xIC8vIGVsZW1lbnQKCWR1cAoJbGVuCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCWJ0b2kKCSsKCWl0b2IKCWV4dHJhY3QgNiAyCglmcmFtZV9idXJ5IC0yIC8vIGhlYWQgb2Zmc2V0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJc3dhcAoJY29uY2F0CglmcmFtZV9idXJ5IC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestNestedArrayLengthInObject.approval.teal b/tests/contracts/artifacts/ABITestNestedArrayLengthInObject.approval.teal index 52cff6e71..adfa6ec0c 100644 --- a/tests/contracts/artifacts/ABITestNestedArrayLengthInObject.approval.teal +++ b/tests/contracts/artifacts/ABITestNestedArrayLengthInObject.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestNestedArrayLengthInObject.arc32.json b/tests/contracts/artifacts/ABITestNestedArrayLengthInObject.arc32.json index 2ccc570ef..10e41b609 100644 --- a/tests/contracts/artifacts/ABITestNestedArrayLengthInObject.arc32.json +++ b/tests/contracts/artifacts/ABITestNestedArrayLengthInObject.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gbmVzdGVkQXJyYXlMZW5ndGhJbk9iamVjdCgpdWludDY0CiphYmlfcm91dGVfbmVzdGVkQXJyYXlMZW5ndGhJbk9iamVjdDoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIG5lc3RlZEFycmF5TGVuZ3RoSW5PYmplY3QoKXVpbnQ2NAoJY2FsbHN1YiBuZXN0ZWRBcnJheUxlbmd0aEluT2JqZWN0CglpdG9iCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIG5lc3RlZEFycmF5TGVuZ3RoSW5PYmplY3QoKTogdWludDY0Cm5lc3RlZEFycmF5TGVuZ3RoSW5PYmplY3Q6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0MjYKCS8vIGE6IHsgZm9vOiBTdGF0aWNBcnJheTx1aW50OCwgNT4gfSA9IHsgZm9vOiBbMTEsIDIyLCAzMywgNDQsIDU1XSB9CglwdXNoYnl0ZXMgMHgwYjE2MjEyYzM3CglmcmFtZV9idXJ5IDAgLy8gYTogeyBmb286IFN0YXRpY0FycmF5PHVpbnQ4LCA1PiB9CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0MjgKCS8vIHJldHVybiBhLmZvby5sZW5ndGg7CglmcmFtZV9kaWcgMCAvLyBhOiB7IGZvbzogU3RhdGljQXJyYXk8dWludDgsIDU+IH0KCXB1c2hpbnQgNQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgwZDBiOWI0OSAvLyBtZXRob2QgIm5lc3RlZEFycmF5TGVuZ3RoSW5PYmplY3QoKXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfbmVzdGVkQXJyYXlMZW5ndGhJbk9iamVjdAoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gbmVzdGVkQXJyYXlMZW5ndGhJbk9iamVjdCgpdWludDY0CiphYmlfcm91dGVfbmVzdGVkQXJyYXlMZW5ndGhJbk9iamVjdDoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIG5lc3RlZEFycmF5TGVuZ3RoSW5PYmplY3QoKXVpbnQ2NAoJY2FsbHN1YiBuZXN0ZWRBcnJheUxlbmd0aEluT2JqZWN0CglpdG9iCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIG5lc3RlZEFycmF5TGVuZ3RoSW5PYmplY3QoKTogdWludDY0Cm5lc3RlZEFycmF5TGVuZ3RoSW5PYmplY3Q6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0MjYKCS8vIGE6IHsgZm9vOiBTdGF0aWNBcnJheTx1aW50OCwgNT4gfSA9IHsgZm9vOiBbMTEsIDIyLCAzMywgNDQsIDU1XSB9CglwdXNoYnl0ZXMgMHgwYjE2MjEyYzM3CglmcmFtZV9idXJ5IDAgLy8gYTogeyBmb286IFN0YXRpY0FycmF5PHVpbnQ4LCA1PiB9CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0MjgKCS8vIHJldHVybiBhLmZvby5sZW5ndGg7CglmcmFtZV9kaWcgMCAvLyBhOiB7IGZvbzogU3RhdGljQXJyYXk8dWludDgsIDU+IH0KCXB1c2hpbnQgNQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgwZDBiOWI0OSAvLyBtZXRob2QgIm5lc3RlZEFycmF5TGVuZ3RoSW5PYmplY3QoKXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfbmVzdGVkQXJyYXlMZW5ndGhJbk9iamVjdAoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestNestedArrayLengthInObject.arc56_draft.json b/tests/contracts/artifacts/ABITestNestedArrayLengthInObject.arc56_draft.json index dd1f5e915..195091fdb 100644 --- a/tests/contracts/artifacts/ABITestNestedArrayLengthInObject.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestNestedArrayLengthInObject.arc56_draft.json @@ -383,7 +383,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gbmVzdGVkQXJyYXlMZW5ndGhJbk9iamVjdCgpdWludDY0CiphYmlfcm91dGVfbmVzdGVkQXJyYXlMZW5ndGhJbk9iamVjdDoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIG5lc3RlZEFycmF5TGVuZ3RoSW5PYmplY3QoKXVpbnQ2NAoJY2FsbHN1YiBuZXN0ZWRBcnJheUxlbmd0aEluT2JqZWN0CglpdG9iCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIG5lc3RlZEFycmF5TGVuZ3RoSW5PYmplY3QoKTogdWludDY0Cm5lc3RlZEFycmF5TGVuZ3RoSW5PYmplY3Q6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0MjYKCS8vIGE6IHsgZm9vOiBTdGF0aWNBcnJheTx1aW50OCwgNT4gfSA9IHsgZm9vOiBbMTEsIDIyLCAzMywgNDQsIDU1XSB9CglwdXNoYnl0ZXMgMHgwYjE2MjEyYzM3CglmcmFtZV9idXJ5IDAgLy8gYTogeyBmb286IFN0YXRpY0FycmF5PHVpbnQ4LCA1PiB9CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0MjgKCS8vIHJldHVybiBhLmZvby5sZW5ndGg7CglmcmFtZV9kaWcgMCAvLyBhOiB7IGZvbzogU3RhdGljQXJyYXk8dWludDgsIDU+IH0KCXB1c2hpbnQgNQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgwZDBiOWI0OSAvLyBtZXRob2QgIm5lc3RlZEFycmF5TGVuZ3RoSW5PYmplY3QoKXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfbmVzdGVkQXJyYXlMZW5ndGhJbk9iamVjdAoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gbmVzdGVkQXJyYXlMZW5ndGhJbk9iamVjdCgpdWludDY0CiphYmlfcm91dGVfbmVzdGVkQXJyYXlMZW5ndGhJbk9iamVjdDoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIG5lc3RlZEFycmF5TGVuZ3RoSW5PYmplY3QoKXVpbnQ2NAoJY2FsbHN1YiBuZXN0ZWRBcnJheUxlbmd0aEluT2JqZWN0CglpdG9iCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIG5lc3RlZEFycmF5TGVuZ3RoSW5PYmplY3QoKTogdWludDY0Cm5lc3RlZEFycmF5TGVuZ3RoSW5PYmplY3Q6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0MjYKCS8vIGE6IHsgZm9vOiBTdGF0aWNBcnJheTx1aW50OCwgNT4gfSA9IHsgZm9vOiBbMTEsIDIyLCAzMywgNDQsIDU1XSB9CglwdXNoYnl0ZXMgMHgwYjE2MjEyYzM3CglmcmFtZV9idXJ5IDAgLy8gYTogeyBmb286IFN0YXRpY0FycmF5PHVpbnQ4LCA1PiB9CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0MjgKCS8vIHJldHVybiBhLmZvby5sZW5ndGg7CglmcmFtZV9kaWcgMCAvLyBhOiB7IGZvbzogU3RhdGljQXJyYXk8dWludDgsIDU+IH0KCXB1c2hpbnQgNQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgwZDBiOWI0OSAvLyBtZXRob2QgIm5lc3RlZEFycmF5TGVuZ3RoSW5PYmplY3QoKXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfbmVzdGVkQXJyYXlMZW5ndGhJbk9iamVjdAoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestNestedArrayLengthInObjectVariable.approval.teal b/tests/contracts/artifacts/ABITestNestedArrayLengthInObjectVariable.approval.teal index 0fe4b7185..dcf7c283d 100644 --- a/tests/contracts/artifacts/ABITestNestedArrayLengthInObjectVariable.approval.teal +++ b/tests/contracts/artifacts/ABITestNestedArrayLengthInObjectVariable.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestNestedArrayLengthInObjectVariable.arc32.json b/tests/contracts/artifacts/ABITestNestedArrayLengthInObjectVariable.arc32.json index 3fe7487d7..24fc4c81c 100644 --- a/tests/contracts/artifacts/ABITestNestedArrayLengthInObjectVariable.arc32.json +++ b/tests/contracts/artifacts/ABITestNestedArrayLengthInObjectVariable.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gbmVzdGVkQXJyYXlMZW5ndGhJbk9iamVjdFZhcmlhYmxlKCl1aW50NjQKKmFiaV9yb3V0ZV9uZXN0ZWRBcnJheUxlbmd0aEluT2JqZWN0VmFyaWFibGU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBuZXN0ZWRBcnJheUxlbmd0aEluT2JqZWN0VmFyaWFibGUoKXVpbnQ2NAoJY2FsbHN1YiBuZXN0ZWRBcnJheUxlbmd0aEluT2JqZWN0VmFyaWFibGUKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gbmVzdGVkQXJyYXlMZW5ndGhJbk9iamVjdFZhcmlhYmxlKCk6IHVpbnQ2NApuZXN0ZWRBcnJheUxlbmd0aEluT2JqZWN0VmFyaWFibGU6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0MzQKCS8vIGE6IHsgZm9vOiBTdGF0aWNBcnJheTx1aW50OCwgNT4gfSA9IHsgZm9vOiBbMTEsIDIyLCAzMywgNDQsIDU1XSB9CglwdXNoYnl0ZXMgMHgwYjE2MjEyYzM3CglmcmFtZV9idXJ5IDAgLy8gYTogeyBmb286IFN0YXRpY0FycmF5PHVpbnQ4LCA1PiB9CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0MzcKCS8vIHJldHVybiBiLmxlbmd0aDsKCXB1c2hpbnQgNQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg4NjA4ZTBkNiAvLyBtZXRob2QgIm5lc3RlZEFycmF5TGVuZ3RoSW5PYmplY3RWYXJpYWJsZSgpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9uZXN0ZWRBcnJheUxlbmd0aEluT2JqZWN0VmFyaWFibGUKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gbmVzdGVkQXJyYXlMZW5ndGhJbk9iamVjdFZhcmlhYmxlKCl1aW50NjQKKmFiaV9yb3V0ZV9uZXN0ZWRBcnJheUxlbmd0aEluT2JqZWN0VmFyaWFibGU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBuZXN0ZWRBcnJheUxlbmd0aEluT2JqZWN0VmFyaWFibGUoKXVpbnQ2NAoJY2FsbHN1YiBuZXN0ZWRBcnJheUxlbmd0aEluT2JqZWN0VmFyaWFibGUKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gbmVzdGVkQXJyYXlMZW5ndGhJbk9iamVjdFZhcmlhYmxlKCk6IHVpbnQ2NApuZXN0ZWRBcnJheUxlbmd0aEluT2JqZWN0VmFyaWFibGU6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0MzQKCS8vIGE6IHsgZm9vOiBTdGF0aWNBcnJheTx1aW50OCwgNT4gfSA9IHsgZm9vOiBbMTEsIDIyLCAzMywgNDQsIDU1XSB9CglwdXNoYnl0ZXMgMHgwYjE2MjEyYzM3CglmcmFtZV9idXJ5IDAgLy8gYTogeyBmb286IFN0YXRpY0FycmF5PHVpbnQ4LCA1PiB9CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0MzcKCS8vIHJldHVybiBiLmxlbmd0aDsKCXB1c2hpbnQgNQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg4NjA4ZTBkNiAvLyBtZXRob2QgIm5lc3RlZEFycmF5TGVuZ3RoSW5PYmplY3RWYXJpYWJsZSgpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9uZXN0ZWRBcnJheUxlbmd0aEluT2JqZWN0VmFyaWFibGUKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestNestedArrayLengthInObjectVariable.arc56_draft.json b/tests/contracts/artifacts/ABITestNestedArrayLengthInObjectVariable.arc56_draft.json index 919e963fc..0a450334c 100644 --- a/tests/contracts/artifacts/ABITestNestedArrayLengthInObjectVariable.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestNestedArrayLengthInObjectVariable.arc56_draft.json @@ -375,7 +375,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gbmVzdGVkQXJyYXlMZW5ndGhJbk9iamVjdFZhcmlhYmxlKCl1aW50NjQKKmFiaV9yb3V0ZV9uZXN0ZWRBcnJheUxlbmd0aEluT2JqZWN0VmFyaWFibGU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBuZXN0ZWRBcnJheUxlbmd0aEluT2JqZWN0VmFyaWFibGUoKXVpbnQ2NAoJY2FsbHN1YiBuZXN0ZWRBcnJheUxlbmd0aEluT2JqZWN0VmFyaWFibGUKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gbmVzdGVkQXJyYXlMZW5ndGhJbk9iamVjdFZhcmlhYmxlKCk6IHVpbnQ2NApuZXN0ZWRBcnJheUxlbmd0aEluT2JqZWN0VmFyaWFibGU6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0MzQKCS8vIGE6IHsgZm9vOiBTdGF0aWNBcnJheTx1aW50OCwgNT4gfSA9IHsgZm9vOiBbMTEsIDIyLCAzMywgNDQsIDU1XSB9CglwdXNoYnl0ZXMgMHgwYjE2MjEyYzM3CglmcmFtZV9idXJ5IDAgLy8gYTogeyBmb286IFN0YXRpY0FycmF5PHVpbnQ4LCA1PiB9CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0MzcKCS8vIHJldHVybiBiLmxlbmd0aDsKCXB1c2hpbnQgNQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg4NjA4ZTBkNiAvLyBtZXRob2QgIm5lc3RlZEFycmF5TGVuZ3RoSW5PYmplY3RWYXJpYWJsZSgpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9uZXN0ZWRBcnJheUxlbmd0aEluT2JqZWN0VmFyaWFibGUKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gbmVzdGVkQXJyYXlMZW5ndGhJbk9iamVjdFZhcmlhYmxlKCl1aW50NjQKKmFiaV9yb3V0ZV9uZXN0ZWRBcnJheUxlbmd0aEluT2JqZWN0VmFyaWFibGU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBuZXN0ZWRBcnJheUxlbmd0aEluT2JqZWN0VmFyaWFibGUoKXVpbnQ2NAoJY2FsbHN1YiBuZXN0ZWRBcnJheUxlbmd0aEluT2JqZWN0VmFyaWFibGUKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gbmVzdGVkQXJyYXlMZW5ndGhJbk9iamVjdFZhcmlhYmxlKCk6IHVpbnQ2NApuZXN0ZWRBcnJheUxlbmd0aEluT2JqZWN0VmFyaWFibGU6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0MzQKCS8vIGE6IHsgZm9vOiBTdGF0aWNBcnJheTx1aW50OCwgNT4gfSA9IHsgZm9vOiBbMTEsIDIyLCAzMywgNDQsIDU1XSB9CglwdXNoYnl0ZXMgMHgwYjE2MjEyYzM3CglmcmFtZV9idXJ5IDAgLy8gYTogeyBmb286IFN0YXRpY0FycmF5PHVpbnQ4LCA1PiB9CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0MzcKCS8vIHJldHVybiBiLmxlbmd0aDsKCXB1c2hpbnQgNQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg4NjA4ZTBkNiAvLyBtZXRob2QgIm5lc3RlZEFycmF5TGVuZ3RoSW5PYmplY3RWYXJpYWJsZSgpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9uZXN0ZWRBcnJheUxlbmd0aEluT2JqZWN0VmFyaWFibGUKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestNestedArrayRef.approval.teal b/tests/contracts/artifacts/ABITestNestedArrayRef.approval.teal index a3c041a1f..1d8ed767e 100644 --- a/tests/contracts/artifacts/ABITestNestedArrayRef.approval.teal +++ b/tests/contracts/artifacts/ABITestNestedArrayRef.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestNestedArrayRef.arc32.json b/tests/contracts/artifacts/ABITestNestedArrayRef.arc32.json index e68a00395..606c8cc34 100644 --- a/tests/contracts/artifacts/ABITestNestedArrayRef.arc32.json +++ b/tests/contracts/artifacts/ABITestNestedArrayRef.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gbmVzdGVkQXJyYXlSZWYoKXVpbnQ4WzJdWzJdCiphYmlfcm91dGVfbmVzdGVkQXJyYXlSZWY6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBuZXN0ZWRBcnJheVJlZigpdWludDhbMl1bMl0KCWNhbGxzdWIgbmVzdGVkQXJyYXlSZWYKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gbmVzdGVkQXJyYXlSZWYoKTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDw4PiwgMj4sIDI+Cm5lc3RlZEFycmF5UmVmOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo3NjEKCS8vIGE6IFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQ8OD4sIDI+LCAyPiA9IFsKCS8vICAgICAgIFsxLCAyXSwKCS8vICAgICAgIFszLCA0XSwKCS8vICAgICBdCglwdXNoYnl0ZXMgMHgwMTAyMDMwNAoJZnJhbWVfYnVyeSAwIC8vIGE6IFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQ8OD4sIDI+LCAyPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo3NjUKCS8vIGIgPSBhWzFdCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NzY3CgkvLyBiWzFdID0gNSBhcyB1aW50PDg+CglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50PDg+LCAyPiwgMj4KCXB1c2hieXRlcyAweDA1CglyZXBsYWNlMiAzCglmcmFtZV9idXJ5IDAgLy8gYjogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDw4PiwgMj4sIDI+CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjc2OQoJLy8gcmV0dXJuIGE7CglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50PDg+LCAyPiwgMj4KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MjI1MmUwZTcgLy8gbWV0aG9kICJuZXN0ZWRBcnJheVJlZigpdWludDhbMl1bMl0iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX25lc3RlZEFycmF5UmVmCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gbmVzdGVkQXJyYXlSZWYoKXVpbnQ4WzJdWzJdCiphYmlfcm91dGVfbmVzdGVkQXJyYXlSZWY6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBuZXN0ZWRBcnJheVJlZigpdWludDhbMl1bMl0KCWNhbGxzdWIgbmVzdGVkQXJyYXlSZWYKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gbmVzdGVkQXJyYXlSZWYoKTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDw4PiwgMj4sIDI+Cm5lc3RlZEFycmF5UmVmOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo3NjEKCS8vIGE6IFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQ8OD4sIDI+LCAyPiA9IFsKCS8vICAgICAgIFsxLCAyXSwKCS8vICAgICAgIFszLCA0XSwKCS8vICAgICBdCglwdXNoYnl0ZXMgMHgwMTAyMDMwNAoJZnJhbWVfYnVyeSAwIC8vIGE6IFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQ8OD4sIDI+LCAyPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo3NjUKCS8vIGIgPSBhWzFdCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NzY3CgkvLyBiWzFdID0gNSBhcyB1aW50PDg+CglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50PDg+LCAyPiwgMj4KCXB1c2hieXRlcyAweDA1CglyZXBsYWNlMiAzCglmcmFtZV9idXJ5IDAgLy8gYjogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDw4PiwgMj4sIDI+CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjc2OQoJLy8gcmV0dXJuIGE7CglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50PDg+LCAyPiwgMj4KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MjI1MmUwZTcgLy8gbWV0aG9kICJuZXN0ZWRBcnJheVJlZigpdWludDhbMl1bMl0iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX25lc3RlZEFycmF5UmVmCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestNestedArrayRef.arc56_draft.json b/tests/contracts/artifacts/ABITestNestedArrayRef.arc56_draft.json index fcbc73fa4..dc691ea46 100644 --- a/tests/contracts/artifacts/ABITestNestedArrayRef.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestNestedArrayRef.arc56_draft.json @@ -400,7 +400,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gbmVzdGVkQXJyYXlSZWYoKXVpbnQ4WzJdWzJdCiphYmlfcm91dGVfbmVzdGVkQXJyYXlSZWY6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBuZXN0ZWRBcnJheVJlZigpdWludDhbMl1bMl0KCWNhbGxzdWIgbmVzdGVkQXJyYXlSZWYKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gbmVzdGVkQXJyYXlSZWYoKTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDw4PiwgMj4sIDI+Cm5lc3RlZEFycmF5UmVmOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo3NjEKCS8vIGE6IFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQ8OD4sIDI+LCAyPiA9IFsKCS8vICAgICAgIFsxLCAyXSwKCS8vICAgICAgIFszLCA0XSwKCS8vICAgICBdCglwdXNoYnl0ZXMgMHgwMTAyMDMwNAoJZnJhbWVfYnVyeSAwIC8vIGE6IFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQ8OD4sIDI+LCAyPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo3NjUKCS8vIGIgPSBhWzFdCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NzY3CgkvLyBiWzFdID0gNSBhcyB1aW50PDg+CglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50PDg+LCAyPiwgMj4KCXB1c2hieXRlcyAweDA1CglyZXBsYWNlMiAzCglmcmFtZV9idXJ5IDAgLy8gYjogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDw4PiwgMj4sIDI+CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjc2OQoJLy8gcmV0dXJuIGE7CglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50PDg+LCAyPiwgMj4KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MjI1MmUwZTcgLy8gbWV0aG9kICJuZXN0ZWRBcnJheVJlZigpdWludDhbMl1bMl0iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX25lc3RlZEFycmF5UmVmCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gbmVzdGVkQXJyYXlSZWYoKXVpbnQ4WzJdWzJdCiphYmlfcm91dGVfbmVzdGVkQXJyYXlSZWY6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBuZXN0ZWRBcnJheVJlZigpdWludDhbMl1bMl0KCWNhbGxzdWIgbmVzdGVkQXJyYXlSZWYKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gbmVzdGVkQXJyYXlSZWYoKTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDw4PiwgMj4sIDI+Cm5lc3RlZEFycmF5UmVmOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo3NjEKCS8vIGE6IFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQ8OD4sIDI+LCAyPiA9IFsKCS8vICAgICAgIFsxLCAyXSwKCS8vICAgICAgIFszLCA0XSwKCS8vICAgICBdCglwdXNoYnl0ZXMgMHgwMTAyMDMwNAoJZnJhbWVfYnVyeSAwIC8vIGE6IFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQ8OD4sIDI+LCAyPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo3NjUKCS8vIGIgPSBhWzFdCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NzY3CgkvLyBiWzFdID0gNSBhcyB1aW50PDg+CglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50PDg+LCAyPiwgMj4KCXB1c2hieXRlcyAweDA1CglyZXBsYWNlMiAzCglmcmFtZV9idXJ5IDAgLy8gYjogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDw4PiwgMj4sIDI+CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjc2OQoJLy8gcmV0dXJuIGE7CglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50PDg+LCAyPiwgMj4KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MjI1MmUwZTcgLy8gbWV0aG9kICJuZXN0ZWRBcnJheVJlZigpdWludDhbMl1bMl0iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX25lc3RlZEFycmF5UmVmCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestNestedObject.approval.teal b/tests/contracts/artifacts/ABITestNestedObject.approval.teal index 96478b80a..3161e1ce6 100644 --- a/tests/contracts/artifacts/ABITestNestedObject.approval.teal +++ b/tests/contracts/artifacts/ABITestNestedObject.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestNestedObject.arc32.json b/tests/contracts/artifacts/ABITestNestedObject.arc32.json index 8cf8ce151..84b6a23da 100644 --- a/tests/contracts/artifacts/ABITestNestedObject.arc32.json +++ b/tests/contracts/artifacts/ABITestNestedObject.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gbmVzdGVkT2JqZWN0KCl1aW50NjQKKmFiaV9yb3V0ZV9uZXN0ZWRPYmplY3Q6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBuZXN0ZWRPYmplY3QoKXVpbnQ2NAoJY2FsbHN1YiBuZXN0ZWRPYmplY3QKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gbmVzdGVkT2JqZWN0KCk6IHVpbnQ2NApuZXN0ZWRPYmplY3Q6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEwODYKCS8vIGE6IHsgYjogeyBjOiB7IGQ6IHVpbnQ2NCB9IH0gfSA9IHsgYjogeyBjOiB7IGQ6IDEgfSB9IH0KCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDEKCWZyYW1lX2J1cnkgMCAvLyBhOiB7IGI6IHsgYzogeyBkOiB1aW50NjQgfSB9IH0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTA4NwoJLy8gYS5iLmMuZCA9IDIKCWZyYW1lX2RpZyAwIC8vIGE6IHsgYjogeyBjOiB7IGQ6IHVpbnQ2NCB9IH0gfQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMgoJcmVwbGFjZTIgMAoJZnJhbWVfYnVyeSAwIC8vIGE6IHsgYjogeyBjOiB7IGQ6IHVpbnQ2NCB9IH0gfQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMDg4CgkvLyByZXR1cm4gYS5iLmMuZDsKCWZyYW1lX2RpZyAwIC8vIGE6IHsgYjogeyBjOiB7IGQ6IHVpbnQ2NCB9IH0gfQoJZXh0cmFjdCAwIDgKCWJ0b2kKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MmMzYzdjMmEgLy8gbWV0aG9kICJuZXN0ZWRPYmplY3QoKXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfbmVzdGVkT2JqZWN0CgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gbmVzdGVkT2JqZWN0KCl1aW50NjQKKmFiaV9yb3V0ZV9uZXN0ZWRPYmplY3Q6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBuZXN0ZWRPYmplY3QoKXVpbnQ2NAoJY2FsbHN1YiBuZXN0ZWRPYmplY3QKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gbmVzdGVkT2JqZWN0KCk6IHVpbnQ2NApuZXN0ZWRPYmplY3Q6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEwODYKCS8vIGE6IHsgYjogeyBjOiB7IGQ6IHVpbnQ2NCB9IH0gfSA9IHsgYjogeyBjOiB7IGQ6IDEgfSB9IH0KCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDEKCWZyYW1lX2J1cnkgMCAvLyBhOiB7IGI6IHsgYzogeyBkOiB1aW50NjQgfSB9IH0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTA4NwoJLy8gYS5iLmMuZCA9IDIKCWZyYW1lX2RpZyAwIC8vIGE6IHsgYjogeyBjOiB7IGQ6IHVpbnQ2NCB9IH0gfQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMgoJcmVwbGFjZTIgMAoJZnJhbWVfYnVyeSAwIC8vIGE6IHsgYjogeyBjOiB7IGQ6IHVpbnQ2NCB9IH0gfQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMDg4CgkvLyByZXR1cm4gYS5iLmMuZDsKCWZyYW1lX2RpZyAwIC8vIGE6IHsgYjogeyBjOiB7IGQ6IHVpbnQ2NCB9IH0gfQoJZXh0cmFjdCAwIDgKCWJ0b2kKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MmMzYzdjMmEgLy8gbWV0aG9kICJuZXN0ZWRPYmplY3QoKXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfbmVzdGVkT2JqZWN0CgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestNestedObject.arc56_draft.json b/tests/contracts/artifacts/ABITestNestedObject.arc56_draft.json index c8b880e7f..ddb8a7360 100644 --- a/tests/contracts/artifacts/ABITestNestedObject.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestNestedObject.arc56_draft.json @@ -434,7 +434,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gbmVzdGVkT2JqZWN0KCl1aW50NjQKKmFiaV9yb3V0ZV9uZXN0ZWRPYmplY3Q6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBuZXN0ZWRPYmplY3QoKXVpbnQ2NAoJY2FsbHN1YiBuZXN0ZWRPYmplY3QKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gbmVzdGVkT2JqZWN0KCk6IHVpbnQ2NApuZXN0ZWRPYmplY3Q6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEwODYKCS8vIGE6IHsgYjogeyBjOiB7IGQ6IHVpbnQ2NCB9IH0gfSA9IHsgYjogeyBjOiB7IGQ6IDEgfSB9IH0KCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDEKCWZyYW1lX2J1cnkgMCAvLyBhOiB7IGI6IHsgYzogeyBkOiB1aW50NjQgfSB9IH0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTA4NwoJLy8gYS5iLmMuZCA9IDIKCWZyYW1lX2RpZyAwIC8vIGE6IHsgYjogeyBjOiB7IGQ6IHVpbnQ2NCB9IH0gfQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMgoJcmVwbGFjZTIgMAoJZnJhbWVfYnVyeSAwIC8vIGE6IHsgYjogeyBjOiB7IGQ6IHVpbnQ2NCB9IH0gfQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMDg4CgkvLyByZXR1cm4gYS5iLmMuZDsKCWZyYW1lX2RpZyAwIC8vIGE6IHsgYjogeyBjOiB7IGQ6IHVpbnQ2NCB9IH0gfQoJZXh0cmFjdCAwIDgKCWJ0b2kKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MmMzYzdjMmEgLy8gbWV0aG9kICJuZXN0ZWRPYmplY3QoKXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfbmVzdGVkT2JqZWN0CgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gbmVzdGVkT2JqZWN0KCl1aW50NjQKKmFiaV9yb3V0ZV9uZXN0ZWRPYmplY3Q6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBuZXN0ZWRPYmplY3QoKXVpbnQ2NAoJY2FsbHN1YiBuZXN0ZWRPYmplY3QKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gbmVzdGVkT2JqZWN0KCk6IHVpbnQ2NApuZXN0ZWRPYmplY3Q6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEwODYKCS8vIGE6IHsgYjogeyBjOiB7IGQ6IHVpbnQ2NCB9IH0gfSA9IHsgYjogeyBjOiB7IGQ6IDEgfSB9IH0KCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDEKCWZyYW1lX2J1cnkgMCAvLyBhOiB7IGI6IHsgYzogeyBkOiB1aW50NjQgfSB9IH0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTA4NwoJLy8gYS5iLmMuZCA9IDIKCWZyYW1lX2RpZyAwIC8vIGE6IHsgYjogeyBjOiB7IGQ6IHVpbnQ2NCB9IH0gfQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMgoJcmVwbGFjZTIgMAoJZnJhbWVfYnVyeSAwIC8vIGE6IHsgYjogeyBjOiB7IGQ6IHVpbnQ2NCB9IH0gfQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMDg4CgkvLyByZXR1cm4gYS5iLmMuZDsKCWZyYW1lX2RpZyAwIC8vIGE6IHsgYjogeyBjOiB7IGQ6IHVpbnQ2NCB9IH0gfQoJZXh0cmFjdCAwIDgKCWJ0b2kKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MmMzYzdjMmEgLy8gbWV0aG9kICJuZXN0ZWRPYmplY3QoKXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfbmVzdGVkT2JqZWN0CgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestNestedObjectType.approval.teal b/tests/contracts/artifacts/ABITestNestedObjectType.approval.teal index d47521f8d..5acb80314 100644 --- a/tests/contracts/artifacts/ABITestNestedObjectType.approval.teal +++ b/tests/contracts/artifacts/ABITestNestedObjectType.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestNestedObjectType.arc32.json b/tests/contracts/artifacts/ABITestNestedObjectType.arc32.json index aaf9b842e..3113554e0 100644 --- a/tests/contracts/artifacts/ABITestNestedObjectType.arc32.json +++ b/tests/contracts/artifacts/ABITestNestedObjectType.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gbmVzdGVkT2JqZWN0VHlwZSgpdWludDY0CiphYmlfcm91dGVfbmVzdGVkT2JqZWN0VHlwZToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIG5lc3RlZE9iamVjdFR5cGUoKXVpbnQ2NAoJY2FsbHN1YiBuZXN0ZWRPYmplY3RUeXBlCglpdG9iCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIG5lc3RlZE9iamVjdFR5cGUoKTogdWludDY0Cm5lc3RlZE9iamVjdFR5cGU6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEwOTYKCS8vIGE6IFQ0ID0geyBiOiB7IGM6IHsgZDogMSB9IH0gfQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMQoJZnJhbWVfYnVyeSAwIC8vIGE6IFQ0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEwOTcKCS8vIGEuYi5jLmQgPSAyCglmcmFtZV9kaWcgMCAvLyBhOiBUNAoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMgoJcmVwbGFjZTIgMAoJZnJhbWVfYnVyeSAwIC8vIGE6IFQ0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEwOTgKCS8vIHJldHVybiBhLmIuYy5kOwoJZnJhbWVfZGlnIDAgLy8gYTogVDQKCWV4dHJhY3QgMCA4CglidG9pCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGVlMjY0YTE4IC8vIG1ldGhvZCAibmVzdGVkT2JqZWN0VHlwZSgpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9uZXN0ZWRPYmplY3RUeXBlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gbmVzdGVkT2JqZWN0VHlwZSgpdWludDY0CiphYmlfcm91dGVfbmVzdGVkT2JqZWN0VHlwZToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIG5lc3RlZE9iamVjdFR5cGUoKXVpbnQ2NAoJY2FsbHN1YiBuZXN0ZWRPYmplY3RUeXBlCglpdG9iCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIG5lc3RlZE9iamVjdFR5cGUoKTogdWludDY0Cm5lc3RlZE9iamVjdFR5cGU6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEwOTYKCS8vIGE6IFQ0ID0geyBiOiB7IGM6IHsgZDogMSB9IH0gfQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMQoJZnJhbWVfYnVyeSAwIC8vIGE6IFQ0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEwOTcKCS8vIGEuYi5jLmQgPSAyCglmcmFtZV9kaWcgMCAvLyBhOiBUNAoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMgoJcmVwbGFjZTIgMAoJZnJhbWVfYnVyeSAwIC8vIGE6IFQ0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEwOTgKCS8vIHJldHVybiBhLmIuYy5kOwoJZnJhbWVfZGlnIDAgLy8gYTogVDQKCWV4dHJhY3QgMCA4CglidG9pCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGVlMjY0YTE4IC8vIG1ldGhvZCAibmVzdGVkT2JqZWN0VHlwZSgpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9uZXN0ZWRPYmplY3RUeXBlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestNestedObjectType.arc56_draft.json b/tests/contracts/artifacts/ABITestNestedObjectType.arc56_draft.json index 5514323e4..95690f1a8 100644 --- a/tests/contracts/artifacts/ABITestNestedObjectType.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestNestedObjectType.arc56_draft.json @@ -434,7 +434,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gbmVzdGVkT2JqZWN0VHlwZSgpdWludDY0CiphYmlfcm91dGVfbmVzdGVkT2JqZWN0VHlwZToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIG5lc3RlZE9iamVjdFR5cGUoKXVpbnQ2NAoJY2FsbHN1YiBuZXN0ZWRPYmplY3RUeXBlCglpdG9iCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIG5lc3RlZE9iamVjdFR5cGUoKTogdWludDY0Cm5lc3RlZE9iamVjdFR5cGU6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEwOTYKCS8vIGE6IFQ0ID0geyBiOiB7IGM6IHsgZDogMSB9IH0gfQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMQoJZnJhbWVfYnVyeSAwIC8vIGE6IFQ0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEwOTcKCS8vIGEuYi5jLmQgPSAyCglmcmFtZV9kaWcgMCAvLyBhOiBUNAoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMgoJcmVwbGFjZTIgMAoJZnJhbWVfYnVyeSAwIC8vIGE6IFQ0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEwOTgKCS8vIHJldHVybiBhLmIuYy5kOwoJZnJhbWVfZGlnIDAgLy8gYTogVDQKCWV4dHJhY3QgMCA4CglidG9pCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGVlMjY0YTE4IC8vIG1ldGhvZCAibmVzdGVkT2JqZWN0VHlwZSgpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9uZXN0ZWRPYmplY3RUeXBlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gbmVzdGVkT2JqZWN0VHlwZSgpdWludDY0CiphYmlfcm91dGVfbmVzdGVkT2JqZWN0VHlwZToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIG5lc3RlZE9iamVjdFR5cGUoKXVpbnQ2NAoJY2FsbHN1YiBuZXN0ZWRPYmplY3RUeXBlCglpdG9iCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIG5lc3RlZE9iamVjdFR5cGUoKTogdWludDY0Cm5lc3RlZE9iamVjdFR5cGU6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEwOTYKCS8vIGE6IFQ0ID0geyBiOiB7IGM6IHsgZDogMSB9IH0gfQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMQoJZnJhbWVfYnVyeSAwIC8vIGE6IFQ0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEwOTcKCS8vIGEuYi5jLmQgPSAyCglmcmFtZV9kaWcgMCAvLyBhOiBUNAoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMgoJcmVwbGFjZTIgMAoJZnJhbWVfYnVyeSAwIC8vIGE6IFQ0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEwOTgKCS8vIHJldHVybiBhLmIuYy5kOwoJZnJhbWVfZGlnIDAgLy8gYTogVDQKCWV4dHJhY3QgMCA4CglidG9pCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGVlMjY0YTE4IC8vIG1ldGhvZCAibmVzdGVkT2JqZWN0VHlwZSgpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9uZXN0ZWRPYmplY3RUeXBlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestNestedStaticArray.approval.teal b/tests/contracts/artifacts/ABITestNestedStaticArray.approval.teal index ec2f4f5cb..0c335e5c1 100644 --- a/tests/contracts/artifacts/ABITestNestedStaticArray.approval.teal +++ b/tests/contracts/artifacts/ABITestNestedStaticArray.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestNestedStaticArray.arc32.json b/tests/contracts/artifacts/ABITestNestedStaticArray.arc32.json index 67d620687..e5d0a4a87 100644 --- a/tests/contracts/artifacts/ABITestNestedStaticArray.arc32.json +++ b/tests/contracts/artifacts/ABITestNestedStaticArray.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gbmVzdGVkU3RhdGljQXJyYXkoKXVpbnQ2NAoqYWJpX3JvdXRlX25lc3RlZFN0YXRpY0FycmF5OgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgbmVzdGVkU3RhdGljQXJyYXkoKXVpbnQ2NAoJY2FsbHN1YiBuZXN0ZWRTdGF0aWNBcnJheQoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBuZXN0ZWRTdGF0aWNBcnJheSgpOiB1aW50NjQKbmVzdGVkU3RhdGljQXJyYXk6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE5OAoJLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDY0LCAzPiwgMz4gPSBbCgkvLyAgICAgICBbMTEsIDIyLCAzM10sCgkvLyAgICAgICBbNDQsIDU1LCA2Nl0sCgkvLyAgICAgICBbNzcsIDg4LCA5OV0sCgkvLyAgICAgXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwYjAwMDAwMDAwMDAwMDAwMTYwMDAwMDAwMDAwMDAwMDIxMDAwMDAwMDAwMDAwMDAyYzAwMDAwMDAwMDAwMDAwMzcwMDAwMDAwMDAwMDAwMDQyMDAwMDAwMDAwMDAwMDA0ZDAwMDAwMDAwMDAwMDAwNTgwMDAwMDAwMDAwMDAwMDYzCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDY0LCAzPiwgMz4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MjA0CgkvLyByZXR1cm4gYVsxXVsxXTsKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4sIDM+CglleHRyYWN0IDMyIDgKCWJ0b2kKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4M2UzMDdjNTUgLy8gbWV0aG9kICJuZXN0ZWRTdGF0aWNBcnJheSgpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9uZXN0ZWRTdGF0aWNBcnJheQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gbmVzdGVkU3RhdGljQXJyYXkoKXVpbnQ2NAoqYWJpX3JvdXRlX25lc3RlZFN0YXRpY0FycmF5OgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgbmVzdGVkU3RhdGljQXJyYXkoKXVpbnQ2NAoJY2FsbHN1YiBuZXN0ZWRTdGF0aWNBcnJheQoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBuZXN0ZWRTdGF0aWNBcnJheSgpOiB1aW50NjQKbmVzdGVkU3RhdGljQXJyYXk6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE5OAoJLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDY0LCAzPiwgMz4gPSBbCgkvLyAgICAgICBbMTEsIDIyLCAzM10sCgkvLyAgICAgICBbNDQsIDU1LCA2Nl0sCgkvLyAgICAgICBbNzcsIDg4LCA5OV0sCgkvLyAgICAgXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwYjAwMDAwMDAwMDAwMDAwMTYwMDAwMDAwMDAwMDAwMDIxMDAwMDAwMDAwMDAwMDAyYzAwMDAwMDAwMDAwMDAwMzcwMDAwMDAwMDAwMDAwMDQyMDAwMDAwMDAwMDAwMDA0ZDAwMDAwMDAwMDAwMDAwNTgwMDAwMDAwMDAwMDAwMDYzCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDY0LCAzPiwgMz4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MjA0CgkvLyByZXR1cm4gYVsxXVsxXTsKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4sIDM+CglleHRyYWN0IDMyIDgKCWJ0b2kKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4M2UzMDdjNTUgLy8gbWV0aG9kICJuZXN0ZWRTdGF0aWNBcnJheSgpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9uZXN0ZWRTdGF0aWNBcnJheQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestNestedStaticArray.arc56_draft.json b/tests/contracts/artifacts/ABITestNestedStaticArray.arc56_draft.json index 353f71db3..0de04b6df 100644 --- a/tests/contracts/artifacts/ABITestNestedStaticArray.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestNestedStaticArray.arc56_draft.json @@ -458,7 +458,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gbmVzdGVkU3RhdGljQXJyYXkoKXVpbnQ2NAoqYWJpX3JvdXRlX25lc3RlZFN0YXRpY0FycmF5OgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgbmVzdGVkU3RhdGljQXJyYXkoKXVpbnQ2NAoJY2FsbHN1YiBuZXN0ZWRTdGF0aWNBcnJheQoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBuZXN0ZWRTdGF0aWNBcnJheSgpOiB1aW50NjQKbmVzdGVkU3RhdGljQXJyYXk6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE5OAoJLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDY0LCAzPiwgMz4gPSBbCgkvLyAgICAgICBbMTEsIDIyLCAzM10sCgkvLyAgICAgICBbNDQsIDU1LCA2Nl0sCgkvLyAgICAgICBbNzcsIDg4LCA5OV0sCgkvLyAgICAgXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwYjAwMDAwMDAwMDAwMDAwMTYwMDAwMDAwMDAwMDAwMDIxMDAwMDAwMDAwMDAwMDAyYzAwMDAwMDAwMDAwMDAwMzcwMDAwMDAwMDAwMDAwMDQyMDAwMDAwMDAwMDAwMDA0ZDAwMDAwMDAwMDAwMDAwNTgwMDAwMDAwMDAwMDAwMDYzCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDY0LCAzPiwgMz4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MjA0CgkvLyByZXR1cm4gYVsxXVsxXTsKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4sIDM+CglleHRyYWN0IDMyIDgKCWJ0b2kKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4M2UzMDdjNTUgLy8gbWV0aG9kICJuZXN0ZWRTdGF0aWNBcnJheSgpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9uZXN0ZWRTdGF0aWNBcnJheQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gbmVzdGVkU3RhdGljQXJyYXkoKXVpbnQ2NAoqYWJpX3JvdXRlX25lc3RlZFN0YXRpY0FycmF5OgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgbmVzdGVkU3RhdGljQXJyYXkoKXVpbnQ2NAoJY2FsbHN1YiBuZXN0ZWRTdGF0aWNBcnJheQoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBuZXN0ZWRTdGF0aWNBcnJheSgpOiB1aW50NjQKbmVzdGVkU3RhdGljQXJyYXk6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE5OAoJLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDY0LCAzPiwgMz4gPSBbCgkvLyAgICAgICBbMTEsIDIyLCAzM10sCgkvLyAgICAgICBbNDQsIDU1LCA2Nl0sCgkvLyAgICAgICBbNzcsIDg4LCA5OV0sCgkvLyAgICAgXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwYjAwMDAwMDAwMDAwMDAwMTYwMDAwMDAwMDAwMDAwMDIxMDAwMDAwMDAwMDAwMDAyYzAwMDAwMDAwMDAwMDAwMzcwMDAwMDAwMDAwMDAwMDQyMDAwMDAwMDAwMDAwMDA0ZDAwMDAwMDAwMDAwMDAwNTgwMDAwMDAwMDAwMDAwMDYzCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDY0LCAzPiwgMz4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MjA0CgkvLyByZXR1cm4gYVsxXVsxXTsKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4sIDM+CglleHRyYWN0IDMyIDgKCWJ0b2kKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4M2UzMDdjNTUgLy8gbWV0aG9kICJuZXN0ZWRTdGF0aWNBcnJheSgpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9uZXN0ZWRTdGF0aWNBcnJheQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestNestedStaticArrayLength.approval.teal b/tests/contracts/artifacts/ABITestNestedStaticArrayLength.approval.teal index bf123a7fe..22227e96d 100644 --- a/tests/contracts/artifacts/ABITestNestedStaticArrayLength.approval.teal +++ b/tests/contracts/artifacts/ABITestNestedStaticArrayLength.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestNestedStaticArrayLength.arc32.json b/tests/contracts/artifacts/ABITestNestedStaticArrayLength.arc32.json index 74c5c0690..afc29a9da 100644 --- a/tests/contracts/artifacts/ABITestNestedStaticArrayLength.arc32.json +++ b/tests/contracts/artifacts/ABITestNestedStaticArrayLength.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gbmVzdGVkU3RhdGljQXJyYXlMZW5ndGgoKXVpbnQ2NAoqYWJpX3JvdXRlX25lc3RlZFN0YXRpY0FycmF5TGVuZ3RoOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgbmVzdGVkU3RhdGljQXJyYXlMZW5ndGgoKXVpbnQ2NAoJY2FsbHN1YiBuZXN0ZWRTdGF0aWNBcnJheUxlbmd0aAoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBuZXN0ZWRTdGF0aWNBcnJheUxlbmd0aCgpOiB1aW50NjQKbmVzdGVkU3RhdGljQXJyYXlMZW5ndGg6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0MTQKCS8vIGE6IFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQ4LCA1PiwgMz4gPSBbCgkvLyAgICAgICBbMTEsIDIyLCAzMywgNDQsIDU1XSwKCS8vICAgICAgIFs2NiwgNzcsIDg4LCA5OSwgMTAwXSwKCS8vICAgICAgIFsxMDEsIDEwMiwgMTAzLCAxMDQsIDEwNV0sCgkvLyAgICAgXQoJcHVzaGJ5dGVzIDB4MGIxNjIxMmMzNzQyNGQ1ODYzNjQ2NTY2Njc2ODY5CglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDgsIDU+LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNDIwCgkvLyByZXR1cm4gYVswXS5sZW5ndGg7CglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50OCwgNT4sIDM+CglwdXNoaW50IDUKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YzU3ODhjMTkgLy8gbWV0aG9kICJuZXN0ZWRTdGF0aWNBcnJheUxlbmd0aCgpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9uZXN0ZWRTdGF0aWNBcnJheUxlbmd0aAoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gbmVzdGVkU3RhdGljQXJyYXlMZW5ndGgoKXVpbnQ2NAoqYWJpX3JvdXRlX25lc3RlZFN0YXRpY0FycmF5TGVuZ3RoOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgbmVzdGVkU3RhdGljQXJyYXlMZW5ndGgoKXVpbnQ2NAoJY2FsbHN1YiBuZXN0ZWRTdGF0aWNBcnJheUxlbmd0aAoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBuZXN0ZWRTdGF0aWNBcnJheUxlbmd0aCgpOiB1aW50NjQKbmVzdGVkU3RhdGljQXJyYXlMZW5ndGg6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0MTQKCS8vIGE6IFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQ4LCA1PiwgMz4gPSBbCgkvLyAgICAgICBbMTEsIDIyLCAzMywgNDQsIDU1XSwKCS8vICAgICAgIFs2NiwgNzcsIDg4LCA5OSwgMTAwXSwKCS8vICAgICAgIFsxMDEsIDEwMiwgMTAzLCAxMDQsIDEwNV0sCgkvLyAgICAgXQoJcHVzaGJ5dGVzIDB4MGIxNjIxMmMzNzQyNGQ1ODYzNjQ2NTY2Njc2ODY5CglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDgsIDU+LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNDIwCgkvLyByZXR1cm4gYVswXS5sZW5ndGg7CglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50OCwgNT4sIDM+CglwdXNoaW50IDUKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YzU3ODhjMTkgLy8gbWV0aG9kICJuZXN0ZWRTdGF0aWNBcnJheUxlbmd0aCgpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9uZXN0ZWRTdGF0aWNBcnJheUxlbmd0aAoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestNestedStaticArrayLength.arc56_draft.json b/tests/contracts/artifacts/ABITestNestedStaticArrayLength.arc56_draft.json index ea8aaf30d..955c96053 100644 --- a/tests/contracts/artifacts/ABITestNestedStaticArrayLength.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestNestedStaticArrayLength.arc56_draft.json @@ -393,7 +393,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gbmVzdGVkU3RhdGljQXJyYXlMZW5ndGgoKXVpbnQ2NAoqYWJpX3JvdXRlX25lc3RlZFN0YXRpY0FycmF5TGVuZ3RoOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgbmVzdGVkU3RhdGljQXJyYXlMZW5ndGgoKXVpbnQ2NAoJY2FsbHN1YiBuZXN0ZWRTdGF0aWNBcnJheUxlbmd0aAoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBuZXN0ZWRTdGF0aWNBcnJheUxlbmd0aCgpOiB1aW50NjQKbmVzdGVkU3RhdGljQXJyYXlMZW5ndGg6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0MTQKCS8vIGE6IFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQ4LCA1PiwgMz4gPSBbCgkvLyAgICAgICBbMTEsIDIyLCAzMywgNDQsIDU1XSwKCS8vICAgICAgIFs2NiwgNzcsIDg4LCA5OSwgMTAwXSwKCS8vICAgICAgIFsxMDEsIDEwMiwgMTAzLCAxMDQsIDEwNV0sCgkvLyAgICAgXQoJcHVzaGJ5dGVzIDB4MGIxNjIxMmMzNzQyNGQ1ODYzNjQ2NTY2Njc2ODY5CglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDgsIDU+LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNDIwCgkvLyByZXR1cm4gYVswXS5sZW5ndGg7CglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50OCwgNT4sIDM+CglwdXNoaW50IDUKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YzU3ODhjMTkgLy8gbWV0aG9kICJuZXN0ZWRTdGF0aWNBcnJheUxlbmd0aCgpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9uZXN0ZWRTdGF0aWNBcnJheUxlbmd0aAoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gbmVzdGVkU3RhdGljQXJyYXlMZW5ndGgoKXVpbnQ2NAoqYWJpX3JvdXRlX25lc3RlZFN0YXRpY0FycmF5TGVuZ3RoOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgbmVzdGVkU3RhdGljQXJyYXlMZW5ndGgoKXVpbnQ2NAoJY2FsbHN1YiBuZXN0ZWRTdGF0aWNBcnJheUxlbmd0aAoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBuZXN0ZWRTdGF0aWNBcnJheUxlbmd0aCgpOiB1aW50NjQKbmVzdGVkU3RhdGljQXJyYXlMZW5ndGg6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0MTQKCS8vIGE6IFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQ4LCA1PiwgMz4gPSBbCgkvLyAgICAgICBbMTEsIDIyLCAzMywgNDQsIDU1XSwKCS8vICAgICAgIFs2NiwgNzcsIDg4LCA5OSwgMTAwXSwKCS8vICAgICAgIFsxMDEsIDEwMiwgMTAzLCAxMDQsIDEwNV0sCgkvLyAgICAgXQoJcHVzaGJ5dGVzIDB4MGIxNjIxMmMzNzQyNGQ1ODYzNjQ2NTY2Njc2ODY5CglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDgsIDU+LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNDIwCgkvLyByZXR1cm4gYVswXS5sZW5ndGg7CglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50OCwgNT4sIDM+CglwdXNoaW50IDUKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YzU3ODhjMTkgLy8gbWV0aG9kICJuZXN0ZWRTdGF0aWNBcnJheUxlbmd0aCgpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9uZXN0ZWRTdGF0aWNBcnJheUxlbmd0aAoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestNestedStaticForEach.approval.teal b/tests/contracts/artifacts/ABITestNestedStaticForEach.approval.teal index b9b89f75a..ceaa398a7 100644 --- a/tests/contracts/artifacts/ABITestNestedStaticForEach.approval.teal +++ b/tests/contracts/artifacts/ABITestNestedStaticForEach.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestNestedStaticForEach.arc32.json b/tests/contracts/artifacts/ABITestNestedStaticForEach.arc32.json index f022999d1..2d9fdcf83 100644 --- a/tests/contracts/artifacts/ABITestNestedStaticForEach.arc32.json +++ b/tests/contracts/artifacts/ABITestNestedStaticForEach.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBuZXN0ZWRTdGF0aWNGb3JFYWNoKCl1aW50NjQKKmFiaV9yb3V0ZV9uZXN0ZWRTdGF0aWNGb3JFYWNoOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgbmVzdGVkU3RhdGljRm9yRWFjaCgpdWludDY0CgljYWxsc3ViIG5lc3RlZFN0YXRpY0ZvckVhY2gKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gbmVzdGVkU3RhdGljRm9yRWFjaCgpOiB1aW50NjQKbmVzdGVkU3RhdGljRm9yRWFjaDoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXBuIDQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTMyMAoJLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDY0LCAzPiwgMz4gPSBbCgkvLyAgICAgICBbMSwgMiwgM10sCgkvLyAgICAgICBbNCwgNSwgNl0sCgkvLyAgICAgICBbNywgOCwgOV0sCgkvLyAgICAgXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMTAwMDAwMDAwMDAwMDAwMDIwMDAwMDAwMDAwMDAwMDAzMDAwMDAwMDAwMDAwMDAwNDAwMDAwMDAwMDAwMDAwMDUwMDAwMDAwMDAwMDAwMDA2MDAwMDAwMDAwMDAwMDAwNzAwMDAwMDAwMDAwMDAwMDgwMDAwMDAwMDAwMDAwMDA5CglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDY0LCAzPiwgMz4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTMyNQoJLy8gc3VtID0gMAoJcHVzaGludCAwCglmcmFtZV9idXJ5IDEgLy8gc3VtOiB1aW50NjQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTMyNwoJLy8gYVsxXS5mb3JFYWNoCglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50NjQsIDM+LCAzPgoJZXh0cmFjdCAyNCAyNAoJZHVwCglmcmFtZV9idXJ5IDIgLy8gY29weSBvZiB0aGUgYXJyYXkgd2UgYXJlIGl0ZXJhdGluZyBvdmVyCglleHRyYWN0IDAgOAoJYnRvaQoJZnJhbWVfYnVyeSAzIC8vIHY6IHVpbnQ2NAoJcHVzaGludCAwCglmcmFtZV9idXJ5IDQgLy8gdGhlIG9mZnNldCB3ZSBhcmUgZXh0cmFjdGluZyB0aGUgbmV4dCBlbGVtZW50IGZyb20KCipmb3JFYWNoXzA6CgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTMyOAoJLy8gc3VtICs9IHYKCWZyYW1lX2RpZyAxIC8vIHN1bTogdWludDY0CglmcmFtZV9kaWcgMyAvLyB2OiB1aW50NjQKCSsKCWZyYW1lX2J1cnkgMSAvLyBzdW06IHVpbnQ2NAoKCS8vIGluY3JlbWVudCBvZmZzZXQgYW5kIGxvb3AgaWYgbm90IG91dCBvZiBib3VuZHMKCWZyYW1lX2RpZyA0IC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglwdXNoaW50IDgKCSsKCWR1cAoJcHVzaGludCAyNCAvLyBvZmZzZXQgb2YgbGFzdCBlbGVtZW50Cgk8CglieiAqZm9yRWFjaF8wX2VuZAoJZnJhbWVfYnVyeSA0IC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglmcmFtZV9kaWcgMiAvLyBjb3B5IG9mIHRoZSBhcnJheSB3ZSBhcmUgaXRlcmF0aW5nIG92ZXIKCWZyYW1lX2RpZyA0IC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglwdXNoaW50IDgKCWV4dHJhY3QKCWJ0b2kKCWZyYW1lX2J1cnkgMyAvLyB2OiB1aW50NjQKCWIgKmZvckVhY2hfMAoKKmZvckVhY2hfMF9lbmQ6CgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTMzMQoJLy8gcmV0dXJuIHN1bTsKCWZyYW1lX2RpZyAxIC8vIHN1bTogdWludDY0CgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCgoJLy8gcG9wIGFsbCBsb2NhbCB2YXJpYWJsZXMgZnJvbSB0aGUgc3RhY2sKCXBvcG4gNAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg2NWIxOTIxZCAvLyBtZXRob2QgIm5lc3RlZFN0YXRpY0ZvckVhY2goKXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfbmVzdGVkU3RhdGljRm9yRWFjaAoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBuZXN0ZWRTdGF0aWNGb3JFYWNoKCl1aW50NjQKKmFiaV9yb3V0ZV9uZXN0ZWRTdGF0aWNGb3JFYWNoOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgbmVzdGVkU3RhdGljRm9yRWFjaCgpdWludDY0CgljYWxsc3ViIG5lc3RlZFN0YXRpY0ZvckVhY2gKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gbmVzdGVkU3RhdGljRm9yRWFjaCgpOiB1aW50NjQKbmVzdGVkU3RhdGljRm9yRWFjaDoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXBuIDQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTMyMAoJLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDY0LCAzPiwgMz4gPSBbCgkvLyAgICAgICBbMSwgMiwgM10sCgkvLyAgICAgICBbNCwgNSwgNl0sCgkvLyAgICAgICBbNywgOCwgOV0sCgkvLyAgICAgXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMTAwMDAwMDAwMDAwMDAwMDIwMDAwMDAwMDAwMDAwMDAzMDAwMDAwMDAwMDAwMDAwNDAwMDAwMDAwMDAwMDAwMDUwMDAwMDAwMDAwMDAwMDA2MDAwMDAwMDAwMDAwMDAwNzAwMDAwMDAwMDAwMDAwMDgwMDAwMDAwMDAwMDAwMDA5CglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDY0LCAzPiwgMz4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTMyNQoJLy8gc3VtID0gMAoJcHVzaGludCAwCglmcmFtZV9idXJ5IDEgLy8gc3VtOiB1aW50NjQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTMyNwoJLy8gYVsxXS5mb3JFYWNoCglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50NjQsIDM+LCAzPgoJZXh0cmFjdCAyNCAyNAoJZHVwCglmcmFtZV9idXJ5IDIgLy8gY29weSBvZiB0aGUgYXJyYXkgd2UgYXJlIGl0ZXJhdGluZyBvdmVyCglleHRyYWN0IDAgOAoJYnRvaQoJZnJhbWVfYnVyeSAzIC8vIHY6IHVpbnQ2NAoJcHVzaGludCAwCglmcmFtZV9idXJ5IDQgLy8gdGhlIG9mZnNldCB3ZSBhcmUgZXh0cmFjdGluZyB0aGUgbmV4dCBlbGVtZW50IGZyb20KCipmb3JFYWNoXzA6CgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTMyOAoJLy8gc3VtICs9IHYKCWZyYW1lX2RpZyAxIC8vIHN1bTogdWludDY0CglmcmFtZV9kaWcgMyAvLyB2OiB1aW50NjQKCSsKCWZyYW1lX2J1cnkgMSAvLyBzdW06IHVpbnQ2NAoKCS8vIGluY3JlbWVudCBvZmZzZXQgYW5kIGxvb3AgaWYgbm90IG91dCBvZiBib3VuZHMKCWZyYW1lX2RpZyA0IC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglwdXNoaW50IDgKCSsKCWR1cAoJcHVzaGludCAyNCAvLyBvZmZzZXQgb2YgbGFzdCBlbGVtZW50Cgk8CglieiAqZm9yRWFjaF8wX2VuZAoJZnJhbWVfYnVyeSA0IC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglmcmFtZV9kaWcgMiAvLyBjb3B5IG9mIHRoZSBhcnJheSB3ZSBhcmUgaXRlcmF0aW5nIG92ZXIKCWZyYW1lX2RpZyA0IC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglwdXNoaW50IDgKCWV4dHJhY3QKCWJ0b2kKCWZyYW1lX2J1cnkgMyAvLyB2OiB1aW50NjQKCWIgKmZvckVhY2hfMAoKKmZvckVhY2hfMF9lbmQ6CgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTMzMQoJLy8gcmV0dXJuIHN1bTsKCWZyYW1lX2RpZyAxIC8vIHN1bTogdWludDY0CgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCgoJLy8gcG9wIGFsbCBsb2NhbCB2YXJpYWJsZXMgZnJvbSB0aGUgc3RhY2sKCXBvcG4gNAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg2NWIxOTIxZCAvLyBtZXRob2QgIm5lc3RlZFN0YXRpY0ZvckVhY2goKXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfbmVzdGVkU3RhdGljRm9yRWFjaAoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestNestedStaticForEach.arc56_draft.json b/tests/contracts/artifacts/ABITestNestedStaticForEach.arc56_draft.json index 58ec7fc36..b9248eeb6 100644 --- a/tests/contracts/artifacts/ABITestNestedStaticForEach.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestNestedStaticForEach.arc56_draft.json @@ -703,7 +703,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBuZXN0ZWRTdGF0aWNGb3JFYWNoKCl1aW50NjQKKmFiaV9yb3V0ZV9uZXN0ZWRTdGF0aWNGb3JFYWNoOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgbmVzdGVkU3RhdGljRm9yRWFjaCgpdWludDY0CgljYWxsc3ViIG5lc3RlZFN0YXRpY0ZvckVhY2gKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gbmVzdGVkU3RhdGljRm9yRWFjaCgpOiB1aW50NjQKbmVzdGVkU3RhdGljRm9yRWFjaDoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXBuIDQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTMyMAoJLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDY0LCAzPiwgMz4gPSBbCgkvLyAgICAgICBbMSwgMiwgM10sCgkvLyAgICAgICBbNCwgNSwgNl0sCgkvLyAgICAgICBbNywgOCwgOV0sCgkvLyAgICAgXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMTAwMDAwMDAwMDAwMDAwMDIwMDAwMDAwMDAwMDAwMDAzMDAwMDAwMDAwMDAwMDAwNDAwMDAwMDAwMDAwMDAwMDUwMDAwMDAwMDAwMDAwMDA2MDAwMDAwMDAwMDAwMDAwNzAwMDAwMDAwMDAwMDAwMDgwMDAwMDAwMDAwMDAwMDA5CglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDY0LCAzPiwgMz4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTMyNQoJLy8gc3VtID0gMAoJcHVzaGludCAwCglmcmFtZV9idXJ5IDEgLy8gc3VtOiB1aW50NjQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTMyNwoJLy8gYVsxXS5mb3JFYWNoCglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50NjQsIDM+LCAzPgoJZXh0cmFjdCAyNCAyNAoJZHVwCglmcmFtZV9idXJ5IDIgLy8gY29weSBvZiB0aGUgYXJyYXkgd2UgYXJlIGl0ZXJhdGluZyBvdmVyCglleHRyYWN0IDAgOAoJYnRvaQoJZnJhbWVfYnVyeSAzIC8vIHY6IHVpbnQ2NAoJcHVzaGludCAwCglmcmFtZV9idXJ5IDQgLy8gdGhlIG9mZnNldCB3ZSBhcmUgZXh0cmFjdGluZyB0aGUgbmV4dCBlbGVtZW50IGZyb20KCipmb3JFYWNoXzA6CgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTMyOAoJLy8gc3VtICs9IHYKCWZyYW1lX2RpZyAxIC8vIHN1bTogdWludDY0CglmcmFtZV9kaWcgMyAvLyB2OiB1aW50NjQKCSsKCWZyYW1lX2J1cnkgMSAvLyBzdW06IHVpbnQ2NAoKCS8vIGluY3JlbWVudCBvZmZzZXQgYW5kIGxvb3AgaWYgbm90IG91dCBvZiBib3VuZHMKCWZyYW1lX2RpZyA0IC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglwdXNoaW50IDgKCSsKCWR1cAoJcHVzaGludCAyNCAvLyBvZmZzZXQgb2YgbGFzdCBlbGVtZW50Cgk8CglieiAqZm9yRWFjaF8wX2VuZAoJZnJhbWVfYnVyeSA0IC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglmcmFtZV9kaWcgMiAvLyBjb3B5IG9mIHRoZSBhcnJheSB3ZSBhcmUgaXRlcmF0aW5nIG92ZXIKCWZyYW1lX2RpZyA0IC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglwdXNoaW50IDgKCWV4dHJhY3QKCWJ0b2kKCWZyYW1lX2J1cnkgMyAvLyB2OiB1aW50NjQKCWIgKmZvckVhY2hfMAoKKmZvckVhY2hfMF9lbmQ6CgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTMzMQoJLy8gcmV0dXJuIHN1bTsKCWZyYW1lX2RpZyAxIC8vIHN1bTogdWludDY0CgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCgoJLy8gcG9wIGFsbCBsb2NhbCB2YXJpYWJsZXMgZnJvbSB0aGUgc3RhY2sKCXBvcG4gNAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg2NWIxOTIxZCAvLyBtZXRob2QgIm5lc3RlZFN0YXRpY0ZvckVhY2goKXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfbmVzdGVkU3RhdGljRm9yRWFjaAoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBuZXN0ZWRTdGF0aWNGb3JFYWNoKCl1aW50NjQKKmFiaV9yb3V0ZV9uZXN0ZWRTdGF0aWNGb3JFYWNoOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgbmVzdGVkU3RhdGljRm9yRWFjaCgpdWludDY0CgljYWxsc3ViIG5lc3RlZFN0YXRpY0ZvckVhY2gKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gbmVzdGVkU3RhdGljRm9yRWFjaCgpOiB1aW50NjQKbmVzdGVkU3RhdGljRm9yRWFjaDoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXBuIDQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTMyMAoJLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDY0LCAzPiwgMz4gPSBbCgkvLyAgICAgICBbMSwgMiwgM10sCgkvLyAgICAgICBbNCwgNSwgNl0sCgkvLyAgICAgICBbNywgOCwgOV0sCgkvLyAgICAgXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMTAwMDAwMDAwMDAwMDAwMDIwMDAwMDAwMDAwMDAwMDAzMDAwMDAwMDAwMDAwMDAwNDAwMDAwMDAwMDAwMDAwMDUwMDAwMDAwMDAwMDAwMDA2MDAwMDAwMDAwMDAwMDAwNzAwMDAwMDAwMDAwMDAwMDgwMDAwMDAwMDAwMDAwMDA5CglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDY0LCAzPiwgMz4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTMyNQoJLy8gc3VtID0gMAoJcHVzaGludCAwCglmcmFtZV9idXJ5IDEgLy8gc3VtOiB1aW50NjQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTMyNwoJLy8gYVsxXS5mb3JFYWNoCglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50NjQsIDM+LCAzPgoJZXh0cmFjdCAyNCAyNAoJZHVwCglmcmFtZV9idXJ5IDIgLy8gY29weSBvZiB0aGUgYXJyYXkgd2UgYXJlIGl0ZXJhdGluZyBvdmVyCglleHRyYWN0IDAgOAoJYnRvaQoJZnJhbWVfYnVyeSAzIC8vIHY6IHVpbnQ2NAoJcHVzaGludCAwCglmcmFtZV9idXJ5IDQgLy8gdGhlIG9mZnNldCB3ZSBhcmUgZXh0cmFjdGluZyB0aGUgbmV4dCBlbGVtZW50IGZyb20KCipmb3JFYWNoXzA6CgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTMyOAoJLy8gc3VtICs9IHYKCWZyYW1lX2RpZyAxIC8vIHN1bTogdWludDY0CglmcmFtZV9kaWcgMyAvLyB2OiB1aW50NjQKCSsKCWZyYW1lX2J1cnkgMSAvLyBzdW06IHVpbnQ2NAoKCS8vIGluY3JlbWVudCBvZmZzZXQgYW5kIGxvb3AgaWYgbm90IG91dCBvZiBib3VuZHMKCWZyYW1lX2RpZyA0IC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglwdXNoaW50IDgKCSsKCWR1cAoJcHVzaGludCAyNCAvLyBvZmZzZXQgb2YgbGFzdCBlbGVtZW50Cgk8CglieiAqZm9yRWFjaF8wX2VuZAoJZnJhbWVfYnVyeSA0IC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglmcmFtZV9kaWcgMiAvLyBjb3B5IG9mIHRoZSBhcnJheSB3ZSBhcmUgaXRlcmF0aW5nIG92ZXIKCWZyYW1lX2RpZyA0IC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglwdXNoaW50IDgKCWV4dHJhY3QKCWJ0b2kKCWZyYW1lX2J1cnkgMyAvLyB2OiB1aW50NjQKCWIgKmZvckVhY2hfMAoKKmZvckVhY2hfMF9lbmQ6CgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTMzMQoJLy8gcmV0dXJuIHN1bTsKCWZyYW1lX2RpZyAxIC8vIHN1bTogdWludDY0CgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCgoJLy8gcG9wIGFsbCBsb2NhbCB2YXJpYWJsZXMgZnJvbSB0aGUgc3RhY2sKCXBvcG4gNAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg2NWIxOTIxZCAvLyBtZXRob2QgIm5lc3RlZFN0YXRpY0ZvckVhY2goKXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfbmVzdGVkU3RhdGljRm9yRWFjaAoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestNestedStaticForEachInBox.approval.teal b/tests/contracts/artifacts/ABITestNestedStaticForEachInBox.approval.teal index 596950400..40cd28333 100644 --- a/tests/contracts/artifacts/ABITestNestedStaticForEachInBox.approval.teal +++ b/tests/contracts/artifacts/ABITestNestedStaticForEachInBox.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x624b6579 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestNestedStaticForEachInBox.arc32.json b/tests/contracts/artifacts/ABITestNestedStaticForEachInBox.arc32.json index 446290ff3..6f3a69a04 100644 --- a/tests/contracts/artifacts/ABITestNestedStaticForEachInBox.arc32.json +++ b/tests/contracts/artifacts/ABITestNestedStaticForEachInBox.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2MjRiNjU3OSAweAoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDQuMQovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIG5lc3RlZFN0YXRpY0ZvckVhY2hJbkJveCgpdWludDY0CiphYmlfcm91dGVfbmVzdGVkU3RhdGljRm9yRWFjaEluQm94OgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgbmVzdGVkU3RhdGljRm9yRWFjaEluQm94KCl1aW50NjQKCWNhbGxzdWIgbmVzdGVkU3RhdGljRm9yRWFjaEluQm94CglpdG9iCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIG5lc3RlZFN0YXRpY0ZvckVhY2hJbkJveCgpOiB1aW50NjQKbmVzdGVkU3RhdGljRm9yRWFjaEluQm94OgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCWJ5dGUgMHgKCWR1cG4gMwoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMzM5CgkvLyB0aGlzLmJLZXkudmFsdWUgPSBbCgkvLyAgICAgICBbMSwgMiwgM10sCgkvLyAgICAgICBbNCwgNSwgNl0sCgkvLyAgICAgICBbNywgOCwgOV0sCgkvLyAgICAgXQoJYnl0ZSAweDYyNGI2NTc5IC8vICJiS2V5IgoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMTAwMDAwMDAwMDAwMDAwMDIwMDAwMDAwMDAwMDAwMDAzMDAwMDAwMDAwMDAwMDAwNDAwMDAwMDAwMDAwMDAwMDUwMDAwMDAwMDAwMDAwMDA2MDAwMDAwMDAwMDAwMDAwNzAwMDAwMDAwMDAwMDAwMDgwMDAwMDAwMDAwMDAwMDA5Cglib3hfcHV0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzNDQKCS8vIHN1bSA9IDAKCXB1c2hpbnQgMAoJZnJhbWVfYnVyeSAwIC8vIHN1bTogdWludDY0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzNDYKCS8vIHRoaXMuYktleS52YWx1ZVsxXS5mb3JFYWNoCglieXRlIDB4NjI0YjY1NzkgLy8gImJLZXkiCglwdXNoaW50IDI0CglwdXNoaW50IDI0Cglib3hfZXh0cmFjdAoJZHVwCglmcmFtZV9idXJ5IDEgLy8gY29weSBvZiB0aGUgYXJyYXkgd2UgYXJlIGl0ZXJhdGluZyBvdmVyCglleHRyYWN0IDAgOAoJYnRvaQoJZnJhbWVfYnVyeSAyIC8vIHY6IHVpbnQ2NAoJcHVzaGludCAwCglmcmFtZV9idXJ5IDMgLy8gdGhlIG9mZnNldCB3ZSBhcmUgZXh0cmFjdGluZyB0aGUgbmV4dCBlbGVtZW50IGZyb20KCipmb3JFYWNoXzA6CgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTM0NwoJLy8gc3VtICs9IHYKCWZyYW1lX2RpZyAwIC8vIHN1bTogdWludDY0CglmcmFtZV9kaWcgMiAvLyB2OiB1aW50NjQKCSsKCWZyYW1lX2J1cnkgMCAvLyBzdW06IHVpbnQ2NAoKCS8vIGluY3JlbWVudCBvZmZzZXQgYW5kIGxvb3AgaWYgbm90IG91dCBvZiBib3VuZHMKCWZyYW1lX2RpZyAzIC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglwdXNoaW50IDgKCSsKCWR1cAoJcHVzaGludCAyNCAvLyBvZmZzZXQgb2YgbGFzdCBlbGVtZW50Cgk8CglieiAqZm9yRWFjaF8wX2VuZAoJZnJhbWVfYnVyeSAzIC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglmcmFtZV9kaWcgMSAvLyBjb3B5IG9mIHRoZSBhcnJheSB3ZSBhcmUgaXRlcmF0aW5nIG92ZXIKCWZyYW1lX2RpZyAzIC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglwdXNoaW50IDgKCWV4dHJhY3QKCWJ0b2kKCWZyYW1lX2J1cnkgMiAvLyB2OiB1aW50NjQKCWIgKmZvckVhY2hfMAoKKmZvckVhY2hfMF9lbmQ6CgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTM1MAoJLy8gcmV0dXJuIHN1bTsKCWZyYW1lX2RpZyAwIC8vIHN1bTogdWludDY0CgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCgoJLy8gcG9wIGFsbCBsb2NhbCB2YXJpYWJsZXMgZnJvbSB0aGUgc3RhY2sKCXBvcG4gMwoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhlMjA5MDhhMiAvLyBtZXRob2QgIm5lc3RlZFN0YXRpY0ZvckVhY2hJbkJveCgpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9uZXN0ZWRTdGF0aWNGb3JFYWNoSW5Cb3gKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2MjRiNjU3OSAweAoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDUuMAovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIG5lc3RlZFN0YXRpY0ZvckVhY2hJbkJveCgpdWludDY0CiphYmlfcm91dGVfbmVzdGVkU3RhdGljRm9yRWFjaEluQm94OgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgbmVzdGVkU3RhdGljRm9yRWFjaEluQm94KCl1aW50NjQKCWNhbGxzdWIgbmVzdGVkU3RhdGljRm9yRWFjaEluQm94CglpdG9iCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIG5lc3RlZFN0YXRpY0ZvckVhY2hJbkJveCgpOiB1aW50NjQKbmVzdGVkU3RhdGljRm9yRWFjaEluQm94OgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCWJ5dGUgMHgKCWR1cG4gMwoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMzM5CgkvLyB0aGlzLmJLZXkudmFsdWUgPSBbCgkvLyAgICAgICBbMSwgMiwgM10sCgkvLyAgICAgICBbNCwgNSwgNl0sCgkvLyAgICAgICBbNywgOCwgOV0sCgkvLyAgICAgXQoJYnl0ZSAweDYyNGI2NTc5IC8vICJiS2V5IgoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMTAwMDAwMDAwMDAwMDAwMDIwMDAwMDAwMDAwMDAwMDAzMDAwMDAwMDAwMDAwMDAwNDAwMDAwMDAwMDAwMDAwMDUwMDAwMDAwMDAwMDAwMDA2MDAwMDAwMDAwMDAwMDAwNzAwMDAwMDAwMDAwMDAwMDgwMDAwMDAwMDAwMDAwMDA5Cglib3hfcHV0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzNDQKCS8vIHN1bSA9IDAKCXB1c2hpbnQgMAoJZnJhbWVfYnVyeSAwIC8vIHN1bTogdWludDY0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzNDYKCS8vIHRoaXMuYktleS52YWx1ZVsxXS5mb3JFYWNoCglieXRlIDB4NjI0YjY1NzkgLy8gImJLZXkiCglwdXNoaW50IDI0CglwdXNoaW50IDI0Cglib3hfZXh0cmFjdAoJZHVwCglmcmFtZV9idXJ5IDEgLy8gY29weSBvZiB0aGUgYXJyYXkgd2UgYXJlIGl0ZXJhdGluZyBvdmVyCglleHRyYWN0IDAgOAoJYnRvaQoJZnJhbWVfYnVyeSAyIC8vIHY6IHVpbnQ2NAoJcHVzaGludCAwCglmcmFtZV9idXJ5IDMgLy8gdGhlIG9mZnNldCB3ZSBhcmUgZXh0cmFjdGluZyB0aGUgbmV4dCBlbGVtZW50IGZyb20KCipmb3JFYWNoXzA6CgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTM0NwoJLy8gc3VtICs9IHYKCWZyYW1lX2RpZyAwIC8vIHN1bTogdWludDY0CglmcmFtZV9kaWcgMiAvLyB2OiB1aW50NjQKCSsKCWZyYW1lX2J1cnkgMCAvLyBzdW06IHVpbnQ2NAoKCS8vIGluY3JlbWVudCBvZmZzZXQgYW5kIGxvb3AgaWYgbm90IG91dCBvZiBib3VuZHMKCWZyYW1lX2RpZyAzIC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglwdXNoaW50IDgKCSsKCWR1cAoJcHVzaGludCAyNCAvLyBvZmZzZXQgb2YgbGFzdCBlbGVtZW50Cgk8CglieiAqZm9yRWFjaF8wX2VuZAoJZnJhbWVfYnVyeSAzIC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglmcmFtZV9kaWcgMSAvLyBjb3B5IG9mIHRoZSBhcnJheSB3ZSBhcmUgaXRlcmF0aW5nIG92ZXIKCWZyYW1lX2RpZyAzIC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglwdXNoaW50IDgKCWV4dHJhY3QKCWJ0b2kKCWZyYW1lX2J1cnkgMiAvLyB2OiB1aW50NjQKCWIgKmZvckVhY2hfMAoKKmZvckVhY2hfMF9lbmQ6CgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTM1MAoJLy8gcmV0dXJuIHN1bTsKCWZyYW1lX2RpZyAwIC8vIHN1bTogdWludDY0CgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCgoJLy8gcG9wIGFsbCBsb2NhbCB2YXJpYWJsZXMgZnJvbSB0aGUgc3RhY2sKCXBvcG4gMwoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhlMjA5MDhhMiAvLyBtZXRob2QgIm5lc3RlZFN0YXRpY0ZvckVhY2hJbkJveCgpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9uZXN0ZWRTdGF0aWNGb3JFYWNoSW5Cb3gKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestNestedStaticForEachInBox.arc56_draft.json b/tests/contracts/artifacts/ABITestNestedStaticForEachInBox.arc56_draft.json index 3c188dd92..0789a9e40 100644 --- a/tests/contracts/artifacts/ABITestNestedStaticForEachInBox.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestNestedStaticForEachInBox.arc56_draft.json @@ -743,7 +743,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2MjRiNjU3OSAweAoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDQuMQovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIG5lc3RlZFN0YXRpY0ZvckVhY2hJbkJveCgpdWludDY0CiphYmlfcm91dGVfbmVzdGVkU3RhdGljRm9yRWFjaEluQm94OgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgbmVzdGVkU3RhdGljRm9yRWFjaEluQm94KCl1aW50NjQKCWNhbGxzdWIgbmVzdGVkU3RhdGljRm9yRWFjaEluQm94CglpdG9iCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIG5lc3RlZFN0YXRpY0ZvckVhY2hJbkJveCgpOiB1aW50NjQKbmVzdGVkU3RhdGljRm9yRWFjaEluQm94OgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCWJ5dGUgMHgKCWR1cG4gMwoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMzM5CgkvLyB0aGlzLmJLZXkudmFsdWUgPSBbCgkvLyAgICAgICBbMSwgMiwgM10sCgkvLyAgICAgICBbNCwgNSwgNl0sCgkvLyAgICAgICBbNywgOCwgOV0sCgkvLyAgICAgXQoJYnl0ZSAweDYyNGI2NTc5IC8vICJiS2V5IgoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMTAwMDAwMDAwMDAwMDAwMDIwMDAwMDAwMDAwMDAwMDAzMDAwMDAwMDAwMDAwMDAwNDAwMDAwMDAwMDAwMDAwMDUwMDAwMDAwMDAwMDAwMDA2MDAwMDAwMDAwMDAwMDAwNzAwMDAwMDAwMDAwMDAwMDgwMDAwMDAwMDAwMDAwMDA5Cglib3hfcHV0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzNDQKCS8vIHN1bSA9IDAKCXB1c2hpbnQgMAoJZnJhbWVfYnVyeSAwIC8vIHN1bTogdWludDY0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzNDYKCS8vIHRoaXMuYktleS52YWx1ZVsxXS5mb3JFYWNoCglieXRlIDB4NjI0YjY1NzkgLy8gImJLZXkiCglwdXNoaW50IDI0CglwdXNoaW50IDI0Cglib3hfZXh0cmFjdAoJZHVwCglmcmFtZV9idXJ5IDEgLy8gY29weSBvZiB0aGUgYXJyYXkgd2UgYXJlIGl0ZXJhdGluZyBvdmVyCglleHRyYWN0IDAgOAoJYnRvaQoJZnJhbWVfYnVyeSAyIC8vIHY6IHVpbnQ2NAoJcHVzaGludCAwCglmcmFtZV9idXJ5IDMgLy8gdGhlIG9mZnNldCB3ZSBhcmUgZXh0cmFjdGluZyB0aGUgbmV4dCBlbGVtZW50IGZyb20KCipmb3JFYWNoXzA6CgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTM0NwoJLy8gc3VtICs9IHYKCWZyYW1lX2RpZyAwIC8vIHN1bTogdWludDY0CglmcmFtZV9kaWcgMiAvLyB2OiB1aW50NjQKCSsKCWZyYW1lX2J1cnkgMCAvLyBzdW06IHVpbnQ2NAoKCS8vIGluY3JlbWVudCBvZmZzZXQgYW5kIGxvb3AgaWYgbm90IG91dCBvZiBib3VuZHMKCWZyYW1lX2RpZyAzIC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglwdXNoaW50IDgKCSsKCWR1cAoJcHVzaGludCAyNCAvLyBvZmZzZXQgb2YgbGFzdCBlbGVtZW50Cgk8CglieiAqZm9yRWFjaF8wX2VuZAoJZnJhbWVfYnVyeSAzIC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglmcmFtZV9kaWcgMSAvLyBjb3B5IG9mIHRoZSBhcnJheSB3ZSBhcmUgaXRlcmF0aW5nIG92ZXIKCWZyYW1lX2RpZyAzIC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglwdXNoaW50IDgKCWV4dHJhY3QKCWJ0b2kKCWZyYW1lX2J1cnkgMiAvLyB2OiB1aW50NjQKCWIgKmZvckVhY2hfMAoKKmZvckVhY2hfMF9lbmQ6CgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTM1MAoJLy8gcmV0dXJuIHN1bTsKCWZyYW1lX2RpZyAwIC8vIHN1bTogdWludDY0CgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCgoJLy8gcG9wIGFsbCBsb2NhbCB2YXJpYWJsZXMgZnJvbSB0aGUgc3RhY2sKCXBvcG4gMwoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhlMjA5MDhhMiAvLyBtZXRob2QgIm5lc3RlZFN0YXRpY0ZvckVhY2hJbkJveCgpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9uZXN0ZWRTdGF0aWNGb3JFYWNoSW5Cb3gKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2MjRiNjU3OSAweAoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDUuMAovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIG5lc3RlZFN0YXRpY0ZvckVhY2hJbkJveCgpdWludDY0CiphYmlfcm91dGVfbmVzdGVkU3RhdGljRm9yRWFjaEluQm94OgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgbmVzdGVkU3RhdGljRm9yRWFjaEluQm94KCl1aW50NjQKCWNhbGxzdWIgbmVzdGVkU3RhdGljRm9yRWFjaEluQm94CglpdG9iCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIG5lc3RlZFN0YXRpY0ZvckVhY2hJbkJveCgpOiB1aW50NjQKbmVzdGVkU3RhdGljRm9yRWFjaEluQm94OgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCWJ5dGUgMHgKCWR1cG4gMwoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMzM5CgkvLyB0aGlzLmJLZXkudmFsdWUgPSBbCgkvLyAgICAgICBbMSwgMiwgM10sCgkvLyAgICAgICBbNCwgNSwgNl0sCgkvLyAgICAgICBbNywgOCwgOV0sCgkvLyAgICAgXQoJYnl0ZSAweDYyNGI2NTc5IC8vICJiS2V5IgoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMTAwMDAwMDAwMDAwMDAwMDIwMDAwMDAwMDAwMDAwMDAzMDAwMDAwMDAwMDAwMDAwNDAwMDAwMDAwMDAwMDAwMDUwMDAwMDAwMDAwMDAwMDA2MDAwMDAwMDAwMDAwMDAwNzAwMDAwMDAwMDAwMDAwMDgwMDAwMDAwMDAwMDAwMDA5Cglib3hfcHV0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzNDQKCS8vIHN1bSA9IDAKCXB1c2hpbnQgMAoJZnJhbWVfYnVyeSAwIC8vIHN1bTogdWludDY0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzNDYKCS8vIHRoaXMuYktleS52YWx1ZVsxXS5mb3JFYWNoCglieXRlIDB4NjI0YjY1NzkgLy8gImJLZXkiCglwdXNoaW50IDI0CglwdXNoaW50IDI0Cglib3hfZXh0cmFjdAoJZHVwCglmcmFtZV9idXJ5IDEgLy8gY29weSBvZiB0aGUgYXJyYXkgd2UgYXJlIGl0ZXJhdGluZyBvdmVyCglleHRyYWN0IDAgOAoJYnRvaQoJZnJhbWVfYnVyeSAyIC8vIHY6IHVpbnQ2NAoJcHVzaGludCAwCglmcmFtZV9idXJ5IDMgLy8gdGhlIG9mZnNldCB3ZSBhcmUgZXh0cmFjdGluZyB0aGUgbmV4dCBlbGVtZW50IGZyb20KCipmb3JFYWNoXzA6CgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTM0NwoJLy8gc3VtICs9IHYKCWZyYW1lX2RpZyAwIC8vIHN1bTogdWludDY0CglmcmFtZV9kaWcgMiAvLyB2OiB1aW50NjQKCSsKCWZyYW1lX2J1cnkgMCAvLyBzdW06IHVpbnQ2NAoKCS8vIGluY3JlbWVudCBvZmZzZXQgYW5kIGxvb3AgaWYgbm90IG91dCBvZiBib3VuZHMKCWZyYW1lX2RpZyAzIC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglwdXNoaW50IDgKCSsKCWR1cAoJcHVzaGludCAyNCAvLyBvZmZzZXQgb2YgbGFzdCBlbGVtZW50Cgk8CglieiAqZm9yRWFjaF8wX2VuZAoJZnJhbWVfYnVyeSAzIC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglmcmFtZV9kaWcgMSAvLyBjb3B5IG9mIHRoZSBhcnJheSB3ZSBhcmUgaXRlcmF0aW5nIG92ZXIKCWZyYW1lX2RpZyAzIC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglwdXNoaW50IDgKCWV4dHJhY3QKCWJ0b2kKCWZyYW1lX2J1cnkgMiAvLyB2OiB1aW50NjQKCWIgKmZvckVhY2hfMAoKKmZvckVhY2hfMF9lbmQ6CgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTM1MAoJLy8gcmV0dXJuIHN1bTsKCWZyYW1lX2RpZyAwIC8vIHN1bTogdWludDY0CgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCgoJLy8gcG9wIGFsbCBsb2NhbCB2YXJpYWJsZXMgZnJvbSB0aGUgc3RhY2sKCXBvcG4gMwoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhlMjA5MDhhMiAvLyBtZXRob2QgIm5lc3RlZFN0YXRpY0ZvckVhY2hJbkJveCgpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9uZXN0ZWRTdGF0aWNGb3JFYWNoSW5Cb3gKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestNestedStructInBoxMap.approval.teal b/tests/contracts/artifacts/ABITestNestedStructInBoxMap.approval.teal index cdf1cef7a..9b9f17e67 100644 --- a/tests/contracts/artifacts/ABITestNestedStructInBoxMap.approval.teal +++ b/tests/contracts/artifacts/ABITestNestedStructInBoxMap.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x624d6170 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestNestedStructInBoxMap.arc32.json b/tests/contracts/artifacts/ABITestNestedStructInBoxMap.arc32.json index 01ac2059e..b0ea6b8fc 100644 --- a/tests/contracts/artifacts/ABITestNestedStructInBoxMap.arc32.json +++ b/tests/contracts/artifacts/ABITestNestedStructInBoxMap.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2MjRkNjE3MAoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDQuMQovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIG5lc3RlZFN0cnVjdEluQm94TWFwKCkoKHVpbnQ4KSkKKmFiaV9yb3V0ZV9uZXN0ZWRTdHJ1Y3RJbkJveE1hcDoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIG5lc3RlZFN0cnVjdEluQm94TWFwKCkoKHVpbnQ4KSkKCWNhbGxzdWIgbmVzdGVkU3RydWN0SW5Cb3hNYXAKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gbmVzdGVkU3RydWN0SW5Cb3hNYXAoKTogVDgKbmVzdGVkU3RydWN0SW5Cb3hNYXA6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTI4MAoJLy8gdGhpcy5iTWFwKCdiTWFwJykudmFsdWUgPSB7IGZvbzogeyBiYXI6IDEgfSB9CglieXRlIDB4NjI0ZDYxNzAgLy8gImJNYXAiCglwdXNoYnl0ZXMgMHgwMQoJYm94X3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjgxCgkvLyB0aGlzLmJNYXAoJ2JNYXAnKS52YWx1ZS5mb28uYmFyID0gMwoJYnl0ZSAweDYyNGQ2MTcwIC8vICJiTWFwIgoJcHVzaGludCAwCglwdXNoYnl0ZXMgMHgwMwoJYm94X3JlcGxhY2UKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTI4MgoJLy8gdGhpcy5iTWFwKCdiTWFwJykudmFsdWUuZm9vLmJhciA9IDx1aW50OD4yCglieXRlIDB4NjI0ZDYxNzAgLy8gImJNYXAiCglwdXNoaW50IDAKCXB1c2hieXRlcyAweDAyCglib3hfcmVwbGFjZQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjgzCgkvLyByZXR1cm4gdGhpcy5iTWFwKCdiTWFwJykudmFsdWU7CglieXRlIDB4NjI0ZDYxNzAgLy8gImJNYXAiCglib3hfZ2V0CgoJLy8gYm94IHZhbHVlIGRvZXMgbm90IGV4aXN0OiB0aGlzLmJNYXAoJ2JNYXAnKS52YWx1ZQoJYXNzZXJ0CglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGE0MTNhMDlmIC8vIG1ldGhvZCAibmVzdGVkU3RydWN0SW5Cb3hNYXAoKSgodWludDgpKSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfbmVzdGVkU3RydWN0SW5Cb3hNYXAKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2MjRkNjE3MAoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDUuMAovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIG5lc3RlZFN0cnVjdEluQm94TWFwKCkoKHVpbnQ4KSkKKmFiaV9yb3V0ZV9uZXN0ZWRTdHJ1Y3RJbkJveE1hcDoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIG5lc3RlZFN0cnVjdEluQm94TWFwKCkoKHVpbnQ4KSkKCWNhbGxzdWIgbmVzdGVkU3RydWN0SW5Cb3hNYXAKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gbmVzdGVkU3RydWN0SW5Cb3hNYXAoKTogVDgKbmVzdGVkU3RydWN0SW5Cb3hNYXA6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTI4MAoJLy8gdGhpcy5iTWFwKCdiTWFwJykudmFsdWUgPSB7IGZvbzogeyBiYXI6IDEgfSB9CglieXRlIDB4NjI0ZDYxNzAgLy8gImJNYXAiCglwdXNoYnl0ZXMgMHgwMQoJYm94X3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjgxCgkvLyB0aGlzLmJNYXAoJ2JNYXAnKS52YWx1ZS5mb28uYmFyID0gMwoJYnl0ZSAweDYyNGQ2MTcwIC8vICJiTWFwIgoJcHVzaGludCAwCglwdXNoYnl0ZXMgMHgwMwoJYm94X3JlcGxhY2UKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTI4MgoJLy8gdGhpcy5iTWFwKCdiTWFwJykudmFsdWUuZm9vLmJhciA9IDx1aW50OD4yCglieXRlIDB4NjI0ZDYxNzAgLy8gImJNYXAiCglwdXNoaW50IDAKCXB1c2hieXRlcyAweDAyCglib3hfcmVwbGFjZQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjgzCgkvLyByZXR1cm4gdGhpcy5iTWFwKCdiTWFwJykudmFsdWU7CglieXRlIDB4NjI0ZDYxNzAgLy8gImJNYXAiCglib3hfZ2V0CgoJLy8gYm94IHZhbHVlIGRvZXMgbm90IGV4aXN0OiB0aGlzLmJNYXAoJ2JNYXAnKS52YWx1ZQoJYXNzZXJ0CglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGE0MTNhMDlmIC8vIG1ldGhvZCAibmVzdGVkU3RydWN0SW5Cb3hNYXAoKSgodWludDgpKSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfbmVzdGVkU3RydWN0SW5Cb3hNYXAKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestNestedStructInBoxMap.arc56_draft.json b/tests/contracts/artifacts/ABITestNestedStructInBoxMap.arc56_draft.json index b38723d95..d43cb0144 100644 --- a/tests/contracts/artifacts/ABITestNestedStructInBoxMap.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestNestedStructInBoxMap.arc56_draft.json @@ -481,7 +481,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2MjRkNjE3MAoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDQuMQovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIG5lc3RlZFN0cnVjdEluQm94TWFwKCkoKHVpbnQ4KSkKKmFiaV9yb3V0ZV9uZXN0ZWRTdHJ1Y3RJbkJveE1hcDoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIG5lc3RlZFN0cnVjdEluQm94TWFwKCkoKHVpbnQ4KSkKCWNhbGxzdWIgbmVzdGVkU3RydWN0SW5Cb3hNYXAKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gbmVzdGVkU3RydWN0SW5Cb3hNYXAoKTogVDgKbmVzdGVkU3RydWN0SW5Cb3hNYXA6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTI4MAoJLy8gdGhpcy5iTWFwKCdiTWFwJykudmFsdWUgPSB7IGZvbzogeyBiYXI6IDEgfSB9CglieXRlIDB4NjI0ZDYxNzAgLy8gImJNYXAiCglwdXNoYnl0ZXMgMHgwMQoJYm94X3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjgxCgkvLyB0aGlzLmJNYXAoJ2JNYXAnKS52YWx1ZS5mb28uYmFyID0gMwoJYnl0ZSAweDYyNGQ2MTcwIC8vICJiTWFwIgoJcHVzaGludCAwCglwdXNoYnl0ZXMgMHgwMwoJYm94X3JlcGxhY2UKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTI4MgoJLy8gdGhpcy5iTWFwKCdiTWFwJykudmFsdWUuZm9vLmJhciA9IDx1aW50OD4yCglieXRlIDB4NjI0ZDYxNzAgLy8gImJNYXAiCglwdXNoaW50IDAKCXB1c2hieXRlcyAweDAyCglib3hfcmVwbGFjZQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjgzCgkvLyByZXR1cm4gdGhpcy5iTWFwKCdiTWFwJykudmFsdWU7CglieXRlIDB4NjI0ZDYxNzAgLy8gImJNYXAiCglib3hfZ2V0CgoJLy8gYm94IHZhbHVlIGRvZXMgbm90IGV4aXN0OiB0aGlzLmJNYXAoJ2JNYXAnKS52YWx1ZQoJYXNzZXJ0CglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGE0MTNhMDlmIC8vIG1ldGhvZCAibmVzdGVkU3RydWN0SW5Cb3hNYXAoKSgodWludDgpKSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfbmVzdGVkU3RydWN0SW5Cb3hNYXAKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2MjRkNjE3MAoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDUuMAovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIG5lc3RlZFN0cnVjdEluQm94TWFwKCkoKHVpbnQ4KSkKKmFiaV9yb3V0ZV9uZXN0ZWRTdHJ1Y3RJbkJveE1hcDoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIG5lc3RlZFN0cnVjdEluQm94TWFwKCkoKHVpbnQ4KSkKCWNhbGxzdWIgbmVzdGVkU3RydWN0SW5Cb3hNYXAKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gbmVzdGVkU3RydWN0SW5Cb3hNYXAoKTogVDgKbmVzdGVkU3RydWN0SW5Cb3hNYXA6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTI4MAoJLy8gdGhpcy5iTWFwKCdiTWFwJykudmFsdWUgPSB7IGZvbzogeyBiYXI6IDEgfSB9CglieXRlIDB4NjI0ZDYxNzAgLy8gImJNYXAiCglwdXNoYnl0ZXMgMHgwMQoJYm94X3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjgxCgkvLyB0aGlzLmJNYXAoJ2JNYXAnKS52YWx1ZS5mb28uYmFyID0gMwoJYnl0ZSAweDYyNGQ2MTcwIC8vICJiTWFwIgoJcHVzaGludCAwCglwdXNoYnl0ZXMgMHgwMwoJYm94X3JlcGxhY2UKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTI4MgoJLy8gdGhpcy5iTWFwKCdiTWFwJykudmFsdWUuZm9vLmJhciA9IDx1aW50OD4yCglieXRlIDB4NjI0ZDYxNzAgLy8gImJNYXAiCglwdXNoaW50IDAKCXB1c2hieXRlcyAweDAyCglib3hfcmVwbGFjZQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjgzCgkvLyByZXR1cm4gdGhpcy5iTWFwKCdiTWFwJykudmFsdWU7CglieXRlIDB4NjI0ZDYxNzAgLy8gImJNYXAiCglib3hfZ2V0CgoJLy8gYm94IHZhbHVlIGRvZXMgbm90IGV4aXN0OiB0aGlzLmJNYXAoJ2JNYXAnKS52YWx1ZQoJYXNzZXJ0CglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGE0MTNhMDlmIC8vIG1ldGhvZCAibmVzdGVkU3RydWN0SW5Cb3hNYXAoKSgodWludDgpKSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfbmVzdGVkU3RydWN0SW5Cb3hNYXAKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestNestedTuple.approval.teal b/tests/contracts/artifacts/ABITestNestedTuple.approval.teal index 7562c5259..f84b920ee 100644 --- a/tests/contracts/artifacts/ABITestNestedTuple.approval.teal +++ b/tests/contracts/artifacts/ABITestNestedTuple.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestNestedTuple.arc32.json b/tests/contracts/artifacts/ABITestNestedTuple.arc32.json index 7f605266e..4d8c5ecf5 100644 --- a/tests/contracts/artifacts/ABITestNestedTuple.arc32.json +++ b/tests/contracts/artifacts/ABITestNestedTuple.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBuZXN0ZWRUdXBsZSgpKHVpbnQxNiwodWludDgsc3RyaW5nKSwodWludDE2LHN0cmluZykpCiphYmlfcm91dGVfbmVzdGVkVHVwbGU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBuZXN0ZWRUdXBsZSgpKHVpbnQxNiwodWludDgsc3RyaW5nKSwodWludDE2LHN0cmluZykpCgljYWxsc3ViIG5lc3RlZFR1cGxlCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIG5lc3RlZFR1cGxlKCk6IFt1aW50MTYsIFt1aW50PDg+LCBzdHJpbmddLCBbdWludDE2LCBzdHJpbmddXQpuZXN0ZWRUdXBsZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjY5MgoJLy8gYTogW3VpbnQxNiwgW3VpbnQ8OD4sIHN0cmluZ10sIFt1aW50MTYsIHN0cmluZ11dID0gWzExLCBbMjIsICdmb28nXSwgWzMzLCAnYmFyJ11dCglieXRlIDB4IC8vIGluaXRpYWwgaGVhZAoJYnl0ZSAweCAvLyBpbml0aWFsIHRhaWwKCXB1c2hieXRlcyAweDAwMDYgLy8gaW5pdGlhbCBoZWFkIG9mZnNldAoJcHVzaGJ5dGVzIDB4MDAwYgoJY2FsbHN1YiAqcHJvY2Vzc19zdGF0aWNfdHVwbGVfZWxlbWVudAoJYnl0ZSAweCAvLyBpbml0aWFsIGhlYWQKCWJ5dGUgMHggLy8gaW5pdGlhbCB0YWlsCglwdXNoYnl0ZXMgMHgwMDAzIC8vIGluaXRpYWwgaGVhZCBvZmZzZXQKCXB1c2hieXRlcyAweDE2CgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAzNjY2ZjZmCgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcG9wIC8vIHBvcCBoZWFkIG9mZnNldAoJY29uY2F0IC8vIGNvbmNhdCBoZWFkIGFuZCB0YWlsCgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJYnl0ZSAweCAvLyBpbml0aWFsIGhlYWQKCWJ5dGUgMHggLy8gaW5pdGlhbCB0YWlsCglwdXNoYnl0ZXMgMHgwMDA0IC8vIGluaXRpYWwgaGVhZCBvZmZzZXQKCXB1c2hieXRlcyAweDAwMjEKCWNhbGxzdWIgKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMDM2MjYxNzIKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50Cglwb3AgLy8gcG9wIGhlYWQgb2Zmc2V0Cgljb25jYXQgLy8gY29uY2F0IGhlYWQgYW5kIHRhaWwKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50Cglwb3AgLy8gcG9wIGhlYWQgb2Zmc2V0Cgljb25jYXQgLy8gY29uY2F0IGhlYWQgYW5kIHRhaWwKCWZyYW1lX2J1cnkgMCAvLyBhOiBbdWludDE2LCBbdWludDw4Piwgc3RyaW5nXSwgW3VpbnQxNiwgc3RyaW5nXV0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6Njk0CgkvLyByZXR1cm4gYTsKCWZyYW1lX2RpZyAwIC8vIGE6IFt1aW50MTYsIFt1aW50PDg+LCBzdHJpbmddLCBbdWludDE2LCBzdHJpbmddXQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg0OWJiNzAxOSAvLyBtZXRob2QgIm5lc3RlZFR1cGxlKCkodWludDE2LCh1aW50OCxzdHJpbmcpLCh1aW50MTYsc3RyaW5nKSkiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX25lc3RlZFR1cGxlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJyCgoqcHJvY2Vzc19zdGF0aWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50Cgljb25jYXQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCXJldHN1YgoKKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50OgoJcHJvdG8gNCAzCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0Cgljb25jYXQKCWZyYW1lX2J1cnkgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0xIC8vIGVsZW1lbnQKCWR1cAoJbGVuCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCWJ0b2kKCSsKCWl0b2IKCWV4dHJhY3QgNiAyCglmcmFtZV9idXJ5IC0yIC8vIGhlYWQgb2Zmc2V0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJc3dhcAoJY29uY2F0CglmcmFtZV9idXJ5IC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBuZXN0ZWRUdXBsZSgpKHVpbnQxNiwodWludDgsc3RyaW5nKSwodWludDE2LHN0cmluZykpCiphYmlfcm91dGVfbmVzdGVkVHVwbGU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBuZXN0ZWRUdXBsZSgpKHVpbnQxNiwodWludDgsc3RyaW5nKSwodWludDE2LHN0cmluZykpCgljYWxsc3ViIG5lc3RlZFR1cGxlCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIG5lc3RlZFR1cGxlKCk6IFt1aW50MTYsIFt1aW50PDg+LCBzdHJpbmddLCBbdWludDE2LCBzdHJpbmddXQpuZXN0ZWRUdXBsZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjY5MgoJLy8gYTogW3VpbnQxNiwgW3VpbnQ8OD4sIHN0cmluZ10sIFt1aW50MTYsIHN0cmluZ11dID0gWzExLCBbMjIsICdmb28nXSwgWzMzLCAnYmFyJ11dCglieXRlIDB4IC8vIGluaXRpYWwgaGVhZAoJYnl0ZSAweCAvLyBpbml0aWFsIHRhaWwKCXB1c2hieXRlcyAweDAwMDYgLy8gaW5pdGlhbCBoZWFkIG9mZnNldAoJcHVzaGJ5dGVzIDB4MDAwYgoJY2FsbHN1YiAqcHJvY2Vzc19zdGF0aWNfdHVwbGVfZWxlbWVudAoJYnl0ZSAweCAvLyBpbml0aWFsIGhlYWQKCWJ5dGUgMHggLy8gaW5pdGlhbCB0YWlsCglwdXNoYnl0ZXMgMHgwMDAzIC8vIGluaXRpYWwgaGVhZCBvZmZzZXQKCXB1c2hieXRlcyAweDE2CgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAzNjY2ZjZmCgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcG9wIC8vIHBvcCBoZWFkIG9mZnNldAoJY29uY2F0IC8vIGNvbmNhdCBoZWFkIGFuZCB0YWlsCgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJYnl0ZSAweCAvLyBpbml0aWFsIGhlYWQKCWJ5dGUgMHggLy8gaW5pdGlhbCB0YWlsCglwdXNoYnl0ZXMgMHgwMDA0IC8vIGluaXRpYWwgaGVhZCBvZmZzZXQKCXB1c2hieXRlcyAweDAwMjEKCWNhbGxzdWIgKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMDM2MjYxNzIKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50Cglwb3AgLy8gcG9wIGhlYWQgb2Zmc2V0Cgljb25jYXQgLy8gY29uY2F0IGhlYWQgYW5kIHRhaWwKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50Cglwb3AgLy8gcG9wIGhlYWQgb2Zmc2V0Cgljb25jYXQgLy8gY29uY2F0IGhlYWQgYW5kIHRhaWwKCWZyYW1lX2J1cnkgMCAvLyBhOiBbdWludDE2LCBbdWludDw4Piwgc3RyaW5nXSwgW3VpbnQxNiwgc3RyaW5nXV0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6Njk0CgkvLyByZXR1cm4gYTsKCWZyYW1lX2RpZyAwIC8vIGE6IFt1aW50MTYsIFt1aW50PDg+LCBzdHJpbmddLCBbdWludDE2LCBzdHJpbmddXQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg0OWJiNzAxOSAvLyBtZXRob2QgIm5lc3RlZFR1cGxlKCkodWludDE2LCh1aW50OCxzdHJpbmcpLCh1aW50MTYsc3RyaW5nKSkiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX25lc3RlZFR1cGxlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJyCgoqcHJvY2Vzc19zdGF0aWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50Cgljb25jYXQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCXJldHN1YgoKKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50OgoJcHJvdG8gNCAzCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0Cgljb25jYXQKCWZyYW1lX2J1cnkgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0xIC8vIGVsZW1lbnQKCWR1cAoJbGVuCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCWJ0b2kKCSsKCWl0b2IKCWV4dHJhY3QgNiAyCglmcmFtZV9idXJ5IC0yIC8vIGhlYWQgb2Zmc2V0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJc3dhcAoJY29uY2F0CglmcmFtZV9idXJ5IC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestNestedTuple.arc56_draft.json b/tests/contracts/artifacts/ABITestNestedTuple.arc56_draft.json index a21b99313..a47af1ee1 100644 --- a/tests/contracts/artifacts/ABITestNestedTuple.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestNestedTuple.arc56_draft.json @@ -826,7 +826,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBuZXN0ZWRUdXBsZSgpKHVpbnQxNiwodWludDgsc3RyaW5nKSwodWludDE2LHN0cmluZykpCiphYmlfcm91dGVfbmVzdGVkVHVwbGU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBuZXN0ZWRUdXBsZSgpKHVpbnQxNiwodWludDgsc3RyaW5nKSwodWludDE2LHN0cmluZykpCgljYWxsc3ViIG5lc3RlZFR1cGxlCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIG5lc3RlZFR1cGxlKCk6IFt1aW50MTYsIFt1aW50PDg+LCBzdHJpbmddLCBbdWludDE2LCBzdHJpbmddXQpuZXN0ZWRUdXBsZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjY5MgoJLy8gYTogW3VpbnQxNiwgW3VpbnQ8OD4sIHN0cmluZ10sIFt1aW50MTYsIHN0cmluZ11dID0gWzExLCBbMjIsICdmb28nXSwgWzMzLCAnYmFyJ11dCglieXRlIDB4IC8vIGluaXRpYWwgaGVhZAoJYnl0ZSAweCAvLyBpbml0aWFsIHRhaWwKCXB1c2hieXRlcyAweDAwMDYgLy8gaW5pdGlhbCBoZWFkIG9mZnNldAoJcHVzaGJ5dGVzIDB4MDAwYgoJY2FsbHN1YiAqcHJvY2Vzc19zdGF0aWNfdHVwbGVfZWxlbWVudAoJYnl0ZSAweCAvLyBpbml0aWFsIGhlYWQKCWJ5dGUgMHggLy8gaW5pdGlhbCB0YWlsCglwdXNoYnl0ZXMgMHgwMDAzIC8vIGluaXRpYWwgaGVhZCBvZmZzZXQKCXB1c2hieXRlcyAweDE2CgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAzNjY2ZjZmCgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcG9wIC8vIHBvcCBoZWFkIG9mZnNldAoJY29uY2F0IC8vIGNvbmNhdCBoZWFkIGFuZCB0YWlsCgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJYnl0ZSAweCAvLyBpbml0aWFsIGhlYWQKCWJ5dGUgMHggLy8gaW5pdGlhbCB0YWlsCglwdXNoYnl0ZXMgMHgwMDA0IC8vIGluaXRpYWwgaGVhZCBvZmZzZXQKCXB1c2hieXRlcyAweDAwMjEKCWNhbGxzdWIgKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMDM2MjYxNzIKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50Cglwb3AgLy8gcG9wIGhlYWQgb2Zmc2V0Cgljb25jYXQgLy8gY29uY2F0IGhlYWQgYW5kIHRhaWwKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50Cglwb3AgLy8gcG9wIGhlYWQgb2Zmc2V0Cgljb25jYXQgLy8gY29uY2F0IGhlYWQgYW5kIHRhaWwKCWZyYW1lX2J1cnkgMCAvLyBhOiBbdWludDE2LCBbdWludDw4Piwgc3RyaW5nXSwgW3VpbnQxNiwgc3RyaW5nXV0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6Njk0CgkvLyByZXR1cm4gYTsKCWZyYW1lX2RpZyAwIC8vIGE6IFt1aW50MTYsIFt1aW50PDg+LCBzdHJpbmddLCBbdWludDE2LCBzdHJpbmddXQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg0OWJiNzAxOSAvLyBtZXRob2QgIm5lc3RlZFR1cGxlKCkodWludDE2LCh1aW50OCxzdHJpbmcpLCh1aW50MTYsc3RyaW5nKSkiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX25lc3RlZFR1cGxlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJyCgoqcHJvY2Vzc19zdGF0aWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50Cgljb25jYXQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCXJldHN1YgoKKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50OgoJcHJvdG8gNCAzCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0Cgljb25jYXQKCWZyYW1lX2J1cnkgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0xIC8vIGVsZW1lbnQKCWR1cAoJbGVuCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCWJ0b2kKCSsKCWl0b2IKCWV4dHJhY3QgNiAyCglmcmFtZV9idXJ5IC0yIC8vIGhlYWQgb2Zmc2V0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJc3dhcAoJY29uY2F0CglmcmFtZV9idXJ5IC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBuZXN0ZWRUdXBsZSgpKHVpbnQxNiwodWludDgsc3RyaW5nKSwodWludDE2LHN0cmluZykpCiphYmlfcm91dGVfbmVzdGVkVHVwbGU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBuZXN0ZWRUdXBsZSgpKHVpbnQxNiwodWludDgsc3RyaW5nKSwodWludDE2LHN0cmluZykpCgljYWxsc3ViIG5lc3RlZFR1cGxlCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIG5lc3RlZFR1cGxlKCk6IFt1aW50MTYsIFt1aW50PDg+LCBzdHJpbmddLCBbdWludDE2LCBzdHJpbmddXQpuZXN0ZWRUdXBsZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjY5MgoJLy8gYTogW3VpbnQxNiwgW3VpbnQ8OD4sIHN0cmluZ10sIFt1aW50MTYsIHN0cmluZ11dID0gWzExLCBbMjIsICdmb28nXSwgWzMzLCAnYmFyJ11dCglieXRlIDB4IC8vIGluaXRpYWwgaGVhZAoJYnl0ZSAweCAvLyBpbml0aWFsIHRhaWwKCXB1c2hieXRlcyAweDAwMDYgLy8gaW5pdGlhbCBoZWFkIG9mZnNldAoJcHVzaGJ5dGVzIDB4MDAwYgoJY2FsbHN1YiAqcHJvY2Vzc19zdGF0aWNfdHVwbGVfZWxlbWVudAoJYnl0ZSAweCAvLyBpbml0aWFsIGhlYWQKCWJ5dGUgMHggLy8gaW5pdGlhbCB0YWlsCglwdXNoYnl0ZXMgMHgwMDAzIC8vIGluaXRpYWwgaGVhZCBvZmZzZXQKCXB1c2hieXRlcyAweDE2CgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAzNjY2ZjZmCgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcG9wIC8vIHBvcCBoZWFkIG9mZnNldAoJY29uY2F0IC8vIGNvbmNhdCBoZWFkIGFuZCB0YWlsCgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJYnl0ZSAweCAvLyBpbml0aWFsIGhlYWQKCWJ5dGUgMHggLy8gaW5pdGlhbCB0YWlsCglwdXNoYnl0ZXMgMHgwMDA0IC8vIGluaXRpYWwgaGVhZCBvZmZzZXQKCXB1c2hieXRlcyAweDAwMjEKCWNhbGxzdWIgKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMDM2MjYxNzIKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50Cglwb3AgLy8gcG9wIGhlYWQgb2Zmc2V0Cgljb25jYXQgLy8gY29uY2F0IGhlYWQgYW5kIHRhaWwKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50Cglwb3AgLy8gcG9wIGhlYWQgb2Zmc2V0Cgljb25jYXQgLy8gY29uY2F0IGhlYWQgYW5kIHRhaWwKCWZyYW1lX2J1cnkgMCAvLyBhOiBbdWludDE2LCBbdWludDw4Piwgc3RyaW5nXSwgW3VpbnQxNiwgc3RyaW5nXV0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6Njk0CgkvLyByZXR1cm4gYTsKCWZyYW1lX2RpZyAwIC8vIGE6IFt1aW50MTYsIFt1aW50PDg+LCBzdHJpbmddLCBbdWludDE2LCBzdHJpbmddXQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg0OWJiNzAxOSAvLyBtZXRob2QgIm5lc3RlZFR1cGxlKCkodWludDE2LCh1aW50OCxzdHJpbmcpLCh1aW50MTYsc3RyaW5nKSkiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX25lc3RlZFR1cGxlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJyCgoqcHJvY2Vzc19zdGF0aWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50Cgljb25jYXQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCXJldHN1YgoKKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50OgoJcHJvdG8gNCAzCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0Cgljb25jYXQKCWZyYW1lX2J1cnkgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0xIC8vIGVsZW1lbnQKCWR1cAoJbGVuCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCWJ0b2kKCSsKCWl0b2IKCWV4dHJhY3QgNiAyCglmcmFtZV9idXJ5IC0yIC8vIGhlYWQgb2Zmc2V0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJc3dhcAoJY29uY2F0CglmcmFtZV9idXJ5IC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestNestedTypesInSignature.approval.teal b/tests/contracts/artifacts/ABITestNestedTypesInSignature.approval.teal index f8e21c197..cd09df0f6 100644 --- a/tests/contracts/artifacts/ABITestNestedTypesInSignature.approval.teal +++ b/tests/contracts/artifacts/ABITestNestedTypesInSignature.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestNestedTypesInSignature.arc32.json b/tests/contracts/artifacts/ABITestNestedTypesInSignature.arc32.json index 719fdc98d..4b54c3d68 100644 --- a/tests/contracts/artifacts/ABITestNestedTypesInSignature.arc32.json +++ b/tests/contracts/artifacts/ABITestNestedTypesInSignature.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gbmVzdGVkVHlwZXNJblNpZ25hdHVyZSgpKCh1aW50NjQsdWludDY0KSx1aW50NjQpCiphYmlfcm91dGVfbmVzdGVkVHlwZXNJblNpZ25hdHVyZToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIG5lc3RlZFR5cGVzSW5TaWduYXR1cmUoKSgodWludDY0LHVpbnQ2NCksdWludDY0KQoJY2FsbHN1YiBuZXN0ZWRUeXBlc0luU2lnbmF0dXJlCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIG5lc3RlZFR5cGVzSW5TaWduYXR1cmUoKTogW1Q1LCB1aW50NjRdCm5lc3RlZFR5cGVzSW5TaWduYXR1cmU6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTEzNgoJLy8gcmV0dXJuIFtiemVybzxUNT4oKSwgMF07CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MjI3MzMxNjYgLy8gbWV0aG9kICJuZXN0ZWRUeXBlc0luU2lnbmF0dXJlKCkoKHVpbnQ2NCx1aW50NjQpLHVpbnQ2NCkiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX25lc3RlZFR5cGVzSW5TaWduYXR1cmUKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gbmVzdGVkVHlwZXNJblNpZ25hdHVyZSgpKCh1aW50NjQsdWludDY0KSx1aW50NjQpCiphYmlfcm91dGVfbmVzdGVkVHlwZXNJblNpZ25hdHVyZToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIG5lc3RlZFR5cGVzSW5TaWduYXR1cmUoKSgodWludDY0LHVpbnQ2NCksdWludDY0KQoJY2FsbHN1YiBuZXN0ZWRUeXBlc0luU2lnbmF0dXJlCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIG5lc3RlZFR5cGVzSW5TaWduYXR1cmUoKTogW1Q1LCB1aW50NjRdCm5lc3RlZFR5cGVzSW5TaWduYXR1cmU6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTEzNgoJLy8gcmV0dXJuIFtiemVybzxUNT4oKSwgMF07CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MjI3MzMxNjYgLy8gbWV0aG9kICJuZXN0ZWRUeXBlc0luU2lnbmF0dXJlKCkoKHVpbnQ2NCx1aW50NjQpLHVpbnQ2NCkiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX25lc3RlZFR5cGVzSW5TaWduYXR1cmUKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestNestedTypesInSignature.arc56_draft.json b/tests/contracts/artifacts/ABITestNestedTypesInSignature.arc56_draft.json index ea6415cca..70aa7a48e 100644 --- a/tests/contracts/artifacts/ABITestNestedTypesInSignature.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestNestedTypesInSignature.arc56_draft.json @@ -355,7 +355,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gbmVzdGVkVHlwZXNJblNpZ25hdHVyZSgpKCh1aW50NjQsdWludDY0KSx1aW50NjQpCiphYmlfcm91dGVfbmVzdGVkVHlwZXNJblNpZ25hdHVyZToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIG5lc3RlZFR5cGVzSW5TaWduYXR1cmUoKSgodWludDY0LHVpbnQ2NCksdWludDY0KQoJY2FsbHN1YiBuZXN0ZWRUeXBlc0luU2lnbmF0dXJlCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIG5lc3RlZFR5cGVzSW5TaWduYXR1cmUoKTogW1Q1LCB1aW50NjRdCm5lc3RlZFR5cGVzSW5TaWduYXR1cmU6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTEzNgoJLy8gcmV0dXJuIFtiemVybzxUNT4oKSwgMF07CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MjI3MzMxNjYgLy8gbWV0aG9kICJuZXN0ZWRUeXBlc0luU2lnbmF0dXJlKCkoKHVpbnQ2NCx1aW50NjQpLHVpbnQ2NCkiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX25lc3RlZFR5cGVzSW5TaWduYXR1cmUKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gbmVzdGVkVHlwZXNJblNpZ25hdHVyZSgpKCh1aW50NjQsdWludDY0KSx1aW50NjQpCiphYmlfcm91dGVfbmVzdGVkVHlwZXNJblNpZ25hdHVyZToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIG5lc3RlZFR5cGVzSW5TaWduYXR1cmUoKSgodWludDY0LHVpbnQ2NCksdWludDY0KQoJY2FsbHN1YiBuZXN0ZWRUeXBlc0luU2lnbmF0dXJlCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIG5lc3RlZFR5cGVzSW5TaWduYXR1cmUoKTogW1Q1LCB1aW50NjRdCm5lc3RlZFR5cGVzSW5TaWduYXR1cmU6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTEzNgoJLy8gcmV0dXJuIFtiemVybzxUNT4oKSwgMF07CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MjI3MzMxNjYgLy8gbWV0aG9kICJuZXN0ZWRUeXBlc0luU2lnbmF0dXJlKCkoKHVpbnQ2NCx1aW50NjQpLHVpbnQ2NCkiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX25lc3RlZFR5cGVzSW5TaWduYXR1cmUKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestNonE2E.approval.teal b/tests/contracts/artifacts/ABITestNonE2E.approval.teal index 4a79c9673..5ab087961 100644 --- a/tests/contracts/artifacts/ABITestNonE2E.approval.teal +++ b/tests/contracts/artifacts/ABITestNonE2E.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestNonE2E.arc32.json b/tests/contracts/artifacts/ABITestNonE2E.arc32.json index 5601e30bc..20202caf4 100644 --- a/tests/contracts/artifacts/ABITestNonE2E.arc32.json +++ b/tests/contracts/artifacts/ABITestNonE2E.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyB0eXBlV2l0aENvbW1lbnRzKCkoc3RyaW5nLHVpbnQ2NCx1aW50NjQpCiphYmlfcm91dGVfdHlwZVdpdGhDb21tZW50czoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHR5cGVXaXRoQ29tbWVudHMoKShzdHJpbmcsdWludDY0LHVpbnQ2NCkKCWNhbGxzdWIgdHlwZVdpdGhDb21tZW50cwoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyB0eXBlV2l0aENvbW1lbnRzKCk6IFQ2CnR5cGVXaXRoQ29tbWVudHM6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTE2MAoJLy8gcmV0dXJuIHsKCS8vICAgICAgIGZvbzogJ0hlbGxvIFdvcmxkIScsCgkvLyAgICAgICBiYXI6IDEsCgkvLyAgICAgICBiYXo6IDIsCgkvLyAgICAgfTsKCWJ5dGUgMHggLy8gaW5pdGlhbCBoZWFkCglieXRlIDB4IC8vIGluaXRpYWwgdGFpbAoJcHVzaGJ5dGVzIDB4MDAxMiAvLyBpbml0aWFsIGhlYWQgb2Zmc2V0CglwdXNoYnl0ZXMgMHgwMDBjNDg2NTZjNmM2ZjIwNTc2ZjcyNmM2NDIxCgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMQoJY2FsbHN1YiAqcHJvY2Vzc19zdGF0aWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMgoJY2FsbHN1YiAqcHJvY2Vzc19zdGF0aWNfdHVwbGVfZWxlbWVudAoJcG9wIC8vIHBvcCBoZWFkIG9mZnNldAoJY29uY2F0IC8vIGNvbmNhdCBoZWFkIGFuZCB0YWlsCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDIxMTdhM2I4IC8vIG1ldGhvZCAidHlwZVdpdGhDb21tZW50cygpKHN0cmluZyx1aW50NjQsdWludDY0KSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfdHlwZVdpdGhDb21tZW50cwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycgoKKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJY29uY2F0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWIKCipwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJY29uY2F0CglmcmFtZV9idXJ5IC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50CglkdXAKCWxlbgoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglidG9pCgkrCglpdG9iCglleHRyYWN0IDYgMgoJZnJhbWVfYnVyeSAtMiAvLyBoZWFkIG9mZnNldAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCXN3YXAKCWNvbmNhdAoJZnJhbWVfYnVyeSAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3Vi", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyB0eXBlV2l0aENvbW1lbnRzKCkoc3RyaW5nLHVpbnQ2NCx1aW50NjQpCiphYmlfcm91dGVfdHlwZVdpdGhDb21tZW50czoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHR5cGVXaXRoQ29tbWVudHMoKShzdHJpbmcsdWludDY0LHVpbnQ2NCkKCWNhbGxzdWIgdHlwZVdpdGhDb21tZW50cwoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyB0eXBlV2l0aENvbW1lbnRzKCk6IFQ2CnR5cGVXaXRoQ29tbWVudHM6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTE2MAoJLy8gcmV0dXJuIHsKCS8vICAgICAgIGZvbzogJ0hlbGxvIFdvcmxkIScsCgkvLyAgICAgICBiYXI6IDEsCgkvLyAgICAgICBiYXo6IDIsCgkvLyAgICAgfTsKCWJ5dGUgMHggLy8gaW5pdGlhbCBoZWFkCglieXRlIDB4IC8vIGluaXRpYWwgdGFpbAoJcHVzaGJ5dGVzIDB4MDAxMiAvLyBpbml0aWFsIGhlYWQgb2Zmc2V0CglwdXNoYnl0ZXMgMHgwMDBjNDg2NTZjNmM2ZjIwNTc2ZjcyNmM2NDIxCgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMQoJY2FsbHN1YiAqcHJvY2Vzc19zdGF0aWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMgoJY2FsbHN1YiAqcHJvY2Vzc19zdGF0aWNfdHVwbGVfZWxlbWVudAoJcG9wIC8vIHBvcCBoZWFkIG9mZnNldAoJY29uY2F0IC8vIGNvbmNhdCBoZWFkIGFuZCB0YWlsCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDIxMTdhM2I4IC8vIG1ldGhvZCAidHlwZVdpdGhDb21tZW50cygpKHN0cmluZyx1aW50NjQsdWludDY0KSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfdHlwZVdpdGhDb21tZW50cwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycgoKKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJY29uY2F0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWIKCipwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJY29uY2F0CglmcmFtZV9idXJ5IC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50CglkdXAKCWxlbgoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglidG9pCgkrCglpdG9iCglleHRyYWN0IDYgMgoJZnJhbWVfYnVyeSAtMiAvLyBoZWFkIG9mZnNldAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCXN3YXAKCWNvbmNhdAoJZnJhbWVfYnVyeSAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3Vi", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestNonE2E.arc56_draft.json b/tests/contracts/artifacts/ABITestNonE2E.arc56_draft.json index 93771b96b..530712889 100644 --- a/tests/contracts/artifacts/ABITestNonE2E.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestNonE2E.arc56_draft.json @@ -693,7 +693,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyB0eXBlV2l0aENvbW1lbnRzKCkoc3RyaW5nLHVpbnQ2NCx1aW50NjQpCiphYmlfcm91dGVfdHlwZVdpdGhDb21tZW50czoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHR5cGVXaXRoQ29tbWVudHMoKShzdHJpbmcsdWludDY0LHVpbnQ2NCkKCWNhbGxzdWIgdHlwZVdpdGhDb21tZW50cwoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyB0eXBlV2l0aENvbW1lbnRzKCk6IFQ2CnR5cGVXaXRoQ29tbWVudHM6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTE2MAoJLy8gcmV0dXJuIHsKCS8vICAgICAgIGZvbzogJ0hlbGxvIFdvcmxkIScsCgkvLyAgICAgICBiYXI6IDEsCgkvLyAgICAgICBiYXo6IDIsCgkvLyAgICAgfTsKCWJ5dGUgMHggLy8gaW5pdGlhbCBoZWFkCglieXRlIDB4IC8vIGluaXRpYWwgdGFpbAoJcHVzaGJ5dGVzIDB4MDAxMiAvLyBpbml0aWFsIGhlYWQgb2Zmc2V0CglwdXNoYnl0ZXMgMHgwMDBjNDg2NTZjNmM2ZjIwNTc2ZjcyNmM2NDIxCgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMQoJY2FsbHN1YiAqcHJvY2Vzc19zdGF0aWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMgoJY2FsbHN1YiAqcHJvY2Vzc19zdGF0aWNfdHVwbGVfZWxlbWVudAoJcG9wIC8vIHBvcCBoZWFkIG9mZnNldAoJY29uY2F0IC8vIGNvbmNhdCBoZWFkIGFuZCB0YWlsCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDIxMTdhM2I4IC8vIG1ldGhvZCAidHlwZVdpdGhDb21tZW50cygpKHN0cmluZyx1aW50NjQsdWludDY0KSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfdHlwZVdpdGhDb21tZW50cwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycgoKKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJY29uY2F0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWIKCipwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJY29uY2F0CglmcmFtZV9idXJ5IC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50CglkdXAKCWxlbgoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglidG9pCgkrCglpdG9iCglleHRyYWN0IDYgMgoJZnJhbWVfYnVyeSAtMiAvLyBoZWFkIG9mZnNldAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCXN3YXAKCWNvbmNhdAoJZnJhbWVfYnVyeSAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3Vi", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyB0eXBlV2l0aENvbW1lbnRzKCkoc3RyaW5nLHVpbnQ2NCx1aW50NjQpCiphYmlfcm91dGVfdHlwZVdpdGhDb21tZW50czoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHR5cGVXaXRoQ29tbWVudHMoKShzdHJpbmcsdWludDY0LHVpbnQ2NCkKCWNhbGxzdWIgdHlwZVdpdGhDb21tZW50cwoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyB0eXBlV2l0aENvbW1lbnRzKCk6IFQ2CnR5cGVXaXRoQ29tbWVudHM6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTE2MAoJLy8gcmV0dXJuIHsKCS8vICAgICAgIGZvbzogJ0hlbGxvIFdvcmxkIScsCgkvLyAgICAgICBiYXI6IDEsCgkvLyAgICAgICBiYXo6IDIsCgkvLyAgICAgfTsKCWJ5dGUgMHggLy8gaW5pdGlhbCBoZWFkCglieXRlIDB4IC8vIGluaXRpYWwgdGFpbAoJcHVzaGJ5dGVzIDB4MDAxMiAvLyBpbml0aWFsIGhlYWQgb2Zmc2V0CglwdXNoYnl0ZXMgMHgwMDBjNDg2NTZjNmM2ZjIwNTc2ZjcyNmM2NDIxCgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMQoJY2FsbHN1YiAqcHJvY2Vzc19zdGF0aWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMgoJY2FsbHN1YiAqcHJvY2Vzc19zdGF0aWNfdHVwbGVfZWxlbWVudAoJcG9wIC8vIHBvcCBoZWFkIG9mZnNldAoJY29uY2F0IC8vIGNvbmNhdCBoZWFkIGFuZCB0YWlsCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDIxMTdhM2I4IC8vIG1ldGhvZCAidHlwZVdpdGhDb21tZW50cygpKHN0cmluZyx1aW50NjQsdWludDY0KSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfdHlwZVdpdGhDb21tZW50cwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycgoKKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJY29uY2F0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWIKCipwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJY29uY2F0CglmcmFtZV9idXJ5IC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50CglkdXAKCWxlbgoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglidG9pCgkrCglpdG9iCglleHRyYWN0IDYgMgoJZnJhbWVfYnVyeSAtMiAvLyBoZWFkIG9mZnNldAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCXN3YXAKCWNvbmNhdAoJZnJhbWVfYnVyeSAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3Vi", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestNonLiteralDynamicElementInTuple.approval.teal b/tests/contracts/artifacts/ABITestNonLiteralDynamicElementInTuple.approval.teal index c13974c80..077025dab 100644 --- a/tests/contracts/artifacts/ABITestNonLiteralDynamicElementInTuple.approval.teal +++ b/tests/contracts/artifacts/ABITestNonLiteralDynamicElementInTuple.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestNonLiteralDynamicElementInTuple.arc32.json b/tests/contracts/artifacts/ABITestNonLiteralDynamicElementInTuple.arc32.json index fdbefc5bf..6d156cedf 100644 --- a/tests/contracts/artifacts/ABITestNonLiteralDynamicElementInTuple.arc32.json +++ b/tests/contracts/artifacts/ABITestNonLiteralDynamicElementInTuple.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBub25MaXRlcmFsRHluYW1pY0VsZW1lbnRJblR1cGxlKCkodWludDgsdWludDE2LHVpbnQ4W10sdWludDE2W10sdWludDhbXSkKKmFiaV9yb3V0ZV9ub25MaXRlcmFsRHluYW1pY0VsZW1lbnRJblR1cGxlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgbm9uTGl0ZXJhbER5bmFtaWNFbGVtZW50SW5UdXBsZSgpKHVpbnQ4LHVpbnQxNix1aW50OFtdLHVpbnQxNltdLHVpbnQ4W10pCgljYWxsc3ViIG5vbkxpdGVyYWxEeW5hbWljRWxlbWVudEluVHVwbGUKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gbm9uTGl0ZXJhbER5bmFtaWNFbGVtZW50SW5UdXBsZSgpOiBbdWludDw4PiwgdWludDE2LCB1aW50PDg+W10sIHVpbnQxNltdLCB1aW50PDg+W11dCm5vbkxpdGVyYWxEeW5hbWljRWxlbWVudEluVHVwbGU6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJYnl0ZSAweAoJZHVwCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQyMAoJLy8gZTogdWludDE2W10gPSBbNSwgNl0KCXB1c2hieXRlcyAweDAwMDUwMDA2CglmcmFtZV9idXJ5IDAgLy8gZTogdWludDE2W10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NDIxCgkvLyBhOiBbdWludDw4PiwgdWludDE2LCB1aW50PDg+W10sIHVpbnQxNltdLCB1aW50PDg+W11dID0gWzEsIDIsIFszLCA0XSwgZSwgWzcsIDhdXQoJYnl0ZSAweCAvLyBpbml0aWFsIGhlYWQKCWJ5dGUgMHggLy8gaW5pdGlhbCB0YWlsCglwdXNoYnl0ZXMgMHgwMDA5IC8vIGluaXRpYWwgaGVhZCBvZmZzZXQKCXB1c2hieXRlcyAweDAxCgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAyCgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAyMDMwNAoJY2FsbHN1YiAqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQKCWZyYW1lX2RpZyAwIC8vIGU6IHVpbnQxNltdCglkdXAKCWxlbgoJcHVzaGludCAyCgkvCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0CgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwMjA3MDgKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50Cglwb3AgLy8gcG9wIGhlYWQgb2Zmc2V0Cgljb25jYXQgLy8gY29uY2F0IGhlYWQgYW5kIHRhaWwKCWZyYW1lX2J1cnkgMSAvLyBhOiBbdWludDw4PiwgdWludDE2LCB1aW50PDg+W10sIHVpbnQxNltdLCB1aW50PDg+W11dCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQyMwoJLy8gcmV0dXJuIGE7CglmcmFtZV9kaWcgMSAvLyBhOiBbdWludDw4PiwgdWludDE2LCB1aW50PDg+W10sIHVpbnQxNltdLCB1aW50PDg+W11dCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCgoJLy8gcG9wIGFsbCBsb2NhbCB2YXJpYWJsZXMgZnJvbSB0aGUgc3RhY2sKCXBvcG4gMQoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgxMzQ2YTIwZiAvLyBtZXRob2QgIm5vbkxpdGVyYWxEeW5hbWljRWxlbWVudEluVHVwbGUoKSh1aW50OCx1aW50MTYsdWludDhbXSx1aW50MTZbXSx1aW50OFtdKSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfbm9uTGl0ZXJhbER5bmFtaWNFbGVtZW50SW5UdXBsZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycgoKKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJY29uY2F0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWIKCipwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJY29uY2F0CglmcmFtZV9idXJ5IC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50CglkdXAKCWxlbgoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglidG9pCgkrCglpdG9iCglleHRyYWN0IDYgMgoJZnJhbWVfYnVyeSAtMiAvLyBoZWFkIG9mZnNldAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCXN3YXAKCWNvbmNhdAoJZnJhbWVfYnVyeSAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3Vi", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBub25MaXRlcmFsRHluYW1pY0VsZW1lbnRJblR1cGxlKCkodWludDgsdWludDE2LHVpbnQ4W10sdWludDE2W10sdWludDhbXSkKKmFiaV9yb3V0ZV9ub25MaXRlcmFsRHluYW1pY0VsZW1lbnRJblR1cGxlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgbm9uTGl0ZXJhbER5bmFtaWNFbGVtZW50SW5UdXBsZSgpKHVpbnQ4LHVpbnQxNix1aW50OFtdLHVpbnQxNltdLHVpbnQ4W10pCgljYWxsc3ViIG5vbkxpdGVyYWxEeW5hbWljRWxlbWVudEluVHVwbGUKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gbm9uTGl0ZXJhbER5bmFtaWNFbGVtZW50SW5UdXBsZSgpOiBbdWludDw4PiwgdWludDE2LCB1aW50PDg+W10sIHVpbnQxNltdLCB1aW50PDg+W11dCm5vbkxpdGVyYWxEeW5hbWljRWxlbWVudEluVHVwbGU6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJYnl0ZSAweAoJZHVwCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQyMAoJLy8gZTogdWludDE2W10gPSBbNSwgNl0KCXB1c2hieXRlcyAweDAwMDUwMDA2CglmcmFtZV9idXJ5IDAgLy8gZTogdWludDE2W10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NDIxCgkvLyBhOiBbdWludDw4PiwgdWludDE2LCB1aW50PDg+W10sIHVpbnQxNltdLCB1aW50PDg+W11dID0gWzEsIDIsIFszLCA0XSwgZSwgWzcsIDhdXQoJYnl0ZSAweCAvLyBpbml0aWFsIGhlYWQKCWJ5dGUgMHggLy8gaW5pdGlhbCB0YWlsCglwdXNoYnl0ZXMgMHgwMDA5IC8vIGluaXRpYWwgaGVhZCBvZmZzZXQKCXB1c2hieXRlcyAweDAxCgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAyCgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAyMDMwNAoJY2FsbHN1YiAqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQKCWZyYW1lX2RpZyAwIC8vIGU6IHVpbnQxNltdCglkdXAKCWxlbgoJcHVzaGludCAyCgkvCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0CgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwMjA3MDgKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50Cglwb3AgLy8gcG9wIGhlYWQgb2Zmc2V0Cgljb25jYXQgLy8gY29uY2F0IGhlYWQgYW5kIHRhaWwKCWZyYW1lX2J1cnkgMSAvLyBhOiBbdWludDw4PiwgdWludDE2LCB1aW50PDg+W10sIHVpbnQxNltdLCB1aW50PDg+W11dCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQyMwoJLy8gcmV0dXJuIGE7CglmcmFtZV9kaWcgMSAvLyBhOiBbdWludDw4PiwgdWludDE2LCB1aW50PDg+W10sIHVpbnQxNltdLCB1aW50PDg+W11dCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCgoJLy8gcG9wIGFsbCBsb2NhbCB2YXJpYWJsZXMgZnJvbSB0aGUgc3RhY2sKCXBvcG4gMQoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgxMzQ2YTIwZiAvLyBtZXRob2QgIm5vbkxpdGVyYWxEeW5hbWljRWxlbWVudEluVHVwbGUoKSh1aW50OCx1aW50MTYsdWludDhbXSx1aW50MTZbXSx1aW50OFtdKSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfbm9uTGl0ZXJhbER5bmFtaWNFbGVtZW50SW5UdXBsZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycgoKKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJY29uY2F0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWIKCipwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJY29uY2F0CglmcmFtZV9idXJ5IC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50CglkdXAKCWxlbgoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglidG9pCgkrCglpdG9iCglleHRyYWN0IDYgMgoJZnJhbWVfYnVyeSAtMiAvLyBoZWFkIG9mZnNldAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCXN3YXAKCWNvbmNhdAoJZnJhbWVfYnVyeSAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3Vi", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestNonLiteralDynamicElementInTuple.arc56_draft.json b/tests/contracts/artifacts/ABITestNonLiteralDynamicElementInTuple.arc56_draft.json index c8a402a11..268216ed3 100644 --- a/tests/contracts/artifacts/ABITestNonLiteralDynamicElementInTuple.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestNonLiteralDynamicElementInTuple.arc56_draft.json @@ -818,7 +818,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBub25MaXRlcmFsRHluYW1pY0VsZW1lbnRJblR1cGxlKCkodWludDgsdWludDE2LHVpbnQ4W10sdWludDE2W10sdWludDhbXSkKKmFiaV9yb3V0ZV9ub25MaXRlcmFsRHluYW1pY0VsZW1lbnRJblR1cGxlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgbm9uTGl0ZXJhbER5bmFtaWNFbGVtZW50SW5UdXBsZSgpKHVpbnQ4LHVpbnQxNix1aW50OFtdLHVpbnQxNltdLHVpbnQ4W10pCgljYWxsc3ViIG5vbkxpdGVyYWxEeW5hbWljRWxlbWVudEluVHVwbGUKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gbm9uTGl0ZXJhbER5bmFtaWNFbGVtZW50SW5UdXBsZSgpOiBbdWludDw4PiwgdWludDE2LCB1aW50PDg+W10sIHVpbnQxNltdLCB1aW50PDg+W11dCm5vbkxpdGVyYWxEeW5hbWljRWxlbWVudEluVHVwbGU6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJYnl0ZSAweAoJZHVwCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQyMAoJLy8gZTogdWludDE2W10gPSBbNSwgNl0KCXB1c2hieXRlcyAweDAwMDUwMDA2CglmcmFtZV9idXJ5IDAgLy8gZTogdWludDE2W10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NDIxCgkvLyBhOiBbdWludDw4PiwgdWludDE2LCB1aW50PDg+W10sIHVpbnQxNltdLCB1aW50PDg+W11dID0gWzEsIDIsIFszLCA0XSwgZSwgWzcsIDhdXQoJYnl0ZSAweCAvLyBpbml0aWFsIGhlYWQKCWJ5dGUgMHggLy8gaW5pdGlhbCB0YWlsCglwdXNoYnl0ZXMgMHgwMDA5IC8vIGluaXRpYWwgaGVhZCBvZmZzZXQKCXB1c2hieXRlcyAweDAxCgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAyCgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAyMDMwNAoJY2FsbHN1YiAqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQKCWZyYW1lX2RpZyAwIC8vIGU6IHVpbnQxNltdCglkdXAKCWxlbgoJcHVzaGludCAyCgkvCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0CgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwMjA3MDgKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50Cglwb3AgLy8gcG9wIGhlYWQgb2Zmc2V0Cgljb25jYXQgLy8gY29uY2F0IGhlYWQgYW5kIHRhaWwKCWZyYW1lX2J1cnkgMSAvLyBhOiBbdWludDw4PiwgdWludDE2LCB1aW50PDg+W10sIHVpbnQxNltdLCB1aW50PDg+W11dCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQyMwoJLy8gcmV0dXJuIGE7CglmcmFtZV9kaWcgMSAvLyBhOiBbdWludDw4PiwgdWludDE2LCB1aW50PDg+W10sIHVpbnQxNltdLCB1aW50PDg+W11dCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCgoJLy8gcG9wIGFsbCBsb2NhbCB2YXJpYWJsZXMgZnJvbSB0aGUgc3RhY2sKCXBvcG4gMQoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgxMzQ2YTIwZiAvLyBtZXRob2QgIm5vbkxpdGVyYWxEeW5hbWljRWxlbWVudEluVHVwbGUoKSh1aW50OCx1aW50MTYsdWludDhbXSx1aW50MTZbXSx1aW50OFtdKSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfbm9uTGl0ZXJhbER5bmFtaWNFbGVtZW50SW5UdXBsZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycgoKKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJY29uY2F0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWIKCipwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJY29uY2F0CglmcmFtZV9idXJ5IC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50CglkdXAKCWxlbgoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglidG9pCgkrCglpdG9iCglleHRyYWN0IDYgMgoJZnJhbWVfYnVyeSAtMiAvLyBoZWFkIG9mZnNldAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCXN3YXAKCWNvbmNhdAoJZnJhbWVfYnVyeSAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3Vi", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBub25MaXRlcmFsRHluYW1pY0VsZW1lbnRJblR1cGxlKCkodWludDgsdWludDE2LHVpbnQ4W10sdWludDE2W10sdWludDhbXSkKKmFiaV9yb3V0ZV9ub25MaXRlcmFsRHluYW1pY0VsZW1lbnRJblR1cGxlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgbm9uTGl0ZXJhbER5bmFtaWNFbGVtZW50SW5UdXBsZSgpKHVpbnQ4LHVpbnQxNix1aW50OFtdLHVpbnQxNltdLHVpbnQ4W10pCgljYWxsc3ViIG5vbkxpdGVyYWxEeW5hbWljRWxlbWVudEluVHVwbGUKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gbm9uTGl0ZXJhbER5bmFtaWNFbGVtZW50SW5UdXBsZSgpOiBbdWludDw4PiwgdWludDE2LCB1aW50PDg+W10sIHVpbnQxNltdLCB1aW50PDg+W11dCm5vbkxpdGVyYWxEeW5hbWljRWxlbWVudEluVHVwbGU6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJYnl0ZSAweAoJZHVwCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQyMAoJLy8gZTogdWludDE2W10gPSBbNSwgNl0KCXB1c2hieXRlcyAweDAwMDUwMDA2CglmcmFtZV9idXJ5IDAgLy8gZTogdWludDE2W10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NDIxCgkvLyBhOiBbdWludDw4PiwgdWludDE2LCB1aW50PDg+W10sIHVpbnQxNltdLCB1aW50PDg+W11dID0gWzEsIDIsIFszLCA0XSwgZSwgWzcsIDhdXQoJYnl0ZSAweCAvLyBpbml0aWFsIGhlYWQKCWJ5dGUgMHggLy8gaW5pdGlhbCB0YWlsCglwdXNoYnl0ZXMgMHgwMDA5IC8vIGluaXRpYWwgaGVhZCBvZmZzZXQKCXB1c2hieXRlcyAweDAxCgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAyCgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAyMDMwNAoJY2FsbHN1YiAqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQKCWZyYW1lX2RpZyAwIC8vIGU6IHVpbnQxNltdCglkdXAKCWxlbgoJcHVzaGludCAyCgkvCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0CgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwMjA3MDgKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50Cglwb3AgLy8gcG9wIGhlYWQgb2Zmc2V0Cgljb25jYXQgLy8gY29uY2F0IGhlYWQgYW5kIHRhaWwKCWZyYW1lX2J1cnkgMSAvLyBhOiBbdWludDw4PiwgdWludDE2LCB1aW50PDg+W10sIHVpbnQxNltdLCB1aW50PDg+W11dCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQyMwoJLy8gcmV0dXJuIGE7CglmcmFtZV9kaWcgMSAvLyBhOiBbdWludDw4PiwgdWludDE2LCB1aW50PDg+W10sIHVpbnQxNltdLCB1aW50PDg+W11dCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCgoJLy8gcG9wIGFsbCBsb2NhbCB2YXJpYWJsZXMgZnJvbSB0aGUgc3RhY2sKCXBvcG4gMQoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgxMzQ2YTIwZiAvLyBtZXRob2QgIm5vbkxpdGVyYWxEeW5hbWljRWxlbWVudEluVHVwbGUoKSh1aW50OCx1aW50MTYsdWludDhbXSx1aW50MTZbXSx1aW50OFtdKSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfbm9uTGl0ZXJhbER5bmFtaWNFbGVtZW50SW5UdXBsZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycgoKKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJY29uY2F0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWIKCipwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJY29uY2F0CglmcmFtZV9idXJ5IC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50CglkdXAKCWxlbgoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglidG9pCgkrCglpdG9iCglleHRyYWN0IDYgMgoJZnJhbWVfYnVyeSAtMiAvLyBoZWFkIG9mZnNldAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCXN3YXAKCWNvbmNhdAoJZnJhbWVfYnVyeSAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3Vi", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestNonLiteralNestedArrayRef.approval.teal b/tests/contracts/artifacts/ABITestNonLiteralNestedArrayRef.approval.teal index fae1cda18..16e0ce895 100644 --- a/tests/contracts/artifacts/ABITestNonLiteralNestedArrayRef.approval.teal +++ b/tests/contracts/artifacts/ABITestNonLiteralNestedArrayRef.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestNonLiteralNestedArrayRef.arc32.json b/tests/contracts/artifacts/ABITestNonLiteralNestedArrayRef.arc32.json index 770a9f2d4..f6d6a2d9a 100644 --- a/tests/contracts/artifacts/ABITestNonLiteralNestedArrayRef.arc32.json +++ b/tests/contracts/artifacts/ABITestNonLiteralNestedArrayRef.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBub25MaXRlcmFsTmVzdGVkQXJyYXlSZWYoKXVpbnQ4WzJdWzJdCiphYmlfcm91dGVfbm9uTGl0ZXJhbE5lc3RlZEFycmF5UmVmOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgbm9uTGl0ZXJhbE5lc3RlZEFycmF5UmVmKCl1aW50OFsyXVsyXQoJY2FsbHN1YiBub25MaXRlcmFsTmVzdGVkQXJyYXlSZWYKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gbm9uTGl0ZXJhbE5lc3RlZEFycmF5UmVmKCk6IFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQ8OD4sIDI+LCAyPgpub25MaXRlcmFsTmVzdGVkQXJyYXlSZWY6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJYnl0ZSAweAoJZHVwbiAyCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjc3NQoJLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDw4PiwgMj4sIDI+ID0gWwoJLy8gICAgICAgWzEsIDJdLAoJLy8gICAgICAgWzMsIDRdLAoJLy8gICAgIF0KCXB1c2hieXRlcyAweDAxMDIwMzA0CglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDw4PiwgMj4sIDI+CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjc4MAoJLy8gaSA9IDEKCXB1c2hpbnQgMQoJZnJhbWVfYnVyeSAxIC8vIGk6IHVpbnQ2NAoJZnJhbWVfZGlnIDEgLy8gaTogdWludDY0CglmcmFtZV9idXJ5IDIgLy8gYWNjZXNzb3I6IGFjY2Vzc29yLy8wLy9iCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjc4MwoJLy8gaSA9IDEzMzcKCXB1c2hpbnQgMTMzNwoJZnJhbWVfYnVyeSAxIC8vIGk6IHVpbnQ2NAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo3ODUKCS8vIGJbMV0gPSA1IGFzIHVpbnQ8OD4KCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQ8OD4sIDI+LCAyPgoJZnJhbWVfZGlnIDIgLy8gc2F2ZWQgYWNjZXNzb3I6IGFjY2Vzc29yLy8wLy9iCglwdXNoaW50IDIKCSogLy8gYWNjICogdHlwZUxlbmd0aAoJcHVzaGludCAxCgkrCglwdXNoYnl0ZXMgMHgwNQoJcmVwbGFjZTMKCWZyYW1lX2J1cnkgMCAvLyBiOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50PDg+LCAyPiwgMj4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6Nzg3CgkvLyByZXR1cm4gYTsKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQ8OD4sIDI+LCAyPgoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoKCS8vIHBvcCBhbGwgbG9jYWwgdmFyaWFibGVzIGZyb20gdGhlIHN0YWNrCglwb3BuIDIKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZTk0MGM2M2EgLy8gbWV0aG9kICJub25MaXRlcmFsTmVzdGVkQXJyYXlSZWYoKXVpbnQ4WzJdWzJdIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9ub25MaXRlcmFsTmVzdGVkQXJyYXlSZWYKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBub25MaXRlcmFsTmVzdGVkQXJyYXlSZWYoKXVpbnQ4WzJdWzJdCiphYmlfcm91dGVfbm9uTGl0ZXJhbE5lc3RlZEFycmF5UmVmOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgbm9uTGl0ZXJhbE5lc3RlZEFycmF5UmVmKCl1aW50OFsyXVsyXQoJY2FsbHN1YiBub25MaXRlcmFsTmVzdGVkQXJyYXlSZWYKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gbm9uTGl0ZXJhbE5lc3RlZEFycmF5UmVmKCk6IFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQ8OD4sIDI+LCAyPgpub25MaXRlcmFsTmVzdGVkQXJyYXlSZWY6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJYnl0ZSAweAoJZHVwbiAyCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjc3NQoJLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDw4PiwgMj4sIDI+ID0gWwoJLy8gICAgICAgWzEsIDJdLAoJLy8gICAgICAgWzMsIDRdLAoJLy8gICAgIF0KCXB1c2hieXRlcyAweDAxMDIwMzA0CglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDw4PiwgMj4sIDI+CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjc4MAoJLy8gaSA9IDEKCXB1c2hpbnQgMQoJZnJhbWVfYnVyeSAxIC8vIGk6IHVpbnQ2NAoJZnJhbWVfZGlnIDEgLy8gaTogdWludDY0CglmcmFtZV9idXJ5IDIgLy8gYWNjZXNzb3I6IGFjY2Vzc29yLy8wLy9iCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjc4MwoJLy8gaSA9IDEzMzcKCXB1c2hpbnQgMTMzNwoJZnJhbWVfYnVyeSAxIC8vIGk6IHVpbnQ2NAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo3ODUKCS8vIGJbMV0gPSA1IGFzIHVpbnQ8OD4KCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQ8OD4sIDI+LCAyPgoJZnJhbWVfZGlnIDIgLy8gc2F2ZWQgYWNjZXNzb3I6IGFjY2Vzc29yLy8wLy9iCglwdXNoaW50IDIKCSogLy8gYWNjICogdHlwZUxlbmd0aAoJcHVzaGludCAxCgkrCglwdXNoYnl0ZXMgMHgwNQoJcmVwbGFjZTMKCWZyYW1lX2J1cnkgMCAvLyBiOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50PDg+LCAyPiwgMj4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6Nzg3CgkvLyByZXR1cm4gYTsKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQ8OD4sIDI+LCAyPgoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoKCS8vIHBvcCBhbGwgbG9jYWwgdmFyaWFibGVzIGZyb20gdGhlIHN0YWNrCglwb3BuIDIKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZTk0MGM2M2EgLy8gbWV0aG9kICJub25MaXRlcmFsTmVzdGVkQXJyYXlSZWYoKXVpbnQ4WzJdWzJdIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9ub25MaXRlcmFsTmVzdGVkQXJyYXlSZWYKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestNonLiteralNestedArrayRef.arc56_draft.json b/tests/contracts/artifacts/ABITestNonLiteralNestedArrayRef.arc56_draft.json index 9de781597..69ca7ebf3 100644 --- a/tests/contracts/artifacts/ABITestNonLiteralNestedArrayRef.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestNonLiteralNestedArrayRef.arc56_draft.json @@ -511,7 +511,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBub25MaXRlcmFsTmVzdGVkQXJyYXlSZWYoKXVpbnQ4WzJdWzJdCiphYmlfcm91dGVfbm9uTGl0ZXJhbE5lc3RlZEFycmF5UmVmOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgbm9uTGl0ZXJhbE5lc3RlZEFycmF5UmVmKCl1aW50OFsyXVsyXQoJY2FsbHN1YiBub25MaXRlcmFsTmVzdGVkQXJyYXlSZWYKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gbm9uTGl0ZXJhbE5lc3RlZEFycmF5UmVmKCk6IFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQ8OD4sIDI+LCAyPgpub25MaXRlcmFsTmVzdGVkQXJyYXlSZWY6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJYnl0ZSAweAoJZHVwbiAyCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjc3NQoJLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDw4PiwgMj4sIDI+ID0gWwoJLy8gICAgICAgWzEsIDJdLAoJLy8gICAgICAgWzMsIDRdLAoJLy8gICAgIF0KCXB1c2hieXRlcyAweDAxMDIwMzA0CglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDw4PiwgMj4sIDI+CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjc4MAoJLy8gaSA9IDEKCXB1c2hpbnQgMQoJZnJhbWVfYnVyeSAxIC8vIGk6IHVpbnQ2NAoJZnJhbWVfZGlnIDEgLy8gaTogdWludDY0CglmcmFtZV9idXJ5IDIgLy8gYWNjZXNzb3I6IGFjY2Vzc29yLy8wLy9iCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjc4MwoJLy8gaSA9IDEzMzcKCXB1c2hpbnQgMTMzNwoJZnJhbWVfYnVyeSAxIC8vIGk6IHVpbnQ2NAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo3ODUKCS8vIGJbMV0gPSA1IGFzIHVpbnQ8OD4KCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQ8OD4sIDI+LCAyPgoJZnJhbWVfZGlnIDIgLy8gc2F2ZWQgYWNjZXNzb3I6IGFjY2Vzc29yLy8wLy9iCglwdXNoaW50IDIKCSogLy8gYWNjICogdHlwZUxlbmd0aAoJcHVzaGludCAxCgkrCglwdXNoYnl0ZXMgMHgwNQoJcmVwbGFjZTMKCWZyYW1lX2J1cnkgMCAvLyBiOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50PDg+LCAyPiwgMj4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6Nzg3CgkvLyByZXR1cm4gYTsKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQ8OD4sIDI+LCAyPgoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoKCS8vIHBvcCBhbGwgbG9jYWwgdmFyaWFibGVzIGZyb20gdGhlIHN0YWNrCglwb3BuIDIKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZTk0MGM2M2EgLy8gbWV0aG9kICJub25MaXRlcmFsTmVzdGVkQXJyYXlSZWYoKXVpbnQ4WzJdWzJdIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9ub25MaXRlcmFsTmVzdGVkQXJyYXlSZWYKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBub25MaXRlcmFsTmVzdGVkQXJyYXlSZWYoKXVpbnQ4WzJdWzJdCiphYmlfcm91dGVfbm9uTGl0ZXJhbE5lc3RlZEFycmF5UmVmOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgbm9uTGl0ZXJhbE5lc3RlZEFycmF5UmVmKCl1aW50OFsyXVsyXQoJY2FsbHN1YiBub25MaXRlcmFsTmVzdGVkQXJyYXlSZWYKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gbm9uTGl0ZXJhbE5lc3RlZEFycmF5UmVmKCk6IFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQ8OD4sIDI+LCAyPgpub25MaXRlcmFsTmVzdGVkQXJyYXlSZWY6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJYnl0ZSAweAoJZHVwbiAyCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjc3NQoJLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDw4PiwgMj4sIDI+ID0gWwoJLy8gICAgICAgWzEsIDJdLAoJLy8gICAgICAgWzMsIDRdLAoJLy8gICAgIF0KCXB1c2hieXRlcyAweDAxMDIwMzA0CglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDw4PiwgMj4sIDI+CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjc4MAoJLy8gaSA9IDEKCXB1c2hpbnQgMQoJZnJhbWVfYnVyeSAxIC8vIGk6IHVpbnQ2NAoJZnJhbWVfZGlnIDEgLy8gaTogdWludDY0CglmcmFtZV9idXJ5IDIgLy8gYWNjZXNzb3I6IGFjY2Vzc29yLy8wLy9iCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjc4MwoJLy8gaSA9IDEzMzcKCXB1c2hpbnQgMTMzNwoJZnJhbWVfYnVyeSAxIC8vIGk6IHVpbnQ2NAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo3ODUKCS8vIGJbMV0gPSA1IGFzIHVpbnQ8OD4KCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQ8OD4sIDI+LCAyPgoJZnJhbWVfZGlnIDIgLy8gc2F2ZWQgYWNjZXNzb3I6IGFjY2Vzc29yLy8wLy9iCglwdXNoaW50IDIKCSogLy8gYWNjICogdHlwZUxlbmd0aAoJcHVzaGludCAxCgkrCglwdXNoYnl0ZXMgMHgwNQoJcmVwbGFjZTMKCWZyYW1lX2J1cnkgMCAvLyBiOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50PDg+LCAyPiwgMj4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6Nzg3CgkvLyByZXR1cm4gYTsKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQ8OD4sIDI+LCAyPgoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoKCS8vIHBvcCBhbGwgbG9jYWwgdmFyaWFibGVzIGZyb20gdGhlIHN0YWNrCglwb3BuIDIKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZTk0MGM2M2EgLy8gbWV0aG9kICJub25MaXRlcmFsTmVzdGVkQXJyYXlSZWYoKXVpbnQ4WzJdWzJdIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9ub25MaXRlcmFsTmVzdGVkQXJyYXlSZWYKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestNonLiteralStaticArrayAccess.approval.teal b/tests/contracts/artifacts/ABITestNonLiteralStaticArrayAccess.approval.teal index 74ffff630..7cff17709 100644 --- a/tests/contracts/artifacts/ABITestNonLiteralStaticArrayAccess.approval.teal +++ b/tests/contracts/artifacts/ABITestNonLiteralStaticArrayAccess.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestNonLiteralStaticArrayAccess.arc32.json b/tests/contracts/artifacts/ABITestNonLiteralStaticArrayAccess.arc32.json index 3cc14463f..a45a91655 100644 --- a/tests/contracts/artifacts/ABITestNonLiteralStaticArrayAccess.arc32.json +++ b/tests/contracts/artifacts/ABITestNonLiteralStaticArrayAccess.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBub25MaXRlcmFsU3RhdGljQXJyYXlBY2Nlc3MoKXVpbnQ2NAoqYWJpX3JvdXRlX25vbkxpdGVyYWxTdGF0aWNBcnJheUFjY2VzczoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIG5vbkxpdGVyYWxTdGF0aWNBcnJheUFjY2VzcygpdWludDY0CgljYWxsc3ViIG5vbkxpdGVyYWxTdGF0aWNBcnJheUFjY2VzcwoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBub25MaXRlcmFsU3RhdGljQXJyYXlBY2Nlc3MoKTogdWludDY0Cm5vbkxpdGVyYWxTdGF0aWNBcnJheUFjY2VzczoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NTUKCS8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4gPSBbMTEsIDIyLCAzM10KCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMGIwMDAwMDAwMDAwMDAwMDE2MDAwMDAwMDAwMDAwMDAyMQoJZnJhbWVfYnVyeSAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NTYKCS8vIG4gPSBidG9pKGl0b2IoMikpCglwdXNoaW50IDIKCWZyYW1lX2J1cnkgMSAvLyBuOiB1aW50NjQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NTgKCS8vIHJldHVybiBhW25dOwoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoJZXh0cmFjdCAxNiA4CglidG9pCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCgoJLy8gcG9wIGFsbCBsb2NhbCB2YXJpYWJsZXMgZnJvbSB0aGUgc3RhY2sKCXBvcG4gMQoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhkN2JkOGRmOCAvLyBtZXRob2QgIm5vbkxpdGVyYWxTdGF0aWNBcnJheUFjY2VzcygpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9ub25MaXRlcmFsU3RhdGljQXJyYXlBY2Nlc3MKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBub25MaXRlcmFsU3RhdGljQXJyYXlBY2Nlc3MoKXVpbnQ2NAoqYWJpX3JvdXRlX25vbkxpdGVyYWxTdGF0aWNBcnJheUFjY2VzczoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIG5vbkxpdGVyYWxTdGF0aWNBcnJheUFjY2VzcygpdWludDY0CgljYWxsc3ViIG5vbkxpdGVyYWxTdGF0aWNBcnJheUFjY2VzcwoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBub25MaXRlcmFsU3RhdGljQXJyYXlBY2Nlc3MoKTogdWludDY0Cm5vbkxpdGVyYWxTdGF0aWNBcnJheUFjY2VzczoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NTUKCS8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4gPSBbMTEsIDIyLCAzM10KCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMGIwMDAwMDAwMDAwMDAwMDE2MDAwMDAwMDAwMDAwMDAyMQoJZnJhbWVfYnVyeSAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NTYKCS8vIG4gPSBidG9pKGl0b2IoMikpCglwdXNoaW50IDIKCWZyYW1lX2J1cnkgMSAvLyBuOiB1aW50NjQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NTgKCS8vIHJldHVybiBhW25dOwoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoJZXh0cmFjdCAxNiA4CglidG9pCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCgoJLy8gcG9wIGFsbCBsb2NhbCB2YXJpYWJsZXMgZnJvbSB0aGUgc3RhY2sKCXBvcG4gMQoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhkN2JkOGRmOCAvLyBtZXRob2QgIm5vbkxpdGVyYWxTdGF0aWNBcnJheUFjY2VzcygpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9ub25MaXRlcmFsU3RhdGljQXJyYXlBY2Nlc3MKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestNonLiteralStaticArrayAccess.arc56_draft.json b/tests/contracts/artifacts/ABITestNonLiteralStaticArrayAccess.arc56_draft.json index 575c27558..9056301e3 100644 --- a/tests/contracts/artifacts/ABITestNonLiteralStaticArrayAccess.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestNonLiteralStaticArrayAccess.arc56_draft.json @@ -450,7 +450,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBub25MaXRlcmFsU3RhdGljQXJyYXlBY2Nlc3MoKXVpbnQ2NAoqYWJpX3JvdXRlX25vbkxpdGVyYWxTdGF0aWNBcnJheUFjY2VzczoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIG5vbkxpdGVyYWxTdGF0aWNBcnJheUFjY2VzcygpdWludDY0CgljYWxsc3ViIG5vbkxpdGVyYWxTdGF0aWNBcnJheUFjY2VzcwoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBub25MaXRlcmFsU3RhdGljQXJyYXlBY2Nlc3MoKTogdWludDY0Cm5vbkxpdGVyYWxTdGF0aWNBcnJheUFjY2VzczoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NTUKCS8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4gPSBbMTEsIDIyLCAzM10KCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMGIwMDAwMDAwMDAwMDAwMDE2MDAwMDAwMDAwMDAwMDAyMQoJZnJhbWVfYnVyeSAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NTYKCS8vIG4gPSBidG9pKGl0b2IoMikpCglwdXNoaW50IDIKCWZyYW1lX2J1cnkgMSAvLyBuOiB1aW50NjQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NTgKCS8vIHJldHVybiBhW25dOwoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoJZXh0cmFjdCAxNiA4CglidG9pCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCgoJLy8gcG9wIGFsbCBsb2NhbCB2YXJpYWJsZXMgZnJvbSB0aGUgc3RhY2sKCXBvcG4gMQoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhkN2JkOGRmOCAvLyBtZXRob2QgIm5vbkxpdGVyYWxTdGF0aWNBcnJheUFjY2VzcygpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9ub25MaXRlcmFsU3RhdGljQXJyYXlBY2Nlc3MKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBub25MaXRlcmFsU3RhdGljQXJyYXlBY2Nlc3MoKXVpbnQ2NAoqYWJpX3JvdXRlX25vbkxpdGVyYWxTdGF0aWNBcnJheUFjY2VzczoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIG5vbkxpdGVyYWxTdGF0aWNBcnJheUFjY2VzcygpdWludDY0CgljYWxsc3ViIG5vbkxpdGVyYWxTdGF0aWNBcnJheUFjY2VzcwoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBub25MaXRlcmFsU3RhdGljQXJyYXlBY2Nlc3MoKTogdWludDY0Cm5vbkxpdGVyYWxTdGF0aWNBcnJheUFjY2VzczoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NTUKCS8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4gPSBbMTEsIDIyLCAzM10KCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMGIwMDAwMDAwMDAwMDAwMDE2MDAwMDAwMDAwMDAwMDAyMQoJZnJhbWVfYnVyeSAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NTYKCS8vIG4gPSBidG9pKGl0b2IoMikpCglwdXNoaW50IDIKCWZyYW1lX2J1cnkgMSAvLyBuOiB1aW50NjQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NTgKCS8vIHJldHVybiBhW25dOwoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoJZXh0cmFjdCAxNiA4CglidG9pCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCgoJLy8gcG9wIGFsbCBsb2NhbCB2YXJpYWJsZXMgZnJvbSB0aGUgc3RhY2sKCXBvcG4gMQoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhkN2JkOGRmOCAvLyBtZXRob2QgIm5vbkxpdGVyYWxTdGF0aWNBcnJheUFjY2VzcygpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9ub25MaXRlcmFsU3RhdGljQXJyYXlBY2Nlc3MKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestNonLiteralStaticArrayElements.approval.teal b/tests/contracts/artifacts/ABITestNonLiteralStaticArrayElements.approval.teal index fdb52d5b6..0fe73b7dd 100644 --- a/tests/contracts/artifacts/ABITestNonLiteralStaticArrayElements.approval.teal +++ b/tests/contracts/artifacts/ABITestNonLiteralStaticArrayElements.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestNonLiteralStaticArrayElements.arc32.json b/tests/contracts/artifacts/ABITestNonLiteralStaticArrayElements.arc32.json index 4396456ec..161cedc1b 100644 --- a/tests/contracts/artifacts/ABITestNonLiteralStaticArrayElements.arc32.json +++ b/tests/contracts/artifacts/ABITestNonLiteralStaticArrayElements.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBub25MaXRlcmFsU3RhdGljQXJyYXlFbGVtZW50cygpdWludDY0CiphYmlfcm91dGVfbm9uTGl0ZXJhbFN0YXRpY0FycmF5RWxlbWVudHM6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBub25MaXRlcmFsU3RhdGljQXJyYXlFbGVtZW50cygpdWludDY0CgljYWxsc3ViIG5vbkxpdGVyYWxTdGF0aWNBcnJheUVsZW1lbnRzCglpdG9iCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIG5vbkxpdGVyYWxTdGF0aWNBcnJheUVsZW1lbnRzKCk6IHVpbnQ2NApub25MaXRlcmFsU3RhdGljQXJyYXlFbGVtZW50czoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXBuIDMKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MzMKCS8vIG4xID0gYnRvaShpdG9iKDExKSkKCXB1c2hpbnQgMTEKCWZyYW1lX2J1cnkgMCAvLyBuMTogdWludDY0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjM0CgkvLyBuMiA9IGJ0b2koaXRvYigyMikpCglwdXNoaW50IDIyCglmcmFtZV9idXJ5IDEgLy8gbjI6IHVpbnQ2NAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czozNQoJLy8gbjMgPSBidG9pKGl0b2IoMzMpKQoJcHVzaGludCAzMwoJZnJhbWVfYnVyeSAyIC8vIG4zOiB1aW50NjQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MzYKCS8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4gPSBbbjEsIG4yLCBuM10KCWZyYW1lX2RpZyAwIC8vIG4xOiB1aW50NjQKCWl0b2IKCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMTYKCWNvbmNhdAoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAyMQoJY29uY2F0CglmcmFtZV9idXJ5IDMgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czozOAoJLy8gcmV0dXJuIGFbMV07CglmcmFtZV9kaWcgMyAvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CglleHRyYWN0IDggOAoJYnRvaQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoKCS8vIHBvcCBhbGwgbG9jYWwgdmFyaWFibGVzIGZyb20gdGhlIHN0YWNrCglwb3BuIDMKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YmNlY2YzMWYgLy8gbWV0aG9kICJub25MaXRlcmFsU3RhdGljQXJyYXlFbGVtZW50cygpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9ub25MaXRlcmFsU3RhdGljQXJyYXlFbGVtZW50cwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBub25MaXRlcmFsU3RhdGljQXJyYXlFbGVtZW50cygpdWludDY0CiphYmlfcm91dGVfbm9uTGl0ZXJhbFN0YXRpY0FycmF5RWxlbWVudHM6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBub25MaXRlcmFsU3RhdGljQXJyYXlFbGVtZW50cygpdWludDY0CgljYWxsc3ViIG5vbkxpdGVyYWxTdGF0aWNBcnJheUVsZW1lbnRzCglpdG9iCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIG5vbkxpdGVyYWxTdGF0aWNBcnJheUVsZW1lbnRzKCk6IHVpbnQ2NApub25MaXRlcmFsU3RhdGljQXJyYXlFbGVtZW50czoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXBuIDMKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MzMKCS8vIG4xID0gYnRvaShpdG9iKDExKSkKCXB1c2hpbnQgMTEKCWZyYW1lX2J1cnkgMCAvLyBuMTogdWludDY0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjM0CgkvLyBuMiA9IGJ0b2koaXRvYigyMikpCglwdXNoaW50IDIyCglmcmFtZV9idXJ5IDEgLy8gbjI6IHVpbnQ2NAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czozNQoJLy8gbjMgPSBidG9pKGl0b2IoMzMpKQoJcHVzaGludCAzMwoJZnJhbWVfYnVyeSAyIC8vIG4zOiB1aW50NjQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MzYKCS8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4gPSBbbjEsIG4yLCBuM10KCWZyYW1lX2RpZyAwIC8vIG4xOiB1aW50NjQKCWl0b2IKCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMTYKCWNvbmNhdAoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAyMQoJY29uY2F0CglmcmFtZV9idXJ5IDMgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czozOAoJLy8gcmV0dXJuIGFbMV07CglmcmFtZV9kaWcgMyAvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CglleHRyYWN0IDggOAoJYnRvaQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoKCS8vIHBvcCBhbGwgbG9jYWwgdmFyaWFibGVzIGZyb20gdGhlIHN0YWNrCglwb3BuIDMKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YmNlY2YzMWYgLy8gbWV0aG9kICJub25MaXRlcmFsU3RhdGljQXJyYXlFbGVtZW50cygpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9ub25MaXRlcmFsU3RhdGljQXJyYXlFbGVtZW50cwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestNonLiteralStaticArrayElements.arc56_draft.json b/tests/contracts/artifacts/ABITestNonLiteralStaticArrayElements.arc56_draft.json index 196c95a2c..e2b779d07 100644 --- a/tests/contracts/artifacts/ABITestNonLiteralStaticArrayElements.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestNonLiteralStaticArrayElements.arc56_draft.json @@ -512,7 +512,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBub25MaXRlcmFsU3RhdGljQXJyYXlFbGVtZW50cygpdWludDY0CiphYmlfcm91dGVfbm9uTGl0ZXJhbFN0YXRpY0FycmF5RWxlbWVudHM6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBub25MaXRlcmFsU3RhdGljQXJyYXlFbGVtZW50cygpdWludDY0CgljYWxsc3ViIG5vbkxpdGVyYWxTdGF0aWNBcnJheUVsZW1lbnRzCglpdG9iCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIG5vbkxpdGVyYWxTdGF0aWNBcnJheUVsZW1lbnRzKCk6IHVpbnQ2NApub25MaXRlcmFsU3RhdGljQXJyYXlFbGVtZW50czoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXBuIDMKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MzMKCS8vIG4xID0gYnRvaShpdG9iKDExKSkKCXB1c2hpbnQgMTEKCWZyYW1lX2J1cnkgMCAvLyBuMTogdWludDY0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjM0CgkvLyBuMiA9IGJ0b2koaXRvYigyMikpCglwdXNoaW50IDIyCglmcmFtZV9idXJ5IDEgLy8gbjI6IHVpbnQ2NAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czozNQoJLy8gbjMgPSBidG9pKGl0b2IoMzMpKQoJcHVzaGludCAzMwoJZnJhbWVfYnVyeSAyIC8vIG4zOiB1aW50NjQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MzYKCS8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4gPSBbbjEsIG4yLCBuM10KCWZyYW1lX2RpZyAwIC8vIG4xOiB1aW50NjQKCWl0b2IKCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMTYKCWNvbmNhdAoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAyMQoJY29uY2F0CglmcmFtZV9idXJ5IDMgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czozOAoJLy8gcmV0dXJuIGFbMV07CglmcmFtZV9kaWcgMyAvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CglleHRyYWN0IDggOAoJYnRvaQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoKCS8vIHBvcCBhbGwgbG9jYWwgdmFyaWFibGVzIGZyb20gdGhlIHN0YWNrCglwb3BuIDMKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YmNlY2YzMWYgLy8gbWV0aG9kICJub25MaXRlcmFsU3RhdGljQXJyYXlFbGVtZW50cygpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9ub25MaXRlcmFsU3RhdGljQXJyYXlFbGVtZW50cwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBub25MaXRlcmFsU3RhdGljQXJyYXlFbGVtZW50cygpdWludDY0CiphYmlfcm91dGVfbm9uTGl0ZXJhbFN0YXRpY0FycmF5RWxlbWVudHM6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBub25MaXRlcmFsU3RhdGljQXJyYXlFbGVtZW50cygpdWludDY0CgljYWxsc3ViIG5vbkxpdGVyYWxTdGF0aWNBcnJheUVsZW1lbnRzCglpdG9iCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIG5vbkxpdGVyYWxTdGF0aWNBcnJheUVsZW1lbnRzKCk6IHVpbnQ2NApub25MaXRlcmFsU3RhdGljQXJyYXlFbGVtZW50czoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXBuIDMKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MzMKCS8vIG4xID0gYnRvaShpdG9iKDExKSkKCXB1c2hpbnQgMTEKCWZyYW1lX2J1cnkgMCAvLyBuMTogdWludDY0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjM0CgkvLyBuMiA9IGJ0b2koaXRvYigyMikpCglwdXNoaW50IDIyCglmcmFtZV9idXJ5IDEgLy8gbjI6IHVpbnQ2NAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czozNQoJLy8gbjMgPSBidG9pKGl0b2IoMzMpKQoJcHVzaGludCAzMwoJZnJhbWVfYnVyeSAyIC8vIG4zOiB1aW50NjQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MzYKCS8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4gPSBbbjEsIG4yLCBuM10KCWZyYW1lX2RpZyAwIC8vIG4xOiB1aW50NjQKCWl0b2IKCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMTYKCWNvbmNhdAoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAyMQoJY29uY2F0CglmcmFtZV9idXJ5IDMgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czozOAoJLy8gcmV0dXJuIGFbMV07CglmcmFtZV9kaWcgMyAvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CglleHRyYWN0IDggOAoJYnRvaQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoKCS8vIHBvcCBhbGwgbG9jYWwgdmFyaWFibGVzIGZyb20gdGhlIHN0YWNrCglwb3BuIDMKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YmNlY2YzMWYgLy8gbWV0aG9kICJub25MaXRlcmFsU3RhdGljQXJyYXlFbGVtZW50cygpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9ub25MaXRlcmFsU3RhdGljQXJyYXlFbGVtZW50cwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestObjectArrayRef.approval.teal b/tests/contracts/artifacts/ABITestObjectArrayRef.approval.teal index 254ca0939..495bc8bd6 100644 --- a/tests/contracts/artifacts/ABITestObjectArrayRef.approval.teal +++ b/tests/contracts/artifacts/ABITestObjectArrayRef.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestObjectArrayRef.arc32.json b/tests/contracts/artifacts/ABITestObjectArrayRef.arc32.json index 281e67d6e..49f6db570 100644 --- a/tests/contracts/artifacts/ABITestObjectArrayRef.arc32.json +++ b/tests/contracts/artifacts/ABITestObjectArrayRef.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gb2JqZWN0QXJyYXlSZWYoKSh1aW50OFsyXVsyXSkKKmFiaV9yb3V0ZV9vYmplY3RBcnJheVJlZjoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIG9iamVjdEFycmF5UmVmKCkodWludDhbMl1bMl0pCgljYWxsc3ViIG9iamVjdEFycmF5UmVmCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIG9iamVjdEFycmF5UmVmKCk6IE9iamVjdFJlZlR5cGUKb2JqZWN0QXJyYXlSZWY6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjgxNwoJLy8gYTogT2JqZWN0UmVmVHlwZSA9IHsKCS8vICAgICAgIGZvbzogWwoJLy8gICAgICAgICBbMSwgMl0sCgkvLyAgICAgICAgIFszLCA0XSwKCS8vICAgICAgIF0sCgkvLyAgICAgfQoJcHVzaGJ5dGVzIDB4MDEwMjAzMDQKCWZyYW1lX2J1cnkgMCAvLyBhOiBPYmplY3RSZWZUeXBlCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjgyNAoJLy8gYyA9IGJbMV0KCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4MjYKCS8vIGNbMV0gPSA1IGFzIHVpbnQ8OD4KCWZyYW1lX2RpZyAwIC8vIGE6IE9iamVjdFJlZlR5cGUKCXB1c2hieXRlcyAweDA1CglyZXBsYWNlMiAzCglmcmFtZV9idXJ5IDAgLy8gYzogT2JqZWN0UmVmVHlwZQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4MjgKCS8vIHJldHVybiBhOwoJZnJhbWVfZGlnIDAgLy8gYTogT2JqZWN0UmVmVHlwZQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg1NDViNDAxNiAvLyBtZXRob2QgIm9iamVjdEFycmF5UmVmKCkodWludDhbMl1bMl0pIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9vYmplY3RBcnJheVJlZgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gb2JqZWN0QXJyYXlSZWYoKSh1aW50OFsyXVsyXSkKKmFiaV9yb3V0ZV9vYmplY3RBcnJheVJlZjoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIG9iamVjdEFycmF5UmVmKCkodWludDhbMl1bMl0pCgljYWxsc3ViIG9iamVjdEFycmF5UmVmCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIG9iamVjdEFycmF5UmVmKCk6IE9iamVjdFJlZlR5cGUKb2JqZWN0QXJyYXlSZWY6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjgxNwoJLy8gYTogT2JqZWN0UmVmVHlwZSA9IHsKCS8vICAgICAgIGZvbzogWwoJLy8gICAgICAgICBbMSwgMl0sCgkvLyAgICAgICAgIFszLCA0XSwKCS8vICAgICAgIF0sCgkvLyAgICAgfQoJcHVzaGJ5dGVzIDB4MDEwMjAzMDQKCWZyYW1lX2J1cnkgMCAvLyBhOiBPYmplY3RSZWZUeXBlCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjgyNAoJLy8gYyA9IGJbMV0KCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4MjYKCS8vIGNbMV0gPSA1IGFzIHVpbnQ8OD4KCWZyYW1lX2RpZyAwIC8vIGE6IE9iamVjdFJlZlR5cGUKCXB1c2hieXRlcyAweDA1CglyZXBsYWNlMiAzCglmcmFtZV9idXJ5IDAgLy8gYzogT2JqZWN0UmVmVHlwZQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4MjgKCS8vIHJldHVybiBhOwoJZnJhbWVfZGlnIDAgLy8gYTogT2JqZWN0UmVmVHlwZQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg1NDViNDAxNiAvLyBtZXRob2QgIm9iamVjdEFycmF5UmVmKCkodWludDhbMl1bMl0pIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9vYmplY3RBcnJheVJlZgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestObjectArrayRef.arc56_draft.json b/tests/contracts/artifacts/ABITestObjectArrayRef.arc56_draft.json index c2e1aeeda..6625a53c6 100644 --- a/tests/contracts/artifacts/ABITestObjectArrayRef.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestObjectArrayRef.arc56_draft.json @@ -408,7 +408,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gb2JqZWN0QXJyYXlSZWYoKSh1aW50OFsyXVsyXSkKKmFiaV9yb3V0ZV9vYmplY3RBcnJheVJlZjoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIG9iamVjdEFycmF5UmVmKCkodWludDhbMl1bMl0pCgljYWxsc3ViIG9iamVjdEFycmF5UmVmCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIG9iamVjdEFycmF5UmVmKCk6IE9iamVjdFJlZlR5cGUKb2JqZWN0QXJyYXlSZWY6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjgxNwoJLy8gYTogT2JqZWN0UmVmVHlwZSA9IHsKCS8vICAgICAgIGZvbzogWwoJLy8gICAgICAgICBbMSwgMl0sCgkvLyAgICAgICAgIFszLCA0XSwKCS8vICAgICAgIF0sCgkvLyAgICAgfQoJcHVzaGJ5dGVzIDB4MDEwMjAzMDQKCWZyYW1lX2J1cnkgMCAvLyBhOiBPYmplY3RSZWZUeXBlCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjgyNAoJLy8gYyA9IGJbMV0KCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4MjYKCS8vIGNbMV0gPSA1IGFzIHVpbnQ8OD4KCWZyYW1lX2RpZyAwIC8vIGE6IE9iamVjdFJlZlR5cGUKCXB1c2hieXRlcyAweDA1CglyZXBsYWNlMiAzCglmcmFtZV9idXJ5IDAgLy8gYzogT2JqZWN0UmVmVHlwZQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4MjgKCS8vIHJldHVybiBhOwoJZnJhbWVfZGlnIDAgLy8gYTogT2JqZWN0UmVmVHlwZQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg1NDViNDAxNiAvLyBtZXRob2QgIm9iamVjdEFycmF5UmVmKCkodWludDhbMl1bMl0pIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9vYmplY3RBcnJheVJlZgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gb2JqZWN0QXJyYXlSZWYoKSh1aW50OFsyXVsyXSkKKmFiaV9yb3V0ZV9vYmplY3RBcnJheVJlZjoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIG9iamVjdEFycmF5UmVmKCkodWludDhbMl1bMl0pCgljYWxsc3ViIG9iamVjdEFycmF5UmVmCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIG9iamVjdEFycmF5UmVmKCk6IE9iamVjdFJlZlR5cGUKb2JqZWN0QXJyYXlSZWY6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjgxNwoJLy8gYTogT2JqZWN0UmVmVHlwZSA9IHsKCS8vICAgICAgIGZvbzogWwoJLy8gICAgICAgICBbMSwgMl0sCgkvLyAgICAgICAgIFszLCA0XSwKCS8vICAgICAgIF0sCgkvLyAgICAgfQoJcHVzaGJ5dGVzIDB4MDEwMjAzMDQKCWZyYW1lX2J1cnkgMCAvLyBhOiBPYmplY3RSZWZUeXBlCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjgyNAoJLy8gYyA9IGJbMV0KCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4MjYKCS8vIGNbMV0gPSA1IGFzIHVpbnQ8OD4KCWZyYW1lX2RpZyAwIC8vIGE6IE9iamVjdFJlZlR5cGUKCXB1c2hieXRlcyAweDA1CglyZXBsYWNlMiAzCglmcmFtZV9idXJ5IDAgLy8gYzogT2JqZWN0UmVmVHlwZQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4MjgKCS8vIHJldHVybiBhOwoJZnJhbWVfZGlnIDAgLy8gYTogT2JqZWN0UmVmVHlwZQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg1NDViNDAxNiAvLyBtZXRob2QgIm9iamVjdEFycmF5UmVmKCkodWludDhbMl1bMl0pIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9vYmplY3RBcnJheVJlZgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestObjectInArgs.approval.teal b/tests/contracts/artifacts/ABITestObjectInArgs.approval.teal index ae65b81ad..6453c6cee 100644 --- a/tests/contracts/artifacts/ABITestObjectInArgs.approval.teal +++ b/tests/contracts/artifacts/ABITestObjectInArgs.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestObjectInArgs.arc32.json b/tests/contracts/artifacts/ABITestObjectInArgs.arc32.json index 85ba93e9a..7bf3accad 100644 --- a/tests/contracts/artifacts/ABITestObjectInArgs.arc32.json +++ b/tests/contracts/artifacts/ABITestObjectInArgs.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcHJpdmF0ZU1ldGhvZChhOiBBZGRyZXNzLCBvYmo6IE9iamVjdEluQXJnc1R5cGUpOiB1aW50NjQKcHJpdmF0ZU1ldGhvZDoKCXByb3RvIDIgMQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNDA0CgkvLyByZXR1cm4gb2JqLmJhciArIG9iai5mb287CglmcmFtZV9kaWcgLTIgLy8gb2JqOiBPYmplY3RJbkFyZ3NUeXBlCglleHRyYWN0IDggOAoJYnRvaQoJZnJhbWVfZGlnIC0yIC8vIG9iajogT2JqZWN0SW5BcmdzVHlwZQoJZXh0cmFjdCAwIDgKCWJ0b2kKCSsKCXJldHN1YgoKLy8gb2JqZWN0SW5BcmdzKCl1aW50NjQKKmFiaV9yb3V0ZV9vYmplY3RJbkFyZ3M6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBvYmplY3RJbkFyZ3MoKXVpbnQ2NAoJY2FsbHN1YiBvYmplY3RJbkFyZ3MKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gb2JqZWN0SW5BcmdzKCk6IHVpbnQ2NApvYmplY3RJbkFyZ3M6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTQwOAoJLy8gcmV0dXJuIHRoaXMucHJpdmF0ZU1ldGhvZCh0aGlzLnR4bi5zZW5kZXIsIHsgZm9vOiAxLCBiYXI6IDIgfSk7CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDAxMDAwMDAwMDAwMDAwMDAwMgoJdHhuIFNlbmRlcgoJY2FsbHN1YiBwcml2YXRlTWV0aG9kCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDY4ODZhOTcxIC8vIG1ldGhvZCAib2JqZWN0SW5BcmdzKCl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX29iamVjdEluQXJncwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcHJpdmF0ZU1ldGhvZChhOiBBZGRyZXNzLCBvYmo6IE9iamVjdEluQXJnc1R5cGUpOiB1aW50NjQKcHJpdmF0ZU1ldGhvZDoKCXByb3RvIDIgMQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNDA0CgkvLyByZXR1cm4gb2JqLmJhciArIG9iai5mb287CglmcmFtZV9kaWcgLTIgLy8gb2JqOiBPYmplY3RJbkFyZ3NUeXBlCglleHRyYWN0IDggOAoJYnRvaQoJZnJhbWVfZGlnIC0yIC8vIG9iajogT2JqZWN0SW5BcmdzVHlwZQoJZXh0cmFjdCAwIDgKCWJ0b2kKCSsKCXJldHN1YgoKLy8gb2JqZWN0SW5BcmdzKCl1aW50NjQKKmFiaV9yb3V0ZV9vYmplY3RJbkFyZ3M6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBvYmplY3RJbkFyZ3MoKXVpbnQ2NAoJY2FsbHN1YiBvYmplY3RJbkFyZ3MKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gb2JqZWN0SW5BcmdzKCk6IHVpbnQ2NApvYmplY3RJbkFyZ3M6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTQwOAoJLy8gcmV0dXJuIHRoaXMucHJpdmF0ZU1ldGhvZCh0aGlzLnR4bi5zZW5kZXIsIHsgZm9vOiAxLCBiYXI6IDIgfSk7CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDAxMDAwMDAwMDAwMDAwMDAwMgoJdHhuIFNlbmRlcgoJY2FsbHN1YiBwcml2YXRlTWV0aG9kCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDY4ODZhOTcxIC8vIG1ldGhvZCAib2JqZWN0SW5BcmdzKCl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX29iamVjdEluQXJncwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestObjectInArgs.arc56_draft.json b/tests/contracts/artifacts/ABITestObjectInArgs.arc56_draft.json index 05c7c8730..2260ef627 100644 --- a/tests/contracts/artifacts/ABITestObjectInArgs.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestObjectInArgs.arc56_draft.json @@ -442,7 +442,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcHJpdmF0ZU1ldGhvZChhOiBBZGRyZXNzLCBvYmo6IE9iamVjdEluQXJnc1R5cGUpOiB1aW50NjQKcHJpdmF0ZU1ldGhvZDoKCXByb3RvIDIgMQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNDA0CgkvLyByZXR1cm4gb2JqLmJhciArIG9iai5mb287CglmcmFtZV9kaWcgLTIgLy8gb2JqOiBPYmplY3RJbkFyZ3NUeXBlCglleHRyYWN0IDggOAoJYnRvaQoJZnJhbWVfZGlnIC0yIC8vIG9iajogT2JqZWN0SW5BcmdzVHlwZQoJZXh0cmFjdCAwIDgKCWJ0b2kKCSsKCXJldHN1YgoKLy8gb2JqZWN0SW5BcmdzKCl1aW50NjQKKmFiaV9yb3V0ZV9vYmplY3RJbkFyZ3M6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBvYmplY3RJbkFyZ3MoKXVpbnQ2NAoJY2FsbHN1YiBvYmplY3RJbkFyZ3MKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gb2JqZWN0SW5BcmdzKCk6IHVpbnQ2NApvYmplY3RJbkFyZ3M6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTQwOAoJLy8gcmV0dXJuIHRoaXMucHJpdmF0ZU1ldGhvZCh0aGlzLnR4bi5zZW5kZXIsIHsgZm9vOiAxLCBiYXI6IDIgfSk7CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDAxMDAwMDAwMDAwMDAwMDAwMgoJdHhuIFNlbmRlcgoJY2FsbHN1YiBwcml2YXRlTWV0aG9kCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDY4ODZhOTcxIC8vIG1ldGhvZCAib2JqZWN0SW5BcmdzKCl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX29iamVjdEluQXJncwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcHJpdmF0ZU1ldGhvZChhOiBBZGRyZXNzLCBvYmo6IE9iamVjdEluQXJnc1R5cGUpOiB1aW50NjQKcHJpdmF0ZU1ldGhvZDoKCXByb3RvIDIgMQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNDA0CgkvLyByZXR1cm4gb2JqLmJhciArIG9iai5mb287CglmcmFtZV9kaWcgLTIgLy8gb2JqOiBPYmplY3RJbkFyZ3NUeXBlCglleHRyYWN0IDggOAoJYnRvaQoJZnJhbWVfZGlnIC0yIC8vIG9iajogT2JqZWN0SW5BcmdzVHlwZQoJZXh0cmFjdCAwIDgKCWJ0b2kKCSsKCXJldHN1YgoKLy8gb2JqZWN0SW5BcmdzKCl1aW50NjQKKmFiaV9yb3V0ZV9vYmplY3RJbkFyZ3M6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBvYmplY3RJbkFyZ3MoKXVpbnQ2NAoJY2FsbHN1YiBvYmplY3RJbkFyZ3MKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gb2JqZWN0SW5BcmdzKCk6IHVpbnQ2NApvYmplY3RJbkFyZ3M6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTQwOAoJLy8gcmV0dXJuIHRoaXMucHJpdmF0ZU1ldGhvZCh0aGlzLnR4bi5zZW5kZXIsIHsgZm9vOiAxLCBiYXI6IDIgfSk7CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDAxMDAwMDAwMDAwMDAwMDAwMgoJdHhuIFNlbmRlcgoJY2FsbHN1YiBwcml2YXRlTWV0aG9kCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDY4ODZhOTcxIC8vIG1ldGhvZCAib2JqZWN0SW5BcmdzKCl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX29iamVjdEluQXJncwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestObjectRef.approval.teal b/tests/contracts/artifacts/ABITestObjectRef.approval.teal index 105631c59..ce35683a5 100644 --- a/tests/contracts/artifacts/ABITestObjectRef.approval.teal +++ b/tests/contracts/artifacts/ABITestObjectRef.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestObjectRef.arc32.json b/tests/contracts/artifacts/ABITestObjectRef.arc32.json index d80caa73d..93fddfea9 100644 --- a/tests/contracts/artifacts/ABITestObjectRef.arc32.json +++ b/tests/contracts/artifacts/ABITestObjectRef.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gb2JqZWN0UmVmKCkodWludDY0KQoqYWJpX3JvdXRlX29iamVjdFJlZjoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIG9iamVjdFJlZigpKHVpbnQ2NCkKCWNhbGxzdWIgb2JqZWN0UmVmCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIG9iamVjdFJlZigpOiB7IGZvbzogdWludDY0IH0Kb2JqZWN0UmVmOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo5ODYKCS8vIG86IHsgZm9vOiB1aW50NjQgfSA9IHsgZm9vOiAxIH0KCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDEKCWZyYW1lX2J1cnkgMCAvLyBvOiB7IGZvbzogdWludDY0IH0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6OTkwCgkvLyByLmZvbyA9IDIKCWZyYW1lX2RpZyAwIC8vIG86IHsgZm9vOiB1aW50NjQgfQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMgoJcmVwbGFjZTIgMAoJZnJhbWVfYnVyeSAwIC8vIHI6IHsgZm9vOiB1aW50NjQgfQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo5OTIKCS8vIHJldHVybiBvOwoJZnJhbWVfZGlnIDAgLy8gbzogeyBmb286IHVpbnQ2NCB9CgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDg1Yzc1YWNhIC8vIG1ldGhvZCAib2JqZWN0UmVmKCkodWludDY0KSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfb2JqZWN0UmVmCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gb2JqZWN0UmVmKCkodWludDY0KQoqYWJpX3JvdXRlX29iamVjdFJlZjoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIG9iamVjdFJlZigpKHVpbnQ2NCkKCWNhbGxzdWIgb2JqZWN0UmVmCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIG9iamVjdFJlZigpOiB7IGZvbzogdWludDY0IH0Kb2JqZWN0UmVmOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo5ODYKCS8vIG86IHsgZm9vOiB1aW50NjQgfSA9IHsgZm9vOiAxIH0KCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDEKCWZyYW1lX2J1cnkgMCAvLyBvOiB7IGZvbzogdWludDY0IH0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6OTkwCgkvLyByLmZvbyA9IDIKCWZyYW1lX2RpZyAwIC8vIG86IHsgZm9vOiB1aW50NjQgfQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMgoJcmVwbGFjZTIgMAoJZnJhbWVfYnVyeSAwIC8vIHI6IHsgZm9vOiB1aW50NjQgfQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo5OTIKCS8vIHJldHVybiBvOwoJZnJhbWVfZGlnIDAgLy8gbzogeyBmb286IHVpbnQ2NCB9CgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDg1Yzc1YWNhIC8vIG1ldGhvZCAib2JqZWN0UmVmKCkodWludDY0KSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfb2JqZWN0UmVmCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestObjectRef.arc56_draft.json b/tests/contracts/artifacts/ABITestObjectRef.arc56_draft.json index d9b4a0254..82554632a 100644 --- a/tests/contracts/artifacts/ABITestObjectRef.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestObjectRef.arc56_draft.json @@ -419,7 +419,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gb2JqZWN0UmVmKCkodWludDY0KQoqYWJpX3JvdXRlX29iamVjdFJlZjoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIG9iamVjdFJlZigpKHVpbnQ2NCkKCWNhbGxzdWIgb2JqZWN0UmVmCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIG9iamVjdFJlZigpOiB7IGZvbzogdWludDY0IH0Kb2JqZWN0UmVmOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo5ODYKCS8vIG86IHsgZm9vOiB1aW50NjQgfSA9IHsgZm9vOiAxIH0KCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDEKCWZyYW1lX2J1cnkgMCAvLyBvOiB7IGZvbzogdWludDY0IH0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6OTkwCgkvLyByLmZvbyA9IDIKCWZyYW1lX2RpZyAwIC8vIG86IHsgZm9vOiB1aW50NjQgfQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMgoJcmVwbGFjZTIgMAoJZnJhbWVfYnVyeSAwIC8vIHI6IHsgZm9vOiB1aW50NjQgfQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo5OTIKCS8vIHJldHVybiBvOwoJZnJhbWVfZGlnIDAgLy8gbzogeyBmb286IHVpbnQ2NCB9CgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDg1Yzc1YWNhIC8vIG1ldGhvZCAib2JqZWN0UmVmKCkodWludDY0KSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfb2JqZWN0UmVmCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gb2JqZWN0UmVmKCkodWludDY0KQoqYWJpX3JvdXRlX29iamVjdFJlZjoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIG9iamVjdFJlZigpKHVpbnQ2NCkKCWNhbGxzdWIgb2JqZWN0UmVmCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIG9iamVjdFJlZigpOiB7IGZvbzogdWludDY0IH0Kb2JqZWN0UmVmOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo5ODYKCS8vIG86IHsgZm9vOiB1aW50NjQgfSA9IHsgZm9vOiAxIH0KCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDEKCWZyYW1lX2J1cnkgMCAvLyBvOiB7IGZvbzogdWludDY0IH0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6OTkwCgkvLyByLmZvbyA9IDIKCWZyYW1lX2RpZyAwIC8vIG86IHsgZm9vOiB1aW50NjQgfQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMgoJcmVwbGFjZTIgMAoJZnJhbWVfYnVyeSAwIC8vIHI6IHsgZm9vOiB1aW50NjQgfQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo5OTIKCS8vIHJldHVybiBvOwoJZnJhbWVfZGlnIDAgLy8gbzogeyBmb286IHVpbnQ2NCB9CgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDg1Yzc1YWNhIC8vIG1ldGhvZCAib2JqZWN0UmVmKCkodWludDY0KSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfb2JqZWN0UmVmCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestOpcodeParamFromObject.approval.teal b/tests/contracts/artifacts/ABITestOpcodeParamFromObject.approval.teal index 771a94198..10d42a6d4 100644 --- a/tests/contracts/artifacts/ABITestOpcodeParamFromObject.approval.teal +++ b/tests/contracts/artifacts/ABITestOpcodeParamFromObject.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestOpcodeParamFromObject.arc32.json b/tests/contracts/artifacts/ABITestOpcodeParamFromObject.arc32.json index 3b726e953..085bf2358 100644 --- a/tests/contracts/artifacts/ABITestOpcodeParamFromObject.arc32.json +++ b/tests/contracts/artifacts/ABITestOpcodeParamFromObject.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gb3Bjb2RlUGFyYW1Gcm9tT2JqZWN0KClhZGRyZXNzCiphYmlfcm91dGVfb3Bjb2RlUGFyYW1Gcm9tT2JqZWN0OgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgb3Bjb2RlUGFyYW1Gcm9tT2JqZWN0KClhZGRyZXNzCgljYWxsc3ViIG9wY29kZVBhcmFtRnJvbU9iamVjdAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBvcGNvZGVQYXJhbUZyb21PYmplY3QoKTogQWRkcmVzcwpvcGNvZGVQYXJhbUZyb21PYmplY3Q6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEwNjcKCS8vIGE6IHsgbXlBcHA6IEFwcElEIH0gPSB7IG15QXBwOiB0aGlzLmFwcCB9Cgl0eG5hIEFwcGxpY2F0aW9ucyAwCglpdG9iCglmcmFtZV9idXJ5IDAgLy8gYTogeyBteUFwcDogQXBwSUQgfQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMDY5CgkvLyByZXR1cm4gdGhpcy5hcHAuYWRkcmVzczsKCWdsb2JhbCBDdXJyZW50QXBwbGljYXRpb25BZGRyZXNzCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDc5ZjcwMzMzIC8vIG1ldGhvZCAib3Bjb2RlUGFyYW1Gcm9tT2JqZWN0KClhZGRyZXNzIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9vcGNvZGVQYXJhbUZyb21PYmplY3QKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gb3Bjb2RlUGFyYW1Gcm9tT2JqZWN0KClhZGRyZXNzCiphYmlfcm91dGVfb3Bjb2RlUGFyYW1Gcm9tT2JqZWN0OgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgb3Bjb2RlUGFyYW1Gcm9tT2JqZWN0KClhZGRyZXNzCgljYWxsc3ViIG9wY29kZVBhcmFtRnJvbU9iamVjdAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBvcGNvZGVQYXJhbUZyb21PYmplY3QoKTogQWRkcmVzcwpvcGNvZGVQYXJhbUZyb21PYmplY3Q6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEwNjcKCS8vIGE6IHsgbXlBcHA6IEFwcElEIH0gPSB7IG15QXBwOiB0aGlzLmFwcCB9Cgl0eG5hIEFwcGxpY2F0aW9ucyAwCglpdG9iCglmcmFtZV9idXJ5IDAgLy8gYTogeyBteUFwcDogQXBwSUQgfQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMDY5CgkvLyByZXR1cm4gdGhpcy5hcHAuYWRkcmVzczsKCWdsb2JhbCBDdXJyZW50QXBwbGljYXRpb25BZGRyZXNzCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDc5ZjcwMzMzIC8vIG1ldGhvZCAib3Bjb2RlUGFyYW1Gcm9tT2JqZWN0KClhZGRyZXNzIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9vcGNvZGVQYXJhbUZyb21PYmplY3QKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestOpcodeParamFromObject.arc56_draft.json b/tests/contracts/artifacts/ABITestOpcodeParamFromObject.arc56_draft.json index 9fb7dc718..45fa355b2 100644 --- a/tests/contracts/artifacts/ABITestOpcodeParamFromObject.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestOpcodeParamFromObject.arc56_draft.json @@ -371,7 +371,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gb3Bjb2RlUGFyYW1Gcm9tT2JqZWN0KClhZGRyZXNzCiphYmlfcm91dGVfb3Bjb2RlUGFyYW1Gcm9tT2JqZWN0OgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgb3Bjb2RlUGFyYW1Gcm9tT2JqZWN0KClhZGRyZXNzCgljYWxsc3ViIG9wY29kZVBhcmFtRnJvbU9iamVjdAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBvcGNvZGVQYXJhbUZyb21PYmplY3QoKTogQWRkcmVzcwpvcGNvZGVQYXJhbUZyb21PYmplY3Q6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEwNjcKCS8vIGE6IHsgbXlBcHA6IEFwcElEIH0gPSB7IG15QXBwOiB0aGlzLmFwcCB9Cgl0eG5hIEFwcGxpY2F0aW9ucyAwCglpdG9iCglmcmFtZV9idXJ5IDAgLy8gYTogeyBteUFwcDogQXBwSUQgfQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMDY5CgkvLyByZXR1cm4gdGhpcy5hcHAuYWRkcmVzczsKCWdsb2JhbCBDdXJyZW50QXBwbGljYXRpb25BZGRyZXNzCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDc5ZjcwMzMzIC8vIG1ldGhvZCAib3Bjb2RlUGFyYW1Gcm9tT2JqZWN0KClhZGRyZXNzIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9vcGNvZGVQYXJhbUZyb21PYmplY3QKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gb3Bjb2RlUGFyYW1Gcm9tT2JqZWN0KClhZGRyZXNzCiphYmlfcm91dGVfb3Bjb2RlUGFyYW1Gcm9tT2JqZWN0OgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgb3Bjb2RlUGFyYW1Gcm9tT2JqZWN0KClhZGRyZXNzCgljYWxsc3ViIG9wY29kZVBhcmFtRnJvbU9iamVjdAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBvcGNvZGVQYXJhbUZyb21PYmplY3QoKTogQWRkcmVzcwpvcGNvZGVQYXJhbUZyb21PYmplY3Q6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEwNjcKCS8vIGE6IHsgbXlBcHA6IEFwcElEIH0gPSB7IG15QXBwOiB0aGlzLmFwcCB9Cgl0eG5hIEFwcGxpY2F0aW9ucyAwCglpdG9iCglmcmFtZV9idXJ5IDAgLy8gYTogeyBteUFwcDogQXBwSUQgfQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMDY5CgkvLyByZXR1cm4gdGhpcy5hcHAuYWRkcmVzczsKCWdsb2JhbCBDdXJyZW50QXBwbGljYXRpb25BZGRyZXNzCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDc5ZjcwMzMzIC8vIG1ldGhvZCAib3Bjb2RlUGFyYW1Gcm9tT2JqZWN0KClhZGRyZXNzIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9vcGNvZGVQYXJhbUZyb21PYmplY3QKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestPartialStaticArray.approval.teal b/tests/contracts/artifacts/ABITestPartialStaticArray.approval.teal index 84228a6b4..cbaa57172 100644 --- a/tests/contracts/artifacts/ABITestPartialStaticArray.approval.teal +++ b/tests/contracts/artifacts/ABITestPartialStaticArray.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestPartialStaticArray.arc32.json b/tests/contracts/artifacts/ABITestPartialStaticArray.arc32.json index f7194df69..c5cbb1914 100644 --- a/tests/contracts/artifacts/ABITestPartialStaticArray.arc32.json +++ b/tests/contracts/artifacts/ABITestPartialStaticArray.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcGFydGlhbFN0YXRpY0FycmF5KCl1aW50MTZbM10KKmFiaV9yb3V0ZV9wYXJ0aWFsU3RhdGljQXJyYXk6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBwYXJ0aWFsU3RhdGljQXJyYXkoKXVpbnQxNlszXQoJY2FsbHN1YiBwYXJ0aWFsU3RhdGljQXJyYXkKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gcGFydGlhbFN0YXRpY0FycmF5KCk6IFN0YXRpY0FycmF5PHVpbnQxNiwgMz4KcGFydGlhbFN0YXRpY0FycmF5OgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4NTAKCS8vIGE6IFN0YXRpY0FycmF5PHVpbnQxNiwgMz4gPSBbMV0KCXB1c2hieXRlcyAweDAwMDEwMDAwMDAwMAoJZnJhbWVfYnVyeSAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQxNiwgMz4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6ODUyCgkvLyByZXR1cm4gYTsKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQxNiwgMz4KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZDI5NGRjMTQgLy8gbWV0aG9kICJwYXJ0aWFsU3RhdGljQXJyYXkoKXVpbnQxNlszXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfcGFydGlhbFN0YXRpY0FycmF5CgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcGFydGlhbFN0YXRpY0FycmF5KCl1aW50MTZbM10KKmFiaV9yb3V0ZV9wYXJ0aWFsU3RhdGljQXJyYXk6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBwYXJ0aWFsU3RhdGljQXJyYXkoKXVpbnQxNlszXQoJY2FsbHN1YiBwYXJ0aWFsU3RhdGljQXJyYXkKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gcGFydGlhbFN0YXRpY0FycmF5KCk6IFN0YXRpY0FycmF5PHVpbnQxNiwgMz4KcGFydGlhbFN0YXRpY0FycmF5OgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4NTAKCS8vIGE6IFN0YXRpY0FycmF5PHVpbnQxNiwgMz4gPSBbMV0KCXB1c2hieXRlcyAweDAwMDEwMDAwMDAwMAoJZnJhbWVfYnVyeSAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQxNiwgMz4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6ODUyCgkvLyByZXR1cm4gYTsKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQxNiwgMz4KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZDI5NGRjMTQgLy8gbWV0aG9kICJwYXJ0aWFsU3RhdGljQXJyYXkoKXVpbnQxNlszXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfcGFydGlhbFN0YXRpY0FycmF5CgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestPartialStaticArray.arc56_draft.json b/tests/contracts/artifacts/ABITestPartialStaticArray.arc56_draft.json index d79520605..fc0b3cda8 100644 --- a/tests/contracts/artifacts/ABITestPartialStaticArray.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestPartialStaticArray.arc56_draft.json @@ -369,7 +369,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcGFydGlhbFN0YXRpY0FycmF5KCl1aW50MTZbM10KKmFiaV9yb3V0ZV9wYXJ0aWFsU3RhdGljQXJyYXk6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBwYXJ0aWFsU3RhdGljQXJyYXkoKXVpbnQxNlszXQoJY2FsbHN1YiBwYXJ0aWFsU3RhdGljQXJyYXkKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gcGFydGlhbFN0YXRpY0FycmF5KCk6IFN0YXRpY0FycmF5PHVpbnQxNiwgMz4KcGFydGlhbFN0YXRpY0FycmF5OgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4NTAKCS8vIGE6IFN0YXRpY0FycmF5PHVpbnQxNiwgMz4gPSBbMV0KCXB1c2hieXRlcyAweDAwMDEwMDAwMDAwMAoJZnJhbWVfYnVyeSAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQxNiwgMz4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6ODUyCgkvLyByZXR1cm4gYTsKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQxNiwgMz4KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZDI5NGRjMTQgLy8gbWV0aG9kICJwYXJ0aWFsU3RhdGljQXJyYXkoKXVpbnQxNlszXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfcGFydGlhbFN0YXRpY0FycmF5CgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcGFydGlhbFN0YXRpY0FycmF5KCl1aW50MTZbM10KKmFiaV9yb3V0ZV9wYXJ0aWFsU3RhdGljQXJyYXk6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBwYXJ0aWFsU3RhdGljQXJyYXkoKXVpbnQxNlszXQoJY2FsbHN1YiBwYXJ0aWFsU3RhdGljQXJyYXkKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gcGFydGlhbFN0YXRpY0FycmF5KCk6IFN0YXRpY0FycmF5PHVpbnQxNiwgMz4KcGFydGlhbFN0YXRpY0FycmF5OgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4NTAKCS8vIGE6IFN0YXRpY0FycmF5PHVpbnQxNiwgMz4gPSBbMV0KCXB1c2hieXRlcyAweDAwMDEwMDAwMDAwMAoJZnJhbWVfYnVyeSAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQxNiwgMz4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6ODUyCgkvLyByZXR1cm4gYTsKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQxNiwgMz4KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZDI5NGRjMTQgLy8gbWV0aG9kICJwYXJ0aWFsU3RhdGljQXJyYXkoKXVpbnQxNlszXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfcGFydGlhbFN0YXRpY0FycmF5CgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestPlusEqualsArrayValue.approval.teal b/tests/contracts/artifacts/ABITestPlusEqualsArrayValue.approval.teal index 1f606cad5..dbc28c039 100644 --- a/tests/contracts/artifacts/ABITestPlusEqualsArrayValue.approval.teal +++ b/tests/contracts/artifacts/ABITestPlusEqualsArrayValue.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestPlusEqualsArrayValue.arc32.json b/tests/contracts/artifacts/ABITestPlusEqualsArrayValue.arc32.json index f144651f5..fc975f110 100644 --- a/tests/contracts/artifacts/ABITestPlusEqualsArrayValue.arc32.json +++ b/tests/contracts/artifacts/ABITestPlusEqualsArrayValue.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcGx1c0VxdWFsc0FycmF5VmFsdWUoKXVpbnQ2NFsyXQoqYWJpX3JvdXRlX3BsdXNFcXVhbHNBcnJheVZhbHVlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgcGx1c0VxdWFsc0FycmF5VmFsdWUoKXVpbnQ2NFsyXQoJY2FsbHN1YiBwbHVzRXF1YWxzQXJyYXlWYWx1ZQoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBwbHVzRXF1YWxzQXJyYXlWYWx1ZSgpOiBTdGF0aWNBcnJheTx1aW50NjQsIDI+CnBsdXNFcXVhbHNBcnJheVZhbHVlOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjMzCgkvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDI+ID0gWzEsIDJdCglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDAxMDAwMDAwMDAwMDAwMDAwMgoJZnJhbWVfYnVyeSAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMj4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTIzNAoJLy8gYVsxXSArPSAxCglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDI+CglwdXNoaW50IDgKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMj4KCWV4dHJhY3QgOCA4CglidG9pCglwdXNoaW50IDEKCSsKCWl0b2IKCXJlcGxhY2UzCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAyPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjM1CgkvLyByZXR1cm4gYTsKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMj4KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YjVlZjc5YmQgLy8gbWV0aG9kICJwbHVzRXF1YWxzQXJyYXlWYWx1ZSgpdWludDY0WzJdIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9wbHVzRXF1YWxzQXJyYXlWYWx1ZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcGx1c0VxdWFsc0FycmF5VmFsdWUoKXVpbnQ2NFsyXQoqYWJpX3JvdXRlX3BsdXNFcXVhbHNBcnJheVZhbHVlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgcGx1c0VxdWFsc0FycmF5VmFsdWUoKXVpbnQ2NFsyXQoJY2FsbHN1YiBwbHVzRXF1YWxzQXJyYXlWYWx1ZQoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBwbHVzRXF1YWxzQXJyYXlWYWx1ZSgpOiBTdGF0aWNBcnJheTx1aW50NjQsIDI+CnBsdXNFcXVhbHNBcnJheVZhbHVlOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjMzCgkvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDI+ID0gWzEsIDJdCglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDAxMDAwMDAwMDAwMDAwMDAwMgoJZnJhbWVfYnVyeSAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMj4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTIzNAoJLy8gYVsxXSArPSAxCglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDI+CglwdXNoaW50IDgKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMj4KCWV4dHJhY3QgOCA4CglidG9pCglwdXNoaW50IDEKCSsKCWl0b2IKCXJlcGxhY2UzCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAyPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjM1CgkvLyByZXR1cm4gYTsKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMj4KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YjVlZjc5YmQgLy8gbWV0aG9kICJwbHVzRXF1YWxzQXJyYXlWYWx1ZSgpdWludDY0WzJdIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9wbHVzRXF1YWxzQXJyYXlWYWx1ZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestPlusEqualsArrayValue.arc56_draft.json b/tests/contracts/artifacts/ABITestPlusEqualsArrayValue.arc56_draft.json index 75253da1a..4b6158317 100644 --- a/tests/contracts/artifacts/ABITestPlusEqualsArrayValue.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestPlusEqualsArrayValue.arc56_draft.json @@ -456,7 +456,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcGx1c0VxdWFsc0FycmF5VmFsdWUoKXVpbnQ2NFsyXQoqYWJpX3JvdXRlX3BsdXNFcXVhbHNBcnJheVZhbHVlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgcGx1c0VxdWFsc0FycmF5VmFsdWUoKXVpbnQ2NFsyXQoJY2FsbHN1YiBwbHVzRXF1YWxzQXJyYXlWYWx1ZQoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBwbHVzRXF1YWxzQXJyYXlWYWx1ZSgpOiBTdGF0aWNBcnJheTx1aW50NjQsIDI+CnBsdXNFcXVhbHNBcnJheVZhbHVlOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjMzCgkvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDI+ID0gWzEsIDJdCglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDAxMDAwMDAwMDAwMDAwMDAwMgoJZnJhbWVfYnVyeSAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMj4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTIzNAoJLy8gYVsxXSArPSAxCglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDI+CglwdXNoaW50IDgKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMj4KCWV4dHJhY3QgOCA4CglidG9pCglwdXNoaW50IDEKCSsKCWl0b2IKCXJlcGxhY2UzCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAyPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjM1CgkvLyByZXR1cm4gYTsKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMj4KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YjVlZjc5YmQgLy8gbWV0aG9kICJwbHVzRXF1YWxzQXJyYXlWYWx1ZSgpdWludDY0WzJdIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9wbHVzRXF1YWxzQXJyYXlWYWx1ZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcGx1c0VxdWFsc0FycmF5VmFsdWUoKXVpbnQ2NFsyXQoqYWJpX3JvdXRlX3BsdXNFcXVhbHNBcnJheVZhbHVlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgcGx1c0VxdWFsc0FycmF5VmFsdWUoKXVpbnQ2NFsyXQoJY2FsbHN1YiBwbHVzRXF1YWxzQXJyYXlWYWx1ZQoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBwbHVzRXF1YWxzQXJyYXlWYWx1ZSgpOiBTdGF0aWNBcnJheTx1aW50NjQsIDI+CnBsdXNFcXVhbHNBcnJheVZhbHVlOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjMzCgkvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDI+ID0gWzEsIDJdCglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDAxMDAwMDAwMDAwMDAwMDAwMgoJZnJhbWVfYnVyeSAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMj4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTIzNAoJLy8gYVsxXSArPSAxCglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDI+CglwdXNoaW50IDgKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMj4KCWV4dHJhY3QgOCA4CglidG9pCglwdXNoaW50IDEKCSsKCWl0b2IKCXJlcGxhY2UzCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAyPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjM1CgkvLyByZXR1cm4gYTsKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMj4KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YjVlZjc5YmQgLy8gbWV0aG9kICJwbHVzRXF1YWxzQXJyYXlWYWx1ZSgpdWludDY0WzJdIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9wbHVzRXF1YWxzQXJyYXlWYWx1ZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestPlusEqualsObjValue.approval.teal b/tests/contracts/artifacts/ABITestPlusEqualsObjValue.approval.teal index 260b650a5..f9c3b74f5 100644 --- a/tests/contracts/artifacts/ABITestPlusEqualsObjValue.approval.teal +++ b/tests/contracts/artifacts/ABITestPlusEqualsObjValue.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestPlusEqualsObjValue.arc32.json b/tests/contracts/artifacts/ABITestPlusEqualsObjValue.arc32.json index 2120107f9..f2852dead 100644 --- a/tests/contracts/artifacts/ABITestPlusEqualsObjValue.arc32.json +++ b/tests/contracts/artifacts/ABITestPlusEqualsObjValue.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcGx1c0VxdWFsc09ialZhbHVlKCkodWludDY0LHVpbnQ2NCkKKmFiaV9yb3V0ZV9wbHVzRXF1YWxzT2JqVmFsdWU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBwbHVzRXF1YWxzT2JqVmFsdWUoKSh1aW50NjQsdWludDY0KQoJY2FsbHN1YiBwbHVzRXF1YWxzT2JqVmFsdWUKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gcGx1c0VxdWFsc09ialZhbHVlKCk6IHsgZm9vOiB1aW50NjQ7IGJhcjogdWludDY0IH0KcGx1c0VxdWFsc09ialZhbHVlOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjQxCgkvLyBhOiB7IGZvbzogdWludDY0OyBiYXI6IHVpbnQ2NCB9ID0geyBmb286IDMsIGJhcjogNCB9CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDAzMDAwMDAwMDAwMDAwMDAwNAoJZnJhbWVfYnVyeSAwIC8vIGE6IHsgZm9vOiB1aW50NjQ7IGJhcjogdWludDY0IH0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTI0MgoJLy8gYS5iYXIgKz0gMQoJZnJhbWVfZGlnIDAgLy8gYTogeyBmb286IHVpbnQ2NDsgYmFyOiB1aW50NjQgfQoJcHVzaGludCA4IC8vIGhlYWRPZmZzZXQKCWZyYW1lX2RpZyAwIC8vIGE6IHsgZm9vOiB1aW50NjQ7IGJhcjogdWludDY0IH0KCWV4dHJhY3QgOCA4CglidG9pCglwdXNoaW50IDEKCSsKCWl0b2IKCXJlcGxhY2UzCglmcmFtZV9idXJ5IDAgLy8gYTogeyBmb286IHVpbnQ2NDsgYmFyOiB1aW50NjQgfQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjQzCgkvLyByZXR1cm4gYTsKCWZyYW1lX2RpZyAwIC8vIGE6IHsgZm9vOiB1aW50NjQ7IGJhcjogdWludDY0IH0KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MjlmODZmOGMgLy8gbWV0aG9kICJwbHVzRXF1YWxzT2JqVmFsdWUoKSh1aW50NjQsdWludDY0KSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfcGx1c0VxdWFsc09ialZhbHVlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcGx1c0VxdWFsc09ialZhbHVlKCkodWludDY0LHVpbnQ2NCkKKmFiaV9yb3V0ZV9wbHVzRXF1YWxzT2JqVmFsdWU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBwbHVzRXF1YWxzT2JqVmFsdWUoKSh1aW50NjQsdWludDY0KQoJY2FsbHN1YiBwbHVzRXF1YWxzT2JqVmFsdWUKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gcGx1c0VxdWFsc09ialZhbHVlKCk6IHsgZm9vOiB1aW50NjQ7IGJhcjogdWludDY0IH0KcGx1c0VxdWFsc09ialZhbHVlOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjQxCgkvLyBhOiB7IGZvbzogdWludDY0OyBiYXI6IHVpbnQ2NCB9ID0geyBmb286IDMsIGJhcjogNCB9CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDAzMDAwMDAwMDAwMDAwMDAwNAoJZnJhbWVfYnVyeSAwIC8vIGE6IHsgZm9vOiB1aW50NjQ7IGJhcjogdWludDY0IH0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTI0MgoJLy8gYS5iYXIgKz0gMQoJZnJhbWVfZGlnIDAgLy8gYTogeyBmb286IHVpbnQ2NDsgYmFyOiB1aW50NjQgfQoJcHVzaGludCA4IC8vIGhlYWRPZmZzZXQKCWZyYW1lX2RpZyAwIC8vIGE6IHsgZm9vOiB1aW50NjQ7IGJhcjogdWludDY0IH0KCWV4dHJhY3QgOCA4CglidG9pCglwdXNoaW50IDEKCSsKCWl0b2IKCXJlcGxhY2UzCglmcmFtZV9idXJ5IDAgLy8gYTogeyBmb286IHVpbnQ2NDsgYmFyOiB1aW50NjQgfQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjQzCgkvLyByZXR1cm4gYTsKCWZyYW1lX2RpZyAwIC8vIGE6IHsgZm9vOiB1aW50NjQ7IGJhcjogdWludDY0IH0KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MjlmODZmOGMgLy8gbWV0aG9kICJwbHVzRXF1YWxzT2JqVmFsdWUoKSh1aW50NjQsdWludDY0KSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfcGx1c0VxdWFsc09ialZhbHVlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestPlusEqualsObjValue.arc56_draft.json b/tests/contracts/artifacts/ABITestPlusEqualsObjValue.arc56_draft.json index b2609a096..253f600bf 100644 --- a/tests/contracts/artifacts/ABITestPlusEqualsObjValue.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestPlusEqualsObjValue.arc56_draft.json @@ -468,7 +468,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcGx1c0VxdWFsc09ialZhbHVlKCkodWludDY0LHVpbnQ2NCkKKmFiaV9yb3V0ZV9wbHVzRXF1YWxzT2JqVmFsdWU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBwbHVzRXF1YWxzT2JqVmFsdWUoKSh1aW50NjQsdWludDY0KQoJY2FsbHN1YiBwbHVzRXF1YWxzT2JqVmFsdWUKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gcGx1c0VxdWFsc09ialZhbHVlKCk6IHsgZm9vOiB1aW50NjQ7IGJhcjogdWludDY0IH0KcGx1c0VxdWFsc09ialZhbHVlOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjQxCgkvLyBhOiB7IGZvbzogdWludDY0OyBiYXI6IHVpbnQ2NCB9ID0geyBmb286IDMsIGJhcjogNCB9CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDAzMDAwMDAwMDAwMDAwMDAwNAoJZnJhbWVfYnVyeSAwIC8vIGE6IHsgZm9vOiB1aW50NjQ7IGJhcjogdWludDY0IH0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTI0MgoJLy8gYS5iYXIgKz0gMQoJZnJhbWVfZGlnIDAgLy8gYTogeyBmb286IHVpbnQ2NDsgYmFyOiB1aW50NjQgfQoJcHVzaGludCA4IC8vIGhlYWRPZmZzZXQKCWZyYW1lX2RpZyAwIC8vIGE6IHsgZm9vOiB1aW50NjQ7IGJhcjogdWludDY0IH0KCWV4dHJhY3QgOCA4CglidG9pCglwdXNoaW50IDEKCSsKCWl0b2IKCXJlcGxhY2UzCglmcmFtZV9idXJ5IDAgLy8gYTogeyBmb286IHVpbnQ2NDsgYmFyOiB1aW50NjQgfQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjQzCgkvLyByZXR1cm4gYTsKCWZyYW1lX2RpZyAwIC8vIGE6IHsgZm9vOiB1aW50NjQ7IGJhcjogdWludDY0IH0KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MjlmODZmOGMgLy8gbWV0aG9kICJwbHVzRXF1YWxzT2JqVmFsdWUoKSh1aW50NjQsdWludDY0KSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfcGx1c0VxdWFsc09ialZhbHVlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcGx1c0VxdWFsc09ialZhbHVlKCkodWludDY0LHVpbnQ2NCkKKmFiaV9yb3V0ZV9wbHVzRXF1YWxzT2JqVmFsdWU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBwbHVzRXF1YWxzT2JqVmFsdWUoKSh1aW50NjQsdWludDY0KQoJY2FsbHN1YiBwbHVzRXF1YWxzT2JqVmFsdWUKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gcGx1c0VxdWFsc09ialZhbHVlKCk6IHsgZm9vOiB1aW50NjQ7IGJhcjogdWludDY0IH0KcGx1c0VxdWFsc09ialZhbHVlOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjQxCgkvLyBhOiB7IGZvbzogdWludDY0OyBiYXI6IHVpbnQ2NCB9ID0geyBmb286IDMsIGJhcjogNCB9CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDAzMDAwMDAwMDAwMDAwMDAwNAoJZnJhbWVfYnVyeSAwIC8vIGE6IHsgZm9vOiB1aW50NjQ7IGJhcjogdWludDY0IH0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTI0MgoJLy8gYS5iYXIgKz0gMQoJZnJhbWVfZGlnIDAgLy8gYTogeyBmb286IHVpbnQ2NDsgYmFyOiB1aW50NjQgfQoJcHVzaGludCA4IC8vIGhlYWRPZmZzZXQKCWZyYW1lX2RpZyAwIC8vIGE6IHsgZm9vOiB1aW50NjQ7IGJhcjogdWludDY0IH0KCWV4dHJhY3QgOCA4CglidG9pCglwdXNoaW50IDEKCSsKCWl0b2IKCXJlcGxhY2UzCglmcmFtZV9idXJ5IDAgLy8gYTogeyBmb286IHVpbnQ2NDsgYmFyOiB1aW50NjQgfQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjQzCgkvLyByZXR1cm4gYTsKCWZyYW1lX2RpZyAwIC8vIGE6IHsgZm9vOiB1aW50NjQ7IGJhcjogdWludDY0IH0KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MjlmODZmOGMgLy8gbWV0aG9kICJwbHVzRXF1YWxzT2JqVmFsdWUoKSh1aW50NjQsdWludDY0KSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfcGx1c0VxdWFsc09ialZhbHVlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestPlusEqualsObjValueInBox.approval.teal b/tests/contracts/artifacts/ABITestPlusEqualsObjValueInBox.approval.teal index b5cad8e63..49a95ba27 100644 --- a/tests/contracts/artifacts/ABITestPlusEqualsObjValueInBox.approval.teal +++ b/tests/contracts/artifacts/ABITestPlusEqualsObjValueInBox.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x624d6170 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestPlusEqualsObjValueInBox.arc32.json b/tests/contracts/artifacts/ABITestPlusEqualsObjValueInBox.arc32.json index ca405ef39..b4df84ef7 100644 --- a/tests/contracts/artifacts/ABITestPlusEqualsObjValueInBox.arc32.json +++ b/tests/contracts/artifacts/ABITestPlusEqualsObjValueInBox.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2MjRkNjE3MAoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDQuMQovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIHBsdXNFcXVhbHNPYmpWYWx1ZUluQm94KCkodWludDY0LHVpbnQ2NCkKKmFiaV9yb3V0ZV9wbHVzRXF1YWxzT2JqVmFsdWVJbkJveDoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHBsdXNFcXVhbHNPYmpWYWx1ZUluQm94KCkodWludDY0LHVpbnQ2NCkKCWNhbGxzdWIgcGx1c0VxdWFsc09ialZhbHVlSW5Cb3gKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gcGx1c0VxdWFsc09ialZhbHVlSW5Cb3goKTogeyBmb286IHVpbnQ2NDsgYmFyOiB1aW50NjQgfQpwbHVzRXF1YWxzT2JqVmFsdWVJbkJveDoKCXByb3RvIDAgMQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjUxCgkvLyB0aGlzLmJNYXAoJ2JNYXAnKS52YWx1ZSA9IHsgZm9vOiAzLCBiYXI6IDQgfQoJYnl0ZSAweDYyNGQ2MTcwIC8vICJiTWFwIgoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMzAwMDAwMDAwMDAwMDAwMDQKCWJveF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTI1MgoJLy8gdGhpcy5iTWFwKCdiTWFwJykudmFsdWUuYmFyICs9IDEKCXB1c2hpbnQgOCAvLyBoZWFkT2Zmc2V0CglieXRlIDB4NjI0ZDYxNzAgLy8gImJNYXAiCglwdXNoaW50IDggLy8gaGVhZE9mZnNldAoJcHVzaGludCA4Cglib3hfZXh0cmFjdAoJYnRvaQoJcHVzaGludCAxCgkrCglpdG9iCglieXRlIDB4NjI0ZDYxNzAgLy8gImJNYXAiCgljb3ZlciAyCglib3hfcmVwbGFjZQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjUzCgkvLyByZXR1cm4gdGhpcy5iTWFwKCdiTWFwJykudmFsdWU7CglieXRlIDB4NjI0ZDYxNzAgLy8gImJNYXAiCglib3hfZ2V0CgoJLy8gYm94IHZhbHVlIGRvZXMgbm90IGV4aXN0OiB0aGlzLmJNYXAoJ2JNYXAnKS52YWx1ZQoJYXNzZXJ0CglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDY2MTliNTExIC8vIG1ldGhvZCAicGx1c0VxdWFsc09ialZhbHVlSW5Cb3goKSh1aW50NjQsdWludDY0KSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfcGx1c0VxdWFsc09ialZhbHVlSW5Cb3gKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2MjRkNjE3MAoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDUuMAovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIHBsdXNFcXVhbHNPYmpWYWx1ZUluQm94KCkodWludDY0LHVpbnQ2NCkKKmFiaV9yb3V0ZV9wbHVzRXF1YWxzT2JqVmFsdWVJbkJveDoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHBsdXNFcXVhbHNPYmpWYWx1ZUluQm94KCkodWludDY0LHVpbnQ2NCkKCWNhbGxzdWIgcGx1c0VxdWFsc09ialZhbHVlSW5Cb3gKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gcGx1c0VxdWFsc09ialZhbHVlSW5Cb3goKTogeyBmb286IHVpbnQ2NDsgYmFyOiB1aW50NjQgfQpwbHVzRXF1YWxzT2JqVmFsdWVJbkJveDoKCXByb3RvIDAgMQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjUxCgkvLyB0aGlzLmJNYXAoJ2JNYXAnKS52YWx1ZSA9IHsgZm9vOiAzLCBiYXI6IDQgfQoJYnl0ZSAweDYyNGQ2MTcwIC8vICJiTWFwIgoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMzAwMDAwMDAwMDAwMDAwMDQKCWJveF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTI1MgoJLy8gdGhpcy5iTWFwKCdiTWFwJykudmFsdWUuYmFyICs9IDEKCXB1c2hpbnQgOCAvLyBoZWFkT2Zmc2V0CglieXRlIDB4NjI0ZDYxNzAgLy8gImJNYXAiCglwdXNoaW50IDggLy8gaGVhZE9mZnNldAoJcHVzaGludCA4Cglib3hfZXh0cmFjdAoJYnRvaQoJcHVzaGludCAxCgkrCglpdG9iCglieXRlIDB4NjI0ZDYxNzAgLy8gImJNYXAiCgljb3ZlciAyCglib3hfcmVwbGFjZQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjUzCgkvLyByZXR1cm4gdGhpcy5iTWFwKCdiTWFwJykudmFsdWU7CglieXRlIDB4NjI0ZDYxNzAgLy8gImJNYXAiCglib3hfZ2V0CgoJLy8gYm94IHZhbHVlIGRvZXMgbm90IGV4aXN0OiB0aGlzLmJNYXAoJ2JNYXAnKS52YWx1ZQoJYXNzZXJ0CglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDY2MTliNTExIC8vIG1ldGhvZCAicGx1c0VxdWFsc09ialZhbHVlSW5Cb3goKSh1aW50NjQsdWludDY0KSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfcGx1c0VxdWFsc09ialZhbHVlSW5Cb3gKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestPlusEqualsObjValueInBox.arc56_draft.json b/tests/contracts/artifacts/ABITestPlusEqualsObjValueInBox.arc56_draft.json index ee95203e3..a37b0d998 100644 --- a/tests/contracts/artifacts/ABITestPlusEqualsObjValueInBox.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestPlusEqualsObjValueInBox.arc56_draft.json @@ -532,7 +532,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2MjRkNjE3MAoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDQuMQovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIHBsdXNFcXVhbHNPYmpWYWx1ZUluQm94KCkodWludDY0LHVpbnQ2NCkKKmFiaV9yb3V0ZV9wbHVzRXF1YWxzT2JqVmFsdWVJbkJveDoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHBsdXNFcXVhbHNPYmpWYWx1ZUluQm94KCkodWludDY0LHVpbnQ2NCkKCWNhbGxzdWIgcGx1c0VxdWFsc09ialZhbHVlSW5Cb3gKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gcGx1c0VxdWFsc09ialZhbHVlSW5Cb3goKTogeyBmb286IHVpbnQ2NDsgYmFyOiB1aW50NjQgfQpwbHVzRXF1YWxzT2JqVmFsdWVJbkJveDoKCXByb3RvIDAgMQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjUxCgkvLyB0aGlzLmJNYXAoJ2JNYXAnKS52YWx1ZSA9IHsgZm9vOiAzLCBiYXI6IDQgfQoJYnl0ZSAweDYyNGQ2MTcwIC8vICJiTWFwIgoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMzAwMDAwMDAwMDAwMDAwMDQKCWJveF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTI1MgoJLy8gdGhpcy5iTWFwKCdiTWFwJykudmFsdWUuYmFyICs9IDEKCXB1c2hpbnQgOCAvLyBoZWFkT2Zmc2V0CglieXRlIDB4NjI0ZDYxNzAgLy8gImJNYXAiCglwdXNoaW50IDggLy8gaGVhZE9mZnNldAoJcHVzaGludCA4Cglib3hfZXh0cmFjdAoJYnRvaQoJcHVzaGludCAxCgkrCglpdG9iCglieXRlIDB4NjI0ZDYxNzAgLy8gImJNYXAiCgljb3ZlciAyCglib3hfcmVwbGFjZQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjUzCgkvLyByZXR1cm4gdGhpcy5iTWFwKCdiTWFwJykudmFsdWU7CglieXRlIDB4NjI0ZDYxNzAgLy8gImJNYXAiCglib3hfZ2V0CgoJLy8gYm94IHZhbHVlIGRvZXMgbm90IGV4aXN0OiB0aGlzLmJNYXAoJ2JNYXAnKS52YWx1ZQoJYXNzZXJ0CglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDY2MTliNTExIC8vIG1ldGhvZCAicGx1c0VxdWFsc09ialZhbHVlSW5Cb3goKSh1aW50NjQsdWludDY0KSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfcGx1c0VxdWFsc09ialZhbHVlSW5Cb3gKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2MjRkNjE3MAoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDUuMAovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIHBsdXNFcXVhbHNPYmpWYWx1ZUluQm94KCkodWludDY0LHVpbnQ2NCkKKmFiaV9yb3V0ZV9wbHVzRXF1YWxzT2JqVmFsdWVJbkJveDoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHBsdXNFcXVhbHNPYmpWYWx1ZUluQm94KCkodWludDY0LHVpbnQ2NCkKCWNhbGxzdWIgcGx1c0VxdWFsc09ialZhbHVlSW5Cb3gKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gcGx1c0VxdWFsc09ialZhbHVlSW5Cb3goKTogeyBmb286IHVpbnQ2NDsgYmFyOiB1aW50NjQgfQpwbHVzRXF1YWxzT2JqVmFsdWVJbkJveDoKCXByb3RvIDAgMQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjUxCgkvLyB0aGlzLmJNYXAoJ2JNYXAnKS52YWx1ZSA9IHsgZm9vOiAzLCBiYXI6IDQgfQoJYnl0ZSAweDYyNGQ2MTcwIC8vICJiTWFwIgoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMzAwMDAwMDAwMDAwMDAwMDQKCWJveF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTI1MgoJLy8gdGhpcy5iTWFwKCdiTWFwJykudmFsdWUuYmFyICs9IDEKCXB1c2hpbnQgOCAvLyBoZWFkT2Zmc2V0CglieXRlIDB4NjI0ZDYxNzAgLy8gImJNYXAiCglwdXNoaW50IDggLy8gaGVhZE9mZnNldAoJcHVzaGludCA4Cglib3hfZXh0cmFjdAoJYnRvaQoJcHVzaGludCAxCgkrCglpdG9iCglieXRlIDB4NjI0ZDYxNzAgLy8gImJNYXAiCgljb3ZlciAyCglib3hfcmVwbGFjZQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjUzCgkvLyByZXR1cm4gdGhpcy5iTWFwKCdiTWFwJykudmFsdWU7CglieXRlIDB4NjI0ZDYxNzAgLy8gImJNYXAiCglib3hfZ2V0CgoJLy8gYm94IHZhbHVlIGRvZXMgbm90IGV4aXN0OiB0aGlzLmJNYXAoJ2JNYXAnKS52YWx1ZQoJYXNzZXJ0CglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDY2MTliNTExIC8vIG1ldGhvZCAicGx1c0VxdWFsc09ialZhbHVlSW5Cb3goKSh1aW50NjQsdWludDY0KSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfcGx1c0VxdWFsc09ialZhbHVlSW5Cb3gKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestPostBoolTupleOffset.approval.teal b/tests/contracts/artifacts/ABITestPostBoolTupleOffset.approval.teal index 689c386eb..a69db681d 100644 --- a/tests/contracts/artifacts/ABITestPostBoolTupleOffset.approval.teal +++ b/tests/contracts/artifacts/ABITestPostBoolTupleOffset.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x0000000000000000 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestPostBoolTupleOffset.arc32.json b/tests/contracts/artifacts/ABITestPostBoolTupleOffset.arc32.json index 07fd73b53..c7b460dfc 100644 --- a/tests/contracts/artifacts/ABITestPostBoolTupleOffset.arc32.json +++ b/tests/contracts/artifacts/ABITestPostBoolTupleOffset.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgwMDAwMDAwMDAwMDAwMDAwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcG9zdEJvb2xUdXBsZU9mZnNldCgpKGJvb2wsdWludDY0LHVpbnQ2NCkKKmFiaV9yb3V0ZV9wb3N0Qm9vbFR1cGxlT2Zmc2V0OgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgcG9zdEJvb2xUdXBsZU9mZnNldCgpKGJvb2wsdWludDY0LHVpbnQ2NCkKCWNhbGxzdWIgcG9zdEJvb2xUdXBsZU9mZnNldAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBwb3N0Qm9vbFR1cGxlT2Zmc2V0KCk6IFQ5CnBvc3RCb29sVHVwbGVPZmZzZXQ6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE2MTkKCS8vIHJldFZhbDogVDkgPSB7IGE6IGZhbHNlLCBiOiAwLCBjOiAwIH0KCXB1c2hieXRlcyAweDAwCglwdXNoaW50IDAKCXB1c2hpbnQgMAoJc2V0Yml0CglieXRlIDB4MDAwMDAwMDAwMDAwMDAwMAoJY29uY2F0CglieXRlIDB4MDAwMDAwMDAwMDAwMDAwMAoJY29uY2F0CglmcmFtZV9idXJ5IDAgLy8gcmV0VmFsOiBUOQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNjIxCgkvLyByZXRWYWwuYSA9IHRydWUKCWZyYW1lX2RpZyAwIC8vIHJldFZhbDogVDkKCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoaW50IDAKCXB1c2hpbnQgMQoJc2V0Yml0CglmcmFtZV9idXJ5IDAgLy8gcmV0VmFsOiBUOQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNjIyCgkvLyByZXRWYWwuYiA9IDEKCWZyYW1lX2RpZyAwIC8vIHJldFZhbDogVDkKCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDAxCglyZXBsYWNlMiAxCglmcmFtZV9idXJ5IDAgLy8gcmV0VmFsOiBUOQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNjIzCgkvLyByZXRWYWwuYyA9IDIKCWZyYW1lX2RpZyAwIC8vIHJldFZhbDogVDkKCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDAyCglyZXBsYWNlMiA5CglmcmFtZV9idXJ5IDAgLy8gcmV0VmFsOiBUOQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNjI1CgkvLyByZXR1cm4gcmV0VmFsOwoJZnJhbWVfZGlnIDAgLy8gcmV0VmFsOiBUOQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhlOGU0Y2ZjNSAvLyBtZXRob2QgInBvc3RCb29sVHVwbGVPZmZzZXQoKShib29sLHVpbnQ2NCx1aW50NjQpIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9wb3N0Qm9vbFR1cGxlT2Zmc2V0CgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgwMDAwMDAwMDAwMDAwMDAwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcG9zdEJvb2xUdXBsZU9mZnNldCgpKGJvb2wsdWludDY0LHVpbnQ2NCkKKmFiaV9yb3V0ZV9wb3N0Qm9vbFR1cGxlT2Zmc2V0OgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgcG9zdEJvb2xUdXBsZU9mZnNldCgpKGJvb2wsdWludDY0LHVpbnQ2NCkKCWNhbGxzdWIgcG9zdEJvb2xUdXBsZU9mZnNldAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBwb3N0Qm9vbFR1cGxlT2Zmc2V0KCk6IFQ5CnBvc3RCb29sVHVwbGVPZmZzZXQ6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE2MTkKCS8vIHJldFZhbDogVDkgPSB7IGE6IGZhbHNlLCBiOiAwLCBjOiAwIH0KCXB1c2hieXRlcyAweDAwCglwdXNoaW50IDAKCXB1c2hpbnQgMAoJc2V0Yml0CglieXRlIDB4MDAwMDAwMDAwMDAwMDAwMAoJY29uY2F0CglieXRlIDB4MDAwMDAwMDAwMDAwMDAwMAoJY29uY2F0CglmcmFtZV9idXJ5IDAgLy8gcmV0VmFsOiBUOQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNjIxCgkvLyByZXRWYWwuYSA9IHRydWUKCWZyYW1lX2RpZyAwIC8vIHJldFZhbDogVDkKCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoaW50IDAKCXB1c2hpbnQgMQoJc2V0Yml0CglmcmFtZV9idXJ5IDAgLy8gcmV0VmFsOiBUOQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNjIyCgkvLyByZXRWYWwuYiA9IDEKCWZyYW1lX2RpZyAwIC8vIHJldFZhbDogVDkKCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDAxCglyZXBsYWNlMiAxCglmcmFtZV9idXJ5IDAgLy8gcmV0VmFsOiBUOQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNjIzCgkvLyByZXRWYWwuYyA9IDIKCWZyYW1lX2RpZyAwIC8vIHJldFZhbDogVDkKCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDAyCglyZXBsYWNlMiA5CglmcmFtZV9idXJ5IDAgLy8gcmV0VmFsOiBUOQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNjI1CgkvLyByZXR1cm4gcmV0VmFsOwoJZnJhbWVfZGlnIDAgLy8gcmV0VmFsOiBUOQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhlOGU0Y2ZjNSAvLyBtZXRob2QgInBvc3RCb29sVHVwbGVPZmZzZXQoKShib29sLHVpbnQ2NCx1aW50NjQpIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9wb3N0Qm9vbFR1cGxlT2Zmc2V0CgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestPostBoolTupleOffset.arc56_draft.json b/tests/contracts/artifacts/ABITestPostBoolTupleOffset.arc56_draft.json index 40d88ca14..e29f6fe33 100644 --- a/tests/contracts/artifacts/ABITestPostBoolTupleOffset.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestPostBoolTupleOffset.arc56_draft.json @@ -633,7 +633,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgwMDAwMDAwMDAwMDAwMDAwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcG9zdEJvb2xUdXBsZU9mZnNldCgpKGJvb2wsdWludDY0LHVpbnQ2NCkKKmFiaV9yb3V0ZV9wb3N0Qm9vbFR1cGxlT2Zmc2V0OgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgcG9zdEJvb2xUdXBsZU9mZnNldCgpKGJvb2wsdWludDY0LHVpbnQ2NCkKCWNhbGxzdWIgcG9zdEJvb2xUdXBsZU9mZnNldAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBwb3N0Qm9vbFR1cGxlT2Zmc2V0KCk6IFQ5CnBvc3RCb29sVHVwbGVPZmZzZXQ6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE2MTkKCS8vIHJldFZhbDogVDkgPSB7IGE6IGZhbHNlLCBiOiAwLCBjOiAwIH0KCXB1c2hieXRlcyAweDAwCglwdXNoaW50IDAKCXB1c2hpbnQgMAoJc2V0Yml0CglieXRlIDB4MDAwMDAwMDAwMDAwMDAwMAoJY29uY2F0CglieXRlIDB4MDAwMDAwMDAwMDAwMDAwMAoJY29uY2F0CglmcmFtZV9idXJ5IDAgLy8gcmV0VmFsOiBUOQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNjIxCgkvLyByZXRWYWwuYSA9IHRydWUKCWZyYW1lX2RpZyAwIC8vIHJldFZhbDogVDkKCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoaW50IDAKCXB1c2hpbnQgMQoJc2V0Yml0CglmcmFtZV9idXJ5IDAgLy8gcmV0VmFsOiBUOQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNjIyCgkvLyByZXRWYWwuYiA9IDEKCWZyYW1lX2RpZyAwIC8vIHJldFZhbDogVDkKCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDAxCglyZXBsYWNlMiAxCglmcmFtZV9idXJ5IDAgLy8gcmV0VmFsOiBUOQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNjIzCgkvLyByZXRWYWwuYyA9IDIKCWZyYW1lX2RpZyAwIC8vIHJldFZhbDogVDkKCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDAyCglyZXBsYWNlMiA5CglmcmFtZV9idXJ5IDAgLy8gcmV0VmFsOiBUOQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNjI1CgkvLyByZXR1cm4gcmV0VmFsOwoJZnJhbWVfZGlnIDAgLy8gcmV0VmFsOiBUOQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhlOGU0Y2ZjNSAvLyBtZXRob2QgInBvc3RCb29sVHVwbGVPZmZzZXQoKShib29sLHVpbnQ2NCx1aW50NjQpIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9wb3N0Qm9vbFR1cGxlT2Zmc2V0CgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgwMDAwMDAwMDAwMDAwMDAwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcG9zdEJvb2xUdXBsZU9mZnNldCgpKGJvb2wsdWludDY0LHVpbnQ2NCkKKmFiaV9yb3V0ZV9wb3N0Qm9vbFR1cGxlT2Zmc2V0OgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgcG9zdEJvb2xUdXBsZU9mZnNldCgpKGJvb2wsdWludDY0LHVpbnQ2NCkKCWNhbGxzdWIgcG9zdEJvb2xUdXBsZU9mZnNldAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBwb3N0Qm9vbFR1cGxlT2Zmc2V0KCk6IFQ5CnBvc3RCb29sVHVwbGVPZmZzZXQ6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE2MTkKCS8vIHJldFZhbDogVDkgPSB7IGE6IGZhbHNlLCBiOiAwLCBjOiAwIH0KCXB1c2hieXRlcyAweDAwCglwdXNoaW50IDAKCXB1c2hpbnQgMAoJc2V0Yml0CglieXRlIDB4MDAwMDAwMDAwMDAwMDAwMAoJY29uY2F0CglieXRlIDB4MDAwMDAwMDAwMDAwMDAwMAoJY29uY2F0CglmcmFtZV9idXJ5IDAgLy8gcmV0VmFsOiBUOQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNjIxCgkvLyByZXRWYWwuYSA9IHRydWUKCWZyYW1lX2RpZyAwIC8vIHJldFZhbDogVDkKCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoaW50IDAKCXB1c2hpbnQgMQoJc2V0Yml0CglmcmFtZV9idXJ5IDAgLy8gcmV0VmFsOiBUOQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNjIyCgkvLyByZXRWYWwuYiA9IDEKCWZyYW1lX2RpZyAwIC8vIHJldFZhbDogVDkKCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDAxCglyZXBsYWNlMiAxCglmcmFtZV9idXJ5IDAgLy8gcmV0VmFsOiBUOQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNjIzCgkvLyByZXRWYWwuYyA9IDIKCWZyYW1lX2RpZyAwIC8vIHJldFZhbDogVDkKCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDAyCglyZXBsYWNlMiA5CglmcmFtZV9idXJ5IDAgLy8gcmV0VmFsOiBUOQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNjI1CgkvLyByZXR1cm4gcmV0VmFsOwoJZnJhbWVfZGlnIDAgLy8gcmV0VmFsOiBUOQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhlOGU0Y2ZjNSAvLyBtZXRob2QgInBvc3RCb29sVHVwbGVPZmZzZXQoKShib29sLHVpbnQ2NCx1aW50NjQpIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9wb3N0Qm9vbFR1cGxlT2Zmc2V0CgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestPushToArrayInBox.approval.teal b/tests/contracts/artifacts/ABITestPushToArrayInBox.approval.teal index e6fb362fd..af001526f 100644 --- a/tests/contracts/artifacts/ABITestPushToArrayInBox.approval.teal +++ b/tests/contracts/artifacts/ABITestPushToArrayInBox.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x624d6170 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestPushToArrayInBox.arc32.json b/tests/contracts/artifacts/ABITestPushToArrayInBox.arc32.json index 843bcb3d8..2dc0980c8 100644 --- a/tests/contracts/artifacts/ABITestPushToArrayInBox.arc32.json +++ b/tests/contracts/artifacts/ABITestPushToArrayInBox.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2MjRkNjE3MAoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDQuMQovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIHB1c2hUb0FycmF5SW5Cb3goKXVpbnQ2NFtdCiphYmlfcm91dGVfcHVzaFRvQXJyYXlJbkJveDoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHB1c2hUb0FycmF5SW5Cb3goKXVpbnQ2NFtdCgljYWxsc3ViIHB1c2hUb0FycmF5SW5Cb3gKCWR1cAoJbGVuCglwdXNoaW50IDgKCS8KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gcHVzaFRvQXJyYXlJbkJveCgpOiBBcHBJRFtdCnB1c2hUb0FycmF5SW5Cb3g6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTU1NAoJLy8gdGhpcy5iTWFwKCdiTWFwJykudmFsdWUgPSBbQXBwSUQuZnJvbVVpbnQ2NCgxKSwgQXBwSUQuZnJvbVVpbnQ2NCgyKV0KCWJ5dGUgMHg2MjRkNjE3MCAvLyAiYk1hcCIKCWR1cAoJYm94X2RlbAoJcG9wCglwdXNoYnl0ZXMgMHgwMDAyMDAwMDAwMDAwMDAwMDAwMTAwMDAwMDAwMDAwMDAwMDIKCWJveF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTU1NgoJLy8gdGhpcy5iTWFwKCdiTWFwJykudmFsdWUucHVzaChBcHBJRC5mcm9tVWludDY0KDMpKQoJYnl0ZSAweDYyNGQ2MTcwIC8vICJiTWFwIgoJYm94X2dldAoKCS8vIGJveCB2YWx1ZSBkb2VzIG5vdCBleGlzdDogdGhpcy5iTWFwKCdiTWFwJykudmFsdWUKCWFzc2VydAoJZXh0cmFjdCAyIDAKCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDMKCWNvbmNhdAoJYnl0ZSAweDYyNGQ2MTcwIC8vICJiTWFwIgoJZHVwCglib3hfZGVsCglwb3AKCXN3YXAKCWR1cAoJbGVuCglwdXNoaW50IDgKCS8KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWJveF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTU1NwoJLy8gdGhpcy5iTWFwKCdiTWFwJykudmFsdWUucHVzaChBcHBJRC5mcm9tVWludDY0KDQpKQoJYnl0ZSAweDYyNGQ2MTcwIC8vICJiTWFwIgoJYm94X2dldAoKCS8vIGJveCB2YWx1ZSBkb2VzIG5vdCBleGlzdDogdGhpcy5iTWFwKCdiTWFwJykudmFsdWUKCWFzc2VydAoJZXh0cmFjdCAyIDAKCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDQKCWNvbmNhdAoJYnl0ZSAweDYyNGQ2MTcwIC8vICJiTWFwIgoJZHVwCglib3hfZGVsCglwb3AKCXN3YXAKCWR1cAoJbGVuCglwdXNoaW50IDgKCS8KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWJveF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTU1OQoJLy8gcmV0dXJuIHRoaXMuYk1hcCgnYk1hcCcpLnZhbHVlOwoJYnl0ZSAweDYyNGQ2MTcwIC8vICJiTWFwIgoJYm94X2dldAoKCS8vIGJveCB2YWx1ZSBkb2VzIG5vdCBleGlzdDogdGhpcy5iTWFwKCdiTWFwJykudmFsdWUKCWFzc2VydAoJZXh0cmFjdCAyIDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YWZhMDdmNjIgLy8gbWV0aG9kICJwdXNoVG9BcnJheUluQm94KCl1aW50NjRbXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfcHVzaFRvQXJyYXlJbkJveAoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2MjRkNjE3MAoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDUuMAovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIHB1c2hUb0FycmF5SW5Cb3goKXVpbnQ2NFtdCiphYmlfcm91dGVfcHVzaFRvQXJyYXlJbkJveDoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHB1c2hUb0FycmF5SW5Cb3goKXVpbnQ2NFtdCgljYWxsc3ViIHB1c2hUb0FycmF5SW5Cb3gKCWR1cAoJbGVuCglwdXNoaW50IDgKCS8KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gcHVzaFRvQXJyYXlJbkJveCgpOiBBcHBJRFtdCnB1c2hUb0FycmF5SW5Cb3g6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTU1NAoJLy8gdGhpcy5iTWFwKCdiTWFwJykudmFsdWUgPSBbQXBwSUQuZnJvbVVpbnQ2NCgxKSwgQXBwSUQuZnJvbVVpbnQ2NCgyKV0KCWJ5dGUgMHg2MjRkNjE3MCAvLyAiYk1hcCIKCWR1cAoJYm94X2RlbAoJcG9wCglwdXNoYnl0ZXMgMHgwMDAyMDAwMDAwMDAwMDAwMDAwMTAwMDAwMDAwMDAwMDAwMDIKCWJveF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTU1NgoJLy8gdGhpcy5iTWFwKCdiTWFwJykudmFsdWUucHVzaChBcHBJRC5mcm9tVWludDY0KDMpKQoJYnl0ZSAweDYyNGQ2MTcwIC8vICJiTWFwIgoJYm94X2dldAoKCS8vIGJveCB2YWx1ZSBkb2VzIG5vdCBleGlzdDogdGhpcy5iTWFwKCdiTWFwJykudmFsdWUKCWFzc2VydAoJZXh0cmFjdCAyIDAKCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDMKCWNvbmNhdAoJYnl0ZSAweDYyNGQ2MTcwIC8vICJiTWFwIgoJZHVwCglib3hfZGVsCglwb3AKCXN3YXAKCWR1cAoJbGVuCglwdXNoaW50IDgKCS8KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWJveF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTU1NwoJLy8gdGhpcy5iTWFwKCdiTWFwJykudmFsdWUucHVzaChBcHBJRC5mcm9tVWludDY0KDQpKQoJYnl0ZSAweDYyNGQ2MTcwIC8vICJiTWFwIgoJYm94X2dldAoKCS8vIGJveCB2YWx1ZSBkb2VzIG5vdCBleGlzdDogdGhpcy5iTWFwKCdiTWFwJykudmFsdWUKCWFzc2VydAoJZXh0cmFjdCAyIDAKCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDQKCWNvbmNhdAoJYnl0ZSAweDYyNGQ2MTcwIC8vICJiTWFwIgoJZHVwCglib3hfZGVsCglwb3AKCXN3YXAKCWR1cAoJbGVuCglwdXNoaW50IDgKCS8KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWJveF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTU1OQoJLy8gcmV0dXJuIHRoaXMuYk1hcCgnYk1hcCcpLnZhbHVlOwoJYnl0ZSAweDYyNGQ2MTcwIC8vICJiTWFwIgoJYm94X2dldAoKCS8vIGJveCB2YWx1ZSBkb2VzIG5vdCBleGlzdDogdGhpcy5iTWFwKCdiTWFwJykudmFsdWUKCWFzc2VydAoJZXh0cmFjdCAyIDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YWZhMDdmNjIgLy8gbWV0aG9kICJwdXNoVG9BcnJheUluQm94KCl1aW50NjRbXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfcHVzaFRvQXJyYXlJbkJveAoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestPushToArrayInBox.arc56_draft.json b/tests/contracts/artifacts/ABITestPushToArrayInBox.arc56_draft.json index 9b31cc0dd..1b10b0de4 100644 --- a/tests/contracts/artifacts/ABITestPushToArrayInBox.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestPushToArrayInBox.arc56_draft.json @@ -832,7 +832,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2MjRkNjE3MAoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDQuMQovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIHB1c2hUb0FycmF5SW5Cb3goKXVpbnQ2NFtdCiphYmlfcm91dGVfcHVzaFRvQXJyYXlJbkJveDoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHB1c2hUb0FycmF5SW5Cb3goKXVpbnQ2NFtdCgljYWxsc3ViIHB1c2hUb0FycmF5SW5Cb3gKCWR1cAoJbGVuCglwdXNoaW50IDgKCS8KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gcHVzaFRvQXJyYXlJbkJveCgpOiBBcHBJRFtdCnB1c2hUb0FycmF5SW5Cb3g6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTU1NAoJLy8gdGhpcy5iTWFwKCdiTWFwJykudmFsdWUgPSBbQXBwSUQuZnJvbVVpbnQ2NCgxKSwgQXBwSUQuZnJvbVVpbnQ2NCgyKV0KCWJ5dGUgMHg2MjRkNjE3MCAvLyAiYk1hcCIKCWR1cAoJYm94X2RlbAoJcG9wCglwdXNoYnl0ZXMgMHgwMDAyMDAwMDAwMDAwMDAwMDAwMTAwMDAwMDAwMDAwMDAwMDIKCWJveF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTU1NgoJLy8gdGhpcy5iTWFwKCdiTWFwJykudmFsdWUucHVzaChBcHBJRC5mcm9tVWludDY0KDMpKQoJYnl0ZSAweDYyNGQ2MTcwIC8vICJiTWFwIgoJYm94X2dldAoKCS8vIGJveCB2YWx1ZSBkb2VzIG5vdCBleGlzdDogdGhpcy5iTWFwKCdiTWFwJykudmFsdWUKCWFzc2VydAoJZXh0cmFjdCAyIDAKCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDMKCWNvbmNhdAoJYnl0ZSAweDYyNGQ2MTcwIC8vICJiTWFwIgoJZHVwCglib3hfZGVsCglwb3AKCXN3YXAKCWR1cAoJbGVuCglwdXNoaW50IDgKCS8KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWJveF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTU1NwoJLy8gdGhpcy5iTWFwKCdiTWFwJykudmFsdWUucHVzaChBcHBJRC5mcm9tVWludDY0KDQpKQoJYnl0ZSAweDYyNGQ2MTcwIC8vICJiTWFwIgoJYm94X2dldAoKCS8vIGJveCB2YWx1ZSBkb2VzIG5vdCBleGlzdDogdGhpcy5iTWFwKCdiTWFwJykudmFsdWUKCWFzc2VydAoJZXh0cmFjdCAyIDAKCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDQKCWNvbmNhdAoJYnl0ZSAweDYyNGQ2MTcwIC8vICJiTWFwIgoJZHVwCglib3hfZGVsCglwb3AKCXN3YXAKCWR1cAoJbGVuCglwdXNoaW50IDgKCS8KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWJveF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTU1OQoJLy8gcmV0dXJuIHRoaXMuYk1hcCgnYk1hcCcpLnZhbHVlOwoJYnl0ZSAweDYyNGQ2MTcwIC8vICJiTWFwIgoJYm94X2dldAoKCS8vIGJveCB2YWx1ZSBkb2VzIG5vdCBleGlzdDogdGhpcy5iTWFwKCdiTWFwJykudmFsdWUKCWFzc2VydAoJZXh0cmFjdCAyIDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YWZhMDdmNjIgLy8gbWV0aG9kICJwdXNoVG9BcnJheUluQm94KCl1aW50NjRbXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfcHVzaFRvQXJyYXlJbkJveAoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2MjRkNjE3MAoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDUuMAovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIHB1c2hUb0FycmF5SW5Cb3goKXVpbnQ2NFtdCiphYmlfcm91dGVfcHVzaFRvQXJyYXlJbkJveDoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHB1c2hUb0FycmF5SW5Cb3goKXVpbnQ2NFtdCgljYWxsc3ViIHB1c2hUb0FycmF5SW5Cb3gKCWR1cAoJbGVuCglwdXNoaW50IDgKCS8KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gcHVzaFRvQXJyYXlJbkJveCgpOiBBcHBJRFtdCnB1c2hUb0FycmF5SW5Cb3g6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTU1NAoJLy8gdGhpcy5iTWFwKCdiTWFwJykudmFsdWUgPSBbQXBwSUQuZnJvbVVpbnQ2NCgxKSwgQXBwSUQuZnJvbVVpbnQ2NCgyKV0KCWJ5dGUgMHg2MjRkNjE3MCAvLyAiYk1hcCIKCWR1cAoJYm94X2RlbAoJcG9wCglwdXNoYnl0ZXMgMHgwMDAyMDAwMDAwMDAwMDAwMDAwMTAwMDAwMDAwMDAwMDAwMDIKCWJveF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTU1NgoJLy8gdGhpcy5iTWFwKCdiTWFwJykudmFsdWUucHVzaChBcHBJRC5mcm9tVWludDY0KDMpKQoJYnl0ZSAweDYyNGQ2MTcwIC8vICJiTWFwIgoJYm94X2dldAoKCS8vIGJveCB2YWx1ZSBkb2VzIG5vdCBleGlzdDogdGhpcy5iTWFwKCdiTWFwJykudmFsdWUKCWFzc2VydAoJZXh0cmFjdCAyIDAKCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDMKCWNvbmNhdAoJYnl0ZSAweDYyNGQ2MTcwIC8vICJiTWFwIgoJZHVwCglib3hfZGVsCglwb3AKCXN3YXAKCWR1cAoJbGVuCglwdXNoaW50IDgKCS8KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWJveF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTU1NwoJLy8gdGhpcy5iTWFwKCdiTWFwJykudmFsdWUucHVzaChBcHBJRC5mcm9tVWludDY0KDQpKQoJYnl0ZSAweDYyNGQ2MTcwIC8vICJiTWFwIgoJYm94X2dldAoKCS8vIGJveCB2YWx1ZSBkb2VzIG5vdCBleGlzdDogdGhpcy5iTWFwKCdiTWFwJykudmFsdWUKCWFzc2VydAoJZXh0cmFjdCAyIDAKCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDQKCWNvbmNhdAoJYnl0ZSAweDYyNGQ2MTcwIC8vICJiTWFwIgoJZHVwCglib3hfZGVsCglwb3AKCXN3YXAKCWR1cAoJbGVuCglwdXNoaW50IDgKCS8KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWJveF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTU1OQoJLy8gcmV0dXJuIHRoaXMuYk1hcCgnYk1hcCcpLnZhbHVlOwoJYnl0ZSAweDYyNGQ2MTcwIC8vICJiTWFwIgoJYm94X2dldAoKCS8vIGJveCB2YWx1ZSBkb2VzIG5vdCBleGlzdDogdGhpcy5iTWFwKCdiTWFwJykudmFsdWUKCWFzc2VydAoJZXh0cmFjdCAyIDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YWZhMDdmNjIgLy8gbWV0aG9kICJwdXNoVG9BcnJheUluQm94KCl1aW50NjRbXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfcHVzaFRvQXJyYXlJbkJveAoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestRawBytesFunction.approval.teal b/tests/contracts/artifacts/ABITestRawBytesFunction.approval.teal index 8d8f12c4d..0f01c597b 100644 --- a/tests/contracts/artifacts/ABITestRawBytesFunction.approval.teal +++ b/tests/contracts/artifacts/ABITestRawBytesFunction.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestRawBytesFunction.arc32.json b/tests/contracts/artifacts/ABITestRawBytesFunction.arc32.json index 15047f2fb..abaa882d7 100644 --- a/tests/contracts/artifacts/ABITestRawBytesFunction.arc32.json +++ b/tests/contracts/artifacts/ABITestRawBytesFunction.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcmF3Qnl0ZXNGdW5jdGlvbigpc3RyaW5nCiphYmlfcm91dGVfcmF3Qnl0ZXNGdW5jdGlvbjoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHJhd0J5dGVzRnVuY3Rpb24oKXN0cmluZwoJY2FsbHN1YiByYXdCeXRlc0Z1bmN0aW9uCglkdXAKCWxlbgoJaXRvYgoJZXh0cmFjdCA2IDIKCXN3YXAKCWNvbmNhdAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyByYXdCeXRlc0Z1bmN0aW9uKCk6IHN0cmluZwpyYXdCeXRlc0Z1bmN0aW9uOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMDUzCgkvLyBhOiBTdGF0aWNBcnJheTx1aW50PDg+LCAzPiA9IFsxLCAyLCAzXQoJcHVzaGJ5dGVzIDB4MDEwMjAzCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8dWludDw4PiwgMz4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTA1NAoJLy8gcmV0dXJuIHJhd0J5dGVzKGEpOwoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8dWludDw4PiwgMz4KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MDg3ODRhZGIgLy8gbWV0aG9kICJyYXdCeXRlc0Z1bmN0aW9uKClzdHJpbmciCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3Jhd0J5dGVzRnVuY3Rpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcmF3Qnl0ZXNGdW5jdGlvbigpc3RyaW5nCiphYmlfcm91dGVfcmF3Qnl0ZXNGdW5jdGlvbjoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHJhd0J5dGVzRnVuY3Rpb24oKXN0cmluZwoJY2FsbHN1YiByYXdCeXRlc0Z1bmN0aW9uCglkdXAKCWxlbgoJaXRvYgoJZXh0cmFjdCA2IDIKCXN3YXAKCWNvbmNhdAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyByYXdCeXRlc0Z1bmN0aW9uKCk6IHN0cmluZwpyYXdCeXRlc0Z1bmN0aW9uOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMDUzCgkvLyBhOiBTdGF0aWNBcnJheTx1aW50PDg+LCAzPiA9IFsxLCAyLCAzXQoJcHVzaGJ5dGVzIDB4MDEwMjAzCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8dWludDw4PiwgMz4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTA1NAoJLy8gcmV0dXJuIHJhd0J5dGVzKGEpOwoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8dWludDw4PiwgMz4KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MDg3ODRhZGIgLy8gbWV0aG9kICJyYXdCeXRlc0Z1bmN0aW9uKClzdHJpbmciCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3Jhd0J5dGVzRnVuY3Rpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestRawBytesFunction.arc56_draft.json b/tests/contracts/artifacts/ABITestRawBytesFunction.arc56_draft.json index d8eec2eb1..7f937ac13 100644 --- a/tests/contracts/artifacts/ABITestRawBytesFunction.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestRawBytesFunction.arc56_draft.json @@ -410,7 +410,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcmF3Qnl0ZXNGdW5jdGlvbigpc3RyaW5nCiphYmlfcm91dGVfcmF3Qnl0ZXNGdW5jdGlvbjoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHJhd0J5dGVzRnVuY3Rpb24oKXN0cmluZwoJY2FsbHN1YiByYXdCeXRlc0Z1bmN0aW9uCglkdXAKCWxlbgoJaXRvYgoJZXh0cmFjdCA2IDIKCXN3YXAKCWNvbmNhdAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyByYXdCeXRlc0Z1bmN0aW9uKCk6IHN0cmluZwpyYXdCeXRlc0Z1bmN0aW9uOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMDUzCgkvLyBhOiBTdGF0aWNBcnJheTx1aW50PDg+LCAzPiA9IFsxLCAyLCAzXQoJcHVzaGJ5dGVzIDB4MDEwMjAzCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8dWludDw4PiwgMz4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTA1NAoJLy8gcmV0dXJuIHJhd0J5dGVzKGEpOwoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8dWludDw4PiwgMz4KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MDg3ODRhZGIgLy8gbWV0aG9kICJyYXdCeXRlc0Z1bmN0aW9uKClzdHJpbmciCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3Jhd0J5dGVzRnVuY3Rpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcmF3Qnl0ZXNGdW5jdGlvbigpc3RyaW5nCiphYmlfcm91dGVfcmF3Qnl0ZXNGdW5jdGlvbjoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHJhd0J5dGVzRnVuY3Rpb24oKXN0cmluZwoJY2FsbHN1YiByYXdCeXRlc0Z1bmN0aW9uCglkdXAKCWxlbgoJaXRvYgoJZXh0cmFjdCA2IDIKCXN3YXAKCWNvbmNhdAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyByYXdCeXRlc0Z1bmN0aW9uKCk6IHN0cmluZwpyYXdCeXRlc0Z1bmN0aW9uOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMDUzCgkvLyBhOiBTdGF0aWNBcnJheTx1aW50PDg+LCAzPiA9IFsxLCAyLCAzXQoJcHVzaGJ5dGVzIDB4MDEwMjAzCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8dWludDw4PiwgMz4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTA1NAoJLy8gcmV0dXJuIHJhd0J5dGVzKGEpOwoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8dWludDw4PiwgMz4KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MDg3ODRhZGIgLy8gbWV0aG9kICJyYXdCeXRlc0Z1bmN0aW9uKClzdHJpbmciCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3Jhd0J5dGVzRnVuY3Rpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestRefTypes.approval.teal b/tests/contracts/artifacts/ABITestRefTypes.approval.teal index f1b2f0b41..f64940a0c 100644 --- a/tests/contracts/artifacts/ABITestRefTypes.approval.teal +++ b/tests/contracts/artifacts/ABITestRefTypes.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestRefTypes.arc32.json b/tests/contracts/artifacts/ABITestRefTypes.arc32.json index cc1673c05..92632b64d 100644 --- a/tests/contracts/artifacts/ABITestRefTypes.arc32.json +++ b/tests/contracts/artifacts/ABITestRefTypes.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcmVmVHlwZXMoYWNjb3VudCxhcHBsaWNhdGlvbixhc3NldCl2b2lkCiphYmlfcm91dGVfcmVmVHlwZXM6CgkvLyBhc2E6IGFzc2V0Cgl0eG5hIEFwcGxpY2F0aW9uQXJncyAzCglidG9pCgl0eG5hcyBBc3NldHMKCgkvLyBhcHA6IGFwcGxpY2F0aW9uCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAyCglidG9pCgl0eG5hcyBBcHBsaWNhdGlvbnMKCgkvLyBhY2N0OiBhY2NvdW50Cgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglidG9pCgl0eG5hcyBBY2NvdW50cwoKCS8vIGV4ZWN1dGUgcmVmVHlwZXMoYWNjb3VudCxhcHBsaWNhdGlvbixhc3NldCl2b2lkCgljYWxsc3ViIHJlZlR5cGVzCglwdXNoaW50IDEKCXJldHVybgoKLy8gcmVmVHlwZXMoYWNjdDogQWNjb3VudFJlZmVyZW5jZSwgYXBwOiBBcHBSZWZlcmVuY2UsIGFzYTogQXNzZXRSZWZlcmVuY2UpOiB2b2lkCnJlZlR5cGVzOgoJcHJvdG8gMyAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE1MjYKCS8vIGFzc2VydCghYWNjdC5pc09wdGVkSW5Ub0Fzc2V0KGFzYSkpCglmcmFtZV9kaWcgLTEgLy8gYWNjdDogQWNjb3VudFJlZmVyZW5jZQoJZnJhbWVfZGlnIC0zIC8vIGFzYTogQXNzZXRSZWZlcmVuY2UKCWFzc2V0X2hvbGRpbmdfZ2V0IEFzc2V0QmFsYW5jZQoJc3dhcAoJcG9wCgkhCglhc3NlcnQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTUyNwoJLy8gYXNzZXJ0KCFhcHAuYWRkcmVzcy5pc09wdGVkSW5Ub0Fzc2V0KGFzYSkpCglmcmFtZV9kaWcgLTIgLy8gYXBwOiBBcHBSZWZlcmVuY2UKCWFwcF9wYXJhbXNfZ2V0IEFwcEFkZHJlc3MKCXBvcAoJZnJhbWVfZGlnIC0zIC8vIGFzYTogQXNzZXRSZWZlcmVuY2UKCWFzc2V0X2hvbGRpbmdfZ2V0IEFzc2V0QmFsYW5jZQoJc3dhcAoJcG9wCgkhCglhc3NlcnQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZTFlOWQ2YzMgLy8gbWV0aG9kICJyZWZUeXBlcyhhY2NvdW50LGFwcGxpY2F0aW9uLGFzc2V0KXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3JlZlR5cGVzCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcmVmVHlwZXMoYWNjb3VudCxhcHBsaWNhdGlvbixhc3NldCl2b2lkCiphYmlfcm91dGVfcmVmVHlwZXM6CgkvLyBhc2E6IGFzc2V0Cgl0eG5hIEFwcGxpY2F0aW9uQXJncyAzCglidG9pCgl0eG5hcyBBc3NldHMKCgkvLyBhcHA6IGFwcGxpY2F0aW9uCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAyCglidG9pCgl0eG5hcyBBcHBsaWNhdGlvbnMKCgkvLyBhY2N0OiBhY2NvdW50Cgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglidG9pCgl0eG5hcyBBY2NvdW50cwoKCS8vIGV4ZWN1dGUgcmVmVHlwZXMoYWNjb3VudCxhcHBsaWNhdGlvbixhc3NldCl2b2lkCgljYWxsc3ViIHJlZlR5cGVzCglwdXNoaW50IDEKCXJldHVybgoKLy8gcmVmVHlwZXMoYWNjdDogQWNjb3VudFJlZmVyZW5jZSwgYXBwOiBBcHBSZWZlcmVuY2UsIGFzYTogQXNzZXRSZWZlcmVuY2UpOiB2b2lkCnJlZlR5cGVzOgoJcHJvdG8gMyAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE1MjYKCS8vIGFzc2VydCghYWNjdC5pc09wdGVkSW5Ub0Fzc2V0KGFzYSkpCglmcmFtZV9kaWcgLTEgLy8gYWNjdDogQWNjb3VudFJlZmVyZW5jZQoJZnJhbWVfZGlnIC0zIC8vIGFzYTogQXNzZXRSZWZlcmVuY2UKCWFzc2V0X2hvbGRpbmdfZ2V0IEFzc2V0QmFsYW5jZQoJc3dhcAoJcG9wCgkhCglhc3NlcnQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTUyNwoJLy8gYXNzZXJ0KCFhcHAuYWRkcmVzcy5pc09wdGVkSW5Ub0Fzc2V0KGFzYSkpCglmcmFtZV9kaWcgLTIgLy8gYXBwOiBBcHBSZWZlcmVuY2UKCWFwcF9wYXJhbXNfZ2V0IEFwcEFkZHJlc3MKCXBvcAoJZnJhbWVfZGlnIC0zIC8vIGFzYTogQXNzZXRSZWZlcmVuY2UKCWFzc2V0X2hvbGRpbmdfZ2V0IEFzc2V0QmFsYW5jZQoJc3dhcAoJcG9wCgkhCglhc3NlcnQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZTFlOWQ2YzMgLy8gbWV0aG9kICJyZWZUeXBlcyhhY2NvdW50LGFwcGxpY2F0aW9uLGFzc2V0KXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3JlZlR5cGVzCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestRefTypes.arc56_draft.json b/tests/contracts/artifacts/ABITestRefTypes.arc56_draft.json index 387530ad7..eb48d4d88 100644 --- a/tests/contracts/artifacts/ABITestRefTypes.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestRefTypes.arc56_draft.json @@ -501,7 +501,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcmVmVHlwZXMoYWNjb3VudCxhcHBsaWNhdGlvbixhc3NldCl2b2lkCiphYmlfcm91dGVfcmVmVHlwZXM6CgkvLyBhc2E6IGFzc2V0Cgl0eG5hIEFwcGxpY2F0aW9uQXJncyAzCglidG9pCgl0eG5hcyBBc3NldHMKCgkvLyBhcHA6IGFwcGxpY2F0aW9uCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAyCglidG9pCgl0eG5hcyBBcHBsaWNhdGlvbnMKCgkvLyBhY2N0OiBhY2NvdW50Cgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglidG9pCgl0eG5hcyBBY2NvdW50cwoKCS8vIGV4ZWN1dGUgcmVmVHlwZXMoYWNjb3VudCxhcHBsaWNhdGlvbixhc3NldCl2b2lkCgljYWxsc3ViIHJlZlR5cGVzCglwdXNoaW50IDEKCXJldHVybgoKLy8gcmVmVHlwZXMoYWNjdDogQWNjb3VudFJlZmVyZW5jZSwgYXBwOiBBcHBSZWZlcmVuY2UsIGFzYTogQXNzZXRSZWZlcmVuY2UpOiB2b2lkCnJlZlR5cGVzOgoJcHJvdG8gMyAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE1MjYKCS8vIGFzc2VydCghYWNjdC5pc09wdGVkSW5Ub0Fzc2V0KGFzYSkpCglmcmFtZV9kaWcgLTEgLy8gYWNjdDogQWNjb3VudFJlZmVyZW5jZQoJZnJhbWVfZGlnIC0zIC8vIGFzYTogQXNzZXRSZWZlcmVuY2UKCWFzc2V0X2hvbGRpbmdfZ2V0IEFzc2V0QmFsYW5jZQoJc3dhcAoJcG9wCgkhCglhc3NlcnQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTUyNwoJLy8gYXNzZXJ0KCFhcHAuYWRkcmVzcy5pc09wdGVkSW5Ub0Fzc2V0KGFzYSkpCglmcmFtZV9kaWcgLTIgLy8gYXBwOiBBcHBSZWZlcmVuY2UKCWFwcF9wYXJhbXNfZ2V0IEFwcEFkZHJlc3MKCXBvcAoJZnJhbWVfZGlnIC0zIC8vIGFzYTogQXNzZXRSZWZlcmVuY2UKCWFzc2V0X2hvbGRpbmdfZ2V0IEFzc2V0QmFsYW5jZQoJc3dhcAoJcG9wCgkhCglhc3NlcnQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZTFlOWQ2YzMgLy8gbWV0aG9kICJyZWZUeXBlcyhhY2NvdW50LGFwcGxpY2F0aW9uLGFzc2V0KXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3JlZlR5cGVzCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcmVmVHlwZXMoYWNjb3VudCxhcHBsaWNhdGlvbixhc3NldCl2b2lkCiphYmlfcm91dGVfcmVmVHlwZXM6CgkvLyBhc2E6IGFzc2V0Cgl0eG5hIEFwcGxpY2F0aW9uQXJncyAzCglidG9pCgl0eG5hcyBBc3NldHMKCgkvLyBhcHA6IGFwcGxpY2F0aW9uCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAyCglidG9pCgl0eG5hcyBBcHBsaWNhdGlvbnMKCgkvLyBhY2N0OiBhY2NvdW50Cgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglidG9pCgl0eG5hcyBBY2NvdW50cwoKCS8vIGV4ZWN1dGUgcmVmVHlwZXMoYWNjb3VudCxhcHBsaWNhdGlvbixhc3NldCl2b2lkCgljYWxsc3ViIHJlZlR5cGVzCglwdXNoaW50IDEKCXJldHVybgoKLy8gcmVmVHlwZXMoYWNjdDogQWNjb3VudFJlZmVyZW5jZSwgYXBwOiBBcHBSZWZlcmVuY2UsIGFzYTogQXNzZXRSZWZlcmVuY2UpOiB2b2lkCnJlZlR5cGVzOgoJcHJvdG8gMyAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE1MjYKCS8vIGFzc2VydCghYWNjdC5pc09wdGVkSW5Ub0Fzc2V0KGFzYSkpCglmcmFtZV9kaWcgLTEgLy8gYWNjdDogQWNjb3VudFJlZmVyZW5jZQoJZnJhbWVfZGlnIC0zIC8vIGFzYTogQXNzZXRSZWZlcmVuY2UKCWFzc2V0X2hvbGRpbmdfZ2V0IEFzc2V0QmFsYW5jZQoJc3dhcAoJcG9wCgkhCglhc3NlcnQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTUyNwoJLy8gYXNzZXJ0KCFhcHAuYWRkcmVzcy5pc09wdGVkSW5Ub0Fzc2V0KGFzYSkpCglmcmFtZV9kaWcgLTIgLy8gYXBwOiBBcHBSZWZlcmVuY2UKCWFwcF9wYXJhbXNfZ2V0IEFwcEFkZHJlc3MKCXBvcAoJZnJhbWVfZGlnIC0zIC8vIGFzYTogQXNzZXRSZWZlcmVuY2UKCWFzc2V0X2hvbGRpbmdfZ2V0IEFzc2V0QmFsYW5jZQoJc3dhcAoJcG9wCgkhCglhc3NlcnQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZTFlOWQ2YzMgLy8gbWV0aG9kICJyZWZUeXBlcyhhY2NvdW50LGFwcGxpY2F0aW9uLGFzc2V0KXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3JlZlR5cGVzCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestReturnByte.approval.teal b/tests/contracts/artifacts/ABITestReturnByte.approval.teal index 5a9af0271..3da0a3d82 100644 --- a/tests/contracts/artifacts/ABITestReturnByte.approval.teal +++ b/tests/contracts/artifacts/ABITestReturnByte.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestReturnByte.arc32.json b/tests/contracts/artifacts/ABITestReturnByte.arc32.json index ca3e9448d..3c45fee93 100644 --- a/tests/contracts/artifacts/ABITestReturnByte.arc32.json +++ b/tests/contracts/artifacts/ABITestReturnByte.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcmV0dXJuQnl0ZSgpYnl0ZQoqYWJpX3JvdXRlX3JldHVybkJ5dGU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSByZXR1cm5CeXRlKClieXRlCgljYWxsc3ViIHJldHVybkJ5dGUKCWR1cAoJbGVuCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHJldHVybkJ5dGUoKTogYnl0ZQpyZXR1cm5CeXRlOgoJcHJvdG8gMCAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE1NjUKCS8vIHJldHVybiByYXdCeXRlKHRydWUpOwoJcHVzaGludCAxCglwdXNoYnl0ZXMgMHgwMAoJcHVzaGludCAwCgl1bmNvdmVyIDIKCXNldGJpdAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg3NmI0MzRjZiAvLyBtZXRob2QgInJldHVybkJ5dGUoKWJ5dGUiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3JldHVybkJ5dGUKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcmV0dXJuQnl0ZSgpYnl0ZQoqYWJpX3JvdXRlX3JldHVybkJ5dGU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSByZXR1cm5CeXRlKClieXRlCgljYWxsc3ViIHJldHVybkJ5dGUKCWR1cAoJbGVuCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHJldHVybkJ5dGUoKTogYnl0ZQpyZXR1cm5CeXRlOgoJcHJvdG8gMCAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE1NjUKCS8vIHJldHVybiByYXdCeXRlKHRydWUpOwoJcHVzaGludCAxCglwdXNoYnl0ZXMgMHgwMAoJcHVzaGludCAwCgl1bmNvdmVyIDIKCXNldGJpdAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg3NmI0MzRjZiAvLyBtZXRob2QgInJldHVybkJ5dGUoKWJ5dGUiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3JldHVybkJ5dGUKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestReturnByte.arc56_draft.json b/tests/contracts/artifacts/ABITestReturnByte.arc56_draft.json index caa02f7eb..012f8aef4 100644 --- a/tests/contracts/artifacts/ABITestReturnByte.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestReturnByte.arc56_draft.json @@ -407,7 +407,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcmV0dXJuQnl0ZSgpYnl0ZQoqYWJpX3JvdXRlX3JldHVybkJ5dGU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSByZXR1cm5CeXRlKClieXRlCgljYWxsc3ViIHJldHVybkJ5dGUKCWR1cAoJbGVuCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHJldHVybkJ5dGUoKTogYnl0ZQpyZXR1cm5CeXRlOgoJcHJvdG8gMCAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE1NjUKCS8vIHJldHVybiByYXdCeXRlKHRydWUpOwoJcHVzaGludCAxCglwdXNoYnl0ZXMgMHgwMAoJcHVzaGludCAwCgl1bmNvdmVyIDIKCXNldGJpdAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg3NmI0MzRjZiAvLyBtZXRob2QgInJldHVybkJ5dGUoKWJ5dGUiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3JldHVybkJ5dGUKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcmV0dXJuQnl0ZSgpYnl0ZQoqYWJpX3JvdXRlX3JldHVybkJ5dGU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSByZXR1cm5CeXRlKClieXRlCgljYWxsc3ViIHJldHVybkJ5dGUKCWR1cAoJbGVuCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHJldHVybkJ5dGUoKTogYnl0ZQpyZXR1cm5CeXRlOgoJcHJvdG8gMCAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE1NjUKCS8vIHJldHVybiByYXdCeXRlKHRydWUpOwoJcHVzaGludCAxCglwdXNoYnl0ZXMgMHgwMAoJcHVzaGludCAwCgl1bmNvdmVyIDIKCXNldGJpdAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg3NmI0MzRjZiAvLyBtZXRob2QgInJldHVybkJ5dGUoKWJ5dGUiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3JldHVybkJ5dGUKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestReturnDynamicArray.approval.teal b/tests/contracts/artifacts/ABITestReturnDynamicArray.approval.teal index e1be8d12d..be34f1677 100644 --- a/tests/contracts/artifacts/ABITestReturnDynamicArray.approval.teal +++ b/tests/contracts/artifacts/ABITestReturnDynamicArray.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestReturnDynamicArray.arc32.json b/tests/contracts/artifacts/ABITestReturnDynamicArray.arc32.json index fb104f182..8f8af5cf9 100644 --- a/tests/contracts/artifacts/ABITestReturnDynamicArray.arc32.json +++ b/tests/contracts/artifacts/ABITestReturnDynamicArray.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcmV0dXJuRHluYW1pY0FycmF5KCl1aW50NjRbXQoqYWJpX3JvdXRlX3JldHVybkR5bmFtaWNBcnJheToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHJldHVybkR5bmFtaWNBcnJheSgpdWludDY0W10KCWNhbGxzdWIgcmV0dXJuRHluYW1pY0FycmF5CglkdXAKCWxlbgoJcHVzaGludCA4CgkvCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHJldHVybkR5bmFtaWNBcnJheSgpOiB1aW50NjRbXQpyZXR1cm5EeW5hbWljQXJyYXk6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjM1NgoJLy8gYTogdWludDY0W10gPSBbMTEsIDIyLCAzM10KCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMGIwMDAwMDAwMDAwMDAwMDE2MDAwMDAwMDAwMDAwMDAyMQoJZnJhbWVfYnVyeSAwIC8vIGE6IHVpbnQ2NFtdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjM1NwoJLy8gcmV0dXJuIGE7CglmcmFtZV9kaWcgMCAvLyBhOiB1aW50NjRbXQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg5ZGVmNmU5ZCAvLyBtZXRob2QgInJldHVybkR5bmFtaWNBcnJheSgpdWludDY0W10iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3JldHVybkR5bmFtaWNBcnJheQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcmV0dXJuRHluYW1pY0FycmF5KCl1aW50NjRbXQoqYWJpX3JvdXRlX3JldHVybkR5bmFtaWNBcnJheToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHJldHVybkR5bmFtaWNBcnJheSgpdWludDY0W10KCWNhbGxzdWIgcmV0dXJuRHluYW1pY0FycmF5CglkdXAKCWxlbgoJcHVzaGludCA4CgkvCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHJldHVybkR5bmFtaWNBcnJheSgpOiB1aW50NjRbXQpyZXR1cm5EeW5hbWljQXJyYXk6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjM1NgoJLy8gYTogdWludDY0W10gPSBbMTEsIDIyLCAzM10KCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMGIwMDAwMDAwMDAwMDAwMDE2MDAwMDAwMDAwMDAwMDAyMQoJZnJhbWVfYnVyeSAwIC8vIGE6IHVpbnQ2NFtdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjM1NwoJLy8gcmV0dXJuIGE7CglmcmFtZV9kaWcgMCAvLyBhOiB1aW50NjRbXQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg5ZGVmNmU5ZCAvLyBtZXRob2QgInJldHVybkR5bmFtaWNBcnJheSgpdWludDY0W10iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3JldHVybkR5bmFtaWNBcnJheQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestReturnDynamicArray.arc56_draft.json b/tests/contracts/artifacts/ABITestReturnDynamicArray.arc56_draft.json index b9d4763ef..df902f4c2 100644 --- a/tests/contracts/artifacts/ABITestReturnDynamicArray.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestReturnDynamicArray.arc56_draft.json @@ -446,7 +446,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcmV0dXJuRHluYW1pY0FycmF5KCl1aW50NjRbXQoqYWJpX3JvdXRlX3JldHVybkR5bmFtaWNBcnJheToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHJldHVybkR5bmFtaWNBcnJheSgpdWludDY0W10KCWNhbGxzdWIgcmV0dXJuRHluYW1pY0FycmF5CglkdXAKCWxlbgoJcHVzaGludCA4CgkvCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHJldHVybkR5bmFtaWNBcnJheSgpOiB1aW50NjRbXQpyZXR1cm5EeW5hbWljQXJyYXk6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjM1NgoJLy8gYTogdWludDY0W10gPSBbMTEsIDIyLCAzM10KCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMGIwMDAwMDAwMDAwMDAwMDE2MDAwMDAwMDAwMDAwMDAyMQoJZnJhbWVfYnVyeSAwIC8vIGE6IHVpbnQ2NFtdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjM1NwoJLy8gcmV0dXJuIGE7CglmcmFtZV9kaWcgMCAvLyBhOiB1aW50NjRbXQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg5ZGVmNmU5ZCAvLyBtZXRob2QgInJldHVybkR5bmFtaWNBcnJheSgpdWludDY0W10iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3JldHVybkR5bmFtaWNBcnJheQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcmV0dXJuRHluYW1pY0FycmF5KCl1aW50NjRbXQoqYWJpX3JvdXRlX3JldHVybkR5bmFtaWNBcnJheToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHJldHVybkR5bmFtaWNBcnJheSgpdWludDY0W10KCWNhbGxzdWIgcmV0dXJuRHluYW1pY0FycmF5CglkdXAKCWxlbgoJcHVzaGludCA4CgkvCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHJldHVybkR5bmFtaWNBcnJheSgpOiB1aW50NjRbXQpyZXR1cm5EeW5hbWljQXJyYXk6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjM1NgoJLy8gYTogdWludDY0W10gPSBbMTEsIDIyLCAzM10KCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMGIwMDAwMDAwMDAwMDAwMDE2MDAwMDAwMDAwMDAwMDAyMQoJZnJhbWVfYnVyeSAwIC8vIGE6IHVpbnQ2NFtdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjM1NwoJLy8gcmV0dXJuIGE7CglmcmFtZV9kaWcgMCAvLyBhOiB1aW50NjRbXQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg5ZGVmNmU5ZCAvLyBtZXRob2QgInJldHVybkR5bmFtaWNBcnJheSgpdWludDY0W10iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3JldHVybkR5bmFtaWNBcnJheQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestReturnDynamicArrayFromTuple.approval.teal b/tests/contracts/artifacts/ABITestReturnDynamicArrayFromTuple.approval.teal index 17a0395a7..72d1e1420 100644 --- a/tests/contracts/artifacts/ABITestReturnDynamicArrayFromTuple.approval.teal +++ b/tests/contracts/artifacts/ABITestReturnDynamicArrayFromTuple.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestReturnDynamicArrayFromTuple.arc32.json b/tests/contracts/artifacts/ABITestReturnDynamicArrayFromTuple.arc32.json index e725a17cc..e88863048 100644 --- a/tests/contracts/artifacts/ABITestReturnDynamicArrayFromTuple.arc32.json +++ b/tests/contracts/artifacts/ABITestReturnDynamicArrayFromTuple.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyByZXR1cm5EeW5hbWljQXJyYXlGcm9tVHVwbGUoKXVpbnQ4W10KKmFiaV9yb3V0ZV9yZXR1cm5EeW5hbWljQXJyYXlGcm9tVHVwbGU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSByZXR1cm5EeW5hbWljQXJyYXlGcm9tVHVwbGUoKXVpbnQ4W10KCWNhbGxzdWIgcmV0dXJuRHluYW1pY0FycmF5RnJvbVR1cGxlCglkdXAKCWxlbgoJaXRvYgoJZXh0cmFjdCA2IDIKCXN3YXAKCWNvbmNhdAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyByZXR1cm5EeW5hbWljQXJyYXlGcm9tVHVwbGUoKTogdWludDw4PltdCnJldHVybkR5bmFtaWNBcnJheUZyb21UdXBsZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjM5OAoJLy8gYTogW3VpbnQ8OD4sIHVpbnQxNiwgdWludDw4PltdLCB1aW50MTZbXSwgdWludDw4PltdXSA9IFsxLCAyLCBbMywgNF0sIFs1LCA2XSwgWzcsIDhdXQoJYnl0ZSAweCAvLyBpbml0aWFsIGhlYWQKCWJ5dGUgMHggLy8gaW5pdGlhbCB0YWlsCglwdXNoYnl0ZXMgMHgwMDA5IC8vIGluaXRpYWwgaGVhZCBvZmZzZXQKCXB1c2hieXRlcyAweDAxCgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAyCgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAyMDMwNAoJY2FsbHN1YiAqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMDIwMDA1MDAwNgoJY2FsbHN1YiAqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMDIwNzA4CgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcG9wIC8vIHBvcCBoZWFkIG9mZnNldAoJY29uY2F0IC8vIGNvbmNhdCBoZWFkIGFuZCB0YWlsCglmcmFtZV9idXJ5IDAgLy8gYTogW3VpbnQ8OD4sIHVpbnQxNiwgdWludDw4PltdLCB1aW50MTZbXSwgdWludDw4PltdXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo0MDAKCS8vIHJldHVybiBhWzRdOwoJZnJhbWVfZGlnIDAgLy8gYTogW3VpbnQ8OD4sIHVpbnQxNiwgdWludDw4PltdLCB1aW50MTZbXSwgdWludDw4PltdXQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgNwoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJdW5jb3ZlciAyCglleHRyYWN0X3VpbnQxNgoJZHVwIC8vIGR1cGxpY2F0ZSBzdGFydCBvZiBlbGVtZW50Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglzd2FwCglleHRyYWN0X3VpbnQxNiAvLyBnZXQgbnVtYmVyIG9mIGVsZW1lbnRzCglwdXNoaW50IDEgLy8gZ2V0IHR5cGUgbGVuZ3RoCgkqIC8vIG11bHRpcGx5IGJ5IHR5cGUgbGVuZ3RoCglwdXNoaW50IDIKCSsgLy8gYWRkIHR3byBmb3IgbGVuZ3RoCglleHRyYWN0MwoJZXh0cmFjdCAyIDAKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZmU2NjQ4YzYgLy8gbWV0aG9kICJyZXR1cm5EeW5hbWljQXJyYXlGcm9tVHVwbGUoKXVpbnQ4W10iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3JldHVybkR5bmFtaWNBcnJheUZyb21UdXBsZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycgoKKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJY29uY2F0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWIKCipwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJY29uY2F0CglmcmFtZV9idXJ5IC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50CglkdXAKCWxlbgoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglidG9pCgkrCglpdG9iCglleHRyYWN0IDYgMgoJZnJhbWVfYnVyeSAtMiAvLyBoZWFkIG9mZnNldAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCXN3YXAKCWNvbmNhdAoJZnJhbWVfYnVyeSAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3Vi", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyByZXR1cm5EeW5hbWljQXJyYXlGcm9tVHVwbGUoKXVpbnQ4W10KKmFiaV9yb3V0ZV9yZXR1cm5EeW5hbWljQXJyYXlGcm9tVHVwbGU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSByZXR1cm5EeW5hbWljQXJyYXlGcm9tVHVwbGUoKXVpbnQ4W10KCWNhbGxzdWIgcmV0dXJuRHluYW1pY0FycmF5RnJvbVR1cGxlCglkdXAKCWxlbgoJaXRvYgoJZXh0cmFjdCA2IDIKCXN3YXAKCWNvbmNhdAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyByZXR1cm5EeW5hbWljQXJyYXlGcm9tVHVwbGUoKTogdWludDw4PltdCnJldHVybkR5bmFtaWNBcnJheUZyb21UdXBsZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjM5OAoJLy8gYTogW3VpbnQ8OD4sIHVpbnQxNiwgdWludDw4PltdLCB1aW50MTZbXSwgdWludDw4PltdXSA9IFsxLCAyLCBbMywgNF0sIFs1LCA2XSwgWzcsIDhdXQoJYnl0ZSAweCAvLyBpbml0aWFsIGhlYWQKCWJ5dGUgMHggLy8gaW5pdGlhbCB0YWlsCglwdXNoYnl0ZXMgMHgwMDA5IC8vIGluaXRpYWwgaGVhZCBvZmZzZXQKCXB1c2hieXRlcyAweDAxCgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAyCgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAyMDMwNAoJY2FsbHN1YiAqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMDIwMDA1MDAwNgoJY2FsbHN1YiAqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMDIwNzA4CgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcG9wIC8vIHBvcCBoZWFkIG9mZnNldAoJY29uY2F0IC8vIGNvbmNhdCBoZWFkIGFuZCB0YWlsCglmcmFtZV9idXJ5IDAgLy8gYTogW3VpbnQ8OD4sIHVpbnQxNiwgdWludDw4PltdLCB1aW50MTZbXSwgdWludDw4PltdXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo0MDAKCS8vIHJldHVybiBhWzRdOwoJZnJhbWVfZGlnIDAgLy8gYTogW3VpbnQ8OD4sIHVpbnQxNiwgdWludDw4PltdLCB1aW50MTZbXSwgdWludDw4PltdXQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgNwoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJdW5jb3ZlciAyCglleHRyYWN0X3VpbnQxNgoJZHVwIC8vIGR1cGxpY2F0ZSBzdGFydCBvZiBlbGVtZW50Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglzd2FwCglleHRyYWN0X3VpbnQxNiAvLyBnZXQgbnVtYmVyIG9mIGVsZW1lbnRzCglwdXNoaW50IDEgLy8gZ2V0IHR5cGUgbGVuZ3RoCgkqIC8vIG11bHRpcGx5IGJ5IHR5cGUgbGVuZ3RoCglwdXNoaW50IDIKCSsgLy8gYWRkIHR3byBmb3IgbGVuZ3RoCglleHRyYWN0MwoJZXh0cmFjdCAyIDAKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZmU2NjQ4YzYgLy8gbWV0aG9kICJyZXR1cm5EeW5hbWljQXJyYXlGcm9tVHVwbGUoKXVpbnQ4W10iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3JldHVybkR5bmFtaWNBcnJheUZyb21UdXBsZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycgoKKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJY29uY2F0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWIKCipwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJY29uY2F0CglmcmFtZV9idXJ5IC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50CglkdXAKCWxlbgoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglidG9pCgkrCglpdG9iCglleHRyYWN0IDYgMgoJZnJhbWVfYnVyeSAtMiAvLyBoZWFkIG9mZnNldAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCXN3YXAKCWNvbmNhdAoJZnJhbWVfYnVyeSAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3Vi", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestReturnDynamicArrayFromTuple.arc56_draft.json b/tests/contracts/artifacts/ABITestReturnDynamicArrayFromTuple.arc56_draft.json index a5c7122fb..fe3259a9a 100644 --- a/tests/contracts/artifacts/ABITestReturnDynamicArrayFromTuple.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestReturnDynamicArrayFromTuple.arc56_draft.json @@ -896,7 +896,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyByZXR1cm5EeW5hbWljQXJyYXlGcm9tVHVwbGUoKXVpbnQ4W10KKmFiaV9yb3V0ZV9yZXR1cm5EeW5hbWljQXJyYXlGcm9tVHVwbGU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSByZXR1cm5EeW5hbWljQXJyYXlGcm9tVHVwbGUoKXVpbnQ4W10KCWNhbGxzdWIgcmV0dXJuRHluYW1pY0FycmF5RnJvbVR1cGxlCglkdXAKCWxlbgoJaXRvYgoJZXh0cmFjdCA2IDIKCXN3YXAKCWNvbmNhdAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyByZXR1cm5EeW5hbWljQXJyYXlGcm9tVHVwbGUoKTogdWludDw4PltdCnJldHVybkR5bmFtaWNBcnJheUZyb21UdXBsZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjM5OAoJLy8gYTogW3VpbnQ8OD4sIHVpbnQxNiwgdWludDw4PltdLCB1aW50MTZbXSwgdWludDw4PltdXSA9IFsxLCAyLCBbMywgNF0sIFs1LCA2XSwgWzcsIDhdXQoJYnl0ZSAweCAvLyBpbml0aWFsIGhlYWQKCWJ5dGUgMHggLy8gaW5pdGlhbCB0YWlsCglwdXNoYnl0ZXMgMHgwMDA5IC8vIGluaXRpYWwgaGVhZCBvZmZzZXQKCXB1c2hieXRlcyAweDAxCgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAyCgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAyMDMwNAoJY2FsbHN1YiAqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMDIwMDA1MDAwNgoJY2FsbHN1YiAqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMDIwNzA4CgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcG9wIC8vIHBvcCBoZWFkIG9mZnNldAoJY29uY2F0IC8vIGNvbmNhdCBoZWFkIGFuZCB0YWlsCglmcmFtZV9idXJ5IDAgLy8gYTogW3VpbnQ8OD4sIHVpbnQxNiwgdWludDw4PltdLCB1aW50MTZbXSwgdWludDw4PltdXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo0MDAKCS8vIHJldHVybiBhWzRdOwoJZnJhbWVfZGlnIDAgLy8gYTogW3VpbnQ8OD4sIHVpbnQxNiwgdWludDw4PltdLCB1aW50MTZbXSwgdWludDw4PltdXQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgNwoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJdW5jb3ZlciAyCglleHRyYWN0X3VpbnQxNgoJZHVwIC8vIGR1cGxpY2F0ZSBzdGFydCBvZiBlbGVtZW50Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglzd2FwCglleHRyYWN0X3VpbnQxNiAvLyBnZXQgbnVtYmVyIG9mIGVsZW1lbnRzCglwdXNoaW50IDEgLy8gZ2V0IHR5cGUgbGVuZ3RoCgkqIC8vIG11bHRpcGx5IGJ5IHR5cGUgbGVuZ3RoCglwdXNoaW50IDIKCSsgLy8gYWRkIHR3byBmb3IgbGVuZ3RoCglleHRyYWN0MwoJZXh0cmFjdCAyIDAKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZmU2NjQ4YzYgLy8gbWV0aG9kICJyZXR1cm5EeW5hbWljQXJyYXlGcm9tVHVwbGUoKXVpbnQ4W10iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3JldHVybkR5bmFtaWNBcnJheUZyb21UdXBsZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycgoKKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJY29uY2F0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWIKCipwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJY29uY2F0CglmcmFtZV9idXJ5IC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50CglkdXAKCWxlbgoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglidG9pCgkrCglpdG9iCglleHRyYWN0IDYgMgoJZnJhbWVfYnVyeSAtMiAvLyBoZWFkIG9mZnNldAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCXN3YXAKCWNvbmNhdAoJZnJhbWVfYnVyeSAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3Vi", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyByZXR1cm5EeW5hbWljQXJyYXlGcm9tVHVwbGUoKXVpbnQ4W10KKmFiaV9yb3V0ZV9yZXR1cm5EeW5hbWljQXJyYXlGcm9tVHVwbGU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSByZXR1cm5EeW5hbWljQXJyYXlGcm9tVHVwbGUoKXVpbnQ4W10KCWNhbGxzdWIgcmV0dXJuRHluYW1pY0FycmF5RnJvbVR1cGxlCglkdXAKCWxlbgoJaXRvYgoJZXh0cmFjdCA2IDIKCXN3YXAKCWNvbmNhdAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyByZXR1cm5EeW5hbWljQXJyYXlGcm9tVHVwbGUoKTogdWludDw4PltdCnJldHVybkR5bmFtaWNBcnJheUZyb21UdXBsZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjM5OAoJLy8gYTogW3VpbnQ8OD4sIHVpbnQxNiwgdWludDw4PltdLCB1aW50MTZbXSwgdWludDw4PltdXSA9IFsxLCAyLCBbMywgNF0sIFs1LCA2XSwgWzcsIDhdXQoJYnl0ZSAweCAvLyBpbml0aWFsIGhlYWQKCWJ5dGUgMHggLy8gaW5pdGlhbCB0YWlsCglwdXNoYnl0ZXMgMHgwMDA5IC8vIGluaXRpYWwgaGVhZCBvZmZzZXQKCXB1c2hieXRlcyAweDAxCgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAyCgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAyMDMwNAoJY2FsbHN1YiAqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMDIwMDA1MDAwNgoJY2FsbHN1YiAqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMDIwNzA4CgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcG9wIC8vIHBvcCBoZWFkIG9mZnNldAoJY29uY2F0IC8vIGNvbmNhdCBoZWFkIGFuZCB0YWlsCglmcmFtZV9idXJ5IDAgLy8gYTogW3VpbnQ8OD4sIHVpbnQxNiwgdWludDw4PltdLCB1aW50MTZbXSwgdWludDw4PltdXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo0MDAKCS8vIHJldHVybiBhWzRdOwoJZnJhbWVfZGlnIDAgLy8gYTogW3VpbnQ8OD4sIHVpbnQxNiwgdWludDw4PltdLCB1aW50MTZbXSwgdWludDw4PltdXQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgNwoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJdW5jb3ZlciAyCglleHRyYWN0X3VpbnQxNgoJZHVwIC8vIGR1cGxpY2F0ZSBzdGFydCBvZiBlbGVtZW50Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglzd2FwCglleHRyYWN0X3VpbnQxNiAvLyBnZXQgbnVtYmVyIG9mIGVsZW1lbnRzCglwdXNoaW50IDEgLy8gZ2V0IHR5cGUgbGVuZ3RoCgkqIC8vIG11bHRpcGx5IGJ5IHR5cGUgbGVuZ3RoCglwdXNoaW50IDIKCSsgLy8gYWRkIHR3byBmb3IgbGVuZ3RoCglleHRyYWN0MwoJZXh0cmFjdCAyIDAKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZmU2NjQ4YzYgLy8gbWV0aG9kICJyZXR1cm5EeW5hbWljQXJyYXlGcm9tVHVwbGUoKXVpbnQ4W10iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3JldHVybkR5bmFtaWNBcnJheUZyb21UdXBsZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycgoKKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJY29uY2F0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWIKCipwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJY29uY2F0CglmcmFtZV9idXJ5IC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50CglkdXAKCWxlbgoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglidG9pCgkrCglpdG9iCglleHRyYWN0IDYgMgoJZnJhbWVfYnVyeSAtMiAvLyBoZWFkIG9mZnNldAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCXN3YXAKCWNvbmNhdAoJZnJhbWVfYnVyeSAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3Vi", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestReturnStaticArray.approval.teal b/tests/contracts/artifacts/ABITestReturnStaticArray.approval.teal index 73f0ada7a..09f9517af 100644 --- a/tests/contracts/artifacts/ABITestReturnStaticArray.approval.teal +++ b/tests/contracts/artifacts/ABITestReturnStaticArray.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestReturnStaticArray.arc32.json b/tests/contracts/artifacts/ABITestReturnStaticArray.arc32.json index 51c1ead77..15ceb2feb 100644 --- a/tests/contracts/artifacts/ABITestReturnStaticArray.arc32.json +++ b/tests/contracts/artifacts/ABITestReturnStaticArray.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcmV0dXJuU3RhdGljQXJyYXkoKXVpbnQ2NFszXQoqYWJpX3JvdXRlX3JldHVyblN0YXRpY0FycmF5OgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgcmV0dXJuU3RhdGljQXJyYXkoKXVpbnQ2NFszXQoJY2FsbHN1YiByZXR1cm5TdGF0aWNBcnJheQoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyByZXR1cm5TdGF0aWNBcnJheSgpOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CnJldHVyblN0YXRpY0FycmF5OgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxOQoJLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPiA9IFsxMSwgMjIsIDMzXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwYjAwMDAwMDAwMDAwMDAwMTYwMDAwMDAwMDAwMDAwMDIxCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoyMQoJLy8gcmV0dXJuIGE7CglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGQ1MzIzZTFmIC8vIG1ldGhvZCAicmV0dXJuU3RhdGljQXJyYXkoKXVpbnQ2NFszXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfcmV0dXJuU3RhdGljQXJyYXkKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcmV0dXJuU3RhdGljQXJyYXkoKXVpbnQ2NFszXQoqYWJpX3JvdXRlX3JldHVyblN0YXRpY0FycmF5OgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgcmV0dXJuU3RhdGljQXJyYXkoKXVpbnQ2NFszXQoJY2FsbHN1YiByZXR1cm5TdGF0aWNBcnJheQoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyByZXR1cm5TdGF0aWNBcnJheSgpOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CnJldHVyblN0YXRpY0FycmF5OgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxOQoJLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPiA9IFsxMSwgMjIsIDMzXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwYjAwMDAwMDAwMDAwMDAwMTYwMDAwMDAwMDAwMDAwMDIxCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoyMQoJLy8gcmV0dXJuIGE7CglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGQ1MzIzZTFmIC8vIG1ldGhvZCAicmV0dXJuU3RhdGljQXJyYXkoKXVpbnQ2NFszXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfcmV0dXJuU3RhdGljQXJyYXkKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestReturnStaticArray.arc56_draft.json b/tests/contracts/artifacts/ABITestReturnStaticArray.arc56_draft.json index 5d5536474..578a21456 100644 --- a/tests/contracts/artifacts/ABITestReturnStaticArray.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestReturnStaticArray.arc56_draft.json @@ -387,7 +387,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcmV0dXJuU3RhdGljQXJyYXkoKXVpbnQ2NFszXQoqYWJpX3JvdXRlX3JldHVyblN0YXRpY0FycmF5OgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgcmV0dXJuU3RhdGljQXJyYXkoKXVpbnQ2NFszXQoJY2FsbHN1YiByZXR1cm5TdGF0aWNBcnJheQoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyByZXR1cm5TdGF0aWNBcnJheSgpOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CnJldHVyblN0YXRpY0FycmF5OgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxOQoJLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPiA9IFsxMSwgMjIsIDMzXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwYjAwMDAwMDAwMDAwMDAwMTYwMDAwMDAwMDAwMDAwMDIxCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoyMQoJLy8gcmV0dXJuIGE7CglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGQ1MzIzZTFmIC8vIG1ldGhvZCAicmV0dXJuU3RhdGljQXJyYXkoKXVpbnQ2NFszXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfcmV0dXJuU3RhdGljQXJyYXkKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcmV0dXJuU3RhdGljQXJyYXkoKXVpbnQ2NFszXQoqYWJpX3JvdXRlX3JldHVyblN0YXRpY0FycmF5OgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgcmV0dXJuU3RhdGljQXJyYXkoKXVpbnQ2NFszXQoJY2FsbHN1YiByZXR1cm5TdGF0aWNBcnJheQoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyByZXR1cm5TdGF0aWNBcnJheSgpOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CnJldHVyblN0YXRpY0FycmF5OgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxOQoJLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPiA9IFsxMSwgMjIsIDMzXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwYjAwMDAwMDAwMDAwMDAwMTYwMDAwMDAwMDAwMDAwMDIxCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoyMQoJLy8gcmV0dXJuIGE7CglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGQ1MzIzZTFmIC8vIG1ldGhvZCAicmV0dXJuU3RhdGljQXJyYXkoKXVpbnQ2NFszXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfcmV0dXJuU3RhdGljQXJyYXkKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestReturnTuple.approval.teal b/tests/contracts/artifacts/ABITestReturnTuple.approval.teal index 0656df307..bab33283d 100644 --- a/tests/contracts/artifacts/ABITestReturnTuple.approval.teal +++ b/tests/contracts/artifacts/ABITestReturnTuple.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestReturnTuple.arc32.json b/tests/contracts/artifacts/ABITestReturnTuple.arc32.json index f38c88a03..a0f8cc2b7 100644 --- a/tests/contracts/artifacts/ABITestReturnTuple.arc32.json +++ b/tests/contracts/artifacts/ABITestReturnTuple.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcmV0dXJuVHVwbGUoKSh1aW50NjQsdWludDE2LHVpbnQ2NCkKKmFiaV9yb3V0ZV9yZXR1cm5UdXBsZToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHJldHVyblR1cGxlKCkodWludDY0LHVpbnQxNix1aW50NjQpCgljYWxsc3ViIHJldHVyblR1cGxlCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHJldHVyblR1cGxlKCk6IFt1aW50NjQsIHVpbnQxNiwgdWludDY0XQpyZXR1cm5UdXBsZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglwdXNoYnl0ZXMgMHgKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MzM1CgkvLyBhOiBbdWludDY0LCB1aW50MTYsIHVpbnQ2NF0gPSBbMTEsIDIyLCAzM10KCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMGIwMDE2MDAwMDAwMDAwMDAwMDAyMQoJZnJhbWVfYnVyeSAwIC8vIGE6IFt1aW50NjQsIHVpbnQxNiwgdWludDY0XQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czozMzYKCS8vIHJldHVybiBhOwoJZnJhbWVfZGlnIDAgLy8gYTogW3VpbnQ2NCwgdWludDE2LCB1aW50NjRdCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDUyOGI4NmJmIC8vIG1ldGhvZCAicmV0dXJuVHVwbGUoKSh1aW50NjQsdWludDE2LHVpbnQ2NCkiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3JldHVyblR1cGxlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcmV0dXJuVHVwbGUoKSh1aW50NjQsdWludDE2LHVpbnQ2NCkKKmFiaV9yb3V0ZV9yZXR1cm5UdXBsZToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHJldHVyblR1cGxlKCkodWludDY0LHVpbnQxNix1aW50NjQpCgljYWxsc3ViIHJldHVyblR1cGxlCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHJldHVyblR1cGxlKCk6IFt1aW50NjQsIHVpbnQxNiwgdWludDY0XQpyZXR1cm5UdXBsZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglwdXNoYnl0ZXMgMHgKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MzM1CgkvLyBhOiBbdWludDY0LCB1aW50MTYsIHVpbnQ2NF0gPSBbMTEsIDIyLCAzM10KCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMGIwMDE2MDAwMDAwMDAwMDAwMDAyMQoJZnJhbWVfYnVyeSAwIC8vIGE6IFt1aW50NjQsIHVpbnQxNiwgdWludDY0XQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czozMzYKCS8vIHJldHVybiBhOwoJZnJhbWVfZGlnIDAgLy8gYTogW3VpbnQ2NCwgdWludDE2LCB1aW50NjRdCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDUyOGI4NmJmIC8vIG1ldGhvZCAicmV0dXJuVHVwbGUoKSh1aW50NjQsdWludDE2LHVpbnQ2NCkiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3JldHVyblR1cGxlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestReturnTuple.arc56_draft.json b/tests/contracts/artifacts/ABITestReturnTuple.arc56_draft.json index 2eb453640..445ceaa16 100644 --- a/tests/contracts/artifacts/ABITestReturnTuple.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestReturnTuple.arc56_draft.json @@ -381,7 +381,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcmV0dXJuVHVwbGUoKSh1aW50NjQsdWludDE2LHVpbnQ2NCkKKmFiaV9yb3V0ZV9yZXR1cm5UdXBsZToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHJldHVyblR1cGxlKCkodWludDY0LHVpbnQxNix1aW50NjQpCgljYWxsc3ViIHJldHVyblR1cGxlCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHJldHVyblR1cGxlKCk6IFt1aW50NjQsIHVpbnQxNiwgdWludDY0XQpyZXR1cm5UdXBsZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglwdXNoYnl0ZXMgMHgKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MzM1CgkvLyBhOiBbdWludDY0LCB1aW50MTYsIHVpbnQ2NF0gPSBbMTEsIDIyLCAzM10KCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMGIwMDE2MDAwMDAwMDAwMDAwMDAyMQoJZnJhbWVfYnVyeSAwIC8vIGE6IFt1aW50NjQsIHVpbnQxNiwgdWludDY0XQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czozMzYKCS8vIHJldHVybiBhOwoJZnJhbWVfZGlnIDAgLy8gYTogW3VpbnQ2NCwgdWludDE2LCB1aW50NjRdCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDUyOGI4NmJmIC8vIG1ldGhvZCAicmV0dXJuVHVwbGUoKSh1aW50NjQsdWludDE2LHVpbnQ2NCkiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3JldHVyblR1cGxlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcmV0dXJuVHVwbGUoKSh1aW50NjQsdWludDE2LHVpbnQ2NCkKKmFiaV9yb3V0ZV9yZXR1cm5UdXBsZToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHJldHVyblR1cGxlKCkodWludDY0LHVpbnQxNix1aW50NjQpCgljYWxsc3ViIHJldHVyblR1cGxlCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHJldHVyblR1cGxlKCk6IFt1aW50NjQsIHVpbnQxNiwgdWludDY0XQpyZXR1cm5UdXBsZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglwdXNoYnl0ZXMgMHgKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MzM1CgkvLyBhOiBbdWludDY0LCB1aW50MTYsIHVpbnQ2NF0gPSBbMTEsIDIyLCAzM10KCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMGIwMDE2MDAwMDAwMDAwMDAwMDAyMQoJZnJhbWVfYnVyeSAwIC8vIGE6IFt1aW50NjQsIHVpbnQxNiwgdWludDY0XQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czozMzYKCS8vIHJldHVybiBhOwoJZnJhbWVfZGlnIDAgLy8gYTogW3VpbnQ2NCwgdWludDE2LCB1aW50NjRdCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDUyOGI4NmJmIC8vIG1ldGhvZCAicmV0dXJuVHVwbGUoKSh1aW50NjQsdWludDE2LHVpbnQ2NCkiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3JldHVyblR1cGxlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestReturnTupleWithDyamicArray.approval.teal b/tests/contracts/artifacts/ABITestReturnTupleWithDyamicArray.approval.teal index bd4af88d6..65a5a5f10 100644 --- a/tests/contracts/artifacts/ABITestReturnTupleWithDyamicArray.approval.teal +++ b/tests/contracts/artifacts/ABITestReturnTupleWithDyamicArray.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestReturnTupleWithDyamicArray.arc32.json b/tests/contracts/artifacts/ABITestReturnTupleWithDyamicArray.arc32.json index 03a5cc457..f660588fb 100644 --- a/tests/contracts/artifacts/ABITestReturnTupleWithDyamicArray.arc32.json +++ b/tests/contracts/artifacts/ABITestReturnTupleWithDyamicArray.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyByZXR1cm5UdXBsZVdpdGhEeWFtaWNBcnJheSgpKHVpbnQ2NCx1aW50MTYsdWludDY0W10sdWludDE2W10pCiphYmlfcm91dGVfcmV0dXJuVHVwbGVXaXRoRHlhbWljQXJyYXk6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSByZXR1cm5UdXBsZVdpdGhEeWFtaWNBcnJheSgpKHVpbnQ2NCx1aW50MTYsdWludDY0W10sdWludDE2W10pCgljYWxsc3ViIHJldHVyblR1cGxlV2l0aER5YW1pY0FycmF5Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHJldHVyblR1cGxlV2l0aER5YW1pY0FycmF5KCk6IFt1aW50NjQsIHVpbnQxNiwgdWludDY0W10sIHVpbnQxNltdXQpyZXR1cm5UdXBsZVdpdGhEeWFtaWNBcnJheToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjM5MAoJLy8gYTogW3VpbnQ2NCwgdWludDE2LCB1aW50NjRbXSwgdWludDE2W11dID0gWzEsIDIsIFszLCA0XSwgWzUsIDZdXQoJYnl0ZSAweCAvLyBpbml0aWFsIGhlYWQKCWJ5dGUgMHggLy8gaW5pdGlhbCB0YWlsCglwdXNoYnl0ZXMgMHgwMDBlIC8vIGluaXRpYWwgaGVhZCBvZmZzZXQKCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDEKCWNhbGxzdWIgKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMDIKCWNhbGxzdWIgKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMDIwMDAwMDAwMDAwMDAwMDAzMDAwMDAwMDAwMDAwMDAwNAoJY2FsbHN1YiAqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMDIwMDA1MDAwNgoJY2FsbHN1YiAqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQKCXBvcCAvLyBwb3AgaGVhZCBvZmZzZXQKCWNvbmNhdCAvLyBjb25jYXQgaGVhZCBhbmQgdGFpbAoJZnJhbWVfYnVyeSAwIC8vIGE6IFt1aW50NjQsIHVpbnQxNiwgdWludDY0W10sIHVpbnQxNltdXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czozOTIKCS8vIHJldHVybiBhOwoJZnJhbWVfZGlnIDAgLy8gYTogW3VpbnQ2NCwgdWludDE2LCB1aW50NjRbXSwgdWludDE2W11dCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDg4YTY5YzVjIC8vIG1ldGhvZCAicmV0dXJuVHVwbGVXaXRoRHlhbWljQXJyYXkoKSh1aW50NjQsdWludDE2LHVpbnQ2NFtdLHVpbnQxNltdKSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfcmV0dXJuVHVwbGVXaXRoRHlhbWljQXJyYXkKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnIKCipwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50OgoJcHJvdG8gNCAzCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0xIC8vIGVsZW1lbnQKCWNvbmNhdAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3ViCgoqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCWNvbmNhdAoJZnJhbWVfYnVyeSAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJZHVwCglsZW4KCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJYnRvaQoJKwoJaXRvYgoJZXh0cmFjdCA2IDIKCWZyYW1lX2J1cnkgLTIgLy8gaGVhZCBvZmZzZXQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglzd2FwCgljb25jYXQKCWZyYW1lX2J1cnkgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCXJldHN1Yg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyByZXR1cm5UdXBsZVdpdGhEeWFtaWNBcnJheSgpKHVpbnQ2NCx1aW50MTYsdWludDY0W10sdWludDE2W10pCiphYmlfcm91dGVfcmV0dXJuVHVwbGVXaXRoRHlhbWljQXJyYXk6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSByZXR1cm5UdXBsZVdpdGhEeWFtaWNBcnJheSgpKHVpbnQ2NCx1aW50MTYsdWludDY0W10sdWludDE2W10pCgljYWxsc3ViIHJldHVyblR1cGxlV2l0aER5YW1pY0FycmF5Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHJldHVyblR1cGxlV2l0aER5YW1pY0FycmF5KCk6IFt1aW50NjQsIHVpbnQxNiwgdWludDY0W10sIHVpbnQxNltdXQpyZXR1cm5UdXBsZVdpdGhEeWFtaWNBcnJheToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjM5MAoJLy8gYTogW3VpbnQ2NCwgdWludDE2LCB1aW50NjRbXSwgdWludDE2W11dID0gWzEsIDIsIFszLCA0XSwgWzUsIDZdXQoJYnl0ZSAweCAvLyBpbml0aWFsIGhlYWQKCWJ5dGUgMHggLy8gaW5pdGlhbCB0YWlsCglwdXNoYnl0ZXMgMHgwMDBlIC8vIGluaXRpYWwgaGVhZCBvZmZzZXQKCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDEKCWNhbGxzdWIgKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMDIKCWNhbGxzdWIgKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMDIwMDAwMDAwMDAwMDAwMDAzMDAwMDAwMDAwMDAwMDAwNAoJY2FsbHN1YiAqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMDIwMDA1MDAwNgoJY2FsbHN1YiAqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQKCXBvcCAvLyBwb3AgaGVhZCBvZmZzZXQKCWNvbmNhdCAvLyBjb25jYXQgaGVhZCBhbmQgdGFpbAoJZnJhbWVfYnVyeSAwIC8vIGE6IFt1aW50NjQsIHVpbnQxNiwgdWludDY0W10sIHVpbnQxNltdXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czozOTIKCS8vIHJldHVybiBhOwoJZnJhbWVfZGlnIDAgLy8gYTogW3VpbnQ2NCwgdWludDE2LCB1aW50NjRbXSwgdWludDE2W11dCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDg4YTY5YzVjIC8vIG1ldGhvZCAicmV0dXJuVHVwbGVXaXRoRHlhbWljQXJyYXkoKSh1aW50NjQsdWludDE2LHVpbnQ2NFtdLHVpbnQxNltdKSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfcmV0dXJuVHVwbGVXaXRoRHlhbWljQXJyYXkKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnIKCipwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50OgoJcHJvdG8gNCAzCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0xIC8vIGVsZW1lbnQKCWNvbmNhdAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3ViCgoqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCWNvbmNhdAoJZnJhbWVfYnVyeSAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJZHVwCglsZW4KCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJYnRvaQoJKwoJaXRvYgoJZXh0cmFjdCA2IDIKCWZyYW1lX2J1cnkgLTIgLy8gaGVhZCBvZmZzZXQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglzd2FwCgljb25jYXQKCWZyYW1lX2J1cnkgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCXJldHN1Yg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestReturnTupleWithDyamicArray.arc56_draft.json b/tests/contracts/artifacts/ABITestReturnTupleWithDyamicArray.arc56_draft.json index c34b94cd0..0ee87d4a8 100644 --- a/tests/contracts/artifacts/ABITestReturnTupleWithDyamicArray.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestReturnTupleWithDyamicArray.arc56_draft.json @@ -730,7 +730,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyByZXR1cm5UdXBsZVdpdGhEeWFtaWNBcnJheSgpKHVpbnQ2NCx1aW50MTYsdWludDY0W10sdWludDE2W10pCiphYmlfcm91dGVfcmV0dXJuVHVwbGVXaXRoRHlhbWljQXJyYXk6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSByZXR1cm5UdXBsZVdpdGhEeWFtaWNBcnJheSgpKHVpbnQ2NCx1aW50MTYsdWludDY0W10sdWludDE2W10pCgljYWxsc3ViIHJldHVyblR1cGxlV2l0aER5YW1pY0FycmF5Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHJldHVyblR1cGxlV2l0aER5YW1pY0FycmF5KCk6IFt1aW50NjQsIHVpbnQxNiwgdWludDY0W10sIHVpbnQxNltdXQpyZXR1cm5UdXBsZVdpdGhEeWFtaWNBcnJheToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjM5MAoJLy8gYTogW3VpbnQ2NCwgdWludDE2LCB1aW50NjRbXSwgdWludDE2W11dID0gWzEsIDIsIFszLCA0XSwgWzUsIDZdXQoJYnl0ZSAweCAvLyBpbml0aWFsIGhlYWQKCWJ5dGUgMHggLy8gaW5pdGlhbCB0YWlsCglwdXNoYnl0ZXMgMHgwMDBlIC8vIGluaXRpYWwgaGVhZCBvZmZzZXQKCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDEKCWNhbGxzdWIgKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMDIKCWNhbGxzdWIgKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMDIwMDAwMDAwMDAwMDAwMDAzMDAwMDAwMDAwMDAwMDAwNAoJY2FsbHN1YiAqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMDIwMDA1MDAwNgoJY2FsbHN1YiAqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQKCXBvcCAvLyBwb3AgaGVhZCBvZmZzZXQKCWNvbmNhdCAvLyBjb25jYXQgaGVhZCBhbmQgdGFpbAoJZnJhbWVfYnVyeSAwIC8vIGE6IFt1aW50NjQsIHVpbnQxNiwgdWludDY0W10sIHVpbnQxNltdXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czozOTIKCS8vIHJldHVybiBhOwoJZnJhbWVfZGlnIDAgLy8gYTogW3VpbnQ2NCwgdWludDE2LCB1aW50NjRbXSwgdWludDE2W11dCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDg4YTY5YzVjIC8vIG1ldGhvZCAicmV0dXJuVHVwbGVXaXRoRHlhbWljQXJyYXkoKSh1aW50NjQsdWludDE2LHVpbnQ2NFtdLHVpbnQxNltdKSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfcmV0dXJuVHVwbGVXaXRoRHlhbWljQXJyYXkKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnIKCipwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50OgoJcHJvdG8gNCAzCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0xIC8vIGVsZW1lbnQKCWNvbmNhdAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3ViCgoqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCWNvbmNhdAoJZnJhbWVfYnVyeSAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJZHVwCglsZW4KCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJYnRvaQoJKwoJaXRvYgoJZXh0cmFjdCA2IDIKCWZyYW1lX2J1cnkgLTIgLy8gaGVhZCBvZmZzZXQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglzd2FwCgljb25jYXQKCWZyYW1lX2J1cnkgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCXJldHN1Yg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyByZXR1cm5UdXBsZVdpdGhEeWFtaWNBcnJheSgpKHVpbnQ2NCx1aW50MTYsdWludDY0W10sdWludDE2W10pCiphYmlfcm91dGVfcmV0dXJuVHVwbGVXaXRoRHlhbWljQXJyYXk6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSByZXR1cm5UdXBsZVdpdGhEeWFtaWNBcnJheSgpKHVpbnQ2NCx1aW50MTYsdWludDY0W10sdWludDE2W10pCgljYWxsc3ViIHJldHVyblR1cGxlV2l0aER5YW1pY0FycmF5Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHJldHVyblR1cGxlV2l0aER5YW1pY0FycmF5KCk6IFt1aW50NjQsIHVpbnQxNiwgdWludDY0W10sIHVpbnQxNltdXQpyZXR1cm5UdXBsZVdpdGhEeWFtaWNBcnJheToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjM5MAoJLy8gYTogW3VpbnQ2NCwgdWludDE2LCB1aW50NjRbXSwgdWludDE2W11dID0gWzEsIDIsIFszLCA0XSwgWzUsIDZdXQoJYnl0ZSAweCAvLyBpbml0aWFsIGhlYWQKCWJ5dGUgMHggLy8gaW5pdGlhbCB0YWlsCglwdXNoYnl0ZXMgMHgwMDBlIC8vIGluaXRpYWwgaGVhZCBvZmZzZXQKCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDEKCWNhbGxzdWIgKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMDIKCWNhbGxzdWIgKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMDIwMDAwMDAwMDAwMDAwMDAzMDAwMDAwMDAwMDAwMDAwNAoJY2FsbHN1YiAqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMDIwMDA1MDAwNgoJY2FsbHN1YiAqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQKCXBvcCAvLyBwb3AgaGVhZCBvZmZzZXQKCWNvbmNhdCAvLyBjb25jYXQgaGVhZCBhbmQgdGFpbAoJZnJhbWVfYnVyeSAwIC8vIGE6IFt1aW50NjQsIHVpbnQxNiwgdWludDY0W10sIHVpbnQxNltdXQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czozOTIKCS8vIHJldHVybiBhOwoJZnJhbWVfZGlnIDAgLy8gYTogW3VpbnQ2NCwgdWludDE2LCB1aW50NjRbXSwgdWludDE2W11dCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDg4YTY5YzVjIC8vIG1ldGhvZCAicmV0dXJuVHVwbGVXaXRoRHlhbWljQXJyYXkoKSh1aW50NjQsdWludDE2LHVpbnQ2NFtdLHVpbnQxNltdKSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfcmV0dXJuVHVwbGVXaXRoRHlhbWljQXJyYXkKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnIKCipwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50OgoJcHJvdG8gNCAzCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0xIC8vIGVsZW1lbnQKCWNvbmNhdAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3ViCgoqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCWNvbmNhdAoJZnJhbWVfYnVyeSAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJZHVwCglsZW4KCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJYnRvaQoJKwoJaXRvYgoJZXh0cmFjdCA2IDIKCWZyYW1lX2J1cnkgLTIgLy8gaGVhZCBvZmZzZXQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglzd2FwCgljb25jYXQKCWZyYW1lX2J1cnkgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCXJldHN1Yg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestSetStaticArrayElement.approval.teal b/tests/contracts/artifacts/ABITestSetStaticArrayElement.approval.teal index 6970d9a16..30313c07c 100644 --- a/tests/contracts/artifacts/ABITestSetStaticArrayElement.approval.teal +++ b/tests/contracts/artifacts/ABITestSetStaticArrayElement.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestSetStaticArrayElement.arc32.json b/tests/contracts/artifacts/ABITestSetStaticArrayElement.arc32.json index 551fd57df..b94a351ef 100644 --- a/tests/contracts/artifacts/ABITestSetStaticArrayElement.arc32.json +++ b/tests/contracts/artifacts/ABITestSetStaticArrayElement.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc2V0U3RhdGljQXJyYXlFbGVtZW50KCl1aW50NjQKKmFiaV9yb3V0ZV9zZXRTdGF0aWNBcnJheUVsZW1lbnQ6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBzZXRTdGF0aWNBcnJheUVsZW1lbnQoKXVpbnQ2NAoJY2FsbHN1YiBzZXRTdGF0aWNBcnJheUVsZW1lbnQKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gc2V0U3RhdGljQXJyYXlFbGVtZW50KCk6IHVpbnQ2NApzZXRTdGF0aWNBcnJheUVsZW1lbnQ6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjY0CgkvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+ID0gWzExLCAyMiwgMzNdCglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDBiMDAwMDAwMDAwMDAwMDAxNjAwMDAwMDAwMDAwMDAwMjEKCWZyYW1lX2J1cnkgMCAvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjY2CgkvLyBhWzFdID0gMjIyCglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMGRlCglyZXBsYWNlMiA4CglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo2OAoJLy8gcmV0dXJuIGFbMV07CglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CglleHRyYWN0IDggOAoJYnRvaQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhjMGY1ZjAwMSAvLyBtZXRob2QgInNldFN0YXRpY0FycmF5RWxlbWVudCgpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9zZXRTdGF0aWNBcnJheUVsZW1lbnQKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc2V0U3RhdGljQXJyYXlFbGVtZW50KCl1aW50NjQKKmFiaV9yb3V0ZV9zZXRTdGF0aWNBcnJheUVsZW1lbnQ6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBzZXRTdGF0aWNBcnJheUVsZW1lbnQoKXVpbnQ2NAoJY2FsbHN1YiBzZXRTdGF0aWNBcnJheUVsZW1lbnQKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gc2V0U3RhdGljQXJyYXlFbGVtZW50KCk6IHVpbnQ2NApzZXRTdGF0aWNBcnJheUVsZW1lbnQ6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjY0CgkvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+ID0gWzExLCAyMiwgMzNdCglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDBiMDAwMDAwMDAwMDAwMDAxNjAwMDAwMDAwMDAwMDAwMjEKCWZyYW1lX2J1cnkgMCAvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjY2CgkvLyBhWzFdID0gMjIyCglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMGRlCglyZXBsYWNlMiA4CglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo2OAoJLy8gcmV0dXJuIGFbMV07CglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CglleHRyYWN0IDggOAoJYnRvaQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhjMGY1ZjAwMSAvLyBtZXRob2QgInNldFN0YXRpY0FycmF5RWxlbWVudCgpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9zZXRTdGF0aWNBcnJheUVsZW1lbnQKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestSetStaticArrayElement.arc56_draft.json b/tests/contracts/artifacts/ABITestSetStaticArrayElement.arc56_draft.json index f4c2e38c3..1644699e2 100644 --- a/tests/contracts/artifacts/ABITestSetStaticArrayElement.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestSetStaticArrayElement.arc56_draft.json @@ -450,7 +450,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc2V0U3RhdGljQXJyYXlFbGVtZW50KCl1aW50NjQKKmFiaV9yb3V0ZV9zZXRTdGF0aWNBcnJheUVsZW1lbnQ6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBzZXRTdGF0aWNBcnJheUVsZW1lbnQoKXVpbnQ2NAoJY2FsbHN1YiBzZXRTdGF0aWNBcnJheUVsZW1lbnQKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gc2V0U3RhdGljQXJyYXlFbGVtZW50KCk6IHVpbnQ2NApzZXRTdGF0aWNBcnJheUVsZW1lbnQ6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjY0CgkvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+ID0gWzExLCAyMiwgMzNdCglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDBiMDAwMDAwMDAwMDAwMDAxNjAwMDAwMDAwMDAwMDAwMjEKCWZyYW1lX2J1cnkgMCAvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjY2CgkvLyBhWzFdID0gMjIyCglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMGRlCglyZXBsYWNlMiA4CglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo2OAoJLy8gcmV0dXJuIGFbMV07CglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CglleHRyYWN0IDggOAoJYnRvaQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhjMGY1ZjAwMSAvLyBtZXRob2QgInNldFN0YXRpY0FycmF5RWxlbWVudCgpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9zZXRTdGF0aWNBcnJheUVsZW1lbnQKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc2V0U3RhdGljQXJyYXlFbGVtZW50KCl1aW50NjQKKmFiaV9yb3V0ZV9zZXRTdGF0aWNBcnJheUVsZW1lbnQ6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBzZXRTdGF0aWNBcnJheUVsZW1lbnQoKXVpbnQ2NAoJY2FsbHN1YiBzZXRTdGF0aWNBcnJheUVsZW1lbnQKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gc2V0U3RhdGljQXJyYXlFbGVtZW50KCk6IHVpbnQ2NApzZXRTdGF0aWNBcnJheUVsZW1lbnQ6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjY0CgkvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+ID0gWzExLCAyMiwgMzNdCglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDBiMDAwMDAwMDAwMDAwMDAxNjAwMDAwMDAwMDAwMDAwMjEKCWZyYW1lX2J1cnkgMCAvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjY2CgkvLyBhWzFdID0gMjIyCglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMGRlCglyZXBsYWNlMiA4CglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo2OAoJLy8gcmV0dXJuIGFbMV07CglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CglleHRyYWN0IDggOAoJYnRvaQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhjMGY1ZjAwMSAvLyBtZXRob2QgInNldFN0YXRpY0FycmF5RWxlbWVudCgpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9zZXRTdGF0aWNBcnJheUVsZW1lbnQKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestShortTypeNotation.approval.teal b/tests/contracts/artifacts/ABITestShortTypeNotation.approval.teal index 6b59323a6..5352e4e52 100644 --- a/tests/contracts/artifacts/ABITestShortTypeNotation.approval.teal +++ b/tests/contracts/artifacts/ABITestShortTypeNotation.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestShortTypeNotation.arc32.json b/tests/contracts/artifacts/ABITestShortTypeNotation.arc32.json index fa50df003..a1381fd2b 100644 --- a/tests/contracts/artifacts/ABITestShortTypeNotation.arc32.json +++ b/tests/contracts/artifacts/ABITestShortTypeNotation.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc2hvcnRUeXBlTm90YXRpb24oKXVpbnQxNgoqYWJpX3JvdXRlX3Nob3J0VHlwZU5vdGF0aW9uOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgc2hvcnRUeXBlTm90YXRpb24oKXVpbnQxNgoJY2FsbHN1YiBzaG9ydFR5cGVOb3RhdGlvbgoJaXRvYgoJZHVwCgliaXRsZW4KCXB1c2hpbnQgMTYKCTw9CgoJLy8gc2hvcnRUeXBlTm90YXRpb24gcmV0dXJuIHZhbHVlIG92ZXJmbG93ZWQgMTYgYml0cwoJYXNzZXJ0CglleHRyYWN0IDYgMgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBzaG9ydFR5cGVOb3RhdGlvbigpOiB1aW50MTYKc2hvcnRUeXBlTm90YXRpb246Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjI5MgoJLy8gYTogW1N0YXRpY0FycmF5PHVpbnQxNiwgMj4sIFN0YXRpY0FycmF5PHVpbnQ2NCwgMj4sIFN0YXRpY0FycmF5PHVpbnQxNiwgMj5dID0gWwoJLy8gICAgICAgWzExLCAyMl0sCgkvLyAgICAgICBbMzMsIDQ0XSwKCS8vICAgICAgIFs1NSwgNjZdLAoJLy8gICAgIF0KCXB1c2hieXRlcyAweDAwMGIwMDE2MDAwMDAwMDAwMDAwMDAyMTAwMDAwMDAwMDAwMDAwMmMwMDM3MDA0MgoJZnJhbWVfYnVyeSAwIC8vIGE6IFtTdGF0aWNBcnJheTx1aW50MTYsIDI+LCBTdGF0aWNBcnJheTx1aW50NjQsIDI+LCBTdGF0aWNBcnJheTx1aW50MTYsIDI+XQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoyOTgKCS8vIHJldHVybiBhWzJdWzFdOwoJZnJhbWVfZGlnIDAgLy8gYTogW1N0YXRpY0FycmF5PHVpbnQxNiwgMj4sIFN0YXRpY0FycmF5PHVpbnQ2NCwgMj4sIFN0YXRpY0FycmF5PHVpbnQxNiwgMj5dCglleHRyYWN0IDIyIDIKCWJ0b2kKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4OGFhZTNjN2YgLy8gbWV0aG9kICJzaG9ydFR5cGVOb3RhdGlvbigpdWludDE2IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9zaG9ydFR5cGVOb3RhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc2hvcnRUeXBlTm90YXRpb24oKXVpbnQxNgoqYWJpX3JvdXRlX3Nob3J0VHlwZU5vdGF0aW9uOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgc2hvcnRUeXBlTm90YXRpb24oKXVpbnQxNgoJY2FsbHN1YiBzaG9ydFR5cGVOb3RhdGlvbgoJaXRvYgoJZHVwCgliaXRsZW4KCXB1c2hpbnQgMTYKCTw9CgoJLy8gc2hvcnRUeXBlTm90YXRpb24gcmV0dXJuIHZhbHVlIG92ZXJmbG93ZWQgMTYgYml0cwoJYXNzZXJ0CglleHRyYWN0IDYgMgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBzaG9ydFR5cGVOb3RhdGlvbigpOiB1aW50MTYKc2hvcnRUeXBlTm90YXRpb246Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjI5MgoJLy8gYTogW1N0YXRpY0FycmF5PHVpbnQxNiwgMj4sIFN0YXRpY0FycmF5PHVpbnQ2NCwgMj4sIFN0YXRpY0FycmF5PHVpbnQxNiwgMj5dID0gWwoJLy8gICAgICAgWzExLCAyMl0sCgkvLyAgICAgICBbMzMsIDQ0XSwKCS8vICAgICAgIFs1NSwgNjZdLAoJLy8gICAgIF0KCXB1c2hieXRlcyAweDAwMGIwMDE2MDAwMDAwMDAwMDAwMDAyMTAwMDAwMDAwMDAwMDAwMmMwMDM3MDA0MgoJZnJhbWVfYnVyeSAwIC8vIGE6IFtTdGF0aWNBcnJheTx1aW50MTYsIDI+LCBTdGF0aWNBcnJheTx1aW50NjQsIDI+LCBTdGF0aWNBcnJheTx1aW50MTYsIDI+XQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoyOTgKCS8vIHJldHVybiBhWzJdWzFdOwoJZnJhbWVfZGlnIDAgLy8gYTogW1N0YXRpY0FycmF5PHVpbnQxNiwgMj4sIFN0YXRpY0FycmF5PHVpbnQ2NCwgMj4sIFN0YXRpY0FycmF5PHVpbnQxNiwgMj5dCglleHRyYWN0IDIyIDIKCWJ0b2kKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4OGFhZTNjN2YgLy8gbWV0aG9kICJzaG9ydFR5cGVOb3RhdGlvbigpdWludDE2IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9zaG9ydFR5cGVOb3RhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestShortTypeNotation.arc56_draft.json b/tests/contracts/artifacts/ABITestShortTypeNotation.arc56_draft.json index ae4651651..b2f1255a7 100644 --- a/tests/contracts/artifacts/ABITestShortTypeNotation.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestShortTypeNotation.arc56_draft.json @@ -456,7 +456,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc2hvcnRUeXBlTm90YXRpb24oKXVpbnQxNgoqYWJpX3JvdXRlX3Nob3J0VHlwZU5vdGF0aW9uOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgc2hvcnRUeXBlTm90YXRpb24oKXVpbnQxNgoJY2FsbHN1YiBzaG9ydFR5cGVOb3RhdGlvbgoJaXRvYgoJZHVwCgliaXRsZW4KCXB1c2hpbnQgMTYKCTw9CgoJLy8gc2hvcnRUeXBlTm90YXRpb24gcmV0dXJuIHZhbHVlIG92ZXJmbG93ZWQgMTYgYml0cwoJYXNzZXJ0CglleHRyYWN0IDYgMgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBzaG9ydFR5cGVOb3RhdGlvbigpOiB1aW50MTYKc2hvcnRUeXBlTm90YXRpb246Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjI5MgoJLy8gYTogW1N0YXRpY0FycmF5PHVpbnQxNiwgMj4sIFN0YXRpY0FycmF5PHVpbnQ2NCwgMj4sIFN0YXRpY0FycmF5PHVpbnQxNiwgMj5dID0gWwoJLy8gICAgICAgWzExLCAyMl0sCgkvLyAgICAgICBbMzMsIDQ0XSwKCS8vICAgICAgIFs1NSwgNjZdLAoJLy8gICAgIF0KCXB1c2hieXRlcyAweDAwMGIwMDE2MDAwMDAwMDAwMDAwMDAyMTAwMDAwMDAwMDAwMDAwMmMwMDM3MDA0MgoJZnJhbWVfYnVyeSAwIC8vIGE6IFtTdGF0aWNBcnJheTx1aW50MTYsIDI+LCBTdGF0aWNBcnJheTx1aW50NjQsIDI+LCBTdGF0aWNBcnJheTx1aW50MTYsIDI+XQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoyOTgKCS8vIHJldHVybiBhWzJdWzFdOwoJZnJhbWVfZGlnIDAgLy8gYTogW1N0YXRpY0FycmF5PHVpbnQxNiwgMj4sIFN0YXRpY0FycmF5PHVpbnQ2NCwgMj4sIFN0YXRpY0FycmF5PHVpbnQxNiwgMj5dCglleHRyYWN0IDIyIDIKCWJ0b2kKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4OGFhZTNjN2YgLy8gbWV0aG9kICJzaG9ydFR5cGVOb3RhdGlvbigpdWludDE2IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9zaG9ydFR5cGVOb3RhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc2hvcnRUeXBlTm90YXRpb24oKXVpbnQxNgoqYWJpX3JvdXRlX3Nob3J0VHlwZU5vdGF0aW9uOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgc2hvcnRUeXBlTm90YXRpb24oKXVpbnQxNgoJY2FsbHN1YiBzaG9ydFR5cGVOb3RhdGlvbgoJaXRvYgoJZHVwCgliaXRsZW4KCXB1c2hpbnQgMTYKCTw9CgoJLy8gc2hvcnRUeXBlTm90YXRpb24gcmV0dXJuIHZhbHVlIG92ZXJmbG93ZWQgMTYgYml0cwoJYXNzZXJ0CglleHRyYWN0IDYgMgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBzaG9ydFR5cGVOb3RhdGlvbigpOiB1aW50MTYKc2hvcnRUeXBlTm90YXRpb246Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjI5MgoJLy8gYTogW1N0YXRpY0FycmF5PHVpbnQxNiwgMj4sIFN0YXRpY0FycmF5PHVpbnQ2NCwgMj4sIFN0YXRpY0FycmF5PHVpbnQxNiwgMj5dID0gWwoJLy8gICAgICAgWzExLCAyMl0sCgkvLyAgICAgICBbMzMsIDQ0XSwKCS8vICAgICAgIFs1NSwgNjZdLAoJLy8gICAgIF0KCXB1c2hieXRlcyAweDAwMGIwMDE2MDAwMDAwMDAwMDAwMDAyMTAwMDAwMDAwMDAwMDAwMmMwMDM3MDA0MgoJZnJhbWVfYnVyeSAwIC8vIGE6IFtTdGF0aWNBcnJheTx1aW50MTYsIDI+LCBTdGF0aWNBcnJheTx1aW50NjQsIDI+LCBTdGF0aWNBcnJheTx1aW50MTYsIDI+XQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoyOTgKCS8vIHJldHVybiBhWzJdWzFdOwoJZnJhbWVfZGlnIDAgLy8gYTogW1N0YXRpY0FycmF5PHVpbnQxNiwgMj4sIFN0YXRpY0FycmF5PHVpbnQ2NCwgMj4sIFN0YXRpY0FycmF5PHVpbnQxNiwgMj5dCglleHRyYWN0IDIyIDIKCWJ0b2kKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4OGFhZTNjN2YgLy8gbWV0aG9kICJzaG9ydFR5cGVOb3RhdGlvbigpdWludDE2IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9zaG9ydFR5cGVOb3RhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestShortenDynamicElementInTuple.approval.teal b/tests/contracts/artifacts/ABITestShortenDynamicElementInTuple.approval.teal index 592ec6f51..6e89d7689 100644 --- a/tests/contracts/artifacts/ABITestShortenDynamicElementInTuple.approval.teal +++ b/tests/contracts/artifacts/ABITestShortenDynamicElementInTuple.approval.teal @@ -2,7 +2,7 @@ intcblock 2 bytecblock 0x00010005 0x00010006 0x00010007 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestShortenDynamicElementInTuple.arc32.json b/tests/contracts/artifacts/ABITestShortenDynamicElementInTuple.arc32.json index 69c49a38b..1b510b290 100644 --- a/tests/contracts/artifacts/ABITestShortenDynamicElementInTuple.arc32.json +++ b/tests/contracts/artifacts/ABITestShortenDynamicElementInTuple.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "#pragma version 10
intcblock 2
bytecblock 0x00010005 0x00010006 0x00010007 0x

// This TEAL was generated by TEALScript v0.104.1
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// shortenDynamicElementInTuple()(uint16[],uint16[],uint16[])
*abi_route_shortenDynamicElementInTuple:
	// The ABI return prefix
	pushbytes 0x151f7c75

	// execute shortenDynamicElementInTuple()(uint16[],uint16[],uint16[])
	callsub shortenDynamicElementInTuple
	concat
	log
	pushint 1
	return

// shortenDynamicElementInTuple(): [uint16[], uint16[], uint16[]]
shortenDynamicElementInTuple:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/abi.algo.ts:586
	// a: [uint16[], uint16[], uint16[]] = [
	//       [1, 2],
	//       [2, 3],
	//       [3, 4],
	//     ]
	byte 0x // initial head
	byte 0x // initial tail
	pushbytes 0x0006 // initial head offset
	pushbytes 0x000200010002
	callsub *process_dynamic_tuple_element
	pushbytes 0x000200020003
	callsub *process_dynamic_tuple_element
	pushbytes 0x000200030004
	callsub *process_dynamic_tuple_element
	pop // pop head offset
	concat // concat head and tail
	frame_bury 0 // a: [uint16[], uint16[], uint16[]]

	// tests/contracts/abi.algo.ts:592
	// a[0] = [5]
	frame_dig 0 // a: [uint16[], uint16[], uint16[]]
	store 255 // full array
	pushint 0
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 2 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x00010005
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 250 // length difference
	load 251 // element head offset
	int 2
	+ // head ofset
	callsub *update_dynamic_head
	load 250 // length difference
	load 251 // element head offset
	pushint 4
	+ // head ofset
	callsub *update_dynamic_head
	load 255 // full array
	frame_bury 0 // a: [uint16[], uint16[], uint16[]]

	// tests/contracts/abi.algo.ts:593
	// a[1] = [6]
	frame_dig 0 // a: [uint16[], uint16[], uint16[]]
	store 255 // full array
	int 2
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 2 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x00010006
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 250 // length difference
	load 251 // element head offset
	int 2
	+ // head ofset
	callsub *update_dynamic_head
	load 255 // full array
	frame_bury 0 // a: [uint16[], uint16[], uint16[]]

	// tests/contracts/abi.algo.ts:594
	// a[2] = [7]
	frame_dig 0 // a: [uint16[], uint16[], uint16[]]
	store 255 // full array
	pushint 4
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 2 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x00010007
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 255 // full array
	frame_bury 0 // a: [uint16[], uint16[], uint16[]]

	// tests/contracts/abi.algo.ts:596
	// return a;
	frame_dig 0 // a: [uint16[], uint16[], uint16[]]

	// set the subroutine return value
	frame_bury 0
	retsub

*abi_route_createApplication:
	pushint 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0xa7dbad86 // method "shortenDynamicElementInTuple()(uint16[],uint16[],uint16[])"
	txna ApplicationArgs 0
	match *abi_route_shortenDynamicElementInTuple

	// this contract does not implement the given ABI method for call NoOp
	err

*process_dynamic_tuple_element:
	proto 4 3
	frame_dig -4 // tuple head
	frame_dig -2 // head offset
	concat
	frame_bury -4 // tuple head
	frame_dig -1 // element
	dup
	len
	frame_dig -2 // head offset
	btoi
	+
	itob
	extract 6 2
	frame_bury -2 // head offset
	frame_dig -3 // tuple tail
	swap
	concat
	frame_bury -3 // tuple tail
	frame_dig -4 // tuple head
	frame_dig -3 // tuple tail
	frame_dig -2 // head offset
	retsub

*update_dynamic_head:
	proto 2 0
	frame_dig -2 // length difference
	load 255 // full array
	frame_dig -1 // dynamic array offset
	extract_uint16 // extract dynamic array offset
	load 249 // subtract head difference
	bz *subtract_head_difference
	+ // add difference to offset
	b *end_calc_new_head

*subtract_head_difference:
	swap
	- // subtract difference from offet

*end_calc_new_head:
	itob // convert to bytes
	extract 6 2 // convert to uint16
	load 255 // full array
	swap
	frame_dig -1 // offset
	swap
	replace3 // update offset
	store 255 // full array
	retsub

*get_length_difference:
	load 252 // new element
	len // length of new element
	load 253 // element length
	<
	bnz *swapped_difference
	load 252 // new element
	len // length of new element
	load 253 // element length
	pushint 1
	store 249 // subtract head difference
	b *get_difference

*swapped_difference:
	load 253 // element length
	load 252 // new element
	len // length of new element
	pushint 0
	store 249 // subtract head difference

*get_difference:
	- // get length difference
	store 250 // length difference
	retsub", + "approval": "#pragma version 10
intcblock 2
bytecblock 0x00010005 0x00010006 0x00010007 0x

// This TEAL was generated by TEALScript v0.105.0
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// shortenDynamicElementInTuple()(uint16[],uint16[],uint16[])
*abi_route_shortenDynamicElementInTuple:
	// The ABI return prefix
	pushbytes 0x151f7c75

	// execute shortenDynamicElementInTuple()(uint16[],uint16[],uint16[])
	callsub shortenDynamicElementInTuple
	concat
	log
	pushint 1
	return

// shortenDynamicElementInTuple(): [uint16[], uint16[], uint16[]]
shortenDynamicElementInTuple:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/abi.algo.ts:586
	// a: [uint16[], uint16[], uint16[]] = [
	//       [1, 2],
	//       [2, 3],
	//       [3, 4],
	//     ]
	byte 0x // initial head
	byte 0x // initial tail
	pushbytes 0x0006 // initial head offset
	pushbytes 0x000200010002
	callsub *process_dynamic_tuple_element
	pushbytes 0x000200020003
	callsub *process_dynamic_tuple_element
	pushbytes 0x000200030004
	callsub *process_dynamic_tuple_element
	pop // pop head offset
	concat // concat head and tail
	frame_bury 0 // a: [uint16[], uint16[], uint16[]]

	// tests/contracts/abi.algo.ts:592
	// a[0] = [5]
	frame_dig 0 // a: [uint16[], uint16[], uint16[]]
	store 255 // full array
	pushint 0
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 2 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x00010005
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 250 // length difference
	load 251 // element head offset
	int 2
	+ // head ofset
	callsub *update_dynamic_head
	load 250 // length difference
	load 251 // element head offset
	pushint 4
	+ // head ofset
	callsub *update_dynamic_head
	load 255 // full array
	frame_bury 0 // a: [uint16[], uint16[], uint16[]]

	// tests/contracts/abi.algo.ts:593
	// a[1] = [6]
	frame_dig 0 // a: [uint16[], uint16[], uint16[]]
	store 255 // full array
	int 2
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 2 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x00010006
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 250 // length difference
	load 251 // element head offset
	int 2
	+ // head ofset
	callsub *update_dynamic_head
	load 255 // full array
	frame_bury 0 // a: [uint16[], uint16[], uint16[]]

	// tests/contracts/abi.algo.ts:594
	// a[2] = [7]
	frame_dig 0 // a: [uint16[], uint16[], uint16[]]
	store 255 // full array
	pushint 4
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 2 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x00010007
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 255 // full array
	frame_bury 0 // a: [uint16[], uint16[], uint16[]]

	// tests/contracts/abi.algo.ts:596
	// return a;
	frame_dig 0 // a: [uint16[], uint16[], uint16[]]

	// set the subroutine return value
	frame_bury 0
	retsub

*abi_route_createApplication:
	pushint 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0xa7dbad86 // method "shortenDynamicElementInTuple()(uint16[],uint16[],uint16[])"
	txna ApplicationArgs 0
	match *abi_route_shortenDynamicElementInTuple

	// this contract does not implement the given ABI method for call NoOp
	err

*process_dynamic_tuple_element:
	proto 4 3
	frame_dig -4 // tuple head
	frame_dig -2 // head offset
	concat
	frame_bury -4 // tuple head
	frame_dig -1 // element
	dup
	len
	frame_dig -2 // head offset
	btoi
	+
	itob
	extract 6 2
	frame_bury -2 // head offset
	frame_dig -3 // tuple tail
	swap
	concat
	frame_bury -3 // tuple tail
	frame_dig -4 // tuple head
	frame_dig -3 // tuple tail
	frame_dig -2 // head offset
	retsub

*update_dynamic_head:
	proto 2 0
	frame_dig -2 // length difference
	load 255 // full array
	frame_dig -1 // dynamic array offset
	extract_uint16 // extract dynamic array offset
	load 249 // subtract head difference
	bz *subtract_head_difference
	+ // add difference to offset
	b *end_calc_new_head

*subtract_head_difference:
	swap
	- // subtract difference from offet

*end_calc_new_head:
	itob // convert to bytes
	extract 6 2 // convert to uint16
	load 255 // full array
	swap
	frame_dig -1 // offset
	swap
	replace3 // update offset
	store 255 // full array
	retsub

*get_length_difference:
	load 252 // new element
	len // length of new element
	load 253 // element length
	<
	bnz *swapped_difference
	load 252 // new element
	len // length of new element
	load 253 // element length
	pushint 1
	store 249 // subtract head difference
	b *get_difference

*swapped_difference:
	load 253 // element length
	load 252 // new element
	len // length of new element
	pushint 0
	store 249 // subtract head difference

*get_difference:
	- // get length difference
	store 250 // length difference
	retsub", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestShortenDynamicElementInTuple.arc56_draft.json b/tests/contracts/artifacts/ABITestShortenDynamicElementInTuple.arc56_draft.json index a6e6acca6..399aab5b1 100644 --- a/tests/contracts/artifacts/ABITestShortenDynamicElementInTuple.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestShortenDynamicElementInTuple.arc56_draft.json @@ -2019,7 +2019,7 @@ } }, "source": { - "approval": "#pragma version 10
intcblock 2
bytecblock 0x00010005 0x00010006 0x00010007 0x

// This TEAL was generated by TEALScript v0.104.1
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// shortenDynamicElementInTuple()(uint16[],uint16[],uint16[])
*abi_route_shortenDynamicElementInTuple:
	// The ABI return prefix
	pushbytes 0x151f7c75

	// execute shortenDynamicElementInTuple()(uint16[],uint16[],uint16[])
	callsub shortenDynamicElementInTuple
	concat
	log
	pushint 1
	return

// shortenDynamicElementInTuple(): [uint16[], uint16[], uint16[]]
shortenDynamicElementInTuple:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/abi.algo.ts:586
	// a: [uint16[], uint16[], uint16[]] = [
	//       [1, 2],
	//       [2, 3],
	//       [3, 4],
	//     ]
	byte 0x // initial head
	byte 0x // initial tail
	pushbytes 0x0006 // initial head offset
	pushbytes 0x000200010002
	callsub *process_dynamic_tuple_element
	pushbytes 0x000200020003
	callsub *process_dynamic_tuple_element
	pushbytes 0x000200030004
	callsub *process_dynamic_tuple_element
	pop // pop head offset
	concat // concat head and tail
	frame_bury 0 // a: [uint16[], uint16[], uint16[]]

	// tests/contracts/abi.algo.ts:592
	// a[0] = [5]
	frame_dig 0 // a: [uint16[], uint16[], uint16[]]
	store 255 // full array
	pushint 0
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 2 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x00010005
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 250 // length difference
	load 251 // element head offset
	int 2
	+ // head ofset
	callsub *update_dynamic_head
	load 250 // length difference
	load 251 // element head offset
	pushint 4
	+ // head ofset
	callsub *update_dynamic_head
	load 255 // full array
	frame_bury 0 // a: [uint16[], uint16[], uint16[]]

	// tests/contracts/abi.algo.ts:593
	// a[1] = [6]
	frame_dig 0 // a: [uint16[], uint16[], uint16[]]
	store 255 // full array
	int 2
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 2 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x00010006
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 250 // length difference
	load 251 // element head offset
	int 2
	+ // head ofset
	callsub *update_dynamic_head
	load 255 // full array
	frame_bury 0 // a: [uint16[], uint16[], uint16[]]

	// tests/contracts/abi.algo.ts:594
	// a[2] = [7]
	frame_dig 0 // a: [uint16[], uint16[], uint16[]]
	store 255 // full array
	pushint 4
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 2 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x00010007
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 255 // full array
	frame_bury 0 // a: [uint16[], uint16[], uint16[]]

	// tests/contracts/abi.algo.ts:596
	// return a;
	frame_dig 0 // a: [uint16[], uint16[], uint16[]]

	// set the subroutine return value
	frame_bury 0
	retsub

*abi_route_createApplication:
	pushint 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0xa7dbad86 // method "shortenDynamicElementInTuple()(uint16[],uint16[],uint16[])"
	txna ApplicationArgs 0
	match *abi_route_shortenDynamicElementInTuple

	// this contract does not implement the given ABI method for call NoOp
	err

*process_dynamic_tuple_element:
	proto 4 3
	frame_dig -4 // tuple head
	frame_dig -2 // head offset
	concat
	frame_bury -4 // tuple head
	frame_dig -1 // element
	dup
	len
	frame_dig -2 // head offset
	btoi
	+
	itob
	extract 6 2
	frame_bury -2 // head offset
	frame_dig -3 // tuple tail
	swap
	concat
	frame_bury -3 // tuple tail
	frame_dig -4 // tuple head
	frame_dig -3 // tuple tail
	frame_dig -2 // head offset
	retsub

*update_dynamic_head:
	proto 2 0
	frame_dig -2 // length difference
	load 255 // full array
	frame_dig -1 // dynamic array offset
	extract_uint16 // extract dynamic array offset
	load 249 // subtract head difference
	bz *subtract_head_difference
	+ // add difference to offset
	b *end_calc_new_head

*subtract_head_difference:
	swap
	- // subtract difference from offet

*end_calc_new_head:
	itob // convert to bytes
	extract 6 2 // convert to uint16
	load 255 // full array
	swap
	frame_dig -1 // offset
	swap
	replace3 // update offset
	store 255 // full array
	retsub

*get_length_difference:
	load 252 // new element
	len // length of new element
	load 253 // element length
	<
	bnz *swapped_difference
	load 252 // new element
	len // length of new element
	load 253 // element length
	pushint 1
	store 249 // subtract head difference
	b *get_difference

*swapped_difference:
	load 253 // element length
	load 252 // new element
	len // length of new element
	pushint 0
	store 249 // subtract head difference

*get_difference:
	- // get length difference
	store 250 // length difference
	retsub", + "approval": "#pragma version 10
intcblock 2
bytecblock 0x00010005 0x00010006 0x00010007 0x

// This TEAL was generated by TEALScript v0.105.0
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// shortenDynamicElementInTuple()(uint16[],uint16[],uint16[])
*abi_route_shortenDynamicElementInTuple:
	// The ABI return prefix
	pushbytes 0x151f7c75

	// execute shortenDynamicElementInTuple()(uint16[],uint16[],uint16[])
	callsub shortenDynamicElementInTuple
	concat
	log
	pushint 1
	return

// shortenDynamicElementInTuple(): [uint16[], uint16[], uint16[]]
shortenDynamicElementInTuple:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/abi.algo.ts:586
	// a: [uint16[], uint16[], uint16[]] = [
	//       [1, 2],
	//       [2, 3],
	//       [3, 4],
	//     ]
	byte 0x // initial head
	byte 0x // initial tail
	pushbytes 0x0006 // initial head offset
	pushbytes 0x000200010002
	callsub *process_dynamic_tuple_element
	pushbytes 0x000200020003
	callsub *process_dynamic_tuple_element
	pushbytes 0x000200030004
	callsub *process_dynamic_tuple_element
	pop // pop head offset
	concat // concat head and tail
	frame_bury 0 // a: [uint16[], uint16[], uint16[]]

	// tests/contracts/abi.algo.ts:592
	// a[0] = [5]
	frame_dig 0 // a: [uint16[], uint16[], uint16[]]
	store 255 // full array
	pushint 0
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 2 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x00010005
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 250 // length difference
	load 251 // element head offset
	int 2
	+ // head ofset
	callsub *update_dynamic_head
	load 250 // length difference
	load 251 // element head offset
	pushint 4
	+ // head ofset
	callsub *update_dynamic_head
	load 255 // full array
	frame_bury 0 // a: [uint16[], uint16[], uint16[]]

	// tests/contracts/abi.algo.ts:593
	// a[1] = [6]
	frame_dig 0 // a: [uint16[], uint16[], uint16[]]
	store 255 // full array
	int 2
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 2 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x00010006
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 250 // length difference
	load 251 // element head offset
	int 2
	+ // head ofset
	callsub *update_dynamic_head
	load 255 // full array
	frame_bury 0 // a: [uint16[], uint16[], uint16[]]

	// tests/contracts/abi.algo.ts:594
	// a[2] = [7]
	frame_dig 0 // a: [uint16[], uint16[], uint16[]]
	store 255 // full array
	pushint 4
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 2 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x00010007
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 255 // full array
	frame_bury 0 // a: [uint16[], uint16[], uint16[]]

	// tests/contracts/abi.algo.ts:596
	// return a;
	frame_dig 0 // a: [uint16[], uint16[], uint16[]]

	// set the subroutine return value
	frame_bury 0
	retsub

*abi_route_createApplication:
	pushint 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0xa7dbad86 // method "shortenDynamicElementInTuple()(uint16[],uint16[],uint16[])"
	txna ApplicationArgs 0
	match *abi_route_shortenDynamicElementInTuple

	// this contract does not implement the given ABI method for call NoOp
	err

*process_dynamic_tuple_element:
	proto 4 3
	frame_dig -4 // tuple head
	frame_dig -2 // head offset
	concat
	frame_bury -4 // tuple head
	frame_dig -1 // element
	dup
	len
	frame_dig -2 // head offset
	btoi
	+
	itob
	extract 6 2
	frame_bury -2 // head offset
	frame_dig -3 // tuple tail
	swap
	concat
	frame_bury -3 // tuple tail
	frame_dig -4 // tuple head
	frame_dig -3 // tuple tail
	frame_dig -2 // head offset
	retsub

*update_dynamic_head:
	proto 2 0
	frame_dig -2 // length difference
	load 255 // full array
	frame_dig -1 // dynamic array offset
	extract_uint16 // extract dynamic array offset
	load 249 // subtract head difference
	bz *subtract_head_difference
	+ // add difference to offset
	b *end_calc_new_head

*subtract_head_difference:
	swap
	- // subtract difference from offet

*end_calc_new_head:
	itob // convert to bytes
	extract 6 2 // convert to uint16
	load 255 // full array
	swap
	frame_dig -1 // offset
	swap
	replace3 // update offset
	store 255 // full array
	retsub

*get_length_difference:
	load 252 // new element
	len // length of new element
	load 253 // element length
	<
	bnz *swapped_difference
	load 252 // new element
	len // length of new element
	load 253 // element length
	pushint 1
	store 249 // subtract head difference
	b *get_difference

*swapped_difference:
	load 253 // element length
	load 252 // new element
	len // length of new element
	pushint 0
	store 249 // subtract head difference

*get_difference:
	- // get length difference
	store 250 // length difference
	retsub", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestSimpleTuple.approval.teal b/tests/contracts/artifacts/ABITestSimpleTuple.approval.teal index 3f8075fda..4d1d823e2 100644 --- a/tests/contracts/artifacts/ABITestSimpleTuple.approval.teal +++ b/tests/contracts/artifacts/ABITestSimpleTuple.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestSimpleTuple.arc32.json b/tests/contracts/artifacts/ABITestSimpleTuple.arc32.json index 5f7872c82..35df4550e 100644 --- a/tests/contracts/artifacts/ABITestSimpleTuple.arc32.json +++ b/tests/contracts/artifacts/ABITestSimpleTuple.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc2ltcGxlVHVwbGUoKXVpbnQxNgoqYWJpX3JvdXRlX3NpbXBsZVR1cGxlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgc2ltcGxlVHVwbGUoKXVpbnQxNgoJY2FsbHN1YiBzaW1wbGVUdXBsZQoJaXRvYgoJZHVwCgliaXRsZW4KCXB1c2hpbnQgMTYKCTw9CgoJLy8gc2ltcGxlVHVwbGUgcmV0dXJuIHZhbHVlIG92ZXJmbG93ZWQgMTYgYml0cwoJYXNzZXJ0CglleHRyYWN0IDYgMgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBzaW1wbGVUdXBsZSgpOiB1aW50MTYKc2ltcGxlVHVwbGU6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjI1NwoJLy8gYTogW3VpbnQ2NCwgdWludDE2LCB1aW50NjQsIHVpbnQxNl0gPSBbMTEsIDIyLCAzMywgNDRdCglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDBiMDAxNjAwMDAwMDAwMDAwMDAwMjEwMDJjCglmcmFtZV9idXJ5IDAgLy8gYTogW3VpbnQ2NCwgdWludDE2LCB1aW50NjQsIHVpbnQxNl0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MjU5CgkvLyByZXR1cm4gYVszXTsKCWZyYW1lX2RpZyAwIC8vIGE6IFt1aW50NjQsIHVpbnQxNiwgdWludDY0LCB1aW50MTZdCglleHRyYWN0IDE4IDIKCWJ0b2kKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4NGYwYmFkY2EgLy8gbWV0aG9kICJzaW1wbGVUdXBsZSgpdWludDE2IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9zaW1wbGVUdXBsZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc2ltcGxlVHVwbGUoKXVpbnQxNgoqYWJpX3JvdXRlX3NpbXBsZVR1cGxlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgc2ltcGxlVHVwbGUoKXVpbnQxNgoJY2FsbHN1YiBzaW1wbGVUdXBsZQoJaXRvYgoJZHVwCgliaXRsZW4KCXB1c2hpbnQgMTYKCTw9CgoJLy8gc2ltcGxlVHVwbGUgcmV0dXJuIHZhbHVlIG92ZXJmbG93ZWQgMTYgYml0cwoJYXNzZXJ0CglleHRyYWN0IDYgMgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBzaW1wbGVUdXBsZSgpOiB1aW50MTYKc2ltcGxlVHVwbGU6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjI1NwoJLy8gYTogW3VpbnQ2NCwgdWludDE2LCB1aW50NjQsIHVpbnQxNl0gPSBbMTEsIDIyLCAzMywgNDRdCglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDBiMDAxNjAwMDAwMDAwMDAwMDAwMjEwMDJjCglmcmFtZV9idXJ5IDAgLy8gYTogW3VpbnQ2NCwgdWludDE2LCB1aW50NjQsIHVpbnQxNl0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MjU5CgkvLyByZXR1cm4gYVszXTsKCWZyYW1lX2RpZyAwIC8vIGE6IFt1aW50NjQsIHVpbnQxNiwgdWludDY0LCB1aW50MTZdCglleHRyYWN0IDE4IDIKCWJ0b2kKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4NGYwYmFkY2EgLy8gbWV0aG9kICJzaW1wbGVUdXBsZSgpdWludDE2IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9zaW1wbGVUdXBsZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestSimpleTuple.arc56_draft.json b/tests/contracts/artifacts/ABITestSimpleTuple.arc56_draft.json index 0ed398f25..0e0871995 100644 --- a/tests/contracts/artifacts/ABITestSimpleTuple.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestSimpleTuple.arc56_draft.json @@ -452,7 +452,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc2ltcGxlVHVwbGUoKXVpbnQxNgoqYWJpX3JvdXRlX3NpbXBsZVR1cGxlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgc2ltcGxlVHVwbGUoKXVpbnQxNgoJY2FsbHN1YiBzaW1wbGVUdXBsZQoJaXRvYgoJZHVwCgliaXRsZW4KCXB1c2hpbnQgMTYKCTw9CgoJLy8gc2ltcGxlVHVwbGUgcmV0dXJuIHZhbHVlIG92ZXJmbG93ZWQgMTYgYml0cwoJYXNzZXJ0CglleHRyYWN0IDYgMgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBzaW1wbGVUdXBsZSgpOiB1aW50MTYKc2ltcGxlVHVwbGU6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjI1NwoJLy8gYTogW3VpbnQ2NCwgdWludDE2LCB1aW50NjQsIHVpbnQxNl0gPSBbMTEsIDIyLCAzMywgNDRdCglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDBiMDAxNjAwMDAwMDAwMDAwMDAwMjEwMDJjCglmcmFtZV9idXJ5IDAgLy8gYTogW3VpbnQ2NCwgdWludDE2LCB1aW50NjQsIHVpbnQxNl0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MjU5CgkvLyByZXR1cm4gYVszXTsKCWZyYW1lX2RpZyAwIC8vIGE6IFt1aW50NjQsIHVpbnQxNiwgdWludDY0LCB1aW50MTZdCglleHRyYWN0IDE4IDIKCWJ0b2kKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4NGYwYmFkY2EgLy8gbWV0aG9kICJzaW1wbGVUdXBsZSgpdWludDE2IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9zaW1wbGVUdXBsZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc2ltcGxlVHVwbGUoKXVpbnQxNgoqYWJpX3JvdXRlX3NpbXBsZVR1cGxlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgc2ltcGxlVHVwbGUoKXVpbnQxNgoJY2FsbHN1YiBzaW1wbGVUdXBsZQoJaXRvYgoJZHVwCgliaXRsZW4KCXB1c2hpbnQgMTYKCTw9CgoJLy8gc2ltcGxlVHVwbGUgcmV0dXJuIHZhbHVlIG92ZXJmbG93ZWQgMTYgYml0cwoJYXNzZXJ0CglleHRyYWN0IDYgMgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBzaW1wbGVUdXBsZSgpOiB1aW50MTYKc2ltcGxlVHVwbGU6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjI1NwoJLy8gYTogW3VpbnQ2NCwgdWludDE2LCB1aW50NjQsIHVpbnQxNl0gPSBbMTEsIDIyLCAzMywgNDRdCglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDBiMDAxNjAwMDAwMDAwMDAwMDAwMjEwMDJjCglmcmFtZV9idXJ5IDAgLy8gYTogW3VpbnQ2NCwgdWludDE2LCB1aW50NjQsIHVpbnQxNl0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MjU5CgkvLyByZXR1cm4gYVszXTsKCWZyYW1lX2RpZyAwIC8vIGE6IFt1aW50NjQsIHVpbnQxNiwgdWludDY0LCB1aW50MTZdCglleHRyYWN0IDE4IDIKCWJ0b2kKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4NGYwYmFkY2EgLy8gbWV0aG9kICJzaW1wbGVUdXBsZSgpdWludDE2IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9zaW1wbGVUdXBsZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestSmallerByteCasting.approval.teal b/tests/contracts/artifacts/ABITestSmallerByteCasting.approval.teal index 24e3c1548..4c29bec0b 100644 --- a/tests/contracts/artifacts/ABITestSmallerByteCasting.approval.teal +++ b/tests/contracts/artifacts/ABITestSmallerByteCasting.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestSmallerByteCasting.arc32.json b/tests/contracts/artifacts/ABITestSmallerByteCasting.arc32.json index d389b4d23..17a3278d3 100644 --- a/tests/contracts/artifacts/ABITestSmallerByteCasting.arc32.json +++ b/tests/contracts/artifacts/ABITestSmallerByteCasting.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc21hbGxlckJ5dGVDYXN0aW5nKGJ5dGVbNF0pYnl0ZVsyXQoqYWJpX3JvdXRlX3NtYWxsZXJCeXRlQ2FzdGluZzoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBhOiBieXRlWzRdCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglkdXAKCWxlbgoJcHVzaGludCA0Cgk9PQoKCS8vIGFyZ3VtZW50IDAgKGEpIGZvciBzbWFsbGVyQnl0ZUNhc3RpbmcgbXVzdCBiZSBhIGJ5dGVbNF0KCWFzc2VydAoKCS8vIGV4ZWN1dGUgc21hbGxlckJ5dGVDYXN0aW5nKGJ5dGVbNF0pYnl0ZVsyXQoJY2FsbHN1YiBzbWFsbGVyQnl0ZUNhc3RpbmcKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gc21hbGxlckJ5dGVDYXN0aW5nKGE6IGJ5dGVzPDQ+KTogYnl0ZXM8Mj4Kc21hbGxlckJ5dGVDYXN0aW5nOgoJcHJvdG8gMSAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEyMTMKCS8vIHJldHVybiA8Ynl0ZXM8Mj4+YTsKCWZyYW1lX2RpZyAtMSAvLyBhOiBieXRlczw0PgoJZXh0cmFjdCAwIDIKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YjUzNDBmYTggLy8gbWV0aG9kICJzbWFsbGVyQnl0ZUNhc3RpbmcoYnl0ZVs0XSlieXRlWzJdIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9zbWFsbGVyQnl0ZUNhc3RpbmcKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc21hbGxlckJ5dGVDYXN0aW5nKGJ5dGVbNF0pYnl0ZVsyXQoqYWJpX3JvdXRlX3NtYWxsZXJCeXRlQ2FzdGluZzoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBhOiBieXRlWzRdCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglkdXAKCWxlbgoJcHVzaGludCA0Cgk9PQoKCS8vIGFyZ3VtZW50IDAgKGEpIGZvciBzbWFsbGVyQnl0ZUNhc3RpbmcgbXVzdCBiZSBhIGJ5dGVbNF0KCWFzc2VydAoKCS8vIGV4ZWN1dGUgc21hbGxlckJ5dGVDYXN0aW5nKGJ5dGVbNF0pYnl0ZVsyXQoJY2FsbHN1YiBzbWFsbGVyQnl0ZUNhc3RpbmcKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gc21hbGxlckJ5dGVDYXN0aW5nKGE6IGJ5dGVzPDQ+KTogYnl0ZXM8Mj4Kc21hbGxlckJ5dGVDYXN0aW5nOgoJcHJvdG8gMSAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEyMTMKCS8vIHJldHVybiA8Ynl0ZXM8Mj4+YTsKCWZyYW1lX2RpZyAtMSAvLyBhOiBieXRlczw0PgoJZXh0cmFjdCAwIDIKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YjUzNDBmYTggLy8gbWV0aG9kICJzbWFsbGVyQnl0ZUNhc3RpbmcoYnl0ZVs0XSlieXRlWzJdIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9zbWFsbGVyQnl0ZUNhc3RpbmcKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestSmallerByteCasting.arc56_draft.json b/tests/contracts/artifacts/ABITestSmallerByteCasting.arc56_draft.json index 9ed6d9731..5b53cc87f 100644 --- a/tests/contracts/artifacts/ABITestSmallerByteCasting.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestSmallerByteCasting.arc56_draft.json @@ -391,7 +391,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc21hbGxlckJ5dGVDYXN0aW5nKGJ5dGVbNF0pYnl0ZVsyXQoqYWJpX3JvdXRlX3NtYWxsZXJCeXRlQ2FzdGluZzoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBhOiBieXRlWzRdCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglkdXAKCWxlbgoJcHVzaGludCA0Cgk9PQoKCS8vIGFyZ3VtZW50IDAgKGEpIGZvciBzbWFsbGVyQnl0ZUNhc3RpbmcgbXVzdCBiZSBhIGJ5dGVbNF0KCWFzc2VydAoKCS8vIGV4ZWN1dGUgc21hbGxlckJ5dGVDYXN0aW5nKGJ5dGVbNF0pYnl0ZVsyXQoJY2FsbHN1YiBzbWFsbGVyQnl0ZUNhc3RpbmcKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gc21hbGxlckJ5dGVDYXN0aW5nKGE6IGJ5dGVzPDQ+KTogYnl0ZXM8Mj4Kc21hbGxlckJ5dGVDYXN0aW5nOgoJcHJvdG8gMSAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEyMTMKCS8vIHJldHVybiA8Ynl0ZXM8Mj4+YTsKCWZyYW1lX2RpZyAtMSAvLyBhOiBieXRlczw0PgoJZXh0cmFjdCAwIDIKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YjUzNDBmYTggLy8gbWV0aG9kICJzbWFsbGVyQnl0ZUNhc3RpbmcoYnl0ZVs0XSlieXRlWzJdIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9zbWFsbGVyQnl0ZUNhc3RpbmcKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc21hbGxlckJ5dGVDYXN0aW5nKGJ5dGVbNF0pYnl0ZVsyXQoqYWJpX3JvdXRlX3NtYWxsZXJCeXRlQ2FzdGluZzoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBhOiBieXRlWzRdCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglkdXAKCWxlbgoJcHVzaGludCA0Cgk9PQoKCS8vIGFyZ3VtZW50IDAgKGEpIGZvciBzbWFsbGVyQnl0ZUNhc3RpbmcgbXVzdCBiZSBhIGJ5dGVbNF0KCWFzc2VydAoKCS8vIGV4ZWN1dGUgc21hbGxlckJ5dGVDYXN0aW5nKGJ5dGVbNF0pYnl0ZVsyXQoJY2FsbHN1YiBzbWFsbGVyQnl0ZUNhc3RpbmcKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gc21hbGxlckJ5dGVDYXN0aW5nKGE6IGJ5dGVzPDQ+KTogYnl0ZXM8Mj4Kc21hbGxlckJ5dGVDYXN0aW5nOgoJcHJvdG8gMSAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEyMTMKCS8vIHJldHVybiA8Ynl0ZXM8Mj4+YTsKCWZyYW1lX2RpZyAtMSAvLyBhOiBieXRlczw0PgoJZXh0cmFjdCAwIDIKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YjUzNDBmYTggLy8gbWV0aG9kICJzbWFsbGVyQnl0ZUNhc3RpbmcoYnl0ZVs0XSlieXRlWzJdIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9zbWFsbGVyQnl0ZUNhc3RpbmcKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestSpliceFirstElement.approval.teal b/tests/contracts/artifacts/ABITestSpliceFirstElement.approval.teal index d2f96211a..ddb17f397 100644 --- a/tests/contracts/artifacts/ABITestSpliceFirstElement.approval.teal +++ b/tests/contracts/artifacts/ABITestSpliceFirstElement.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestSpliceFirstElement.arc32.json b/tests/contracts/artifacts/ABITestSpliceFirstElement.arc32.json index 46d7c2ca4..93ae66bcd 100644 --- a/tests/contracts/artifacts/ABITestSpliceFirstElement.arc32.json +++ b/tests/contracts/artifacts/ABITestSpliceFirstElement.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3BsaWNlRmlyc3RFbGVtZW50KCl1aW50MTZbXQoqYWJpX3JvdXRlX3NwbGljZUZpcnN0RWxlbWVudDoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHNwbGljZUZpcnN0RWxlbWVudCgpdWludDE2W10KCWNhbGxzdWIgc3BsaWNlRmlyc3RFbGVtZW50CglkdXAKCWxlbgoJcHVzaGludCAyCgkvCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHNwbGljZUZpcnN0RWxlbWVudCgpOiB1aW50MTZbXQpzcGxpY2VGaXJzdEVsZW1lbnQ6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjUxMAoJLy8gYTogdWludDE2W10gPSBbMSwgMiwgM10KCXB1c2hieXRlcyAweDAwMDEwMDAyMDAwMwoJZnJhbWVfYnVyeSAwIC8vIGE6IHVpbnQxNltdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjUxMgoJLy8gYS5zcGxpY2UoMCwgMSkKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCglwdXNoaW50IDEKCXB1c2hpbnQgMAoJc3RvcmUgMjQ3IC8vIHNwbGljZSBzdGFydAoJcHVzaGludCA0CglzdG9yZSAyNDYgLy8gc3BsaWNlIGJ5dGUgbGVuZ3RoCglmcmFtZV9kaWcgMCAvLyBhOiB1aW50MTZbXQoJcHVzaGludCAwCglsb2FkIDI0NyAvLyBzcGxpY2Ugc3RhcnQKCXN1YnN0cmluZzMKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCglkdXAKCWxlbgoJbG9hZCAyNDcgLy8gc3BsaWNlIHN0YXJ0Cglsb2FkIDI0NiAvLyBzcGxpY2UgYnl0ZSBsZW5ndGgKCSsKCXB1c2hpbnQgMgoJLQoJc3dhcAoJc3Vic3RyaW5nMwoJY29uY2F0CglmcmFtZV9idXJ5IDAgLy8gYTogdWludDE2W10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NTE0CgkvLyByZXR1cm4gYTsKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDkzMmEzM2EzIC8vIG1ldGhvZCAic3BsaWNlRmlyc3RFbGVtZW50KCl1aW50MTZbXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3BsaWNlRmlyc3RFbGVtZW50CgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3BsaWNlRmlyc3RFbGVtZW50KCl1aW50MTZbXQoqYWJpX3JvdXRlX3NwbGljZUZpcnN0RWxlbWVudDoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHNwbGljZUZpcnN0RWxlbWVudCgpdWludDE2W10KCWNhbGxzdWIgc3BsaWNlRmlyc3RFbGVtZW50CglkdXAKCWxlbgoJcHVzaGludCAyCgkvCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHNwbGljZUZpcnN0RWxlbWVudCgpOiB1aW50MTZbXQpzcGxpY2VGaXJzdEVsZW1lbnQ6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjUxMAoJLy8gYTogdWludDE2W10gPSBbMSwgMiwgM10KCXB1c2hieXRlcyAweDAwMDEwMDAyMDAwMwoJZnJhbWVfYnVyeSAwIC8vIGE6IHVpbnQxNltdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjUxMgoJLy8gYS5zcGxpY2UoMCwgMSkKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCglwdXNoaW50IDEKCXB1c2hpbnQgMAoJc3RvcmUgMjQ3IC8vIHNwbGljZSBzdGFydAoJcHVzaGludCA0CglzdG9yZSAyNDYgLy8gc3BsaWNlIGJ5dGUgbGVuZ3RoCglmcmFtZV9kaWcgMCAvLyBhOiB1aW50MTZbXQoJcHVzaGludCAwCglsb2FkIDI0NyAvLyBzcGxpY2Ugc3RhcnQKCXN1YnN0cmluZzMKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCglkdXAKCWxlbgoJbG9hZCAyNDcgLy8gc3BsaWNlIHN0YXJ0Cglsb2FkIDI0NiAvLyBzcGxpY2UgYnl0ZSBsZW5ndGgKCSsKCXB1c2hpbnQgMgoJLQoJc3dhcAoJc3Vic3RyaW5nMwoJY29uY2F0CglmcmFtZV9idXJ5IDAgLy8gYTogdWludDE2W10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NTE0CgkvLyByZXR1cm4gYTsKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDkzMmEzM2EzIC8vIG1ldGhvZCAic3BsaWNlRmlyc3RFbGVtZW50KCl1aW50MTZbXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3BsaWNlRmlyc3RFbGVtZW50CgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestSpliceFirstElement.arc56_draft.json b/tests/contracts/artifacts/ABITestSpliceFirstElement.arc56_draft.json index 4311adb9c..d892ee574 100644 --- a/tests/contracts/artifacts/ABITestSpliceFirstElement.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestSpliceFirstElement.arc56_draft.json @@ -596,7 +596,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3BsaWNlRmlyc3RFbGVtZW50KCl1aW50MTZbXQoqYWJpX3JvdXRlX3NwbGljZUZpcnN0RWxlbWVudDoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHNwbGljZUZpcnN0RWxlbWVudCgpdWludDE2W10KCWNhbGxzdWIgc3BsaWNlRmlyc3RFbGVtZW50CglkdXAKCWxlbgoJcHVzaGludCAyCgkvCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHNwbGljZUZpcnN0RWxlbWVudCgpOiB1aW50MTZbXQpzcGxpY2VGaXJzdEVsZW1lbnQ6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjUxMAoJLy8gYTogdWludDE2W10gPSBbMSwgMiwgM10KCXB1c2hieXRlcyAweDAwMDEwMDAyMDAwMwoJZnJhbWVfYnVyeSAwIC8vIGE6IHVpbnQxNltdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjUxMgoJLy8gYS5zcGxpY2UoMCwgMSkKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCglwdXNoaW50IDEKCXB1c2hpbnQgMAoJc3RvcmUgMjQ3IC8vIHNwbGljZSBzdGFydAoJcHVzaGludCA0CglzdG9yZSAyNDYgLy8gc3BsaWNlIGJ5dGUgbGVuZ3RoCglmcmFtZV9kaWcgMCAvLyBhOiB1aW50MTZbXQoJcHVzaGludCAwCglsb2FkIDI0NyAvLyBzcGxpY2Ugc3RhcnQKCXN1YnN0cmluZzMKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCglkdXAKCWxlbgoJbG9hZCAyNDcgLy8gc3BsaWNlIHN0YXJ0Cglsb2FkIDI0NiAvLyBzcGxpY2UgYnl0ZSBsZW5ndGgKCSsKCXB1c2hpbnQgMgoJLQoJc3dhcAoJc3Vic3RyaW5nMwoJY29uY2F0CglmcmFtZV9idXJ5IDAgLy8gYTogdWludDE2W10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NTE0CgkvLyByZXR1cm4gYTsKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDkzMmEzM2EzIC8vIG1ldGhvZCAic3BsaWNlRmlyc3RFbGVtZW50KCl1aW50MTZbXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3BsaWNlRmlyc3RFbGVtZW50CgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3BsaWNlRmlyc3RFbGVtZW50KCl1aW50MTZbXQoqYWJpX3JvdXRlX3NwbGljZUZpcnN0RWxlbWVudDoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHNwbGljZUZpcnN0RWxlbWVudCgpdWludDE2W10KCWNhbGxzdWIgc3BsaWNlRmlyc3RFbGVtZW50CglkdXAKCWxlbgoJcHVzaGludCAyCgkvCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHNwbGljZUZpcnN0RWxlbWVudCgpOiB1aW50MTZbXQpzcGxpY2VGaXJzdEVsZW1lbnQ6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjUxMAoJLy8gYTogdWludDE2W10gPSBbMSwgMiwgM10KCXB1c2hieXRlcyAweDAwMDEwMDAyMDAwMwoJZnJhbWVfYnVyeSAwIC8vIGE6IHVpbnQxNltdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjUxMgoJLy8gYS5zcGxpY2UoMCwgMSkKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCglwdXNoaW50IDEKCXB1c2hpbnQgMAoJc3RvcmUgMjQ3IC8vIHNwbGljZSBzdGFydAoJcHVzaGludCA0CglzdG9yZSAyNDYgLy8gc3BsaWNlIGJ5dGUgbGVuZ3RoCglmcmFtZV9kaWcgMCAvLyBhOiB1aW50MTZbXQoJcHVzaGludCAwCglsb2FkIDI0NyAvLyBzcGxpY2Ugc3RhcnQKCXN1YnN0cmluZzMKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCglkdXAKCWxlbgoJbG9hZCAyNDcgLy8gc3BsaWNlIHN0YXJ0Cglsb2FkIDI0NiAvLyBzcGxpY2UgYnl0ZSBsZW5ndGgKCSsKCXB1c2hpbnQgMgoJLQoJc3dhcAoJc3Vic3RyaW5nMwoJY29uY2F0CglmcmFtZV9idXJ5IDAgLy8gYTogdWludDE2W10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NTE0CgkvLyByZXR1cm4gYTsKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDkzMmEzM2EzIC8vIG1ldGhvZCAic3BsaWNlRmlyc3RFbGVtZW50KCl1aW50MTZbXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3BsaWNlRmlyc3RFbGVtZW50CgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestSpliceFirstElementValue.approval.teal b/tests/contracts/artifacts/ABITestSpliceFirstElementValue.approval.teal index be5fa29aa..6728a2db5 100644 --- a/tests/contracts/artifacts/ABITestSpliceFirstElementValue.approval.teal +++ b/tests/contracts/artifacts/ABITestSpliceFirstElementValue.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestSpliceFirstElementValue.arc32.json b/tests/contracts/artifacts/ABITestSpliceFirstElementValue.arc32.json index c215827ad..ea1078d8e 100644 --- a/tests/contracts/artifacts/ABITestSpliceFirstElementValue.arc32.json +++ b/tests/contracts/artifacts/ABITestSpliceFirstElementValue.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBzcGxpY2VGaXJzdEVsZW1lbnRWYWx1ZSgpdWludDE2W10KKmFiaV9yb3V0ZV9zcGxpY2VGaXJzdEVsZW1lbnRWYWx1ZToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHNwbGljZUZpcnN0RWxlbWVudFZhbHVlKCl1aW50MTZbXQoJY2FsbHN1YiBzcGxpY2VGaXJzdEVsZW1lbnRWYWx1ZQoJZHVwCglsZW4KCXB1c2hpbnQgMgoJLwoJaXRvYgoJZXh0cmFjdCA2IDIKCXN3YXAKCWNvbmNhdAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBzcGxpY2VGaXJzdEVsZW1lbnRWYWx1ZSgpOiB1aW50MTZbXQpzcGxpY2VGaXJzdEVsZW1lbnRWYWx1ZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NTIwCgkvLyBhOiB1aW50MTZbXSA9IFsxLCAyLCAzXQoJcHVzaGJ5dGVzIDB4MDAwMTAwMDIwMDAzCglmcmFtZV9idXJ5IDAgLy8gYTogdWludDE2W10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NTIyCgkvLyB2ID0gYS5zcGxpY2UoMCwgMSkKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCglwdXNoaW50IDEKCXB1c2hpbnQgMAoJc3RvcmUgMjQ3IC8vIHNwbGljZSBzdGFydAoJcHVzaGludCA0CglzdG9yZSAyNDYgLy8gc3BsaWNlIGJ5dGUgbGVuZ3RoCglmcmFtZV9kaWcgMCAvLyBhOiB1aW50MTZbXQoJcHVzaGludCAwCglsb2FkIDI0NyAvLyBzcGxpY2Ugc3RhcnQKCXN1YnN0cmluZzMKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCglkdXAKCWxlbgoJbG9hZCAyNDcgLy8gc3BsaWNlIHN0YXJ0Cglsb2FkIDI0NiAvLyBzcGxpY2UgYnl0ZSBsZW5ndGgKCSsKCXB1c2hpbnQgMgoJLQoJc3dhcAoJc3Vic3RyaW5nMwoJY29uY2F0CglmcmFtZV9kaWcgMCAvLyBhOiB1aW50MTZbXQoJbG9hZCAyNDcgLy8gc3BsaWNlIHN0YXJ0Cglsb2FkIDI0NiAvLyBzcGxpY2UgYnl0ZSBsZW5ndGgKCXB1c2hpbnQgMgoJLQoJZXh0cmFjdDMKCXN3YXAKCWZyYW1lX2J1cnkgMCAvLyBhOiB1aW50MTZbXQoJZnJhbWVfYnVyeSAxIC8vIHY6IHVpbnQxNltdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjUyNAoJLy8gcmV0dXJuIHY7CglmcmFtZV9kaWcgMSAvLyB2OiB1aW50MTZbXQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoKCS8vIHBvcCBhbGwgbG9jYWwgdmFyaWFibGVzIGZyb20gdGhlIHN0YWNrCglwb3BuIDEKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YmQ4YzdiZDcgLy8gbWV0aG9kICJzcGxpY2VGaXJzdEVsZW1lbnRWYWx1ZSgpdWludDE2W10iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3NwbGljZUZpcnN0RWxlbWVudFZhbHVlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBzcGxpY2VGaXJzdEVsZW1lbnRWYWx1ZSgpdWludDE2W10KKmFiaV9yb3V0ZV9zcGxpY2VGaXJzdEVsZW1lbnRWYWx1ZToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHNwbGljZUZpcnN0RWxlbWVudFZhbHVlKCl1aW50MTZbXQoJY2FsbHN1YiBzcGxpY2VGaXJzdEVsZW1lbnRWYWx1ZQoJZHVwCglsZW4KCXB1c2hpbnQgMgoJLwoJaXRvYgoJZXh0cmFjdCA2IDIKCXN3YXAKCWNvbmNhdAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBzcGxpY2VGaXJzdEVsZW1lbnRWYWx1ZSgpOiB1aW50MTZbXQpzcGxpY2VGaXJzdEVsZW1lbnRWYWx1ZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NTIwCgkvLyBhOiB1aW50MTZbXSA9IFsxLCAyLCAzXQoJcHVzaGJ5dGVzIDB4MDAwMTAwMDIwMDAzCglmcmFtZV9idXJ5IDAgLy8gYTogdWludDE2W10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NTIyCgkvLyB2ID0gYS5zcGxpY2UoMCwgMSkKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCglwdXNoaW50IDEKCXB1c2hpbnQgMAoJc3RvcmUgMjQ3IC8vIHNwbGljZSBzdGFydAoJcHVzaGludCA0CglzdG9yZSAyNDYgLy8gc3BsaWNlIGJ5dGUgbGVuZ3RoCglmcmFtZV9kaWcgMCAvLyBhOiB1aW50MTZbXQoJcHVzaGludCAwCglsb2FkIDI0NyAvLyBzcGxpY2Ugc3RhcnQKCXN1YnN0cmluZzMKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCglkdXAKCWxlbgoJbG9hZCAyNDcgLy8gc3BsaWNlIHN0YXJ0Cglsb2FkIDI0NiAvLyBzcGxpY2UgYnl0ZSBsZW5ndGgKCSsKCXB1c2hpbnQgMgoJLQoJc3dhcAoJc3Vic3RyaW5nMwoJY29uY2F0CglmcmFtZV9kaWcgMCAvLyBhOiB1aW50MTZbXQoJbG9hZCAyNDcgLy8gc3BsaWNlIHN0YXJ0Cglsb2FkIDI0NiAvLyBzcGxpY2UgYnl0ZSBsZW5ndGgKCXB1c2hpbnQgMgoJLQoJZXh0cmFjdDMKCXN3YXAKCWZyYW1lX2J1cnkgMCAvLyBhOiB1aW50MTZbXQoJZnJhbWVfYnVyeSAxIC8vIHY6IHVpbnQxNltdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjUyNAoJLy8gcmV0dXJuIHY7CglmcmFtZV9kaWcgMSAvLyB2OiB1aW50MTZbXQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoKCS8vIHBvcCBhbGwgbG9jYWwgdmFyaWFibGVzIGZyb20gdGhlIHN0YWNrCglwb3BuIDEKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YmQ4YzdiZDcgLy8gbWV0aG9kICJzcGxpY2VGaXJzdEVsZW1lbnRWYWx1ZSgpdWludDE2W10iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3NwbGljZUZpcnN0RWxlbWVudFZhbHVlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestSpliceFirstElementValue.arc56_draft.json b/tests/contracts/artifacts/ABITestSpliceFirstElementValue.arc56_draft.json index 622c4443c..382734874 100644 --- a/tests/contracts/artifacts/ABITestSpliceFirstElementValue.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestSpliceFirstElementValue.arc56_draft.json @@ -681,7 +681,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBzcGxpY2VGaXJzdEVsZW1lbnRWYWx1ZSgpdWludDE2W10KKmFiaV9yb3V0ZV9zcGxpY2VGaXJzdEVsZW1lbnRWYWx1ZToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHNwbGljZUZpcnN0RWxlbWVudFZhbHVlKCl1aW50MTZbXQoJY2FsbHN1YiBzcGxpY2VGaXJzdEVsZW1lbnRWYWx1ZQoJZHVwCglsZW4KCXB1c2hpbnQgMgoJLwoJaXRvYgoJZXh0cmFjdCA2IDIKCXN3YXAKCWNvbmNhdAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBzcGxpY2VGaXJzdEVsZW1lbnRWYWx1ZSgpOiB1aW50MTZbXQpzcGxpY2VGaXJzdEVsZW1lbnRWYWx1ZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NTIwCgkvLyBhOiB1aW50MTZbXSA9IFsxLCAyLCAzXQoJcHVzaGJ5dGVzIDB4MDAwMTAwMDIwMDAzCglmcmFtZV9idXJ5IDAgLy8gYTogdWludDE2W10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NTIyCgkvLyB2ID0gYS5zcGxpY2UoMCwgMSkKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCglwdXNoaW50IDEKCXB1c2hpbnQgMAoJc3RvcmUgMjQ3IC8vIHNwbGljZSBzdGFydAoJcHVzaGludCA0CglzdG9yZSAyNDYgLy8gc3BsaWNlIGJ5dGUgbGVuZ3RoCglmcmFtZV9kaWcgMCAvLyBhOiB1aW50MTZbXQoJcHVzaGludCAwCglsb2FkIDI0NyAvLyBzcGxpY2Ugc3RhcnQKCXN1YnN0cmluZzMKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCglkdXAKCWxlbgoJbG9hZCAyNDcgLy8gc3BsaWNlIHN0YXJ0Cglsb2FkIDI0NiAvLyBzcGxpY2UgYnl0ZSBsZW5ndGgKCSsKCXB1c2hpbnQgMgoJLQoJc3dhcAoJc3Vic3RyaW5nMwoJY29uY2F0CglmcmFtZV9kaWcgMCAvLyBhOiB1aW50MTZbXQoJbG9hZCAyNDcgLy8gc3BsaWNlIHN0YXJ0Cglsb2FkIDI0NiAvLyBzcGxpY2UgYnl0ZSBsZW5ndGgKCXB1c2hpbnQgMgoJLQoJZXh0cmFjdDMKCXN3YXAKCWZyYW1lX2J1cnkgMCAvLyBhOiB1aW50MTZbXQoJZnJhbWVfYnVyeSAxIC8vIHY6IHVpbnQxNltdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjUyNAoJLy8gcmV0dXJuIHY7CglmcmFtZV9kaWcgMSAvLyB2OiB1aW50MTZbXQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoKCS8vIHBvcCBhbGwgbG9jYWwgdmFyaWFibGVzIGZyb20gdGhlIHN0YWNrCglwb3BuIDEKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YmQ4YzdiZDcgLy8gbWV0aG9kICJzcGxpY2VGaXJzdEVsZW1lbnRWYWx1ZSgpdWludDE2W10iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3NwbGljZUZpcnN0RWxlbWVudFZhbHVlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBzcGxpY2VGaXJzdEVsZW1lbnRWYWx1ZSgpdWludDE2W10KKmFiaV9yb3V0ZV9zcGxpY2VGaXJzdEVsZW1lbnRWYWx1ZToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHNwbGljZUZpcnN0RWxlbWVudFZhbHVlKCl1aW50MTZbXQoJY2FsbHN1YiBzcGxpY2VGaXJzdEVsZW1lbnRWYWx1ZQoJZHVwCglsZW4KCXB1c2hpbnQgMgoJLwoJaXRvYgoJZXh0cmFjdCA2IDIKCXN3YXAKCWNvbmNhdAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBzcGxpY2VGaXJzdEVsZW1lbnRWYWx1ZSgpOiB1aW50MTZbXQpzcGxpY2VGaXJzdEVsZW1lbnRWYWx1ZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NTIwCgkvLyBhOiB1aW50MTZbXSA9IFsxLCAyLCAzXQoJcHVzaGJ5dGVzIDB4MDAwMTAwMDIwMDAzCglmcmFtZV9idXJ5IDAgLy8gYTogdWludDE2W10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NTIyCgkvLyB2ID0gYS5zcGxpY2UoMCwgMSkKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCglwdXNoaW50IDEKCXB1c2hpbnQgMAoJc3RvcmUgMjQ3IC8vIHNwbGljZSBzdGFydAoJcHVzaGludCA0CglzdG9yZSAyNDYgLy8gc3BsaWNlIGJ5dGUgbGVuZ3RoCglmcmFtZV9kaWcgMCAvLyBhOiB1aW50MTZbXQoJcHVzaGludCAwCglsb2FkIDI0NyAvLyBzcGxpY2Ugc3RhcnQKCXN1YnN0cmluZzMKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCglkdXAKCWxlbgoJbG9hZCAyNDcgLy8gc3BsaWNlIHN0YXJ0Cglsb2FkIDI0NiAvLyBzcGxpY2UgYnl0ZSBsZW5ndGgKCSsKCXB1c2hpbnQgMgoJLQoJc3dhcAoJc3Vic3RyaW5nMwoJY29uY2F0CglmcmFtZV9kaWcgMCAvLyBhOiB1aW50MTZbXQoJbG9hZCAyNDcgLy8gc3BsaWNlIHN0YXJ0Cglsb2FkIDI0NiAvLyBzcGxpY2UgYnl0ZSBsZW5ndGgKCXB1c2hpbnQgMgoJLQoJZXh0cmFjdDMKCXN3YXAKCWZyYW1lX2J1cnkgMCAvLyBhOiB1aW50MTZbXQoJZnJhbWVfYnVyeSAxIC8vIHY6IHVpbnQxNltdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjUyNAoJLy8gcmV0dXJuIHY7CglmcmFtZV9kaWcgMSAvLyB2OiB1aW50MTZbXQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoKCS8vIHBvcCBhbGwgbG9jYWwgdmFyaWFibGVzIGZyb20gdGhlIHN0YWNrCglwb3BuIDEKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YmQ4YzdiZDcgLy8gbWV0aG9kICJzcGxpY2VGaXJzdEVsZW1lbnRWYWx1ZSgpdWludDE2W10iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3NwbGljZUZpcnN0RWxlbWVudFZhbHVlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestSpliceLastElement.approval.teal b/tests/contracts/artifacts/ABITestSpliceLastElement.approval.teal index 69c63ff45..4e399a91e 100644 --- a/tests/contracts/artifacts/ABITestSpliceLastElement.approval.teal +++ b/tests/contracts/artifacts/ABITestSpliceLastElement.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestSpliceLastElement.arc32.json b/tests/contracts/artifacts/ABITestSpliceLastElement.arc32.json index 228017476..07a56f96f 100644 --- a/tests/contracts/artifacts/ABITestSpliceLastElement.arc32.json +++ b/tests/contracts/artifacts/ABITestSpliceLastElement.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3BsaWNlTGFzdEVsZW1lbnQoKXVpbnQxNltdCiphYmlfcm91dGVfc3BsaWNlTGFzdEVsZW1lbnQ6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBzcGxpY2VMYXN0RWxlbWVudCgpdWludDE2W10KCWNhbGxzdWIgc3BsaWNlTGFzdEVsZW1lbnQKCWR1cAoJbGVuCglwdXNoaW50IDIKCS8KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gc3BsaWNlTGFzdEVsZW1lbnQoKTogdWludDE2W10Kc3BsaWNlTGFzdEVsZW1lbnQ6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQ5MAoJLy8gYTogdWludDE2W10gPSBbMSwgMiwgM10KCXB1c2hieXRlcyAweDAwMDEwMDAyMDAwMwoJZnJhbWVfYnVyeSAwIC8vIGE6IHVpbnQxNltdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQ5MgoJLy8gYS5zcGxpY2UoMiwgMSkKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCglwdXNoaW50IDEKCXB1c2hpbnQgNAoJc3RvcmUgMjQ3IC8vIHNwbGljZSBzdGFydAoJcHVzaGludCA0CglzdG9yZSAyNDYgLy8gc3BsaWNlIGJ5dGUgbGVuZ3RoCglmcmFtZV9kaWcgMCAvLyBhOiB1aW50MTZbXQoJcHVzaGludCAwCglsb2FkIDI0NyAvLyBzcGxpY2Ugc3RhcnQKCXN1YnN0cmluZzMKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCglkdXAKCWxlbgoJbG9hZCAyNDcgLy8gc3BsaWNlIHN0YXJ0Cglsb2FkIDI0NiAvLyBzcGxpY2UgYnl0ZSBsZW5ndGgKCSsKCXB1c2hpbnQgMgoJLQoJc3dhcAoJc3Vic3RyaW5nMwoJY29uY2F0CglmcmFtZV9idXJ5IDAgLy8gYTogdWludDE2W10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NDk0CgkvLyByZXR1cm4gYTsKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDgwZWQ0ZmI1IC8vIG1ldGhvZCAic3BsaWNlTGFzdEVsZW1lbnQoKXVpbnQxNltdIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9zcGxpY2VMYXN0RWxlbWVudAoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3BsaWNlTGFzdEVsZW1lbnQoKXVpbnQxNltdCiphYmlfcm91dGVfc3BsaWNlTGFzdEVsZW1lbnQ6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBzcGxpY2VMYXN0RWxlbWVudCgpdWludDE2W10KCWNhbGxzdWIgc3BsaWNlTGFzdEVsZW1lbnQKCWR1cAoJbGVuCglwdXNoaW50IDIKCS8KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gc3BsaWNlTGFzdEVsZW1lbnQoKTogdWludDE2W10Kc3BsaWNlTGFzdEVsZW1lbnQ6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQ5MAoJLy8gYTogdWludDE2W10gPSBbMSwgMiwgM10KCXB1c2hieXRlcyAweDAwMDEwMDAyMDAwMwoJZnJhbWVfYnVyeSAwIC8vIGE6IHVpbnQxNltdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQ5MgoJLy8gYS5zcGxpY2UoMiwgMSkKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCglwdXNoaW50IDEKCXB1c2hpbnQgNAoJc3RvcmUgMjQ3IC8vIHNwbGljZSBzdGFydAoJcHVzaGludCA0CglzdG9yZSAyNDYgLy8gc3BsaWNlIGJ5dGUgbGVuZ3RoCglmcmFtZV9kaWcgMCAvLyBhOiB1aW50MTZbXQoJcHVzaGludCAwCglsb2FkIDI0NyAvLyBzcGxpY2Ugc3RhcnQKCXN1YnN0cmluZzMKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCglkdXAKCWxlbgoJbG9hZCAyNDcgLy8gc3BsaWNlIHN0YXJ0Cglsb2FkIDI0NiAvLyBzcGxpY2UgYnl0ZSBsZW5ndGgKCSsKCXB1c2hpbnQgMgoJLQoJc3dhcAoJc3Vic3RyaW5nMwoJY29uY2F0CglmcmFtZV9idXJ5IDAgLy8gYTogdWludDE2W10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NDk0CgkvLyByZXR1cm4gYTsKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDgwZWQ0ZmI1IC8vIG1ldGhvZCAic3BsaWNlTGFzdEVsZW1lbnQoKXVpbnQxNltdIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9zcGxpY2VMYXN0RWxlbWVudAoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestSpliceLastElement.arc56_draft.json b/tests/contracts/artifacts/ABITestSpliceLastElement.arc56_draft.json index 900fd4d33..22b6a9a75 100644 --- a/tests/contracts/artifacts/ABITestSpliceLastElement.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestSpliceLastElement.arc56_draft.json @@ -596,7 +596,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3BsaWNlTGFzdEVsZW1lbnQoKXVpbnQxNltdCiphYmlfcm91dGVfc3BsaWNlTGFzdEVsZW1lbnQ6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBzcGxpY2VMYXN0RWxlbWVudCgpdWludDE2W10KCWNhbGxzdWIgc3BsaWNlTGFzdEVsZW1lbnQKCWR1cAoJbGVuCglwdXNoaW50IDIKCS8KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gc3BsaWNlTGFzdEVsZW1lbnQoKTogdWludDE2W10Kc3BsaWNlTGFzdEVsZW1lbnQ6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQ5MAoJLy8gYTogdWludDE2W10gPSBbMSwgMiwgM10KCXB1c2hieXRlcyAweDAwMDEwMDAyMDAwMwoJZnJhbWVfYnVyeSAwIC8vIGE6IHVpbnQxNltdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQ5MgoJLy8gYS5zcGxpY2UoMiwgMSkKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCglwdXNoaW50IDEKCXB1c2hpbnQgNAoJc3RvcmUgMjQ3IC8vIHNwbGljZSBzdGFydAoJcHVzaGludCA0CglzdG9yZSAyNDYgLy8gc3BsaWNlIGJ5dGUgbGVuZ3RoCglmcmFtZV9kaWcgMCAvLyBhOiB1aW50MTZbXQoJcHVzaGludCAwCglsb2FkIDI0NyAvLyBzcGxpY2Ugc3RhcnQKCXN1YnN0cmluZzMKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCglkdXAKCWxlbgoJbG9hZCAyNDcgLy8gc3BsaWNlIHN0YXJ0Cglsb2FkIDI0NiAvLyBzcGxpY2UgYnl0ZSBsZW5ndGgKCSsKCXB1c2hpbnQgMgoJLQoJc3dhcAoJc3Vic3RyaW5nMwoJY29uY2F0CglmcmFtZV9idXJ5IDAgLy8gYTogdWludDE2W10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NDk0CgkvLyByZXR1cm4gYTsKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDgwZWQ0ZmI1IC8vIG1ldGhvZCAic3BsaWNlTGFzdEVsZW1lbnQoKXVpbnQxNltdIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9zcGxpY2VMYXN0RWxlbWVudAoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3BsaWNlTGFzdEVsZW1lbnQoKXVpbnQxNltdCiphYmlfcm91dGVfc3BsaWNlTGFzdEVsZW1lbnQ6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBzcGxpY2VMYXN0RWxlbWVudCgpdWludDE2W10KCWNhbGxzdWIgc3BsaWNlTGFzdEVsZW1lbnQKCWR1cAoJbGVuCglwdXNoaW50IDIKCS8KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gc3BsaWNlTGFzdEVsZW1lbnQoKTogdWludDE2W10Kc3BsaWNlTGFzdEVsZW1lbnQ6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQ5MAoJLy8gYTogdWludDE2W10gPSBbMSwgMiwgM10KCXB1c2hieXRlcyAweDAwMDEwMDAyMDAwMwoJZnJhbWVfYnVyeSAwIC8vIGE6IHVpbnQxNltdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjQ5MgoJLy8gYS5zcGxpY2UoMiwgMSkKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCglwdXNoaW50IDEKCXB1c2hpbnQgNAoJc3RvcmUgMjQ3IC8vIHNwbGljZSBzdGFydAoJcHVzaGludCA0CglzdG9yZSAyNDYgLy8gc3BsaWNlIGJ5dGUgbGVuZ3RoCglmcmFtZV9kaWcgMCAvLyBhOiB1aW50MTZbXQoJcHVzaGludCAwCglsb2FkIDI0NyAvLyBzcGxpY2Ugc3RhcnQKCXN1YnN0cmluZzMKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCglkdXAKCWxlbgoJbG9hZCAyNDcgLy8gc3BsaWNlIHN0YXJ0Cglsb2FkIDI0NiAvLyBzcGxpY2UgYnl0ZSBsZW5ndGgKCSsKCXB1c2hpbnQgMgoJLQoJc3dhcAoJc3Vic3RyaW5nMwoJY29uY2F0CglmcmFtZV9idXJ5IDAgLy8gYTogdWludDE2W10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NDk0CgkvLyByZXR1cm4gYTsKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDgwZWQ0ZmI1IC8vIG1ldGhvZCAic3BsaWNlTGFzdEVsZW1lbnQoKXVpbnQxNltdIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9zcGxpY2VMYXN0RWxlbWVudAoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestSpliceLastElementValue.approval.teal b/tests/contracts/artifacts/ABITestSpliceLastElementValue.approval.teal index cc78c7373..e762c303d 100644 --- a/tests/contracts/artifacts/ABITestSpliceLastElementValue.approval.teal +++ b/tests/contracts/artifacts/ABITestSpliceLastElementValue.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestSpliceLastElementValue.arc32.json b/tests/contracts/artifacts/ABITestSpliceLastElementValue.arc32.json index 6345a853e..6d50ee8e2 100644 --- a/tests/contracts/artifacts/ABITestSpliceLastElementValue.arc32.json +++ b/tests/contracts/artifacts/ABITestSpliceLastElementValue.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBzcGxpY2VMYXN0RWxlbWVudFZhbHVlKCl1aW50MTZbXQoqYWJpX3JvdXRlX3NwbGljZUxhc3RFbGVtZW50VmFsdWU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBzcGxpY2VMYXN0RWxlbWVudFZhbHVlKCl1aW50MTZbXQoJY2FsbHN1YiBzcGxpY2VMYXN0RWxlbWVudFZhbHVlCglkdXAKCWxlbgoJcHVzaGludCAyCgkvCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHNwbGljZUxhc3RFbGVtZW50VmFsdWUoKTogdWludDE2W10Kc3BsaWNlTGFzdEVsZW1lbnRWYWx1ZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NTAwCgkvLyBhOiB1aW50MTZbXSA9IFsxLCAyLCAzXQoJcHVzaGJ5dGVzIDB4MDAwMTAwMDIwMDAzCglmcmFtZV9idXJ5IDAgLy8gYTogdWludDE2W10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NTAyCgkvLyB2ID0gYS5zcGxpY2UoMiwgMSkKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCglwdXNoaW50IDEKCXB1c2hpbnQgNAoJc3RvcmUgMjQ3IC8vIHNwbGljZSBzdGFydAoJcHVzaGludCA0CglzdG9yZSAyNDYgLy8gc3BsaWNlIGJ5dGUgbGVuZ3RoCglmcmFtZV9kaWcgMCAvLyBhOiB1aW50MTZbXQoJcHVzaGludCAwCglsb2FkIDI0NyAvLyBzcGxpY2Ugc3RhcnQKCXN1YnN0cmluZzMKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCglkdXAKCWxlbgoJbG9hZCAyNDcgLy8gc3BsaWNlIHN0YXJ0Cglsb2FkIDI0NiAvLyBzcGxpY2UgYnl0ZSBsZW5ndGgKCSsKCXB1c2hpbnQgMgoJLQoJc3dhcAoJc3Vic3RyaW5nMwoJY29uY2F0CglmcmFtZV9kaWcgMCAvLyBhOiB1aW50MTZbXQoJbG9hZCAyNDcgLy8gc3BsaWNlIHN0YXJ0Cglsb2FkIDI0NiAvLyBzcGxpY2UgYnl0ZSBsZW5ndGgKCXB1c2hpbnQgMgoJLQoJZXh0cmFjdDMKCXN3YXAKCWZyYW1lX2J1cnkgMCAvLyBhOiB1aW50MTZbXQoJZnJhbWVfYnVyeSAxIC8vIHY6IHVpbnQxNltdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjUwNAoJLy8gcmV0dXJuIHY7CglmcmFtZV9kaWcgMSAvLyB2OiB1aW50MTZbXQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoKCS8vIHBvcCBhbGwgbG9jYWwgdmFyaWFibGVzIGZyb20gdGhlIHN0YWNrCglwb3BuIDEKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4Y2RkZjIyOGMgLy8gbWV0aG9kICJzcGxpY2VMYXN0RWxlbWVudFZhbHVlKCl1aW50MTZbXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3BsaWNlTGFzdEVsZW1lbnRWYWx1ZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBzcGxpY2VMYXN0RWxlbWVudFZhbHVlKCl1aW50MTZbXQoqYWJpX3JvdXRlX3NwbGljZUxhc3RFbGVtZW50VmFsdWU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBzcGxpY2VMYXN0RWxlbWVudFZhbHVlKCl1aW50MTZbXQoJY2FsbHN1YiBzcGxpY2VMYXN0RWxlbWVudFZhbHVlCglkdXAKCWxlbgoJcHVzaGludCAyCgkvCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHNwbGljZUxhc3RFbGVtZW50VmFsdWUoKTogdWludDE2W10Kc3BsaWNlTGFzdEVsZW1lbnRWYWx1ZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NTAwCgkvLyBhOiB1aW50MTZbXSA9IFsxLCAyLCAzXQoJcHVzaGJ5dGVzIDB4MDAwMTAwMDIwMDAzCglmcmFtZV9idXJ5IDAgLy8gYTogdWludDE2W10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NTAyCgkvLyB2ID0gYS5zcGxpY2UoMiwgMSkKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCglwdXNoaW50IDEKCXB1c2hpbnQgNAoJc3RvcmUgMjQ3IC8vIHNwbGljZSBzdGFydAoJcHVzaGludCA0CglzdG9yZSAyNDYgLy8gc3BsaWNlIGJ5dGUgbGVuZ3RoCglmcmFtZV9kaWcgMCAvLyBhOiB1aW50MTZbXQoJcHVzaGludCAwCglsb2FkIDI0NyAvLyBzcGxpY2Ugc3RhcnQKCXN1YnN0cmluZzMKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCglkdXAKCWxlbgoJbG9hZCAyNDcgLy8gc3BsaWNlIHN0YXJ0Cglsb2FkIDI0NiAvLyBzcGxpY2UgYnl0ZSBsZW5ndGgKCSsKCXB1c2hpbnQgMgoJLQoJc3dhcAoJc3Vic3RyaW5nMwoJY29uY2F0CglmcmFtZV9kaWcgMCAvLyBhOiB1aW50MTZbXQoJbG9hZCAyNDcgLy8gc3BsaWNlIHN0YXJ0Cglsb2FkIDI0NiAvLyBzcGxpY2UgYnl0ZSBsZW5ndGgKCXB1c2hpbnQgMgoJLQoJZXh0cmFjdDMKCXN3YXAKCWZyYW1lX2J1cnkgMCAvLyBhOiB1aW50MTZbXQoJZnJhbWVfYnVyeSAxIC8vIHY6IHVpbnQxNltdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjUwNAoJLy8gcmV0dXJuIHY7CglmcmFtZV9kaWcgMSAvLyB2OiB1aW50MTZbXQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoKCS8vIHBvcCBhbGwgbG9jYWwgdmFyaWFibGVzIGZyb20gdGhlIHN0YWNrCglwb3BuIDEKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4Y2RkZjIyOGMgLy8gbWV0aG9kICJzcGxpY2VMYXN0RWxlbWVudFZhbHVlKCl1aW50MTZbXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3BsaWNlTGFzdEVsZW1lbnRWYWx1ZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestSpliceLastElementValue.arc56_draft.json b/tests/contracts/artifacts/ABITestSpliceLastElementValue.arc56_draft.json index 0e98cbfeb..8ebe817dd 100644 --- a/tests/contracts/artifacts/ABITestSpliceLastElementValue.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestSpliceLastElementValue.arc56_draft.json @@ -681,7 +681,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBzcGxpY2VMYXN0RWxlbWVudFZhbHVlKCl1aW50MTZbXQoqYWJpX3JvdXRlX3NwbGljZUxhc3RFbGVtZW50VmFsdWU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBzcGxpY2VMYXN0RWxlbWVudFZhbHVlKCl1aW50MTZbXQoJY2FsbHN1YiBzcGxpY2VMYXN0RWxlbWVudFZhbHVlCglkdXAKCWxlbgoJcHVzaGludCAyCgkvCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHNwbGljZUxhc3RFbGVtZW50VmFsdWUoKTogdWludDE2W10Kc3BsaWNlTGFzdEVsZW1lbnRWYWx1ZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NTAwCgkvLyBhOiB1aW50MTZbXSA9IFsxLCAyLCAzXQoJcHVzaGJ5dGVzIDB4MDAwMTAwMDIwMDAzCglmcmFtZV9idXJ5IDAgLy8gYTogdWludDE2W10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NTAyCgkvLyB2ID0gYS5zcGxpY2UoMiwgMSkKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCglwdXNoaW50IDEKCXB1c2hpbnQgNAoJc3RvcmUgMjQ3IC8vIHNwbGljZSBzdGFydAoJcHVzaGludCA0CglzdG9yZSAyNDYgLy8gc3BsaWNlIGJ5dGUgbGVuZ3RoCglmcmFtZV9kaWcgMCAvLyBhOiB1aW50MTZbXQoJcHVzaGludCAwCglsb2FkIDI0NyAvLyBzcGxpY2Ugc3RhcnQKCXN1YnN0cmluZzMKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCglkdXAKCWxlbgoJbG9hZCAyNDcgLy8gc3BsaWNlIHN0YXJ0Cglsb2FkIDI0NiAvLyBzcGxpY2UgYnl0ZSBsZW5ndGgKCSsKCXB1c2hpbnQgMgoJLQoJc3dhcAoJc3Vic3RyaW5nMwoJY29uY2F0CglmcmFtZV9kaWcgMCAvLyBhOiB1aW50MTZbXQoJbG9hZCAyNDcgLy8gc3BsaWNlIHN0YXJ0Cglsb2FkIDI0NiAvLyBzcGxpY2UgYnl0ZSBsZW5ndGgKCXB1c2hpbnQgMgoJLQoJZXh0cmFjdDMKCXN3YXAKCWZyYW1lX2J1cnkgMCAvLyBhOiB1aW50MTZbXQoJZnJhbWVfYnVyeSAxIC8vIHY6IHVpbnQxNltdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjUwNAoJLy8gcmV0dXJuIHY7CglmcmFtZV9kaWcgMSAvLyB2OiB1aW50MTZbXQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoKCS8vIHBvcCBhbGwgbG9jYWwgdmFyaWFibGVzIGZyb20gdGhlIHN0YWNrCglwb3BuIDEKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4Y2RkZjIyOGMgLy8gbWV0aG9kICJzcGxpY2VMYXN0RWxlbWVudFZhbHVlKCl1aW50MTZbXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3BsaWNlTGFzdEVsZW1lbnRWYWx1ZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBzcGxpY2VMYXN0RWxlbWVudFZhbHVlKCl1aW50MTZbXQoqYWJpX3JvdXRlX3NwbGljZUxhc3RFbGVtZW50VmFsdWU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBzcGxpY2VMYXN0RWxlbWVudFZhbHVlKCl1aW50MTZbXQoJY2FsbHN1YiBzcGxpY2VMYXN0RWxlbWVudFZhbHVlCglkdXAKCWxlbgoJcHVzaGludCAyCgkvCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHNwbGljZUxhc3RFbGVtZW50VmFsdWUoKTogdWludDE2W10Kc3BsaWNlTGFzdEVsZW1lbnRWYWx1ZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NTAwCgkvLyBhOiB1aW50MTZbXSA9IFsxLCAyLCAzXQoJcHVzaGJ5dGVzIDB4MDAwMTAwMDIwMDAzCglmcmFtZV9idXJ5IDAgLy8gYTogdWludDE2W10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NTAyCgkvLyB2ID0gYS5zcGxpY2UoMiwgMSkKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCglwdXNoaW50IDEKCXB1c2hpbnQgNAoJc3RvcmUgMjQ3IC8vIHNwbGljZSBzdGFydAoJcHVzaGludCA0CglzdG9yZSAyNDYgLy8gc3BsaWNlIGJ5dGUgbGVuZ3RoCglmcmFtZV9kaWcgMCAvLyBhOiB1aW50MTZbXQoJcHVzaGludCAwCglsb2FkIDI0NyAvLyBzcGxpY2Ugc3RhcnQKCXN1YnN0cmluZzMKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQxNltdCglkdXAKCWxlbgoJbG9hZCAyNDcgLy8gc3BsaWNlIHN0YXJ0Cglsb2FkIDI0NiAvLyBzcGxpY2UgYnl0ZSBsZW5ndGgKCSsKCXB1c2hpbnQgMgoJLQoJc3dhcAoJc3Vic3RyaW5nMwoJY29uY2F0CglmcmFtZV9kaWcgMCAvLyBhOiB1aW50MTZbXQoJbG9hZCAyNDcgLy8gc3BsaWNlIHN0YXJ0Cglsb2FkIDI0NiAvLyBzcGxpY2UgYnl0ZSBsZW5ndGgKCXB1c2hpbnQgMgoJLQoJZXh0cmFjdDMKCXN3YXAKCWZyYW1lX2J1cnkgMCAvLyBhOiB1aW50MTZbXQoJZnJhbWVfYnVyeSAxIC8vIHY6IHVpbnQxNltdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjUwNAoJLy8gcmV0dXJuIHY7CglmcmFtZV9kaWcgMSAvLyB2OiB1aW50MTZbXQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoKCS8vIHBvcCBhbGwgbG9jYWwgdmFyaWFibGVzIGZyb20gdGhlIHN0YWNrCglwb3BuIDEKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4Y2RkZjIyOGMgLy8gbWV0aG9kICJzcGxpY2VMYXN0RWxlbWVudFZhbHVlKCl1aW50MTZbXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3BsaWNlTGFzdEVsZW1lbnRWYWx1ZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestStaticArray.approval.teal b/tests/contracts/artifacts/ABITestStaticArray.approval.teal index efa536de2..c4eadbe6c 100644 --- a/tests/contracts/artifacts/ABITestStaticArray.approval.teal +++ b/tests/contracts/artifacts/ABITestStaticArray.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestStaticArray.arc32.json b/tests/contracts/artifacts/ABITestStaticArray.arc32.json index ae90c6c57..4101b3331 100644 --- a/tests/contracts/artifacts/ABITestStaticArray.arc32.json +++ b/tests/contracts/artifacts/ABITestStaticArray.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RhdGljQXJyYXkoKXVpbnQ2NAoqYWJpX3JvdXRlX3N0YXRpY0FycmF5OgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgc3RhdGljQXJyYXkoKXVpbnQ2NAoJY2FsbHN1YiBzdGF0aWNBcnJheQoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBzdGF0aWNBcnJheSgpOiB1aW50NjQKc3RhdGljQXJyYXk6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjExCgkvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+ID0gWzExLCAyMiwgMzNdCglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDBiMDAwMDAwMDAwMDAwMDAxNjAwMDAwMDAwMDAwMDAwMjEKCWZyYW1lX2J1cnkgMCAvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzCgkvLyByZXR1cm4gYVsxXTsKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCWV4dHJhY3QgOCA4CglidG9pCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGVmMzJkZjE5IC8vIG1ldGhvZCAic3RhdGljQXJyYXkoKXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RhdGljQXJyYXkKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RhdGljQXJyYXkoKXVpbnQ2NAoqYWJpX3JvdXRlX3N0YXRpY0FycmF5OgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgc3RhdGljQXJyYXkoKXVpbnQ2NAoJY2FsbHN1YiBzdGF0aWNBcnJheQoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBzdGF0aWNBcnJheSgpOiB1aW50NjQKc3RhdGljQXJyYXk6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjExCgkvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+ID0gWzExLCAyMiwgMzNdCglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDBiMDAwMDAwMDAwMDAwMDAxNjAwMDAwMDAwMDAwMDAwMjEKCWZyYW1lX2J1cnkgMCAvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzCgkvLyByZXR1cm4gYVsxXTsKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCWV4dHJhY3QgOCA4CglidG9pCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGVmMzJkZjE5IC8vIG1ldGhvZCAic3RhdGljQXJyYXkoKXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RhdGljQXJyYXkKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestStaticArray.arc56_draft.json b/tests/contracts/artifacts/ABITestStaticArray.arc56_draft.json index 6d9485b53..dea95c4d7 100644 --- a/tests/contracts/artifacts/ABITestStaticArray.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestStaticArray.arc56_draft.json @@ -410,7 +410,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RhdGljQXJyYXkoKXVpbnQ2NAoqYWJpX3JvdXRlX3N0YXRpY0FycmF5OgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgc3RhdGljQXJyYXkoKXVpbnQ2NAoJY2FsbHN1YiBzdGF0aWNBcnJheQoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBzdGF0aWNBcnJheSgpOiB1aW50NjQKc3RhdGljQXJyYXk6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjExCgkvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+ID0gWzExLCAyMiwgMzNdCglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDBiMDAwMDAwMDAwMDAwMDAxNjAwMDAwMDAwMDAwMDAwMjEKCWZyYW1lX2J1cnkgMCAvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzCgkvLyByZXR1cm4gYVsxXTsKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCWV4dHJhY3QgOCA4CglidG9pCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGVmMzJkZjE5IC8vIG1ldGhvZCAic3RhdGljQXJyYXkoKXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RhdGljQXJyYXkKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RhdGljQXJyYXkoKXVpbnQ2NAoqYWJpX3JvdXRlX3N0YXRpY0FycmF5OgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgc3RhdGljQXJyYXkoKXVpbnQ2NAoJY2FsbHN1YiBzdGF0aWNBcnJheQoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBzdGF0aWNBcnJheSgpOiB1aW50NjQKc3RhdGljQXJyYXk6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjExCgkvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+ID0gWzExLCAyMiwgMzNdCglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDBiMDAwMDAwMDAwMDAwMDAxNjAwMDAwMDAwMDAwMDAwMjEKCWZyYW1lX2J1cnkgMCAvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzCgkvLyByZXR1cm4gYVsxXTsKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCWV4dHJhY3QgOCA4CglidG9pCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGVmMzJkZjE5IC8vIG1ldGhvZCAic3RhdGljQXJyYXkoKXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RhdGljQXJyYXkKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestStaticArrayArg.approval.teal b/tests/contracts/artifacts/ABITestStaticArrayArg.approval.teal index 397d4e484..91a07c919 100644 --- a/tests/contracts/artifacts/ABITestStaticArrayArg.approval.teal +++ b/tests/contracts/artifacts/ABITestStaticArrayArg.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestStaticArrayArg.arc32.json b/tests/contracts/artifacts/ABITestStaticArrayArg.arc32.json index 51c9fa7a6..190f2f1c7 100644 --- a/tests/contracts/artifacts/ABITestStaticArrayArg.arc32.json +++ b/tests/contracts/artifacts/ABITestStaticArrayArg.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RhdGljQXJyYXlBcmcodWludDY0WzNdKXVpbnQ2NAoqYWJpX3JvdXRlX3N0YXRpY0FycmF5QXJnOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGE6IHVpbnQ2NFszXQoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJZHVwCglsZW4KCXB1c2hpbnQgMjQKCT09CgoJLy8gYXJndW1lbnQgMCAoYSkgZm9yIHN0YXRpY0FycmF5QXJnIG11c3QgYmUgYSB1aW50NjRbM10KCWFzc2VydAoKCS8vIGV4ZWN1dGUgc3RhdGljQXJyYXlBcmcodWludDY0WzNdKXVpbnQ2NAoJY2FsbHN1YiBzdGF0aWNBcnJheUFyZwoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBzdGF0aWNBcnJheUFyZyhhOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+KTogdWludDY0CnN0YXRpY0FycmF5QXJnOgoJcHJvdG8gMSAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjI3CgkvLyByZXR1cm4gYVsxXTsKCWZyYW1lX2RpZyAtMSAvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CglleHRyYWN0IDggOAoJYnRvaQoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhiOWJhZWM1NiAvLyBtZXRob2QgInN0YXRpY0FycmF5QXJnKHVpbnQ2NFszXSl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3N0YXRpY0FycmF5QXJnCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RhdGljQXJyYXlBcmcodWludDY0WzNdKXVpbnQ2NAoqYWJpX3JvdXRlX3N0YXRpY0FycmF5QXJnOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGE6IHVpbnQ2NFszXQoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJZHVwCglsZW4KCXB1c2hpbnQgMjQKCT09CgoJLy8gYXJndW1lbnQgMCAoYSkgZm9yIHN0YXRpY0FycmF5QXJnIG11c3QgYmUgYSB1aW50NjRbM10KCWFzc2VydAoKCS8vIGV4ZWN1dGUgc3RhdGljQXJyYXlBcmcodWludDY0WzNdKXVpbnQ2NAoJY2FsbHN1YiBzdGF0aWNBcnJheUFyZwoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBzdGF0aWNBcnJheUFyZyhhOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+KTogdWludDY0CnN0YXRpY0FycmF5QXJnOgoJcHJvdG8gMSAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjI3CgkvLyByZXR1cm4gYVsxXTsKCWZyYW1lX2RpZyAtMSAvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CglleHRyYWN0IDggOAoJYnRvaQoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhiOWJhZWM1NiAvLyBtZXRob2QgInN0YXRpY0FycmF5QXJnKHVpbnQ2NFszXSl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3N0YXRpY0FycmF5QXJnCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestStaticArrayArg.arc56_draft.json b/tests/contracts/artifacts/ABITestStaticArrayArg.arc56_draft.json index 9f0043397..137a8d940 100644 --- a/tests/contracts/artifacts/ABITestStaticArrayArg.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestStaticArrayArg.arc56_draft.json @@ -405,7 +405,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RhdGljQXJyYXlBcmcodWludDY0WzNdKXVpbnQ2NAoqYWJpX3JvdXRlX3N0YXRpY0FycmF5QXJnOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGE6IHVpbnQ2NFszXQoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJZHVwCglsZW4KCXB1c2hpbnQgMjQKCT09CgoJLy8gYXJndW1lbnQgMCAoYSkgZm9yIHN0YXRpY0FycmF5QXJnIG11c3QgYmUgYSB1aW50NjRbM10KCWFzc2VydAoKCS8vIGV4ZWN1dGUgc3RhdGljQXJyYXlBcmcodWludDY0WzNdKXVpbnQ2NAoJY2FsbHN1YiBzdGF0aWNBcnJheUFyZwoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBzdGF0aWNBcnJheUFyZyhhOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+KTogdWludDY0CnN0YXRpY0FycmF5QXJnOgoJcHJvdG8gMSAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjI3CgkvLyByZXR1cm4gYVsxXTsKCWZyYW1lX2RpZyAtMSAvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CglleHRyYWN0IDggOAoJYnRvaQoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhiOWJhZWM1NiAvLyBtZXRob2QgInN0YXRpY0FycmF5QXJnKHVpbnQ2NFszXSl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3N0YXRpY0FycmF5QXJnCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RhdGljQXJyYXlBcmcodWludDY0WzNdKXVpbnQ2NAoqYWJpX3JvdXRlX3N0YXRpY0FycmF5QXJnOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGE6IHVpbnQ2NFszXQoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJZHVwCglsZW4KCXB1c2hpbnQgMjQKCT09CgoJLy8gYXJndW1lbnQgMCAoYSkgZm9yIHN0YXRpY0FycmF5QXJnIG11c3QgYmUgYSB1aW50NjRbM10KCWFzc2VydAoKCS8vIGV4ZWN1dGUgc3RhdGljQXJyYXlBcmcodWludDY0WzNdKXVpbnQ2NAoJY2FsbHN1YiBzdGF0aWNBcnJheUFyZwoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBzdGF0aWNBcnJheUFyZyhhOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+KTogdWludDY0CnN0YXRpY0FycmF5QXJnOgoJcHJvdG8gMSAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjI3CgkvLyByZXR1cm4gYVsxXTsKCWZyYW1lX2RpZyAtMSAvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CglleHRyYWN0IDggOAoJYnRvaQoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhiOWJhZWM1NiAvLyBtZXRob2QgInN0YXRpY0FycmF5QXJnKHVpbnQ2NFszXSl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3N0YXRpY0FycmF5QXJnCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestStaticArrayInStorageMap.approval.teal b/tests/contracts/artifacts/ABITestStaticArrayInStorageMap.approval.teal index e9ef9d0f5..04d022432 100644 --- a/tests/contracts/artifacts/ABITestStaticArrayInStorageMap.approval.teal +++ b/tests/contracts/artifacts/ABITestStaticArrayInStorageMap.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x674d6170 0x6c4d6170 0x624d6170 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestStaticArrayInStorageMap.arc32.json b/tests/contracts/artifacts/ABITestStaticArrayInStorageMap.arc32.json index 4c7210487..3e12cfa80 100644 --- a/tests/contracts/artifacts/ABITestStaticArrayInStorageMap.arc32.json +++ b/tests/contracts/artifacts/ABITestStaticArrayInStorageMap.arc32.json @@ -49,7 +49,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2NzRkNjE3MCAweDZjNGQ2MTcwIDB4NjI0ZDYxNzAgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKk5PVF9JTVBMRU1FTlRFRCAqY2FsbF9PcHRJbiAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RhdGljQXJyYXlJblN0b3JhZ2VNYXAoKXVpbnQ2NFszXQoqYWJpX3JvdXRlX3N0YXRpY0FycmF5SW5TdG9yYWdlTWFwOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgc3RhdGljQXJyYXlJblN0b3JhZ2VNYXAoKXVpbnQ2NFszXQoJY2FsbHN1YiBzdGF0aWNBcnJheUluU3RvcmFnZU1hcAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBzdGF0aWNBcnJheUluU3RvcmFnZU1hcCgpOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CnN0YXRpY0FycmF5SW5TdG9yYWdlTWFwOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCWJ5dGUgMHgKCWR1cAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNDUKCS8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4gPSBbMTEsIDIyLCAzM10KCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMGIwMDAwMDAwMDAwMDAwMDE2MDAwMDAwMDAwMDAwMDAyMQoJZnJhbWVfYnVyeSAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTQ3CgkvLyB0aGlzLmdNYXAoJ2dNYXAnKS52YWx1ZSA9IGEKCWJ5dGUgMHg2NzRkNjE3MCAvLyAiZ01hcCIKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCWFwcF9nbG9iYWxfcHV0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0OAoJLy8gdGhpcy5sTWFwKHRoaXMudHhuLnNlbmRlciwgJ2xNYXAnKS52YWx1ZSA9IGEKCXR4biBTZW5kZXIKCWJ5dGUgMHg2YzRkNjE3MCAvLyAibE1hcCIKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCWFwcF9sb2NhbF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTQ5CgkvLyB0aGlzLmJNYXAoJ2JNYXAnKS52YWx1ZSA9IGEKCWJ5dGUgMHg2MjRkNjE3MCAvLyAiYk1hcCIKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCWJveF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTUxCgkvLyByZXQ6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4gPSBbCgkvLyAgICAgICB0aGlzLmdNYXAoJ2dNYXAnKS52YWx1ZVsxXSwKCS8vICAgICAgIHRoaXMubE1hcCh0aGlzLnR4bi5zZW5kZXIsICdsTWFwJykudmFsdWVbMV0sCgkvLyAgICAgICB0aGlzLmJNYXAoJ2JNYXAnKS52YWx1ZVsxXSwKCS8vICAgICBdCglieXRlIDB4Njc0ZDYxNzAgLy8gImdNYXAiCglhcHBfZ2xvYmFsX2dldAoJZXh0cmFjdCA4IDgKCWJ0b2kKCWl0b2IKCXR4biBTZW5kZXIKCWJ5dGUgMHg2YzRkNjE3MCAvLyAibE1hcCIKCWFwcF9sb2NhbF9nZXQKCWV4dHJhY3QgOCA4CglidG9pCglpdG9iCgljb25jYXQKCWJ5dGUgMHg2MjRkNjE3MCAvLyAiYk1hcCIKCXB1c2hpbnQgOAoJcHVzaGludCA4Cglib3hfZXh0cmFjdAoJYnRvaQoJaXRvYgoJY29uY2F0CglmcmFtZV9idXJ5IDEgLy8gcmV0OiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE1NwoJLy8gcmV0dXJuIHJldDsKCWZyYW1lX2RpZyAxIC8vIHJldDogU3RhdGljQXJyYXk8dWludDY0LCAzPgoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoKCS8vIHBvcCBhbGwgbG9jYWwgdmFyaWFibGVzIGZyb20gdGhlIHN0YWNrCglwb3BuIDEKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9PcHRJbjoKCXB1c2hieXRlcyAweDQ2ZjFhNGIxIC8vIG1ldGhvZCAic3RhdGljQXJyYXlJblN0b3JhZ2VNYXAoKXVpbnQ2NFszXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RhdGljQXJyYXlJblN0b3JhZ2VNYXAKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBPcHRJbgoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2NzRkNjE3MCAweDZjNGQ2MTcwIDB4NjI0ZDYxNzAgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKk5PVF9JTVBMRU1FTlRFRCAqY2FsbF9PcHRJbiAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RhdGljQXJyYXlJblN0b3JhZ2VNYXAoKXVpbnQ2NFszXQoqYWJpX3JvdXRlX3N0YXRpY0FycmF5SW5TdG9yYWdlTWFwOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgc3RhdGljQXJyYXlJblN0b3JhZ2VNYXAoKXVpbnQ2NFszXQoJY2FsbHN1YiBzdGF0aWNBcnJheUluU3RvcmFnZU1hcAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBzdGF0aWNBcnJheUluU3RvcmFnZU1hcCgpOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CnN0YXRpY0FycmF5SW5TdG9yYWdlTWFwOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCWJ5dGUgMHgKCWR1cAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNDUKCS8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4gPSBbMTEsIDIyLCAzM10KCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMGIwMDAwMDAwMDAwMDAwMDE2MDAwMDAwMDAwMDAwMDAyMQoJZnJhbWVfYnVyeSAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTQ3CgkvLyB0aGlzLmdNYXAoJ2dNYXAnKS52YWx1ZSA9IGEKCWJ5dGUgMHg2NzRkNjE3MCAvLyAiZ01hcCIKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCWFwcF9nbG9iYWxfcHV0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0OAoJLy8gdGhpcy5sTWFwKHRoaXMudHhuLnNlbmRlciwgJ2xNYXAnKS52YWx1ZSA9IGEKCXR4biBTZW5kZXIKCWJ5dGUgMHg2YzRkNjE3MCAvLyAibE1hcCIKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCWFwcF9sb2NhbF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTQ5CgkvLyB0aGlzLmJNYXAoJ2JNYXAnKS52YWx1ZSA9IGEKCWJ5dGUgMHg2MjRkNjE3MCAvLyAiYk1hcCIKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCWJveF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTUxCgkvLyByZXQ6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4gPSBbCgkvLyAgICAgICB0aGlzLmdNYXAoJ2dNYXAnKS52YWx1ZVsxXSwKCS8vICAgICAgIHRoaXMubE1hcCh0aGlzLnR4bi5zZW5kZXIsICdsTWFwJykudmFsdWVbMV0sCgkvLyAgICAgICB0aGlzLmJNYXAoJ2JNYXAnKS52YWx1ZVsxXSwKCS8vICAgICBdCglieXRlIDB4Njc0ZDYxNzAgLy8gImdNYXAiCglhcHBfZ2xvYmFsX2dldAoJZXh0cmFjdCA4IDgKCWJ0b2kKCWl0b2IKCXR4biBTZW5kZXIKCWJ5dGUgMHg2YzRkNjE3MCAvLyAibE1hcCIKCWFwcF9sb2NhbF9nZXQKCWV4dHJhY3QgOCA4CglidG9pCglpdG9iCgljb25jYXQKCWJ5dGUgMHg2MjRkNjE3MCAvLyAiYk1hcCIKCXB1c2hpbnQgOAoJcHVzaGludCA4Cglib3hfZXh0cmFjdAoJYnRvaQoJaXRvYgoJY29uY2F0CglmcmFtZV9idXJ5IDEgLy8gcmV0OiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE1NwoJLy8gcmV0dXJuIHJldDsKCWZyYW1lX2RpZyAxIC8vIHJldDogU3RhdGljQXJyYXk8dWludDY0LCAzPgoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoKCS8vIHBvcCBhbGwgbG9jYWwgdmFyaWFibGVzIGZyb20gdGhlIHN0YWNrCglwb3BuIDEKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9PcHRJbjoKCXB1c2hieXRlcyAweDQ2ZjFhNGIxIC8vIG1ldGhvZCAic3RhdGljQXJyYXlJblN0b3JhZ2VNYXAoKXVpbnQ2NFszXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RhdGljQXJyYXlJblN0b3JhZ2VNYXAKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBPcHRJbgoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestStaticArrayInStorageMap.arc56_draft.json b/tests/contracts/artifacts/ABITestStaticArrayInStorageMap.arc56_draft.json index 984e1af92..01e83f7a6 100644 --- a/tests/contracts/artifacts/ABITestStaticArrayInStorageMap.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestStaticArrayInStorageMap.arc56_draft.json @@ -711,7 +711,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2NzRkNjE3MCAweDZjNGQ2MTcwIDB4NjI0ZDYxNzAgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKk5PVF9JTVBMRU1FTlRFRCAqY2FsbF9PcHRJbiAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RhdGljQXJyYXlJblN0b3JhZ2VNYXAoKXVpbnQ2NFszXQoqYWJpX3JvdXRlX3N0YXRpY0FycmF5SW5TdG9yYWdlTWFwOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgc3RhdGljQXJyYXlJblN0b3JhZ2VNYXAoKXVpbnQ2NFszXQoJY2FsbHN1YiBzdGF0aWNBcnJheUluU3RvcmFnZU1hcAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBzdGF0aWNBcnJheUluU3RvcmFnZU1hcCgpOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CnN0YXRpY0FycmF5SW5TdG9yYWdlTWFwOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCWJ5dGUgMHgKCWR1cAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNDUKCS8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4gPSBbMTEsIDIyLCAzM10KCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMGIwMDAwMDAwMDAwMDAwMDE2MDAwMDAwMDAwMDAwMDAyMQoJZnJhbWVfYnVyeSAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTQ3CgkvLyB0aGlzLmdNYXAoJ2dNYXAnKS52YWx1ZSA9IGEKCWJ5dGUgMHg2NzRkNjE3MCAvLyAiZ01hcCIKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCWFwcF9nbG9iYWxfcHV0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0OAoJLy8gdGhpcy5sTWFwKHRoaXMudHhuLnNlbmRlciwgJ2xNYXAnKS52YWx1ZSA9IGEKCXR4biBTZW5kZXIKCWJ5dGUgMHg2YzRkNjE3MCAvLyAibE1hcCIKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCWFwcF9sb2NhbF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTQ5CgkvLyB0aGlzLmJNYXAoJ2JNYXAnKS52YWx1ZSA9IGEKCWJ5dGUgMHg2MjRkNjE3MCAvLyAiYk1hcCIKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCWJveF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTUxCgkvLyByZXQ6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4gPSBbCgkvLyAgICAgICB0aGlzLmdNYXAoJ2dNYXAnKS52YWx1ZVsxXSwKCS8vICAgICAgIHRoaXMubE1hcCh0aGlzLnR4bi5zZW5kZXIsICdsTWFwJykudmFsdWVbMV0sCgkvLyAgICAgICB0aGlzLmJNYXAoJ2JNYXAnKS52YWx1ZVsxXSwKCS8vICAgICBdCglieXRlIDB4Njc0ZDYxNzAgLy8gImdNYXAiCglhcHBfZ2xvYmFsX2dldAoJZXh0cmFjdCA4IDgKCWJ0b2kKCWl0b2IKCXR4biBTZW5kZXIKCWJ5dGUgMHg2YzRkNjE3MCAvLyAibE1hcCIKCWFwcF9sb2NhbF9nZXQKCWV4dHJhY3QgOCA4CglidG9pCglpdG9iCgljb25jYXQKCWJ5dGUgMHg2MjRkNjE3MCAvLyAiYk1hcCIKCXB1c2hpbnQgOAoJcHVzaGludCA4Cglib3hfZXh0cmFjdAoJYnRvaQoJaXRvYgoJY29uY2F0CglmcmFtZV9idXJ5IDEgLy8gcmV0OiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE1NwoJLy8gcmV0dXJuIHJldDsKCWZyYW1lX2RpZyAxIC8vIHJldDogU3RhdGljQXJyYXk8dWludDY0LCAzPgoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoKCS8vIHBvcCBhbGwgbG9jYWwgdmFyaWFibGVzIGZyb20gdGhlIHN0YWNrCglwb3BuIDEKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9PcHRJbjoKCXB1c2hieXRlcyAweDQ2ZjFhNGIxIC8vIG1ldGhvZCAic3RhdGljQXJyYXlJblN0b3JhZ2VNYXAoKXVpbnQ2NFszXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RhdGljQXJyYXlJblN0b3JhZ2VNYXAKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBPcHRJbgoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2NzRkNjE3MCAweDZjNGQ2MTcwIDB4NjI0ZDYxNzAgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKk5PVF9JTVBMRU1FTlRFRCAqY2FsbF9PcHRJbiAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RhdGljQXJyYXlJblN0b3JhZ2VNYXAoKXVpbnQ2NFszXQoqYWJpX3JvdXRlX3N0YXRpY0FycmF5SW5TdG9yYWdlTWFwOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgc3RhdGljQXJyYXlJblN0b3JhZ2VNYXAoKXVpbnQ2NFszXQoJY2FsbHN1YiBzdGF0aWNBcnJheUluU3RvcmFnZU1hcAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBzdGF0aWNBcnJheUluU3RvcmFnZU1hcCgpOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CnN0YXRpY0FycmF5SW5TdG9yYWdlTWFwOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCWJ5dGUgMHgKCWR1cAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNDUKCS8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4gPSBbMTEsIDIyLCAzM10KCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMGIwMDAwMDAwMDAwMDAwMDE2MDAwMDAwMDAwMDAwMDAyMQoJZnJhbWVfYnVyeSAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTQ3CgkvLyB0aGlzLmdNYXAoJ2dNYXAnKS52YWx1ZSA9IGEKCWJ5dGUgMHg2NzRkNjE3MCAvLyAiZ01hcCIKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCWFwcF9nbG9iYWxfcHV0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0OAoJLy8gdGhpcy5sTWFwKHRoaXMudHhuLnNlbmRlciwgJ2xNYXAnKS52YWx1ZSA9IGEKCXR4biBTZW5kZXIKCWJ5dGUgMHg2YzRkNjE3MCAvLyAibE1hcCIKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCWFwcF9sb2NhbF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTQ5CgkvLyB0aGlzLmJNYXAoJ2JNYXAnKS52YWx1ZSA9IGEKCWJ5dGUgMHg2MjRkNjE3MCAvLyAiYk1hcCIKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCWJveF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTUxCgkvLyByZXQ6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4gPSBbCgkvLyAgICAgICB0aGlzLmdNYXAoJ2dNYXAnKS52YWx1ZVsxXSwKCS8vICAgICAgIHRoaXMubE1hcCh0aGlzLnR4bi5zZW5kZXIsICdsTWFwJykudmFsdWVbMV0sCgkvLyAgICAgICB0aGlzLmJNYXAoJ2JNYXAnKS52YWx1ZVsxXSwKCS8vICAgICBdCglieXRlIDB4Njc0ZDYxNzAgLy8gImdNYXAiCglhcHBfZ2xvYmFsX2dldAoJZXh0cmFjdCA4IDgKCWJ0b2kKCWl0b2IKCXR4biBTZW5kZXIKCWJ5dGUgMHg2YzRkNjE3MCAvLyAibE1hcCIKCWFwcF9sb2NhbF9nZXQKCWV4dHJhY3QgOCA4CglidG9pCglpdG9iCgljb25jYXQKCWJ5dGUgMHg2MjRkNjE3MCAvLyAiYk1hcCIKCXB1c2hpbnQgOAoJcHVzaGludCA4Cglib3hfZXh0cmFjdAoJYnRvaQoJaXRvYgoJY29uY2F0CglmcmFtZV9idXJ5IDEgLy8gcmV0OiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE1NwoJLy8gcmV0dXJuIHJldDsKCWZyYW1lX2RpZyAxIC8vIHJldDogU3RhdGljQXJyYXk8dWludDY0LCAzPgoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoKCS8vIHBvcCBhbGwgbG9jYWwgdmFyaWFibGVzIGZyb20gdGhlIHN0YWNrCglwb3BuIDEKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9PcHRJbjoKCXB1c2hieXRlcyAweDQ2ZjFhNGIxIC8vIG1ldGhvZCAic3RhdGljQXJyYXlJblN0b3JhZ2VNYXAoKXVpbnQ2NFszXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RhdGljQXJyYXlJblN0b3JhZ2VNYXAKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBPcHRJbgoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestStaticArrayInStorageRef.approval.teal b/tests/contracts/artifacts/ABITestStaticArrayInStorageRef.approval.teal index 4d9b13d08..f82aaab0a 100644 --- a/tests/contracts/artifacts/ABITestStaticArrayInStorageRef.approval.teal +++ b/tests/contracts/artifacts/ABITestStaticArrayInStorageRef.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x67526566 0x6c526566 0x62526566 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestStaticArrayInStorageRef.arc32.json b/tests/contracts/artifacts/ABITestStaticArrayInStorageRef.arc32.json index 412cb51dd..f29f211f2 100644 --- a/tests/contracts/artifacts/ABITestStaticArrayInStorageRef.arc32.json +++ b/tests/contracts/artifacts/ABITestStaticArrayInStorageRef.arc32.json @@ -49,7 +49,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2NzUyNjU2NiAweDZjNTI2NTY2IDB4NjI1MjY1NjYgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKk5PVF9JTVBMRU1FTlRFRCAqY2FsbF9PcHRJbiAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RhdGljQXJyYXlJblN0b3JhZ2VSZWYoKXVpbnQ2NFszXQoqYWJpX3JvdXRlX3N0YXRpY0FycmF5SW5TdG9yYWdlUmVmOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgc3RhdGljQXJyYXlJblN0b3JhZ2VSZWYoKXVpbnQ2NFszXQoJY2FsbHN1YiBzdGF0aWNBcnJheUluU3RvcmFnZVJlZgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBzdGF0aWNBcnJheUluU3RvcmFnZVJlZigpOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CnN0YXRpY0FycmF5SW5TdG9yYWdlUmVmOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCWJ5dGUgMHgKCWR1cAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4NwoJLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPiA9IFsxMSwgMjIsIDMzXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwYjAwMDAwMDAwMDAwMDAwMTYwMDAwMDAwMDAwMDAwMDIxCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4OQoJLy8gdGhpcy5nUmVmLnZhbHVlID0gYQoJYnl0ZSAweDY3NTI2NTY2IC8vICJnUmVmIgoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoJYXBwX2dsb2JhbF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6OTAKCS8vIHRoaXMubFJlZih0aGlzLnR4bi5zZW5kZXIpLnZhbHVlID0gYQoJdHhuIFNlbmRlcgoJYnl0ZSAweDZjNTI2NTY2IC8vICJsUmVmIgoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoJYXBwX2xvY2FsX3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo5MQoJLy8gdGhpcy5iUmVmLnZhbHVlID0gYQoJYnl0ZSAweDYyNTI2NTY2IC8vICJiUmVmIgoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoJYm94X3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo5MwoJLy8gcmV0OiBTdGF0aWNBcnJheTx1aW50NjQsIDM+ID0gW3RoaXMuZ1JlZi52YWx1ZVsxXSwgdGhpcy5sUmVmKHRoaXMudHhuLnNlbmRlcikudmFsdWVbMV0sIHRoaXMuYlJlZi52YWx1ZVsxXV0KCWJ5dGUgMHg2NzUyNjU2NiAvLyAiZ1JlZiIKCWFwcF9nbG9iYWxfZ2V0CglleHRyYWN0IDggOAoJYnRvaQoJaXRvYgoJdHhuIFNlbmRlcgoJYnl0ZSAweDZjNTI2NTY2IC8vICJsUmVmIgoJYXBwX2xvY2FsX2dldAoJZXh0cmFjdCA4IDgKCWJ0b2kKCWl0b2IKCWNvbmNhdAoJYnl0ZSAweDYyNTI2NTY2IC8vICJiUmVmIgoJcHVzaGludCA4CglwdXNoaW50IDgKCWJveF9leHRyYWN0CglidG9pCglpdG9iCgljb25jYXQKCWZyYW1lX2J1cnkgMSAvLyByZXQ6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6OTUKCS8vIHJldHVybiByZXQ7CglmcmFtZV9kaWcgMSAvLyByZXQ6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCgkvLyBwb3AgYWxsIGxvY2FsIHZhcmlhYmxlcyBmcm9tIHRoZSBzdGFjawoJcG9wbiAxCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfT3B0SW46CglwdXNoYnl0ZXMgMHgwNzUwMjJlNSAvLyBtZXRob2QgInN0YXRpY0FycmF5SW5TdG9yYWdlUmVmKCl1aW50NjRbM10iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3N0YXRpY0FycmF5SW5TdG9yYWdlUmVmCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgT3B0SW4KCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2NzUyNjU2NiAweDZjNTI2NTY2IDB4NjI1MjY1NjYgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKk5PVF9JTVBMRU1FTlRFRCAqY2FsbF9PcHRJbiAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RhdGljQXJyYXlJblN0b3JhZ2VSZWYoKXVpbnQ2NFszXQoqYWJpX3JvdXRlX3N0YXRpY0FycmF5SW5TdG9yYWdlUmVmOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgc3RhdGljQXJyYXlJblN0b3JhZ2VSZWYoKXVpbnQ2NFszXQoJY2FsbHN1YiBzdGF0aWNBcnJheUluU3RvcmFnZVJlZgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBzdGF0aWNBcnJheUluU3RvcmFnZVJlZigpOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CnN0YXRpY0FycmF5SW5TdG9yYWdlUmVmOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCWJ5dGUgMHgKCWR1cAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4NwoJLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPiA9IFsxMSwgMjIsIDMzXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwYjAwMDAwMDAwMDAwMDAwMTYwMDAwMDAwMDAwMDAwMDIxCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4OQoJLy8gdGhpcy5nUmVmLnZhbHVlID0gYQoJYnl0ZSAweDY3NTI2NTY2IC8vICJnUmVmIgoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoJYXBwX2dsb2JhbF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6OTAKCS8vIHRoaXMubFJlZih0aGlzLnR4bi5zZW5kZXIpLnZhbHVlID0gYQoJdHhuIFNlbmRlcgoJYnl0ZSAweDZjNTI2NTY2IC8vICJsUmVmIgoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoJYXBwX2xvY2FsX3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo5MQoJLy8gdGhpcy5iUmVmLnZhbHVlID0gYQoJYnl0ZSAweDYyNTI2NTY2IC8vICJiUmVmIgoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoJYm94X3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo5MwoJLy8gcmV0OiBTdGF0aWNBcnJheTx1aW50NjQsIDM+ID0gW3RoaXMuZ1JlZi52YWx1ZVsxXSwgdGhpcy5sUmVmKHRoaXMudHhuLnNlbmRlcikudmFsdWVbMV0sIHRoaXMuYlJlZi52YWx1ZVsxXV0KCWJ5dGUgMHg2NzUyNjU2NiAvLyAiZ1JlZiIKCWFwcF9nbG9iYWxfZ2V0CglleHRyYWN0IDggOAoJYnRvaQoJaXRvYgoJdHhuIFNlbmRlcgoJYnl0ZSAweDZjNTI2NTY2IC8vICJsUmVmIgoJYXBwX2xvY2FsX2dldAoJZXh0cmFjdCA4IDgKCWJ0b2kKCWl0b2IKCWNvbmNhdAoJYnl0ZSAweDYyNTI2NTY2IC8vICJiUmVmIgoJcHVzaGludCA4CglwdXNoaW50IDgKCWJveF9leHRyYWN0CglidG9pCglpdG9iCgljb25jYXQKCWZyYW1lX2J1cnkgMSAvLyByZXQ6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6OTUKCS8vIHJldHVybiByZXQ7CglmcmFtZV9kaWcgMSAvLyByZXQ6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCgkvLyBwb3AgYWxsIGxvY2FsIHZhcmlhYmxlcyBmcm9tIHRoZSBzdGFjawoJcG9wbiAxCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfT3B0SW46CglwdXNoYnl0ZXMgMHgwNzUwMjJlNSAvLyBtZXRob2QgInN0YXRpY0FycmF5SW5TdG9yYWdlUmVmKCl1aW50NjRbM10iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3N0YXRpY0FycmF5SW5TdG9yYWdlUmVmCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgT3B0SW4KCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestStaticArrayInStorageRef.arc56_draft.json b/tests/contracts/artifacts/ABITestStaticArrayInStorageRef.arc56_draft.json index 86412b6f7..082057c60 100644 --- a/tests/contracts/artifacts/ABITestStaticArrayInStorageRef.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestStaticArrayInStorageRef.arc56_draft.json @@ -711,7 +711,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2NzUyNjU2NiAweDZjNTI2NTY2IDB4NjI1MjY1NjYgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKk5PVF9JTVBMRU1FTlRFRCAqY2FsbF9PcHRJbiAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RhdGljQXJyYXlJblN0b3JhZ2VSZWYoKXVpbnQ2NFszXQoqYWJpX3JvdXRlX3N0YXRpY0FycmF5SW5TdG9yYWdlUmVmOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgc3RhdGljQXJyYXlJblN0b3JhZ2VSZWYoKXVpbnQ2NFszXQoJY2FsbHN1YiBzdGF0aWNBcnJheUluU3RvcmFnZVJlZgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBzdGF0aWNBcnJheUluU3RvcmFnZVJlZigpOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CnN0YXRpY0FycmF5SW5TdG9yYWdlUmVmOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCWJ5dGUgMHgKCWR1cAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4NwoJLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPiA9IFsxMSwgMjIsIDMzXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwYjAwMDAwMDAwMDAwMDAwMTYwMDAwMDAwMDAwMDAwMDIxCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4OQoJLy8gdGhpcy5nUmVmLnZhbHVlID0gYQoJYnl0ZSAweDY3NTI2NTY2IC8vICJnUmVmIgoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoJYXBwX2dsb2JhbF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6OTAKCS8vIHRoaXMubFJlZih0aGlzLnR4bi5zZW5kZXIpLnZhbHVlID0gYQoJdHhuIFNlbmRlcgoJYnl0ZSAweDZjNTI2NTY2IC8vICJsUmVmIgoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoJYXBwX2xvY2FsX3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo5MQoJLy8gdGhpcy5iUmVmLnZhbHVlID0gYQoJYnl0ZSAweDYyNTI2NTY2IC8vICJiUmVmIgoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoJYm94X3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo5MwoJLy8gcmV0OiBTdGF0aWNBcnJheTx1aW50NjQsIDM+ID0gW3RoaXMuZ1JlZi52YWx1ZVsxXSwgdGhpcy5sUmVmKHRoaXMudHhuLnNlbmRlcikudmFsdWVbMV0sIHRoaXMuYlJlZi52YWx1ZVsxXV0KCWJ5dGUgMHg2NzUyNjU2NiAvLyAiZ1JlZiIKCWFwcF9nbG9iYWxfZ2V0CglleHRyYWN0IDggOAoJYnRvaQoJaXRvYgoJdHhuIFNlbmRlcgoJYnl0ZSAweDZjNTI2NTY2IC8vICJsUmVmIgoJYXBwX2xvY2FsX2dldAoJZXh0cmFjdCA4IDgKCWJ0b2kKCWl0b2IKCWNvbmNhdAoJYnl0ZSAweDYyNTI2NTY2IC8vICJiUmVmIgoJcHVzaGludCA4CglwdXNoaW50IDgKCWJveF9leHRyYWN0CglidG9pCglpdG9iCgljb25jYXQKCWZyYW1lX2J1cnkgMSAvLyByZXQ6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6OTUKCS8vIHJldHVybiByZXQ7CglmcmFtZV9kaWcgMSAvLyByZXQ6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCgkvLyBwb3AgYWxsIGxvY2FsIHZhcmlhYmxlcyBmcm9tIHRoZSBzdGFjawoJcG9wbiAxCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfT3B0SW46CglwdXNoYnl0ZXMgMHgwNzUwMjJlNSAvLyBtZXRob2QgInN0YXRpY0FycmF5SW5TdG9yYWdlUmVmKCl1aW50NjRbM10iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3N0YXRpY0FycmF5SW5TdG9yYWdlUmVmCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgT3B0SW4KCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2NzUyNjU2NiAweDZjNTI2NTY2IDB4NjI1MjY1NjYgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKk5PVF9JTVBMRU1FTlRFRCAqY2FsbF9PcHRJbiAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RhdGljQXJyYXlJblN0b3JhZ2VSZWYoKXVpbnQ2NFszXQoqYWJpX3JvdXRlX3N0YXRpY0FycmF5SW5TdG9yYWdlUmVmOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgc3RhdGljQXJyYXlJblN0b3JhZ2VSZWYoKXVpbnQ2NFszXQoJY2FsbHN1YiBzdGF0aWNBcnJheUluU3RvcmFnZVJlZgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBzdGF0aWNBcnJheUluU3RvcmFnZVJlZigpOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CnN0YXRpY0FycmF5SW5TdG9yYWdlUmVmOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCWJ5dGUgMHgKCWR1cAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4NwoJLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPiA9IFsxMSwgMjIsIDMzXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwYjAwMDAwMDAwMDAwMDAwMTYwMDAwMDAwMDAwMDAwMDIxCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4OQoJLy8gdGhpcy5nUmVmLnZhbHVlID0gYQoJYnl0ZSAweDY3NTI2NTY2IC8vICJnUmVmIgoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoJYXBwX2dsb2JhbF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6OTAKCS8vIHRoaXMubFJlZih0aGlzLnR4bi5zZW5kZXIpLnZhbHVlID0gYQoJdHhuIFNlbmRlcgoJYnl0ZSAweDZjNTI2NTY2IC8vICJsUmVmIgoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoJYXBwX2xvY2FsX3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo5MQoJLy8gdGhpcy5iUmVmLnZhbHVlID0gYQoJYnl0ZSAweDYyNTI2NTY2IC8vICJiUmVmIgoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoJYm94X3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo5MwoJLy8gcmV0OiBTdGF0aWNBcnJheTx1aW50NjQsIDM+ID0gW3RoaXMuZ1JlZi52YWx1ZVsxXSwgdGhpcy5sUmVmKHRoaXMudHhuLnNlbmRlcikudmFsdWVbMV0sIHRoaXMuYlJlZi52YWx1ZVsxXV0KCWJ5dGUgMHg2NzUyNjU2NiAvLyAiZ1JlZiIKCWFwcF9nbG9iYWxfZ2V0CglleHRyYWN0IDggOAoJYnRvaQoJaXRvYgoJdHhuIFNlbmRlcgoJYnl0ZSAweDZjNTI2NTY2IC8vICJsUmVmIgoJYXBwX2xvY2FsX2dldAoJZXh0cmFjdCA4IDgKCWJ0b2kKCWl0b2IKCWNvbmNhdAoJYnl0ZSAweDYyNTI2NTY2IC8vICJiUmVmIgoJcHVzaGludCA4CglwdXNoaW50IDgKCWJveF9leHRyYWN0CglidG9pCglpdG9iCgljb25jYXQKCWZyYW1lX2J1cnkgMSAvLyByZXQ6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6OTUKCS8vIHJldHVybiByZXQ7CglmcmFtZV9kaWcgMSAvLyByZXQ6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCgkvLyBwb3AgYWxsIGxvY2FsIHZhcmlhYmxlcyBmcm9tIHRoZSBzdGFjawoJcG9wbiAxCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfT3B0SW46CglwdXNoYnl0ZXMgMHgwNzUwMjJlNSAvLyBtZXRob2QgInN0YXRpY0FycmF5SW5TdG9yYWdlUmVmKCl1aW50NjRbM10iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3N0YXRpY0FycmF5SW5TdG9yYWdlUmVmCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgT3B0SW4KCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestStaticArrayLength.approval.teal b/tests/contracts/artifacts/ABITestStaticArrayLength.approval.teal index aed08b44a..9032c6cfc 100644 --- a/tests/contracts/artifacts/ABITestStaticArrayLength.approval.teal +++ b/tests/contracts/artifacts/ABITestStaticArrayLength.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestStaticArrayLength.arc32.json b/tests/contracts/artifacts/ABITestStaticArrayLength.arc32.json index 0b2fa322d..744de9707 100644 --- a/tests/contracts/artifacts/ABITestStaticArrayLength.arc32.json +++ b/tests/contracts/artifacts/ABITestStaticArrayLength.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RhdGljQXJyYXlMZW5ndGgoKXVpbnQ2NAoqYWJpX3JvdXRlX3N0YXRpY0FycmF5TGVuZ3RoOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgc3RhdGljQXJyYXlMZW5ndGgoKXVpbnQ2NAoJY2FsbHN1YiBzdGF0aWNBcnJheUxlbmd0aAoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBzdGF0aWNBcnJheUxlbmd0aCgpOiB1aW50NjQKc3RhdGljQXJyYXlMZW5ndGg6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzODUKCS8vIGE6IFN0YXRpY0FycmF5PHVpbnQ4LCA1PiA9IFsxMSwgMjIsIDMzLCA0NCwgNTVdCglwdXNoYnl0ZXMgMHgwYjE2MjEyYzM3CglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8dWludDgsIDU+CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzODcKCS8vIHJldHVybiBhLmxlbmd0aDsKCXB1c2hpbnQgNQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgyMmJjZjM5NCAvLyBtZXRob2QgInN0YXRpY0FycmF5TGVuZ3RoKCl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3N0YXRpY0FycmF5TGVuZ3RoCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RhdGljQXJyYXlMZW5ndGgoKXVpbnQ2NAoqYWJpX3JvdXRlX3N0YXRpY0FycmF5TGVuZ3RoOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgc3RhdGljQXJyYXlMZW5ndGgoKXVpbnQ2NAoJY2FsbHN1YiBzdGF0aWNBcnJheUxlbmd0aAoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBzdGF0aWNBcnJheUxlbmd0aCgpOiB1aW50NjQKc3RhdGljQXJyYXlMZW5ndGg6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzODUKCS8vIGE6IFN0YXRpY0FycmF5PHVpbnQ4LCA1PiA9IFsxMSwgMjIsIDMzLCA0NCwgNTVdCglwdXNoYnl0ZXMgMHgwYjE2MjEyYzM3CglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8dWludDgsIDU+CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzODcKCS8vIHJldHVybiBhLmxlbmd0aDsKCXB1c2hpbnQgNQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgyMmJjZjM5NCAvLyBtZXRob2QgInN0YXRpY0FycmF5TGVuZ3RoKCl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3N0YXRpY0FycmF5TGVuZ3RoCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestStaticArrayLength.arc56_draft.json b/tests/contracts/artifacts/ABITestStaticArrayLength.arc56_draft.json index 5e63dc15e..8ed28805b 100644 --- a/tests/contracts/artifacts/ABITestStaticArrayLength.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestStaticArrayLength.arc56_draft.json @@ -375,7 +375,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RhdGljQXJyYXlMZW5ndGgoKXVpbnQ2NAoqYWJpX3JvdXRlX3N0YXRpY0FycmF5TGVuZ3RoOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgc3RhdGljQXJyYXlMZW5ndGgoKXVpbnQ2NAoJY2FsbHN1YiBzdGF0aWNBcnJheUxlbmd0aAoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBzdGF0aWNBcnJheUxlbmd0aCgpOiB1aW50NjQKc3RhdGljQXJyYXlMZW5ndGg6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzODUKCS8vIGE6IFN0YXRpY0FycmF5PHVpbnQ4LCA1PiA9IFsxMSwgMjIsIDMzLCA0NCwgNTVdCglwdXNoYnl0ZXMgMHgwYjE2MjEyYzM3CglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8dWludDgsIDU+CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzODcKCS8vIHJldHVybiBhLmxlbmd0aDsKCXB1c2hpbnQgNQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgyMmJjZjM5NCAvLyBtZXRob2QgInN0YXRpY0FycmF5TGVuZ3RoKCl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3N0YXRpY0FycmF5TGVuZ3RoCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RhdGljQXJyYXlMZW5ndGgoKXVpbnQ2NAoqYWJpX3JvdXRlX3N0YXRpY0FycmF5TGVuZ3RoOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgc3RhdGljQXJyYXlMZW5ndGgoKXVpbnQ2NAoJY2FsbHN1YiBzdGF0aWNBcnJheUxlbmd0aAoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBzdGF0aWNBcnJheUxlbmd0aCgpOiB1aW50NjQKc3RhdGljQXJyYXlMZW5ndGg6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzODUKCS8vIGE6IFN0YXRpY0FycmF5PHVpbnQ4LCA1PiA9IFsxMSwgMjIsIDMzLCA0NCwgNTVdCglwdXNoYnl0ZXMgMHgwYjE2MjEyYzM3CglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8dWludDgsIDU+CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzODcKCS8vIHJldHVybiBhLmxlbmd0aDsKCXB1c2hpbnQgNQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgyMmJjZjM5NCAvLyBtZXRob2QgInN0YXRpY0FycmF5TGVuZ3RoKCl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3N0YXRpY0FycmF5TGVuZ3RoCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestStaticBoolArray.approval.teal b/tests/contracts/artifacts/ABITestStaticBoolArray.approval.teal index 25ad7f64d..f3c79b87e 100644 --- a/tests/contracts/artifacts/ABITestStaticBoolArray.approval.teal +++ b/tests/contracts/artifacts/ABITestStaticBoolArray.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestStaticBoolArray.arc32.json b/tests/contracts/artifacts/ABITestStaticBoolArray.arc32.json index ac7d6698e..cc5845433 100644 --- a/tests/contracts/artifacts/ABITestStaticBoolArray.arc32.json +++ b/tests/contracts/artifacts/ABITestStaticBoolArray.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RhdGljQm9vbEFycmF5KClib29sWzldCiphYmlfcm91dGVfc3RhdGljQm9vbEFycmF5OgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgc3RhdGljQm9vbEFycmF5KClib29sWzldCgljYWxsc3ViIHN0YXRpY0Jvb2xBcnJheQoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBzdGF0aWNCb29sQXJyYXkoKTogU3RhdGljQXJyYXk8Ym9vbGVhbiwgOT4Kc3RhdGljQm9vbEFycmF5OgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4OTcKCS8vIGE6IFN0YXRpY0FycmF5PGJvb2xlYW4sIDk+ID0gW3RydWUsIGZhbHNlLCB0cnVlLCB0cnVlLCBmYWxzZSwgZmFsc2UsIHRydWUsIGZhbHNlLCBmYWxzZV0KCXB1c2hieXRlcyAweDAwMDAKCXB1c2hpbnQgMAoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hpbnQgMQoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgMgoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hpbnQgMwoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hpbnQgNAoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgNQoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgNgoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hpbnQgNwoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgOAoJcHVzaGludCAwCglzZXRiaXQKCWZyYW1lX2J1cnkgMCAvLyBhOiBTdGF0aWNBcnJheTxib29sZWFuLCA5PgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4OTkKCS8vIHJldHVybiBhOwoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8Ym9vbGVhbiwgOT4KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MDgzNjk5M2EgLy8gbWV0aG9kICJzdGF0aWNCb29sQXJyYXkoKWJvb2xbOV0iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3N0YXRpY0Jvb2xBcnJheQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RhdGljQm9vbEFycmF5KClib29sWzldCiphYmlfcm91dGVfc3RhdGljQm9vbEFycmF5OgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgc3RhdGljQm9vbEFycmF5KClib29sWzldCgljYWxsc3ViIHN0YXRpY0Jvb2xBcnJheQoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBzdGF0aWNCb29sQXJyYXkoKTogU3RhdGljQXJyYXk8Ym9vbGVhbiwgOT4Kc3RhdGljQm9vbEFycmF5OgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4OTcKCS8vIGE6IFN0YXRpY0FycmF5PGJvb2xlYW4sIDk+ID0gW3RydWUsIGZhbHNlLCB0cnVlLCB0cnVlLCBmYWxzZSwgZmFsc2UsIHRydWUsIGZhbHNlLCBmYWxzZV0KCXB1c2hieXRlcyAweDAwMDAKCXB1c2hpbnQgMAoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hpbnQgMQoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgMgoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hpbnQgMwoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hpbnQgNAoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgNQoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgNgoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hpbnQgNwoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgOAoJcHVzaGludCAwCglzZXRiaXQKCWZyYW1lX2J1cnkgMCAvLyBhOiBTdGF0aWNBcnJheTxib29sZWFuLCA5PgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4OTkKCS8vIHJldHVybiBhOwoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8Ym9vbGVhbiwgOT4KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MDgzNjk5M2EgLy8gbWV0aG9kICJzdGF0aWNCb29sQXJyYXkoKWJvb2xbOV0iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3N0YXRpY0Jvb2xBcnJheQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestStaticBoolArray.arc56_draft.json b/tests/contracts/artifacts/ABITestStaticBoolArray.arc56_draft.json index 404240e46..7344c5e68 100644 --- a/tests/contracts/artifacts/ABITestStaticBoolArray.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestStaticBoolArray.arc56_draft.json @@ -572,7 +572,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RhdGljQm9vbEFycmF5KClib29sWzldCiphYmlfcm91dGVfc3RhdGljQm9vbEFycmF5OgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgc3RhdGljQm9vbEFycmF5KClib29sWzldCgljYWxsc3ViIHN0YXRpY0Jvb2xBcnJheQoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBzdGF0aWNCb29sQXJyYXkoKTogU3RhdGljQXJyYXk8Ym9vbGVhbiwgOT4Kc3RhdGljQm9vbEFycmF5OgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4OTcKCS8vIGE6IFN0YXRpY0FycmF5PGJvb2xlYW4sIDk+ID0gW3RydWUsIGZhbHNlLCB0cnVlLCB0cnVlLCBmYWxzZSwgZmFsc2UsIHRydWUsIGZhbHNlLCBmYWxzZV0KCXB1c2hieXRlcyAweDAwMDAKCXB1c2hpbnQgMAoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hpbnQgMQoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgMgoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hpbnQgMwoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hpbnQgNAoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgNQoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgNgoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hpbnQgNwoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgOAoJcHVzaGludCAwCglzZXRiaXQKCWZyYW1lX2J1cnkgMCAvLyBhOiBTdGF0aWNBcnJheTxib29sZWFuLCA5PgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4OTkKCS8vIHJldHVybiBhOwoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8Ym9vbGVhbiwgOT4KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MDgzNjk5M2EgLy8gbWV0aG9kICJzdGF0aWNCb29sQXJyYXkoKWJvb2xbOV0iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3N0YXRpY0Jvb2xBcnJheQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RhdGljQm9vbEFycmF5KClib29sWzldCiphYmlfcm91dGVfc3RhdGljQm9vbEFycmF5OgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgc3RhdGljQm9vbEFycmF5KClib29sWzldCgljYWxsc3ViIHN0YXRpY0Jvb2xBcnJheQoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBzdGF0aWNCb29sQXJyYXkoKTogU3RhdGljQXJyYXk8Ym9vbGVhbiwgOT4Kc3RhdGljQm9vbEFycmF5OgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4OTcKCS8vIGE6IFN0YXRpY0FycmF5PGJvb2xlYW4sIDk+ID0gW3RydWUsIGZhbHNlLCB0cnVlLCB0cnVlLCBmYWxzZSwgZmFsc2UsIHRydWUsIGZhbHNlLCBmYWxzZV0KCXB1c2hieXRlcyAweDAwMDAKCXB1c2hpbnQgMAoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hpbnQgMQoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgMgoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hpbnQgMwoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hpbnQgNAoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgNQoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgNgoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hpbnQgNwoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgOAoJcHVzaGludCAwCglzZXRiaXQKCWZyYW1lX2J1cnkgMCAvLyBhOiBTdGF0aWNBcnJheTxib29sZWFuLCA5PgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4OTkKCS8vIHJldHVybiBhOwoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8Ym9vbGVhbiwgOT4KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MDgzNjk5M2EgLy8gbWV0aG9kICJzdGF0aWNCb29sQXJyYXkoKWJvb2xbOV0iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3N0YXRpY0Jvb2xBcnJheQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestStaticBoolArrayAccess.approval.teal b/tests/contracts/artifacts/ABITestStaticBoolArrayAccess.approval.teal index b8c324843..163c0a74d 100644 --- a/tests/contracts/artifacts/ABITestStaticBoolArrayAccess.approval.teal +++ b/tests/contracts/artifacts/ABITestStaticBoolArrayAccess.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestStaticBoolArrayAccess.arc32.json b/tests/contracts/artifacts/ABITestStaticBoolArrayAccess.arc32.json index 885685978..e379b6179 100644 --- a/tests/contracts/artifacts/ABITestStaticBoolArrayAccess.arc32.json +++ b/tests/contracts/artifacts/ABITestStaticBoolArrayAccess.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RhdGljQm9vbEFycmF5QWNjZXNzKClib29sCiphYmlfcm91dGVfc3RhdGljQm9vbEFycmF5QWNjZXNzOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgc3RhdGljQm9vbEFycmF5QWNjZXNzKClib29sCgljYWxsc3ViIHN0YXRpY0Jvb2xBcnJheUFjY2VzcwoJcHVzaGJ5dGVzIDB4MDAKCXB1c2hpbnQgMAoJdW5jb3ZlciAyCglzZXRiaXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gc3RhdGljQm9vbEFycmF5QWNjZXNzKCk6IGJvb2xlYW4Kc3RhdGljQm9vbEFycmF5QWNjZXNzOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo5MjMKCS8vIGE6IFN0YXRpY0FycmF5PGJvb2xlYW4sIDk+ID0gW3RydWUsIGZhbHNlLCB0cnVlLCB0cnVlLCBmYWxzZSwgZmFsc2UsIHRydWUsIGZhbHNlLCBmYWxzZV0KCXB1c2hieXRlcyAweDAwMDAKCXB1c2hpbnQgMAoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hpbnQgMQoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgMgoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hpbnQgMwoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hpbnQgNAoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgNQoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgNgoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hpbnQgNwoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgOAoJcHVzaGludCAwCglzZXRiaXQKCWZyYW1lX2J1cnkgMCAvLyBhOiBTdGF0aWNBcnJheTxib29sZWFuLCA5PgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo5MjUKCS8vIHJldHVybiBhWzhdOwoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8Ym9vbGVhbiwgOT4KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoaW50IDgKCWdldGJpdAoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhlNGViMmMxZiAvLyBtZXRob2QgInN0YXRpY0Jvb2xBcnJheUFjY2VzcygpYm9vbCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RhdGljQm9vbEFycmF5QWNjZXNzCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RhdGljQm9vbEFycmF5QWNjZXNzKClib29sCiphYmlfcm91dGVfc3RhdGljQm9vbEFycmF5QWNjZXNzOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgc3RhdGljQm9vbEFycmF5QWNjZXNzKClib29sCgljYWxsc3ViIHN0YXRpY0Jvb2xBcnJheUFjY2VzcwoJcHVzaGJ5dGVzIDB4MDAKCXB1c2hpbnQgMAoJdW5jb3ZlciAyCglzZXRiaXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gc3RhdGljQm9vbEFycmF5QWNjZXNzKCk6IGJvb2xlYW4Kc3RhdGljQm9vbEFycmF5QWNjZXNzOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo5MjMKCS8vIGE6IFN0YXRpY0FycmF5PGJvb2xlYW4sIDk+ID0gW3RydWUsIGZhbHNlLCB0cnVlLCB0cnVlLCBmYWxzZSwgZmFsc2UsIHRydWUsIGZhbHNlLCBmYWxzZV0KCXB1c2hieXRlcyAweDAwMDAKCXB1c2hpbnQgMAoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hpbnQgMQoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgMgoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hpbnQgMwoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hpbnQgNAoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgNQoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgNgoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hpbnQgNwoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgOAoJcHVzaGludCAwCglzZXRiaXQKCWZyYW1lX2J1cnkgMCAvLyBhOiBTdGF0aWNBcnJheTxib29sZWFuLCA5PgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo5MjUKCS8vIHJldHVybiBhWzhdOwoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8Ym9vbGVhbiwgOT4KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoaW50IDgKCWdldGJpdAoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhlNGViMmMxZiAvLyBtZXRob2QgInN0YXRpY0Jvb2xBcnJheUFjY2VzcygpYm9vbCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RhdGljQm9vbEFycmF5QWNjZXNzCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestStaticBoolArrayAccess.arc56_draft.json b/tests/contracts/artifacts/ABITestStaticBoolArrayAccess.arc56_draft.json index 2d17d10b7..38a7acee8 100644 --- a/tests/contracts/artifacts/ABITestStaticBoolArrayAccess.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestStaticBoolArrayAccess.arc56_draft.json @@ -635,7 +635,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RhdGljQm9vbEFycmF5QWNjZXNzKClib29sCiphYmlfcm91dGVfc3RhdGljQm9vbEFycmF5QWNjZXNzOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgc3RhdGljQm9vbEFycmF5QWNjZXNzKClib29sCgljYWxsc3ViIHN0YXRpY0Jvb2xBcnJheUFjY2VzcwoJcHVzaGJ5dGVzIDB4MDAKCXB1c2hpbnQgMAoJdW5jb3ZlciAyCglzZXRiaXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gc3RhdGljQm9vbEFycmF5QWNjZXNzKCk6IGJvb2xlYW4Kc3RhdGljQm9vbEFycmF5QWNjZXNzOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo5MjMKCS8vIGE6IFN0YXRpY0FycmF5PGJvb2xlYW4sIDk+ID0gW3RydWUsIGZhbHNlLCB0cnVlLCB0cnVlLCBmYWxzZSwgZmFsc2UsIHRydWUsIGZhbHNlLCBmYWxzZV0KCXB1c2hieXRlcyAweDAwMDAKCXB1c2hpbnQgMAoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hpbnQgMQoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgMgoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hpbnQgMwoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hpbnQgNAoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgNQoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgNgoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hpbnQgNwoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgOAoJcHVzaGludCAwCglzZXRiaXQKCWZyYW1lX2J1cnkgMCAvLyBhOiBTdGF0aWNBcnJheTxib29sZWFuLCA5PgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo5MjUKCS8vIHJldHVybiBhWzhdOwoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8Ym9vbGVhbiwgOT4KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoaW50IDgKCWdldGJpdAoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhlNGViMmMxZiAvLyBtZXRob2QgInN0YXRpY0Jvb2xBcnJheUFjY2VzcygpYm9vbCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RhdGljQm9vbEFycmF5QWNjZXNzCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RhdGljQm9vbEFycmF5QWNjZXNzKClib29sCiphYmlfcm91dGVfc3RhdGljQm9vbEFycmF5QWNjZXNzOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgc3RhdGljQm9vbEFycmF5QWNjZXNzKClib29sCgljYWxsc3ViIHN0YXRpY0Jvb2xBcnJheUFjY2VzcwoJcHVzaGJ5dGVzIDB4MDAKCXB1c2hpbnQgMAoJdW5jb3ZlciAyCglzZXRiaXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gc3RhdGljQm9vbEFycmF5QWNjZXNzKCk6IGJvb2xlYW4Kc3RhdGljQm9vbEFycmF5QWNjZXNzOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo5MjMKCS8vIGE6IFN0YXRpY0FycmF5PGJvb2xlYW4sIDk+ID0gW3RydWUsIGZhbHNlLCB0cnVlLCB0cnVlLCBmYWxzZSwgZmFsc2UsIHRydWUsIGZhbHNlLCBmYWxzZV0KCXB1c2hieXRlcyAweDAwMDAKCXB1c2hpbnQgMAoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hpbnQgMQoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgMgoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hpbnQgMwoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hpbnQgNAoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgNQoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgNgoJcHVzaGludCAxCglzZXRiaXQKCXB1c2hpbnQgNwoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgOAoJcHVzaGludCAwCglzZXRiaXQKCWZyYW1lX2J1cnkgMCAvLyBhOiBTdGF0aWNBcnJheTxib29sZWFuLCA5PgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo5MjUKCS8vIHJldHVybiBhWzhdOwoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8Ym9vbGVhbiwgOT4KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoaW50IDgKCWdldGJpdAoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhlNGViMmMxZiAvLyBtZXRob2QgInN0YXRpY0Jvb2xBcnJheUFjY2VzcygpYm9vbCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RhdGljQm9vbEFycmF5QWNjZXNzCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestStaticBoolArrayUpdate.approval.teal b/tests/contracts/artifacts/ABITestStaticBoolArrayUpdate.approval.teal index 66323a47b..68d5afcf2 100644 --- a/tests/contracts/artifacts/ABITestStaticBoolArrayUpdate.approval.teal +++ b/tests/contracts/artifacts/ABITestStaticBoolArrayUpdate.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 intcblock 1 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestStaticBoolArrayUpdate.arc32.json b/tests/contracts/artifacts/ABITestStaticBoolArrayUpdate.arc32.json index d786ee916..00903f3d7 100644 --- a/tests/contracts/artifacts/ABITestStaticBoolArrayUpdate.arc32.json +++ b/tests/contracts/artifacts/ABITestStaticBoolArrayUpdate.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmludGNibG9jayAxCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RhdGljQm9vbEFycmF5VXBkYXRlKClib29sWzldCiphYmlfcm91dGVfc3RhdGljQm9vbEFycmF5VXBkYXRlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgc3RhdGljQm9vbEFycmF5VXBkYXRlKClib29sWzldCgljYWxsc3ViIHN0YXRpY0Jvb2xBcnJheVVwZGF0ZQoJY29uY2F0Cglsb2cKCWludCAxCglyZXR1cm4KCi8vIHN0YXRpY0Jvb2xBcnJheVVwZGF0ZSgpOiBTdGF0aWNBcnJheTxib29sZWFuLCA5PgpzdGF0aWNCb29sQXJyYXlVcGRhdGU6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjk0NwoJLy8gYTogU3RhdGljQXJyYXk8Ym9vbGVhbiwgOT4gPSBbdHJ1ZSwgZmFsc2UsIHRydWUsIHRydWUsIGZhbHNlLCBmYWxzZSwgdHJ1ZSwgZmFsc2UsIGZhbHNlXQoJcHVzaGJ5dGVzIDB4MDAwMAoJcHVzaGludCAwCglpbnQgMQoJc2V0Yml0CglpbnQgMQoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgMgoJaW50IDEKCXNldGJpdAoJcHVzaGludCAzCglpbnQgMQoJc2V0Yml0CglwdXNoaW50IDQKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDUKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDYKCWludCAxCglzZXRiaXQKCXB1c2hpbnQgNwoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgOAoJcHVzaGludCAwCglzZXRiaXQKCWZyYW1lX2J1cnkgMCAvLyBhOiBTdGF0aWNBcnJheTxib29sZWFuLCA5PgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo5NDkKCS8vIGFbOF0gPSB0cnVlCglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTxib29sZWFuLCA5PgoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgOAoJaW50IDEKCXNldGJpdAoJZnJhbWVfYnVyeSAwIC8vIGE6IFN0YXRpY0FycmF5PGJvb2xlYW4sIDk+CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjk1MQoJLy8gcmV0dXJuIGE7CglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTxib29sZWFuLCA5PgoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDgxMjcwZjM0IC8vIG1ldGhvZCAic3RhdGljQm9vbEFycmF5VXBkYXRlKClib29sWzldIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9zdGF0aWNCb29sQXJyYXlVcGRhdGUKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmludGNibG9jayAxCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RhdGljQm9vbEFycmF5VXBkYXRlKClib29sWzldCiphYmlfcm91dGVfc3RhdGljQm9vbEFycmF5VXBkYXRlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgc3RhdGljQm9vbEFycmF5VXBkYXRlKClib29sWzldCgljYWxsc3ViIHN0YXRpY0Jvb2xBcnJheVVwZGF0ZQoJY29uY2F0Cglsb2cKCWludCAxCglyZXR1cm4KCi8vIHN0YXRpY0Jvb2xBcnJheVVwZGF0ZSgpOiBTdGF0aWNBcnJheTxib29sZWFuLCA5PgpzdGF0aWNCb29sQXJyYXlVcGRhdGU6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjk0NwoJLy8gYTogU3RhdGljQXJyYXk8Ym9vbGVhbiwgOT4gPSBbdHJ1ZSwgZmFsc2UsIHRydWUsIHRydWUsIGZhbHNlLCBmYWxzZSwgdHJ1ZSwgZmFsc2UsIGZhbHNlXQoJcHVzaGJ5dGVzIDB4MDAwMAoJcHVzaGludCAwCglpbnQgMQoJc2V0Yml0CglpbnQgMQoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgMgoJaW50IDEKCXNldGJpdAoJcHVzaGludCAzCglpbnQgMQoJc2V0Yml0CglwdXNoaW50IDQKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDUKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDYKCWludCAxCglzZXRiaXQKCXB1c2hpbnQgNwoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgOAoJcHVzaGludCAwCglzZXRiaXQKCWZyYW1lX2J1cnkgMCAvLyBhOiBTdGF0aWNBcnJheTxib29sZWFuLCA5PgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo5NDkKCS8vIGFbOF0gPSB0cnVlCglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTxib29sZWFuLCA5PgoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgOAoJaW50IDEKCXNldGJpdAoJZnJhbWVfYnVyeSAwIC8vIGE6IFN0YXRpY0FycmF5PGJvb2xlYW4sIDk+CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjk1MQoJLy8gcmV0dXJuIGE7CglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTxib29sZWFuLCA5PgoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDgxMjcwZjM0IC8vIG1ldGhvZCAic3RhdGljQm9vbEFycmF5VXBkYXRlKClib29sWzldIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9zdGF0aWNCb29sQXJyYXlVcGRhdGUKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestStaticBoolArrayUpdate.arc56_draft.json b/tests/contracts/artifacts/ABITestStaticBoolArrayUpdate.arc56_draft.json index 06191823c..945c4ae38 100644 --- a/tests/contracts/artifacts/ABITestStaticBoolArrayUpdate.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestStaticBoolArrayUpdate.arc56_draft.json @@ -636,7 +636,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmludGNibG9jayAxCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RhdGljQm9vbEFycmF5VXBkYXRlKClib29sWzldCiphYmlfcm91dGVfc3RhdGljQm9vbEFycmF5VXBkYXRlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgc3RhdGljQm9vbEFycmF5VXBkYXRlKClib29sWzldCgljYWxsc3ViIHN0YXRpY0Jvb2xBcnJheVVwZGF0ZQoJY29uY2F0Cglsb2cKCWludCAxCglyZXR1cm4KCi8vIHN0YXRpY0Jvb2xBcnJheVVwZGF0ZSgpOiBTdGF0aWNBcnJheTxib29sZWFuLCA5PgpzdGF0aWNCb29sQXJyYXlVcGRhdGU6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjk0NwoJLy8gYTogU3RhdGljQXJyYXk8Ym9vbGVhbiwgOT4gPSBbdHJ1ZSwgZmFsc2UsIHRydWUsIHRydWUsIGZhbHNlLCBmYWxzZSwgdHJ1ZSwgZmFsc2UsIGZhbHNlXQoJcHVzaGJ5dGVzIDB4MDAwMAoJcHVzaGludCAwCglpbnQgMQoJc2V0Yml0CglpbnQgMQoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgMgoJaW50IDEKCXNldGJpdAoJcHVzaGludCAzCglpbnQgMQoJc2V0Yml0CglwdXNoaW50IDQKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDUKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDYKCWludCAxCglzZXRiaXQKCXB1c2hpbnQgNwoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgOAoJcHVzaGludCAwCglzZXRiaXQKCWZyYW1lX2J1cnkgMCAvLyBhOiBTdGF0aWNBcnJheTxib29sZWFuLCA5PgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo5NDkKCS8vIGFbOF0gPSB0cnVlCglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTxib29sZWFuLCA5PgoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgOAoJaW50IDEKCXNldGJpdAoJZnJhbWVfYnVyeSAwIC8vIGE6IFN0YXRpY0FycmF5PGJvb2xlYW4sIDk+CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjk1MQoJLy8gcmV0dXJuIGE7CglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTxib29sZWFuLCA5PgoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDgxMjcwZjM0IC8vIG1ldGhvZCAic3RhdGljQm9vbEFycmF5VXBkYXRlKClib29sWzldIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9zdGF0aWNCb29sQXJyYXlVcGRhdGUKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmludGNibG9jayAxCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RhdGljQm9vbEFycmF5VXBkYXRlKClib29sWzldCiphYmlfcm91dGVfc3RhdGljQm9vbEFycmF5VXBkYXRlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgc3RhdGljQm9vbEFycmF5VXBkYXRlKClib29sWzldCgljYWxsc3ViIHN0YXRpY0Jvb2xBcnJheVVwZGF0ZQoJY29uY2F0Cglsb2cKCWludCAxCglyZXR1cm4KCi8vIHN0YXRpY0Jvb2xBcnJheVVwZGF0ZSgpOiBTdGF0aWNBcnJheTxib29sZWFuLCA5PgpzdGF0aWNCb29sQXJyYXlVcGRhdGU6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjk0NwoJLy8gYTogU3RhdGljQXJyYXk8Ym9vbGVhbiwgOT4gPSBbdHJ1ZSwgZmFsc2UsIHRydWUsIHRydWUsIGZhbHNlLCBmYWxzZSwgdHJ1ZSwgZmFsc2UsIGZhbHNlXQoJcHVzaGJ5dGVzIDB4MDAwMAoJcHVzaGludCAwCglpbnQgMQoJc2V0Yml0CglpbnQgMQoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgMgoJaW50IDEKCXNldGJpdAoJcHVzaGludCAzCglpbnQgMQoJc2V0Yml0CglwdXNoaW50IDQKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDUKCXB1c2hpbnQgMAoJc2V0Yml0CglwdXNoaW50IDYKCWludCAxCglzZXRiaXQKCXB1c2hpbnQgNwoJcHVzaGludCAwCglzZXRiaXQKCXB1c2hpbnQgOAoJcHVzaGludCAwCglzZXRiaXQKCWZyYW1lX2J1cnkgMCAvLyBhOiBTdGF0aWNBcnJheTxib29sZWFuLCA5PgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo5NDkKCS8vIGFbOF0gPSB0cnVlCglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTxib29sZWFuLCA5PgoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgOAoJaW50IDEKCXNldGJpdAoJZnJhbWVfYnVyeSAwIC8vIGE6IFN0YXRpY0FycmF5PGJvb2xlYW4sIDk+CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjk1MQoJLy8gcmV0dXJuIGE7CglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTxib29sZWFuLCA5PgoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDgxMjcwZjM0IC8vIG1ldGhvZCAic3RhdGljQm9vbEFycmF5VXBkYXRlKClib29sWzldIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9zdGF0aWNCb29sQXJyYXlVcGRhdGUKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestStaticByteCasting.approval.teal b/tests/contracts/artifacts/ABITestStaticByteCasting.approval.teal index 150b15b34..82aef58d3 100644 --- a/tests/contracts/artifacts/ABITestStaticByteCasting.approval.teal +++ b/tests/contracts/artifacts/ABITestStaticByteCasting.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestStaticByteCasting.arc32.json b/tests/contracts/artifacts/ABITestStaticByteCasting.arc32.json index 1faabb8c3..9a5352321 100644 --- a/tests/contracts/artifacts/ABITestStaticByteCasting.arc32.json +++ b/tests/contracts/artifacts/ABITestStaticByteCasting.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RhdGljQnl0ZUNhc3RpbmcoKWJ5dGVbNV0KKmFiaV9yb3V0ZV9zdGF0aWNCeXRlQ2FzdGluZzoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHN0YXRpY0J5dGVDYXN0aW5nKClieXRlWzVdCgljYWxsc3ViIHN0YXRpY0J5dGVDYXN0aW5nCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHN0YXRpY0J5dGVDYXN0aW5nKCk6IGJ5dGVzPDU+CnN0YXRpY0J5dGVDYXN0aW5nOgoJcHJvdG8gMCAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEwNDEKCS8vIHJldHVybiAnYWJjJyBhcyBieXRlczw1PjsKCXB1c2hieXRlcyAweDYxNjI2MzAwMDAgLy8gImFiYyIKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ODNmYjViNTUgLy8gbWV0aG9kICJzdGF0aWNCeXRlQ2FzdGluZygpYnl0ZVs1XSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RhdGljQnl0ZUNhc3RpbmcKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RhdGljQnl0ZUNhc3RpbmcoKWJ5dGVbNV0KKmFiaV9yb3V0ZV9zdGF0aWNCeXRlQ2FzdGluZzoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHN0YXRpY0J5dGVDYXN0aW5nKClieXRlWzVdCgljYWxsc3ViIHN0YXRpY0J5dGVDYXN0aW5nCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHN0YXRpY0J5dGVDYXN0aW5nKCk6IGJ5dGVzPDU+CnN0YXRpY0J5dGVDYXN0aW5nOgoJcHJvdG8gMCAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEwNDEKCS8vIHJldHVybiAnYWJjJyBhcyBieXRlczw1PjsKCXB1c2hieXRlcyAweDYxNjI2MzAwMDAgLy8gImFiYyIKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ODNmYjViNTUgLy8gbWV0aG9kICJzdGF0aWNCeXRlQ2FzdGluZygpYnl0ZVs1XSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RhdGljQnl0ZUNhc3RpbmcKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestStaticByteCasting.arc56_draft.json b/tests/contracts/artifacts/ABITestStaticByteCasting.arc56_draft.json index 1180e580e..3ff268bce 100644 --- a/tests/contracts/artifacts/ABITestStaticByteCasting.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestStaticByteCasting.arc56_draft.json @@ -336,7 +336,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RhdGljQnl0ZUNhc3RpbmcoKWJ5dGVbNV0KKmFiaV9yb3V0ZV9zdGF0aWNCeXRlQ2FzdGluZzoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHN0YXRpY0J5dGVDYXN0aW5nKClieXRlWzVdCgljYWxsc3ViIHN0YXRpY0J5dGVDYXN0aW5nCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHN0YXRpY0J5dGVDYXN0aW5nKCk6IGJ5dGVzPDU+CnN0YXRpY0J5dGVDYXN0aW5nOgoJcHJvdG8gMCAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEwNDEKCS8vIHJldHVybiAnYWJjJyBhcyBieXRlczw1PjsKCXB1c2hieXRlcyAweDYxNjI2MzAwMDAgLy8gImFiYyIKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ODNmYjViNTUgLy8gbWV0aG9kICJzdGF0aWNCeXRlQ2FzdGluZygpYnl0ZVs1XSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RhdGljQnl0ZUNhc3RpbmcKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RhdGljQnl0ZUNhc3RpbmcoKWJ5dGVbNV0KKmFiaV9yb3V0ZV9zdGF0aWNCeXRlQ2FzdGluZzoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHN0YXRpY0J5dGVDYXN0aW5nKClieXRlWzVdCgljYWxsc3ViIHN0YXRpY0J5dGVDYXN0aW5nCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHN0YXRpY0J5dGVDYXN0aW5nKCk6IGJ5dGVzPDU+CnN0YXRpY0J5dGVDYXN0aW5nOgoJcHJvdG8gMCAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEwNDEKCS8vIHJldHVybiAnYWJjJyBhcyBieXRlczw1PjsKCXB1c2hieXRlcyAweDYxNjI2MzAwMDAgLy8gImFiYyIKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ODNmYjViNTUgLy8gbWV0aG9kICJzdGF0aWNCeXRlQ2FzdGluZygpYnl0ZVs1XSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RhdGljQnl0ZUNhc3RpbmcKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestStaticForEach.approval.teal b/tests/contracts/artifacts/ABITestStaticForEach.approval.teal index cd87203aa..19ddf06f1 100644 --- a/tests/contracts/artifacts/ABITestStaticForEach.approval.teal +++ b/tests/contracts/artifacts/ABITestStaticForEach.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestStaticForEach.arc32.json b/tests/contracts/artifacts/ABITestStaticForEach.arc32.json index 79d90bab0..7b2649acc 100644 --- a/tests/contracts/artifacts/ABITestStaticForEach.arc32.json +++ b/tests/contracts/artifacts/ABITestStaticForEach.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBzdGF0aWNGb3JFYWNoKCl1aW50NjQKKmFiaV9yb3V0ZV9zdGF0aWNGb3JFYWNoOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgc3RhdGljRm9yRWFjaCgpdWludDY0CgljYWxsc3ViIHN0YXRpY0ZvckVhY2gKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gc3RhdGljRm9yRWFjaCgpOiB1aW50NjQKc3RhdGljRm9yRWFjaDoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXBuIDQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTMwOAoJLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPiA9IFsxLCAyLCAzXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMTAwMDAwMDAwMDAwMDAwMDIwMDAwMDAwMDAwMDAwMDAzCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMzA5CgkvLyBzdW0gPSAwCglwdXNoaW50IDAKCWZyYW1lX2J1cnkgMSAvLyBzdW06IHVpbnQ2NAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMzExCgkvLyBhLmZvckVhY2gKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCWR1cAoJZnJhbWVfYnVyeSAyIC8vIGNvcHkgb2YgdGhlIGFycmF5IHdlIGFyZSBpdGVyYXRpbmcgb3ZlcgoJZXh0cmFjdCAwIDgKCWJ0b2kKCWZyYW1lX2J1cnkgMyAvLyB2OiB1aW50NjQKCXB1c2hpbnQgMAoJZnJhbWVfYnVyeSA0IC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCgoqZm9yRWFjaF8wOgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzMTIKCS8vIHN1bSArPSB2CglmcmFtZV9kaWcgMSAvLyBzdW06IHVpbnQ2NAoJZnJhbWVfZGlnIDMgLy8gdjogdWludDY0CgkrCglmcmFtZV9idXJ5IDEgLy8gc3VtOiB1aW50NjQKCgkvLyBpbmNyZW1lbnQgb2Zmc2V0IGFuZCBsb29wIGlmIG5vdCBvdXQgb2YgYm91bmRzCglmcmFtZV9kaWcgNCAvLyB0aGUgb2Zmc2V0IHdlIGFyZSBleHRyYWN0aW5nIHRoZSBuZXh0IGVsZW1lbnQgZnJvbQoJcHVzaGludCA4CgkrCglkdXAKCXB1c2hpbnQgMjQgLy8gb2Zmc2V0IG9mIGxhc3QgZWxlbWVudAoJPAoJYnogKmZvckVhY2hfMF9lbmQKCWZyYW1lX2J1cnkgNCAvLyB0aGUgb2Zmc2V0IHdlIGFyZSBleHRyYWN0aW5nIHRoZSBuZXh0IGVsZW1lbnQgZnJvbQoJZnJhbWVfZGlnIDIgLy8gY29weSBvZiB0aGUgYXJyYXkgd2UgYXJlIGl0ZXJhdGluZyBvdmVyCglmcmFtZV9kaWcgNCAvLyB0aGUgb2Zmc2V0IHdlIGFyZSBleHRyYWN0aW5nIHRoZSBuZXh0IGVsZW1lbnQgZnJvbQoJcHVzaGludCA4CglleHRyYWN0CglidG9pCglmcmFtZV9idXJ5IDMgLy8gdjogdWludDY0CgliICpmb3JFYWNoXzAKCipmb3JFYWNoXzBfZW5kOgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzMTQKCS8vIHJldHVybiBzdW07CglmcmFtZV9kaWcgMSAvLyBzdW06IHVpbnQ2NAoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoKCS8vIHBvcCBhbGwgbG9jYWwgdmFyaWFibGVzIGZyb20gdGhlIHN0YWNrCglwb3BuIDQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YzJjNThmOWYgLy8gbWV0aG9kICJzdGF0aWNGb3JFYWNoKCl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3N0YXRpY0ZvckVhY2gKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBzdGF0aWNGb3JFYWNoKCl1aW50NjQKKmFiaV9yb3V0ZV9zdGF0aWNGb3JFYWNoOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgc3RhdGljRm9yRWFjaCgpdWludDY0CgljYWxsc3ViIHN0YXRpY0ZvckVhY2gKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gc3RhdGljRm9yRWFjaCgpOiB1aW50NjQKc3RhdGljRm9yRWFjaDoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXBuIDQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTMwOAoJLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPiA9IFsxLCAyLCAzXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMTAwMDAwMDAwMDAwMDAwMDIwMDAwMDAwMDAwMDAwMDAzCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMzA5CgkvLyBzdW0gPSAwCglwdXNoaW50IDAKCWZyYW1lX2J1cnkgMSAvLyBzdW06IHVpbnQ2NAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMzExCgkvLyBhLmZvckVhY2gKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCWR1cAoJZnJhbWVfYnVyeSAyIC8vIGNvcHkgb2YgdGhlIGFycmF5IHdlIGFyZSBpdGVyYXRpbmcgb3ZlcgoJZXh0cmFjdCAwIDgKCWJ0b2kKCWZyYW1lX2J1cnkgMyAvLyB2OiB1aW50NjQKCXB1c2hpbnQgMAoJZnJhbWVfYnVyeSA0IC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCgoqZm9yRWFjaF8wOgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzMTIKCS8vIHN1bSArPSB2CglmcmFtZV9kaWcgMSAvLyBzdW06IHVpbnQ2NAoJZnJhbWVfZGlnIDMgLy8gdjogdWludDY0CgkrCglmcmFtZV9idXJ5IDEgLy8gc3VtOiB1aW50NjQKCgkvLyBpbmNyZW1lbnQgb2Zmc2V0IGFuZCBsb29wIGlmIG5vdCBvdXQgb2YgYm91bmRzCglmcmFtZV9kaWcgNCAvLyB0aGUgb2Zmc2V0IHdlIGFyZSBleHRyYWN0aW5nIHRoZSBuZXh0IGVsZW1lbnQgZnJvbQoJcHVzaGludCA4CgkrCglkdXAKCXB1c2hpbnQgMjQgLy8gb2Zmc2V0IG9mIGxhc3QgZWxlbWVudAoJPAoJYnogKmZvckVhY2hfMF9lbmQKCWZyYW1lX2J1cnkgNCAvLyB0aGUgb2Zmc2V0IHdlIGFyZSBleHRyYWN0aW5nIHRoZSBuZXh0IGVsZW1lbnQgZnJvbQoJZnJhbWVfZGlnIDIgLy8gY29weSBvZiB0aGUgYXJyYXkgd2UgYXJlIGl0ZXJhdGluZyBvdmVyCglmcmFtZV9kaWcgNCAvLyB0aGUgb2Zmc2V0IHdlIGFyZSBleHRyYWN0aW5nIHRoZSBuZXh0IGVsZW1lbnQgZnJvbQoJcHVzaGludCA4CglleHRyYWN0CglidG9pCglmcmFtZV9idXJ5IDMgLy8gdjogdWludDY0CgliICpmb3JFYWNoXzAKCipmb3JFYWNoXzBfZW5kOgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzMTQKCS8vIHJldHVybiBzdW07CglmcmFtZV9kaWcgMSAvLyBzdW06IHVpbnQ2NAoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoKCS8vIHBvcCBhbGwgbG9jYWwgdmFyaWFibGVzIGZyb20gdGhlIHN0YWNrCglwb3BuIDQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YzJjNThmOWYgLy8gbWV0aG9kICJzdGF0aWNGb3JFYWNoKCl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3N0YXRpY0ZvckVhY2gKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestStaticForEach.arc56_draft.json b/tests/contracts/artifacts/ABITestStaticForEach.arc56_draft.json index 1f2647253..7d24e7edd 100644 --- a/tests/contracts/artifacts/ABITestStaticForEach.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestStaticForEach.arc56_draft.json @@ -646,7 +646,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBzdGF0aWNGb3JFYWNoKCl1aW50NjQKKmFiaV9yb3V0ZV9zdGF0aWNGb3JFYWNoOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgc3RhdGljRm9yRWFjaCgpdWludDY0CgljYWxsc3ViIHN0YXRpY0ZvckVhY2gKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gc3RhdGljRm9yRWFjaCgpOiB1aW50NjQKc3RhdGljRm9yRWFjaDoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXBuIDQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTMwOAoJLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPiA9IFsxLCAyLCAzXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMTAwMDAwMDAwMDAwMDAwMDIwMDAwMDAwMDAwMDAwMDAzCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMzA5CgkvLyBzdW0gPSAwCglwdXNoaW50IDAKCWZyYW1lX2J1cnkgMSAvLyBzdW06IHVpbnQ2NAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMzExCgkvLyBhLmZvckVhY2gKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCWR1cAoJZnJhbWVfYnVyeSAyIC8vIGNvcHkgb2YgdGhlIGFycmF5IHdlIGFyZSBpdGVyYXRpbmcgb3ZlcgoJZXh0cmFjdCAwIDgKCWJ0b2kKCWZyYW1lX2J1cnkgMyAvLyB2OiB1aW50NjQKCXB1c2hpbnQgMAoJZnJhbWVfYnVyeSA0IC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCgoqZm9yRWFjaF8wOgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzMTIKCS8vIHN1bSArPSB2CglmcmFtZV9kaWcgMSAvLyBzdW06IHVpbnQ2NAoJZnJhbWVfZGlnIDMgLy8gdjogdWludDY0CgkrCglmcmFtZV9idXJ5IDEgLy8gc3VtOiB1aW50NjQKCgkvLyBpbmNyZW1lbnQgb2Zmc2V0IGFuZCBsb29wIGlmIG5vdCBvdXQgb2YgYm91bmRzCglmcmFtZV9kaWcgNCAvLyB0aGUgb2Zmc2V0IHdlIGFyZSBleHRyYWN0aW5nIHRoZSBuZXh0IGVsZW1lbnQgZnJvbQoJcHVzaGludCA4CgkrCglkdXAKCXB1c2hpbnQgMjQgLy8gb2Zmc2V0IG9mIGxhc3QgZWxlbWVudAoJPAoJYnogKmZvckVhY2hfMF9lbmQKCWZyYW1lX2J1cnkgNCAvLyB0aGUgb2Zmc2V0IHdlIGFyZSBleHRyYWN0aW5nIHRoZSBuZXh0IGVsZW1lbnQgZnJvbQoJZnJhbWVfZGlnIDIgLy8gY29weSBvZiB0aGUgYXJyYXkgd2UgYXJlIGl0ZXJhdGluZyBvdmVyCglmcmFtZV9kaWcgNCAvLyB0aGUgb2Zmc2V0IHdlIGFyZSBleHRyYWN0aW5nIHRoZSBuZXh0IGVsZW1lbnQgZnJvbQoJcHVzaGludCA4CglleHRyYWN0CglidG9pCglmcmFtZV9idXJ5IDMgLy8gdjogdWludDY0CgliICpmb3JFYWNoXzAKCipmb3JFYWNoXzBfZW5kOgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzMTQKCS8vIHJldHVybiBzdW07CglmcmFtZV9kaWcgMSAvLyBzdW06IHVpbnQ2NAoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoKCS8vIHBvcCBhbGwgbG9jYWwgdmFyaWFibGVzIGZyb20gdGhlIHN0YWNrCglwb3BuIDQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YzJjNThmOWYgLy8gbWV0aG9kICJzdGF0aWNGb3JFYWNoKCl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3N0YXRpY0ZvckVhY2gKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBzdGF0aWNGb3JFYWNoKCl1aW50NjQKKmFiaV9yb3V0ZV9zdGF0aWNGb3JFYWNoOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgc3RhdGljRm9yRWFjaCgpdWludDY0CgljYWxsc3ViIHN0YXRpY0ZvckVhY2gKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gc3RhdGljRm9yRWFjaCgpOiB1aW50NjQKc3RhdGljRm9yRWFjaDoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXBuIDQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTMwOAoJLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPiA9IFsxLCAyLCAzXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMTAwMDAwMDAwMDAwMDAwMDIwMDAwMDAwMDAwMDAwMDAzCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMzA5CgkvLyBzdW0gPSAwCglwdXNoaW50IDAKCWZyYW1lX2J1cnkgMSAvLyBzdW06IHVpbnQ2NAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMzExCgkvLyBhLmZvckVhY2gKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCWR1cAoJZnJhbWVfYnVyeSAyIC8vIGNvcHkgb2YgdGhlIGFycmF5IHdlIGFyZSBpdGVyYXRpbmcgb3ZlcgoJZXh0cmFjdCAwIDgKCWJ0b2kKCWZyYW1lX2J1cnkgMyAvLyB2OiB1aW50NjQKCXB1c2hpbnQgMAoJZnJhbWVfYnVyeSA0IC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCgoqZm9yRWFjaF8wOgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzMTIKCS8vIHN1bSArPSB2CglmcmFtZV9kaWcgMSAvLyBzdW06IHVpbnQ2NAoJZnJhbWVfZGlnIDMgLy8gdjogdWludDY0CgkrCglmcmFtZV9idXJ5IDEgLy8gc3VtOiB1aW50NjQKCgkvLyBpbmNyZW1lbnQgb2Zmc2V0IGFuZCBsb29wIGlmIG5vdCBvdXQgb2YgYm91bmRzCglmcmFtZV9kaWcgNCAvLyB0aGUgb2Zmc2V0IHdlIGFyZSBleHRyYWN0aW5nIHRoZSBuZXh0IGVsZW1lbnQgZnJvbQoJcHVzaGludCA4CgkrCglkdXAKCXB1c2hpbnQgMjQgLy8gb2Zmc2V0IG9mIGxhc3QgZWxlbWVudAoJPAoJYnogKmZvckVhY2hfMF9lbmQKCWZyYW1lX2J1cnkgNCAvLyB0aGUgb2Zmc2V0IHdlIGFyZSBleHRyYWN0aW5nIHRoZSBuZXh0IGVsZW1lbnQgZnJvbQoJZnJhbWVfZGlnIDIgLy8gY29weSBvZiB0aGUgYXJyYXkgd2UgYXJlIGl0ZXJhdGluZyBvdmVyCglmcmFtZV9kaWcgNCAvLyB0aGUgb2Zmc2V0IHdlIGFyZSBleHRyYWN0aW5nIHRoZSBuZXh0IGVsZW1lbnQgZnJvbQoJcHVzaGludCA4CglleHRyYWN0CglidG9pCglmcmFtZV9idXJ5IDMgLy8gdjogdWludDY0CgliICpmb3JFYWNoXzAKCipmb3JFYWNoXzBfZW5kOgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzMTQKCS8vIHJldHVybiBzdW07CglmcmFtZV9kaWcgMSAvLyBzdW06IHVpbnQ2NAoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoKCS8vIHBvcCBhbGwgbG9jYWwgdmFyaWFibGVzIGZyb20gdGhlIHN0YWNrCglwb3BuIDQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YzJjNThmOWYgLy8gbWV0aG9kICJzdGF0aWNGb3JFYWNoKCl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3N0YXRpY0ZvckVhY2gKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestStaticForOf.approval.teal b/tests/contracts/artifacts/ABITestStaticForOf.approval.teal index 2370d3f7f..b469f0fab 100644 --- a/tests/contracts/artifacts/ABITestStaticForOf.approval.teal +++ b/tests/contracts/artifacts/ABITestStaticForOf.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestStaticForOf.arc32.json b/tests/contracts/artifacts/ABITestStaticForOf.arc32.json index 48df3c726..6688cd4b1 100644 --- a/tests/contracts/artifacts/ABITestStaticForOf.arc32.json +++ b/tests/contracts/artifacts/ABITestStaticForOf.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBzdGF0aWNGb3JPZigpdWludDY0CiphYmlfcm91dGVfc3RhdGljRm9yT2Y6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBzdGF0aWNGb3JPZigpdWludDY0CgljYWxsc3ViIHN0YXRpY0Zvck9mCglpdG9iCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHN0YXRpY0Zvck9mKCk6IHVpbnQ2NApzdGF0aWNGb3JPZjoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXBuIDQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTQ1MwoJLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPiA9IFsxLCAyLCAzXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMTAwMDAwMDAwMDAwMDAwMDIwMDAwMDAwMDAwMDAwMDAzCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNDU0CgkvLyBzdW0gPSAwCglwdXNoaW50IDAKCWZyYW1lX2J1cnkgMSAvLyBzdW06IHVpbnQ2NAoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoJZHVwCglmcmFtZV9idXJ5IDIgLy8gY29weSBvZiB0aGUgYXJyYXkgd2UgYXJlIGl0ZXJhdGluZyBvdmVyCglleHRyYWN0IDAgOAoJYnRvaQoJZnJhbWVfYnVyeSAzIC8vIHY6IHVpbnQ2NAoJcHVzaGludCAwCglmcmFtZV9idXJ5IDQgLy8gdGhlIG9mZnNldCB3ZSBhcmUgZXh0cmFjdGluZyB0aGUgbmV4dCBlbGVtZW50IGZyb20KCipmb3JPZl8wOgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0NTgKCS8vIHN1bSArPSB2CglmcmFtZV9kaWcgMSAvLyBzdW06IHVpbnQ2NAoJZnJhbWVfZGlnIDMgLy8gdjogdWludDY0CgkrCglmcmFtZV9idXJ5IDEgLy8gc3VtOiB1aW50NjQKCipmb3JPZl8wX2NvbnRpbnVlOgoJLy8gaW5jcmVtZW50IG9mZnNldCBhbmQgbG9vcCBpZiBub3Qgb3V0IG9mIGJvdW5kcwoJZnJhbWVfZGlnIDQgLy8gdGhlIG9mZnNldCB3ZSBhcmUgZXh0cmFjdGluZyB0aGUgbmV4dCBlbGVtZW50IGZyb20KCXB1c2hpbnQgOAoJKwoJZHVwCglwdXNoaW50IDI0IC8vIG9mZnNldCBvZiBsYXN0IGVsZW1lbnQKCTwKCWJ6ICpmb3JPZl8wX2VuZAoJZnJhbWVfYnVyeSA0IC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglmcmFtZV9kaWcgMiAvLyBjb3B5IG9mIHRoZSBhcnJheSB3ZSBhcmUgaXRlcmF0aW5nIG92ZXIKCWZyYW1lX2RpZyA0IC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglwdXNoaW50IDgKCWV4dHJhY3QKCWJ0b2kKCWZyYW1lX2J1cnkgMyAvLyB2OiB1aW50NjQKCWIgKmZvck9mXzAKCipmb3JPZl8wX2VuZDoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNDYwCgkvLyByZXR1cm4gc3VtOwoJZnJhbWVfZGlnIDEgLy8gc3VtOiB1aW50NjQKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCgkvLyBwb3AgYWxsIGxvY2FsIHZhcmlhYmxlcyBmcm9tIHRoZSBzdGFjawoJcG9wbiA0CglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDgwYzliNDc5IC8vIG1ldGhvZCAic3RhdGljRm9yT2YoKXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RhdGljRm9yT2YKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBzdGF0aWNGb3JPZigpdWludDY0CiphYmlfcm91dGVfc3RhdGljRm9yT2Y6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBzdGF0aWNGb3JPZigpdWludDY0CgljYWxsc3ViIHN0YXRpY0Zvck9mCglpdG9iCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHN0YXRpY0Zvck9mKCk6IHVpbnQ2NApzdGF0aWNGb3JPZjoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXBuIDQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTQ1MwoJLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPiA9IFsxLCAyLCAzXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMTAwMDAwMDAwMDAwMDAwMDIwMDAwMDAwMDAwMDAwMDAzCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNDU0CgkvLyBzdW0gPSAwCglwdXNoaW50IDAKCWZyYW1lX2J1cnkgMSAvLyBzdW06IHVpbnQ2NAoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoJZHVwCglmcmFtZV9idXJ5IDIgLy8gY29weSBvZiB0aGUgYXJyYXkgd2UgYXJlIGl0ZXJhdGluZyBvdmVyCglleHRyYWN0IDAgOAoJYnRvaQoJZnJhbWVfYnVyeSAzIC8vIHY6IHVpbnQ2NAoJcHVzaGludCAwCglmcmFtZV9idXJ5IDQgLy8gdGhlIG9mZnNldCB3ZSBhcmUgZXh0cmFjdGluZyB0aGUgbmV4dCBlbGVtZW50IGZyb20KCipmb3JPZl8wOgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0NTgKCS8vIHN1bSArPSB2CglmcmFtZV9kaWcgMSAvLyBzdW06IHVpbnQ2NAoJZnJhbWVfZGlnIDMgLy8gdjogdWludDY0CgkrCglmcmFtZV9idXJ5IDEgLy8gc3VtOiB1aW50NjQKCipmb3JPZl8wX2NvbnRpbnVlOgoJLy8gaW5jcmVtZW50IG9mZnNldCBhbmQgbG9vcCBpZiBub3Qgb3V0IG9mIGJvdW5kcwoJZnJhbWVfZGlnIDQgLy8gdGhlIG9mZnNldCB3ZSBhcmUgZXh0cmFjdGluZyB0aGUgbmV4dCBlbGVtZW50IGZyb20KCXB1c2hpbnQgOAoJKwoJZHVwCglwdXNoaW50IDI0IC8vIG9mZnNldCBvZiBsYXN0IGVsZW1lbnQKCTwKCWJ6ICpmb3JPZl8wX2VuZAoJZnJhbWVfYnVyeSA0IC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglmcmFtZV9kaWcgMiAvLyBjb3B5IG9mIHRoZSBhcnJheSB3ZSBhcmUgaXRlcmF0aW5nIG92ZXIKCWZyYW1lX2RpZyA0IC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglwdXNoaW50IDgKCWV4dHJhY3QKCWJ0b2kKCWZyYW1lX2J1cnkgMyAvLyB2OiB1aW50NjQKCWIgKmZvck9mXzAKCipmb3JPZl8wX2VuZDoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNDYwCgkvLyByZXR1cm4gc3VtOwoJZnJhbWVfZGlnIDEgLy8gc3VtOiB1aW50NjQKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCgkvLyBwb3AgYWxsIGxvY2FsIHZhcmlhYmxlcyBmcm9tIHRoZSBzdGFjawoJcG9wbiA0CglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDgwYzliNDc5IC8vIG1ldGhvZCAic3RhdGljRm9yT2YoKXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RhdGljRm9yT2YKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestStaticForOf.arc56_draft.json b/tests/contracts/artifacts/ABITestStaticForOf.arc56_draft.json index 693eab777..85b023870 100644 --- a/tests/contracts/artifacts/ABITestStaticForOf.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestStaticForOf.arc56_draft.json @@ -646,7 +646,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBzdGF0aWNGb3JPZigpdWludDY0CiphYmlfcm91dGVfc3RhdGljRm9yT2Y6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBzdGF0aWNGb3JPZigpdWludDY0CgljYWxsc3ViIHN0YXRpY0Zvck9mCglpdG9iCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHN0YXRpY0Zvck9mKCk6IHVpbnQ2NApzdGF0aWNGb3JPZjoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXBuIDQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTQ1MwoJLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPiA9IFsxLCAyLCAzXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMTAwMDAwMDAwMDAwMDAwMDIwMDAwMDAwMDAwMDAwMDAzCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNDU0CgkvLyBzdW0gPSAwCglwdXNoaW50IDAKCWZyYW1lX2J1cnkgMSAvLyBzdW06IHVpbnQ2NAoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoJZHVwCglmcmFtZV9idXJ5IDIgLy8gY29weSBvZiB0aGUgYXJyYXkgd2UgYXJlIGl0ZXJhdGluZyBvdmVyCglleHRyYWN0IDAgOAoJYnRvaQoJZnJhbWVfYnVyeSAzIC8vIHY6IHVpbnQ2NAoJcHVzaGludCAwCglmcmFtZV9idXJ5IDQgLy8gdGhlIG9mZnNldCB3ZSBhcmUgZXh0cmFjdGluZyB0aGUgbmV4dCBlbGVtZW50IGZyb20KCipmb3JPZl8wOgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0NTgKCS8vIHN1bSArPSB2CglmcmFtZV9kaWcgMSAvLyBzdW06IHVpbnQ2NAoJZnJhbWVfZGlnIDMgLy8gdjogdWludDY0CgkrCglmcmFtZV9idXJ5IDEgLy8gc3VtOiB1aW50NjQKCipmb3JPZl8wX2NvbnRpbnVlOgoJLy8gaW5jcmVtZW50IG9mZnNldCBhbmQgbG9vcCBpZiBub3Qgb3V0IG9mIGJvdW5kcwoJZnJhbWVfZGlnIDQgLy8gdGhlIG9mZnNldCB3ZSBhcmUgZXh0cmFjdGluZyB0aGUgbmV4dCBlbGVtZW50IGZyb20KCXB1c2hpbnQgOAoJKwoJZHVwCglwdXNoaW50IDI0IC8vIG9mZnNldCBvZiBsYXN0IGVsZW1lbnQKCTwKCWJ6ICpmb3JPZl8wX2VuZAoJZnJhbWVfYnVyeSA0IC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglmcmFtZV9kaWcgMiAvLyBjb3B5IG9mIHRoZSBhcnJheSB3ZSBhcmUgaXRlcmF0aW5nIG92ZXIKCWZyYW1lX2RpZyA0IC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglwdXNoaW50IDgKCWV4dHJhY3QKCWJ0b2kKCWZyYW1lX2J1cnkgMyAvLyB2OiB1aW50NjQKCWIgKmZvck9mXzAKCipmb3JPZl8wX2VuZDoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNDYwCgkvLyByZXR1cm4gc3VtOwoJZnJhbWVfZGlnIDEgLy8gc3VtOiB1aW50NjQKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCgkvLyBwb3AgYWxsIGxvY2FsIHZhcmlhYmxlcyBmcm9tIHRoZSBzdGFjawoJcG9wbiA0CglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDgwYzliNDc5IC8vIG1ldGhvZCAic3RhdGljRm9yT2YoKXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RhdGljRm9yT2YKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBzdGF0aWNGb3JPZigpdWludDY0CiphYmlfcm91dGVfc3RhdGljRm9yT2Y6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBzdGF0aWNGb3JPZigpdWludDY0CgljYWxsc3ViIHN0YXRpY0Zvck9mCglpdG9iCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHN0YXRpY0Zvck9mKCk6IHVpbnQ2NApzdGF0aWNGb3JPZjoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXBuIDQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTQ1MwoJLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPiA9IFsxLCAyLCAzXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMTAwMDAwMDAwMDAwMDAwMDIwMDAwMDAwMDAwMDAwMDAzCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNDU0CgkvLyBzdW0gPSAwCglwdXNoaW50IDAKCWZyYW1lX2J1cnkgMSAvLyBzdW06IHVpbnQ2NAoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoJZHVwCglmcmFtZV9idXJ5IDIgLy8gY29weSBvZiB0aGUgYXJyYXkgd2UgYXJlIGl0ZXJhdGluZyBvdmVyCglleHRyYWN0IDAgOAoJYnRvaQoJZnJhbWVfYnVyeSAzIC8vIHY6IHVpbnQ2NAoJcHVzaGludCAwCglmcmFtZV9idXJ5IDQgLy8gdGhlIG9mZnNldCB3ZSBhcmUgZXh0cmFjdGluZyB0aGUgbmV4dCBlbGVtZW50IGZyb20KCipmb3JPZl8wOgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE0NTgKCS8vIHN1bSArPSB2CglmcmFtZV9kaWcgMSAvLyBzdW06IHVpbnQ2NAoJZnJhbWVfZGlnIDMgLy8gdjogdWludDY0CgkrCglmcmFtZV9idXJ5IDEgLy8gc3VtOiB1aW50NjQKCipmb3JPZl8wX2NvbnRpbnVlOgoJLy8gaW5jcmVtZW50IG9mZnNldCBhbmQgbG9vcCBpZiBub3Qgb3V0IG9mIGJvdW5kcwoJZnJhbWVfZGlnIDQgLy8gdGhlIG9mZnNldCB3ZSBhcmUgZXh0cmFjdGluZyB0aGUgbmV4dCBlbGVtZW50IGZyb20KCXB1c2hpbnQgOAoJKwoJZHVwCglwdXNoaW50IDI0IC8vIG9mZnNldCBvZiBsYXN0IGVsZW1lbnQKCTwKCWJ6ICpmb3JPZl8wX2VuZAoJZnJhbWVfYnVyeSA0IC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglmcmFtZV9kaWcgMiAvLyBjb3B5IG9mIHRoZSBhcnJheSB3ZSBhcmUgaXRlcmF0aW5nIG92ZXIKCWZyYW1lX2RpZyA0IC8vIHRoZSBvZmZzZXQgd2UgYXJlIGV4dHJhY3RpbmcgdGhlIG5leHQgZWxlbWVudCBmcm9tCglwdXNoaW50IDgKCWV4dHJhY3QKCWJ0b2kKCWZyYW1lX2J1cnkgMyAvLyB2OiB1aW50NjQKCWIgKmZvck9mXzAKCipmb3JPZl8wX2VuZDoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNDYwCgkvLyByZXR1cm4gc3VtOwoJZnJhbWVfZGlnIDEgLy8gc3VtOiB1aW50NjQKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCgkvLyBwb3AgYWxsIGxvY2FsIHZhcmlhYmxlcyBmcm9tIHRoZSBzdGFjawoJcG9wbiA0CglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDgwYzliNDc5IC8vIG1ldGhvZCAic3RhdGljRm9yT2YoKXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RhdGljRm9yT2YKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestStaticStringArrayArg.approval.teal b/tests/contracts/artifacts/ABITestStaticStringArrayArg.approval.teal index b03625b2f..6b33db544 100644 --- a/tests/contracts/artifacts/ABITestStaticStringArrayArg.approval.teal +++ b/tests/contracts/artifacts/ABITestStaticStringArrayArg.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestStaticStringArrayArg.arc32.json b/tests/contracts/artifacts/ABITestStaticStringArrayArg.arc32.json index 8d44d77af..4f6d81cad 100644 --- a/tests/contracts/artifacts/ABITestStaticStringArrayArg.arc32.json +++ b/tests/contracts/artifacts/ABITestStaticStringArrayArg.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RhdGljU3RyaW5nQXJyYXlBcmcoc3RyaW5nWzNdKXN0cmluZwoqYWJpX3JvdXRlX3N0YXRpY1N0cmluZ0FycmF5QXJnOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGE6IHN0cmluZ1szXQoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoKCS8vIGV4ZWN1dGUgc3RhdGljU3RyaW5nQXJyYXlBcmcoc3RyaW5nWzNdKXN0cmluZwoJY2FsbHN1YiBzdGF0aWNTdHJpbmdBcnJheUFyZwoJZHVwCglsZW4KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gc3RhdGljU3RyaW5nQXJyYXlBcmcoYTogU3RhdGljQXJyYXk8c3RyaW5nLCAzPik6IHN0cmluZwpzdGF0aWNTdHJpbmdBcnJheUFyZzoKCXByb3RvIDEgMQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo2NDUKCS8vIHJldHVybiBhWzFdOwoJZnJhbWVfZGlnIC0xIC8vIGE6IFN0YXRpY0FycmF5PHN0cmluZywgMz4KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoaW50IDIKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXVuY292ZXIgMgoJZXh0cmFjdF91aW50MTYKCWR1cCAvLyBkdXBsaWNhdGUgc3RhcnQgb2YgZWxlbWVudAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJc3dhcAoJZXh0cmFjdF91aW50MTYgLy8gZ2V0IG51bWJlciBvZiBlbGVtZW50cwoJcHVzaGludCAxIC8vIGdldCB0eXBlIGxlbmd0aAoJKiAvLyBtdWx0aXBseSBieSB0eXBlIGxlbmd0aAoJcHVzaGludCAyCgkrIC8vIGFkZCB0d28gZm9yIGxlbmd0aAoJZXh0cmFjdDMKCWV4dHJhY3QgMiAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGJjOGQxMjA0IC8vIG1ldGhvZCAic3RhdGljU3RyaW5nQXJyYXlBcmcoc3RyaW5nWzNdKXN0cmluZyIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RhdGljU3RyaW5nQXJyYXlBcmcKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RhdGljU3RyaW5nQXJyYXlBcmcoc3RyaW5nWzNdKXN0cmluZwoqYWJpX3JvdXRlX3N0YXRpY1N0cmluZ0FycmF5QXJnOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGE6IHN0cmluZ1szXQoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoKCS8vIGV4ZWN1dGUgc3RhdGljU3RyaW5nQXJyYXlBcmcoc3RyaW5nWzNdKXN0cmluZwoJY2FsbHN1YiBzdGF0aWNTdHJpbmdBcnJheUFyZwoJZHVwCglsZW4KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gc3RhdGljU3RyaW5nQXJyYXlBcmcoYTogU3RhdGljQXJyYXk8c3RyaW5nLCAzPik6IHN0cmluZwpzdGF0aWNTdHJpbmdBcnJheUFyZzoKCXByb3RvIDEgMQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo2NDUKCS8vIHJldHVybiBhWzFdOwoJZnJhbWVfZGlnIC0xIC8vIGE6IFN0YXRpY0FycmF5PHN0cmluZywgMz4KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoaW50IDIKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXVuY292ZXIgMgoJZXh0cmFjdF91aW50MTYKCWR1cCAvLyBkdXBsaWNhdGUgc3RhcnQgb2YgZWxlbWVudAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJc3dhcAoJZXh0cmFjdF91aW50MTYgLy8gZ2V0IG51bWJlciBvZiBlbGVtZW50cwoJcHVzaGludCAxIC8vIGdldCB0eXBlIGxlbmd0aAoJKiAvLyBtdWx0aXBseSBieSB0eXBlIGxlbmd0aAoJcHVzaGludCAyCgkrIC8vIGFkZCB0d28gZm9yIGxlbmd0aAoJZXh0cmFjdDMKCWV4dHJhY3QgMiAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGJjOGQxMjA0IC8vIG1ldGhvZCAic3RhdGljU3RyaW5nQXJyYXlBcmcoc3RyaW5nWzNdKXN0cmluZyIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RhdGljU3RyaW5nQXJyYXlBcmcKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestStaticStringArrayArg.arc56_draft.json b/tests/contracts/artifacts/ABITestStaticStringArrayArg.arc56_draft.json index 9cba52d90..b47da4c71 100644 --- a/tests/contracts/artifacts/ABITestStaticStringArrayArg.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestStaticStringArrayArg.arc56_draft.json @@ -511,7 +511,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RhdGljU3RyaW5nQXJyYXlBcmcoc3RyaW5nWzNdKXN0cmluZwoqYWJpX3JvdXRlX3N0YXRpY1N0cmluZ0FycmF5QXJnOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGE6IHN0cmluZ1szXQoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoKCS8vIGV4ZWN1dGUgc3RhdGljU3RyaW5nQXJyYXlBcmcoc3RyaW5nWzNdKXN0cmluZwoJY2FsbHN1YiBzdGF0aWNTdHJpbmdBcnJheUFyZwoJZHVwCglsZW4KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gc3RhdGljU3RyaW5nQXJyYXlBcmcoYTogU3RhdGljQXJyYXk8c3RyaW5nLCAzPik6IHN0cmluZwpzdGF0aWNTdHJpbmdBcnJheUFyZzoKCXByb3RvIDEgMQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo2NDUKCS8vIHJldHVybiBhWzFdOwoJZnJhbWVfZGlnIC0xIC8vIGE6IFN0YXRpY0FycmF5PHN0cmluZywgMz4KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoaW50IDIKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXVuY292ZXIgMgoJZXh0cmFjdF91aW50MTYKCWR1cCAvLyBkdXBsaWNhdGUgc3RhcnQgb2YgZWxlbWVudAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJc3dhcAoJZXh0cmFjdF91aW50MTYgLy8gZ2V0IG51bWJlciBvZiBlbGVtZW50cwoJcHVzaGludCAxIC8vIGdldCB0eXBlIGxlbmd0aAoJKiAvLyBtdWx0aXBseSBieSB0eXBlIGxlbmd0aAoJcHVzaGludCAyCgkrIC8vIGFkZCB0d28gZm9yIGxlbmd0aAoJZXh0cmFjdDMKCWV4dHJhY3QgMiAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGJjOGQxMjA0IC8vIG1ldGhvZCAic3RhdGljU3RyaW5nQXJyYXlBcmcoc3RyaW5nWzNdKXN0cmluZyIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RhdGljU3RyaW5nQXJyYXlBcmcKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RhdGljU3RyaW5nQXJyYXlBcmcoc3RyaW5nWzNdKXN0cmluZwoqYWJpX3JvdXRlX3N0YXRpY1N0cmluZ0FycmF5QXJnOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGE6IHN0cmluZ1szXQoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoKCS8vIGV4ZWN1dGUgc3RhdGljU3RyaW5nQXJyYXlBcmcoc3RyaW5nWzNdKXN0cmluZwoJY2FsbHN1YiBzdGF0aWNTdHJpbmdBcnJheUFyZwoJZHVwCglsZW4KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gc3RhdGljU3RyaW5nQXJyYXlBcmcoYTogU3RhdGljQXJyYXk8c3RyaW5nLCAzPik6IHN0cmluZwpzdGF0aWNTdHJpbmdBcnJheUFyZzoKCXByb3RvIDEgMQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo2NDUKCS8vIHJldHVybiBhWzFdOwoJZnJhbWVfZGlnIC0xIC8vIGE6IFN0YXRpY0FycmF5PHN0cmluZywgMz4KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoaW50IDIKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXVuY292ZXIgMgoJZXh0cmFjdF91aW50MTYKCWR1cCAvLyBkdXBsaWNhdGUgc3RhcnQgb2YgZWxlbWVudAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJc3dhcAoJZXh0cmFjdF91aW50MTYgLy8gZ2V0IG51bWJlciBvZiBlbGVtZW50cwoJcHVzaGludCAxIC8vIGdldCB0eXBlIGxlbmd0aAoJKiAvLyBtdWx0aXBseSBieSB0eXBlIGxlbmd0aAoJcHVzaGludCAyCgkrIC8vIGFkZCB0d28gZm9yIGxlbmd0aAoJZXh0cmFjdDMKCWV4dHJhY3QgMiAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGJjOGQxMjA0IC8vIG1ldGhvZCAic3RhdGljU3RyaW5nQXJyYXlBcmcoc3RyaW5nWzNdKXN0cmluZyIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RhdGljU3RyaW5nQXJyYXlBcmcKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestStaticTypeInBox.approval.teal b/tests/contracts/artifacts/ABITestStaticTypeInBox.approval.teal index dd87f8b6e..4765b1f50 100644 --- a/tests/contracts/artifacts/ABITestStaticTypeInBox.approval.teal +++ b/tests/contracts/artifacts/ABITestStaticTypeInBox.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestStaticTypeInBox.arc32.json b/tests/contracts/artifacts/ABITestStaticTypeInBox.arc32.json index b3bae04d9..afa0ba42f 100644 --- a/tests/contracts/artifacts/ABITestStaticTypeInBox.arc32.json +++ b/tests/contracts/artifacts/ABITestStaticTypeInBox.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RhdGljVHlwZUluQm94KCl2b2lkCiphYmlfcm91dGVfc3RhdGljVHlwZUluQm94OgoJLy8gZXhlY3V0ZSBzdGF0aWNUeXBlSW5Cb3goKXZvaWQKCWNhbGxzdWIgc3RhdGljVHlwZUluQm94CglwdXNoaW50IDEKCXJldHVybgoKLy8gc3RhdGljVHlwZUluQm94KCk6IHZvaWQKc3RhdGljVHlwZUluQm94OgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE1MzUKCS8vIHRoaXMuYk1hcCh0aGlzLnR4bi5zZW5kZXIpLnZhbHVlID0gdGhpcy50eG4uc2VuZGVyCgl0eG4gU2VuZGVyCgl0eG4gU2VuZGVyCglib3hfcHV0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE1MzYKCS8vIGFzc2VydCh0aGlzLmJNYXAodGhpcy50eG4uc2VuZGVyKS52YWx1ZS5pc0luTGVkZ2VyKQoJdHhuIFNlbmRlcgoJYm94X2dldAoKCS8vIGJveCB2YWx1ZSBkb2VzIG5vdCBleGlzdDogdGhpcy5iTWFwKHRoaXMudHhuLnNlbmRlcikudmFsdWUKCWFzc2VydAoJYWNjdF9wYXJhbXNfZ2V0IEFjY3RCYWxhbmNlCglzd2FwCglwb3AKCWFzc2VydAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgwZjUyMDdkOSAvLyBtZXRob2QgInN0YXRpY1R5cGVJbkJveCgpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RhdGljVHlwZUluQm94CgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RhdGljVHlwZUluQm94KCl2b2lkCiphYmlfcm91dGVfc3RhdGljVHlwZUluQm94OgoJLy8gZXhlY3V0ZSBzdGF0aWNUeXBlSW5Cb3goKXZvaWQKCWNhbGxzdWIgc3RhdGljVHlwZUluQm94CglwdXNoaW50IDEKCXJldHVybgoKLy8gc3RhdGljVHlwZUluQm94KCk6IHZvaWQKc3RhdGljVHlwZUluQm94OgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE1MzUKCS8vIHRoaXMuYk1hcCh0aGlzLnR4bi5zZW5kZXIpLnZhbHVlID0gdGhpcy50eG4uc2VuZGVyCgl0eG4gU2VuZGVyCgl0eG4gU2VuZGVyCglib3hfcHV0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE1MzYKCS8vIGFzc2VydCh0aGlzLmJNYXAodGhpcy50eG4uc2VuZGVyKS52YWx1ZS5pc0luTGVkZ2VyKQoJdHhuIFNlbmRlcgoJYm94X2dldAoKCS8vIGJveCB2YWx1ZSBkb2VzIG5vdCBleGlzdDogdGhpcy5iTWFwKHRoaXMudHhuLnNlbmRlcikudmFsdWUKCWFzc2VydAoJYWNjdF9wYXJhbXNfZ2V0IEFjY3RCYWxhbmNlCglzd2FwCglwb3AKCWFzc2VydAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgwZjUyMDdkOSAvLyBtZXRob2QgInN0YXRpY1R5cGVJbkJveCgpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RhdGljVHlwZUluQm94CgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestStaticTypeInBox.arc56_draft.json b/tests/contracts/artifacts/ABITestStaticTypeInBox.arc56_draft.json index 774c77bf9..1e40c99d6 100644 --- a/tests/contracts/artifacts/ABITestStaticTypeInBox.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestStaticTypeInBox.arc56_draft.json @@ -377,7 +377,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RhdGljVHlwZUluQm94KCl2b2lkCiphYmlfcm91dGVfc3RhdGljVHlwZUluQm94OgoJLy8gZXhlY3V0ZSBzdGF0aWNUeXBlSW5Cb3goKXZvaWQKCWNhbGxzdWIgc3RhdGljVHlwZUluQm94CglwdXNoaW50IDEKCXJldHVybgoKLy8gc3RhdGljVHlwZUluQm94KCk6IHZvaWQKc3RhdGljVHlwZUluQm94OgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE1MzUKCS8vIHRoaXMuYk1hcCh0aGlzLnR4bi5zZW5kZXIpLnZhbHVlID0gdGhpcy50eG4uc2VuZGVyCgl0eG4gU2VuZGVyCgl0eG4gU2VuZGVyCglib3hfcHV0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE1MzYKCS8vIGFzc2VydCh0aGlzLmJNYXAodGhpcy50eG4uc2VuZGVyKS52YWx1ZS5pc0luTGVkZ2VyKQoJdHhuIFNlbmRlcgoJYm94X2dldAoKCS8vIGJveCB2YWx1ZSBkb2VzIG5vdCBleGlzdDogdGhpcy5iTWFwKHRoaXMudHhuLnNlbmRlcikudmFsdWUKCWFzc2VydAoJYWNjdF9wYXJhbXNfZ2V0IEFjY3RCYWxhbmNlCglzd2FwCglwb3AKCWFzc2VydAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgwZjUyMDdkOSAvLyBtZXRob2QgInN0YXRpY1R5cGVJbkJveCgpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RhdGljVHlwZUluQm94CgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RhdGljVHlwZUluQm94KCl2b2lkCiphYmlfcm91dGVfc3RhdGljVHlwZUluQm94OgoJLy8gZXhlY3V0ZSBzdGF0aWNUeXBlSW5Cb3goKXZvaWQKCWNhbGxzdWIgc3RhdGljVHlwZUluQm94CglwdXNoaW50IDEKCXJldHVybgoKLy8gc3RhdGljVHlwZUluQm94KCk6IHZvaWQKc3RhdGljVHlwZUluQm94OgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE1MzUKCS8vIHRoaXMuYk1hcCh0aGlzLnR4bi5zZW5kZXIpLnZhbHVlID0gdGhpcy50eG4uc2VuZGVyCgl0eG4gU2VuZGVyCgl0eG4gU2VuZGVyCglib3hfcHV0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE1MzYKCS8vIGFzc2VydCh0aGlzLmJNYXAodGhpcy50eG4uc2VuZGVyKS52YWx1ZS5pc0luTGVkZ2VyKQoJdHhuIFNlbmRlcgoJYm94X2dldAoKCS8vIGJveCB2YWx1ZSBkb2VzIG5vdCBleGlzdDogdGhpcy5iTWFwKHRoaXMudHhuLnNlbmRlcikudmFsdWUKCWFzc2VydAoJYWNjdF9wYXJhbXNfZ2V0IEFjY3RCYWxhbmNlCglzd2FwCglwb3AKCWFzc2VydAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgwZjUyMDdkOSAvLyBtZXRob2QgInN0YXRpY1R5cGVJbkJveCgpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RhdGljVHlwZUluQm94CgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestStoragePropertyReferenceInBox.approval.teal b/tests/contracts/artifacts/ABITestStoragePropertyReferenceInBox.approval.teal index 86f7e0542..9344268b7 100644 --- a/tests/contracts/artifacts/ABITestStoragePropertyReferenceInBox.approval.teal +++ b/tests/contracts/artifacts/ABITestStoragePropertyReferenceInBox.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x0004624d6170 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestStoragePropertyReferenceInBox.arc32.json b/tests/contracts/artifacts/ABITestStoragePropertyReferenceInBox.arc32.json index b0d5f8425..969222d6c 100644 --- a/tests/contracts/artifacts/ABITestStoragePropertyReferenceInBox.arc32.json +++ b/tests/contracts/artifacts/ABITestStoragePropertyReferenceInBox.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgwMDA0NjI0ZDYxNzAKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBzdG9yYWdlUHJvcGVydHlSZWZlcmVuY2VJbkJveCgpdWludDY0CiphYmlfcm91dGVfc3RvcmFnZVByb3BlcnR5UmVmZXJlbmNlSW5Cb3g6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBzdG9yYWdlUHJvcGVydHlSZWZlcmVuY2VJbkJveCgpdWludDY0CgljYWxsc3ViIHN0b3JhZ2VQcm9wZXJ0eVJlZmVyZW5jZUluQm94CglpdG9iCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHN0b3JhZ2VQcm9wZXJ0eVJlZmVyZW5jZUluQm94KCk6IHVpbnQ2NApzdG9yYWdlUHJvcGVydHlSZWZlcmVuY2VJbkJveDoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglwdXNoYnl0ZXMgMHgKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTU0NAoJLy8gdGhpcy5iTWFwKCdiTWFwJykudmFsdWUgPSB7IGZvbzogdGhpcy50eG4uc2VuZGVyLCBiYXI6IHsgYmF6OiAxMzM3IH0gfQoJYnl0ZSAweDAwMDQ2MjRkNjE3MAoJdHhuIFNlbmRlcgoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDUzOQoJY29uY2F0Cglib3hfcHV0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE1NDUKCS8vIHYgPSB0aGlzLmJNYXAoJ2JNYXAnKS52YWx1ZS5iYXIuYmF6CglieXRlIDB4MDAwNDYyNGQ2MTcwCglwdXNoaW50IDMyCglwdXNoaW50IDgKCWJveF9leHRyYWN0CglidG9pCglmcmFtZV9idXJ5IDAgLy8gdjogdWludDY0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE1NDYKCS8vIHJldHVybiB2OwoJZnJhbWVfZGlnIDAgLy8gdjogdWludDY0CgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDU0YTg1OGViIC8vIG1ldGhvZCAic3RvcmFnZVByb3BlcnR5UmVmZXJlbmNlSW5Cb3goKXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RvcmFnZVByb3BlcnR5UmVmZXJlbmNlSW5Cb3gKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgwMDA0NjI0ZDYxNzAKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBzdG9yYWdlUHJvcGVydHlSZWZlcmVuY2VJbkJveCgpdWludDY0CiphYmlfcm91dGVfc3RvcmFnZVByb3BlcnR5UmVmZXJlbmNlSW5Cb3g6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBzdG9yYWdlUHJvcGVydHlSZWZlcmVuY2VJbkJveCgpdWludDY0CgljYWxsc3ViIHN0b3JhZ2VQcm9wZXJ0eVJlZmVyZW5jZUluQm94CglpdG9iCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHN0b3JhZ2VQcm9wZXJ0eVJlZmVyZW5jZUluQm94KCk6IHVpbnQ2NApzdG9yYWdlUHJvcGVydHlSZWZlcmVuY2VJbkJveDoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglwdXNoYnl0ZXMgMHgKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTU0NAoJLy8gdGhpcy5iTWFwKCdiTWFwJykudmFsdWUgPSB7IGZvbzogdGhpcy50eG4uc2VuZGVyLCBiYXI6IHsgYmF6OiAxMzM3IH0gfQoJYnl0ZSAweDAwMDQ2MjRkNjE3MAoJdHhuIFNlbmRlcgoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDUzOQoJY29uY2F0Cglib3hfcHV0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE1NDUKCS8vIHYgPSB0aGlzLmJNYXAoJ2JNYXAnKS52YWx1ZS5iYXIuYmF6CglieXRlIDB4MDAwNDYyNGQ2MTcwCglwdXNoaW50IDMyCglwdXNoaW50IDgKCWJveF9leHRyYWN0CglidG9pCglmcmFtZV9idXJ5IDAgLy8gdjogdWludDY0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE1NDYKCS8vIHJldHVybiB2OwoJZnJhbWVfZGlnIDAgLy8gdjogdWludDY0CgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDU0YTg1OGViIC8vIG1ldGhvZCAic3RvcmFnZVByb3BlcnR5UmVmZXJlbmNlSW5Cb3goKXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RvcmFnZVByb3BlcnR5UmVmZXJlbmNlSW5Cb3gKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestStoragePropertyReferenceInBox.arc56_draft.json b/tests/contracts/artifacts/ABITestStoragePropertyReferenceInBox.arc56_draft.json index 87254d465..580bda6ca 100644 --- a/tests/contracts/artifacts/ABITestStoragePropertyReferenceInBox.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestStoragePropertyReferenceInBox.arc56_draft.json @@ -494,7 +494,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgwMDA0NjI0ZDYxNzAKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBzdG9yYWdlUHJvcGVydHlSZWZlcmVuY2VJbkJveCgpdWludDY0CiphYmlfcm91dGVfc3RvcmFnZVByb3BlcnR5UmVmZXJlbmNlSW5Cb3g6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBzdG9yYWdlUHJvcGVydHlSZWZlcmVuY2VJbkJveCgpdWludDY0CgljYWxsc3ViIHN0b3JhZ2VQcm9wZXJ0eVJlZmVyZW5jZUluQm94CglpdG9iCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHN0b3JhZ2VQcm9wZXJ0eVJlZmVyZW5jZUluQm94KCk6IHVpbnQ2NApzdG9yYWdlUHJvcGVydHlSZWZlcmVuY2VJbkJveDoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglwdXNoYnl0ZXMgMHgKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTU0NAoJLy8gdGhpcy5iTWFwKCdiTWFwJykudmFsdWUgPSB7IGZvbzogdGhpcy50eG4uc2VuZGVyLCBiYXI6IHsgYmF6OiAxMzM3IH0gfQoJYnl0ZSAweDAwMDQ2MjRkNjE3MAoJdHhuIFNlbmRlcgoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDUzOQoJY29uY2F0Cglib3hfcHV0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE1NDUKCS8vIHYgPSB0aGlzLmJNYXAoJ2JNYXAnKS52YWx1ZS5iYXIuYmF6CglieXRlIDB4MDAwNDYyNGQ2MTcwCglwdXNoaW50IDMyCglwdXNoaW50IDgKCWJveF9leHRyYWN0CglidG9pCglmcmFtZV9idXJ5IDAgLy8gdjogdWludDY0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE1NDYKCS8vIHJldHVybiB2OwoJZnJhbWVfZGlnIDAgLy8gdjogdWludDY0CgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDU0YTg1OGViIC8vIG1ldGhvZCAic3RvcmFnZVByb3BlcnR5UmVmZXJlbmNlSW5Cb3goKXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RvcmFnZVByb3BlcnR5UmVmZXJlbmNlSW5Cb3gKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgwMDA0NjI0ZDYxNzAKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBzdG9yYWdlUHJvcGVydHlSZWZlcmVuY2VJbkJveCgpdWludDY0CiphYmlfcm91dGVfc3RvcmFnZVByb3BlcnR5UmVmZXJlbmNlSW5Cb3g6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBzdG9yYWdlUHJvcGVydHlSZWZlcmVuY2VJbkJveCgpdWludDY0CgljYWxsc3ViIHN0b3JhZ2VQcm9wZXJ0eVJlZmVyZW5jZUluQm94CglpdG9iCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHN0b3JhZ2VQcm9wZXJ0eVJlZmVyZW5jZUluQm94KCk6IHVpbnQ2NApzdG9yYWdlUHJvcGVydHlSZWZlcmVuY2VJbkJveDoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglwdXNoYnl0ZXMgMHgKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTU0NAoJLy8gdGhpcy5iTWFwKCdiTWFwJykudmFsdWUgPSB7IGZvbzogdGhpcy50eG4uc2VuZGVyLCBiYXI6IHsgYmF6OiAxMzM3IH0gfQoJYnl0ZSAweDAwMDQ2MjRkNjE3MAoJdHhuIFNlbmRlcgoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDUzOQoJY29uY2F0Cglib3hfcHV0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE1NDUKCS8vIHYgPSB0aGlzLmJNYXAoJ2JNYXAnKS52YWx1ZS5iYXIuYmF6CglieXRlIDB4MDAwNDYyNGQ2MTcwCglwdXNoaW50IDMyCglwdXNoaW50IDgKCWJveF9leHRyYWN0CglidG9pCglmcmFtZV9idXJ5IDAgLy8gdjogdWludDY0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE1NDYKCS8vIHJldHVybiB2OwoJZnJhbWVfZGlnIDAgLy8gdjogdWludDY0CgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDU0YTg1OGViIC8vIG1ldGhvZCAic3RvcmFnZVByb3BlcnR5UmVmZXJlbmNlSW5Cb3goKXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RvcmFnZVByb3BlcnR5UmVmZXJlbmNlSW5Cb3gKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestStorageRefAccount.approval.teal b/tests/contracts/artifacts/ABITestStorageRefAccount.approval.teal index 8e84110bd..005c0de43 100644 --- a/tests/contracts/artifacts/ABITestStorageRefAccount.approval.teal +++ b/tests/contracts/artifacts/ABITestStorageRefAccount.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x0000000000000000 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestStorageRefAccount.arc32.json b/tests/contracts/artifacts/ABITestStorageRefAccount.arc32.json index a3f8119d5..a73c8328b 100644 --- a/tests/contracts/artifacts/ABITestStorageRefAccount.arc32.json +++ b/tests/contracts/artifacts/ABITestStorageRefAccount.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgwMDAwMDAwMDAwMDAwMDAwIDB4CgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpOT1RfSU1QTEVNRU5URUQgKmNhbGxfT3B0SW4gKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIHN0b3JhZ2VSZWZBY2NvdW50KCl1aW50NjQKKmFiaV9yb3V0ZV9zdG9yYWdlUmVmQWNjb3VudDoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHN0b3JhZ2VSZWZBY2NvdW50KCl1aW50NjQKCWNhbGxzdWIgc3RvcmFnZVJlZkFjY291bnQKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gc3RvcmFnZVJlZkFjY291bnQoKTogdWludDY0CnN0b3JhZ2VSZWZBY2NvdW50OgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCWJ5dGUgMHgKCWR1cAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMDE5CgkvLyBhZGRyID0gdGhpcy50eG4uc2VuZGVyCgl0eG4gU2VuZGVyCglmcmFtZV9idXJ5IDAgLy8gYWRkcjogYWRkcmVzcwoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMDIwCgkvLyB0aGlzLmxNYXAoYWRkciwgMCkudmFsdWUgPSBbMSwgMiwgM10KCWZyYW1lX2RpZyAwIC8vIGFkZHI6IGFkZHJlc3MKCWJ5dGUgMHgwMDAwMDAwMDAwMDAwMDAwCglwdXNoYnl0ZXMgMHgwMDAzMDAwMDAwMDAwMDAwMDAwMTAwMDAwMDAwMDAwMDAwMDIwMDAwMDAwMDAwMDAwMDAzCglhcHBfbG9jYWxfcHV0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEwMjEKCS8vIHIgPSB0aGlzLmxNYXAoYWRkciwgMCkudmFsdWUKCWZyYW1lX2RpZyAwIC8vIGFkZHI6IGFkZHJlc3MKCWZyYW1lX2J1cnkgMSAvLyBzdG9yYWdlIGFjY291bnQvL3IKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTAyMwoJLy8gYWRkciA9IGdsb2JhbHMuemVyb0FkZHJlc3MKCWdsb2JhbCBaZXJvQWRkcmVzcwoJZnJhbWVfYnVyeSAwIC8vIGFkZHI6IGFkZHJlc3MKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTAyNQoJLy8gclsxXSA9IDQKCWZyYW1lX2RpZyAxIC8vIHN0b3JhZ2UgYWNjb3VudC8vcgoJYnl0ZSAweDAwMDAwMDAwMDAwMDAwMDAKCWFwcF9sb2NhbF9nZXQKCWV4dHJhY3QgMiAwCglzdG9yZSAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwNAoJcmVwbGFjZTIgOAoJZnJhbWVfZGlnIDEgLy8gc3RvcmFnZSBhY2NvdW50Ly9yCglieXRlIDB4MDAwMDAwMDAwMDAwMDAwMAoJdW5jb3ZlciAyCglkdXAKCWxlbgoJcHVzaGludCA4CgkvCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0CglhcHBfbG9jYWxfcHV0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEwMjcKCS8vIHJldHVybiB0aGlzLmxNYXAodGhpcy50eG4uc2VuZGVyLCAwKS52YWx1ZVsxXTsKCXR4biBTZW5kZXIKCWJ5dGUgMHgwMDAwMDAwMDAwMDAwMDAwCglhcHBfbG9jYWxfZ2V0CglleHRyYWN0IDIgMAoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWV4dHJhY3QgOCA4CglidG9pCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCgoJLy8gcG9wIGFsbCBsb2NhbCB2YXJpYWJsZXMgZnJvbSB0aGUgc3RhY2sKCXBvcG4gMQoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX09wdEluOgoJcHVzaGJ5dGVzIDB4YmU3NzdjZTYgLy8gbWV0aG9kICJzdG9yYWdlUmVmQWNjb3VudCgpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9zdG9yYWdlUmVmQWNjb3VudAoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE9wdEluCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgwMDAwMDAwMDAwMDAwMDAwIDB4CgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpOT1RfSU1QTEVNRU5URUQgKmNhbGxfT3B0SW4gKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIHN0b3JhZ2VSZWZBY2NvdW50KCl1aW50NjQKKmFiaV9yb3V0ZV9zdG9yYWdlUmVmQWNjb3VudDoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHN0b3JhZ2VSZWZBY2NvdW50KCl1aW50NjQKCWNhbGxzdWIgc3RvcmFnZVJlZkFjY291bnQKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gc3RvcmFnZVJlZkFjY291bnQoKTogdWludDY0CnN0b3JhZ2VSZWZBY2NvdW50OgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCWJ5dGUgMHgKCWR1cAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMDE5CgkvLyBhZGRyID0gdGhpcy50eG4uc2VuZGVyCgl0eG4gU2VuZGVyCglmcmFtZV9idXJ5IDAgLy8gYWRkcjogYWRkcmVzcwoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMDIwCgkvLyB0aGlzLmxNYXAoYWRkciwgMCkudmFsdWUgPSBbMSwgMiwgM10KCWZyYW1lX2RpZyAwIC8vIGFkZHI6IGFkZHJlc3MKCWJ5dGUgMHgwMDAwMDAwMDAwMDAwMDAwCglwdXNoYnl0ZXMgMHgwMDAzMDAwMDAwMDAwMDAwMDAwMTAwMDAwMDAwMDAwMDAwMDIwMDAwMDAwMDAwMDAwMDAzCglhcHBfbG9jYWxfcHV0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEwMjEKCS8vIHIgPSB0aGlzLmxNYXAoYWRkciwgMCkudmFsdWUKCWZyYW1lX2RpZyAwIC8vIGFkZHI6IGFkZHJlc3MKCWZyYW1lX2J1cnkgMSAvLyBzdG9yYWdlIGFjY291bnQvL3IKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTAyMwoJLy8gYWRkciA9IGdsb2JhbHMuemVyb0FkZHJlc3MKCWdsb2JhbCBaZXJvQWRkcmVzcwoJZnJhbWVfYnVyeSAwIC8vIGFkZHI6IGFkZHJlc3MKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTAyNQoJLy8gclsxXSA9IDQKCWZyYW1lX2RpZyAxIC8vIHN0b3JhZ2UgYWNjb3VudC8vcgoJYnl0ZSAweDAwMDAwMDAwMDAwMDAwMDAKCWFwcF9sb2NhbF9nZXQKCWV4dHJhY3QgMiAwCglzdG9yZSAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwNAoJcmVwbGFjZTIgOAoJZnJhbWVfZGlnIDEgLy8gc3RvcmFnZSBhY2NvdW50Ly9yCglieXRlIDB4MDAwMDAwMDAwMDAwMDAwMAoJdW5jb3ZlciAyCglkdXAKCWxlbgoJcHVzaGludCA4CgkvCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0CglhcHBfbG9jYWxfcHV0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEwMjcKCS8vIHJldHVybiB0aGlzLmxNYXAodGhpcy50eG4uc2VuZGVyLCAwKS52YWx1ZVsxXTsKCXR4biBTZW5kZXIKCWJ5dGUgMHgwMDAwMDAwMDAwMDAwMDAwCglhcHBfbG9jYWxfZ2V0CglleHRyYWN0IDIgMAoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWV4dHJhY3QgOCA4CglidG9pCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCgoJLy8gcG9wIGFsbCBsb2NhbCB2YXJpYWJsZXMgZnJvbSB0aGUgc3RhY2sKCXBvcG4gMQoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX09wdEluOgoJcHVzaGJ5dGVzIDB4YmU3NzdjZTYgLy8gbWV0aG9kICJzdG9yYWdlUmVmQWNjb3VudCgpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9zdG9yYWdlUmVmQWNjb3VudAoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE9wdEluCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestStorageRefAccount.arc56_draft.json b/tests/contracts/artifacts/ABITestStorageRefAccount.arc56_draft.json index bcfcc896b..4dcd4d6d4 100644 --- a/tests/contracts/artifacts/ABITestStorageRefAccount.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestStorageRefAccount.arc56_draft.json @@ -747,7 +747,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgwMDAwMDAwMDAwMDAwMDAwIDB4CgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpOT1RfSU1QTEVNRU5URUQgKmNhbGxfT3B0SW4gKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIHN0b3JhZ2VSZWZBY2NvdW50KCl1aW50NjQKKmFiaV9yb3V0ZV9zdG9yYWdlUmVmQWNjb3VudDoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHN0b3JhZ2VSZWZBY2NvdW50KCl1aW50NjQKCWNhbGxzdWIgc3RvcmFnZVJlZkFjY291bnQKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gc3RvcmFnZVJlZkFjY291bnQoKTogdWludDY0CnN0b3JhZ2VSZWZBY2NvdW50OgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCWJ5dGUgMHgKCWR1cAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMDE5CgkvLyBhZGRyID0gdGhpcy50eG4uc2VuZGVyCgl0eG4gU2VuZGVyCglmcmFtZV9idXJ5IDAgLy8gYWRkcjogYWRkcmVzcwoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMDIwCgkvLyB0aGlzLmxNYXAoYWRkciwgMCkudmFsdWUgPSBbMSwgMiwgM10KCWZyYW1lX2RpZyAwIC8vIGFkZHI6IGFkZHJlc3MKCWJ5dGUgMHgwMDAwMDAwMDAwMDAwMDAwCglwdXNoYnl0ZXMgMHgwMDAzMDAwMDAwMDAwMDAwMDAwMTAwMDAwMDAwMDAwMDAwMDIwMDAwMDAwMDAwMDAwMDAzCglhcHBfbG9jYWxfcHV0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEwMjEKCS8vIHIgPSB0aGlzLmxNYXAoYWRkciwgMCkudmFsdWUKCWZyYW1lX2RpZyAwIC8vIGFkZHI6IGFkZHJlc3MKCWZyYW1lX2J1cnkgMSAvLyBzdG9yYWdlIGFjY291bnQvL3IKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTAyMwoJLy8gYWRkciA9IGdsb2JhbHMuemVyb0FkZHJlc3MKCWdsb2JhbCBaZXJvQWRkcmVzcwoJZnJhbWVfYnVyeSAwIC8vIGFkZHI6IGFkZHJlc3MKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTAyNQoJLy8gclsxXSA9IDQKCWZyYW1lX2RpZyAxIC8vIHN0b3JhZ2UgYWNjb3VudC8vcgoJYnl0ZSAweDAwMDAwMDAwMDAwMDAwMDAKCWFwcF9sb2NhbF9nZXQKCWV4dHJhY3QgMiAwCglzdG9yZSAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwNAoJcmVwbGFjZTIgOAoJZnJhbWVfZGlnIDEgLy8gc3RvcmFnZSBhY2NvdW50Ly9yCglieXRlIDB4MDAwMDAwMDAwMDAwMDAwMAoJdW5jb3ZlciAyCglkdXAKCWxlbgoJcHVzaGludCA4CgkvCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0CglhcHBfbG9jYWxfcHV0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEwMjcKCS8vIHJldHVybiB0aGlzLmxNYXAodGhpcy50eG4uc2VuZGVyLCAwKS52YWx1ZVsxXTsKCXR4biBTZW5kZXIKCWJ5dGUgMHgwMDAwMDAwMDAwMDAwMDAwCglhcHBfbG9jYWxfZ2V0CglleHRyYWN0IDIgMAoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWV4dHJhY3QgOCA4CglidG9pCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCgoJLy8gcG9wIGFsbCBsb2NhbCB2YXJpYWJsZXMgZnJvbSB0aGUgc3RhY2sKCXBvcG4gMQoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX09wdEluOgoJcHVzaGJ5dGVzIDB4YmU3NzdjZTYgLy8gbWV0aG9kICJzdG9yYWdlUmVmQWNjb3VudCgpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9zdG9yYWdlUmVmQWNjb3VudAoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE9wdEluCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgwMDAwMDAwMDAwMDAwMDAwIDB4CgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpOT1RfSU1QTEVNRU5URUQgKmNhbGxfT3B0SW4gKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIHN0b3JhZ2VSZWZBY2NvdW50KCl1aW50NjQKKmFiaV9yb3V0ZV9zdG9yYWdlUmVmQWNjb3VudDoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHN0b3JhZ2VSZWZBY2NvdW50KCl1aW50NjQKCWNhbGxzdWIgc3RvcmFnZVJlZkFjY291bnQKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gc3RvcmFnZVJlZkFjY291bnQoKTogdWludDY0CnN0b3JhZ2VSZWZBY2NvdW50OgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCWJ5dGUgMHgKCWR1cAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMDE5CgkvLyBhZGRyID0gdGhpcy50eG4uc2VuZGVyCgl0eG4gU2VuZGVyCglmcmFtZV9idXJ5IDAgLy8gYWRkcjogYWRkcmVzcwoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMDIwCgkvLyB0aGlzLmxNYXAoYWRkciwgMCkudmFsdWUgPSBbMSwgMiwgM10KCWZyYW1lX2RpZyAwIC8vIGFkZHI6IGFkZHJlc3MKCWJ5dGUgMHgwMDAwMDAwMDAwMDAwMDAwCglwdXNoYnl0ZXMgMHgwMDAzMDAwMDAwMDAwMDAwMDAwMTAwMDAwMDAwMDAwMDAwMDIwMDAwMDAwMDAwMDAwMDAzCglhcHBfbG9jYWxfcHV0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEwMjEKCS8vIHIgPSB0aGlzLmxNYXAoYWRkciwgMCkudmFsdWUKCWZyYW1lX2RpZyAwIC8vIGFkZHI6IGFkZHJlc3MKCWZyYW1lX2J1cnkgMSAvLyBzdG9yYWdlIGFjY291bnQvL3IKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTAyMwoJLy8gYWRkciA9IGdsb2JhbHMuemVyb0FkZHJlc3MKCWdsb2JhbCBaZXJvQWRkcmVzcwoJZnJhbWVfYnVyeSAwIC8vIGFkZHI6IGFkZHJlc3MKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTAyNQoJLy8gclsxXSA9IDQKCWZyYW1lX2RpZyAxIC8vIHN0b3JhZ2UgYWNjb3VudC8vcgoJYnl0ZSAweDAwMDAwMDAwMDAwMDAwMDAKCWFwcF9sb2NhbF9nZXQKCWV4dHJhY3QgMiAwCglzdG9yZSAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwNAoJcmVwbGFjZTIgOAoJZnJhbWVfZGlnIDEgLy8gc3RvcmFnZSBhY2NvdW50Ly9yCglieXRlIDB4MDAwMDAwMDAwMDAwMDAwMAoJdW5jb3ZlciAyCglkdXAKCWxlbgoJcHVzaGludCA4CgkvCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0CglhcHBfbG9jYWxfcHV0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEwMjcKCS8vIHJldHVybiB0aGlzLmxNYXAodGhpcy50eG4uc2VuZGVyLCAwKS52YWx1ZVsxXTsKCXR4biBTZW5kZXIKCWJ5dGUgMHgwMDAwMDAwMDAwMDAwMDAwCglhcHBfbG9jYWxfZ2V0CglleHRyYWN0IDIgMAoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWV4dHJhY3QgOCA4CglidG9pCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCgoJLy8gcG9wIGFsbCBsb2NhbCB2YXJpYWJsZXMgZnJvbSB0aGUgc3RhY2sKCXBvcG4gMQoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX09wdEluOgoJcHVzaGJ5dGVzIDB4YmU3NzdjZTYgLy8gbWV0aG9kICJzdG9yYWdlUmVmQWNjb3VudCgpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9zdG9yYWdlUmVmQWNjb3VudAoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE9wdEluCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestStorageRefKey.approval.teal b/tests/contracts/artifacts/ABITestStorageRefKey.approval.teal index 5f5bdd5d5..16b8734be 100644 --- a/tests/contracts/artifacts/ABITestStorageRefKey.approval.teal +++ b/tests/contracts/artifacts/ABITestStorageRefKey.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x0000000000000000 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestStorageRefKey.arc32.json b/tests/contracts/artifacts/ABITestStorageRefKey.arc32.json index eb1add997..5e3bf82c7 100644 --- a/tests/contracts/artifacts/ABITestStorageRefKey.arc32.json +++ b/tests/contracts/artifacts/ABITestStorageRefKey.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgwMDAwMDAwMDAwMDAwMDAwIDB4CgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RvcmFnZVJlZktleSgpdWludDY0CiphYmlfcm91dGVfc3RvcmFnZVJlZktleToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHN0b3JhZ2VSZWZLZXkoKXVpbnQ2NAoJY2FsbHN1YiBzdG9yYWdlUmVmS2V5CglpdG9iCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHN0b3JhZ2VSZWZLZXkoKTogdWludDY0CnN0b3JhZ2VSZWZLZXk6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJYnl0ZSAweAoJZHVwCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEwMDAKCS8vIHRoaXMuZ01hcCgwKS52YWx1ZSA9IFsxLCAyLCAzXQoJYnl0ZSAweDAwMDAwMDAwMDAwMDAwMDAKCXB1c2hieXRlcyAweDAwMDMwMDAwMDAwMDAwMDAwMDAxMDAwMDAwMDAwMDAwMDAwMjAwMDAwMDAwMDAwMDAwMDMKCWFwcF9nbG9iYWxfcHV0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEwMDIKCS8vIGkgPSAwCglwdXNoaW50IDAKCWZyYW1lX2J1cnkgMCAvLyBpOiB1aW50NjQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTAwNAoJLy8gciA9IHRoaXMuZ01hcChpKS52YWx1ZQoJZnJhbWVfZGlnIDAgLy8gaTogdWludDY0CglpdG9iCglmcmFtZV9idXJ5IDEgLy8gc3RvcmFnZSBrZXkvL3IKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTAwNgoJLy8gaSA9IDEKCXB1c2hpbnQgMQoJZnJhbWVfYnVyeSAwIC8vIGk6IHVpbnQ2NAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMDA4CgkvLyByWzFdID0gNAoJZnJhbWVfZGlnIDEgLy8gc3RvcmFnZSBrZXkvL3IKCWFwcF9nbG9iYWxfZ2V0CglleHRyYWN0IDIgMAoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDQKCXJlcGxhY2UyIDgKCWZyYW1lX2RpZyAxIC8vIHN0b3JhZ2Uga2V5Ly9yCglzd2FwCglkdXAKCWxlbgoJcHVzaGludCA4CgkvCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0CglhcHBfZ2xvYmFsX3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMDEwCgkvLyByZXR1cm4gdGhpcy5nTWFwKDApLnZhbHVlWzFdOwoJYnl0ZSAweDAwMDAwMDAwMDAwMDAwMDAKCWFwcF9nbG9iYWxfZ2V0CglleHRyYWN0IDIgMAoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWV4dHJhY3QgOCA4CglidG9pCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCgoJLy8gcG9wIGFsbCBsb2NhbCB2YXJpYWJsZXMgZnJvbSB0aGUgc3RhY2sKCXBvcG4gMQoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhlNmJiZGNkMSAvLyBtZXRob2QgInN0b3JhZ2VSZWZLZXkoKXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RvcmFnZVJlZktleQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgwMDAwMDAwMDAwMDAwMDAwIDB4CgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RvcmFnZVJlZktleSgpdWludDY0CiphYmlfcm91dGVfc3RvcmFnZVJlZktleToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHN0b3JhZ2VSZWZLZXkoKXVpbnQ2NAoJY2FsbHN1YiBzdG9yYWdlUmVmS2V5CglpdG9iCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHN0b3JhZ2VSZWZLZXkoKTogdWludDY0CnN0b3JhZ2VSZWZLZXk6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJYnl0ZSAweAoJZHVwCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEwMDAKCS8vIHRoaXMuZ01hcCgwKS52YWx1ZSA9IFsxLCAyLCAzXQoJYnl0ZSAweDAwMDAwMDAwMDAwMDAwMDAKCXB1c2hieXRlcyAweDAwMDMwMDAwMDAwMDAwMDAwMDAxMDAwMDAwMDAwMDAwMDAwMjAwMDAwMDAwMDAwMDAwMDMKCWFwcF9nbG9iYWxfcHV0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEwMDIKCS8vIGkgPSAwCglwdXNoaW50IDAKCWZyYW1lX2J1cnkgMCAvLyBpOiB1aW50NjQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTAwNAoJLy8gciA9IHRoaXMuZ01hcChpKS52YWx1ZQoJZnJhbWVfZGlnIDAgLy8gaTogdWludDY0CglpdG9iCglmcmFtZV9idXJ5IDEgLy8gc3RvcmFnZSBrZXkvL3IKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTAwNgoJLy8gaSA9IDEKCXB1c2hpbnQgMQoJZnJhbWVfYnVyeSAwIC8vIGk6IHVpbnQ2NAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMDA4CgkvLyByWzFdID0gNAoJZnJhbWVfZGlnIDEgLy8gc3RvcmFnZSBrZXkvL3IKCWFwcF9nbG9iYWxfZ2V0CglleHRyYWN0IDIgMAoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDQKCXJlcGxhY2UyIDgKCWZyYW1lX2RpZyAxIC8vIHN0b3JhZ2Uga2V5Ly9yCglzd2FwCglkdXAKCWxlbgoJcHVzaGludCA4CgkvCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0CglhcHBfZ2xvYmFsX3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMDEwCgkvLyByZXR1cm4gdGhpcy5nTWFwKDApLnZhbHVlWzFdOwoJYnl0ZSAweDAwMDAwMDAwMDAwMDAwMDAKCWFwcF9nbG9iYWxfZ2V0CglleHRyYWN0IDIgMAoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWV4dHJhY3QgOCA4CglidG9pCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCgoJLy8gcG9wIGFsbCBsb2NhbCB2YXJpYWJsZXMgZnJvbSB0aGUgc3RhY2sKCXBvcG4gMQoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhlNmJiZGNkMSAvLyBtZXRob2QgInN0b3JhZ2VSZWZLZXkoKXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RvcmFnZVJlZktleQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestStorageRefKey.arc56_draft.json b/tests/contracts/artifacts/ABITestStorageRefKey.arc56_draft.json index c847cba24..a9d210414 100644 --- a/tests/contracts/artifacts/ABITestStorageRefKey.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestStorageRefKey.arc56_draft.json @@ -705,7 +705,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgwMDAwMDAwMDAwMDAwMDAwIDB4CgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RvcmFnZVJlZktleSgpdWludDY0CiphYmlfcm91dGVfc3RvcmFnZVJlZktleToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHN0b3JhZ2VSZWZLZXkoKXVpbnQ2NAoJY2FsbHN1YiBzdG9yYWdlUmVmS2V5CglpdG9iCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHN0b3JhZ2VSZWZLZXkoKTogdWludDY0CnN0b3JhZ2VSZWZLZXk6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJYnl0ZSAweAoJZHVwCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEwMDAKCS8vIHRoaXMuZ01hcCgwKS52YWx1ZSA9IFsxLCAyLCAzXQoJYnl0ZSAweDAwMDAwMDAwMDAwMDAwMDAKCXB1c2hieXRlcyAweDAwMDMwMDAwMDAwMDAwMDAwMDAxMDAwMDAwMDAwMDAwMDAwMjAwMDAwMDAwMDAwMDAwMDMKCWFwcF9nbG9iYWxfcHV0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEwMDIKCS8vIGkgPSAwCglwdXNoaW50IDAKCWZyYW1lX2J1cnkgMCAvLyBpOiB1aW50NjQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTAwNAoJLy8gciA9IHRoaXMuZ01hcChpKS52YWx1ZQoJZnJhbWVfZGlnIDAgLy8gaTogdWludDY0CglpdG9iCglmcmFtZV9idXJ5IDEgLy8gc3RvcmFnZSBrZXkvL3IKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTAwNgoJLy8gaSA9IDEKCXB1c2hpbnQgMQoJZnJhbWVfYnVyeSAwIC8vIGk6IHVpbnQ2NAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMDA4CgkvLyByWzFdID0gNAoJZnJhbWVfZGlnIDEgLy8gc3RvcmFnZSBrZXkvL3IKCWFwcF9nbG9iYWxfZ2V0CglleHRyYWN0IDIgMAoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDQKCXJlcGxhY2UyIDgKCWZyYW1lX2RpZyAxIC8vIHN0b3JhZ2Uga2V5Ly9yCglzd2FwCglkdXAKCWxlbgoJcHVzaGludCA4CgkvCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0CglhcHBfZ2xvYmFsX3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMDEwCgkvLyByZXR1cm4gdGhpcy5nTWFwKDApLnZhbHVlWzFdOwoJYnl0ZSAweDAwMDAwMDAwMDAwMDAwMDAKCWFwcF9nbG9iYWxfZ2V0CglleHRyYWN0IDIgMAoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWV4dHJhY3QgOCA4CglidG9pCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCgoJLy8gcG9wIGFsbCBsb2NhbCB2YXJpYWJsZXMgZnJvbSB0aGUgc3RhY2sKCXBvcG4gMQoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhlNmJiZGNkMSAvLyBtZXRob2QgInN0b3JhZ2VSZWZLZXkoKXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RvcmFnZVJlZktleQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgwMDAwMDAwMDAwMDAwMDAwIDB4CgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RvcmFnZVJlZktleSgpdWludDY0CiphYmlfcm91dGVfc3RvcmFnZVJlZktleToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHN0b3JhZ2VSZWZLZXkoKXVpbnQ2NAoJY2FsbHN1YiBzdG9yYWdlUmVmS2V5CglpdG9iCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHN0b3JhZ2VSZWZLZXkoKTogdWludDY0CnN0b3JhZ2VSZWZLZXk6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJYnl0ZSAweAoJZHVwCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEwMDAKCS8vIHRoaXMuZ01hcCgwKS52YWx1ZSA9IFsxLCAyLCAzXQoJYnl0ZSAweDAwMDAwMDAwMDAwMDAwMDAKCXB1c2hieXRlcyAweDAwMDMwMDAwMDAwMDAwMDAwMDAxMDAwMDAwMDAwMDAwMDAwMjAwMDAwMDAwMDAwMDAwMDMKCWFwcF9nbG9iYWxfcHV0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEwMDIKCS8vIGkgPSAwCglwdXNoaW50IDAKCWZyYW1lX2J1cnkgMCAvLyBpOiB1aW50NjQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTAwNAoJLy8gciA9IHRoaXMuZ01hcChpKS52YWx1ZQoJZnJhbWVfZGlnIDAgLy8gaTogdWludDY0CglpdG9iCglmcmFtZV9idXJ5IDEgLy8gc3RvcmFnZSBrZXkvL3IKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTAwNgoJLy8gaSA9IDEKCXB1c2hpbnQgMQoJZnJhbWVfYnVyeSAwIC8vIGk6IHVpbnQ2NAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMDA4CgkvLyByWzFdID0gNAoJZnJhbWVfZGlnIDEgLy8gc3RvcmFnZSBrZXkvL3IKCWFwcF9nbG9iYWxfZ2V0CglleHRyYWN0IDIgMAoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMDQKCXJlcGxhY2UyIDgKCWZyYW1lX2RpZyAxIC8vIHN0b3JhZ2Uga2V5Ly9yCglzd2FwCglkdXAKCWxlbgoJcHVzaGludCA4CgkvCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0CglhcHBfZ2xvYmFsX3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMDEwCgkvLyByZXR1cm4gdGhpcy5nTWFwKDApLnZhbHVlWzFdOwoJYnl0ZSAweDAwMDAwMDAwMDAwMDAwMDAKCWFwcF9nbG9iYWxfZ2V0CglleHRyYWN0IDIgMAoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWV4dHJhY3QgOCA4CglidG9pCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCgoJLy8gcG9wIGFsbCBsb2NhbCB2YXJpYWJsZXMgZnJvbSB0aGUgc3RhY2sKCXBvcG4gMQoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhlNmJiZGNkMSAvLyBtZXRob2QgInN0b3JhZ2VSZWZLZXkoKXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RvcmFnZVJlZktleQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestStorageTypeHint.approval.teal b/tests/contracts/artifacts/ABITestStorageTypeHint.approval.teal index 2d6f86a47..fcabb87bb 100644 --- a/tests/contracts/artifacts/ABITestStorageTypeHint.approval.teal +++ b/tests/contracts/artifacts/ABITestStorageTypeHint.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x674b6579 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestStorageTypeHint.arc32.json b/tests/contracts/artifacts/ABITestStorageTypeHint.arc32.json index f0dd1ed51..0592f837a 100644 --- a/tests/contracts/artifacts/ABITestStorageTypeHint.arc32.json +++ b/tests/contracts/artifacts/ABITestStorageTypeHint.arc32.json @@ -44,7 +44,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2NzRiNjU3OQoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDQuMQovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIHBhcnRpYWxTdGF0aWNBcnJheSgpdWludDE2WzNdCiphYmlfcm91dGVfcGFydGlhbFN0YXRpY0FycmF5OgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgcGFydGlhbFN0YXRpY0FycmF5KCl1aW50MTZbM10KCWNhbGxzdWIgcGFydGlhbFN0YXRpY0FycmF5Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHBhcnRpYWxTdGF0aWNBcnJheSgpOiBTdGF0aWNBcnJheTx1aW50MTYsIDM+CnBhcnRpYWxTdGF0aWNBcnJheToKCXByb3RvIDAgMQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4NjAKCS8vIHRoaXMuZ0tleS52YWx1ZSA9IFsxLCAyLCAzXQoJYnl0ZSAweDY3NGI2NTc5IC8vICJnS2V5IgoJcHVzaGJ5dGVzIDB4MDAwMTAwMDIwMDAzCglhcHBfZ2xvYmFsX3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4NjIKCS8vIHJldHVybiB0aGlzLmdLZXkudmFsdWU7CglieXRlIDB4Njc0YjY1NzkgLy8gImdLZXkiCglhcHBfZ2xvYmFsX2dldAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhkMjk0ZGMxNCAvLyBtZXRob2QgInBhcnRpYWxTdGF0aWNBcnJheSgpdWludDE2WzNdIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9wYXJ0aWFsU3RhdGljQXJyYXkKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2NzRiNjU3OQoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDUuMAovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIHBhcnRpYWxTdGF0aWNBcnJheSgpdWludDE2WzNdCiphYmlfcm91dGVfcGFydGlhbFN0YXRpY0FycmF5OgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgcGFydGlhbFN0YXRpY0FycmF5KCl1aW50MTZbM10KCWNhbGxzdWIgcGFydGlhbFN0YXRpY0FycmF5Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHBhcnRpYWxTdGF0aWNBcnJheSgpOiBTdGF0aWNBcnJheTx1aW50MTYsIDM+CnBhcnRpYWxTdGF0aWNBcnJheToKCXByb3RvIDAgMQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4NjAKCS8vIHRoaXMuZ0tleS52YWx1ZSA9IFsxLCAyLCAzXQoJYnl0ZSAweDY3NGI2NTc5IC8vICJnS2V5IgoJcHVzaGJ5dGVzIDB4MDAwMTAwMDIwMDAzCglhcHBfZ2xvYmFsX3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4NjIKCS8vIHJldHVybiB0aGlzLmdLZXkudmFsdWU7CglieXRlIDB4Njc0YjY1NzkgLy8gImdLZXkiCglhcHBfZ2xvYmFsX2dldAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhkMjk0ZGMxNCAvLyBtZXRob2QgInBhcnRpYWxTdGF0aWNBcnJheSgpdWludDE2WzNdIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9wYXJ0aWFsU3RhdGljQXJyYXkKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestStorageTypeHint.arc56_draft.json b/tests/contracts/artifacts/ABITestStorageTypeHint.arc56_draft.json index e0642a796..facf74a26 100644 --- a/tests/contracts/artifacts/ABITestStorageTypeHint.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestStorageTypeHint.arc56_draft.json @@ -394,7 +394,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2NzRiNjU3OQoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDQuMQovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIHBhcnRpYWxTdGF0aWNBcnJheSgpdWludDE2WzNdCiphYmlfcm91dGVfcGFydGlhbFN0YXRpY0FycmF5OgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgcGFydGlhbFN0YXRpY0FycmF5KCl1aW50MTZbM10KCWNhbGxzdWIgcGFydGlhbFN0YXRpY0FycmF5Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHBhcnRpYWxTdGF0aWNBcnJheSgpOiBTdGF0aWNBcnJheTx1aW50MTYsIDM+CnBhcnRpYWxTdGF0aWNBcnJheToKCXByb3RvIDAgMQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4NjAKCS8vIHRoaXMuZ0tleS52YWx1ZSA9IFsxLCAyLCAzXQoJYnl0ZSAweDY3NGI2NTc5IC8vICJnS2V5IgoJcHVzaGJ5dGVzIDB4MDAwMTAwMDIwMDAzCglhcHBfZ2xvYmFsX3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4NjIKCS8vIHJldHVybiB0aGlzLmdLZXkudmFsdWU7CglieXRlIDB4Njc0YjY1NzkgLy8gImdLZXkiCglhcHBfZ2xvYmFsX2dldAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhkMjk0ZGMxNCAvLyBtZXRob2QgInBhcnRpYWxTdGF0aWNBcnJheSgpdWludDE2WzNdIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9wYXJ0aWFsU3RhdGljQXJyYXkKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2NzRiNjU3OQoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDUuMAovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIHBhcnRpYWxTdGF0aWNBcnJheSgpdWludDE2WzNdCiphYmlfcm91dGVfcGFydGlhbFN0YXRpY0FycmF5OgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgcGFydGlhbFN0YXRpY0FycmF5KCl1aW50MTZbM10KCWNhbGxzdWIgcGFydGlhbFN0YXRpY0FycmF5Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHBhcnRpYWxTdGF0aWNBcnJheSgpOiBTdGF0aWNBcnJheTx1aW50MTYsIDM+CnBhcnRpYWxTdGF0aWNBcnJheToKCXByb3RvIDAgMQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4NjAKCS8vIHRoaXMuZ0tleS52YWx1ZSA9IFsxLCAyLCAzXQoJYnl0ZSAweDY3NGI2NTc5IC8vICJnS2V5IgoJcHVzaGJ5dGVzIDB4MDAwMTAwMDIwMDAzCglhcHBfZ2xvYmFsX3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4NjIKCS8vIHJldHVybiB0aGlzLmdLZXkudmFsdWU7CglieXRlIDB4Njc0YjY1NzkgLy8gImdLZXkiCglhcHBfZ2xvYmFsX2dldAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhkMjk0ZGMxNCAvLyBtZXRob2QgInBhcnRpYWxTdGF0aWNBcnJheSgpdWludDE2WzNdIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9wYXJ0aWFsU3RhdGljQXJyYXkKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestStringAccessor.approval.teal b/tests/contracts/artifacts/ABITestStringAccessor.approval.teal index a245a3015..93f5edf78 100644 --- a/tests/contracts/artifacts/ABITestStringAccessor.approval.teal +++ b/tests/contracts/artifacts/ABITestStringAccessor.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestStringAccessor.arc32.json b/tests/contracts/artifacts/ABITestStringAccessor.arc32.json index 83e8b6e0a..c1b88f40a 100644 --- a/tests/contracts/artifacts/ABITestStringAccessor.arc32.json +++ b/tests/contracts/artifacts/ABITestStringAccessor.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RyaW5nQWNjZXNzb3IoKXN0cmluZwoqYWJpX3JvdXRlX3N0cmluZ0FjY2Vzc29yOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgc3RyaW5nQWNjZXNzb3IoKXN0cmluZwoJY2FsbHN1YiBzdHJpbmdBY2Nlc3NvcgoJZHVwCglsZW4KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gc3RyaW5nQWNjZXNzb3IoKTogc3RyaW5nCnN0cmluZ0FjY2Vzc29yOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4MzQKCS8vIHMgPSBjb25jYXQoJ0hlbGxvICcsICdXb3JsZCcpCglwdXNoYnl0ZXMgMHg0ODY1NmM2YzZmMjA1NzZmNzI2YzY0CglmcmFtZV9idXJ5IDAgLy8gczogYnl0ZVtdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjgzNgoJLy8gcmV0dXJuIHNbMV07CglmcmFtZV9kaWcgMCAvLyBzOiBieXRlW10KCWV4dHJhY3QgMSAxCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGRjNjM2MzI0IC8vIG1ldGhvZCAic3RyaW5nQWNjZXNzb3IoKXN0cmluZyIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RyaW5nQWNjZXNzb3IKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RyaW5nQWNjZXNzb3IoKXN0cmluZwoqYWJpX3JvdXRlX3N0cmluZ0FjY2Vzc29yOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgc3RyaW5nQWNjZXNzb3IoKXN0cmluZwoJY2FsbHN1YiBzdHJpbmdBY2Nlc3NvcgoJZHVwCglsZW4KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gc3RyaW5nQWNjZXNzb3IoKTogc3RyaW5nCnN0cmluZ0FjY2Vzc29yOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4MzQKCS8vIHMgPSBjb25jYXQoJ0hlbGxvICcsICdXb3JsZCcpCglwdXNoYnl0ZXMgMHg0ODY1NmM2YzZmMjA1NzZmNzI2YzY0CglmcmFtZV9idXJ5IDAgLy8gczogYnl0ZVtdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjgzNgoJLy8gcmV0dXJuIHNbMV07CglmcmFtZV9kaWcgMCAvLyBzOiBieXRlW10KCWV4dHJhY3QgMSAxCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGRjNjM2MzI0IC8vIG1ldGhvZCAic3RyaW5nQWNjZXNzb3IoKXN0cmluZyIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RyaW5nQWNjZXNzb3IKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestStringAccessor.arc56_draft.json b/tests/contracts/artifacts/ABITestStringAccessor.arc56_draft.json index ea09b4942..170a4612a 100644 --- a/tests/contracts/artifacts/ABITestStringAccessor.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestStringAccessor.arc56_draft.json @@ -427,7 +427,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RyaW5nQWNjZXNzb3IoKXN0cmluZwoqYWJpX3JvdXRlX3N0cmluZ0FjY2Vzc29yOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgc3RyaW5nQWNjZXNzb3IoKXN0cmluZwoJY2FsbHN1YiBzdHJpbmdBY2Nlc3NvcgoJZHVwCglsZW4KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gc3RyaW5nQWNjZXNzb3IoKTogc3RyaW5nCnN0cmluZ0FjY2Vzc29yOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4MzQKCS8vIHMgPSBjb25jYXQoJ0hlbGxvICcsICdXb3JsZCcpCglwdXNoYnl0ZXMgMHg0ODY1NmM2YzZmMjA1NzZmNzI2YzY0CglmcmFtZV9idXJ5IDAgLy8gczogYnl0ZVtdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjgzNgoJLy8gcmV0dXJuIHNbMV07CglmcmFtZV9kaWcgMCAvLyBzOiBieXRlW10KCWV4dHJhY3QgMSAxCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGRjNjM2MzI0IC8vIG1ldGhvZCAic3RyaW5nQWNjZXNzb3IoKXN0cmluZyIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RyaW5nQWNjZXNzb3IKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RyaW5nQWNjZXNzb3IoKXN0cmluZwoqYWJpX3JvdXRlX3N0cmluZ0FjY2Vzc29yOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgc3RyaW5nQWNjZXNzb3IoKXN0cmluZwoJY2FsbHN1YiBzdHJpbmdBY2Nlc3NvcgoJZHVwCglsZW4KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gc3RyaW5nQWNjZXNzb3IoKTogc3RyaW5nCnN0cmluZ0FjY2Vzc29yOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo4MzQKCS8vIHMgPSBjb25jYXQoJ0hlbGxvICcsICdXb3JsZCcpCglwdXNoYnl0ZXMgMHg0ODY1NmM2YzZmMjA1NzZmNzI2YzY0CglmcmFtZV9idXJ5IDAgLy8gczogYnl0ZVtdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjgzNgoJLy8gcmV0dXJuIHNbMV07CglmcmFtZV9kaWcgMCAvLyBzOiBieXRlW10KCWV4dHJhY3QgMSAxCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGRjNjM2MzI0IC8vIG1ldGhvZCAic3RyaW5nQWNjZXNzb3IoKXN0cmluZyIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RyaW5nQWNjZXNzb3IKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestStringArg.approval.teal b/tests/contracts/artifacts/ABITestStringArg.approval.teal index 2063c5176..7e6540e54 100644 --- a/tests/contracts/artifacts/ABITestStringArg.approval.teal +++ b/tests/contracts/artifacts/ABITestStringArg.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestStringArg.arc32.json b/tests/contracts/artifacts/ABITestStringArg.arc32.json index ed99e36d5..cb7e809be 100644 --- a/tests/contracts/artifacts/ABITestStringArg.arc32.json +++ b/tests/contracts/artifacts/ABITestStringArg.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RyaW5nQXJnKHN0cmluZyl2b2lkCiphYmlfcm91dGVfc3RyaW5nQXJnOgoJLy8gczogc3RyaW5nCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglleHRyYWN0IDIgMAoKCS8vIGV4ZWN1dGUgc3RyaW5nQXJnKHN0cmluZyl2b2lkCgljYWxsc3ViIHN0cmluZ0FyZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHN0cmluZ0FyZyhzOiBzdHJpbmcpOiB2b2lkCnN0cmluZ0FyZzoKCXByb3RvIDEgMAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo1MzYKCS8vIGFzc2VydChzID09PSAnSGVsbG8gV29ybGQhJykKCWZyYW1lX2RpZyAtMSAvLyBzOiBzdHJpbmcKCXB1c2hieXRlcyAweDQ4NjU2YzZjNmYyMDU3NmY3MjZjNjQyMSAvLyAiSGVsbG8gV29ybGQhIgoJPT0KCWFzc2VydAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhhZmE1NmRkMSAvLyBtZXRob2QgInN0cmluZ0FyZyhzdHJpbmcpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RyaW5nQXJnCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RyaW5nQXJnKHN0cmluZyl2b2lkCiphYmlfcm91dGVfc3RyaW5nQXJnOgoJLy8gczogc3RyaW5nCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglleHRyYWN0IDIgMAoKCS8vIGV4ZWN1dGUgc3RyaW5nQXJnKHN0cmluZyl2b2lkCgljYWxsc3ViIHN0cmluZ0FyZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHN0cmluZ0FyZyhzOiBzdHJpbmcpOiB2b2lkCnN0cmluZ0FyZzoKCXByb3RvIDEgMAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo1MzYKCS8vIGFzc2VydChzID09PSAnSGVsbG8gV29ybGQhJykKCWZyYW1lX2RpZyAtMSAvLyBzOiBzdHJpbmcKCXB1c2hieXRlcyAweDQ4NjU2YzZjNmYyMDU3NmY3MjZjNjQyMSAvLyAiSGVsbG8gV29ybGQhIgoJPT0KCWFzc2VydAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhhZmE1NmRkMSAvLyBtZXRob2QgInN0cmluZ0FyZyhzdHJpbmcpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RyaW5nQXJnCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestStringArg.arc56_draft.json b/tests/contracts/artifacts/ABITestStringArg.arc56_draft.json index 1867d10de..2faaca3cd 100644 --- a/tests/contracts/artifacts/ABITestStringArg.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestStringArg.arc56_draft.json @@ -362,7 +362,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RyaW5nQXJnKHN0cmluZyl2b2lkCiphYmlfcm91dGVfc3RyaW5nQXJnOgoJLy8gczogc3RyaW5nCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglleHRyYWN0IDIgMAoKCS8vIGV4ZWN1dGUgc3RyaW5nQXJnKHN0cmluZyl2b2lkCgljYWxsc3ViIHN0cmluZ0FyZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHN0cmluZ0FyZyhzOiBzdHJpbmcpOiB2b2lkCnN0cmluZ0FyZzoKCXByb3RvIDEgMAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo1MzYKCS8vIGFzc2VydChzID09PSAnSGVsbG8gV29ybGQhJykKCWZyYW1lX2RpZyAtMSAvLyBzOiBzdHJpbmcKCXB1c2hieXRlcyAweDQ4NjU2YzZjNmYyMDU3NmY3MjZjNjQyMSAvLyAiSGVsbG8gV29ybGQhIgoJPT0KCWFzc2VydAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhhZmE1NmRkMSAvLyBtZXRob2QgInN0cmluZ0FyZyhzdHJpbmcpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RyaW5nQXJnCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RyaW5nQXJnKHN0cmluZyl2b2lkCiphYmlfcm91dGVfc3RyaW5nQXJnOgoJLy8gczogc3RyaW5nCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglleHRyYWN0IDIgMAoKCS8vIGV4ZWN1dGUgc3RyaW5nQXJnKHN0cmluZyl2b2lkCgljYWxsc3ViIHN0cmluZ0FyZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHN0cmluZ0FyZyhzOiBzdHJpbmcpOiB2b2lkCnN0cmluZ0FyZzoKCXByb3RvIDEgMAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo1MzYKCS8vIGFzc2VydChzID09PSAnSGVsbG8gV29ybGQhJykKCWZyYW1lX2RpZyAtMSAvLyBzOiBzdHJpbmcKCXB1c2hieXRlcyAweDQ4NjU2YzZjNmYyMDU3NmY3MjZjNjQyMSAvLyAiSGVsbG8gV29ybGQhIgoJPT0KCWFzc2VydAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhhZmE1NmRkMSAvLyBtZXRob2QgInN0cmluZ0FyZyhzdHJpbmcpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RyaW5nQXJnCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestStringArray.approval.teal b/tests/contracts/artifacts/ABITestStringArray.approval.teal index 5dd7b1069..f9ef92be4 100644 --- a/tests/contracts/artifacts/ABITestStringArray.approval.teal +++ b/tests/contracts/artifacts/ABITestStringArray.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestStringArray.arc32.json b/tests/contracts/artifacts/ABITestStringArray.arc32.json index 2b46fb826..dc3466c5e 100644 --- a/tests/contracts/artifacts/ABITestStringArray.arc32.json +++ b/tests/contracts/artifacts/ABITestStringArray.arc32.json @@ -44,7 +44,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RyaW5nQXJyYXkoc3RyaW5nW10pdm9pZAoqYWJpX3JvdXRlX3N0cmluZ0FycmF5OgoJLy8gYTogc3RyaW5nW10KCXR4bmEgQXBwbGljYXRpb25BcmdzIDEKCgkvLyBleGVjdXRlIHN0cmluZ0FycmF5KHN0cmluZ1tdKXZvaWQKCWNhbGxzdWIgc3RyaW5nQXJyYXkKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBzdHJpbmdBcnJheShhOiBzdHJpbmdbXSk6IHZvaWQKc3RyaW5nQXJyYXk6Cglwcm90byAxIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTE4MwoJLy8gdGhpcy5nS2V5LnZhbHVlID0gYQoJcHVzaGJ5dGVzIDB4Njc0YjY1NzkgLy8gImdLZXkiCglmcmFtZV9kaWcgLTEgLy8gYTogc3RyaW5nW10KCWFwcF9nbG9iYWxfcHV0CglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDgyNGQ2NDY3IC8vIG1ldGhvZCAic3RyaW5nQXJyYXkoc3RyaW5nW10pdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RyaW5nQXJyYXkKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RyaW5nQXJyYXkoc3RyaW5nW10pdm9pZAoqYWJpX3JvdXRlX3N0cmluZ0FycmF5OgoJLy8gYTogc3RyaW5nW10KCXR4bmEgQXBwbGljYXRpb25BcmdzIDEKCgkvLyBleGVjdXRlIHN0cmluZ0FycmF5KHN0cmluZ1tdKXZvaWQKCWNhbGxzdWIgc3RyaW5nQXJyYXkKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBzdHJpbmdBcnJheShhOiBzdHJpbmdbXSk6IHZvaWQKc3RyaW5nQXJyYXk6Cglwcm90byAxIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTE4MwoJLy8gdGhpcy5nS2V5LnZhbHVlID0gYQoJcHVzaGJ5dGVzIDB4Njc0YjY1NzkgLy8gImdLZXkiCglmcmFtZV9kaWcgLTEgLy8gYTogc3RyaW5nW10KCWFwcF9nbG9iYWxfcHV0CglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDgyNGQ2NDY3IC8vIG1ldGhvZCAic3RyaW5nQXJyYXkoc3RyaW5nW10pdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RyaW5nQXJyYXkKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestStringArray.arc56_draft.json b/tests/contracts/artifacts/ABITestStringArray.arc56_draft.json index ca30bdde6..ae854301b 100644 --- a/tests/contracts/artifacts/ABITestStringArray.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestStringArray.arc56_draft.json @@ -344,7 +344,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RyaW5nQXJyYXkoc3RyaW5nW10pdm9pZAoqYWJpX3JvdXRlX3N0cmluZ0FycmF5OgoJLy8gYTogc3RyaW5nW10KCXR4bmEgQXBwbGljYXRpb25BcmdzIDEKCgkvLyBleGVjdXRlIHN0cmluZ0FycmF5KHN0cmluZ1tdKXZvaWQKCWNhbGxzdWIgc3RyaW5nQXJyYXkKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBzdHJpbmdBcnJheShhOiBzdHJpbmdbXSk6IHZvaWQKc3RyaW5nQXJyYXk6Cglwcm90byAxIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTE4MwoJLy8gdGhpcy5nS2V5LnZhbHVlID0gYQoJcHVzaGJ5dGVzIDB4Njc0YjY1NzkgLy8gImdLZXkiCglmcmFtZV9kaWcgLTEgLy8gYTogc3RyaW5nW10KCWFwcF9nbG9iYWxfcHV0CglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDgyNGQ2NDY3IC8vIG1ldGhvZCAic3RyaW5nQXJyYXkoc3RyaW5nW10pdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RyaW5nQXJyYXkKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RyaW5nQXJyYXkoc3RyaW5nW10pdm9pZAoqYWJpX3JvdXRlX3N0cmluZ0FycmF5OgoJLy8gYTogc3RyaW5nW10KCXR4bmEgQXBwbGljYXRpb25BcmdzIDEKCgkvLyBleGVjdXRlIHN0cmluZ0FycmF5KHN0cmluZ1tdKXZvaWQKCWNhbGxzdWIgc3RyaW5nQXJyYXkKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBzdHJpbmdBcnJheShhOiBzdHJpbmdbXSk6IHZvaWQKc3RyaW5nQXJyYXk6Cglwcm90byAxIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTE4MwoJLy8gdGhpcy5nS2V5LnZhbHVlID0gYQoJcHVzaGJ5dGVzIDB4Njc0YjY1NzkgLy8gImdLZXkiCglmcmFtZV9kaWcgLTEgLy8gYTogc3RyaW5nW10KCWFwcF9nbG9iYWxfcHV0CglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDgyNGQ2NDY3IC8vIG1ldGhvZCAic3RyaW5nQXJyYXkoc3RyaW5nW10pdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RyaW5nQXJyYXkKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestStringInTuple.approval.teal b/tests/contracts/artifacts/ABITestStringInTuple.approval.teal index 44b8f73bd..eec3a76c6 100644 --- a/tests/contracts/artifacts/ABITestStringInTuple.approval.teal +++ b/tests/contracts/artifacts/ABITestStringInTuple.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestStringInTuple.arc32.json b/tests/contracts/artifacts/ABITestStringInTuple.arc32.json index 8fa3d96d5..c301ade7f 100644 --- a/tests/contracts/artifacts/ABITestStringInTuple.arc32.json +++ b/tests/contracts/artifacts/ABITestStringInTuple.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBzdHJpbmdJblR1cGxlKCkodWludDE2LHVpbnQ4W10sc3RyaW5nLHVpbnQ4W10pCiphYmlfcm91dGVfc3RyaW5nSW5UdXBsZToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHN0cmluZ0luVHVwbGUoKSh1aW50MTYsdWludDhbXSxzdHJpbmcsdWludDhbXSkKCWNhbGxzdWIgc3RyaW5nSW5UdXBsZQoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBzdHJpbmdJblR1cGxlKCk6IFt1aW50MTYsIHVpbnQ8OD5bXSwgc3RyaW5nLCB1aW50PDg+W11dCnN0cmluZ0luVHVwbGU6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJYnl0ZSAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo1NDIKCS8vIGE6IFt1aW50MTYsIHVpbnQ8OD5bXSwgc3RyaW5nLCB1aW50PDg+W11dID0gWzEsIFsyXSwgJ0hlbGxvIFdvcmxkIScsIFszXV0KCWJ5dGUgMHggLy8gaW5pdGlhbCBoZWFkCglieXRlIDB4IC8vIGluaXRpYWwgdGFpbAoJcHVzaGJ5dGVzIDB4MDAwOCAvLyBpbml0aWFsIGhlYWQgb2Zmc2V0CglwdXNoYnl0ZXMgMHgwMDAxCgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAxMDIKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDBjNDg2NTZjNmM2ZjIwNTc2ZjcyNmM2NDIxCgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwMTAzCgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcG9wIC8vIHBvcCBoZWFkIG9mZnNldAoJY29uY2F0IC8vIGNvbmNhdCBoZWFkIGFuZCB0YWlsCglmcmFtZV9idXJ5IDAgLy8gYTogW3VpbnQxNiwgdWludDw4PltdLCBzdHJpbmcsIHVpbnQ8OD5bXV0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NTQ0CgkvLyByZXR1cm4gYTsKCWZyYW1lX2RpZyAwIC8vIGE6IFt1aW50MTYsIHVpbnQ8OD5bXSwgc3RyaW5nLCB1aW50PDg+W11dCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDRjMGQ1NjU4IC8vIG1ldGhvZCAic3RyaW5nSW5UdXBsZSgpKHVpbnQxNix1aW50OFtdLHN0cmluZyx1aW50OFtdKSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RyaW5nSW5UdXBsZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycgoKKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJY29uY2F0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWIKCipwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJY29uY2F0CglmcmFtZV9idXJ5IC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50CglkdXAKCWxlbgoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglidG9pCgkrCglpdG9iCglleHRyYWN0IDYgMgoJZnJhbWVfYnVyeSAtMiAvLyBoZWFkIG9mZnNldAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCXN3YXAKCWNvbmNhdAoJZnJhbWVfYnVyeSAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3Vi", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBzdHJpbmdJblR1cGxlKCkodWludDE2LHVpbnQ4W10sc3RyaW5nLHVpbnQ4W10pCiphYmlfcm91dGVfc3RyaW5nSW5UdXBsZToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHN0cmluZ0luVHVwbGUoKSh1aW50MTYsdWludDhbXSxzdHJpbmcsdWludDhbXSkKCWNhbGxzdWIgc3RyaW5nSW5UdXBsZQoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBzdHJpbmdJblR1cGxlKCk6IFt1aW50MTYsIHVpbnQ8OD5bXSwgc3RyaW5nLCB1aW50PDg+W11dCnN0cmluZ0luVHVwbGU6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJYnl0ZSAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo1NDIKCS8vIGE6IFt1aW50MTYsIHVpbnQ8OD5bXSwgc3RyaW5nLCB1aW50PDg+W11dID0gWzEsIFsyXSwgJ0hlbGxvIFdvcmxkIScsIFszXV0KCWJ5dGUgMHggLy8gaW5pdGlhbCBoZWFkCglieXRlIDB4IC8vIGluaXRpYWwgdGFpbAoJcHVzaGJ5dGVzIDB4MDAwOCAvLyBpbml0aWFsIGhlYWQgb2Zmc2V0CglwdXNoYnl0ZXMgMHgwMDAxCgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAxMDIKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDBjNDg2NTZjNmM2ZjIwNTc2ZjcyNmM2NDIxCgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwMTAzCgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcG9wIC8vIHBvcCBoZWFkIG9mZnNldAoJY29uY2F0IC8vIGNvbmNhdCBoZWFkIGFuZCB0YWlsCglmcmFtZV9idXJ5IDAgLy8gYTogW3VpbnQxNiwgdWludDw4PltdLCBzdHJpbmcsIHVpbnQ8OD5bXV0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NTQ0CgkvLyByZXR1cm4gYTsKCWZyYW1lX2RpZyAwIC8vIGE6IFt1aW50MTYsIHVpbnQ8OD5bXSwgc3RyaW5nLCB1aW50PDg+W11dCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDRjMGQ1NjU4IC8vIG1ldGhvZCAic3RyaW5nSW5UdXBsZSgpKHVpbnQxNix1aW50OFtdLHN0cmluZyx1aW50OFtdKSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RyaW5nSW5UdXBsZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycgoKKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJY29uY2F0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWIKCipwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJY29uY2F0CglmcmFtZV9idXJ5IC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50CglkdXAKCWxlbgoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglidG9pCgkrCglpdG9iCglleHRyYWN0IDYgMgoJZnJhbWVfYnVyeSAtMiAvLyBoZWFkIG9mZnNldAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCXN3YXAKCWNvbmNhdAoJZnJhbWVfYnVyeSAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3Vi", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestStringInTuple.arc56_draft.json b/tests/contracts/artifacts/ABITestStringInTuple.arc56_draft.json index 3aef4562e..d2284c195 100644 --- a/tests/contracts/artifacts/ABITestStringInTuple.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestStringInTuple.arc56_draft.json @@ -718,7 +718,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBzdHJpbmdJblR1cGxlKCkodWludDE2LHVpbnQ4W10sc3RyaW5nLHVpbnQ4W10pCiphYmlfcm91dGVfc3RyaW5nSW5UdXBsZToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHN0cmluZ0luVHVwbGUoKSh1aW50MTYsdWludDhbXSxzdHJpbmcsdWludDhbXSkKCWNhbGxzdWIgc3RyaW5nSW5UdXBsZQoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBzdHJpbmdJblR1cGxlKCk6IFt1aW50MTYsIHVpbnQ8OD5bXSwgc3RyaW5nLCB1aW50PDg+W11dCnN0cmluZ0luVHVwbGU6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJYnl0ZSAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo1NDIKCS8vIGE6IFt1aW50MTYsIHVpbnQ8OD5bXSwgc3RyaW5nLCB1aW50PDg+W11dID0gWzEsIFsyXSwgJ0hlbGxvIFdvcmxkIScsIFszXV0KCWJ5dGUgMHggLy8gaW5pdGlhbCBoZWFkCglieXRlIDB4IC8vIGluaXRpYWwgdGFpbAoJcHVzaGJ5dGVzIDB4MDAwOCAvLyBpbml0aWFsIGhlYWQgb2Zmc2V0CglwdXNoYnl0ZXMgMHgwMDAxCgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAxMDIKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDBjNDg2NTZjNmM2ZjIwNTc2ZjcyNmM2NDIxCgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwMTAzCgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcG9wIC8vIHBvcCBoZWFkIG9mZnNldAoJY29uY2F0IC8vIGNvbmNhdCBoZWFkIGFuZCB0YWlsCglmcmFtZV9idXJ5IDAgLy8gYTogW3VpbnQxNiwgdWludDw4PltdLCBzdHJpbmcsIHVpbnQ8OD5bXV0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NTQ0CgkvLyByZXR1cm4gYTsKCWZyYW1lX2RpZyAwIC8vIGE6IFt1aW50MTYsIHVpbnQ8OD5bXSwgc3RyaW5nLCB1aW50PDg+W11dCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDRjMGQ1NjU4IC8vIG1ldGhvZCAic3RyaW5nSW5UdXBsZSgpKHVpbnQxNix1aW50OFtdLHN0cmluZyx1aW50OFtdKSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RyaW5nSW5UdXBsZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycgoKKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJY29uY2F0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWIKCipwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJY29uY2F0CglmcmFtZV9idXJ5IC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50CglkdXAKCWxlbgoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglidG9pCgkrCglpdG9iCglleHRyYWN0IDYgMgoJZnJhbWVfYnVyeSAtMiAvLyBoZWFkIG9mZnNldAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCXN3YXAKCWNvbmNhdAoJZnJhbWVfYnVyeSAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3Vi", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBzdHJpbmdJblR1cGxlKCkodWludDE2LHVpbnQ4W10sc3RyaW5nLHVpbnQ4W10pCiphYmlfcm91dGVfc3RyaW5nSW5UdXBsZToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHN0cmluZ0luVHVwbGUoKSh1aW50MTYsdWludDhbXSxzdHJpbmcsdWludDhbXSkKCWNhbGxzdWIgc3RyaW5nSW5UdXBsZQoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBzdHJpbmdJblR1cGxlKCk6IFt1aW50MTYsIHVpbnQ8OD5bXSwgc3RyaW5nLCB1aW50PDg+W11dCnN0cmluZ0luVHVwbGU6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJYnl0ZSAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo1NDIKCS8vIGE6IFt1aW50MTYsIHVpbnQ8OD5bXSwgc3RyaW5nLCB1aW50PDg+W11dID0gWzEsIFsyXSwgJ0hlbGxvIFdvcmxkIScsIFszXV0KCWJ5dGUgMHggLy8gaW5pdGlhbCBoZWFkCglieXRlIDB4IC8vIGluaXRpYWwgdGFpbAoJcHVzaGJ5dGVzIDB4MDAwOCAvLyBpbml0aWFsIGhlYWQgb2Zmc2V0CglwdXNoYnl0ZXMgMHgwMDAxCgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAxMDIKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDBjNDg2NTZjNmM2ZjIwNTc2ZjcyNmM2NDIxCgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwMTAzCgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcG9wIC8vIHBvcCBoZWFkIG9mZnNldAoJY29uY2F0IC8vIGNvbmNhdCBoZWFkIGFuZCB0YWlsCglmcmFtZV9idXJ5IDAgLy8gYTogW3VpbnQxNiwgdWludDw4PltdLCBzdHJpbmcsIHVpbnQ8OD5bXV0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NTQ0CgkvLyByZXR1cm4gYTsKCWZyYW1lX2RpZyAwIC8vIGE6IFt1aW50MTYsIHVpbnQ8OD5bXSwgc3RyaW5nLCB1aW50PDg+W11dCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDRjMGQ1NjU4IC8vIG1ldGhvZCAic3RyaW5nSW5UdXBsZSgpKHVpbnQxNix1aW50OFtdLHN0cmluZyx1aW50OFtdKSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfc3RyaW5nSW5UdXBsZQoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycgoKKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJY29uY2F0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWIKCipwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJY29uY2F0CglmcmFtZV9idXJ5IC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50CglkdXAKCWxlbgoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglidG9pCgkrCglpdG9iCglleHRyYWN0IDYgMgoJZnJhbWVfYnVyeSAtMiAvLyBoZWFkIG9mZnNldAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCXN3YXAKCWNvbmNhdAoJZnJhbWVfYnVyeSAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3Vi", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestStringLength.approval.teal b/tests/contracts/artifacts/ABITestStringLength.approval.teal index 9e24651ea..3c4e99ecc 100644 --- a/tests/contracts/artifacts/ABITestStringLength.approval.teal +++ b/tests/contracts/artifacts/ABITestStringLength.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestStringLength.arc32.json b/tests/contracts/artifacts/ABITestStringLength.arc32.json index b13e23c22..73fb88bd4 100644 --- a/tests/contracts/artifacts/ABITestStringLength.arc32.json +++ b/tests/contracts/artifacts/ABITestStringLength.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RyaW5nTGVuZ3RoKCl1aW50NjQKKmFiaV9yb3V0ZV9zdHJpbmdMZW5ndGg6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBzdHJpbmdMZW5ndGgoKXVpbnQ2NAoJY2FsbHN1YiBzdHJpbmdMZW5ndGgKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gc3RyaW5nTGVuZ3RoKCk6IHVpbnQ2NApzdHJpbmdMZW5ndGg6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjc0MwoJLy8gcyA9IGNvbmNhdCgnZm9vICcsICdiYXInKQoJcHVzaGJ5dGVzIDB4NjY2ZjZmMjA2MjYxNzIKCWZyYW1lX2J1cnkgMCAvLyBzOiBieXRlW10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NzQ1CgkvLyByZXR1cm4gcy5sZW5ndGg7CglmcmFtZV9kaWcgMCAvLyBzOiBieXRlW10KCWxlbgoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg2NTllNDMwNyAvLyBtZXRob2QgInN0cmluZ0xlbmd0aCgpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9zdHJpbmdMZW5ndGgKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RyaW5nTGVuZ3RoKCl1aW50NjQKKmFiaV9yb3V0ZV9zdHJpbmdMZW5ndGg6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBzdHJpbmdMZW5ndGgoKXVpbnQ2NAoJY2FsbHN1YiBzdHJpbmdMZW5ndGgKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gc3RyaW5nTGVuZ3RoKCk6IHVpbnQ2NApzdHJpbmdMZW5ndGg6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjc0MwoJLy8gcyA9IGNvbmNhdCgnZm9vICcsICdiYXInKQoJcHVzaGJ5dGVzIDB4NjY2ZjZmMjA2MjYxNzIKCWZyYW1lX2J1cnkgMCAvLyBzOiBieXRlW10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NzQ1CgkvLyByZXR1cm4gcy5sZW5ndGg7CglmcmFtZV9kaWcgMCAvLyBzOiBieXRlW10KCWxlbgoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg2NTllNDMwNyAvLyBtZXRob2QgInN0cmluZ0xlbmd0aCgpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9zdHJpbmdMZW5ndGgKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestStringLength.arc56_draft.json b/tests/contracts/artifacts/ABITestStringLength.arc56_draft.json index bf418433f..47c3c08e1 100644 --- a/tests/contracts/artifacts/ABITestStringLength.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestStringLength.arc56_draft.json @@ -384,7 +384,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RyaW5nTGVuZ3RoKCl1aW50NjQKKmFiaV9yb3V0ZV9zdHJpbmdMZW5ndGg6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBzdHJpbmdMZW5ndGgoKXVpbnQ2NAoJY2FsbHN1YiBzdHJpbmdMZW5ndGgKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gc3RyaW5nTGVuZ3RoKCk6IHVpbnQ2NApzdHJpbmdMZW5ndGg6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjc0MwoJLy8gcyA9IGNvbmNhdCgnZm9vICcsICdiYXInKQoJcHVzaGJ5dGVzIDB4NjY2ZjZmMjA2MjYxNzIKCWZyYW1lX2J1cnkgMCAvLyBzOiBieXRlW10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NzQ1CgkvLyByZXR1cm4gcy5sZW5ndGg7CglmcmFtZV9kaWcgMCAvLyBzOiBieXRlW10KCWxlbgoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg2NTllNDMwNyAvLyBtZXRob2QgInN0cmluZ0xlbmd0aCgpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9zdHJpbmdMZW5ndGgKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RyaW5nTGVuZ3RoKCl1aW50NjQKKmFiaV9yb3V0ZV9zdHJpbmdMZW5ndGg6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBzdHJpbmdMZW5ndGgoKXVpbnQ2NAoJY2FsbHN1YiBzdHJpbmdMZW5ndGgKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gc3RyaW5nTGVuZ3RoKCk6IHVpbnQ2NApzdHJpbmdMZW5ndGg6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjc0MwoJLy8gcyA9IGNvbmNhdCgnZm9vICcsICdiYXInKQoJcHVzaGJ5dGVzIDB4NjY2ZjZmMjA2MjYxNzIKCWZyYW1lX2J1cnkgMCAvLyBzOiBieXRlW10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NzQ1CgkvLyByZXR1cm4gcy5sZW5ndGg7CglmcmFtZV9kaWcgMCAvLyBzOiBieXRlW10KCWxlbgoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg2NTllNDMwNyAvLyBtZXRob2QgInN0cmluZ0xlbmd0aCgpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9zdHJpbmdMZW5ndGgKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestStringReturn.approval.teal b/tests/contracts/artifacts/ABITestStringReturn.approval.teal index 23fc5a4b9..bdc8fd220 100644 --- a/tests/contracts/artifacts/ABITestStringReturn.approval.teal +++ b/tests/contracts/artifacts/ABITestStringReturn.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestStringReturn.arc32.json b/tests/contracts/artifacts/ABITestStringReturn.arc32.json index 0ca759d00..8ce28315a 100644 --- a/tests/contracts/artifacts/ABITestStringReturn.arc32.json +++ b/tests/contracts/artifacts/ABITestStringReturn.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RyaW5nUmV0dXJuKClzdHJpbmcKKmFiaV9yb3V0ZV9zdHJpbmdSZXR1cm46CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBzdHJpbmdSZXR1cm4oKXN0cmluZwoJY2FsbHN1YiBzdHJpbmdSZXR1cm4KCWR1cAoJbGVuCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHN0cmluZ1JldHVybigpOiBzdHJpbmcKc3RyaW5nUmV0dXJuOgoJcHJvdG8gMCAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjUzMAoJLy8gcmV0dXJuICdIZWxsbyBXb3JsZCEnOwoJcHVzaGJ5dGVzIDB4NDg2NTZjNmM2ZjIwNTc2ZjcyNmM2NDIxIC8vICJIZWxsbyBXb3JsZCEiCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDY4NDMwZTkyIC8vIG1ldGhvZCAic3RyaW5nUmV0dXJuKClzdHJpbmciCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3N0cmluZ1JldHVybgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RyaW5nUmV0dXJuKClzdHJpbmcKKmFiaV9yb3V0ZV9zdHJpbmdSZXR1cm46CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBzdHJpbmdSZXR1cm4oKXN0cmluZwoJY2FsbHN1YiBzdHJpbmdSZXR1cm4KCWR1cAoJbGVuCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHN0cmluZ1JldHVybigpOiBzdHJpbmcKc3RyaW5nUmV0dXJuOgoJcHJvdG8gMCAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjUzMAoJLy8gcmV0dXJuICdIZWxsbyBXb3JsZCEnOwoJcHVzaGJ5dGVzIDB4NDg2NTZjNmM2ZjIwNTc2ZjcyNmM2NDIxIC8vICJIZWxsbyBXb3JsZCEiCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDY4NDMwZTkyIC8vIG1ldGhvZCAic3RyaW5nUmV0dXJuKClzdHJpbmciCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3N0cmluZ1JldHVybgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestStringReturn.arc56_draft.json b/tests/contracts/artifacts/ABITestStringReturn.arc56_draft.json index 3ceeeaee6..7a37a44ba 100644 --- a/tests/contracts/artifacts/ABITestStringReturn.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestStringReturn.arc56_draft.json @@ -387,7 +387,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RyaW5nUmV0dXJuKClzdHJpbmcKKmFiaV9yb3V0ZV9zdHJpbmdSZXR1cm46CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBzdHJpbmdSZXR1cm4oKXN0cmluZwoJY2FsbHN1YiBzdHJpbmdSZXR1cm4KCWR1cAoJbGVuCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHN0cmluZ1JldHVybigpOiBzdHJpbmcKc3RyaW5nUmV0dXJuOgoJcHJvdG8gMCAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjUzMAoJLy8gcmV0dXJuICdIZWxsbyBXb3JsZCEnOwoJcHVzaGJ5dGVzIDB4NDg2NTZjNmM2ZjIwNTc2ZjcyNmM2NDIxIC8vICJIZWxsbyBXb3JsZCEiCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDY4NDMwZTkyIC8vIG1ldGhvZCAic3RyaW5nUmV0dXJuKClzdHJpbmciCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3N0cmluZ1JldHVybgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gc3RyaW5nUmV0dXJuKClzdHJpbmcKKmFiaV9yb3V0ZV9zdHJpbmdSZXR1cm46CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBzdHJpbmdSZXR1cm4oKXN0cmluZwoJY2FsbHN1YiBzdHJpbmdSZXR1cm4KCWR1cAoJbGVuCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHN0cmluZ1JldHVybigpOiBzdHJpbmcKc3RyaW5nUmV0dXJuOgoJcHJvdG8gMCAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjUzMAoJLy8gcmV0dXJuICdIZWxsbyBXb3JsZCEnOwoJcHVzaGJ5dGVzIDB4NDg2NTZjNmM2ZjIwNTc2ZjcyNmM2NDIxIC8vICJIZWxsbyBXb3JsZCEiCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDY4NDMwZTkyIC8vIG1ldGhvZCAic3RyaW5nUmV0dXJuKClzdHJpbmciCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3N0cmluZ1JldHVybgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestThreeDimensionalUint16Array.approval.teal b/tests/contracts/artifacts/ABITestThreeDimensionalUint16Array.approval.teal index 3381446ad..fa5d85bec 100644 --- a/tests/contracts/artifacts/ABITestThreeDimensionalUint16Array.approval.teal +++ b/tests/contracts/artifacts/ABITestThreeDimensionalUint16Array.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestThreeDimensionalUint16Array.arc32.json b/tests/contracts/artifacts/ABITestThreeDimensionalUint16Array.arc32.json index 8c2607503..8bf6533a1 100644 --- a/tests/contracts/artifacts/ABITestThreeDimensionalUint16Array.arc32.json +++ b/tests/contracts/artifacts/ABITestThreeDimensionalUint16Array.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdGhyZWVEaW1lbnNpb25hbFVpbnQxNkFycmF5KCl1aW50MTYKKmFiaV9yb3V0ZV90aHJlZURpbWVuc2lvbmFsVWludDE2QXJyYXk6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSB0aHJlZURpbWVuc2lvbmFsVWludDE2QXJyYXkoKXVpbnQxNgoJY2FsbHN1YiB0aHJlZURpbWVuc2lvbmFsVWludDE2QXJyYXkKCWl0b2IKCWR1cAoJYml0bGVuCglwdXNoaW50IDE2Cgk8PQoKCS8vIHRocmVlRGltZW5zaW9uYWxVaW50MTZBcnJheSByZXR1cm4gdmFsdWUgb3ZlcmZsb3dlZCAxNiBiaXRzCglhc3NlcnQKCWV4dHJhY3QgNiAyCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHRocmVlRGltZW5zaW9uYWxVaW50MTZBcnJheSgpOiB1aW50MTYKdGhyZWVEaW1lbnNpb25hbFVpbnQxNkFycmF5OgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoyMzgKCS8vIGE6IFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQxNiwgMj4sIDI+LCAyPiA9IFsKCS8vICAgICAgIFsKCS8vICAgICAgICAgWzExLCAyMl0sCgkvLyAgICAgICAgIFszMywgNDRdLAoJLy8gICAgICAgXSwKCS8vICAgICAgIFsKCS8vICAgICAgICAgWzU1LCA2Nl0sCgkvLyAgICAgICAgIFs3NywgODhdLAoJLy8gICAgICAgXSwKCS8vICAgICBdCglwdXNoYnl0ZXMgMHgwMDBiMDAxNjAwMjEwMDJjMDAzNzAwNDIwMDRkMDA1OAoJZnJhbWVfYnVyeSAwIC8vIGE6IFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQxNiwgMj4sIDI+LCAyPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoyNDkKCS8vIGFbMV1bMV0gPSBbNzc3LCA4ODhdCglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50MTYsIDI+LCAyPiwgMj4KCXB1c2hieXRlcyAweDAzMDkwMzc4CglyZXBsYWNlMiAxMgoJZnJhbWVfYnVyeSAwIC8vIGE6IFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQxNiwgMj4sIDI+LCAyPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoyNTEKCS8vIHJldHVybiBhWzFdWzFdWzFdOwoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDE2LCAyPiwgMj4sIDI+CglleHRyYWN0IDE0IDIKCWJ0b2kKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YzQ0MDIzNTUgLy8gbWV0aG9kICJ0aHJlZURpbWVuc2lvbmFsVWludDE2QXJyYXkoKXVpbnQxNiIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfdGhyZWVEaW1lbnNpb25hbFVpbnQxNkFycmF5CgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdGhyZWVEaW1lbnNpb25hbFVpbnQxNkFycmF5KCl1aW50MTYKKmFiaV9yb3V0ZV90aHJlZURpbWVuc2lvbmFsVWludDE2QXJyYXk6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSB0aHJlZURpbWVuc2lvbmFsVWludDE2QXJyYXkoKXVpbnQxNgoJY2FsbHN1YiB0aHJlZURpbWVuc2lvbmFsVWludDE2QXJyYXkKCWl0b2IKCWR1cAoJYml0bGVuCglwdXNoaW50IDE2Cgk8PQoKCS8vIHRocmVlRGltZW5zaW9uYWxVaW50MTZBcnJheSByZXR1cm4gdmFsdWUgb3ZlcmZsb3dlZCAxNiBiaXRzCglhc3NlcnQKCWV4dHJhY3QgNiAyCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHRocmVlRGltZW5zaW9uYWxVaW50MTZBcnJheSgpOiB1aW50MTYKdGhyZWVEaW1lbnNpb25hbFVpbnQxNkFycmF5OgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoyMzgKCS8vIGE6IFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQxNiwgMj4sIDI+LCAyPiA9IFsKCS8vICAgICAgIFsKCS8vICAgICAgICAgWzExLCAyMl0sCgkvLyAgICAgICAgIFszMywgNDRdLAoJLy8gICAgICAgXSwKCS8vICAgICAgIFsKCS8vICAgICAgICAgWzU1LCA2Nl0sCgkvLyAgICAgICAgIFs3NywgODhdLAoJLy8gICAgICAgXSwKCS8vICAgICBdCglwdXNoYnl0ZXMgMHgwMDBiMDAxNjAwMjEwMDJjMDAzNzAwNDIwMDRkMDA1OAoJZnJhbWVfYnVyeSAwIC8vIGE6IFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQxNiwgMj4sIDI+LCAyPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoyNDkKCS8vIGFbMV1bMV0gPSBbNzc3LCA4ODhdCglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50MTYsIDI+LCAyPiwgMj4KCXB1c2hieXRlcyAweDAzMDkwMzc4CglyZXBsYWNlMiAxMgoJZnJhbWVfYnVyeSAwIC8vIGE6IFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQxNiwgMj4sIDI+LCAyPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoyNTEKCS8vIHJldHVybiBhWzFdWzFdWzFdOwoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDE2LCAyPiwgMj4sIDI+CglleHRyYWN0IDE0IDIKCWJ0b2kKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YzQ0MDIzNTUgLy8gbWV0aG9kICJ0aHJlZURpbWVuc2lvbmFsVWludDE2QXJyYXkoKXVpbnQxNiIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfdGhyZWVEaW1lbnNpb25hbFVpbnQxNkFycmF5CgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestThreeDimensionalUint16Array.arc56_draft.json b/tests/contracts/artifacts/ABITestThreeDimensionalUint16Array.arc56_draft.json index 73f0566f2..3d2f90164 100644 --- a/tests/contracts/artifacts/ABITestThreeDimensionalUint16Array.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestThreeDimensionalUint16Array.arc56_draft.json @@ -484,7 +484,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdGhyZWVEaW1lbnNpb25hbFVpbnQxNkFycmF5KCl1aW50MTYKKmFiaV9yb3V0ZV90aHJlZURpbWVuc2lvbmFsVWludDE2QXJyYXk6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSB0aHJlZURpbWVuc2lvbmFsVWludDE2QXJyYXkoKXVpbnQxNgoJY2FsbHN1YiB0aHJlZURpbWVuc2lvbmFsVWludDE2QXJyYXkKCWl0b2IKCWR1cAoJYml0bGVuCglwdXNoaW50IDE2Cgk8PQoKCS8vIHRocmVlRGltZW5zaW9uYWxVaW50MTZBcnJheSByZXR1cm4gdmFsdWUgb3ZlcmZsb3dlZCAxNiBiaXRzCglhc3NlcnQKCWV4dHJhY3QgNiAyCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHRocmVlRGltZW5zaW9uYWxVaW50MTZBcnJheSgpOiB1aW50MTYKdGhyZWVEaW1lbnNpb25hbFVpbnQxNkFycmF5OgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoyMzgKCS8vIGE6IFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQxNiwgMj4sIDI+LCAyPiA9IFsKCS8vICAgICAgIFsKCS8vICAgICAgICAgWzExLCAyMl0sCgkvLyAgICAgICAgIFszMywgNDRdLAoJLy8gICAgICAgXSwKCS8vICAgICAgIFsKCS8vICAgICAgICAgWzU1LCA2Nl0sCgkvLyAgICAgICAgIFs3NywgODhdLAoJLy8gICAgICAgXSwKCS8vICAgICBdCglwdXNoYnl0ZXMgMHgwMDBiMDAxNjAwMjEwMDJjMDAzNzAwNDIwMDRkMDA1OAoJZnJhbWVfYnVyeSAwIC8vIGE6IFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQxNiwgMj4sIDI+LCAyPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoyNDkKCS8vIGFbMV1bMV0gPSBbNzc3LCA4ODhdCglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50MTYsIDI+LCAyPiwgMj4KCXB1c2hieXRlcyAweDAzMDkwMzc4CglyZXBsYWNlMiAxMgoJZnJhbWVfYnVyeSAwIC8vIGE6IFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQxNiwgMj4sIDI+LCAyPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoyNTEKCS8vIHJldHVybiBhWzFdWzFdWzFdOwoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDE2LCAyPiwgMj4sIDI+CglleHRyYWN0IDE0IDIKCWJ0b2kKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YzQ0MDIzNTUgLy8gbWV0aG9kICJ0aHJlZURpbWVuc2lvbmFsVWludDE2QXJyYXkoKXVpbnQxNiIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfdGhyZWVEaW1lbnNpb25hbFVpbnQxNkFycmF5CgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdGhyZWVEaW1lbnNpb25hbFVpbnQxNkFycmF5KCl1aW50MTYKKmFiaV9yb3V0ZV90aHJlZURpbWVuc2lvbmFsVWludDE2QXJyYXk6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSB0aHJlZURpbWVuc2lvbmFsVWludDE2QXJyYXkoKXVpbnQxNgoJY2FsbHN1YiB0aHJlZURpbWVuc2lvbmFsVWludDE2QXJyYXkKCWl0b2IKCWR1cAoJYml0bGVuCglwdXNoaW50IDE2Cgk8PQoKCS8vIHRocmVlRGltZW5zaW9uYWxVaW50MTZBcnJheSByZXR1cm4gdmFsdWUgb3ZlcmZsb3dlZCAxNiBiaXRzCglhc3NlcnQKCWV4dHJhY3QgNiAyCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHRocmVlRGltZW5zaW9uYWxVaW50MTZBcnJheSgpOiB1aW50MTYKdGhyZWVEaW1lbnNpb25hbFVpbnQxNkFycmF5OgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoyMzgKCS8vIGE6IFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQxNiwgMj4sIDI+LCAyPiA9IFsKCS8vICAgICAgIFsKCS8vICAgICAgICAgWzExLCAyMl0sCgkvLyAgICAgICAgIFszMywgNDRdLAoJLy8gICAgICAgXSwKCS8vICAgICAgIFsKCS8vICAgICAgICAgWzU1LCA2Nl0sCgkvLyAgICAgICAgIFs3NywgODhdLAoJLy8gICAgICAgXSwKCS8vICAgICBdCglwdXNoYnl0ZXMgMHgwMDBiMDAxNjAwMjEwMDJjMDAzNzAwNDIwMDRkMDA1OAoJZnJhbWVfYnVyeSAwIC8vIGE6IFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQxNiwgMj4sIDI+LCAyPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoyNDkKCS8vIGFbMV1bMV0gPSBbNzc3LCA4ODhdCglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50MTYsIDI+LCAyPiwgMj4KCXB1c2hieXRlcyAweDAzMDkwMzc4CglyZXBsYWNlMiAxMgoJZnJhbWVfYnVyeSAwIC8vIGE6IFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQxNiwgMj4sIDI+LCAyPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoyNTEKCS8vIHJldHVybiBhWzFdWzFdWzFdOwoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDE2LCAyPiwgMj4sIDI+CglleHRyYWN0IDE0IDIKCWJ0b2kKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YzQ0MDIzNTUgLy8gbWV0aG9kICJ0aHJlZURpbWVuc2lvbmFsVWludDE2QXJyYXkoKXVpbnQxNiIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfdGhyZWVEaW1lbnNpb25hbFVpbnQxNkFycmF5CgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestTupleArg.approval.teal b/tests/contracts/artifacts/ABITestTupleArg.approval.teal index b747bcbe5..dd41e4221 100644 --- a/tests/contracts/artifacts/ABITestTupleArg.approval.teal +++ b/tests/contracts/artifacts/ABITestTupleArg.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestTupleArg.arc32.json b/tests/contracts/artifacts/ABITestTupleArg.arc32.json index a1d8f1abc..37b0b402d 100644 --- a/tests/contracts/artifacts/ABITestTupleArg.arc32.json +++ b/tests/contracts/artifacts/ABITestTupleArg.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdHVwbGVBcmcoKHVpbnQ2NCx1aW50MTYsdWludDY0KSl1aW50MTYKKmFiaV9yb3V0ZV90dXBsZUFyZzoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBhOiAodWludDY0LHVpbnQxNix1aW50NjQpCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglkdXAKCWxlbgoJcHVzaGludCAxOAoJPT0KCgkvLyBhcmd1bWVudCAwIChhKSBmb3IgdHVwbGVBcmcgbXVzdCBiZSBhICh1aW50NjQsdWludDE2LHVpbnQ2NCkKCWFzc2VydAoKCS8vIGV4ZWN1dGUgdHVwbGVBcmcoKHVpbnQ2NCx1aW50MTYsdWludDY0KSl1aW50MTYKCWNhbGxzdWIgdHVwbGVBcmcKCWl0b2IKCWR1cAoJYml0bGVuCglwdXNoaW50IDE2Cgk8PQoKCS8vIHR1cGxlQXJnIHJldHVybiB2YWx1ZSBvdmVyZmxvd2VkIDE2IGJpdHMKCWFzc2VydAoJZXh0cmFjdCA2IDIKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gdHVwbGVBcmcoYTogW3VpbnQ2NCwgdWludDE2LCB1aW50NjRdKTogdWludDE2CnR1cGxlQXJnOgoJcHJvdG8gMSAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjM0MgoJLy8gcmV0dXJuIGFbMV07CglmcmFtZV9kaWcgLTEgLy8gYTogW3VpbnQ2NCwgdWludDE2LCB1aW50NjRdCglleHRyYWN0IDggMgoJYnRvaQoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg5ZDNiZGViNyAvLyBtZXRob2QgInR1cGxlQXJnKCh1aW50NjQsdWludDE2LHVpbnQ2NCkpdWludDE2IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV90dXBsZUFyZwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdHVwbGVBcmcoKHVpbnQ2NCx1aW50MTYsdWludDY0KSl1aW50MTYKKmFiaV9yb3V0ZV90dXBsZUFyZzoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBhOiAodWludDY0LHVpbnQxNix1aW50NjQpCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglkdXAKCWxlbgoJcHVzaGludCAxOAoJPT0KCgkvLyBhcmd1bWVudCAwIChhKSBmb3IgdHVwbGVBcmcgbXVzdCBiZSBhICh1aW50NjQsdWludDE2LHVpbnQ2NCkKCWFzc2VydAoKCS8vIGV4ZWN1dGUgdHVwbGVBcmcoKHVpbnQ2NCx1aW50MTYsdWludDY0KSl1aW50MTYKCWNhbGxzdWIgdHVwbGVBcmcKCWl0b2IKCWR1cAoJYml0bGVuCglwdXNoaW50IDE2Cgk8PQoKCS8vIHR1cGxlQXJnIHJldHVybiB2YWx1ZSBvdmVyZmxvd2VkIDE2IGJpdHMKCWFzc2VydAoJZXh0cmFjdCA2IDIKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gdHVwbGVBcmcoYTogW3VpbnQ2NCwgdWludDE2LCB1aW50NjRdKTogdWludDE2CnR1cGxlQXJnOgoJcHJvdG8gMSAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjM0MgoJLy8gcmV0dXJuIGFbMV07CglmcmFtZV9kaWcgLTEgLy8gYTogW3VpbnQ2NCwgdWludDE2LCB1aW50NjRdCglleHRyYWN0IDggMgoJYnRvaQoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg5ZDNiZGViNyAvLyBtZXRob2QgInR1cGxlQXJnKCh1aW50NjQsdWludDE2LHVpbnQ2NCkpdWludDE2IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV90dXBsZUFyZwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestTupleArg.arc56_draft.json b/tests/contracts/artifacts/ABITestTupleArg.arc56_draft.json index c770ccade..ab14ac9cc 100644 --- a/tests/contracts/artifacts/ABITestTupleArg.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestTupleArg.arc56_draft.json @@ -451,7 +451,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdHVwbGVBcmcoKHVpbnQ2NCx1aW50MTYsdWludDY0KSl1aW50MTYKKmFiaV9yb3V0ZV90dXBsZUFyZzoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBhOiAodWludDY0LHVpbnQxNix1aW50NjQpCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglkdXAKCWxlbgoJcHVzaGludCAxOAoJPT0KCgkvLyBhcmd1bWVudCAwIChhKSBmb3IgdHVwbGVBcmcgbXVzdCBiZSBhICh1aW50NjQsdWludDE2LHVpbnQ2NCkKCWFzc2VydAoKCS8vIGV4ZWN1dGUgdHVwbGVBcmcoKHVpbnQ2NCx1aW50MTYsdWludDY0KSl1aW50MTYKCWNhbGxzdWIgdHVwbGVBcmcKCWl0b2IKCWR1cAoJYml0bGVuCglwdXNoaW50IDE2Cgk8PQoKCS8vIHR1cGxlQXJnIHJldHVybiB2YWx1ZSBvdmVyZmxvd2VkIDE2IGJpdHMKCWFzc2VydAoJZXh0cmFjdCA2IDIKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gdHVwbGVBcmcoYTogW3VpbnQ2NCwgdWludDE2LCB1aW50NjRdKTogdWludDE2CnR1cGxlQXJnOgoJcHJvdG8gMSAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjM0MgoJLy8gcmV0dXJuIGFbMV07CglmcmFtZV9kaWcgLTEgLy8gYTogW3VpbnQ2NCwgdWludDE2LCB1aW50NjRdCglleHRyYWN0IDggMgoJYnRvaQoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg5ZDNiZGViNyAvLyBtZXRob2QgInR1cGxlQXJnKCh1aW50NjQsdWludDE2LHVpbnQ2NCkpdWludDE2IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV90dXBsZUFyZwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdHVwbGVBcmcoKHVpbnQ2NCx1aW50MTYsdWludDY0KSl1aW50MTYKKmFiaV9yb3V0ZV90dXBsZUFyZzoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBhOiAodWludDY0LHVpbnQxNix1aW50NjQpCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglkdXAKCWxlbgoJcHVzaGludCAxOAoJPT0KCgkvLyBhcmd1bWVudCAwIChhKSBmb3IgdHVwbGVBcmcgbXVzdCBiZSBhICh1aW50NjQsdWludDE2LHVpbnQ2NCkKCWFzc2VydAoKCS8vIGV4ZWN1dGUgdHVwbGVBcmcoKHVpbnQ2NCx1aW50MTYsdWludDY0KSl1aW50MTYKCWNhbGxzdWIgdHVwbGVBcmcKCWl0b2IKCWR1cAoJYml0bGVuCglwdXNoaW50IDE2Cgk8PQoKCS8vIHR1cGxlQXJnIHJldHVybiB2YWx1ZSBvdmVyZmxvd2VkIDE2IGJpdHMKCWFzc2VydAoJZXh0cmFjdCA2IDIKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gdHVwbGVBcmcoYTogW3VpbnQ2NCwgdWludDE2LCB1aW50NjRdKTogdWludDE2CnR1cGxlQXJnOgoJcHJvdG8gMSAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjM0MgoJLy8gcmV0dXJuIGFbMV07CglmcmFtZV9kaWcgLTEgLy8gYTogW3VpbnQ2NCwgdWludDE2LCB1aW50NjRdCglleHRyYWN0IDggMgoJYnRvaQoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg5ZDNiZGViNyAvLyBtZXRob2QgInR1cGxlQXJnKCh1aW50NjQsdWludDE2LHVpbnQ2NCkpdWludDE2IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV90dXBsZUFyZwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestTupleInArray.approval.teal b/tests/contracts/artifacts/ABITestTupleInArray.approval.teal index f91f3b324..ec17c58fc 100644 --- a/tests/contracts/artifacts/ABITestTupleInArray.approval.teal +++ b/tests/contracts/artifacts/ABITestTupleInArray.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestTupleInArray.arc32.json b/tests/contracts/artifacts/ABITestTupleInArray.arc32.json index 1f24bd786..4bea525eb 100644 --- a/tests/contracts/artifacts/ABITestTupleInArray.arc32.json +++ b/tests/contracts/artifacts/ABITestTupleInArray.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdHVwbGVJbkFycmF5KCl1aW50MTYKKmFiaV9yb3V0ZV90dXBsZUluQXJyYXk6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSB0dXBsZUluQXJyYXkoKXVpbnQxNgoJY2FsbHN1YiB0dXBsZUluQXJyYXkKCWl0b2IKCWR1cAoJYml0bGVuCglwdXNoaW50IDE2Cgk8PQoKCS8vIHR1cGxlSW5BcnJheSByZXR1cm4gdmFsdWUgb3ZlcmZsb3dlZCAxNiBiaXRzCglhc3NlcnQKCWV4dHJhY3QgNiAyCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHR1cGxlSW5BcnJheSgpOiB1aW50MTYKdHVwbGVJbkFycmF5OgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoyNzMKCS8vIGE6IFN0YXRpY0FycmF5PFt1aW50NjQsIHVpbnQxNl0sIDI+ID0gWwoJLy8gICAgICAgWzExLCAyMl0sCgkvLyAgICAgICBbMzMsIDQ0XSwKCS8vICAgICBdCglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDBiMDAxNjAwMDAwMDAwMDAwMDAwMjEwMDJjCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8W3VpbnQ2NCwgdWludDE2XSwgMj4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6Mjc4CgkvLyByZXR1cm4gYVsxXVsxXTsKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PFt1aW50NjQsIHVpbnQxNl0sIDI+CglleHRyYWN0IDE4IDIKCWJ0b2kKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MWRjMjgwNmEgLy8gbWV0aG9kICJ0dXBsZUluQXJyYXkoKXVpbnQxNiIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfdHVwbGVJbkFycmF5CgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdHVwbGVJbkFycmF5KCl1aW50MTYKKmFiaV9yb3V0ZV90dXBsZUluQXJyYXk6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSB0dXBsZUluQXJyYXkoKXVpbnQxNgoJY2FsbHN1YiB0dXBsZUluQXJyYXkKCWl0b2IKCWR1cAoJYml0bGVuCglwdXNoaW50IDE2Cgk8PQoKCS8vIHR1cGxlSW5BcnJheSByZXR1cm4gdmFsdWUgb3ZlcmZsb3dlZCAxNiBiaXRzCglhc3NlcnQKCWV4dHJhY3QgNiAyCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHR1cGxlSW5BcnJheSgpOiB1aW50MTYKdHVwbGVJbkFycmF5OgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoyNzMKCS8vIGE6IFN0YXRpY0FycmF5PFt1aW50NjQsIHVpbnQxNl0sIDI+ID0gWwoJLy8gICAgICAgWzExLCAyMl0sCgkvLyAgICAgICBbMzMsIDQ0XSwKCS8vICAgICBdCglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDBiMDAxNjAwMDAwMDAwMDAwMDAwMjEwMDJjCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8W3VpbnQ2NCwgdWludDE2XSwgMj4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6Mjc4CgkvLyByZXR1cm4gYVsxXVsxXTsKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PFt1aW50NjQsIHVpbnQxNl0sIDI+CglleHRyYWN0IDE4IDIKCWJ0b2kKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MWRjMjgwNmEgLy8gbWV0aG9kICJ0dXBsZUluQXJyYXkoKXVpbnQxNiIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfdHVwbGVJbkFycmF5CgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestTupleInArray.arc56_draft.json b/tests/contracts/artifacts/ABITestTupleInArray.arc56_draft.json index 96d93f466..dfba8dfe5 100644 --- a/tests/contracts/artifacts/ABITestTupleInArray.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestTupleInArray.arc56_draft.json @@ -452,7 +452,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdHVwbGVJbkFycmF5KCl1aW50MTYKKmFiaV9yb3V0ZV90dXBsZUluQXJyYXk6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSB0dXBsZUluQXJyYXkoKXVpbnQxNgoJY2FsbHN1YiB0dXBsZUluQXJyYXkKCWl0b2IKCWR1cAoJYml0bGVuCglwdXNoaW50IDE2Cgk8PQoKCS8vIHR1cGxlSW5BcnJheSByZXR1cm4gdmFsdWUgb3ZlcmZsb3dlZCAxNiBiaXRzCglhc3NlcnQKCWV4dHJhY3QgNiAyCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHR1cGxlSW5BcnJheSgpOiB1aW50MTYKdHVwbGVJbkFycmF5OgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoyNzMKCS8vIGE6IFN0YXRpY0FycmF5PFt1aW50NjQsIHVpbnQxNl0sIDI+ID0gWwoJLy8gICAgICAgWzExLCAyMl0sCgkvLyAgICAgICBbMzMsIDQ0XSwKCS8vICAgICBdCglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDBiMDAxNjAwMDAwMDAwMDAwMDAwMjEwMDJjCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8W3VpbnQ2NCwgdWludDE2XSwgMj4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6Mjc4CgkvLyByZXR1cm4gYVsxXVsxXTsKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PFt1aW50NjQsIHVpbnQxNl0sIDI+CglleHRyYWN0IDE4IDIKCWJ0b2kKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MWRjMjgwNmEgLy8gbWV0aG9kICJ0dXBsZUluQXJyYXkoKXVpbnQxNiIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfdHVwbGVJbkFycmF5CgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdHVwbGVJbkFycmF5KCl1aW50MTYKKmFiaV9yb3V0ZV90dXBsZUluQXJyYXk6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSB0dXBsZUluQXJyYXkoKXVpbnQxNgoJY2FsbHN1YiB0dXBsZUluQXJyYXkKCWl0b2IKCWR1cAoJYml0bGVuCglwdXNoaW50IDE2Cgk8PQoKCS8vIHR1cGxlSW5BcnJheSByZXR1cm4gdmFsdWUgb3ZlcmZsb3dlZCAxNiBiaXRzCglhc3NlcnQKCWV4dHJhY3QgNiAyCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHR1cGxlSW5BcnJheSgpOiB1aW50MTYKdHVwbGVJbkFycmF5OgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoyNzMKCS8vIGE6IFN0YXRpY0FycmF5PFt1aW50NjQsIHVpbnQxNl0sIDI+ID0gWwoJLy8gICAgICAgWzExLCAyMl0sCgkvLyAgICAgICBbMzMsIDQ0XSwKCS8vICAgICBdCglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDBiMDAxNjAwMDAwMDAwMDAwMDAwMjEwMDJjCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8W3VpbnQ2NCwgdWludDE2XSwgMj4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6Mjc4CgkvLyByZXR1cm4gYVsxXVsxXTsKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PFt1aW50NjQsIHVpbnQxNl0sIDI+CglleHRyYWN0IDE4IDIKCWJ0b2kKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MWRjMjgwNmEgLy8gbWV0aG9kICJ0dXBsZUluQXJyYXkoKXVpbnQxNiIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfdHVwbGVJbkFycmF5CgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestTupleInTuple.approval.teal b/tests/contracts/artifacts/ABITestTupleInTuple.approval.teal index 6eb1a1cb8..73755c4f4 100644 --- a/tests/contracts/artifacts/ABITestTupleInTuple.approval.teal +++ b/tests/contracts/artifacts/ABITestTupleInTuple.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestTupleInTuple.arc32.json b/tests/contracts/artifacts/ABITestTupleInTuple.arc32.json index 9fa5dc7ea..1b79c9026 100644 --- a/tests/contracts/artifacts/ABITestTupleInTuple.arc32.json +++ b/tests/contracts/artifacts/ABITestTupleInTuple.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdHVwbGVJblR1cGxlKCl1aW50NjQKKmFiaV9yb3V0ZV90dXBsZUluVHVwbGU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSB0dXBsZUluVHVwbGUoKXVpbnQ2NAoJY2FsbHN1YiB0dXBsZUluVHVwbGUKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gdHVwbGVJblR1cGxlKCk6IHVpbnQ2NAp0dXBsZUluVHVwbGU6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjI4NAoJLy8gYTogW3VpbnQxNiwgdWludDE2LCBbdWludDY0LCB1aW50MTZdLCBbdWludDE2LCB1aW50NjRdXSA9IFsxMSwgMjIsIFszMywgNDRdLCBbNTUsIDY2XV0KCXB1c2hieXRlcyAweDAwMGIwMDE2MDAwMDAwMDAwMDAwMDAyMTAwMmMwMDM3MDAwMDAwMDAwMDAwMDA0MgoJZnJhbWVfYnVyeSAwIC8vIGE6IFt1aW50MTYsIHVpbnQxNiwgW3VpbnQ2NCwgdWludDE2XSwgW3VpbnQxNiwgdWludDY0XV0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6Mjg2CgkvLyByZXR1cm4gYVszXVsxXTsKCWZyYW1lX2RpZyAwIC8vIGE6IFt1aW50MTYsIHVpbnQxNiwgW3VpbnQ2NCwgdWludDE2XSwgW3VpbnQxNiwgdWludDY0XV0KCWV4dHJhY3QgMTYgOAoJYnRvaQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgyYjZjNGQ2YSAvLyBtZXRob2QgInR1cGxlSW5UdXBsZSgpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV90dXBsZUluVHVwbGUKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdHVwbGVJblR1cGxlKCl1aW50NjQKKmFiaV9yb3V0ZV90dXBsZUluVHVwbGU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSB0dXBsZUluVHVwbGUoKXVpbnQ2NAoJY2FsbHN1YiB0dXBsZUluVHVwbGUKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gdHVwbGVJblR1cGxlKCk6IHVpbnQ2NAp0dXBsZUluVHVwbGU6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjI4NAoJLy8gYTogW3VpbnQxNiwgdWludDE2LCBbdWludDY0LCB1aW50MTZdLCBbdWludDE2LCB1aW50NjRdXSA9IFsxMSwgMjIsIFszMywgNDRdLCBbNTUsIDY2XV0KCXB1c2hieXRlcyAweDAwMGIwMDE2MDAwMDAwMDAwMDAwMDAyMTAwMmMwMDM3MDAwMDAwMDAwMDAwMDA0MgoJZnJhbWVfYnVyeSAwIC8vIGE6IFt1aW50MTYsIHVpbnQxNiwgW3VpbnQ2NCwgdWludDE2XSwgW3VpbnQxNiwgdWludDY0XV0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6Mjg2CgkvLyByZXR1cm4gYVszXVsxXTsKCWZyYW1lX2RpZyAwIC8vIGE6IFt1aW50MTYsIHVpbnQxNiwgW3VpbnQ2NCwgdWludDE2XSwgW3VpbnQxNiwgdWludDY0XV0KCWV4dHJhY3QgMTYgOAoJYnRvaQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgyYjZjNGQ2YSAvLyBtZXRob2QgInR1cGxlSW5UdXBsZSgpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV90dXBsZUluVHVwbGUKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestTupleInTuple.arc56_draft.json b/tests/contracts/artifacts/ABITestTupleInTuple.arc56_draft.json index 5d0d7ac75..b9d98428d 100644 --- a/tests/contracts/artifacts/ABITestTupleInTuple.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestTupleInTuple.arc56_draft.json @@ -410,7 +410,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdHVwbGVJblR1cGxlKCl1aW50NjQKKmFiaV9yb3V0ZV90dXBsZUluVHVwbGU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSB0dXBsZUluVHVwbGUoKXVpbnQ2NAoJY2FsbHN1YiB0dXBsZUluVHVwbGUKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gdHVwbGVJblR1cGxlKCk6IHVpbnQ2NAp0dXBsZUluVHVwbGU6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjI4NAoJLy8gYTogW3VpbnQxNiwgdWludDE2LCBbdWludDY0LCB1aW50MTZdLCBbdWludDE2LCB1aW50NjRdXSA9IFsxMSwgMjIsIFszMywgNDRdLCBbNTUsIDY2XV0KCXB1c2hieXRlcyAweDAwMGIwMDE2MDAwMDAwMDAwMDAwMDAyMTAwMmMwMDM3MDAwMDAwMDAwMDAwMDA0MgoJZnJhbWVfYnVyeSAwIC8vIGE6IFt1aW50MTYsIHVpbnQxNiwgW3VpbnQ2NCwgdWludDE2XSwgW3VpbnQxNiwgdWludDY0XV0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6Mjg2CgkvLyByZXR1cm4gYVszXVsxXTsKCWZyYW1lX2RpZyAwIC8vIGE6IFt1aW50MTYsIHVpbnQxNiwgW3VpbnQ2NCwgdWludDE2XSwgW3VpbnQxNiwgdWludDY0XV0KCWV4dHJhY3QgMTYgOAoJYnRvaQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgyYjZjNGQ2YSAvLyBtZXRob2QgInR1cGxlSW5UdXBsZSgpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV90dXBsZUluVHVwbGUKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdHVwbGVJblR1cGxlKCl1aW50NjQKKmFiaV9yb3V0ZV90dXBsZUluVHVwbGU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSB0dXBsZUluVHVwbGUoKXVpbnQ2NAoJY2FsbHN1YiB0dXBsZUluVHVwbGUKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gdHVwbGVJblR1cGxlKCk6IHVpbnQ2NAp0dXBsZUluVHVwbGU6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjI4NAoJLy8gYTogW3VpbnQxNiwgdWludDE2LCBbdWludDY0LCB1aW50MTZdLCBbdWludDE2LCB1aW50NjRdXSA9IFsxMSwgMjIsIFszMywgNDRdLCBbNTUsIDY2XV0KCXB1c2hieXRlcyAweDAwMGIwMDE2MDAwMDAwMDAwMDAwMDAyMTAwMmMwMDM3MDAwMDAwMDAwMDAwMDA0MgoJZnJhbWVfYnVyeSAwIC8vIGE6IFt1aW50MTYsIHVpbnQxNiwgW3VpbnQ2NCwgdWludDE2XSwgW3VpbnQxNiwgdWludDY0XV0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6Mjg2CgkvLyByZXR1cm4gYVszXVsxXTsKCWZyYW1lX2RpZyAwIC8vIGE6IFt1aW50MTYsIHVpbnQxNiwgW3VpbnQ2NCwgdWludDE2XSwgW3VpbnQxNiwgdWludDY0XV0KCWV4dHJhY3QgMTYgOAoJYnRvaQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgyYjZjNGQ2YSAvLyBtZXRob2QgInR1cGxlSW5UdXBsZSgpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV90dXBsZUluVHVwbGUKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestTxnTypes.approval.teal b/tests/contracts/artifacts/ABITestTxnTypes.approval.teal index 8a6f561b9..b8dfb1a8e 100644 --- a/tests/contracts/artifacts/ABITestTxnTypes.approval.teal +++ b/tests/contracts/artifacts/ABITestTxnTypes.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestTxnTypes.arc32.json b/tests/contracts/artifacts/ABITestTxnTypes.arc32.json index ab814826e..e2a1639d5 100644 --- a/tests/contracts/artifacts/ABITestTxnTypes.arc32.json +++ b/tests/contracts/artifacts/ABITestTxnTypes.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdHhuVHlwZXModHhuLGFwcGwsYWNmZyxhZnJ6LGF4ZmVyLGtleXJlZyxwYXkpdm9pZAoqYWJpX3JvdXRlX3R4blR5cGVzOgoJLy8gcDogcGF5Cgl0eG4gR3JvdXBJbmRleAoJcHVzaGludCAxCgktCglkdXAKCWd0eG5zIFR5cGVFbnVtCglwdXNoaW50IDEgLy8gcGF5Cgk9PQoKCS8vIGFyZ3VtZW50IDAgKHApIGZvciB0eG5UeXBlcyBtdXN0IGJlIGEgcGF5IHRyYW5zYWN0aW9uCglhc3NlcnQKCgkvLyBrcjoga2V5cmVnCgl0eG4gR3JvdXBJbmRleAoJcHVzaGludCAyCgktCglkdXAKCWd0eG5zIFR5cGVFbnVtCglwdXNoaW50IDIgLy8ga2V5cmVnCgk9PQoKCS8vIGFyZ3VtZW50IDEgKGtyKSBmb3IgdHhuVHlwZXMgbXVzdCBiZSBhIGtleXJlZyB0cmFuc2FjdGlvbgoJYXNzZXJ0CgoJLy8gYXQ6IGF4ZmVyCgl0eG4gR3JvdXBJbmRleAoJcHVzaGludCAzCgktCglkdXAKCWd0eG5zIFR5cGVFbnVtCglwdXNoaW50IDQgLy8gYXhmZXIKCT09CgoJLy8gYXJndW1lbnQgMiAoYXQpIGZvciB0eG5UeXBlcyBtdXN0IGJlIGEgYXhmZXIgdHJhbnNhY3Rpb24KCWFzc2VydAoKCS8vIGFmOiBhZnJ6Cgl0eG4gR3JvdXBJbmRleAoJcHVzaGludCA0CgktCglkdXAKCWd0eG5zIFR5cGVFbnVtCglwdXNoaW50IDUgLy8gYWZyegoJPT0KCgkvLyBhcmd1bWVudCAzIChhZikgZm9yIHR4blR5cGVzIG11c3QgYmUgYSBhZnJ6IHRyYW5zYWN0aW9uCglhc3NlcnQKCgkvLyBhYzogYWNmZwoJdHhuIEdyb3VwSW5kZXgKCXB1c2hpbnQgNQoJLQoJZHVwCglndHhucyBUeXBlRW51bQoJcHVzaGludCAzIC8vIGFjZmcKCT09CgoJLy8gYXJndW1lbnQgNCAoYWMpIGZvciB0eG5UeXBlcyBtdXN0IGJlIGEgYWNmZyB0cmFuc2FjdGlvbgoJYXNzZXJ0CgoJLy8gYTogYXBwbAoJdHhuIEdyb3VwSW5kZXgKCXB1c2hpbnQgNgoJLQoJZHVwCglndHhucyBUeXBlRW51bQoJcHVzaGludCA2IC8vIGFwcGwKCT09CgoJLy8gYXJndW1lbnQgNSAoYSkgZm9yIHR4blR5cGVzIG11c3QgYmUgYSBhcHBsIHRyYW5zYWN0aW9uCglhc3NlcnQKCgkvLyB0OiB0eG4KCXR4biBHcm91cEluZGV4CglwdXNoaW50IDcKCS0KCgkvLyBleGVjdXRlIHR4blR5cGVzKHR4bixhcHBsLGFjZmcsYWZyeixheGZlcixrZXlyZWcscGF5KXZvaWQKCWNhbGxzdWIgdHhuVHlwZXMKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyB0eG5UeXBlcyh0OiBUeG4sIGE6IEFwcENhbGxUeG4sIGFjOiBBc3NldENvbmZpZ1R4biwgYWY6IEFzc2V0RnJlZXplVHhuLCBhdDogQXNzZXRUcmFuc2ZlclR4biwga3I6IEtleVJlZ1R4biwgcDogUGF5VHhuKTogdm9pZAp0eG5UeXBlczoKCXByb3RvIDcgMAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo3MjYKCS8vIGFzc2VydCh0LnNlbmRlciA9PT0gYS5zZW5kZXIpCglmcmFtZV9kaWcgLTEgLy8gdDogVHhuCglndHhucyBTZW5kZXIKCWZyYW1lX2RpZyAtMiAvLyBhOiBBcHBDYWxsVHhuCglndHhucyBTZW5kZXIKCT09Cglhc3NlcnQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NzI3CgkvLyBhc3NlcnQoYWMuc2VuZGVyID09PSBhZi5zZW5kZXIpCglmcmFtZV9kaWcgLTMgLy8gYWM6IEFzc2V0Q29uZmlnVHhuCglndHhucyBTZW5kZXIKCWZyYW1lX2RpZyAtNCAvLyBhZjogQXNzZXRGcmVlemVUeG4KCWd0eG5zIFNlbmRlcgoJPT0KCWFzc2VydAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo3MjgKCS8vIGFzc2VydChhdC5zZW5kZXIgPT09IGtyLnNlbmRlcikKCWZyYW1lX2RpZyAtNSAvLyBhdDogQXNzZXRUcmFuc2ZlclR4bgoJZ3R4bnMgU2VuZGVyCglmcmFtZV9kaWcgLTYgLy8ga3I6IEtleVJlZ1R4bgoJZ3R4bnMgU2VuZGVyCgk9PQoJYXNzZXJ0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjcyOQoJLy8gYXNzZXJ0KHAuc2VuZGVyID09PSB0LnNlbmRlcikKCWZyYW1lX2RpZyAtNyAvLyBwOiBQYXlUeG4KCWd0eG5zIFNlbmRlcgoJZnJhbWVfZGlnIC0xIC8vIHQ6IFR4bgoJZ3R4bnMgU2VuZGVyCgk9PQoJYXNzZXJ0CglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDg0MDMzN2VmIC8vIG1ldGhvZCAidHhuVHlwZXModHhuLGFwcGwsYWNmZyxhZnJ6LGF4ZmVyLGtleXJlZyxwYXkpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfdHhuVHlwZXMKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdHhuVHlwZXModHhuLGFwcGwsYWNmZyxhZnJ6LGF4ZmVyLGtleXJlZyxwYXkpdm9pZAoqYWJpX3JvdXRlX3R4blR5cGVzOgoJLy8gcDogcGF5Cgl0eG4gR3JvdXBJbmRleAoJcHVzaGludCAxCgktCglkdXAKCWd0eG5zIFR5cGVFbnVtCglwdXNoaW50IDEgLy8gcGF5Cgk9PQoKCS8vIGFyZ3VtZW50IDAgKHApIGZvciB0eG5UeXBlcyBtdXN0IGJlIGEgcGF5IHRyYW5zYWN0aW9uCglhc3NlcnQKCgkvLyBrcjoga2V5cmVnCgl0eG4gR3JvdXBJbmRleAoJcHVzaGludCAyCgktCglkdXAKCWd0eG5zIFR5cGVFbnVtCglwdXNoaW50IDIgLy8ga2V5cmVnCgk9PQoKCS8vIGFyZ3VtZW50IDEgKGtyKSBmb3IgdHhuVHlwZXMgbXVzdCBiZSBhIGtleXJlZyB0cmFuc2FjdGlvbgoJYXNzZXJ0CgoJLy8gYXQ6IGF4ZmVyCgl0eG4gR3JvdXBJbmRleAoJcHVzaGludCAzCgktCglkdXAKCWd0eG5zIFR5cGVFbnVtCglwdXNoaW50IDQgLy8gYXhmZXIKCT09CgoJLy8gYXJndW1lbnQgMiAoYXQpIGZvciB0eG5UeXBlcyBtdXN0IGJlIGEgYXhmZXIgdHJhbnNhY3Rpb24KCWFzc2VydAoKCS8vIGFmOiBhZnJ6Cgl0eG4gR3JvdXBJbmRleAoJcHVzaGludCA0CgktCglkdXAKCWd0eG5zIFR5cGVFbnVtCglwdXNoaW50IDUgLy8gYWZyegoJPT0KCgkvLyBhcmd1bWVudCAzIChhZikgZm9yIHR4blR5cGVzIG11c3QgYmUgYSBhZnJ6IHRyYW5zYWN0aW9uCglhc3NlcnQKCgkvLyBhYzogYWNmZwoJdHhuIEdyb3VwSW5kZXgKCXB1c2hpbnQgNQoJLQoJZHVwCglndHhucyBUeXBlRW51bQoJcHVzaGludCAzIC8vIGFjZmcKCT09CgoJLy8gYXJndW1lbnQgNCAoYWMpIGZvciB0eG5UeXBlcyBtdXN0IGJlIGEgYWNmZyB0cmFuc2FjdGlvbgoJYXNzZXJ0CgoJLy8gYTogYXBwbAoJdHhuIEdyb3VwSW5kZXgKCXB1c2hpbnQgNgoJLQoJZHVwCglndHhucyBUeXBlRW51bQoJcHVzaGludCA2IC8vIGFwcGwKCT09CgoJLy8gYXJndW1lbnQgNSAoYSkgZm9yIHR4blR5cGVzIG11c3QgYmUgYSBhcHBsIHRyYW5zYWN0aW9uCglhc3NlcnQKCgkvLyB0OiB0eG4KCXR4biBHcm91cEluZGV4CglwdXNoaW50IDcKCS0KCgkvLyBleGVjdXRlIHR4blR5cGVzKHR4bixhcHBsLGFjZmcsYWZyeixheGZlcixrZXlyZWcscGF5KXZvaWQKCWNhbGxzdWIgdHhuVHlwZXMKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyB0eG5UeXBlcyh0OiBUeG4sIGE6IEFwcENhbGxUeG4sIGFjOiBBc3NldENvbmZpZ1R4biwgYWY6IEFzc2V0RnJlZXplVHhuLCBhdDogQXNzZXRUcmFuc2ZlclR4biwga3I6IEtleVJlZ1R4biwgcDogUGF5VHhuKTogdm9pZAp0eG5UeXBlczoKCXByb3RvIDcgMAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo3MjYKCS8vIGFzc2VydCh0LnNlbmRlciA9PT0gYS5zZW5kZXIpCglmcmFtZV9kaWcgLTEgLy8gdDogVHhuCglndHhucyBTZW5kZXIKCWZyYW1lX2RpZyAtMiAvLyBhOiBBcHBDYWxsVHhuCglndHhucyBTZW5kZXIKCT09Cglhc3NlcnQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NzI3CgkvLyBhc3NlcnQoYWMuc2VuZGVyID09PSBhZi5zZW5kZXIpCglmcmFtZV9kaWcgLTMgLy8gYWM6IEFzc2V0Q29uZmlnVHhuCglndHhucyBTZW5kZXIKCWZyYW1lX2RpZyAtNCAvLyBhZjogQXNzZXRGcmVlemVUeG4KCWd0eG5zIFNlbmRlcgoJPT0KCWFzc2VydAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo3MjgKCS8vIGFzc2VydChhdC5zZW5kZXIgPT09IGtyLnNlbmRlcikKCWZyYW1lX2RpZyAtNSAvLyBhdDogQXNzZXRUcmFuc2ZlclR4bgoJZ3R4bnMgU2VuZGVyCglmcmFtZV9kaWcgLTYgLy8ga3I6IEtleVJlZ1R4bgoJZ3R4bnMgU2VuZGVyCgk9PQoJYXNzZXJ0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjcyOQoJLy8gYXNzZXJ0KHAuc2VuZGVyID09PSB0LnNlbmRlcikKCWZyYW1lX2RpZyAtNyAvLyBwOiBQYXlUeG4KCWd0eG5zIFNlbmRlcgoJZnJhbWVfZGlnIC0xIC8vIHQ6IFR4bgoJZ3R4bnMgU2VuZGVyCgk9PQoJYXNzZXJ0CglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDg0MDMzN2VmIC8vIG1ldGhvZCAidHhuVHlwZXModHhuLGFwcGwsYWNmZyxhZnJ6LGF4ZmVyLGtleXJlZyxwYXkpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfdHhuVHlwZXMKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestTxnTypes.arc56_draft.json b/tests/contracts/artifacts/ABITestTxnTypes.arc56_draft.json index 0ab42602d..153a93448 100644 --- a/tests/contracts/artifacts/ABITestTxnTypes.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestTxnTypes.arc56_draft.json @@ -899,7 +899,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdHhuVHlwZXModHhuLGFwcGwsYWNmZyxhZnJ6LGF4ZmVyLGtleXJlZyxwYXkpdm9pZAoqYWJpX3JvdXRlX3R4blR5cGVzOgoJLy8gcDogcGF5Cgl0eG4gR3JvdXBJbmRleAoJcHVzaGludCAxCgktCglkdXAKCWd0eG5zIFR5cGVFbnVtCglwdXNoaW50IDEgLy8gcGF5Cgk9PQoKCS8vIGFyZ3VtZW50IDAgKHApIGZvciB0eG5UeXBlcyBtdXN0IGJlIGEgcGF5IHRyYW5zYWN0aW9uCglhc3NlcnQKCgkvLyBrcjoga2V5cmVnCgl0eG4gR3JvdXBJbmRleAoJcHVzaGludCAyCgktCglkdXAKCWd0eG5zIFR5cGVFbnVtCglwdXNoaW50IDIgLy8ga2V5cmVnCgk9PQoKCS8vIGFyZ3VtZW50IDEgKGtyKSBmb3IgdHhuVHlwZXMgbXVzdCBiZSBhIGtleXJlZyB0cmFuc2FjdGlvbgoJYXNzZXJ0CgoJLy8gYXQ6IGF4ZmVyCgl0eG4gR3JvdXBJbmRleAoJcHVzaGludCAzCgktCglkdXAKCWd0eG5zIFR5cGVFbnVtCglwdXNoaW50IDQgLy8gYXhmZXIKCT09CgoJLy8gYXJndW1lbnQgMiAoYXQpIGZvciB0eG5UeXBlcyBtdXN0IGJlIGEgYXhmZXIgdHJhbnNhY3Rpb24KCWFzc2VydAoKCS8vIGFmOiBhZnJ6Cgl0eG4gR3JvdXBJbmRleAoJcHVzaGludCA0CgktCglkdXAKCWd0eG5zIFR5cGVFbnVtCglwdXNoaW50IDUgLy8gYWZyegoJPT0KCgkvLyBhcmd1bWVudCAzIChhZikgZm9yIHR4blR5cGVzIG11c3QgYmUgYSBhZnJ6IHRyYW5zYWN0aW9uCglhc3NlcnQKCgkvLyBhYzogYWNmZwoJdHhuIEdyb3VwSW5kZXgKCXB1c2hpbnQgNQoJLQoJZHVwCglndHhucyBUeXBlRW51bQoJcHVzaGludCAzIC8vIGFjZmcKCT09CgoJLy8gYXJndW1lbnQgNCAoYWMpIGZvciB0eG5UeXBlcyBtdXN0IGJlIGEgYWNmZyB0cmFuc2FjdGlvbgoJYXNzZXJ0CgoJLy8gYTogYXBwbAoJdHhuIEdyb3VwSW5kZXgKCXB1c2hpbnQgNgoJLQoJZHVwCglndHhucyBUeXBlRW51bQoJcHVzaGludCA2IC8vIGFwcGwKCT09CgoJLy8gYXJndW1lbnQgNSAoYSkgZm9yIHR4blR5cGVzIG11c3QgYmUgYSBhcHBsIHRyYW5zYWN0aW9uCglhc3NlcnQKCgkvLyB0OiB0eG4KCXR4biBHcm91cEluZGV4CglwdXNoaW50IDcKCS0KCgkvLyBleGVjdXRlIHR4blR5cGVzKHR4bixhcHBsLGFjZmcsYWZyeixheGZlcixrZXlyZWcscGF5KXZvaWQKCWNhbGxzdWIgdHhuVHlwZXMKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyB0eG5UeXBlcyh0OiBUeG4sIGE6IEFwcENhbGxUeG4sIGFjOiBBc3NldENvbmZpZ1R4biwgYWY6IEFzc2V0RnJlZXplVHhuLCBhdDogQXNzZXRUcmFuc2ZlclR4biwga3I6IEtleVJlZ1R4biwgcDogUGF5VHhuKTogdm9pZAp0eG5UeXBlczoKCXByb3RvIDcgMAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo3MjYKCS8vIGFzc2VydCh0LnNlbmRlciA9PT0gYS5zZW5kZXIpCglmcmFtZV9kaWcgLTEgLy8gdDogVHhuCglndHhucyBTZW5kZXIKCWZyYW1lX2RpZyAtMiAvLyBhOiBBcHBDYWxsVHhuCglndHhucyBTZW5kZXIKCT09Cglhc3NlcnQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NzI3CgkvLyBhc3NlcnQoYWMuc2VuZGVyID09PSBhZi5zZW5kZXIpCglmcmFtZV9kaWcgLTMgLy8gYWM6IEFzc2V0Q29uZmlnVHhuCglndHhucyBTZW5kZXIKCWZyYW1lX2RpZyAtNCAvLyBhZjogQXNzZXRGcmVlemVUeG4KCWd0eG5zIFNlbmRlcgoJPT0KCWFzc2VydAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo3MjgKCS8vIGFzc2VydChhdC5zZW5kZXIgPT09IGtyLnNlbmRlcikKCWZyYW1lX2RpZyAtNSAvLyBhdDogQXNzZXRUcmFuc2ZlclR4bgoJZ3R4bnMgU2VuZGVyCglmcmFtZV9kaWcgLTYgLy8ga3I6IEtleVJlZ1R4bgoJZ3R4bnMgU2VuZGVyCgk9PQoJYXNzZXJ0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjcyOQoJLy8gYXNzZXJ0KHAuc2VuZGVyID09PSB0LnNlbmRlcikKCWZyYW1lX2RpZyAtNyAvLyBwOiBQYXlUeG4KCWd0eG5zIFNlbmRlcgoJZnJhbWVfZGlnIC0xIC8vIHQ6IFR4bgoJZ3R4bnMgU2VuZGVyCgk9PQoJYXNzZXJ0CglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDg0MDMzN2VmIC8vIG1ldGhvZCAidHhuVHlwZXModHhuLGFwcGwsYWNmZyxhZnJ6LGF4ZmVyLGtleXJlZyxwYXkpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfdHhuVHlwZXMKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdHhuVHlwZXModHhuLGFwcGwsYWNmZyxhZnJ6LGF4ZmVyLGtleXJlZyxwYXkpdm9pZAoqYWJpX3JvdXRlX3R4blR5cGVzOgoJLy8gcDogcGF5Cgl0eG4gR3JvdXBJbmRleAoJcHVzaGludCAxCgktCglkdXAKCWd0eG5zIFR5cGVFbnVtCglwdXNoaW50IDEgLy8gcGF5Cgk9PQoKCS8vIGFyZ3VtZW50IDAgKHApIGZvciB0eG5UeXBlcyBtdXN0IGJlIGEgcGF5IHRyYW5zYWN0aW9uCglhc3NlcnQKCgkvLyBrcjoga2V5cmVnCgl0eG4gR3JvdXBJbmRleAoJcHVzaGludCAyCgktCglkdXAKCWd0eG5zIFR5cGVFbnVtCglwdXNoaW50IDIgLy8ga2V5cmVnCgk9PQoKCS8vIGFyZ3VtZW50IDEgKGtyKSBmb3IgdHhuVHlwZXMgbXVzdCBiZSBhIGtleXJlZyB0cmFuc2FjdGlvbgoJYXNzZXJ0CgoJLy8gYXQ6IGF4ZmVyCgl0eG4gR3JvdXBJbmRleAoJcHVzaGludCAzCgktCglkdXAKCWd0eG5zIFR5cGVFbnVtCglwdXNoaW50IDQgLy8gYXhmZXIKCT09CgoJLy8gYXJndW1lbnQgMiAoYXQpIGZvciB0eG5UeXBlcyBtdXN0IGJlIGEgYXhmZXIgdHJhbnNhY3Rpb24KCWFzc2VydAoKCS8vIGFmOiBhZnJ6Cgl0eG4gR3JvdXBJbmRleAoJcHVzaGludCA0CgktCglkdXAKCWd0eG5zIFR5cGVFbnVtCglwdXNoaW50IDUgLy8gYWZyegoJPT0KCgkvLyBhcmd1bWVudCAzIChhZikgZm9yIHR4blR5cGVzIG11c3QgYmUgYSBhZnJ6IHRyYW5zYWN0aW9uCglhc3NlcnQKCgkvLyBhYzogYWNmZwoJdHhuIEdyb3VwSW5kZXgKCXB1c2hpbnQgNQoJLQoJZHVwCglndHhucyBUeXBlRW51bQoJcHVzaGludCAzIC8vIGFjZmcKCT09CgoJLy8gYXJndW1lbnQgNCAoYWMpIGZvciB0eG5UeXBlcyBtdXN0IGJlIGEgYWNmZyB0cmFuc2FjdGlvbgoJYXNzZXJ0CgoJLy8gYTogYXBwbAoJdHhuIEdyb3VwSW5kZXgKCXB1c2hpbnQgNgoJLQoJZHVwCglndHhucyBUeXBlRW51bQoJcHVzaGludCA2IC8vIGFwcGwKCT09CgoJLy8gYXJndW1lbnQgNSAoYSkgZm9yIHR4blR5cGVzIG11c3QgYmUgYSBhcHBsIHRyYW5zYWN0aW9uCglhc3NlcnQKCgkvLyB0OiB0eG4KCXR4biBHcm91cEluZGV4CglwdXNoaW50IDcKCS0KCgkvLyBleGVjdXRlIHR4blR5cGVzKHR4bixhcHBsLGFjZmcsYWZyeixheGZlcixrZXlyZWcscGF5KXZvaWQKCWNhbGxzdWIgdHhuVHlwZXMKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyB0eG5UeXBlcyh0OiBUeG4sIGE6IEFwcENhbGxUeG4sIGFjOiBBc3NldENvbmZpZ1R4biwgYWY6IEFzc2V0RnJlZXplVHhuLCBhdDogQXNzZXRUcmFuc2ZlclR4biwga3I6IEtleVJlZ1R4biwgcDogUGF5VHhuKTogdm9pZAp0eG5UeXBlczoKCXByb3RvIDcgMAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo3MjYKCS8vIGFzc2VydCh0LnNlbmRlciA9PT0gYS5zZW5kZXIpCglmcmFtZV9kaWcgLTEgLy8gdDogVHhuCglndHhucyBTZW5kZXIKCWZyYW1lX2RpZyAtMiAvLyBhOiBBcHBDYWxsVHhuCglndHhucyBTZW5kZXIKCT09Cglhc3NlcnQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NzI3CgkvLyBhc3NlcnQoYWMuc2VuZGVyID09PSBhZi5zZW5kZXIpCglmcmFtZV9kaWcgLTMgLy8gYWM6IEFzc2V0Q29uZmlnVHhuCglndHhucyBTZW5kZXIKCWZyYW1lX2RpZyAtNCAvLyBhZjogQXNzZXRGcmVlemVUeG4KCWd0eG5zIFNlbmRlcgoJPT0KCWFzc2VydAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo3MjgKCS8vIGFzc2VydChhdC5zZW5kZXIgPT09IGtyLnNlbmRlcikKCWZyYW1lX2RpZyAtNSAvLyBhdDogQXNzZXRUcmFuc2ZlclR4bgoJZ3R4bnMgU2VuZGVyCglmcmFtZV9kaWcgLTYgLy8ga3I6IEtleVJlZ1R4bgoJZ3R4bnMgU2VuZGVyCgk9PQoJYXNzZXJ0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjcyOQoJLy8gYXNzZXJ0KHAuc2VuZGVyID09PSB0LnNlbmRlcikKCWZyYW1lX2RpZyAtNyAvLyBwOiBQYXlUeG4KCWd0eG5zIFNlbmRlcgoJZnJhbWVfZGlnIC0xIC8vIHQ6IFR4bgoJZ3R4bnMgU2VuZGVyCgk9PQoJYXNzZXJ0CglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDg0MDMzN2VmIC8vIG1ldGhvZCAidHhuVHlwZXModHhuLGFwcGwsYWNmZyxhZnJ6LGF4ZmVyLGtleXJlZyxwYXkpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfdHhuVHlwZXMKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestTypedConst.approval.teal b/tests/contracts/artifacts/ABITestTypedConst.approval.teal index b0aa1e4e1..c5ad414ee 100644 --- a/tests/contracts/artifacts/ABITestTypedConst.approval.teal +++ b/tests/contracts/artifacts/ABITestTypedConst.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestTypedConst.arc32.json b/tests/contracts/artifacts/ABITestTypedConst.arc32.json index 962f431ee..db702f8b3 100644 --- a/tests/contracts/artifacts/ABITestTypedConst.arc32.json +++ b/tests/contracts/artifacts/ABITestTypedConst.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gbWF4UG9vbHMoKXZvaWQKKmFiaV9yb3V0ZV9tYXhQb29sczoKCS8vIGV4ZWN1dGUgbWF4UG9vbHMoKXZvaWQKCWNhbGxzdWIgbWF4UG9vbHMKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBtYXhQb29scygpOiB2b2lkCm1heFBvb2xzOgoJcHJvdG8gMCAwCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjkxCgkvLyB1aW50MTZWYXI6IHVpbnQxNiA9IDI1NgoJcHVzaGludCAyNTYKCWZyYW1lX2J1cnkgMCAvLyB1aW50MTZWYXI6IHVpbnQxNgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjkyCgkvLyBhc3NlcnQodWludDE2VmFyID09PSBVSU5UMTZfQ09OU1QpCglwdXNoaW50IDI1NiAvLyB1aW50MTZWYXI6IHVpbnQxNgoJcHVzaGludCAyNTYKCT09Cglhc3NlcnQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YWI1M2RiYmEgLy8gbWV0aG9kICJtYXhQb29scygpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfbWF4UG9vbHMKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gbWF4UG9vbHMoKXZvaWQKKmFiaV9yb3V0ZV9tYXhQb29sczoKCS8vIGV4ZWN1dGUgbWF4UG9vbHMoKXZvaWQKCWNhbGxzdWIgbWF4UG9vbHMKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBtYXhQb29scygpOiB2b2lkCm1heFBvb2xzOgoJcHJvdG8gMCAwCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjkxCgkvLyB1aW50MTZWYXI6IHVpbnQxNiA9IDI1NgoJcHVzaGludCAyNTYKCWZyYW1lX2J1cnkgMCAvLyB1aW50MTZWYXI6IHVpbnQxNgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjkyCgkvLyBhc3NlcnQodWludDE2VmFyID09PSBVSU5UMTZfQ09OU1QpCglwdXNoaW50IDI1NiAvLyB1aW50MTZWYXI6IHVpbnQxNgoJcHVzaGludCAyNTYKCT09Cglhc3NlcnQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YWI1M2RiYmEgLy8gbWV0aG9kICJtYXhQb29scygpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfbWF4UG9vbHMKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestTypedConst.arc56_draft.json b/tests/contracts/artifacts/ABITestTypedConst.arc56_draft.json index a31d68b1d..028fabff1 100644 --- a/tests/contracts/artifacts/ABITestTypedConst.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestTypedConst.arc56_draft.json @@ -354,7 +354,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gbWF4UG9vbHMoKXZvaWQKKmFiaV9yb3V0ZV9tYXhQb29sczoKCS8vIGV4ZWN1dGUgbWF4UG9vbHMoKXZvaWQKCWNhbGxzdWIgbWF4UG9vbHMKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBtYXhQb29scygpOiB2b2lkCm1heFBvb2xzOgoJcHJvdG8gMCAwCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjkxCgkvLyB1aW50MTZWYXI6IHVpbnQxNiA9IDI1NgoJcHVzaGludCAyNTYKCWZyYW1lX2J1cnkgMCAvLyB1aW50MTZWYXI6IHVpbnQxNgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjkyCgkvLyBhc3NlcnQodWludDE2VmFyID09PSBVSU5UMTZfQ09OU1QpCglwdXNoaW50IDI1NiAvLyB1aW50MTZWYXI6IHVpbnQxNgoJcHVzaGludCAyNTYKCT09Cglhc3NlcnQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YWI1M2RiYmEgLy8gbWV0aG9kICJtYXhQb29scygpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfbWF4UG9vbHMKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gbWF4UG9vbHMoKXZvaWQKKmFiaV9yb3V0ZV9tYXhQb29sczoKCS8vIGV4ZWN1dGUgbWF4UG9vbHMoKXZvaWQKCWNhbGxzdWIgbWF4UG9vbHMKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBtYXhQb29scygpOiB2b2lkCm1heFBvb2xzOgoJcHJvdG8gMCAwCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjkxCgkvLyB1aW50MTZWYXI6IHVpbnQxNiA9IDI1NgoJcHVzaGludCAyNTYKCWZyYW1lX2J1cnkgMCAvLyB1aW50MTZWYXI6IHVpbnQxNgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjkyCgkvLyBhc3NlcnQodWludDE2VmFyID09PSBVSU5UMTZfQ09OU1QpCglwdXNoaW50IDI1NiAvLyB1aW50MTZWYXI6IHVpbnQxNgoJcHVzaGludCAyNTYKCT09Cglhc3NlcnQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YWI1M2RiYmEgLy8gbWV0aG9kICJtYXhQb29scygpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfbWF4UG9vbHMKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestTypedVarFromStorage.approval.teal b/tests/contracts/artifacts/ABITestTypedVarFromStorage.approval.teal index 4eb534eb1..a42e931b2 100644 --- a/tests/contracts/artifacts/ABITestTypedVarFromStorage.approval.teal +++ b/tests/contracts/artifacts/ABITestTypedVarFromStorage.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestTypedVarFromStorage.arc32.json b/tests/contracts/artifacts/ABITestTypedVarFromStorage.arc32.json index ee826d8b5..65480da5b 100644 --- a/tests/contracts/artifacts/ABITestTypedVarFromStorage.arc32.json +++ b/tests/contracts/artifacts/ABITestTypedVarFromStorage.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdHlwZWRWYXJGcm9tU3RvcmFnZSh1aW50MzIpYnl0ZVszMl0KKmFiaV9yb3V0ZV90eXBlZFZhckZyb21TdG9yYWdlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGtleTogdWludDMyCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglkdXAKCWxlbgoJcHVzaGludCA0Cgk9PQoKCS8vIGFyZ3VtZW50IDAgKGtleSkgZm9yIHR5cGVkVmFyRnJvbVN0b3JhZ2UgbXVzdCBiZSBhIHVpbnQzMgoJYXNzZXJ0CglidG9pCgoJLy8gZXhlY3V0ZSB0eXBlZFZhckZyb21TdG9yYWdlKHVpbnQzMilieXRlWzMyXQoJY2FsbHN1YiB0eXBlZFZhckZyb21TdG9yYWdlCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHR5cGVkVmFyRnJvbVN0b3JhZ2Uoa2V5OiB1aW50PDMyPik6IGJ5dGVzMzIKdHlwZWRWYXJGcm9tU3RvcmFnZToKCXByb3RvIDEgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglwdXNoYnl0ZXMgMHgKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTMwMAoJLy8gdmFsdWU6IGJ5dGVzMzIgPSB0aGlzLmJveE1hcFRlc3Qoa2V5KS52YWx1ZQoJZnJhbWVfZGlnIC0xIC8vIGtleTogdWludDwzMj4KCWl0b2IKCWV4dHJhY3QgNCA0CglmcmFtZV9idXJ5IDAgLy8gc3RvcmFnZSBrZXkvL3ZhbHVlCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzMDIKCS8vIHJldHVybiB2YWx1ZTsKCWZyYW1lX2RpZyAwIC8vIHN0b3JhZ2Uga2V5Ly92YWx1ZQoJYm94X2dldAoKCS8vIGJveCB2YWx1ZSBkb2VzIG5vdCBleGlzdDogdGhpcy5ib3hNYXBUZXN0KGtleSkudmFsdWUKCWFzc2VydAoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg0YzUyOWY1NSAvLyBtZXRob2QgInR5cGVkVmFyRnJvbVN0b3JhZ2UodWludDMyKWJ5dGVbMzJdIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV90eXBlZFZhckZyb21TdG9yYWdlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdHlwZWRWYXJGcm9tU3RvcmFnZSh1aW50MzIpYnl0ZVszMl0KKmFiaV9yb3V0ZV90eXBlZFZhckZyb21TdG9yYWdlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGtleTogdWludDMyCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglkdXAKCWxlbgoJcHVzaGludCA0Cgk9PQoKCS8vIGFyZ3VtZW50IDAgKGtleSkgZm9yIHR5cGVkVmFyRnJvbVN0b3JhZ2UgbXVzdCBiZSBhIHVpbnQzMgoJYXNzZXJ0CglidG9pCgoJLy8gZXhlY3V0ZSB0eXBlZFZhckZyb21TdG9yYWdlKHVpbnQzMilieXRlWzMyXQoJY2FsbHN1YiB0eXBlZFZhckZyb21TdG9yYWdlCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHR5cGVkVmFyRnJvbVN0b3JhZ2Uoa2V5OiB1aW50PDMyPik6IGJ5dGVzMzIKdHlwZWRWYXJGcm9tU3RvcmFnZToKCXByb3RvIDEgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglwdXNoYnl0ZXMgMHgKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTMwMAoJLy8gdmFsdWU6IGJ5dGVzMzIgPSB0aGlzLmJveE1hcFRlc3Qoa2V5KS52YWx1ZQoJZnJhbWVfZGlnIC0xIC8vIGtleTogdWludDwzMj4KCWl0b2IKCWV4dHJhY3QgNCA0CglmcmFtZV9idXJ5IDAgLy8gc3RvcmFnZSBrZXkvL3ZhbHVlCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzMDIKCS8vIHJldHVybiB2YWx1ZTsKCWZyYW1lX2RpZyAwIC8vIHN0b3JhZ2Uga2V5Ly92YWx1ZQoJYm94X2dldAoKCS8vIGJveCB2YWx1ZSBkb2VzIG5vdCBleGlzdDogdGhpcy5ib3hNYXBUZXN0KGtleSkudmFsdWUKCWFzc2VydAoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg0YzUyOWY1NSAvLyBtZXRob2QgInR5cGVkVmFyRnJvbVN0b3JhZ2UodWludDMyKWJ5dGVbMzJdIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV90eXBlZFZhckZyb21TdG9yYWdlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestTypedVarFromStorage.arc56_draft.json b/tests/contracts/artifacts/ABITestTypedVarFromStorage.arc56_draft.json index 52e1a958c..0b3f9aa99 100644 --- a/tests/contracts/artifacts/ABITestTypedVarFromStorage.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestTypedVarFromStorage.arc56_draft.json @@ -457,7 +457,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdHlwZWRWYXJGcm9tU3RvcmFnZSh1aW50MzIpYnl0ZVszMl0KKmFiaV9yb3V0ZV90eXBlZFZhckZyb21TdG9yYWdlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGtleTogdWludDMyCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglkdXAKCWxlbgoJcHVzaGludCA0Cgk9PQoKCS8vIGFyZ3VtZW50IDAgKGtleSkgZm9yIHR5cGVkVmFyRnJvbVN0b3JhZ2UgbXVzdCBiZSBhIHVpbnQzMgoJYXNzZXJ0CglidG9pCgoJLy8gZXhlY3V0ZSB0eXBlZFZhckZyb21TdG9yYWdlKHVpbnQzMilieXRlWzMyXQoJY2FsbHN1YiB0eXBlZFZhckZyb21TdG9yYWdlCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHR5cGVkVmFyRnJvbVN0b3JhZ2Uoa2V5OiB1aW50PDMyPik6IGJ5dGVzMzIKdHlwZWRWYXJGcm9tU3RvcmFnZToKCXByb3RvIDEgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglwdXNoYnl0ZXMgMHgKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTMwMAoJLy8gdmFsdWU6IGJ5dGVzMzIgPSB0aGlzLmJveE1hcFRlc3Qoa2V5KS52YWx1ZQoJZnJhbWVfZGlnIC0xIC8vIGtleTogdWludDwzMj4KCWl0b2IKCWV4dHJhY3QgNCA0CglmcmFtZV9idXJ5IDAgLy8gc3RvcmFnZSBrZXkvL3ZhbHVlCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzMDIKCS8vIHJldHVybiB2YWx1ZTsKCWZyYW1lX2RpZyAwIC8vIHN0b3JhZ2Uga2V5Ly92YWx1ZQoJYm94X2dldAoKCS8vIGJveCB2YWx1ZSBkb2VzIG5vdCBleGlzdDogdGhpcy5ib3hNYXBUZXN0KGtleSkudmFsdWUKCWFzc2VydAoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg0YzUyOWY1NSAvLyBtZXRob2QgInR5cGVkVmFyRnJvbVN0b3JhZ2UodWludDMyKWJ5dGVbMzJdIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV90eXBlZFZhckZyb21TdG9yYWdlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdHlwZWRWYXJGcm9tU3RvcmFnZSh1aW50MzIpYnl0ZVszMl0KKmFiaV9yb3V0ZV90eXBlZFZhckZyb21TdG9yYWdlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGtleTogdWludDMyCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglkdXAKCWxlbgoJcHVzaGludCA0Cgk9PQoKCS8vIGFyZ3VtZW50IDAgKGtleSkgZm9yIHR5cGVkVmFyRnJvbVN0b3JhZ2UgbXVzdCBiZSBhIHVpbnQzMgoJYXNzZXJ0CglidG9pCgoJLy8gZXhlY3V0ZSB0eXBlZFZhckZyb21TdG9yYWdlKHVpbnQzMilieXRlWzMyXQoJY2FsbHN1YiB0eXBlZFZhckZyb21TdG9yYWdlCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHR5cGVkVmFyRnJvbVN0b3JhZ2Uoa2V5OiB1aW50PDMyPik6IGJ5dGVzMzIKdHlwZWRWYXJGcm9tU3RvcmFnZToKCXByb3RvIDEgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglwdXNoYnl0ZXMgMHgKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTMwMAoJLy8gdmFsdWU6IGJ5dGVzMzIgPSB0aGlzLmJveE1hcFRlc3Qoa2V5KS52YWx1ZQoJZnJhbWVfZGlnIC0xIC8vIGtleTogdWludDwzMj4KCWl0b2IKCWV4dHJhY3QgNCA0CglmcmFtZV9idXJ5IDAgLy8gc3RvcmFnZSBrZXkvL3ZhbHVlCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjEzMDIKCS8vIHJldHVybiB2YWx1ZTsKCWZyYW1lX2RpZyAwIC8vIHN0b3JhZ2Uga2V5Ly92YWx1ZQoJYm94X2dldAoKCS8vIGJveCB2YWx1ZSBkb2VzIG5vdCBleGlzdDogdGhpcy5ib3hNYXBUZXN0KGtleSkudmFsdWUKCWFzc2VydAoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg0YzUyOWY1NSAvLyBtZXRob2QgInR5cGVkVmFyRnJvbVN0b3JhZ2UodWludDMyKWJ5dGVbMzJdIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV90eXBlZFZhckZyb21TdG9yYWdlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestUint64Casting.approval.teal b/tests/contracts/artifacts/ABITestUint64Casting.approval.teal index 7c5341c7f..ab9d94f97 100644 --- a/tests/contracts/artifacts/ABITestUint64Casting.approval.teal +++ b/tests/contracts/artifacts/ABITestUint64Casting.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestUint64Casting.arc32.json b/tests/contracts/artifacts/ABITestUint64Casting.arc32.json index f27f41e9e..23e066608 100644 --- a/tests/contracts/artifacts/ABITestUint64Casting.arc32.json +++ b/tests/contracts/artifacts/ABITestUint64Casting.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdWludDY0Q2FzdGluZyh1aW50MjU2KXVpbnQ2NAoqYWJpX3JvdXRlX3VpbnQ2NENhc3Rpbmc6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gYTogdWludDI1NgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJZHVwCglsZW4KCXB1c2hpbnQgMzIKCT09CgoJLy8gYXJndW1lbnQgMCAoYSkgZm9yIHVpbnQ2NENhc3RpbmcgbXVzdCBiZSBhIHVpbnQyNTYKCWFzc2VydAoKCS8vIGV4ZWN1dGUgdWludDY0Q2FzdGluZyh1aW50MjU2KXVpbnQ2NAoJY2FsbHN1YiB1aW50NjRDYXN0aW5nCglpdG9iCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHVpbnQ2NENhc3RpbmcoYTogdWludDI1Nik6IHVpbnQ2NAp1aW50NjRDYXN0aW5nOgoJcHJvdG8gMSAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjExOTUKCS8vIHJldHVybiBhIGFzIHVpbnQ2NDsKCWZyYW1lX2RpZyAtMSAvLyBhOiB1aW50MjU2CglkdXAKCWJpdGxlbgoJcHVzaGludCA2NAoJPD0KCgkvLyBhIGFzIHVpbnQ2NCBvdmVyZmxvd2VkIDY0IGJpdHMKCWFzc2VydAoJZXh0cmFjdCAyNCA4CglidG9pCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGZhYzk5NzA2IC8vIG1ldGhvZCAidWludDY0Q2FzdGluZyh1aW50MjU2KXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfdWludDY0Q2FzdGluZwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdWludDY0Q2FzdGluZyh1aW50MjU2KXVpbnQ2NAoqYWJpX3JvdXRlX3VpbnQ2NENhc3Rpbmc6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gYTogdWludDI1NgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJZHVwCglsZW4KCXB1c2hpbnQgMzIKCT09CgoJLy8gYXJndW1lbnQgMCAoYSkgZm9yIHVpbnQ2NENhc3RpbmcgbXVzdCBiZSBhIHVpbnQyNTYKCWFzc2VydAoKCS8vIGV4ZWN1dGUgdWludDY0Q2FzdGluZyh1aW50MjU2KXVpbnQ2NAoJY2FsbHN1YiB1aW50NjRDYXN0aW5nCglpdG9iCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHVpbnQ2NENhc3RpbmcoYTogdWludDI1Nik6IHVpbnQ2NAp1aW50NjRDYXN0aW5nOgoJcHJvdG8gMSAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjExOTUKCS8vIHJldHVybiBhIGFzIHVpbnQ2NDsKCWZyYW1lX2RpZyAtMSAvLyBhOiB1aW50MjU2CglkdXAKCWJpdGxlbgoJcHVzaGludCA2NAoJPD0KCgkvLyBhIGFzIHVpbnQ2NCBvdmVyZmxvd2VkIDY0IGJpdHMKCWFzc2VydAoJZXh0cmFjdCAyNCA4CglidG9pCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGZhYzk5NzA2IC8vIG1ldGhvZCAidWludDY0Q2FzdGluZyh1aW50MjU2KXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfdWludDY0Q2FzdGluZwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestUint64Casting.arc56_draft.json b/tests/contracts/artifacts/ABITestUint64Casting.arc56_draft.json index 363526d91..1e53830ee 100644 --- a/tests/contracts/artifacts/ABITestUint64Casting.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestUint64Casting.arc56_draft.json @@ -442,7 +442,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdWludDY0Q2FzdGluZyh1aW50MjU2KXVpbnQ2NAoqYWJpX3JvdXRlX3VpbnQ2NENhc3Rpbmc6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gYTogdWludDI1NgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJZHVwCglsZW4KCXB1c2hpbnQgMzIKCT09CgoJLy8gYXJndW1lbnQgMCAoYSkgZm9yIHVpbnQ2NENhc3RpbmcgbXVzdCBiZSBhIHVpbnQyNTYKCWFzc2VydAoKCS8vIGV4ZWN1dGUgdWludDY0Q2FzdGluZyh1aW50MjU2KXVpbnQ2NAoJY2FsbHN1YiB1aW50NjRDYXN0aW5nCglpdG9iCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHVpbnQ2NENhc3RpbmcoYTogdWludDI1Nik6IHVpbnQ2NAp1aW50NjRDYXN0aW5nOgoJcHJvdG8gMSAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjExOTUKCS8vIHJldHVybiBhIGFzIHVpbnQ2NDsKCWZyYW1lX2RpZyAtMSAvLyBhOiB1aW50MjU2CglkdXAKCWJpdGxlbgoJcHVzaGludCA2NAoJPD0KCgkvLyBhIGFzIHVpbnQ2NCBvdmVyZmxvd2VkIDY0IGJpdHMKCWFzc2VydAoJZXh0cmFjdCAyNCA4CglidG9pCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGZhYzk5NzA2IC8vIG1ldGhvZCAidWludDY0Q2FzdGluZyh1aW50MjU2KXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfdWludDY0Q2FzdGluZwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdWludDY0Q2FzdGluZyh1aW50MjU2KXVpbnQ2NAoqYWJpX3JvdXRlX3VpbnQ2NENhc3Rpbmc6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gYTogdWludDI1NgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJZHVwCglsZW4KCXB1c2hpbnQgMzIKCT09CgoJLy8gYXJndW1lbnQgMCAoYSkgZm9yIHVpbnQ2NENhc3RpbmcgbXVzdCBiZSBhIHVpbnQyNTYKCWFzc2VydAoKCS8vIGV4ZWN1dGUgdWludDY0Q2FzdGluZyh1aW50MjU2KXVpbnQ2NAoJY2FsbHN1YiB1aW50NjRDYXN0aW5nCglpdG9iCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHVpbnQ2NENhc3RpbmcoYTogdWludDI1Nik6IHVpbnQ2NAp1aW50NjRDYXN0aW5nOgoJcHJvdG8gMSAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjExOTUKCS8vIHJldHVybiBhIGFzIHVpbnQ2NDsKCWZyYW1lX2RpZyAtMSAvLyBhOiB1aW50MjU2CglkdXAKCWJpdGxlbgoJcHVzaGludCA2NAoJPD0KCgkvLyBhIGFzIHVpbnQ2NCBvdmVyZmxvd2VkIDY0IGJpdHMKCWFzc2VydAoJZXh0cmFjdCAyNCA4CglidG9pCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGZhYzk5NzA2IC8vIG1ldGhvZCAidWludDY0Q2FzdGluZyh1aW50MjU2KXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfdWludDY0Q2FzdGluZwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestUintCasting.approval.teal b/tests/contracts/artifacts/ABITestUintCasting.approval.teal index 3ee7f7fa1..797485853 100644 --- a/tests/contracts/artifacts/ABITestUintCasting.approval.teal +++ b/tests/contracts/artifacts/ABITestUintCasting.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestUintCasting.arc32.json b/tests/contracts/artifacts/ABITestUintCasting.arc32.json index 4e287211f..60859edfe 100644 --- a/tests/contracts/artifacts/ABITestUintCasting.arc32.json +++ b/tests/contracts/artifacts/ABITestUintCasting.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdWludENhc3RpbmcodWludDgpdWludDI1NgoqYWJpX3JvdXRlX3VpbnRDYXN0aW5nOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGE6IHVpbnQ4Cgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglkdXAKCWxlbgoJcHVzaGludCAxCgk9PQoKCS8vIGFyZ3VtZW50IDAgKGEpIGZvciB1aW50Q2FzdGluZyBtdXN0IGJlIGEgdWludDgKCWFzc2VydAoJYnRvaQoKCS8vIGV4ZWN1dGUgdWludENhc3RpbmcodWludDgpdWludDI1NgoJY2FsbHN1YiB1aW50Q2FzdGluZwoJZHVwCgliaXRsZW4KCXB1c2hpbnQgMjU2Cgk8PQoKCS8vIHVpbnRDYXN0aW5nIHJldHVybiB2YWx1ZSBvdmVyZmxvd2VkIDI1NiBiaXRzCglhc3NlcnQKCXB1c2hieXRlcyAweEZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkYKCWImCglkdXAKCWxlbgoJZHVwCglwdXNoaW50IDMyCgktCglzd2FwCglzdWJzdHJpbmczCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHVpbnRDYXN0aW5nKGE6IHVpbnQ8OD4pOiB1aW50MjU2CnVpbnRDYXN0aW5nOgoJcHJvdG8gMSAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjExODkKCS8vIHJldHVybiA8dWludDI1Nj5hOwoJZnJhbWVfZGlnIC0xIC8vIGE6IHVpbnQ8OD4KCWl0b2IKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZjUyYmY4NjYgLy8gbWV0aG9kICJ1aW50Q2FzdGluZyh1aW50OCl1aW50MjU2IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV91aW50Q2FzdGluZwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdWludENhc3RpbmcodWludDgpdWludDI1NgoqYWJpX3JvdXRlX3VpbnRDYXN0aW5nOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGE6IHVpbnQ4Cgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglkdXAKCWxlbgoJcHVzaGludCAxCgk9PQoKCS8vIGFyZ3VtZW50IDAgKGEpIGZvciB1aW50Q2FzdGluZyBtdXN0IGJlIGEgdWludDgKCWFzc2VydAoJYnRvaQoKCS8vIGV4ZWN1dGUgdWludENhc3RpbmcodWludDgpdWludDI1NgoJY2FsbHN1YiB1aW50Q2FzdGluZwoJZHVwCgliaXRsZW4KCXB1c2hpbnQgMjU2Cgk8PQoKCS8vIHVpbnRDYXN0aW5nIHJldHVybiB2YWx1ZSBvdmVyZmxvd2VkIDI1NiBiaXRzCglhc3NlcnQKCXB1c2hieXRlcyAweEZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkYKCWImCglkdXAKCWxlbgoJZHVwCglwdXNoaW50IDMyCgktCglzd2FwCglzdWJzdHJpbmczCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHVpbnRDYXN0aW5nKGE6IHVpbnQ8OD4pOiB1aW50MjU2CnVpbnRDYXN0aW5nOgoJcHJvdG8gMSAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjExODkKCS8vIHJldHVybiA8dWludDI1Nj5hOwoJZnJhbWVfZGlnIC0xIC8vIGE6IHVpbnQ8OD4KCWl0b2IKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZjUyYmY4NjYgLy8gbWV0aG9kICJ1aW50Q2FzdGluZyh1aW50OCl1aW50MjU2IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV91aW50Q2FzdGluZwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestUintCasting.arc56_draft.json b/tests/contracts/artifacts/ABITestUintCasting.arc56_draft.json index fb1e51f4f..a1e08df1c 100644 --- a/tests/contracts/artifacts/ABITestUintCasting.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestUintCasting.arc56_draft.json @@ -531,7 +531,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdWludENhc3RpbmcodWludDgpdWludDI1NgoqYWJpX3JvdXRlX3VpbnRDYXN0aW5nOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGE6IHVpbnQ4Cgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglkdXAKCWxlbgoJcHVzaGludCAxCgk9PQoKCS8vIGFyZ3VtZW50IDAgKGEpIGZvciB1aW50Q2FzdGluZyBtdXN0IGJlIGEgdWludDgKCWFzc2VydAoJYnRvaQoKCS8vIGV4ZWN1dGUgdWludENhc3RpbmcodWludDgpdWludDI1NgoJY2FsbHN1YiB1aW50Q2FzdGluZwoJZHVwCgliaXRsZW4KCXB1c2hpbnQgMjU2Cgk8PQoKCS8vIHVpbnRDYXN0aW5nIHJldHVybiB2YWx1ZSBvdmVyZmxvd2VkIDI1NiBiaXRzCglhc3NlcnQKCXB1c2hieXRlcyAweEZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkYKCWImCglkdXAKCWxlbgoJZHVwCglwdXNoaW50IDMyCgktCglzd2FwCglzdWJzdHJpbmczCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHVpbnRDYXN0aW5nKGE6IHVpbnQ8OD4pOiB1aW50MjU2CnVpbnRDYXN0aW5nOgoJcHJvdG8gMSAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjExODkKCS8vIHJldHVybiA8dWludDI1Nj5hOwoJZnJhbWVfZGlnIC0xIC8vIGE6IHVpbnQ8OD4KCWl0b2IKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZjUyYmY4NjYgLy8gbWV0aG9kICJ1aW50Q2FzdGluZyh1aW50OCl1aW50MjU2IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV91aW50Q2FzdGluZwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdWludENhc3RpbmcodWludDgpdWludDI1NgoqYWJpX3JvdXRlX3VpbnRDYXN0aW5nOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGE6IHVpbnQ4Cgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglkdXAKCWxlbgoJcHVzaGludCAxCgk9PQoKCS8vIGFyZ3VtZW50IDAgKGEpIGZvciB1aW50Q2FzdGluZyBtdXN0IGJlIGEgdWludDgKCWFzc2VydAoJYnRvaQoKCS8vIGV4ZWN1dGUgdWludENhc3RpbmcodWludDgpdWludDI1NgoJY2FsbHN1YiB1aW50Q2FzdGluZwoJZHVwCgliaXRsZW4KCXB1c2hpbnQgMjU2Cgk8PQoKCS8vIHVpbnRDYXN0aW5nIHJldHVybiB2YWx1ZSBvdmVyZmxvd2VkIDI1NiBiaXRzCglhc3NlcnQKCXB1c2hieXRlcyAweEZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkZGRkYKCWImCglkdXAKCWxlbgoJZHVwCglwdXNoaW50IDMyCgktCglzd2FwCglzdWJzdHJpbmczCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHVpbnRDYXN0aW5nKGE6IHVpbnQ8OD4pOiB1aW50MjU2CnVpbnRDYXN0aW5nOgoJcHJvdG8gMSAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjExODkKCS8vIHJldHVybiA8dWludDI1Nj5hOwoJZnJhbWVfZGlnIC0xIC8vIGE6IHVpbnQ8OD4KCWl0b2IKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZjUyYmY4NjYgLy8gbWV0aG9kICJ1aW50Q2FzdGluZyh1aW50OCl1aW50MjU2IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV91aW50Q2FzdGluZwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestUintNComparison.approval.teal b/tests/contracts/artifacts/ABITestUintNComparison.approval.teal index 9b397766b..bf4f22adf 100644 --- a/tests/contracts/artifacts/ABITestUintNComparison.approval.teal +++ b/tests/contracts/artifacts/ABITestUintNComparison.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestUintNComparison.arc32.json b/tests/contracts/artifacts/ABITestUintNComparison.arc32.json index 8d059877d..ca3f70266 100644 --- a/tests/contracts/artifacts/ABITestUintNComparison.arc32.json +++ b/tests/contracts/artifacts/ABITestUintNComparison.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdWludE5Db21wYXJpc29uKHVpbnQyNTYsdWludDI1Nilib29sCiphYmlfcm91dGVfdWludE5Db21wYXJpc29uOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIHk6IHVpbnQyNTYKCXR4bmEgQXBwbGljYXRpb25BcmdzIDIKCWR1cAoJbGVuCglwdXNoaW50IDMyCgk9PQoKCS8vIGFyZ3VtZW50IDAgKHkpIGZvciB1aW50TkNvbXBhcmlzb24gbXVzdCBiZSBhIHVpbnQyNTYKCWFzc2VydAoKCS8vIHg6IHVpbnQyNTYKCXR4bmEgQXBwbGljYXRpb25BcmdzIDEKCWR1cAoJbGVuCglwdXNoaW50IDMyCgk9PQoKCS8vIGFyZ3VtZW50IDEgKHgpIGZvciB1aW50TkNvbXBhcmlzb24gbXVzdCBiZSBhIHVpbnQyNTYKCWFzc2VydAoKCS8vIGV4ZWN1dGUgdWludE5Db21wYXJpc29uKHVpbnQyNTYsdWludDI1Nilib29sCgljYWxsc3ViIHVpbnROQ29tcGFyaXNvbgoJcHVzaGJ5dGVzIDB4MDAKCXB1c2hpbnQgMAoJdW5jb3ZlciAyCglzZXRiaXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gdWludE5Db21wYXJpc29uKHg6IHVpbnQyNTYsIHk6IHVpbnQyNTYpOiBib29sZWFuCnVpbnROQ29tcGFyaXNvbjoKCXByb3RvIDIgMQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjU5CgkvLyByZXR1cm4geCA+PSB5OwoJZnJhbWVfZGlnIC0xIC8vIHg6IHVpbnQyNTYKCWZyYW1lX2RpZyAtMiAvLyB5OiB1aW50MjU2CgliPj0KCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YmIwODkwNjEgLy8gbWV0aG9kICJ1aW50TkNvbXBhcmlzb24odWludDI1Nix1aW50MjU2KWJvb2wiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3VpbnROQ29tcGFyaXNvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdWludE5Db21wYXJpc29uKHVpbnQyNTYsdWludDI1Nilib29sCiphYmlfcm91dGVfdWludE5Db21wYXJpc29uOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIHk6IHVpbnQyNTYKCXR4bmEgQXBwbGljYXRpb25BcmdzIDIKCWR1cAoJbGVuCglwdXNoaW50IDMyCgk9PQoKCS8vIGFyZ3VtZW50IDAgKHkpIGZvciB1aW50TkNvbXBhcmlzb24gbXVzdCBiZSBhIHVpbnQyNTYKCWFzc2VydAoKCS8vIHg6IHVpbnQyNTYKCXR4bmEgQXBwbGljYXRpb25BcmdzIDEKCWR1cAoJbGVuCglwdXNoaW50IDMyCgk9PQoKCS8vIGFyZ3VtZW50IDEgKHgpIGZvciB1aW50TkNvbXBhcmlzb24gbXVzdCBiZSBhIHVpbnQyNTYKCWFzc2VydAoKCS8vIGV4ZWN1dGUgdWludE5Db21wYXJpc29uKHVpbnQyNTYsdWludDI1Nilib29sCgljYWxsc3ViIHVpbnROQ29tcGFyaXNvbgoJcHVzaGJ5dGVzIDB4MDAKCXB1c2hpbnQgMAoJdW5jb3ZlciAyCglzZXRiaXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gdWludE5Db21wYXJpc29uKHg6IHVpbnQyNTYsIHk6IHVpbnQyNTYpOiBib29sZWFuCnVpbnROQ29tcGFyaXNvbjoKCXByb3RvIDIgMQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjU5CgkvLyByZXR1cm4geCA+PSB5OwoJZnJhbWVfZGlnIC0xIC8vIHg6IHVpbnQyNTYKCWZyYW1lX2RpZyAtMiAvLyB5OiB1aW50MjU2CgliPj0KCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YmIwODkwNjEgLy8gbWV0aG9kICJ1aW50TkNvbXBhcmlzb24odWludDI1Nix1aW50MjU2KWJvb2wiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3VpbnROQ29tcGFyaXNvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestUintNComparison.arc56_draft.json b/tests/contracts/artifacts/ABITestUintNComparison.arc56_draft.json index 00a73efe1..3365f271a 100644 --- a/tests/contracts/artifacts/ABITestUintNComparison.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestUintNComparison.arc56_draft.json @@ -479,7 +479,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdWludE5Db21wYXJpc29uKHVpbnQyNTYsdWludDI1Nilib29sCiphYmlfcm91dGVfdWludE5Db21wYXJpc29uOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIHk6IHVpbnQyNTYKCXR4bmEgQXBwbGljYXRpb25BcmdzIDIKCWR1cAoJbGVuCglwdXNoaW50IDMyCgk9PQoKCS8vIGFyZ3VtZW50IDAgKHkpIGZvciB1aW50TkNvbXBhcmlzb24gbXVzdCBiZSBhIHVpbnQyNTYKCWFzc2VydAoKCS8vIHg6IHVpbnQyNTYKCXR4bmEgQXBwbGljYXRpb25BcmdzIDEKCWR1cAoJbGVuCglwdXNoaW50IDMyCgk9PQoKCS8vIGFyZ3VtZW50IDEgKHgpIGZvciB1aW50TkNvbXBhcmlzb24gbXVzdCBiZSBhIHVpbnQyNTYKCWFzc2VydAoKCS8vIGV4ZWN1dGUgdWludE5Db21wYXJpc29uKHVpbnQyNTYsdWludDI1Nilib29sCgljYWxsc3ViIHVpbnROQ29tcGFyaXNvbgoJcHVzaGJ5dGVzIDB4MDAKCXB1c2hpbnQgMAoJdW5jb3ZlciAyCglzZXRiaXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gdWludE5Db21wYXJpc29uKHg6IHVpbnQyNTYsIHk6IHVpbnQyNTYpOiBib29sZWFuCnVpbnROQ29tcGFyaXNvbjoKCXByb3RvIDIgMQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjU5CgkvLyByZXR1cm4geCA+PSB5OwoJZnJhbWVfZGlnIC0xIC8vIHg6IHVpbnQyNTYKCWZyYW1lX2RpZyAtMiAvLyB5OiB1aW50MjU2CgliPj0KCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YmIwODkwNjEgLy8gbWV0aG9kICJ1aW50TkNvbXBhcmlzb24odWludDI1Nix1aW50MjU2KWJvb2wiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3VpbnROQ29tcGFyaXNvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdWludE5Db21wYXJpc29uKHVpbnQyNTYsdWludDI1Nilib29sCiphYmlfcm91dGVfdWludE5Db21wYXJpc29uOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIHk6IHVpbnQyNTYKCXR4bmEgQXBwbGljYXRpb25BcmdzIDIKCWR1cAoJbGVuCglwdXNoaW50IDMyCgk9PQoKCS8vIGFyZ3VtZW50IDAgKHkpIGZvciB1aW50TkNvbXBhcmlzb24gbXVzdCBiZSBhIHVpbnQyNTYKCWFzc2VydAoKCS8vIHg6IHVpbnQyNTYKCXR4bmEgQXBwbGljYXRpb25BcmdzIDEKCWR1cAoJbGVuCglwdXNoaW50IDMyCgk9PQoKCS8vIGFyZ3VtZW50IDEgKHgpIGZvciB1aW50TkNvbXBhcmlzb24gbXVzdCBiZSBhIHVpbnQyNTYKCWFzc2VydAoKCS8vIGV4ZWN1dGUgdWludE5Db21wYXJpc29uKHVpbnQyNTYsdWludDI1Nilib29sCgljYWxsc3ViIHVpbnROQ29tcGFyaXNvbgoJcHVzaGJ5dGVzIDB4MDAKCXB1c2hpbnQgMAoJdW5jb3ZlciAyCglzZXRiaXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gdWludE5Db21wYXJpc29uKHg6IHVpbnQyNTYsIHk6IHVpbnQyNTYpOiBib29sZWFuCnVpbnROQ29tcGFyaXNvbjoKCXByb3RvIDIgMQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjU5CgkvLyByZXR1cm4geCA+PSB5OwoJZnJhbWVfZGlnIC0xIC8vIHg6IHVpbnQyNTYKCWZyYW1lX2RpZyAtMiAvLyB5OiB1aW50MjU2CgliPj0KCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4YmIwODkwNjEgLy8gbWV0aG9kICJ1aW50TkNvbXBhcmlzb24odWludDI1Nix1aW50MjU2KWJvb2wiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3VpbnROQ29tcGFyaXNvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestUpdateArrayRefInBoxStorage.approval.teal b/tests/contracts/artifacts/ABITestUpdateArrayRefInBoxStorage.approval.teal index 3862e6dcb..db16bd49c 100644 --- a/tests/contracts/artifacts/ABITestUpdateArrayRefInBoxStorage.approval.teal +++ b/tests/contracts/artifacts/ABITestUpdateArrayRefInBoxStorage.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestUpdateArrayRefInBoxStorage.arc32.json b/tests/contracts/artifacts/ABITestUpdateArrayRefInBoxStorage.arc32.json index d08daac7e..bcc86e365 100644 --- a/tests/contracts/artifacts/ABITestUpdateArrayRefInBoxStorage.arc32.json +++ b/tests/contracts/artifacts/ABITestUpdateArrayRefInBoxStorage.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpOT1RfSU1QTEVNRU5URUQgKmNhbGxfT3B0SW4gKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIHVwZGF0ZUFycmF5UmVmSW5Cb3hTdG9yYWdlKCkodWludDgsdWludDY0KQoqYWJpX3JvdXRlX3VwZGF0ZUFycmF5UmVmSW5Cb3hTdG9yYWdlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgdXBkYXRlQXJyYXlSZWZJbkJveFN0b3JhZ2UoKSh1aW50OCx1aW50NjQpCgljYWxsc3ViIHVwZGF0ZUFycmF5UmVmSW5Cb3hTdG9yYWdlCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHVwZGF0ZUFycmF5UmVmSW5Cb3hTdG9yYWdlKCk6IFt1aW50PDg+LCB1aW50NjRdCnVwZGF0ZUFycmF5UmVmSW5Cb3hTdG9yYWdlOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMTA3CgkvLyB0aGlzLmJNYXAodGhpcy50eG4uc2VuZGVyKS52YWx1ZSA9IFsxLCAyXQoJdHhuIFNlbmRlcgoJcHVzaGJ5dGVzIDB4MDEwMDAwMDAwMDAwMDAwMDAyCglib3hfcHV0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjExMDkKCS8vIHYgPSB0aGlzLmJNYXAodGhpcy50eG4uc2VuZGVyKS52YWx1ZQoJdHhuIFNlbmRlcgoJZnJhbWVfYnVyeSAwIC8vIHN0b3JhZ2Uga2V5Ly92CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjExMTEKCS8vIHZbMF0gPSAzCglmcmFtZV9kaWcgMCAvLyBzdG9yYWdlIGtleS8vdgoJcHVzaGludCAwCglwdXNoYnl0ZXMgMHgwMwoJYm94X3JlcGxhY2UKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTExMwoJLy8gcmV0dXJuIHY7CglmcmFtZV9kaWcgMCAvLyBzdG9yYWdlIGtleS8vdgoJYm94X2dldAoKCS8vIGJveCB2YWx1ZSBkb2VzIG5vdCBleGlzdDogdGhpcy5iTWFwKHRoaXMudHhuLnNlbmRlcikudmFsdWUKCWFzc2VydAoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX09wdEluOgoJcHVzaGJ5dGVzIDB4OGU1ZWQ5MmYgLy8gbWV0aG9kICJ1cGRhdGVBcnJheVJlZkluQm94U3RvcmFnZSgpKHVpbnQ4LHVpbnQ2NCkiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3VwZGF0ZUFycmF5UmVmSW5Cb3hTdG9yYWdlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgT3B0SW4KCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpOT1RfSU1QTEVNRU5URUQgKmNhbGxfT3B0SW4gKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIHVwZGF0ZUFycmF5UmVmSW5Cb3hTdG9yYWdlKCkodWludDgsdWludDY0KQoqYWJpX3JvdXRlX3VwZGF0ZUFycmF5UmVmSW5Cb3hTdG9yYWdlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgdXBkYXRlQXJyYXlSZWZJbkJveFN0b3JhZ2UoKSh1aW50OCx1aW50NjQpCgljYWxsc3ViIHVwZGF0ZUFycmF5UmVmSW5Cb3hTdG9yYWdlCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHVwZGF0ZUFycmF5UmVmSW5Cb3hTdG9yYWdlKCk6IFt1aW50PDg+LCB1aW50NjRdCnVwZGF0ZUFycmF5UmVmSW5Cb3hTdG9yYWdlOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMTA3CgkvLyB0aGlzLmJNYXAodGhpcy50eG4uc2VuZGVyKS52YWx1ZSA9IFsxLCAyXQoJdHhuIFNlbmRlcgoJcHVzaGJ5dGVzIDB4MDEwMDAwMDAwMDAwMDAwMDAyCglib3hfcHV0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjExMDkKCS8vIHYgPSB0aGlzLmJNYXAodGhpcy50eG4uc2VuZGVyKS52YWx1ZQoJdHhuIFNlbmRlcgoJZnJhbWVfYnVyeSAwIC8vIHN0b3JhZ2Uga2V5Ly92CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjExMTEKCS8vIHZbMF0gPSAzCglmcmFtZV9kaWcgMCAvLyBzdG9yYWdlIGtleS8vdgoJcHVzaGludCAwCglwdXNoYnl0ZXMgMHgwMwoJYm94X3JlcGxhY2UKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTExMwoJLy8gcmV0dXJuIHY7CglmcmFtZV9kaWcgMCAvLyBzdG9yYWdlIGtleS8vdgoJYm94X2dldAoKCS8vIGJveCB2YWx1ZSBkb2VzIG5vdCBleGlzdDogdGhpcy5iTWFwKHRoaXMudHhuLnNlbmRlcikudmFsdWUKCWFzc2VydAoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX09wdEluOgoJcHVzaGJ5dGVzIDB4OGU1ZWQ5MmYgLy8gbWV0aG9kICJ1cGRhdGVBcnJheVJlZkluQm94U3RvcmFnZSgpKHVpbnQ4LHVpbnQ2NCkiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3VwZGF0ZUFycmF5UmVmSW5Cb3hTdG9yYWdlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgT3B0SW4KCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestUpdateArrayRefInBoxStorage.arc56_draft.json b/tests/contracts/artifacts/ABITestUpdateArrayRefInBoxStorage.arc56_draft.json index 3b3bd0890..b66482861 100644 --- a/tests/contracts/artifacts/ABITestUpdateArrayRefInBoxStorage.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestUpdateArrayRefInBoxStorage.arc56_draft.json @@ -447,7 +447,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpOT1RfSU1QTEVNRU5URUQgKmNhbGxfT3B0SW4gKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIHVwZGF0ZUFycmF5UmVmSW5Cb3hTdG9yYWdlKCkodWludDgsdWludDY0KQoqYWJpX3JvdXRlX3VwZGF0ZUFycmF5UmVmSW5Cb3hTdG9yYWdlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgdXBkYXRlQXJyYXlSZWZJbkJveFN0b3JhZ2UoKSh1aW50OCx1aW50NjQpCgljYWxsc3ViIHVwZGF0ZUFycmF5UmVmSW5Cb3hTdG9yYWdlCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHVwZGF0ZUFycmF5UmVmSW5Cb3hTdG9yYWdlKCk6IFt1aW50PDg+LCB1aW50NjRdCnVwZGF0ZUFycmF5UmVmSW5Cb3hTdG9yYWdlOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMTA3CgkvLyB0aGlzLmJNYXAodGhpcy50eG4uc2VuZGVyKS52YWx1ZSA9IFsxLCAyXQoJdHhuIFNlbmRlcgoJcHVzaGJ5dGVzIDB4MDEwMDAwMDAwMDAwMDAwMDAyCglib3hfcHV0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjExMDkKCS8vIHYgPSB0aGlzLmJNYXAodGhpcy50eG4uc2VuZGVyKS52YWx1ZQoJdHhuIFNlbmRlcgoJZnJhbWVfYnVyeSAwIC8vIHN0b3JhZ2Uga2V5Ly92CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjExMTEKCS8vIHZbMF0gPSAzCglmcmFtZV9kaWcgMCAvLyBzdG9yYWdlIGtleS8vdgoJcHVzaGludCAwCglwdXNoYnl0ZXMgMHgwMwoJYm94X3JlcGxhY2UKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTExMwoJLy8gcmV0dXJuIHY7CglmcmFtZV9kaWcgMCAvLyBzdG9yYWdlIGtleS8vdgoJYm94X2dldAoKCS8vIGJveCB2YWx1ZSBkb2VzIG5vdCBleGlzdDogdGhpcy5iTWFwKHRoaXMudHhuLnNlbmRlcikudmFsdWUKCWFzc2VydAoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX09wdEluOgoJcHVzaGJ5dGVzIDB4OGU1ZWQ5MmYgLy8gbWV0aG9kICJ1cGRhdGVBcnJheVJlZkluQm94U3RvcmFnZSgpKHVpbnQ4LHVpbnQ2NCkiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3VwZGF0ZUFycmF5UmVmSW5Cb3hTdG9yYWdlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgT3B0SW4KCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpOT1RfSU1QTEVNRU5URUQgKmNhbGxfT3B0SW4gKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIHVwZGF0ZUFycmF5UmVmSW5Cb3hTdG9yYWdlKCkodWludDgsdWludDY0KQoqYWJpX3JvdXRlX3VwZGF0ZUFycmF5UmVmSW5Cb3hTdG9yYWdlOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgdXBkYXRlQXJyYXlSZWZJbkJveFN0b3JhZ2UoKSh1aW50OCx1aW50NjQpCgljYWxsc3ViIHVwZGF0ZUFycmF5UmVmSW5Cb3hTdG9yYWdlCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHVwZGF0ZUFycmF5UmVmSW5Cb3hTdG9yYWdlKCk6IFt1aW50PDg+LCB1aW50NjRdCnVwZGF0ZUFycmF5UmVmSW5Cb3hTdG9yYWdlOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCXB1c2hieXRlcyAweAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMTA3CgkvLyB0aGlzLmJNYXAodGhpcy50eG4uc2VuZGVyKS52YWx1ZSA9IFsxLCAyXQoJdHhuIFNlbmRlcgoJcHVzaGJ5dGVzIDB4MDEwMDAwMDAwMDAwMDAwMDAyCglib3hfcHV0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjExMDkKCS8vIHYgPSB0aGlzLmJNYXAodGhpcy50eG4uc2VuZGVyKS52YWx1ZQoJdHhuIFNlbmRlcgoJZnJhbWVfYnVyeSAwIC8vIHN0b3JhZ2Uga2V5Ly92CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjExMTEKCS8vIHZbMF0gPSAzCglmcmFtZV9kaWcgMCAvLyBzdG9yYWdlIGtleS8vdgoJcHVzaGludCAwCglwdXNoYnl0ZXMgMHgwMwoJYm94X3JlcGxhY2UKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTExMwoJLy8gcmV0dXJuIHY7CglmcmFtZV9kaWcgMCAvLyBzdG9yYWdlIGtleS8vdgoJYm94X2dldAoKCS8vIGJveCB2YWx1ZSBkb2VzIG5vdCBleGlzdDogdGhpcy5iTWFwKHRoaXMudHhuLnNlbmRlcikudmFsdWUKCWFzc2VydAoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX09wdEluOgoJcHVzaGJ5dGVzIDB4OGU1ZWQ5MmYgLy8gbWV0aG9kICJ1cGRhdGVBcnJheVJlZkluQm94U3RvcmFnZSgpKHVpbnQ4LHVpbnQ2NCkiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3VwZGF0ZUFycmF5UmVmSW5Cb3hTdG9yYWdlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgT3B0SW4KCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestUpdateDynamicArrayElement.approval.teal b/tests/contracts/artifacts/ABITestUpdateDynamicArrayElement.approval.teal index ad7d9148b..5da83da53 100644 --- a/tests/contracts/artifacts/ABITestUpdateDynamicArrayElement.approval.teal +++ b/tests/contracts/artifacts/ABITestUpdateDynamicArrayElement.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestUpdateDynamicArrayElement.arc32.json b/tests/contracts/artifacts/ABITestUpdateDynamicArrayElement.arc32.json index c1d9029cb..5521065b9 100644 --- a/tests/contracts/artifacts/ABITestUpdateDynamicArrayElement.arc32.json +++ b/tests/contracts/artifacts/ABITestUpdateDynamicArrayElement.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdXBkYXRlRHluYW1pY0FycmF5RWxlbWVudCgpdWludDY0CiphYmlfcm91dGVfdXBkYXRlRHluYW1pY0FycmF5RWxlbWVudDoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHVwZGF0ZUR5bmFtaWNBcnJheUVsZW1lbnQoKXVpbnQ2NAoJY2FsbHN1YiB1cGRhdGVEeW5hbWljQXJyYXlFbGVtZW50CglpdG9iCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHVwZGF0ZUR5bmFtaWNBcnJheUVsZW1lbnQoKTogdWludDY0CnVwZGF0ZUR5bmFtaWNBcnJheUVsZW1lbnQ6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjM2OQoJLy8gYTogdWludDY0W10gPSBbMTEsIDIyLCAzM10KCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMGIwMDAwMDAwMDAwMDAwMDE2MDAwMDAwMDAwMDAwMDAyMQoJZnJhbWVfYnVyeSAwIC8vIGE6IHVpbnQ2NFtdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjM3MQoJLy8gYVsxXSA9IDIyMgoJZnJhbWVfZGlnIDAgLy8gYTogdWludDY0W10KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMGRlCglyZXBsYWNlMiA4CglmcmFtZV9idXJ5IDAgLy8gYTogdWludDY0W10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MzczCgkvLyByZXR1cm4gYVsxXTsKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQ2NFtdCglzdG9yZSAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJZXh0cmFjdCA4IDgKCWJ0b2kKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4NDkxYTE1M2QgLy8gbWV0aG9kICJ1cGRhdGVEeW5hbWljQXJyYXlFbGVtZW50KCl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3VwZGF0ZUR5bmFtaWNBcnJheUVsZW1lbnQKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdXBkYXRlRHluYW1pY0FycmF5RWxlbWVudCgpdWludDY0CiphYmlfcm91dGVfdXBkYXRlRHluYW1pY0FycmF5RWxlbWVudDoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHVwZGF0ZUR5bmFtaWNBcnJheUVsZW1lbnQoKXVpbnQ2NAoJY2FsbHN1YiB1cGRhdGVEeW5hbWljQXJyYXlFbGVtZW50CglpdG9iCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHVwZGF0ZUR5bmFtaWNBcnJheUVsZW1lbnQoKTogdWludDY0CnVwZGF0ZUR5bmFtaWNBcnJheUVsZW1lbnQ6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjM2OQoJLy8gYTogdWludDY0W10gPSBbMTEsIDIyLCAzM10KCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMGIwMDAwMDAwMDAwMDAwMDE2MDAwMDAwMDAwMDAwMDAyMQoJZnJhbWVfYnVyeSAwIC8vIGE6IHVpbnQ2NFtdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjM3MQoJLy8gYVsxXSA9IDIyMgoJZnJhbWVfZGlnIDAgLy8gYTogdWludDY0W10KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMGRlCglyZXBsYWNlMiA4CglmcmFtZV9idXJ5IDAgLy8gYTogdWludDY0W10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MzczCgkvLyByZXR1cm4gYVsxXTsKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQ2NFtdCglzdG9yZSAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJZXh0cmFjdCA4IDgKCWJ0b2kKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4NDkxYTE1M2QgLy8gbWV0aG9kICJ1cGRhdGVEeW5hbWljQXJyYXlFbGVtZW50KCl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3VwZGF0ZUR5bmFtaWNBcnJheUVsZW1lbnQKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestUpdateDynamicArrayElement.arc56_draft.json b/tests/contracts/artifacts/ABITestUpdateDynamicArrayElement.arc56_draft.json index 5379ae178..bfe427171 100644 --- a/tests/contracts/artifacts/ABITestUpdateDynamicArrayElement.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestUpdateDynamicArrayElement.arc56_draft.json @@ -482,7 +482,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdXBkYXRlRHluYW1pY0FycmF5RWxlbWVudCgpdWludDY0CiphYmlfcm91dGVfdXBkYXRlRHluYW1pY0FycmF5RWxlbWVudDoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHVwZGF0ZUR5bmFtaWNBcnJheUVsZW1lbnQoKXVpbnQ2NAoJY2FsbHN1YiB1cGRhdGVEeW5hbWljQXJyYXlFbGVtZW50CglpdG9iCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHVwZGF0ZUR5bmFtaWNBcnJheUVsZW1lbnQoKTogdWludDY0CnVwZGF0ZUR5bmFtaWNBcnJheUVsZW1lbnQ6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjM2OQoJLy8gYTogdWludDY0W10gPSBbMTEsIDIyLCAzM10KCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMGIwMDAwMDAwMDAwMDAwMDE2MDAwMDAwMDAwMDAwMDAyMQoJZnJhbWVfYnVyeSAwIC8vIGE6IHVpbnQ2NFtdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjM3MQoJLy8gYVsxXSA9IDIyMgoJZnJhbWVfZGlnIDAgLy8gYTogdWludDY0W10KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMGRlCglyZXBsYWNlMiA4CglmcmFtZV9idXJ5IDAgLy8gYTogdWludDY0W10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MzczCgkvLyByZXR1cm4gYVsxXTsKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQ2NFtdCglzdG9yZSAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJZXh0cmFjdCA4IDgKCWJ0b2kKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4NDkxYTE1M2QgLy8gbWV0aG9kICJ1cGRhdGVEeW5hbWljQXJyYXlFbGVtZW50KCl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3VwZGF0ZUR5bmFtaWNBcnJheUVsZW1lbnQKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdXBkYXRlRHluYW1pY0FycmF5RWxlbWVudCgpdWludDY0CiphYmlfcm91dGVfdXBkYXRlRHluYW1pY0FycmF5RWxlbWVudDoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHVwZGF0ZUR5bmFtaWNBcnJheUVsZW1lbnQoKXVpbnQ2NAoJY2FsbHN1YiB1cGRhdGVEeW5hbWljQXJyYXlFbGVtZW50CglpdG9iCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHVwZGF0ZUR5bmFtaWNBcnJheUVsZW1lbnQoKTogdWludDY0CnVwZGF0ZUR5bmFtaWNBcnJheUVsZW1lbnQ6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjM2OQoJLy8gYTogdWludDY0W10gPSBbMTEsIDIyLCAzM10KCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMGIwMDAwMDAwMDAwMDAwMDE2MDAwMDAwMDAwMDAwMDAyMQoJZnJhbWVfYnVyeSAwIC8vIGE6IHVpbnQ2NFtdCgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjM3MQoJLy8gYVsxXSA9IDIyMgoJZnJhbWVfZGlnIDAgLy8gYTogdWludDY0W10KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMGRlCglyZXBsYWNlMiA4CglmcmFtZV9idXJ5IDAgLy8gYTogdWludDY0W10KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MzczCgkvLyByZXR1cm4gYVsxXTsKCWZyYW1lX2RpZyAwIC8vIGE6IHVpbnQ2NFtdCglzdG9yZSAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJZXh0cmFjdCA4IDgKCWJ0b2kKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4NDkxYTE1M2QgLy8gbWV0aG9kICJ1cGRhdGVEeW5hbWljQXJyYXlFbGVtZW50KCl1aW50NjQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3VwZGF0ZUR5bmFtaWNBcnJheUVsZW1lbnQKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestUpdateDynamicArrayInMiddleOfTuple.approval.teal b/tests/contracts/artifacts/ABITestUpdateDynamicArrayInMiddleOfTuple.approval.teal index 1d00e470d..008a60549 100644 --- a/tests/contracts/artifacts/ABITestUpdateDynamicArrayInMiddleOfTuple.approval.teal +++ b/tests/contracts/artifacts/ABITestUpdateDynamicArrayInMiddleOfTuple.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x00020405 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestUpdateDynamicArrayInMiddleOfTuple.arc32.json b/tests/contracts/artifacts/ABITestUpdateDynamicArrayInMiddleOfTuple.arc32.json index d8bf81c30..00506cd44 100644 --- a/tests/contracts/artifacts/ABITestUpdateDynamicArrayInMiddleOfTuple.arc32.json +++ b/tests/contracts/artifacts/ABITestUpdateDynamicArrayInMiddleOfTuple.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgwMDAyMDQwNSAweAoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDQuMQovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIHVwZGF0ZUR5bmFtaWNBcnJheUluTWlkZGxlT2ZUdXBsZSgpKHVpbnQxNix1aW50OFtdLHVpbnQxNikKKmFiaV9yb3V0ZV91cGRhdGVEeW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSB1cGRhdGVEeW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGUoKSh1aW50MTYsdWludDhbXSx1aW50MTYpCgljYWxsc3ViIHVwZGF0ZUR5bmFtaWNBcnJheUluTWlkZGxlT2ZUdXBsZQoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyB1cGRhdGVEeW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGUoKTogW3VpbnQxNiwgdWludDw4PltdLCB1aW50MTZdCnVwZGF0ZUR5bmFtaWNBcnJheUluTWlkZGxlT2ZUdXBsZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjY4MgoJLy8gYTogW3VpbnQxNiwgdWludDw4PltdLCB1aW50MTZdID0gWzEsIFsyXSwgM10KCWJ5dGUgMHggLy8gaW5pdGlhbCBoZWFkCglieXRlIDB4IC8vIGluaXRpYWwgdGFpbAoJcHVzaGJ5dGVzIDB4MDAwNiAvLyBpbml0aWFsIGhlYWQgb2Zmc2V0CglwdXNoYnl0ZXMgMHgwMDAxCgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAxMDIKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAzCgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50Cglwb3AgLy8gcG9wIGhlYWQgb2Zmc2V0Cgljb25jYXQgLy8gY29uY2F0IGhlYWQgYW5kIHRhaWwKCWZyYW1lX2J1cnkgMCAvLyBhOiBbdWludDE2LCB1aW50PDg+W10sIHVpbnQxNl0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6Njg0CgkvLyBhWzFdID0gWzQsIDVdCglmcmFtZV9kaWcgMCAvLyBhOiBbdWludDE2LCB1aW50PDg+W10sIHVpbnQxNl0KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoaW50IDIKCWR1cAoJc3RvcmUgMjUxIC8vIGVsZW1lbnQgaGVhZCBvZmZzZXQKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXVuY292ZXIgMgoJZXh0cmFjdF91aW50MTYKCWR1cAoJc3RvcmUgMjU0IC8vIGVsZW1lbnQgc3RhcnQKCWR1cCAvLyBkdXBsaWNhdGUgc3RhcnQgb2YgZWxlbWVudAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJc3dhcAoJZXh0cmFjdF91aW50MTYgLy8gZ2V0IG51bWJlciBvZiBlbGVtZW50cwoJcHVzaGludCAxIC8vIGdldCB0eXBlIGxlbmd0aAoJKiAvLyBtdWx0aXBseSBieSB0eXBlIGxlbmd0aAoJcHVzaGludCAyCgkrIC8vIGFkZCB0d28gZm9yIGxlbmd0aAoJc3RvcmUgMjUzIC8vIGVsZW1lbnQgbGVuZ3RoCglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoaW50IDAKCWxvYWQgMjU0IC8vIGVsZW1lbnQgc3RhcnQKCXN1YnN0cmluZzMKCWJ5dGUgMHgwMDAyMDQwNQoJZHVwCglzdG9yZSAyNTIgLy8gbmV3IGVsZW1lbnQKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU0IC8vIGVsZW1lbnQgc3RhcnQKCWxvYWQgMjUzIC8vIGVsZW1lbnQgbGVuZ3RoCgkrIC8vIGdldCBlbmQgb2YgRWxlbWVudAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJbGVuCglzdWJzdHJpbmczCgljb25jYXQKCWNvbmNhdAoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWNhbGxzdWIgKmdldF9sZW5ndGhfZGlmZmVyZW5jZQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJZnJhbWVfYnVyeSAwIC8vIGE6IFt1aW50MTYsIHVpbnQ8OD5bXSwgdWludDE2XQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo2ODYKCS8vIHJldHVybiBhOwoJZnJhbWVfZGlnIDAgLy8gYTogW3VpbnQxNiwgdWludDw4PltdLCB1aW50MTZdCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDljZGVjZGM4IC8vIG1ldGhvZCAidXBkYXRlRHluYW1pY0FycmF5SW5NaWRkbGVPZlR1cGxlKCkodWludDE2LHVpbnQ4W10sdWludDE2KSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfdXBkYXRlRHluYW1pY0FycmF5SW5NaWRkbGVPZlR1cGxlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJyCgoqcHJvY2Vzc19zdGF0aWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50Cgljb25jYXQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCXJldHN1YgoKKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50OgoJcHJvdG8gNCAzCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0Cgljb25jYXQKCWZyYW1lX2J1cnkgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0xIC8vIGVsZW1lbnQKCWR1cAoJbGVuCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCWJ0b2kKCSsKCWl0b2IKCWV4dHJhY3QgNiAyCglmcmFtZV9idXJ5IC0yIC8vIGhlYWQgb2Zmc2V0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJc3dhcAoJY29uY2F0CglmcmFtZV9idXJ5IC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWIKCipnZXRfbGVuZ3RoX2RpZmZlcmVuY2U6Cglsb2FkIDI1MiAvLyBuZXcgZWxlbWVudAoJbGVuIC8vIGxlbmd0aCBvZiBuZXcgZWxlbWVudAoJbG9hZCAyNTMgLy8gZWxlbWVudCBsZW5ndGgKCTwKCWJueiAqc3dhcHBlZF9kaWZmZXJlbmNlCglsb2FkIDI1MiAvLyBuZXcgZWxlbWVudAoJbGVuIC8vIGxlbmd0aCBvZiBuZXcgZWxlbWVudAoJbG9hZCAyNTMgLy8gZWxlbWVudCBsZW5ndGgKCXB1c2hpbnQgMQoJc3RvcmUgMjQ5IC8vIHN1YnRyYWN0IGhlYWQgZGlmZmVyZW5jZQoJYiAqZ2V0X2RpZmZlcmVuY2UKCipzd2FwcGVkX2RpZmZlcmVuY2U6Cglsb2FkIDI1MyAvLyBlbGVtZW50IGxlbmd0aAoJbG9hZCAyNTIgLy8gbmV3IGVsZW1lbnQKCWxlbiAvLyBsZW5ndGggb2YgbmV3IGVsZW1lbnQKCXB1c2hpbnQgMAoJc3RvcmUgMjQ5IC8vIHN1YnRyYWN0IGhlYWQgZGlmZmVyZW5jZQoKKmdldF9kaWZmZXJlbmNlOgoJLSAvLyBnZXQgbGVuZ3RoIGRpZmZlcmVuY2UKCXN0b3JlIDI1MCAvLyBsZW5ndGggZGlmZmVyZW5jZQoJcmV0c3Vi", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgwMDAyMDQwNSAweAoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDUuMAovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIHVwZGF0ZUR5bmFtaWNBcnJheUluTWlkZGxlT2ZUdXBsZSgpKHVpbnQxNix1aW50OFtdLHVpbnQxNikKKmFiaV9yb3V0ZV91cGRhdGVEeW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSB1cGRhdGVEeW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGUoKSh1aW50MTYsdWludDhbXSx1aW50MTYpCgljYWxsc3ViIHVwZGF0ZUR5bmFtaWNBcnJheUluTWlkZGxlT2ZUdXBsZQoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyB1cGRhdGVEeW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGUoKTogW3VpbnQxNiwgdWludDw4PltdLCB1aW50MTZdCnVwZGF0ZUR5bmFtaWNBcnJheUluTWlkZGxlT2ZUdXBsZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjY4MgoJLy8gYTogW3VpbnQxNiwgdWludDw4PltdLCB1aW50MTZdID0gWzEsIFsyXSwgM10KCWJ5dGUgMHggLy8gaW5pdGlhbCBoZWFkCglieXRlIDB4IC8vIGluaXRpYWwgdGFpbAoJcHVzaGJ5dGVzIDB4MDAwNiAvLyBpbml0aWFsIGhlYWQgb2Zmc2V0CglwdXNoYnl0ZXMgMHgwMDAxCgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAxMDIKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAzCgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50Cglwb3AgLy8gcG9wIGhlYWQgb2Zmc2V0Cgljb25jYXQgLy8gY29uY2F0IGhlYWQgYW5kIHRhaWwKCWZyYW1lX2J1cnkgMCAvLyBhOiBbdWludDE2LCB1aW50PDg+W10sIHVpbnQxNl0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6Njg0CgkvLyBhWzFdID0gWzQsIDVdCglmcmFtZV9kaWcgMCAvLyBhOiBbdWludDE2LCB1aW50PDg+W10sIHVpbnQxNl0KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoaW50IDIKCWR1cAoJc3RvcmUgMjUxIC8vIGVsZW1lbnQgaGVhZCBvZmZzZXQKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXVuY292ZXIgMgoJZXh0cmFjdF91aW50MTYKCWR1cAoJc3RvcmUgMjU0IC8vIGVsZW1lbnQgc3RhcnQKCWR1cCAvLyBkdXBsaWNhdGUgc3RhcnQgb2YgZWxlbWVudAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJc3dhcAoJZXh0cmFjdF91aW50MTYgLy8gZ2V0IG51bWJlciBvZiBlbGVtZW50cwoJcHVzaGludCAxIC8vIGdldCB0eXBlIGxlbmd0aAoJKiAvLyBtdWx0aXBseSBieSB0eXBlIGxlbmd0aAoJcHVzaGludCAyCgkrIC8vIGFkZCB0d28gZm9yIGxlbmd0aAoJc3RvcmUgMjUzIC8vIGVsZW1lbnQgbGVuZ3RoCglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoaW50IDAKCWxvYWQgMjU0IC8vIGVsZW1lbnQgc3RhcnQKCXN1YnN0cmluZzMKCWJ5dGUgMHgwMDAyMDQwNQoJZHVwCglzdG9yZSAyNTIgLy8gbmV3IGVsZW1lbnQKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU0IC8vIGVsZW1lbnQgc3RhcnQKCWxvYWQgMjUzIC8vIGVsZW1lbnQgbGVuZ3RoCgkrIC8vIGdldCBlbmQgb2YgRWxlbWVudAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJbGVuCglzdWJzdHJpbmczCgljb25jYXQKCWNvbmNhdAoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWNhbGxzdWIgKmdldF9sZW5ndGhfZGlmZmVyZW5jZQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJZnJhbWVfYnVyeSAwIC8vIGE6IFt1aW50MTYsIHVpbnQ8OD5bXSwgdWludDE2XQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo2ODYKCS8vIHJldHVybiBhOwoJZnJhbWVfZGlnIDAgLy8gYTogW3VpbnQxNiwgdWludDw4PltdLCB1aW50MTZdCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDljZGVjZGM4IC8vIG1ldGhvZCAidXBkYXRlRHluYW1pY0FycmF5SW5NaWRkbGVPZlR1cGxlKCkodWludDE2LHVpbnQ4W10sdWludDE2KSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfdXBkYXRlRHluYW1pY0FycmF5SW5NaWRkbGVPZlR1cGxlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJyCgoqcHJvY2Vzc19zdGF0aWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50Cgljb25jYXQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCXJldHN1YgoKKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50OgoJcHJvdG8gNCAzCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0Cgljb25jYXQKCWZyYW1lX2J1cnkgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0xIC8vIGVsZW1lbnQKCWR1cAoJbGVuCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCWJ0b2kKCSsKCWl0b2IKCWV4dHJhY3QgNiAyCglmcmFtZV9idXJ5IC0yIC8vIGhlYWQgb2Zmc2V0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJc3dhcAoJY29uY2F0CglmcmFtZV9idXJ5IC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWIKCipnZXRfbGVuZ3RoX2RpZmZlcmVuY2U6Cglsb2FkIDI1MiAvLyBuZXcgZWxlbWVudAoJbGVuIC8vIGxlbmd0aCBvZiBuZXcgZWxlbWVudAoJbG9hZCAyNTMgLy8gZWxlbWVudCBsZW5ndGgKCTwKCWJueiAqc3dhcHBlZF9kaWZmZXJlbmNlCglsb2FkIDI1MiAvLyBuZXcgZWxlbWVudAoJbGVuIC8vIGxlbmd0aCBvZiBuZXcgZWxlbWVudAoJbG9hZCAyNTMgLy8gZWxlbWVudCBsZW5ndGgKCXB1c2hpbnQgMQoJc3RvcmUgMjQ5IC8vIHN1YnRyYWN0IGhlYWQgZGlmZmVyZW5jZQoJYiAqZ2V0X2RpZmZlcmVuY2UKCipzd2FwcGVkX2RpZmZlcmVuY2U6Cglsb2FkIDI1MyAvLyBlbGVtZW50IGxlbmd0aAoJbG9hZCAyNTIgLy8gbmV3IGVsZW1lbnQKCWxlbiAvLyBsZW5ndGggb2YgbmV3IGVsZW1lbnQKCXB1c2hpbnQgMAoJc3RvcmUgMjQ5IC8vIHN1YnRyYWN0IGhlYWQgZGlmZmVyZW5jZQoKKmdldF9kaWZmZXJlbmNlOgoJLSAvLyBnZXQgbGVuZ3RoIGRpZmZlcmVuY2UKCXN0b3JlIDI1MCAvLyBsZW5ndGggZGlmZmVyZW5jZQoJcmV0c3Vi", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestUpdateDynamicArrayInMiddleOfTuple.arc56_draft.json b/tests/contracts/artifacts/ABITestUpdateDynamicArrayInMiddleOfTuple.arc56_draft.json index 14319b000..3b349e194 100644 --- a/tests/contracts/artifacts/ABITestUpdateDynamicArrayInMiddleOfTuple.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestUpdateDynamicArrayInMiddleOfTuple.arc56_draft.json @@ -1149,7 +1149,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgwMDAyMDQwNSAweAoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDQuMQovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIHVwZGF0ZUR5bmFtaWNBcnJheUluTWlkZGxlT2ZUdXBsZSgpKHVpbnQxNix1aW50OFtdLHVpbnQxNikKKmFiaV9yb3V0ZV91cGRhdGVEeW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSB1cGRhdGVEeW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGUoKSh1aW50MTYsdWludDhbXSx1aW50MTYpCgljYWxsc3ViIHVwZGF0ZUR5bmFtaWNBcnJheUluTWlkZGxlT2ZUdXBsZQoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyB1cGRhdGVEeW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGUoKTogW3VpbnQxNiwgdWludDw4PltdLCB1aW50MTZdCnVwZGF0ZUR5bmFtaWNBcnJheUluTWlkZGxlT2ZUdXBsZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjY4MgoJLy8gYTogW3VpbnQxNiwgdWludDw4PltdLCB1aW50MTZdID0gWzEsIFsyXSwgM10KCWJ5dGUgMHggLy8gaW5pdGlhbCBoZWFkCglieXRlIDB4IC8vIGluaXRpYWwgdGFpbAoJcHVzaGJ5dGVzIDB4MDAwNiAvLyBpbml0aWFsIGhlYWQgb2Zmc2V0CglwdXNoYnl0ZXMgMHgwMDAxCgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAxMDIKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAzCgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50Cglwb3AgLy8gcG9wIGhlYWQgb2Zmc2V0Cgljb25jYXQgLy8gY29uY2F0IGhlYWQgYW5kIHRhaWwKCWZyYW1lX2J1cnkgMCAvLyBhOiBbdWludDE2LCB1aW50PDg+W10sIHVpbnQxNl0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6Njg0CgkvLyBhWzFdID0gWzQsIDVdCglmcmFtZV9kaWcgMCAvLyBhOiBbdWludDE2LCB1aW50PDg+W10sIHVpbnQxNl0KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoaW50IDIKCWR1cAoJc3RvcmUgMjUxIC8vIGVsZW1lbnQgaGVhZCBvZmZzZXQKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXVuY292ZXIgMgoJZXh0cmFjdF91aW50MTYKCWR1cAoJc3RvcmUgMjU0IC8vIGVsZW1lbnQgc3RhcnQKCWR1cCAvLyBkdXBsaWNhdGUgc3RhcnQgb2YgZWxlbWVudAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJc3dhcAoJZXh0cmFjdF91aW50MTYgLy8gZ2V0IG51bWJlciBvZiBlbGVtZW50cwoJcHVzaGludCAxIC8vIGdldCB0eXBlIGxlbmd0aAoJKiAvLyBtdWx0aXBseSBieSB0eXBlIGxlbmd0aAoJcHVzaGludCAyCgkrIC8vIGFkZCB0d28gZm9yIGxlbmd0aAoJc3RvcmUgMjUzIC8vIGVsZW1lbnQgbGVuZ3RoCglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoaW50IDAKCWxvYWQgMjU0IC8vIGVsZW1lbnQgc3RhcnQKCXN1YnN0cmluZzMKCWJ5dGUgMHgwMDAyMDQwNQoJZHVwCglzdG9yZSAyNTIgLy8gbmV3IGVsZW1lbnQKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU0IC8vIGVsZW1lbnQgc3RhcnQKCWxvYWQgMjUzIC8vIGVsZW1lbnQgbGVuZ3RoCgkrIC8vIGdldCBlbmQgb2YgRWxlbWVudAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJbGVuCglzdWJzdHJpbmczCgljb25jYXQKCWNvbmNhdAoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWNhbGxzdWIgKmdldF9sZW5ndGhfZGlmZmVyZW5jZQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJZnJhbWVfYnVyeSAwIC8vIGE6IFt1aW50MTYsIHVpbnQ8OD5bXSwgdWludDE2XQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo2ODYKCS8vIHJldHVybiBhOwoJZnJhbWVfZGlnIDAgLy8gYTogW3VpbnQxNiwgdWludDw4PltdLCB1aW50MTZdCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDljZGVjZGM4IC8vIG1ldGhvZCAidXBkYXRlRHluYW1pY0FycmF5SW5NaWRkbGVPZlR1cGxlKCkodWludDE2LHVpbnQ4W10sdWludDE2KSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfdXBkYXRlRHluYW1pY0FycmF5SW5NaWRkbGVPZlR1cGxlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJyCgoqcHJvY2Vzc19zdGF0aWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50Cgljb25jYXQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCXJldHN1YgoKKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50OgoJcHJvdG8gNCAzCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0Cgljb25jYXQKCWZyYW1lX2J1cnkgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0xIC8vIGVsZW1lbnQKCWR1cAoJbGVuCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCWJ0b2kKCSsKCWl0b2IKCWV4dHJhY3QgNiAyCglmcmFtZV9idXJ5IC0yIC8vIGhlYWQgb2Zmc2V0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJc3dhcAoJY29uY2F0CglmcmFtZV9idXJ5IC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWIKCipnZXRfbGVuZ3RoX2RpZmZlcmVuY2U6Cglsb2FkIDI1MiAvLyBuZXcgZWxlbWVudAoJbGVuIC8vIGxlbmd0aCBvZiBuZXcgZWxlbWVudAoJbG9hZCAyNTMgLy8gZWxlbWVudCBsZW5ndGgKCTwKCWJueiAqc3dhcHBlZF9kaWZmZXJlbmNlCglsb2FkIDI1MiAvLyBuZXcgZWxlbWVudAoJbGVuIC8vIGxlbmd0aCBvZiBuZXcgZWxlbWVudAoJbG9hZCAyNTMgLy8gZWxlbWVudCBsZW5ndGgKCXB1c2hpbnQgMQoJc3RvcmUgMjQ5IC8vIHN1YnRyYWN0IGhlYWQgZGlmZmVyZW5jZQoJYiAqZ2V0X2RpZmZlcmVuY2UKCipzd2FwcGVkX2RpZmZlcmVuY2U6Cglsb2FkIDI1MyAvLyBlbGVtZW50IGxlbmd0aAoJbG9hZCAyNTIgLy8gbmV3IGVsZW1lbnQKCWxlbiAvLyBsZW5ndGggb2YgbmV3IGVsZW1lbnQKCXB1c2hpbnQgMAoJc3RvcmUgMjQ5IC8vIHN1YnRyYWN0IGhlYWQgZGlmZmVyZW5jZQoKKmdldF9kaWZmZXJlbmNlOgoJLSAvLyBnZXQgbGVuZ3RoIGRpZmZlcmVuY2UKCXN0b3JlIDI1MCAvLyBsZW5ndGggZGlmZmVyZW5jZQoJcmV0c3Vi", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgwMDAyMDQwNSAweAoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDUuMAovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIHVwZGF0ZUR5bmFtaWNBcnJheUluTWlkZGxlT2ZUdXBsZSgpKHVpbnQxNix1aW50OFtdLHVpbnQxNikKKmFiaV9yb3V0ZV91cGRhdGVEeW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSB1cGRhdGVEeW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGUoKSh1aW50MTYsdWludDhbXSx1aW50MTYpCgljYWxsc3ViIHVwZGF0ZUR5bmFtaWNBcnJheUluTWlkZGxlT2ZUdXBsZQoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyB1cGRhdGVEeW5hbWljQXJyYXlJbk1pZGRsZU9mVHVwbGUoKTogW3VpbnQxNiwgdWludDw4PltdLCB1aW50MTZdCnVwZGF0ZUR5bmFtaWNBcnJheUluTWlkZGxlT2ZUdXBsZToKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjY4MgoJLy8gYTogW3VpbnQxNiwgdWludDw4PltdLCB1aW50MTZdID0gWzEsIFsyXSwgM10KCWJ5dGUgMHggLy8gaW5pdGlhbCBoZWFkCglieXRlIDB4IC8vIGluaXRpYWwgdGFpbAoJcHVzaGJ5dGVzIDB4MDAwNiAvLyBpbml0aWFsIGhlYWQgb2Zmc2V0CglwdXNoYnl0ZXMgMHgwMDAxCgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAxMDIKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAzCgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50Cglwb3AgLy8gcG9wIGhlYWQgb2Zmc2V0Cgljb25jYXQgLy8gY29uY2F0IGhlYWQgYW5kIHRhaWwKCWZyYW1lX2J1cnkgMCAvLyBhOiBbdWludDE2LCB1aW50PDg+W10sIHVpbnQxNl0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6Njg0CgkvLyBhWzFdID0gWzQsIDVdCglmcmFtZV9kaWcgMCAvLyBhOiBbdWludDE2LCB1aW50PDg+W10sIHVpbnQxNl0KCXN0b3JlIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoaW50IDIKCWR1cAoJc3RvcmUgMjUxIC8vIGVsZW1lbnQgaGVhZCBvZmZzZXQKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXVuY292ZXIgMgoJZXh0cmFjdF91aW50MTYKCWR1cAoJc3RvcmUgMjU0IC8vIGVsZW1lbnQgc3RhcnQKCWR1cCAvLyBkdXBsaWNhdGUgc3RhcnQgb2YgZWxlbWVudAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJc3dhcAoJZXh0cmFjdF91aW50MTYgLy8gZ2V0IG51bWJlciBvZiBlbGVtZW50cwoJcHVzaGludCAxIC8vIGdldCB0eXBlIGxlbmd0aAoJKiAvLyBtdWx0aXBseSBieSB0eXBlIGxlbmd0aAoJcHVzaGludCAyCgkrIC8vIGFkZCB0d28gZm9yIGxlbmd0aAoJc3RvcmUgMjUzIC8vIGVsZW1lbnQgbGVuZ3RoCglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglwdXNoaW50IDAKCWxvYWQgMjU0IC8vIGVsZW1lbnQgc3RhcnQKCXN1YnN0cmluZzMKCWJ5dGUgMHgwMDAyMDQwNQoJZHVwCglzdG9yZSAyNTIgLy8gbmV3IGVsZW1lbnQKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU0IC8vIGVsZW1lbnQgc3RhcnQKCWxvYWQgMjUzIC8vIGVsZW1lbnQgbGVuZ3RoCgkrIC8vIGdldCBlbmQgb2YgRWxlbWVudAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJbGVuCglzdWJzdHJpbmczCgljb25jYXQKCWNvbmNhdAoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWNhbGxzdWIgKmdldF9sZW5ndGhfZGlmZmVyZW5jZQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJZnJhbWVfYnVyeSAwIC8vIGE6IFt1aW50MTYsIHVpbnQ8OD5bXSwgdWludDE2XQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo2ODYKCS8vIHJldHVybiBhOwoJZnJhbWVfZGlnIDAgLy8gYTogW3VpbnQxNiwgdWludDw4PltdLCB1aW50MTZdCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDljZGVjZGM4IC8vIG1ldGhvZCAidXBkYXRlRHluYW1pY0FycmF5SW5NaWRkbGVPZlR1cGxlKCkodWludDE2LHVpbnQ4W10sdWludDE2KSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfdXBkYXRlRHluYW1pY0FycmF5SW5NaWRkbGVPZlR1cGxlCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJyCgoqcHJvY2Vzc19zdGF0aWNfdHVwbGVfZWxlbWVudDoKCXByb3RvIDQgMwoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMSAvLyBlbGVtZW50Cgljb25jYXQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCXJldHN1YgoKKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50OgoJcHJvdG8gNCAzCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0Cgljb25jYXQKCWZyYW1lX2J1cnkgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0xIC8vIGVsZW1lbnQKCWR1cAoJbGVuCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCWJ0b2kKCSsKCWl0b2IKCWV4dHJhY3QgNiAyCglmcmFtZV9idXJ5IC0yIC8vIGhlYWQgb2Zmc2V0CglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJc3dhcAoJY29uY2F0CglmcmFtZV9idXJ5IC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC0yIC8vIGhlYWQgb2Zmc2V0CglyZXRzdWIKCipnZXRfbGVuZ3RoX2RpZmZlcmVuY2U6Cglsb2FkIDI1MiAvLyBuZXcgZWxlbWVudAoJbGVuIC8vIGxlbmd0aCBvZiBuZXcgZWxlbWVudAoJbG9hZCAyNTMgLy8gZWxlbWVudCBsZW5ndGgKCTwKCWJueiAqc3dhcHBlZF9kaWZmZXJlbmNlCglsb2FkIDI1MiAvLyBuZXcgZWxlbWVudAoJbGVuIC8vIGxlbmd0aCBvZiBuZXcgZWxlbWVudAoJbG9hZCAyNTMgLy8gZWxlbWVudCBsZW5ndGgKCXB1c2hpbnQgMQoJc3RvcmUgMjQ5IC8vIHN1YnRyYWN0IGhlYWQgZGlmZmVyZW5jZQoJYiAqZ2V0X2RpZmZlcmVuY2UKCipzd2FwcGVkX2RpZmZlcmVuY2U6Cglsb2FkIDI1MyAvLyBlbGVtZW50IGxlbmd0aAoJbG9hZCAyNTIgLy8gbmV3IGVsZW1lbnQKCWxlbiAvLyBsZW5ndGggb2YgbmV3IGVsZW1lbnQKCXB1c2hpbnQgMAoJc3RvcmUgMjQ5IC8vIHN1YnRyYWN0IGhlYWQgZGlmZmVyZW5jZQoKKmdldF9kaWZmZXJlbmNlOgoJLSAvLyBnZXQgbGVuZ3RoIGRpZmZlcmVuY2UKCXN0b3JlIDI1MCAvLyBsZW5ndGggZGlmZmVyZW5jZQoJcmV0c3Vi", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestUpdateDynamicArrayInTuple.approval.teal b/tests/contracts/artifacts/ABITestUpdateDynamicArrayInTuple.approval.teal index 90c3cee02..cf5eefc79 100644 --- a/tests/contracts/artifacts/ABITestUpdateDynamicArrayInTuple.approval.teal +++ b/tests/contracts/artifacts/ABITestUpdateDynamicArrayInTuple.approval.teal @@ -2,7 +2,7 @@ intcblock 2 bytecblock 0x0002000a000b 0x0002000e000f 0x00020c0d 0x00021011 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestUpdateDynamicArrayInTuple.arc32.json b/tests/contracts/artifacts/ABITestUpdateDynamicArrayInTuple.arc32.json index a457b77dc..f4d6e7cd0 100644 --- a/tests/contracts/artifacts/ABITestUpdateDynamicArrayInTuple.arc32.json +++ b/tests/contracts/artifacts/ABITestUpdateDynamicArrayInTuple.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "#pragma version 10
intcblock 2
bytecblock 0x0002000a000b 0x0002000e000f 0x00020c0d 0x00021011 0x

// This TEAL was generated by TEALScript v0.104.1
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// updateDynamicArrayInTuple()(uint8,uint16[],uint8[],uint16[],uint8[])
*abi_route_updateDynamicArrayInTuple:
	// The ABI return prefix
	pushbytes 0x151f7c75

	// execute updateDynamicArrayInTuple()(uint8,uint16[],uint8[],uint16[],uint8[])
	callsub updateDynamicArrayInTuple
	concat
	log
	pushint 1
	return

// updateDynamicArrayInTuple(): [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]
updateDynamicArrayInTuple:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/abi.algo.ts:406
	// a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]] = [9, [8], [7], [6], [5]]
	byte 0x // initial head
	byte 0x // initial tail
	pushbytes 0x0009 // initial head offset
	pushbytes 0x09
	callsub *process_static_tuple_element
	pushbytes 0x00010008
	callsub *process_dynamic_tuple_element
	pushbytes 0x000107
	callsub *process_dynamic_tuple_element
	pushbytes 0x00010006
	callsub *process_dynamic_tuple_element
	pushbytes 0x000105
	callsub *process_dynamic_tuple_element
	pop // pop head offset
	concat // concat head and tail
	frame_bury 0 // a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]

	// tests/contracts/abi.algo.ts:408
	// a[0] = 99 as uint<8>
	frame_dig 0 // a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]
	store 255 // full array
	load 255 // full array
	pushbytes 0x63
	replace2 0
	frame_bury 0 // a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]

	// tests/contracts/abi.algo.ts:409
	// a[1] = [10, 11]
	frame_dig 0 // a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]
	store 255 // full array
	pushint 1
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 2 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x0002000a000b
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 250 // length difference
	load 251 // element head offset
	int 2
	+ // head ofset
	callsub *update_dynamic_head
	load 250 // length difference
	load 251 // element head offset
	pushint 4
	+ // head ofset
	callsub *update_dynamic_head
	load 250 // length difference
	load 251 // element head offset
	pushint 6
	+ // head ofset
	callsub *update_dynamic_head
	load 255 // full array
	frame_bury 0 // a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]

	// tests/contracts/abi.algo.ts:410
	// a[2] = [12, 13]
	frame_dig 0 // a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]
	store 255 // full array
	pushint 3
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	pushint 1 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x00020c0d
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 250 // length difference
	load 251 // element head offset
	int 2
	+ // head ofset
	callsub *update_dynamic_head
	load 250 // length difference
	load 251 // element head offset
	pushint 4
	+ // head ofset
	callsub *update_dynamic_head
	load 255 // full array
	frame_bury 0 // a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]

	// tests/contracts/abi.algo.ts:411
	// a[3] = [14, 15]
	frame_dig 0 // a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]
	store 255 // full array
	pushint 5
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 2 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x0002000e000f
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 250 // length difference
	load 251 // element head offset
	int 2
	+ // head ofset
	callsub *update_dynamic_head
	load 255 // full array
	frame_bury 0 // a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]

	// tests/contracts/abi.algo.ts:412
	// a[4] = [16, 17]
	frame_dig 0 // a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]
	store 255 // full array
	pushint 7
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	pushint 1 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x00021011
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 255 // full array
	frame_bury 0 // a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]

	// tests/contracts/abi.algo.ts:414
	// return a;
	frame_dig 0 // a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]

	// set the subroutine return value
	frame_bury 0
	retsub

*abi_route_createApplication:
	pushint 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0xc54460fd // method "updateDynamicArrayInTuple()(uint8,uint16[],uint8[],uint16[],uint8[])"
	txna ApplicationArgs 0
	match *abi_route_updateDynamicArrayInTuple

	// this contract does not implement the given ABI method for call NoOp
	err

*process_static_tuple_element:
	proto 4 3
	frame_dig -4 // tuple head
	frame_dig -1 // element
	concat
	frame_dig -3 // tuple tail
	frame_dig -2 // head offset
	retsub

*process_dynamic_tuple_element:
	proto 4 3
	frame_dig -4 // tuple head
	frame_dig -2 // head offset
	concat
	frame_bury -4 // tuple head
	frame_dig -1 // element
	dup
	len
	frame_dig -2 // head offset
	btoi
	+
	itob
	extract 6 2
	frame_bury -2 // head offset
	frame_dig -3 // tuple tail
	swap
	concat
	frame_bury -3 // tuple tail
	frame_dig -4 // tuple head
	frame_dig -3 // tuple tail
	frame_dig -2 // head offset
	retsub

*update_dynamic_head:
	proto 2 0
	frame_dig -2 // length difference
	load 255 // full array
	frame_dig -1 // dynamic array offset
	extract_uint16 // extract dynamic array offset
	load 249 // subtract head difference
	bz *subtract_head_difference
	+ // add difference to offset
	b *end_calc_new_head

*subtract_head_difference:
	swap
	- // subtract difference from offet

*end_calc_new_head:
	itob // convert to bytes
	extract 6 2 // convert to uint16
	load 255 // full array
	swap
	frame_dig -1 // offset
	swap
	replace3 // update offset
	store 255 // full array
	retsub

*get_length_difference:
	load 252 // new element
	len // length of new element
	load 253 // element length
	<
	bnz *swapped_difference
	load 252 // new element
	len // length of new element
	load 253 // element length
	pushint 1
	store 249 // subtract head difference
	b *get_difference

*swapped_difference:
	load 253 // element length
	load 252 // new element
	len // length of new element
	pushint 0
	store 249 // subtract head difference

*get_difference:
	- // get length difference
	store 250 // length difference
	retsub", + "approval": "#pragma version 10
intcblock 2
bytecblock 0x0002000a000b 0x0002000e000f 0x00020c0d 0x00021011 0x

// This TEAL was generated by TEALScript v0.105.0
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// updateDynamicArrayInTuple()(uint8,uint16[],uint8[],uint16[],uint8[])
*abi_route_updateDynamicArrayInTuple:
	// The ABI return prefix
	pushbytes 0x151f7c75

	// execute updateDynamicArrayInTuple()(uint8,uint16[],uint8[],uint16[],uint8[])
	callsub updateDynamicArrayInTuple
	concat
	log
	pushint 1
	return

// updateDynamicArrayInTuple(): [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]
updateDynamicArrayInTuple:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/abi.algo.ts:406
	// a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]] = [9, [8], [7], [6], [5]]
	byte 0x // initial head
	byte 0x // initial tail
	pushbytes 0x0009 // initial head offset
	pushbytes 0x09
	callsub *process_static_tuple_element
	pushbytes 0x00010008
	callsub *process_dynamic_tuple_element
	pushbytes 0x000107
	callsub *process_dynamic_tuple_element
	pushbytes 0x00010006
	callsub *process_dynamic_tuple_element
	pushbytes 0x000105
	callsub *process_dynamic_tuple_element
	pop // pop head offset
	concat // concat head and tail
	frame_bury 0 // a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]

	// tests/contracts/abi.algo.ts:408
	// a[0] = 99 as uint<8>
	frame_dig 0 // a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]
	store 255 // full array
	load 255 // full array
	pushbytes 0x63
	replace2 0
	frame_bury 0 // a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]

	// tests/contracts/abi.algo.ts:409
	// a[1] = [10, 11]
	frame_dig 0 // a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]
	store 255 // full array
	pushint 1
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 2 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x0002000a000b
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 250 // length difference
	load 251 // element head offset
	int 2
	+ // head ofset
	callsub *update_dynamic_head
	load 250 // length difference
	load 251 // element head offset
	pushint 4
	+ // head ofset
	callsub *update_dynamic_head
	load 250 // length difference
	load 251 // element head offset
	pushint 6
	+ // head ofset
	callsub *update_dynamic_head
	load 255 // full array
	frame_bury 0 // a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]

	// tests/contracts/abi.algo.ts:410
	// a[2] = [12, 13]
	frame_dig 0 // a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]
	store 255 // full array
	pushint 3
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	pushint 1 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x00020c0d
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 250 // length difference
	load 251 // element head offset
	int 2
	+ // head ofset
	callsub *update_dynamic_head
	load 250 // length difference
	load 251 // element head offset
	pushint 4
	+ // head ofset
	callsub *update_dynamic_head
	load 255 // full array
	frame_bury 0 // a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]

	// tests/contracts/abi.algo.ts:411
	// a[3] = [14, 15]
	frame_dig 0 // a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]
	store 255 // full array
	pushint 5
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 2 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x0002000e000f
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 250 // length difference
	load 251 // element head offset
	int 2
	+ // head ofset
	callsub *update_dynamic_head
	load 255 // full array
	frame_bury 0 // a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]

	// tests/contracts/abi.algo.ts:412
	// a[4] = [16, 17]
	frame_dig 0 // a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]
	store 255 // full array
	pushint 7
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	pushint 1 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x00021011
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 255 // full array
	frame_bury 0 // a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]

	// tests/contracts/abi.algo.ts:414
	// return a;
	frame_dig 0 // a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]

	// set the subroutine return value
	frame_bury 0
	retsub

*abi_route_createApplication:
	pushint 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0xc54460fd // method "updateDynamicArrayInTuple()(uint8,uint16[],uint8[],uint16[],uint8[])"
	txna ApplicationArgs 0
	match *abi_route_updateDynamicArrayInTuple

	// this contract does not implement the given ABI method for call NoOp
	err

*process_static_tuple_element:
	proto 4 3
	frame_dig -4 // tuple head
	frame_dig -1 // element
	concat
	frame_dig -3 // tuple tail
	frame_dig -2 // head offset
	retsub

*process_dynamic_tuple_element:
	proto 4 3
	frame_dig -4 // tuple head
	frame_dig -2 // head offset
	concat
	frame_bury -4 // tuple head
	frame_dig -1 // element
	dup
	len
	frame_dig -2 // head offset
	btoi
	+
	itob
	extract 6 2
	frame_bury -2 // head offset
	frame_dig -3 // tuple tail
	swap
	concat
	frame_bury -3 // tuple tail
	frame_dig -4 // tuple head
	frame_dig -3 // tuple tail
	frame_dig -2 // head offset
	retsub

*update_dynamic_head:
	proto 2 0
	frame_dig -2 // length difference
	load 255 // full array
	frame_dig -1 // dynamic array offset
	extract_uint16 // extract dynamic array offset
	load 249 // subtract head difference
	bz *subtract_head_difference
	+ // add difference to offset
	b *end_calc_new_head

*subtract_head_difference:
	swap
	- // subtract difference from offet

*end_calc_new_head:
	itob // convert to bytes
	extract 6 2 // convert to uint16
	load 255 // full array
	swap
	frame_dig -1 // offset
	swap
	replace3 // update offset
	store 255 // full array
	retsub

*get_length_difference:
	load 252 // new element
	len // length of new element
	load 253 // element length
	<
	bnz *swapped_difference
	load 252 // new element
	len // length of new element
	load 253 // element length
	pushint 1
	store 249 // subtract head difference
	b *get_difference

*swapped_difference:
	load 253 // element length
	load 252 // new element
	len // length of new element
	pushint 0
	store 249 // subtract head difference

*get_difference:
	- // get length difference
	store 250 // length difference
	retsub", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestUpdateDynamicArrayInTuple.arc56_draft.json b/tests/contracts/artifacts/ABITestUpdateDynamicArrayInTuple.arc56_draft.json index 1cf924e1e..1ea8cbd7e 100644 --- a/tests/contracts/artifacts/ABITestUpdateDynamicArrayInTuple.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestUpdateDynamicArrayInTuple.arc56_draft.json @@ -2597,7 +2597,7 @@ } }, "source": { - "approval": "#pragma version 10
intcblock 2
bytecblock 0x0002000a000b 0x0002000e000f 0x00020c0d 0x00021011 0x

// This TEAL was generated by TEALScript v0.104.1
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// updateDynamicArrayInTuple()(uint8,uint16[],uint8[],uint16[],uint8[])
*abi_route_updateDynamicArrayInTuple:
	// The ABI return prefix
	pushbytes 0x151f7c75

	// execute updateDynamicArrayInTuple()(uint8,uint16[],uint8[],uint16[],uint8[])
	callsub updateDynamicArrayInTuple
	concat
	log
	pushint 1
	return

// updateDynamicArrayInTuple(): [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]
updateDynamicArrayInTuple:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/abi.algo.ts:406
	// a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]] = [9, [8], [7], [6], [5]]
	byte 0x // initial head
	byte 0x // initial tail
	pushbytes 0x0009 // initial head offset
	pushbytes 0x09
	callsub *process_static_tuple_element
	pushbytes 0x00010008
	callsub *process_dynamic_tuple_element
	pushbytes 0x000107
	callsub *process_dynamic_tuple_element
	pushbytes 0x00010006
	callsub *process_dynamic_tuple_element
	pushbytes 0x000105
	callsub *process_dynamic_tuple_element
	pop // pop head offset
	concat // concat head and tail
	frame_bury 0 // a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]

	// tests/contracts/abi.algo.ts:408
	// a[0] = 99 as uint<8>
	frame_dig 0 // a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]
	store 255 // full array
	load 255 // full array
	pushbytes 0x63
	replace2 0
	frame_bury 0 // a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]

	// tests/contracts/abi.algo.ts:409
	// a[1] = [10, 11]
	frame_dig 0 // a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]
	store 255 // full array
	pushint 1
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 2 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x0002000a000b
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 250 // length difference
	load 251 // element head offset
	int 2
	+ // head ofset
	callsub *update_dynamic_head
	load 250 // length difference
	load 251 // element head offset
	pushint 4
	+ // head ofset
	callsub *update_dynamic_head
	load 250 // length difference
	load 251 // element head offset
	pushint 6
	+ // head ofset
	callsub *update_dynamic_head
	load 255 // full array
	frame_bury 0 // a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]

	// tests/contracts/abi.algo.ts:410
	// a[2] = [12, 13]
	frame_dig 0 // a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]
	store 255 // full array
	pushint 3
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	pushint 1 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x00020c0d
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 250 // length difference
	load 251 // element head offset
	int 2
	+ // head ofset
	callsub *update_dynamic_head
	load 250 // length difference
	load 251 // element head offset
	pushint 4
	+ // head ofset
	callsub *update_dynamic_head
	load 255 // full array
	frame_bury 0 // a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]

	// tests/contracts/abi.algo.ts:411
	// a[3] = [14, 15]
	frame_dig 0 // a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]
	store 255 // full array
	pushint 5
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 2 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x0002000e000f
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 250 // length difference
	load 251 // element head offset
	int 2
	+ // head ofset
	callsub *update_dynamic_head
	load 255 // full array
	frame_bury 0 // a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]

	// tests/contracts/abi.algo.ts:412
	// a[4] = [16, 17]
	frame_dig 0 // a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]
	store 255 // full array
	pushint 7
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	pushint 1 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x00021011
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 255 // full array
	frame_bury 0 // a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]

	// tests/contracts/abi.algo.ts:414
	// return a;
	frame_dig 0 // a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]

	// set the subroutine return value
	frame_bury 0
	retsub

*abi_route_createApplication:
	pushint 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0xc54460fd // method "updateDynamicArrayInTuple()(uint8,uint16[],uint8[],uint16[],uint8[])"
	txna ApplicationArgs 0
	match *abi_route_updateDynamicArrayInTuple

	// this contract does not implement the given ABI method for call NoOp
	err

*process_static_tuple_element:
	proto 4 3
	frame_dig -4 // tuple head
	frame_dig -1 // element
	concat
	frame_dig -3 // tuple tail
	frame_dig -2 // head offset
	retsub

*process_dynamic_tuple_element:
	proto 4 3
	frame_dig -4 // tuple head
	frame_dig -2 // head offset
	concat
	frame_bury -4 // tuple head
	frame_dig -1 // element
	dup
	len
	frame_dig -2 // head offset
	btoi
	+
	itob
	extract 6 2
	frame_bury -2 // head offset
	frame_dig -3 // tuple tail
	swap
	concat
	frame_bury -3 // tuple tail
	frame_dig -4 // tuple head
	frame_dig -3 // tuple tail
	frame_dig -2 // head offset
	retsub

*update_dynamic_head:
	proto 2 0
	frame_dig -2 // length difference
	load 255 // full array
	frame_dig -1 // dynamic array offset
	extract_uint16 // extract dynamic array offset
	load 249 // subtract head difference
	bz *subtract_head_difference
	+ // add difference to offset
	b *end_calc_new_head

*subtract_head_difference:
	swap
	- // subtract difference from offet

*end_calc_new_head:
	itob // convert to bytes
	extract 6 2 // convert to uint16
	load 255 // full array
	swap
	frame_dig -1 // offset
	swap
	replace3 // update offset
	store 255 // full array
	retsub

*get_length_difference:
	load 252 // new element
	len // length of new element
	load 253 // element length
	<
	bnz *swapped_difference
	load 252 // new element
	len // length of new element
	load 253 // element length
	pushint 1
	store 249 // subtract head difference
	b *get_difference

*swapped_difference:
	load 253 // element length
	load 252 // new element
	len // length of new element
	pushint 0
	store 249 // subtract head difference

*get_difference:
	- // get length difference
	store 250 // length difference
	retsub", + "approval": "#pragma version 10
intcblock 2
bytecblock 0x0002000a000b 0x0002000e000f 0x00020c0d 0x00021011 0x

// This TEAL was generated by TEALScript v0.105.0
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// updateDynamicArrayInTuple()(uint8,uint16[],uint8[],uint16[],uint8[])
*abi_route_updateDynamicArrayInTuple:
	// The ABI return prefix
	pushbytes 0x151f7c75

	// execute updateDynamicArrayInTuple()(uint8,uint16[],uint8[],uint16[],uint8[])
	callsub updateDynamicArrayInTuple
	concat
	log
	pushint 1
	return

// updateDynamicArrayInTuple(): [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]
updateDynamicArrayInTuple:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/abi.algo.ts:406
	// a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]] = [9, [8], [7], [6], [5]]
	byte 0x // initial head
	byte 0x // initial tail
	pushbytes 0x0009 // initial head offset
	pushbytes 0x09
	callsub *process_static_tuple_element
	pushbytes 0x00010008
	callsub *process_dynamic_tuple_element
	pushbytes 0x000107
	callsub *process_dynamic_tuple_element
	pushbytes 0x00010006
	callsub *process_dynamic_tuple_element
	pushbytes 0x000105
	callsub *process_dynamic_tuple_element
	pop // pop head offset
	concat // concat head and tail
	frame_bury 0 // a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]

	// tests/contracts/abi.algo.ts:408
	// a[0] = 99 as uint<8>
	frame_dig 0 // a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]
	store 255 // full array
	load 255 // full array
	pushbytes 0x63
	replace2 0
	frame_bury 0 // a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]

	// tests/contracts/abi.algo.ts:409
	// a[1] = [10, 11]
	frame_dig 0 // a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]
	store 255 // full array
	pushint 1
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 2 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x0002000a000b
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 250 // length difference
	load 251 // element head offset
	int 2
	+ // head ofset
	callsub *update_dynamic_head
	load 250 // length difference
	load 251 // element head offset
	pushint 4
	+ // head ofset
	callsub *update_dynamic_head
	load 250 // length difference
	load 251 // element head offset
	pushint 6
	+ // head ofset
	callsub *update_dynamic_head
	load 255 // full array
	frame_bury 0 // a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]

	// tests/contracts/abi.algo.ts:410
	// a[2] = [12, 13]
	frame_dig 0 // a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]
	store 255 // full array
	pushint 3
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	pushint 1 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x00020c0d
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 250 // length difference
	load 251 // element head offset
	int 2
	+ // head ofset
	callsub *update_dynamic_head
	load 250 // length difference
	load 251 // element head offset
	pushint 4
	+ // head ofset
	callsub *update_dynamic_head
	load 255 // full array
	frame_bury 0 // a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]

	// tests/contracts/abi.algo.ts:411
	// a[3] = [14, 15]
	frame_dig 0 // a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]
	store 255 // full array
	pushint 5
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 2 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x0002000e000f
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 250 // length difference
	load 251 // element head offset
	int 2
	+ // head ofset
	callsub *update_dynamic_head
	load 255 // full array
	frame_bury 0 // a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]

	// tests/contracts/abi.algo.ts:412
	// a[4] = [16, 17]
	frame_dig 0 // a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]
	store 255 // full array
	pushint 7
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	pushint 1 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x00021011
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 255 // full array
	frame_bury 0 // a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]

	// tests/contracts/abi.algo.ts:414
	// return a;
	frame_dig 0 // a: [uint<8>, uint16[], uint<8>[], uint16[], uint<8>[]]

	// set the subroutine return value
	frame_bury 0
	retsub

*abi_route_createApplication:
	pushint 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0xc54460fd // method "updateDynamicArrayInTuple()(uint8,uint16[],uint8[],uint16[],uint8[])"
	txna ApplicationArgs 0
	match *abi_route_updateDynamicArrayInTuple

	// this contract does not implement the given ABI method for call NoOp
	err

*process_static_tuple_element:
	proto 4 3
	frame_dig -4 // tuple head
	frame_dig -1 // element
	concat
	frame_dig -3 // tuple tail
	frame_dig -2 // head offset
	retsub

*process_dynamic_tuple_element:
	proto 4 3
	frame_dig -4 // tuple head
	frame_dig -2 // head offset
	concat
	frame_bury -4 // tuple head
	frame_dig -1 // element
	dup
	len
	frame_dig -2 // head offset
	btoi
	+
	itob
	extract 6 2
	frame_bury -2 // head offset
	frame_dig -3 // tuple tail
	swap
	concat
	frame_bury -3 // tuple tail
	frame_dig -4 // tuple head
	frame_dig -3 // tuple tail
	frame_dig -2 // head offset
	retsub

*update_dynamic_head:
	proto 2 0
	frame_dig -2 // length difference
	load 255 // full array
	frame_dig -1 // dynamic array offset
	extract_uint16 // extract dynamic array offset
	load 249 // subtract head difference
	bz *subtract_head_difference
	+ // add difference to offset
	b *end_calc_new_head

*subtract_head_difference:
	swap
	- // subtract difference from offet

*end_calc_new_head:
	itob // convert to bytes
	extract 6 2 // convert to uint16
	load 255 // full array
	swap
	frame_dig -1 // offset
	swap
	replace3 // update offset
	store 255 // full array
	retsub

*get_length_difference:
	load 252 // new element
	len // length of new element
	load 253 // element length
	<
	bnz *swapped_difference
	load 252 // new element
	len // length of new element
	load 253 // element length
	pushint 1
	store 249 // subtract head difference
	b *get_difference

*swapped_difference:
	load 253 // element length
	load 252 // new element
	len // length of new element
	pushint 0
	store 249 // subtract head difference

*get_difference:
	- // get length difference
	store 250 // length difference
	retsub", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestUpdateDynamicElementInTupleWithSameLength.approval.teal b/tests/contracts/artifacts/ABITestUpdateDynamicElementInTupleWithSameLength.approval.teal index f2cfe7d8e..cbe5c3a78 100644 --- a/tests/contracts/artifacts/ABITestUpdateDynamicElementInTupleWithSameLength.approval.teal +++ b/tests/contracts/artifacts/ABITestUpdateDynamicElementInTupleWithSameLength.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x00030a0b0c 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestUpdateDynamicElementInTupleWithSameLength.arc32.json b/tests/contracts/artifacts/ABITestUpdateDynamicElementInTupleWithSameLength.arc32.json index f13b3e430..6de75643d 100644 --- a/tests/contracts/artifacts/ABITestUpdateDynamicElementInTupleWithSameLength.arc32.json +++ b/tests/contracts/artifacts/ABITestUpdateDynamicElementInTupleWithSameLength.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgwMDAzMGEwYjBjIDB4CgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdXBkYXRlRHluYW1pY0VsZW1lbnRJblR1cGxlV2l0aFNhbWVMZW5ndGgoKSh1aW50MTYsdWludDhbXSx1aW50MTYsdWludDhbXSx1aW50MTYpCiphYmlfcm91dGVfdXBkYXRlRHluYW1pY0VsZW1lbnRJblR1cGxlV2l0aFNhbWVMZW5ndGg6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSB1cGRhdGVEeW5hbWljRWxlbWVudEluVHVwbGVXaXRoU2FtZUxlbmd0aCgpKHVpbnQxNix1aW50OFtdLHVpbnQxNix1aW50OFtdLHVpbnQxNikKCWNhbGxzdWIgdXBkYXRlRHluYW1pY0VsZW1lbnRJblR1cGxlV2l0aFNhbWVMZW5ndGgKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gdXBkYXRlRHluYW1pY0VsZW1lbnRJblR1cGxlV2l0aFNhbWVMZW5ndGgoKTogW3VpbnQxNiwgdWludDw4PltdLCB1aW50MTYsIHVpbnQ8OD5bXSwgdWludDE2XQp1cGRhdGVEeW5hbWljRWxlbWVudEluVHVwbGVXaXRoU2FtZUxlbmd0aDoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjcwMAoJLy8gYTogW3VpbnQxNiwgdWludDw4PltdLCB1aW50MTYsIHVpbnQ8OD5bXSwgdWludDE2XSA9IFsxLCBbMiwgMywgNF0sIDUsIFs2LCA3LCA4XSwgOV0KCWJ5dGUgMHggLy8gaW5pdGlhbCBoZWFkCglieXRlIDB4IC8vIGluaXRpYWwgdGFpbAoJcHVzaGJ5dGVzIDB4MDAwYSAvLyBpbml0aWFsIGhlYWQgb2Zmc2V0CglwdXNoYnl0ZXMgMHgwMDAxCgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAzMDIwMzA0CgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwNQoJY2FsbHN1YiAqcHJvY2Vzc19zdGF0aWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwMzA2MDcwOAoJY2FsbHN1YiAqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMDkKCWNhbGxzdWIgKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQKCXBvcCAvLyBwb3AgaGVhZCBvZmZzZXQKCWNvbmNhdCAvLyBjb25jYXQgaGVhZCBhbmQgdGFpbAoJZnJhbWVfYnVyeSAwIC8vIGE6IFt1aW50MTYsIHVpbnQ8OD5bXSwgdWludDE2LCB1aW50PDg+W10sIHVpbnQxNl0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NzAyCgkvLyBhWzFdID0gWzEwLCAxMSwgMTJdCglmcmFtZV9kaWcgMCAvLyBhOiBbdWludDE2LCB1aW50PDg+W10sIHVpbnQxNiwgdWludDw4PltdLCB1aW50MTZdCglzdG9yZSAyNTUgLy8gZnVsbCBhcnJheQoJcHVzaGludCAyCglkdXAKCXN0b3JlIDI1MSAvLyBlbGVtZW50IGhlYWQgb2Zmc2V0Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cgl1bmNvdmVyIDIKCWV4dHJhY3RfdWludDE2CglkdXAKCXN0b3JlIDI1NCAvLyBlbGVtZW50IHN0YXJ0CglkdXAgLy8gZHVwbGljYXRlIHN0YXJ0IG9mIGVsZW1lbnQKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXN3YXAKCWV4dHJhY3RfdWludDE2IC8vIGdldCBudW1iZXIgb2YgZWxlbWVudHMKCXB1c2hpbnQgMSAvLyBnZXQgdHlwZSBsZW5ndGgKCSogLy8gbXVsdGlwbHkgYnkgdHlwZSBsZW5ndGgKCXB1c2hpbnQgMgoJKyAvLyBhZGQgdHdvIGZvciBsZW5ndGgKCXN0b3JlIDI1MyAvLyBlbGVtZW50IGxlbmd0aAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJcHVzaGludCAwCglsb2FkIDI1NCAvLyBlbGVtZW50IHN0YXJ0CglzdWJzdHJpbmczCglieXRlIDB4MDAwMzBhMGIwYwoJZHVwCglzdG9yZSAyNTIgLy8gbmV3IGVsZW1lbnQKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU0IC8vIGVsZW1lbnQgc3RhcnQKCWxvYWQgMjUzIC8vIGVsZW1lbnQgbGVuZ3RoCgkrIC8vIGdldCBlbmQgb2YgRWxlbWVudAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJbGVuCglzdWJzdHJpbmczCgljb25jYXQKCWNvbmNhdAoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWNhbGxzdWIgKmdldF9sZW5ndGhfZGlmZmVyZW5jZQoJbG9hZCAyNTAgLy8gbGVuZ3RoIGRpZmZlcmVuY2UKCWxvYWQgMjUxIC8vIGVsZW1lbnQgaGVhZCBvZmZzZXQKCXB1c2hpbnQgNAoJKyAvLyBoZWFkIG9mc2V0CgljYWxsc3ViICp1cGRhdGVfZHluYW1pY19oZWFkCglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglmcmFtZV9idXJ5IDAgLy8gYTogW3VpbnQxNiwgdWludDw4PltdLCB1aW50MTYsIHVpbnQ8OD5bXSwgdWludDE2XQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo3MDQKCS8vIHJldHVybiBhOwoJZnJhbWVfZGlnIDAgLy8gYTogW3VpbnQxNiwgdWludDw4PltdLCB1aW50MTYsIHVpbnQ8OD5bXSwgdWludDE2XQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg0MmRlYTgzOCAvLyBtZXRob2QgInVwZGF0ZUR5bmFtaWNFbGVtZW50SW5UdXBsZVdpdGhTYW1lTGVuZ3RoKCkodWludDE2LHVpbnQ4W10sdWludDE2LHVpbnQ4W10sdWludDE2KSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfdXBkYXRlRHluYW1pY0VsZW1lbnRJblR1cGxlV2l0aFNhbWVMZW5ndGgKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnIKCipwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50OgoJcHJvdG8gNCAzCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0xIC8vIGVsZW1lbnQKCWNvbmNhdAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3ViCgoqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCWNvbmNhdAoJZnJhbWVfYnVyeSAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJZHVwCglsZW4KCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJYnRvaQoJKwoJaXRvYgoJZXh0cmFjdCA2IDIKCWZyYW1lX2J1cnkgLTIgLy8gaGVhZCBvZmZzZXQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglzd2FwCgljb25jYXQKCWZyYW1lX2J1cnkgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCXJldHN1YgoKKnVwZGF0ZV9keW5hbWljX2hlYWQ6Cglwcm90byAyIDAKCWZyYW1lX2RpZyAtMiAvLyBsZW5ndGggZGlmZmVyZW5jZQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJZnJhbWVfZGlnIC0xIC8vIGR5bmFtaWMgYXJyYXkgb2Zmc2V0CglleHRyYWN0X3VpbnQxNiAvLyBleHRyYWN0IGR5bmFtaWMgYXJyYXkgb2Zmc2V0Cglsb2FkIDI0OSAvLyBzdWJ0cmFjdCBoZWFkIGRpZmZlcmVuY2UKCWJ6ICpzdWJ0cmFjdF9oZWFkX2RpZmZlcmVuY2UKCSsgLy8gYWRkIGRpZmZlcmVuY2UgdG8gb2Zmc2V0CgliICplbmRfY2FsY19uZXdfaGVhZAoKKnN1YnRyYWN0X2hlYWRfZGlmZmVyZW5jZToKCXN3YXAKCS0gLy8gc3VidHJhY3QgZGlmZmVyZW5jZSBmcm9tIG9mZmV0CgoqZW5kX2NhbGNfbmV3X2hlYWQ6CglpdG9iIC8vIGNvbnZlcnQgdG8gYnl0ZXMKCWV4dHJhY3QgNiAyIC8vIGNvbnZlcnQgdG8gdWludDE2Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglzd2FwCglmcmFtZV9kaWcgLTEgLy8gb2Zmc2V0Cglzd2FwCglyZXBsYWNlMyAvLyB1cGRhdGUgb2Zmc2V0CglzdG9yZSAyNTUgLy8gZnVsbCBhcnJheQoJcmV0c3ViCgoqZ2V0X2xlbmd0aF9kaWZmZXJlbmNlOgoJbG9hZCAyNTIgLy8gbmV3IGVsZW1lbnQKCWxlbiAvLyBsZW5ndGggb2YgbmV3IGVsZW1lbnQKCWxvYWQgMjUzIC8vIGVsZW1lbnQgbGVuZ3RoCgk8CglibnogKnN3YXBwZWRfZGlmZmVyZW5jZQoJbG9hZCAyNTIgLy8gbmV3IGVsZW1lbnQKCWxlbiAvLyBsZW5ndGggb2YgbmV3IGVsZW1lbnQKCWxvYWQgMjUzIC8vIGVsZW1lbnQgbGVuZ3RoCglwdXNoaW50IDEKCXN0b3JlIDI0OSAvLyBzdWJ0cmFjdCBoZWFkIGRpZmZlcmVuY2UKCWIgKmdldF9kaWZmZXJlbmNlCgoqc3dhcHBlZF9kaWZmZXJlbmNlOgoJbG9hZCAyNTMgLy8gZWxlbWVudCBsZW5ndGgKCWxvYWQgMjUyIC8vIG5ldyBlbGVtZW50CglsZW4gLy8gbGVuZ3RoIG9mIG5ldyBlbGVtZW50CglwdXNoaW50IDAKCXN0b3JlIDI0OSAvLyBzdWJ0cmFjdCBoZWFkIGRpZmZlcmVuY2UKCipnZXRfZGlmZmVyZW5jZToKCS0gLy8gZ2V0IGxlbmd0aCBkaWZmZXJlbmNlCglzdG9yZSAyNTAgLy8gbGVuZ3RoIGRpZmZlcmVuY2UKCXJldHN1Yg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgwMDAzMGEwYjBjIDB4CgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdXBkYXRlRHluYW1pY0VsZW1lbnRJblR1cGxlV2l0aFNhbWVMZW5ndGgoKSh1aW50MTYsdWludDhbXSx1aW50MTYsdWludDhbXSx1aW50MTYpCiphYmlfcm91dGVfdXBkYXRlRHluYW1pY0VsZW1lbnRJblR1cGxlV2l0aFNhbWVMZW5ndGg6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSB1cGRhdGVEeW5hbWljRWxlbWVudEluVHVwbGVXaXRoU2FtZUxlbmd0aCgpKHVpbnQxNix1aW50OFtdLHVpbnQxNix1aW50OFtdLHVpbnQxNikKCWNhbGxzdWIgdXBkYXRlRHluYW1pY0VsZW1lbnRJblR1cGxlV2l0aFNhbWVMZW5ndGgKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gdXBkYXRlRHluYW1pY0VsZW1lbnRJblR1cGxlV2l0aFNhbWVMZW5ndGgoKTogW3VpbnQxNiwgdWludDw4PltdLCB1aW50MTYsIHVpbnQ8OD5bXSwgdWludDE2XQp1cGRhdGVEeW5hbWljRWxlbWVudEluVHVwbGVXaXRoU2FtZUxlbmd0aDoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjcwMAoJLy8gYTogW3VpbnQxNiwgdWludDw4PltdLCB1aW50MTYsIHVpbnQ8OD5bXSwgdWludDE2XSA9IFsxLCBbMiwgMywgNF0sIDUsIFs2LCA3LCA4XSwgOV0KCWJ5dGUgMHggLy8gaW5pdGlhbCBoZWFkCglieXRlIDB4IC8vIGluaXRpYWwgdGFpbAoJcHVzaGJ5dGVzIDB4MDAwYSAvLyBpbml0aWFsIGhlYWQgb2Zmc2V0CglwdXNoYnl0ZXMgMHgwMDAxCgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAzMDIwMzA0CgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwNQoJY2FsbHN1YiAqcHJvY2Vzc19zdGF0aWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwMzA2MDcwOAoJY2FsbHN1YiAqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMDkKCWNhbGxzdWIgKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQKCXBvcCAvLyBwb3AgaGVhZCBvZmZzZXQKCWNvbmNhdCAvLyBjb25jYXQgaGVhZCBhbmQgdGFpbAoJZnJhbWVfYnVyeSAwIC8vIGE6IFt1aW50MTYsIHVpbnQ8OD5bXSwgdWludDE2LCB1aW50PDg+W10sIHVpbnQxNl0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NzAyCgkvLyBhWzFdID0gWzEwLCAxMSwgMTJdCglmcmFtZV9kaWcgMCAvLyBhOiBbdWludDE2LCB1aW50PDg+W10sIHVpbnQxNiwgdWludDw4PltdLCB1aW50MTZdCglzdG9yZSAyNTUgLy8gZnVsbCBhcnJheQoJcHVzaGludCAyCglkdXAKCXN0b3JlIDI1MSAvLyBlbGVtZW50IGhlYWQgb2Zmc2V0Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cgl1bmNvdmVyIDIKCWV4dHJhY3RfdWludDE2CglkdXAKCXN0b3JlIDI1NCAvLyBlbGVtZW50IHN0YXJ0CglkdXAgLy8gZHVwbGljYXRlIHN0YXJ0IG9mIGVsZW1lbnQKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXN3YXAKCWV4dHJhY3RfdWludDE2IC8vIGdldCBudW1iZXIgb2YgZWxlbWVudHMKCXB1c2hpbnQgMSAvLyBnZXQgdHlwZSBsZW5ndGgKCSogLy8gbXVsdGlwbHkgYnkgdHlwZSBsZW5ndGgKCXB1c2hpbnQgMgoJKyAvLyBhZGQgdHdvIGZvciBsZW5ndGgKCXN0b3JlIDI1MyAvLyBlbGVtZW50IGxlbmd0aAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJcHVzaGludCAwCglsb2FkIDI1NCAvLyBlbGVtZW50IHN0YXJ0CglzdWJzdHJpbmczCglieXRlIDB4MDAwMzBhMGIwYwoJZHVwCglzdG9yZSAyNTIgLy8gbmV3IGVsZW1lbnQKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU0IC8vIGVsZW1lbnQgc3RhcnQKCWxvYWQgMjUzIC8vIGVsZW1lbnQgbGVuZ3RoCgkrIC8vIGdldCBlbmQgb2YgRWxlbWVudAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJbGVuCglzdWJzdHJpbmczCgljb25jYXQKCWNvbmNhdAoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWNhbGxzdWIgKmdldF9sZW5ndGhfZGlmZmVyZW5jZQoJbG9hZCAyNTAgLy8gbGVuZ3RoIGRpZmZlcmVuY2UKCWxvYWQgMjUxIC8vIGVsZW1lbnQgaGVhZCBvZmZzZXQKCXB1c2hpbnQgNAoJKyAvLyBoZWFkIG9mc2V0CgljYWxsc3ViICp1cGRhdGVfZHluYW1pY19oZWFkCglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglmcmFtZV9idXJ5IDAgLy8gYTogW3VpbnQxNiwgdWludDw4PltdLCB1aW50MTYsIHVpbnQ8OD5bXSwgdWludDE2XQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo3MDQKCS8vIHJldHVybiBhOwoJZnJhbWVfZGlnIDAgLy8gYTogW3VpbnQxNiwgdWludDw4PltdLCB1aW50MTYsIHVpbnQ8OD5bXSwgdWludDE2XQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg0MmRlYTgzOCAvLyBtZXRob2QgInVwZGF0ZUR5bmFtaWNFbGVtZW50SW5UdXBsZVdpdGhTYW1lTGVuZ3RoKCkodWludDE2LHVpbnQ4W10sdWludDE2LHVpbnQ4W10sdWludDE2KSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfdXBkYXRlRHluYW1pY0VsZW1lbnRJblR1cGxlV2l0aFNhbWVMZW5ndGgKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnIKCipwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50OgoJcHJvdG8gNCAzCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0xIC8vIGVsZW1lbnQKCWNvbmNhdAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3ViCgoqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCWNvbmNhdAoJZnJhbWVfYnVyeSAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJZHVwCglsZW4KCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJYnRvaQoJKwoJaXRvYgoJZXh0cmFjdCA2IDIKCWZyYW1lX2J1cnkgLTIgLy8gaGVhZCBvZmZzZXQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglzd2FwCgljb25jYXQKCWZyYW1lX2J1cnkgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCXJldHN1YgoKKnVwZGF0ZV9keW5hbWljX2hlYWQ6Cglwcm90byAyIDAKCWZyYW1lX2RpZyAtMiAvLyBsZW5ndGggZGlmZmVyZW5jZQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJZnJhbWVfZGlnIC0xIC8vIGR5bmFtaWMgYXJyYXkgb2Zmc2V0CglleHRyYWN0X3VpbnQxNiAvLyBleHRyYWN0IGR5bmFtaWMgYXJyYXkgb2Zmc2V0Cglsb2FkIDI0OSAvLyBzdWJ0cmFjdCBoZWFkIGRpZmZlcmVuY2UKCWJ6ICpzdWJ0cmFjdF9oZWFkX2RpZmZlcmVuY2UKCSsgLy8gYWRkIGRpZmZlcmVuY2UgdG8gb2Zmc2V0CgliICplbmRfY2FsY19uZXdfaGVhZAoKKnN1YnRyYWN0X2hlYWRfZGlmZmVyZW5jZToKCXN3YXAKCS0gLy8gc3VidHJhY3QgZGlmZmVyZW5jZSBmcm9tIG9mZmV0CgoqZW5kX2NhbGNfbmV3X2hlYWQ6CglpdG9iIC8vIGNvbnZlcnQgdG8gYnl0ZXMKCWV4dHJhY3QgNiAyIC8vIGNvbnZlcnQgdG8gdWludDE2Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglzd2FwCglmcmFtZV9kaWcgLTEgLy8gb2Zmc2V0Cglzd2FwCglyZXBsYWNlMyAvLyB1cGRhdGUgb2Zmc2V0CglzdG9yZSAyNTUgLy8gZnVsbCBhcnJheQoJcmV0c3ViCgoqZ2V0X2xlbmd0aF9kaWZmZXJlbmNlOgoJbG9hZCAyNTIgLy8gbmV3IGVsZW1lbnQKCWxlbiAvLyBsZW5ndGggb2YgbmV3IGVsZW1lbnQKCWxvYWQgMjUzIC8vIGVsZW1lbnQgbGVuZ3RoCgk8CglibnogKnN3YXBwZWRfZGlmZmVyZW5jZQoJbG9hZCAyNTIgLy8gbmV3IGVsZW1lbnQKCWxlbiAvLyBsZW5ndGggb2YgbmV3IGVsZW1lbnQKCWxvYWQgMjUzIC8vIGVsZW1lbnQgbGVuZ3RoCglwdXNoaW50IDEKCXN0b3JlIDI0OSAvLyBzdWJ0cmFjdCBoZWFkIGRpZmZlcmVuY2UKCWIgKmdldF9kaWZmZXJlbmNlCgoqc3dhcHBlZF9kaWZmZXJlbmNlOgoJbG9hZCAyNTMgLy8gZWxlbWVudCBsZW5ndGgKCWxvYWQgMjUyIC8vIG5ldyBlbGVtZW50CglsZW4gLy8gbGVuZ3RoIG9mIG5ldyBlbGVtZW50CglwdXNoaW50IDAKCXN0b3JlIDI0OSAvLyBzdWJ0cmFjdCBoZWFkIGRpZmZlcmVuY2UKCipnZXRfZGlmZmVyZW5jZToKCS0gLy8gZ2V0IGxlbmd0aCBkaWZmZXJlbmNlCglzdG9yZSAyNTAgLy8gbGVuZ3RoIGRpZmZlcmVuY2UKCXJldHN1Yg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestUpdateDynamicElementInTupleWithSameLength.arc56_draft.json b/tests/contracts/artifacts/ABITestUpdateDynamicElementInTupleWithSameLength.arc56_draft.json index 1f139f65e..ee7a30673 100644 --- a/tests/contracts/artifacts/ABITestUpdateDynamicElementInTupleWithSameLength.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestUpdateDynamicElementInTupleWithSameLength.arc56_draft.json @@ -1389,7 +1389,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgwMDAzMGEwYjBjIDB4CgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdXBkYXRlRHluYW1pY0VsZW1lbnRJblR1cGxlV2l0aFNhbWVMZW5ndGgoKSh1aW50MTYsdWludDhbXSx1aW50MTYsdWludDhbXSx1aW50MTYpCiphYmlfcm91dGVfdXBkYXRlRHluYW1pY0VsZW1lbnRJblR1cGxlV2l0aFNhbWVMZW5ndGg6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSB1cGRhdGVEeW5hbWljRWxlbWVudEluVHVwbGVXaXRoU2FtZUxlbmd0aCgpKHVpbnQxNix1aW50OFtdLHVpbnQxNix1aW50OFtdLHVpbnQxNikKCWNhbGxzdWIgdXBkYXRlRHluYW1pY0VsZW1lbnRJblR1cGxlV2l0aFNhbWVMZW5ndGgKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gdXBkYXRlRHluYW1pY0VsZW1lbnRJblR1cGxlV2l0aFNhbWVMZW5ndGgoKTogW3VpbnQxNiwgdWludDw4PltdLCB1aW50MTYsIHVpbnQ8OD5bXSwgdWludDE2XQp1cGRhdGVEeW5hbWljRWxlbWVudEluVHVwbGVXaXRoU2FtZUxlbmd0aDoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjcwMAoJLy8gYTogW3VpbnQxNiwgdWludDw4PltdLCB1aW50MTYsIHVpbnQ8OD5bXSwgdWludDE2XSA9IFsxLCBbMiwgMywgNF0sIDUsIFs2LCA3LCA4XSwgOV0KCWJ5dGUgMHggLy8gaW5pdGlhbCBoZWFkCglieXRlIDB4IC8vIGluaXRpYWwgdGFpbAoJcHVzaGJ5dGVzIDB4MDAwYSAvLyBpbml0aWFsIGhlYWQgb2Zmc2V0CglwdXNoYnl0ZXMgMHgwMDAxCgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAzMDIwMzA0CgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwNQoJY2FsbHN1YiAqcHJvY2Vzc19zdGF0aWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwMzA2MDcwOAoJY2FsbHN1YiAqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMDkKCWNhbGxzdWIgKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQKCXBvcCAvLyBwb3AgaGVhZCBvZmZzZXQKCWNvbmNhdCAvLyBjb25jYXQgaGVhZCBhbmQgdGFpbAoJZnJhbWVfYnVyeSAwIC8vIGE6IFt1aW50MTYsIHVpbnQ8OD5bXSwgdWludDE2LCB1aW50PDg+W10sIHVpbnQxNl0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NzAyCgkvLyBhWzFdID0gWzEwLCAxMSwgMTJdCglmcmFtZV9kaWcgMCAvLyBhOiBbdWludDE2LCB1aW50PDg+W10sIHVpbnQxNiwgdWludDw4PltdLCB1aW50MTZdCglzdG9yZSAyNTUgLy8gZnVsbCBhcnJheQoJcHVzaGludCAyCglkdXAKCXN0b3JlIDI1MSAvLyBlbGVtZW50IGhlYWQgb2Zmc2V0Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cgl1bmNvdmVyIDIKCWV4dHJhY3RfdWludDE2CglkdXAKCXN0b3JlIDI1NCAvLyBlbGVtZW50IHN0YXJ0CglkdXAgLy8gZHVwbGljYXRlIHN0YXJ0IG9mIGVsZW1lbnQKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXN3YXAKCWV4dHJhY3RfdWludDE2IC8vIGdldCBudW1iZXIgb2YgZWxlbWVudHMKCXB1c2hpbnQgMSAvLyBnZXQgdHlwZSBsZW5ndGgKCSogLy8gbXVsdGlwbHkgYnkgdHlwZSBsZW5ndGgKCXB1c2hpbnQgMgoJKyAvLyBhZGQgdHdvIGZvciBsZW5ndGgKCXN0b3JlIDI1MyAvLyBlbGVtZW50IGxlbmd0aAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJcHVzaGludCAwCglsb2FkIDI1NCAvLyBlbGVtZW50IHN0YXJ0CglzdWJzdHJpbmczCglieXRlIDB4MDAwMzBhMGIwYwoJZHVwCglzdG9yZSAyNTIgLy8gbmV3IGVsZW1lbnQKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU0IC8vIGVsZW1lbnQgc3RhcnQKCWxvYWQgMjUzIC8vIGVsZW1lbnQgbGVuZ3RoCgkrIC8vIGdldCBlbmQgb2YgRWxlbWVudAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJbGVuCglzdWJzdHJpbmczCgljb25jYXQKCWNvbmNhdAoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWNhbGxzdWIgKmdldF9sZW5ndGhfZGlmZmVyZW5jZQoJbG9hZCAyNTAgLy8gbGVuZ3RoIGRpZmZlcmVuY2UKCWxvYWQgMjUxIC8vIGVsZW1lbnQgaGVhZCBvZmZzZXQKCXB1c2hpbnQgNAoJKyAvLyBoZWFkIG9mc2V0CgljYWxsc3ViICp1cGRhdGVfZHluYW1pY19oZWFkCglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglmcmFtZV9idXJ5IDAgLy8gYTogW3VpbnQxNiwgdWludDw4PltdLCB1aW50MTYsIHVpbnQ8OD5bXSwgdWludDE2XQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo3MDQKCS8vIHJldHVybiBhOwoJZnJhbWVfZGlnIDAgLy8gYTogW3VpbnQxNiwgdWludDw4PltdLCB1aW50MTYsIHVpbnQ8OD5bXSwgdWludDE2XQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg0MmRlYTgzOCAvLyBtZXRob2QgInVwZGF0ZUR5bmFtaWNFbGVtZW50SW5UdXBsZVdpdGhTYW1lTGVuZ3RoKCkodWludDE2LHVpbnQ4W10sdWludDE2LHVpbnQ4W10sdWludDE2KSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfdXBkYXRlRHluYW1pY0VsZW1lbnRJblR1cGxlV2l0aFNhbWVMZW5ndGgKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnIKCipwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50OgoJcHJvdG8gNCAzCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0xIC8vIGVsZW1lbnQKCWNvbmNhdAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3ViCgoqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCWNvbmNhdAoJZnJhbWVfYnVyeSAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJZHVwCglsZW4KCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJYnRvaQoJKwoJaXRvYgoJZXh0cmFjdCA2IDIKCWZyYW1lX2J1cnkgLTIgLy8gaGVhZCBvZmZzZXQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglzd2FwCgljb25jYXQKCWZyYW1lX2J1cnkgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCXJldHN1YgoKKnVwZGF0ZV9keW5hbWljX2hlYWQ6Cglwcm90byAyIDAKCWZyYW1lX2RpZyAtMiAvLyBsZW5ndGggZGlmZmVyZW5jZQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJZnJhbWVfZGlnIC0xIC8vIGR5bmFtaWMgYXJyYXkgb2Zmc2V0CglleHRyYWN0X3VpbnQxNiAvLyBleHRyYWN0IGR5bmFtaWMgYXJyYXkgb2Zmc2V0Cglsb2FkIDI0OSAvLyBzdWJ0cmFjdCBoZWFkIGRpZmZlcmVuY2UKCWJ6ICpzdWJ0cmFjdF9oZWFkX2RpZmZlcmVuY2UKCSsgLy8gYWRkIGRpZmZlcmVuY2UgdG8gb2Zmc2V0CgliICplbmRfY2FsY19uZXdfaGVhZAoKKnN1YnRyYWN0X2hlYWRfZGlmZmVyZW5jZToKCXN3YXAKCS0gLy8gc3VidHJhY3QgZGlmZmVyZW5jZSBmcm9tIG9mZmV0CgoqZW5kX2NhbGNfbmV3X2hlYWQ6CglpdG9iIC8vIGNvbnZlcnQgdG8gYnl0ZXMKCWV4dHJhY3QgNiAyIC8vIGNvbnZlcnQgdG8gdWludDE2Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglzd2FwCglmcmFtZV9kaWcgLTEgLy8gb2Zmc2V0Cglzd2FwCglyZXBsYWNlMyAvLyB1cGRhdGUgb2Zmc2V0CglzdG9yZSAyNTUgLy8gZnVsbCBhcnJheQoJcmV0c3ViCgoqZ2V0X2xlbmd0aF9kaWZmZXJlbmNlOgoJbG9hZCAyNTIgLy8gbmV3IGVsZW1lbnQKCWxlbiAvLyBsZW5ndGggb2YgbmV3IGVsZW1lbnQKCWxvYWQgMjUzIC8vIGVsZW1lbnQgbGVuZ3RoCgk8CglibnogKnN3YXBwZWRfZGlmZmVyZW5jZQoJbG9hZCAyNTIgLy8gbmV3IGVsZW1lbnQKCWxlbiAvLyBsZW5ndGggb2YgbmV3IGVsZW1lbnQKCWxvYWQgMjUzIC8vIGVsZW1lbnQgbGVuZ3RoCglwdXNoaW50IDEKCXN0b3JlIDI0OSAvLyBzdWJ0cmFjdCBoZWFkIGRpZmZlcmVuY2UKCWIgKmdldF9kaWZmZXJlbmNlCgoqc3dhcHBlZF9kaWZmZXJlbmNlOgoJbG9hZCAyNTMgLy8gZWxlbWVudCBsZW5ndGgKCWxvYWQgMjUyIC8vIG5ldyBlbGVtZW50CglsZW4gLy8gbGVuZ3RoIG9mIG5ldyBlbGVtZW50CglwdXNoaW50IDAKCXN0b3JlIDI0OSAvLyBzdWJ0cmFjdCBoZWFkIGRpZmZlcmVuY2UKCipnZXRfZGlmZmVyZW5jZToKCS0gLy8gZ2V0IGxlbmd0aCBkaWZmZXJlbmNlCglzdG9yZSAyNTAgLy8gbGVuZ3RoIGRpZmZlcmVuY2UKCXJldHN1Yg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgwMDAzMGEwYjBjIDB4CgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdXBkYXRlRHluYW1pY0VsZW1lbnRJblR1cGxlV2l0aFNhbWVMZW5ndGgoKSh1aW50MTYsdWludDhbXSx1aW50MTYsdWludDhbXSx1aW50MTYpCiphYmlfcm91dGVfdXBkYXRlRHluYW1pY0VsZW1lbnRJblR1cGxlV2l0aFNhbWVMZW5ndGg6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSB1cGRhdGVEeW5hbWljRWxlbWVudEluVHVwbGVXaXRoU2FtZUxlbmd0aCgpKHVpbnQxNix1aW50OFtdLHVpbnQxNix1aW50OFtdLHVpbnQxNikKCWNhbGxzdWIgdXBkYXRlRHluYW1pY0VsZW1lbnRJblR1cGxlV2l0aFNhbWVMZW5ndGgKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gdXBkYXRlRHluYW1pY0VsZW1lbnRJblR1cGxlV2l0aFNhbWVMZW5ndGgoKTogW3VpbnQxNiwgdWludDw4PltdLCB1aW50MTYsIHVpbnQ8OD5bXSwgdWludDE2XQp1cGRhdGVEeW5hbWljRWxlbWVudEluVHVwbGVXaXRoU2FtZUxlbmd0aDoKCXByb3RvIDAgMQoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjcwMAoJLy8gYTogW3VpbnQxNiwgdWludDw4PltdLCB1aW50MTYsIHVpbnQ8OD5bXSwgdWludDE2XSA9IFsxLCBbMiwgMywgNF0sIDUsIFs2LCA3LCA4XSwgOV0KCWJ5dGUgMHggLy8gaW5pdGlhbCBoZWFkCglieXRlIDB4IC8vIGluaXRpYWwgdGFpbAoJcHVzaGJ5dGVzIDB4MDAwYSAvLyBpbml0aWFsIGhlYWQgb2Zmc2V0CglwdXNoYnl0ZXMgMHgwMDAxCgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAzMDIwMzA0CgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwNQoJY2FsbHN1YiAqcHJvY2Vzc19zdGF0aWNfdHVwbGVfZWxlbWVudAoJcHVzaGJ5dGVzIDB4MDAwMzA2MDcwOAoJY2FsbHN1YiAqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMDkKCWNhbGxzdWIgKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQKCXBvcCAvLyBwb3AgaGVhZCBvZmZzZXQKCWNvbmNhdCAvLyBjb25jYXQgaGVhZCBhbmQgdGFpbAoJZnJhbWVfYnVyeSAwIC8vIGE6IFt1aW50MTYsIHVpbnQ8OD5bXSwgdWludDE2LCB1aW50PDg+W10sIHVpbnQxNl0KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NzAyCgkvLyBhWzFdID0gWzEwLCAxMSwgMTJdCglmcmFtZV9kaWcgMCAvLyBhOiBbdWludDE2LCB1aW50PDg+W10sIHVpbnQxNiwgdWludDw4PltdLCB1aW50MTZdCglzdG9yZSAyNTUgLy8gZnVsbCBhcnJheQoJcHVzaGludCAyCglkdXAKCXN0b3JlIDI1MSAvLyBlbGVtZW50IGhlYWQgb2Zmc2V0Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cgl1bmNvdmVyIDIKCWV4dHJhY3RfdWludDE2CglkdXAKCXN0b3JlIDI1NCAvLyBlbGVtZW50IHN0YXJ0CglkdXAgLy8gZHVwbGljYXRlIHN0YXJ0IG9mIGVsZW1lbnQKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXN3YXAKCWV4dHJhY3RfdWludDE2IC8vIGdldCBudW1iZXIgb2YgZWxlbWVudHMKCXB1c2hpbnQgMSAvLyBnZXQgdHlwZSBsZW5ndGgKCSogLy8gbXVsdGlwbHkgYnkgdHlwZSBsZW5ndGgKCXB1c2hpbnQgMgoJKyAvLyBhZGQgdHdvIGZvciBsZW5ndGgKCXN0b3JlIDI1MyAvLyBlbGVtZW50IGxlbmd0aAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJcHVzaGludCAwCglsb2FkIDI1NCAvLyBlbGVtZW50IHN0YXJ0CglzdWJzdHJpbmczCglieXRlIDB4MDAwMzBhMGIwYwoJZHVwCglzdG9yZSAyNTIgLy8gbmV3IGVsZW1lbnQKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU0IC8vIGVsZW1lbnQgc3RhcnQKCWxvYWQgMjUzIC8vIGVsZW1lbnQgbGVuZ3RoCgkrIC8vIGdldCBlbmQgb2YgRWxlbWVudAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJbGVuCglzdWJzdHJpbmczCgljb25jYXQKCWNvbmNhdAoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWNhbGxzdWIgKmdldF9sZW5ndGhfZGlmZmVyZW5jZQoJbG9hZCAyNTAgLy8gbGVuZ3RoIGRpZmZlcmVuY2UKCWxvYWQgMjUxIC8vIGVsZW1lbnQgaGVhZCBvZmZzZXQKCXB1c2hpbnQgNAoJKyAvLyBoZWFkIG9mc2V0CgljYWxsc3ViICp1cGRhdGVfZHluYW1pY19oZWFkCglsb2FkIDI1NSAvLyBmdWxsIGFycmF5CglmcmFtZV9idXJ5IDAgLy8gYTogW3VpbnQxNiwgdWludDw4PltdLCB1aW50MTYsIHVpbnQ8OD5bXSwgdWludDE2XQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo3MDQKCS8vIHJldHVybiBhOwoJZnJhbWVfZGlnIDAgLy8gYTogW3VpbnQxNiwgdWludDw4PltdLCB1aW50MTYsIHVpbnQ8OD5bXSwgdWludDE2XQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg0MmRlYTgzOCAvLyBtZXRob2QgInVwZGF0ZUR5bmFtaWNFbGVtZW50SW5UdXBsZVdpdGhTYW1lTGVuZ3RoKCkodWludDE2LHVpbnQ4W10sdWludDE2LHVpbnQ4W10sdWludDE2KSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfdXBkYXRlRHluYW1pY0VsZW1lbnRJblR1cGxlV2l0aFNhbWVMZW5ndGgKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnIKCipwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50OgoJcHJvdG8gNCAzCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0xIC8vIGVsZW1lbnQKCWNvbmNhdAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3ViCgoqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCWNvbmNhdAoJZnJhbWVfYnVyeSAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJZHVwCglsZW4KCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJYnRvaQoJKwoJaXRvYgoJZXh0cmFjdCA2IDIKCWZyYW1lX2J1cnkgLTIgLy8gaGVhZCBvZmZzZXQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglzd2FwCgljb25jYXQKCWZyYW1lX2J1cnkgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCXJldHN1YgoKKnVwZGF0ZV9keW5hbWljX2hlYWQ6Cglwcm90byAyIDAKCWZyYW1lX2RpZyAtMiAvLyBsZW5ndGggZGlmZmVyZW5jZQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJZnJhbWVfZGlnIC0xIC8vIGR5bmFtaWMgYXJyYXkgb2Zmc2V0CglleHRyYWN0X3VpbnQxNiAvLyBleHRyYWN0IGR5bmFtaWMgYXJyYXkgb2Zmc2V0Cglsb2FkIDI0OSAvLyBzdWJ0cmFjdCBoZWFkIGRpZmZlcmVuY2UKCWJ6ICpzdWJ0cmFjdF9oZWFkX2RpZmZlcmVuY2UKCSsgLy8gYWRkIGRpZmZlcmVuY2UgdG8gb2Zmc2V0CgliICplbmRfY2FsY19uZXdfaGVhZAoKKnN1YnRyYWN0X2hlYWRfZGlmZmVyZW5jZToKCXN3YXAKCS0gLy8gc3VidHJhY3QgZGlmZmVyZW5jZSBmcm9tIG9mZmV0CgoqZW5kX2NhbGNfbmV3X2hlYWQ6CglpdG9iIC8vIGNvbnZlcnQgdG8gYnl0ZXMKCWV4dHJhY3QgNiAyIC8vIGNvbnZlcnQgdG8gdWludDE2Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglzd2FwCglmcmFtZV9kaWcgLTEgLy8gb2Zmc2V0Cglzd2FwCglyZXBsYWNlMyAvLyB1cGRhdGUgb2Zmc2V0CglzdG9yZSAyNTUgLy8gZnVsbCBhcnJheQoJcmV0c3ViCgoqZ2V0X2xlbmd0aF9kaWZmZXJlbmNlOgoJbG9hZCAyNTIgLy8gbmV3IGVsZW1lbnQKCWxlbiAvLyBsZW5ndGggb2YgbmV3IGVsZW1lbnQKCWxvYWQgMjUzIC8vIGVsZW1lbnQgbGVuZ3RoCgk8CglibnogKnN3YXBwZWRfZGlmZmVyZW5jZQoJbG9hZCAyNTIgLy8gbmV3IGVsZW1lbnQKCWxlbiAvLyBsZW5ndGggb2YgbmV3IGVsZW1lbnQKCWxvYWQgMjUzIC8vIGVsZW1lbnQgbGVuZ3RoCglwdXNoaW50IDEKCXN0b3JlIDI0OSAvLyBzdWJ0cmFjdCBoZWFkIGRpZmZlcmVuY2UKCWIgKmdldF9kaWZmZXJlbmNlCgoqc3dhcHBlZF9kaWZmZXJlbmNlOgoJbG9hZCAyNTMgLy8gZWxlbWVudCBsZW5ndGgKCWxvYWQgMjUyIC8vIG5ldyBlbGVtZW50CglsZW4gLy8gbGVuZ3RoIG9mIG5ldyBlbGVtZW50CglwdXNoaW50IDAKCXN0b3JlIDI0OSAvLyBzdWJ0cmFjdCBoZWFkIGRpZmZlcmVuY2UKCipnZXRfZGlmZmVyZW5jZToKCS0gLy8gZ2V0IGxlbmd0aCBkaWZmZXJlbmNlCglzdG9yZSAyNTAgLy8gbGVuZ3RoIGRpZmZlcmVuY2UKCXJldHN1Yg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestUpdateNamedTuple.approval.teal b/tests/contracts/artifacts/ABITestUpdateNamedTuple.approval.teal index 1b37f2ce1..21e34b593 100644 --- a/tests/contracts/artifacts/ABITestUpdateNamedTuple.approval.teal +++ b/tests/contracts/artifacts/ABITestUpdateNamedTuple.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x000c48656c6c6f20576f726c6421 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestUpdateNamedTuple.arc32.json b/tests/contracts/artifacts/ABITestUpdateNamedTuple.arc32.json index 31ad0d940..0c8f1b042 100644 --- a/tests/contracts/artifacts/ABITestUpdateNamedTuple.arc32.json +++ b/tests/contracts/artifacts/ABITestUpdateNamedTuple.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgwMDBjNDg2NTZjNmM2ZjIwNTc2ZjcyNmM2NDIxIDB4CgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdXBkYXRlTmFtZWRUdXBsZSgpc3RyaW5nCiphYmlfcm91dGVfdXBkYXRlTmFtZWRUdXBsZToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHVwZGF0ZU5hbWVkVHVwbGUoKXN0cmluZwoJY2FsbHN1YiB1cGRhdGVOYW1lZFR1cGxlCglkdXAKCWxlbgoJaXRvYgoJZXh0cmFjdCA2IDIKCXN3YXAKCWNvbmNhdAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyB1cGRhdGVOYW1lZFR1cGxlKCk6IHN0cmluZwp1cGRhdGVOYW1lZFR1cGxlOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCWJ5dGUgMHgKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NjE2CgkvLyBhOiB7CgkvLyAgICAgICBmb286IHVpbnQxNjsKCS8vICAgICAgIGJhcjogc3RyaW5nOwoJLy8gICAgIH0gPSB7CgkvLyAgICAgICBmb286IDEsCgkvLyAgICAgICBiYXI6ICdIaT8nLAoJLy8gICAgIH0KCWJ5dGUgMHggLy8gaW5pdGlhbCBoZWFkCglieXRlIDB4IC8vIGluaXRpYWwgdGFpbAoJcHVzaGJ5dGVzIDB4MDAwNCAvLyBpbml0aWFsIGhlYWQgb2Zmc2V0CglwdXNoYnl0ZXMgMHgwMDAxCgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAzNDg2OTNmCgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcG9wIC8vIHBvcCBoZWFkIG9mZnNldAoJY29uY2F0IC8vIGNvbmNhdCBoZWFkIGFuZCB0YWlsCglmcmFtZV9idXJ5IDAgLy8gYTogeyAgICAgICBmb286IHVpbnQxNjsgICAgICAgYmFyOiBzdHJpbmc7ICAgICB9CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjYyNAoJLy8gYS5iYXIgPSAnSGVsbG8gV29ybGQhJwoJZnJhbWVfZGlnIDAgLy8gYTogeyAgICAgICBmb286IHVpbnQxNjsgICAgICAgYmFyOiBzdHJpbmc7ICAgICB9CglzdG9yZSAyNTUgLy8gZnVsbCBhcnJheQoJcHVzaGludCAyCglkdXAKCXN0b3JlIDI1MSAvLyBlbGVtZW50IGhlYWQgb2Zmc2V0Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cgl1bmNvdmVyIDIKCWV4dHJhY3RfdWludDE2CglkdXAKCXN0b3JlIDI1NCAvLyBlbGVtZW50IHN0YXJ0CglkdXAgLy8gZHVwbGljYXRlIHN0YXJ0IG9mIGVsZW1lbnQKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXN3YXAKCWV4dHJhY3RfdWludDE2IC8vIGdldCBudW1iZXIgb2YgZWxlbWVudHMKCXB1c2hpbnQgMSAvLyBnZXQgdHlwZSBsZW5ndGgKCSogLy8gbXVsdGlwbHkgYnkgdHlwZSBsZW5ndGgKCXB1c2hpbnQgMgoJKyAvLyBhZGQgdHdvIGZvciBsZW5ndGgKCXN0b3JlIDI1MyAvLyBlbGVtZW50IGxlbmd0aAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJcHVzaGludCAwCglsb2FkIDI1NCAvLyBlbGVtZW50IHN0YXJ0CglzdWJzdHJpbmczCglieXRlIDB4MDAwYzQ4NjU2YzZjNmYyMDU3NmY3MjZjNjQyMQoJZHVwCglzdG9yZSAyNTIgLy8gbmV3IGVsZW1lbnQKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU0IC8vIGVsZW1lbnQgc3RhcnQKCWxvYWQgMjUzIC8vIGVsZW1lbnQgbGVuZ3RoCgkrIC8vIGdldCBlbmQgb2YgRWxlbWVudAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJbGVuCglzdWJzdHJpbmczCgljb25jYXQKCWNvbmNhdAoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWNhbGxzdWIgKmdldF9sZW5ndGhfZGlmZmVyZW5jZQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJZnJhbWVfYnVyeSAwIC8vIGE6IHsgICAgICAgZm9vOiB1aW50MTY7ICAgICAgIGJhcjogc3RyaW5nOyAgICAgfQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo2MjYKCS8vIHJldHVybiBhLmJhcjsKCWZyYW1lX2RpZyAwIC8vIGE6IHsgICAgICAgZm9vOiB1aW50MTY7ICAgICAgIGJhcjogc3RyaW5nOyAgICAgfQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgMgoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJdW5jb3ZlciAyCglleHRyYWN0X3VpbnQxNgoJZHVwIC8vIGR1cGxpY2F0ZSBzdGFydCBvZiBlbGVtZW50Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglzd2FwCglleHRyYWN0X3VpbnQxNiAvLyBnZXQgbnVtYmVyIG9mIGVsZW1lbnRzCglwdXNoaW50IDEgLy8gZ2V0IHR5cGUgbGVuZ3RoCgkqIC8vIG11bHRpcGx5IGJ5IHR5cGUgbGVuZ3RoCglwdXNoaW50IDIKCSsgLy8gYWRkIHR3byBmb3IgbGVuZ3RoCglleHRyYWN0MwoJZXh0cmFjdCAyIDAKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MmQ5Njk2OWEgLy8gbWV0aG9kICJ1cGRhdGVOYW1lZFR1cGxlKClzdHJpbmciCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3VwZGF0ZU5hbWVkVHVwbGUKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnIKCipwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50OgoJcHJvdG8gNCAzCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0xIC8vIGVsZW1lbnQKCWNvbmNhdAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3ViCgoqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCWNvbmNhdAoJZnJhbWVfYnVyeSAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJZHVwCglsZW4KCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJYnRvaQoJKwoJaXRvYgoJZXh0cmFjdCA2IDIKCWZyYW1lX2J1cnkgLTIgLy8gaGVhZCBvZmZzZXQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglzd2FwCgljb25jYXQKCWZyYW1lX2J1cnkgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCXJldHN1YgoKKmdldF9sZW5ndGhfZGlmZmVyZW5jZToKCWxvYWQgMjUyIC8vIG5ldyBlbGVtZW50CglsZW4gLy8gbGVuZ3RoIG9mIG5ldyBlbGVtZW50Cglsb2FkIDI1MyAvLyBlbGVtZW50IGxlbmd0aAoJPAoJYm56ICpzd2FwcGVkX2RpZmZlcmVuY2UKCWxvYWQgMjUyIC8vIG5ldyBlbGVtZW50CglsZW4gLy8gbGVuZ3RoIG9mIG5ldyBlbGVtZW50Cglsb2FkIDI1MyAvLyBlbGVtZW50IGxlbmd0aAoJcHVzaGludCAxCglzdG9yZSAyNDkgLy8gc3VidHJhY3QgaGVhZCBkaWZmZXJlbmNlCgliICpnZXRfZGlmZmVyZW5jZQoKKnN3YXBwZWRfZGlmZmVyZW5jZToKCWxvYWQgMjUzIC8vIGVsZW1lbnQgbGVuZ3RoCglsb2FkIDI1MiAvLyBuZXcgZWxlbWVudAoJbGVuIC8vIGxlbmd0aCBvZiBuZXcgZWxlbWVudAoJcHVzaGludCAwCglzdG9yZSAyNDkgLy8gc3VidHJhY3QgaGVhZCBkaWZmZXJlbmNlCgoqZ2V0X2RpZmZlcmVuY2U6CgktIC8vIGdldCBsZW5ndGggZGlmZmVyZW5jZQoJc3RvcmUgMjUwIC8vIGxlbmd0aCBkaWZmZXJlbmNlCglyZXRzdWI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgwMDBjNDg2NTZjNmM2ZjIwNTc2ZjcyNmM2NDIxIDB4CgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdXBkYXRlTmFtZWRUdXBsZSgpc3RyaW5nCiphYmlfcm91dGVfdXBkYXRlTmFtZWRUdXBsZToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHVwZGF0ZU5hbWVkVHVwbGUoKXN0cmluZwoJY2FsbHN1YiB1cGRhdGVOYW1lZFR1cGxlCglkdXAKCWxlbgoJaXRvYgoJZXh0cmFjdCA2IDIKCXN3YXAKCWNvbmNhdAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyB1cGRhdGVOYW1lZFR1cGxlKCk6IHN0cmluZwp1cGRhdGVOYW1lZFR1cGxlOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCWJ5dGUgMHgKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NjE2CgkvLyBhOiB7CgkvLyAgICAgICBmb286IHVpbnQxNjsKCS8vICAgICAgIGJhcjogc3RyaW5nOwoJLy8gICAgIH0gPSB7CgkvLyAgICAgICBmb286IDEsCgkvLyAgICAgICBiYXI6ICdIaT8nLAoJLy8gICAgIH0KCWJ5dGUgMHggLy8gaW5pdGlhbCBoZWFkCglieXRlIDB4IC8vIGluaXRpYWwgdGFpbAoJcHVzaGJ5dGVzIDB4MDAwNCAvLyBpbml0aWFsIGhlYWQgb2Zmc2V0CglwdXNoYnl0ZXMgMHgwMDAxCgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAzNDg2OTNmCgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcG9wIC8vIHBvcCBoZWFkIG9mZnNldAoJY29uY2F0IC8vIGNvbmNhdCBoZWFkIGFuZCB0YWlsCglmcmFtZV9idXJ5IDAgLy8gYTogeyAgICAgICBmb286IHVpbnQxNjsgICAgICAgYmFyOiBzdHJpbmc7ICAgICB9CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjYyNAoJLy8gYS5iYXIgPSAnSGVsbG8gV29ybGQhJwoJZnJhbWVfZGlnIDAgLy8gYTogeyAgICAgICBmb286IHVpbnQxNjsgICAgICAgYmFyOiBzdHJpbmc7ICAgICB9CglzdG9yZSAyNTUgLy8gZnVsbCBhcnJheQoJcHVzaGludCAyCglkdXAKCXN0b3JlIDI1MSAvLyBlbGVtZW50IGhlYWQgb2Zmc2V0Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cgl1bmNvdmVyIDIKCWV4dHJhY3RfdWludDE2CglkdXAKCXN0b3JlIDI1NCAvLyBlbGVtZW50IHN0YXJ0CglkdXAgLy8gZHVwbGljYXRlIHN0YXJ0IG9mIGVsZW1lbnQKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXN3YXAKCWV4dHJhY3RfdWludDE2IC8vIGdldCBudW1iZXIgb2YgZWxlbWVudHMKCXB1c2hpbnQgMSAvLyBnZXQgdHlwZSBsZW5ndGgKCSogLy8gbXVsdGlwbHkgYnkgdHlwZSBsZW5ndGgKCXB1c2hpbnQgMgoJKyAvLyBhZGQgdHdvIGZvciBsZW5ndGgKCXN0b3JlIDI1MyAvLyBlbGVtZW50IGxlbmd0aAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJcHVzaGludCAwCglsb2FkIDI1NCAvLyBlbGVtZW50IHN0YXJ0CglzdWJzdHJpbmczCglieXRlIDB4MDAwYzQ4NjU2YzZjNmYyMDU3NmY3MjZjNjQyMQoJZHVwCglzdG9yZSAyNTIgLy8gbmV3IGVsZW1lbnQKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU0IC8vIGVsZW1lbnQgc3RhcnQKCWxvYWQgMjUzIC8vIGVsZW1lbnQgbGVuZ3RoCgkrIC8vIGdldCBlbmQgb2YgRWxlbWVudAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJbGVuCglzdWJzdHJpbmczCgljb25jYXQKCWNvbmNhdAoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWNhbGxzdWIgKmdldF9sZW5ndGhfZGlmZmVyZW5jZQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJZnJhbWVfYnVyeSAwIC8vIGE6IHsgICAgICAgZm9vOiB1aW50MTY7ICAgICAgIGJhcjogc3RyaW5nOyAgICAgfQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo2MjYKCS8vIHJldHVybiBhLmJhcjsKCWZyYW1lX2RpZyAwIC8vIGE6IHsgICAgICAgZm9vOiB1aW50MTY7ICAgICAgIGJhcjogc3RyaW5nOyAgICAgfQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgMgoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJdW5jb3ZlciAyCglleHRyYWN0X3VpbnQxNgoJZHVwIC8vIGR1cGxpY2F0ZSBzdGFydCBvZiBlbGVtZW50Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglzd2FwCglleHRyYWN0X3VpbnQxNiAvLyBnZXQgbnVtYmVyIG9mIGVsZW1lbnRzCglwdXNoaW50IDEgLy8gZ2V0IHR5cGUgbGVuZ3RoCgkqIC8vIG11bHRpcGx5IGJ5IHR5cGUgbGVuZ3RoCglwdXNoaW50IDIKCSsgLy8gYWRkIHR3byBmb3IgbGVuZ3RoCglleHRyYWN0MwoJZXh0cmFjdCAyIDAKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MmQ5Njk2OWEgLy8gbWV0aG9kICJ1cGRhdGVOYW1lZFR1cGxlKClzdHJpbmciCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3VwZGF0ZU5hbWVkVHVwbGUKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnIKCipwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50OgoJcHJvdG8gNCAzCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0xIC8vIGVsZW1lbnQKCWNvbmNhdAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3ViCgoqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCWNvbmNhdAoJZnJhbWVfYnVyeSAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJZHVwCglsZW4KCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJYnRvaQoJKwoJaXRvYgoJZXh0cmFjdCA2IDIKCWZyYW1lX2J1cnkgLTIgLy8gaGVhZCBvZmZzZXQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglzd2FwCgljb25jYXQKCWZyYW1lX2J1cnkgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCXJldHN1YgoKKmdldF9sZW5ndGhfZGlmZmVyZW5jZToKCWxvYWQgMjUyIC8vIG5ldyBlbGVtZW50CglsZW4gLy8gbGVuZ3RoIG9mIG5ldyBlbGVtZW50Cglsb2FkIDI1MyAvLyBlbGVtZW50IGxlbmd0aAoJPAoJYm56ICpzd2FwcGVkX2RpZmZlcmVuY2UKCWxvYWQgMjUyIC8vIG5ldyBlbGVtZW50CglsZW4gLy8gbGVuZ3RoIG9mIG5ldyBlbGVtZW50Cglsb2FkIDI1MyAvLyBlbGVtZW50IGxlbmd0aAoJcHVzaGludCAxCglzdG9yZSAyNDkgLy8gc3VidHJhY3QgaGVhZCBkaWZmZXJlbmNlCgliICpnZXRfZGlmZmVyZW5jZQoKKnN3YXBwZWRfZGlmZmVyZW5jZToKCWxvYWQgMjUzIC8vIGVsZW1lbnQgbGVuZ3RoCglsb2FkIDI1MiAvLyBuZXcgZWxlbWVudAoJbGVuIC8vIGxlbmd0aCBvZiBuZXcgZWxlbWVudAoJcHVzaGludCAwCglzdG9yZSAyNDkgLy8gc3VidHJhY3QgaGVhZCBkaWZmZXJlbmNlCgoqZ2V0X2RpZmZlcmVuY2U6CgktIC8vIGdldCBsZW5ndGggZGlmZmVyZW5jZQoJc3RvcmUgMjUwIC8vIGxlbmd0aCBkaWZmZXJlbmNlCglyZXRzdWI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestUpdateNamedTuple.arc56_draft.json b/tests/contracts/artifacts/ABITestUpdateNamedTuple.arc56_draft.json index 45cc58972..19e155772 100644 --- a/tests/contracts/artifacts/ABITestUpdateNamedTuple.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestUpdateNamedTuple.arc56_draft.json @@ -1318,7 +1318,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgwMDBjNDg2NTZjNmM2ZjIwNTc2ZjcyNmM2NDIxIDB4CgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdXBkYXRlTmFtZWRUdXBsZSgpc3RyaW5nCiphYmlfcm91dGVfdXBkYXRlTmFtZWRUdXBsZToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHVwZGF0ZU5hbWVkVHVwbGUoKXN0cmluZwoJY2FsbHN1YiB1cGRhdGVOYW1lZFR1cGxlCglkdXAKCWxlbgoJaXRvYgoJZXh0cmFjdCA2IDIKCXN3YXAKCWNvbmNhdAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyB1cGRhdGVOYW1lZFR1cGxlKCk6IHN0cmluZwp1cGRhdGVOYW1lZFR1cGxlOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCWJ5dGUgMHgKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NjE2CgkvLyBhOiB7CgkvLyAgICAgICBmb286IHVpbnQxNjsKCS8vICAgICAgIGJhcjogc3RyaW5nOwoJLy8gICAgIH0gPSB7CgkvLyAgICAgICBmb286IDEsCgkvLyAgICAgICBiYXI6ICdIaT8nLAoJLy8gICAgIH0KCWJ5dGUgMHggLy8gaW5pdGlhbCBoZWFkCglieXRlIDB4IC8vIGluaXRpYWwgdGFpbAoJcHVzaGJ5dGVzIDB4MDAwNCAvLyBpbml0aWFsIGhlYWQgb2Zmc2V0CglwdXNoYnl0ZXMgMHgwMDAxCgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAzNDg2OTNmCgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcG9wIC8vIHBvcCBoZWFkIG9mZnNldAoJY29uY2F0IC8vIGNvbmNhdCBoZWFkIGFuZCB0YWlsCglmcmFtZV9idXJ5IDAgLy8gYTogeyAgICAgICBmb286IHVpbnQxNjsgICAgICAgYmFyOiBzdHJpbmc7ICAgICB9CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjYyNAoJLy8gYS5iYXIgPSAnSGVsbG8gV29ybGQhJwoJZnJhbWVfZGlnIDAgLy8gYTogeyAgICAgICBmb286IHVpbnQxNjsgICAgICAgYmFyOiBzdHJpbmc7ICAgICB9CglzdG9yZSAyNTUgLy8gZnVsbCBhcnJheQoJcHVzaGludCAyCglkdXAKCXN0b3JlIDI1MSAvLyBlbGVtZW50IGhlYWQgb2Zmc2V0Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cgl1bmNvdmVyIDIKCWV4dHJhY3RfdWludDE2CglkdXAKCXN0b3JlIDI1NCAvLyBlbGVtZW50IHN0YXJ0CglkdXAgLy8gZHVwbGljYXRlIHN0YXJ0IG9mIGVsZW1lbnQKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXN3YXAKCWV4dHJhY3RfdWludDE2IC8vIGdldCBudW1iZXIgb2YgZWxlbWVudHMKCXB1c2hpbnQgMSAvLyBnZXQgdHlwZSBsZW5ndGgKCSogLy8gbXVsdGlwbHkgYnkgdHlwZSBsZW5ndGgKCXB1c2hpbnQgMgoJKyAvLyBhZGQgdHdvIGZvciBsZW5ndGgKCXN0b3JlIDI1MyAvLyBlbGVtZW50IGxlbmd0aAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJcHVzaGludCAwCglsb2FkIDI1NCAvLyBlbGVtZW50IHN0YXJ0CglzdWJzdHJpbmczCglieXRlIDB4MDAwYzQ4NjU2YzZjNmYyMDU3NmY3MjZjNjQyMQoJZHVwCglzdG9yZSAyNTIgLy8gbmV3IGVsZW1lbnQKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU0IC8vIGVsZW1lbnQgc3RhcnQKCWxvYWQgMjUzIC8vIGVsZW1lbnQgbGVuZ3RoCgkrIC8vIGdldCBlbmQgb2YgRWxlbWVudAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJbGVuCglzdWJzdHJpbmczCgljb25jYXQKCWNvbmNhdAoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWNhbGxzdWIgKmdldF9sZW5ndGhfZGlmZmVyZW5jZQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJZnJhbWVfYnVyeSAwIC8vIGE6IHsgICAgICAgZm9vOiB1aW50MTY7ICAgICAgIGJhcjogc3RyaW5nOyAgICAgfQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo2MjYKCS8vIHJldHVybiBhLmJhcjsKCWZyYW1lX2RpZyAwIC8vIGE6IHsgICAgICAgZm9vOiB1aW50MTY7ICAgICAgIGJhcjogc3RyaW5nOyAgICAgfQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgMgoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJdW5jb3ZlciAyCglleHRyYWN0X3VpbnQxNgoJZHVwIC8vIGR1cGxpY2F0ZSBzdGFydCBvZiBlbGVtZW50Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglzd2FwCglleHRyYWN0X3VpbnQxNiAvLyBnZXQgbnVtYmVyIG9mIGVsZW1lbnRzCglwdXNoaW50IDEgLy8gZ2V0IHR5cGUgbGVuZ3RoCgkqIC8vIG11bHRpcGx5IGJ5IHR5cGUgbGVuZ3RoCglwdXNoaW50IDIKCSsgLy8gYWRkIHR3byBmb3IgbGVuZ3RoCglleHRyYWN0MwoJZXh0cmFjdCAyIDAKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MmQ5Njk2OWEgLy8gbWV0aG9kICJ1cGRhdGVOYW1lZFR1cGxlKClzdHJpbmciCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3VwZGF0ZU5hbWVkVHVwbGUKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnIKCipwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50OgoJcHJvdG8gNCAzCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0xIC8vIGVsZW1lbnQKCWNvbmNhdAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3ViCgoqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCWNvbmNhdAoJZnJhbWVfYnVyeSAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJZHVwCglsZW4KCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJYnRvaQoJKwoJaXRvYgoJZXh0cmFjdCA2IDIKCWZyYW1lX2J1cnkgLTIgLy8gaGVhZCBvZmZzZXQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglzd2FwCgljb25jYXQKCWZyYW1lX2J1cnkgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCXJldHN1YgoKKmdldF9sZW5ndGhfZGlmZmVyZW5jZToKCWxvYWQgMjUyIC8vIG5ldyBlbGVtZW50CglsZW4gLy8gbGVuZ3RoIG9mIG5ldyBlbGVtZW50Cglsb2FkIDI1MyAvLyBlbGVtZW50IGxlbmd0aAoJPAoJYm56ICpzd2FwcGVkX2RpZmZlcmVuY2UKCWxvYWQgMjUyIC8vIG5ldyBlbGVtZW50CglsZW4gLy8gbGVuZ3RoIG9mIG5ldyBlbGVtZW50Cglsb2FkIDI1MyAvLyBlbGVtZW50IGxlbmd0aAoJcHVzaGludCAxCglzdG9yZSAyNDkgLy8gc3VidHJhY3QgaGVhZCBkaWZmZXJlbmNlCgliICpnZXRfZGlmZmVyZW5jZQoKKnN3YXBwZWRfZGlmZmVyZW5jZToKCWxvYWQgMjUzIC8vIGVsZW1lbnQgbGVuZ3RoCglsb2FkIDI1MiAvLyBuZXcgZWxlbWVudAoJbGVuIC8vIGxlbmd0aCBvZiBuZXcgZWxlbWVudAoJcHVzaGludCAwCglzdG9yZSAyNDkgLy8gc3VidHJhY3QgaGVhZCBkaWZmZXJlbmNlCgoqZ2V0X2RpZmZlcmVuY2U6CgktIC8vIGdldCBsZW5ndGggZGlmZmVyZW5jZQoJc3RvcmUgMjUwIC8vIGxlbmd0aCBkaWZmZXJlbmNlCglyZXRzdWI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgwMDBjNDg2NTZjNmM2ZjIwNTc2ZjcyNmM2NDIxIDB4CgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdXBkYXRlTmFtZWRUdXBsZSgpc3RyaW5nCiphYmlfcm91dGVfdXBkYXRlTmFtZWRUdXBsZToKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHVwZGF0ZU5hbWVkVHVwbGUoKXN0cmluZwoJY2FsbHN1YiB1cGRhdGVOYW1lZFR1cGxlCglkdXAKCWxlbgoJaXRvYgoJZXh0cmFjdCA2IDIKCXN3YXAKCWNvbmNhdAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyB1cGRhdGVOYW1lZFR1cGxlKCk6IHN0cmluZwp1cGRhdGVOYW1lZFR1cGxlOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCWJ5dGUgMHgKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6NjE2CgkvLyBhOiB7CgkvLyAgICAgICBmb286IHVpbnQxNjsKCS8vICAgICAgIGJhcjogc3RyaW5nOwoJLy8gICAgIH0gPSB7CgkvLyAgICAgICBmb286IDEsCgkvLyAgICAgICBiYXI6ICdIaT8nLAoJLy8gICAgIH0KCWJ5dGUgMHggLy8gaW5pdGlhbCBoZWFkCglieXRlIDB4IC8vIGluaXRpYWwgdGFpbAoJcHVzaGJ5dGVzIDB4MDAwNCAvLyBpbml0aWFsIGhlYWQgb2Zmc2V0CglwdXNoYnl0ZXMgMHgwMDAxCgljYWxsc3ViICpwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50CglwdXNoYnl0ZXMgMHgwMDAzNDg2OTNmCgljYWxsc3ViICpwcm9jZXNzX2R5bmFtaWNfdHVwbGVfZWxlbWVudAoJcG9wIC8vIHBvcCBoZWFkIG9mZnNldAoJY29uY2F0IC8vIGNvbmNhdCBoZWFkIGFuZCB0YWlsCglmcmFtZV9idXJ5IDAgLy8gYTogeyAgICAgICBmb286IHVpbnQxNjsgICAgICAgYmFyOiBzdHJpbmc7ICAgICB9CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjYyNAoJLy8gYS5iYXIgPSAnSGVsbG8gV29ybGQhJwoJZnJhbWVfZGlnIDAgLy8gYTogeyAgICAgICBmb286IHVpbnQxNjsgICAgICAgYmFyOiBzdHJpbmc7ICAgICB9CglzdG9yZSAyNTUgLy8gZnVsbCBhcnJheQoJcHVzaGludCAyCglkdXAKCXN0b3JlIDI1MSAvLyBlbGVtZW50IGhlYWQgb2Zmc2V0Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cgl1bmNvdmVyIDIKCWV4dHJhY3RfdWludDE2CglkdXAKCXN0b3JlIDI1NCAvLyBlbGVtZW50IHN0YXJ0CglkdXAgLy8gZHVwbGljYXRlIHN0YXJ0IG9mIGVsZW1lbnQKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXN3YXAKCWV4dHJhY3RfdWludDE2IC8vIGdldCBudW1iZXIgb2YgZWxlbWVudHMKCXB1c2hpbnQgMSAvLyBnZXQgdHlwZSBsZW5ndGgKCSogLy8gbXVsdGlwbHkgYnkgdHlwZSBsZW5ndGgKCXB1c2hpbnQgMgoJKyAvLyBhZGQgdHdvIGZvciBsZW5ndGgKCXN0b3JlIDI1MyAvLyBlbGVtZW50IGxlbmd0aAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJcHVzaGludCAwCglsb2FkIDI1NCAvLyBlbGVtZW50IHN0YXJ0CglzdWJzdHJpbmczCglieXRlIDB4MDAwYzQ4NjU2YzZjNmYyMDU3NmY3MjZjNjQyMQoJZHVwCglzdG9yZSAyNTIgLy8gbmV3IGVsZW1lbnQKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU0IC8vIGVsZW1lbnQgc3RhcnQKCWxvYWQgMjUzIC8vIGVsZW1lbnQgbGVuZ3RoCgkrIC8vIGdldCBlbmQgb2YgRWxlbWVudAoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJbGVuCglzdWJzdHJpbmczCgljb25jYXQKCWNvbmNhdAoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWNhbGxzdWIgKmdldF9sZW5ndGhfZGlmZmVyZW5jZQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJZnJhbWVfYnVyeSAwIC8vIGE6IHsgICAgICAgZm9vOiB1aW50MTY7ICAgICAgIGJhcjogc3RyaW5nOyAgICAgfQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czo2MjYKCS8vIHJldHVybiBhLmJhcjsKCWZyYW1lX2RpZyAwIC8vIGE6IHsgICAgICAgZm9vOiB1aW50MTY7ICAgICAgIGJhcjogc3RyaW5nOyAgICAgfQoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgMgoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJdW5jb3ZlciAyCglleHRyYWN0X3VpbnQxNgoJZHVwIC8vIGR1cGxpY2F0ZSBzdGFydCBvZiBlbGVtZW50Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglzd2FwCglleHRyYWN0X3VpbnQxNiAvLyBnZXQgbnVtYmVyIG9mIGVsZW1lbnRzCglwdXNoaW50IDEgLy8gZ2V0IHR5cGUgbGVuZ3RoCgkqIC8vIG11bHRpcGx5IGJ5IHR5cGUgbGVuZ3RoCglwdXNoaW50IDIKCSsgLy8gYWRkIHR3byBmb3IgbGVuZ3RoCglleHRyYWN0MwoJZXh0cmFjdCAyIDAKCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MmQ5Njk2OWEgLy8gbWV0aG9kICJ1cGRhdGVOYW1lZFR1cGxlKClzdHJpbmciCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3VwZGF0ZU5hbWVkVHVwbGUKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnIKCipwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50OgoJcHJvdG8gNCAzCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0xIC8vIGVsZW1lbnQKCWNvbmNhdAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3ViCgoqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCWNvbmNhdAoJZnJhbWVfYnVyeSAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJZHVwCglsZW4KCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJYnRvaQoJKwoJaXRvYgoJZXh0cmFjdCA2IDIKCWZyYW1lX2J1cnkgLTIgLy8gaGVhZCBvZmZzZXQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglzd2FwCgljb25jYXQKCWZyYW1lX2J1cnkgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCXJldHN1YgoKKmdldF9sZW5ndGhfZGlmZmVyZW5jZToKCWxvYWQgMjUyIC8vIG5ldyBlbGVtZW50CglsZW4gLy8gbGVuZ3RoIG9mIG5ldyBlbGVtZW50Cglsb2FkIDI1MyAvLyBlbGVtZW50IGxlbmd0aAoJPAoJYm56ICpzd2FwcGVkX2RpZmZlcmVuY2UKCWxvYWQgMjUyIC8vIG5ldyBlbGVtZW50CglsZW4gLy8gbGVuZ3RoIG9mIG5ldyBlbGVtZW50Cglsb2FkIDI1MyAvLyBlbGVtZW50IGxlbmd0aAoJcHVzaGludCAxCglzdG9yZSAyNDkgLy8gc3VidHJhY3QgaGVhZCBkaWZmZXJlbmNlCgliICpnZXRfZGlmZmVyZW5jZQoKKnN3YXBwZWRfZGlmZmVyZW5jZToKCWxvYWQgMjUzIC8vIGVsZW1lbnQgbGVuZ3RoCglsb2FkIDI1MiAvLyBuZXcgZWxlbWVudAoJbGVuIC8vIGxlbmd0aCBvZiBuZXcgZWxlbWVudAoJcHVzaGludCAwCglzdG9yZSAyNDkgLy8gc3VidHJhY3QgaGVhZCBkaWZmZXJlbmNlCgoqZ2V0X2RpZmZlcmVuY2U6CgktIC8vIGdldCBsZW5ndGggZGlmZmVyZW5jZQoJc3RvcmUgMjUwIC8vIGxlbmd0aCBkaWZmZXJlbmNlCglyZXRzdWI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestUpdateNestedStaticArray.approval.teal b/tests/contracts/artifacts/ABITestUpdateNestedStaticArray.approval.teal index f6576c406..9f888ed99 100644 --- a/tests/contracts/artifacts/ABITestUpdateNestedStaticArray.approval.teal +++ b/tests/contracts/artifacts/ABITestUpdateNestedStaticArray.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestUpdateNestedStaticArray.arc32.json b/tests/contracts/artifacts/ABITestUpdateNestedStaticArray.arc32.json index 0f92b94b6..9c8bfc87d 100644 --- a/tests/contracts/artifacts/ABITestUpdateNestedStaticArray.arc32.json +++ b/tests/contracts/artifacts/ABITestUpdateNestedStaticArray.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdXBkYXRlTmVzdGVkU3RhdGljQXJyYXkoKXVpbnQ2NAoqYWJpX3JvdXRlX3VwZGF0ZU5lc3RlZFN0YXRpY0FycmF5OgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgdXBkYXRlTmVzdGVkU3RhdGljQXJyYXkoKXVpbnQ2NAoJY2FsbHN1YiB1cGRhdGVOZXN0ZWRTdGF0aWNBcnJheQoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyB1cGRhdGVOZXN0ZWRTdGF0aWNBcnJheSgpOiB1aW50NjQKdXBkYXRlTmVzdGVkU3RhdGljQXJyYXk6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjIyNAoJLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDY0LCAzPiwgMz4gPSBbCgkvLyAgICAgICBbMTEsIDIyLCAzM10sCgkvLyAgICAgICBbNDQsIDU1LCA2Nl0sCgkvLyAgICAgICBbNzcsIDg4LCA5OV0sCgkvLyAgICAgXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwYjAwMDAwMDAwMDAwMDAwMTYwMDAwMDAwMDAwMDAwMDIxMDAwMDAwMDAwMDAwMDAyYzAwMDAwMDAwMDAwMDAwMzcwMDAwMDAwMDAwMDAwMDQyMDAwMDAwMDAwMDAwMDA0ZDAwMDAwMDAwMDAwMDAwNTgwMDAwMDAwMDAwMDAwMDYzCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDY0LCAzPiwgMz4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MjMwCgkvLyBhWzFdID0gWzQ0NCwgNTU1LCA2NjZdCglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50NjQsIDM+LCAzPgoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDFiYzAwMDAwMDAwMDAwMDAyMmIwMDAwMDAwMDAwMDAwMjlhCglyZXBsYWNlMiAyNAoJZnJhbWVfYnVyeSAwIC8vIGE6IFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4sIDM+CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjIzMgoJLy8gcmV0dXJuIGFbMV1bMV07CglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50NjQsIDM+LCAzPgoJZXh0cmFjdCAzMiA4CglidG9pCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDcwNDE0MmViIC8vIG1ldGhvZCAidXBkYXRlTmVzdGVkU3RhdGljQXJyYXkoKXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfdXBkYXRlTmVzdGVkU3RhdGljQXJyYXkKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdXBkYXRlTmVzdGVkU3RhdGljQXJyYXkoKXVpbnQ2NAoqYWJpX3JvdXRlX3VwZGF0ZU5lc3RlZFN0YXRpY0FycmF5OgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgdXBkYXRlTmVzdGVkU3RhdGljQXJyYXkoKXVpbnQ2NAoJY2FsbHN1YiB1cGRhdGVOZXN0ZWRTdGF0aWNBcnJheQoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyB1cGRhdGVOZXN0ZWRTdGF0aWNBcnJheSgpOiB1aW50NjQKdXBkYXRlTmVzdGVkU3RhdGljQXJyYXk6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjIyNAoJLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDY0LCAzPiwgMz4gPSBbCgkvLyAgICAgICBbMTEsIDIyLCAzM10sCgkvLyAgICAgICBbNDQsIDU1LCA2Nl0sCgkvLyAgICAgICBbNzcsIDg4LCA5OV0sCgkvLyAgICAgXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwYjAwMDAwMDAwMDAwMDAwMTYwMDAwMDAwMDAwMDAwMDIxMDAwMDAwMDAwMDAwMDAyYzAwMDAwMDAwMDAwMDAwMzcwMDAwMDAwMDAwMDAwMDQyMDAwMDAwMDAwMDAwMDA0ZDAwMDAwMDAwMDAwMDAwNTgwMDAwMDAwMDAwMDAwMDYzCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDY0LCAzPiwgMz4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MjMwCgkvLyBhWzFdID0gWzQ0NCwgNTU1LCA2NjZdCglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50NjQsIDM+LCAzPgoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDFiYzAwMDAwMDAwMDAwMDAyMmIwMDAwMDAwMDAwMDAwMjlhCglyZXBsYWNlMiAyNAoJZnJhbWVfYnVyeSAwIC8vIGE6IFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4sIDM+CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjIzMgoJLy8gcmV0dXJuIGFbMV1bMV07CglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50NjQsIDM+LCAzPgoJZXh0cmFjdCAzMiA4CglidG9pCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDcwNDE0MmViIC8vIG1ldGhvZCAidXBkYXRlTmVzdGVkU3RhdGljQXJyYXkoKXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfdXBkYXRlTmVzdGVkU3RhdGljQXJyYXkKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestUpdateNestedStaticArray.arc56_draft.json b/tests/contracts/artifacts/ABITestUpdateNestedStaticArray.arc56_draft.json index e44916a66..0abc52ed2 100644 --- a/tests/contracts/artifacts/ABITestUpdateNestedStaticArray.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestUpdateNestedStaticArray.arc56_draft.json @@ -514,7 +514,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdXBkYXRlTmVzdGVkU3RhdGljQXJyYXkoKXVpbnQ2NAoqYWJpX3JvdXRlX3VwZGF0ZU5lc3RlZFN0YXRpY0FycmF5OgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgdXBkYXRlTmVzdGVkU3RhdGljQXJyYXkoKXVpbnQ2NAoJY2FsbHN1YiB1cGRhdGVOZXN0ZWRTdGF0aWNBcnJheQoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyB1cGRhdGVOZXN0ZWRTdGF0aWNBcnJheSgpOiB1aW50NjQKdXBkYXRlTmVzdGVkU3RhdGljQXJyYXk6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjIyNAoJLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDY0LCAzPiwgMz4gPSBbCgkvLyAgICAgICBbMTEsIDIyLCAzM10sCgkvLyAgICAgICBbNDQsIDU1LCA2Nl0sCgkvLyAgICAgICBbNzcsIDg4LCA5OV0sCgkvLyAgICAgXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwYjAwMDAwMDAwMDAwMDAwMTYwMDAwMDAwMDAwMDAwMDIxMDAwMDAwMDAwMDAwMDAyYzAwMDAwMDAwMDAwMDAwMzcwMDAwMDAwMDAwMDAwMDQyMDAwMDAwMDAwMDAwMDA0ZDAwMDAwMDAwMDAwMDAwNTgwMDAwMDAwMDAwMDAwMDYzCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDY0LCAzPiwgMz4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MjMwCgkvLyBhWzFdID0gWzQ0NCwgNTU1LCA2NjZdCglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50NjQsIDM+LCAzPgoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDFiYzAwMDAwMDAwMDAwMDAyMmIwMDAwMDAwMDAwMDAwMjlhCglyZXBsYWNlMiAyNAoJZnJhbWVfYnVyeSAwIC8vIGE6IFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4sIDM+CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjIzMgoJLy8gcmV0dXJuIGFbMV1bMV07CglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50NjQsIDM+LCAzPgoJZXh0cmFjdCAzMiA4CglidG9pCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDcwNDE0MmViIC8vIG1ldGhvZCAidXBkYXRlTmVzdGVkU3RhdGljQXJyYXkoKXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfdXBkYXRlTmVzdGVkU3RhdGljQXJyYXkKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdXBkYXRlTmVzdGVkU3RhdGljQXJyYXkoKXVpbnQ2NAoqYWJpX3JvdXRlX3VwZGF0ZU5lc3RlZFN0YXRpY0FycmF5OgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgdXBkYXRlTmVzdGVkU3RhdGljQXJyYXkoKXVpbnQ2NAoJY2FsbHN1YiB1cGRhdGVOZXN0ZWRTdGF0aWNBcnJheQoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyB1cGRhdGVOZXN0ZWRTdGF0aWNBcnJheSgpOiB1aW50NjQKdXBkYXRlTmVzdGVkU3RhdGljQXJyYXk6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjIyNAoJLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDY0LCAzPiwgMz4gPSBbCgkvLyAgICAgICBbMTEsIDIyLCAzM10sCgkvLyAgICAgICBbNDQsIDU1LCA2Nl0sCgkvLyAgICAgICBbNzcsIDg4LCA5OV0sCgkvLyAgICAgXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwYjAwMDAwMDAwMDAwMDAwMTYwMDAwMDAwMDAwMDAwMDIxMDAwMDAwMDAwMDAwMDAyYzAwMDAwMDAwMDAwMDAwMzcwMDAwMDAwMDAwMDAwMDQyMDAwMDAwMDAwMDAwMDA0ZDAwMDAwMDAwMDAwMDAwNTgwMDAwMDAwMDAwMDAwMDYzCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDY0LCAzPiwgMz4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MjMwCgkvLyBhWzFdID0gWzQ0NCwgNTU1LCA2NjZdCglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50NjQsIDM+LCAzPgoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDFiYzAwMDAwMDAwMDAwMDAyMmIwMDAwMDAwMDAwMDAwMjlhCglyZXBsYWNlMiAyNAoJZnJhbWVfYnVyeSAwIC8vIGE6IFN0YXRpY0FycmF5PFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4sIDM+CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjIzMgoJLy8gcmV0dXJuIGFbMV1bMV07CglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50NjQsIDM+LCAzPgoJZXh0cmFjdCAzMiA4CglidG9pCgoJLy8gc2V0IHRoZSBzdWJyb3V0aW5lIHJldHVybiB2YWx1ZQoJZnJhbWVfYnVyeSAwCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDcwNDE0MmViIC8vIG1ldGhvZCAidXBkYXRlTmVzdGVkU3RhdGljQXJyYXkoKXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfdXBkYXRlTmVzdGVkU3RhdGljQXJyYXkKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestUpdateNestedStaticArrayElement.approval.teal b/tests/contracts/artifacts/ABITestUpdateNestedStaticArrayElement.approval.teal index 719dd4220..7cb88d9b7 100644 --- a/tests/contracts/artifacts/ABITestUpdateNestedStaticArrayElement.approval.teal +++ b/tests/contracts/artifacts/ABITestUpdateNestedStaticArrayElement.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestUpdateNestedStaticArrayElement.arc32.json b/tests/contracts/artifacts/ABITestUpdateNestedStaticArrayElement.arc32.json index 1d730a25d..418915885 100644 --- a/tests/contracts/artifacts/ABITestUpdateNestedStaticArrayElement.arc32.json +++ b/tests/contracts/artifacts/ABITestUpdateNestedStaticArrayElement.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdXBkYXRlTmVzdGVkU3RhdGljQXJyYXlFbGVtZW50KCl1aW50NjQKKmFiaV9yb3V0ZV91cGRhdGVOZXN0ZWRTdGF0aWNBcnJheUVsZW1lbnQ6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSB1cGRhdGVOZXN0ZWRTdGF0aWNBcnJheUVsZW1lbnQoKXVpbnQ2NAoJY2FsbHN1YiB1cGRhdGVOZXN0ZWRTdGF0aWNBcnJheUVsZW1lbnQKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gdXBkYXRlTmVzdGVkU3RhdGljQXJyYXlFbGVtZW50KCk6IHVpbnQ2NAp1cGRhdGVOZXN0ZWRTdGF0aWNBcnJheUVsZW1lbnQ6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjIxMAoJLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDY0LCAzPiwgMz4gPSBbCgkvLyAgICAgICBbMTEsIDIyLCAzM10sCgkvLyAgICAgICBbNDQsIDU1LCA2Nl0sCgkvLyAgICAgICBbNzcsIDg4LCA5OV0sCgkvLyAgICAgXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwYjAwMDAwMDAwMDAwMDAwMTYwMDAwMDAwMDAwMDAwMDIxMDAwMDAwMDAwMDAwMDAyYzAwMDAwMDAwMDAwMDAwMzcwMDAwMDAwMDAwMDAwMDQyMDAwMDAwMDAwMDAwMDA0ZDAwMDAwMDAwMDAwMDAwNTgwMDAwMDAwMDAwMDAwMDYzCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDY0LCAzPiwgMz4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MjE2CgkvLyBhWzFdWzFdID0gNTU1CglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50NjQsIDM+LCAzPgoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDIyYgoJcmVwbGFjZTIgMzIKCWZyYW1lX2J1cnkgMCAvLyBhOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50NjQsIDM+LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoyMTgKCS8vIHJldHVybiBhWzFdWzFdOwoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDY0LCAzPiwgMz4KCWV4dHJhY3QgMzIgOAoJYnRvaQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhkNjkxMTM1YiAvLyBtZXRob2QgInVwZGF0ZU5lc3RlZFN0YXRpY0FycmF5RWxlbWVudCgpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV91cGRhdGVOZXN0ZWRTdGF0aWNBcnJheUVsZW1lbnQKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdXBkYXRlTmVzdGVkU3RhdGljQXJyYXlFbGVtZW50KCl1aW50NjQKKmFiaV9yb3V0ZV91cGRhdGVOZXN0ZWRTdGF0aWNBcnJheUVsZW1lbnQ6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSB1cGRhdGVOZXN0ZWRTdGF0aWNBcnJheUVsZW1lbnQoKXVpbnQ2NAoJY2FsbHN1YiB1cGRhdGVOZXN0ZWRTdGF0aWNBcnJheUVsZW1lbnQKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gdXBkYXRlTmVzdGVkU3RhdGljQXJyYXlFbGVtZW50KCk6IHVpbnQ2NAp1cGRhdGVOZXN0ZWRTdGF0aWNBcnJheUVsZW1lbnQ6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjIxMAoJLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDY0LCAzPiwgMz4gPSBbCgkvLyAgICAgICBbMTEsIDIyLCAzM10sCgkvLyAgICAgICBbNDQsIDU1LCA2Nl0sCgkvLyAgICAgICBbNzcsIDg4LCA5OV0sCgkvLyAgICAgXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwYjAwMDAwMDAwMDAwMDAwMTYwMDAwMDAwMDAwMDAwMDIxMDAwMDAwMDAwMDAwMDAyYzAwMDAwMDAwMDAwMDAwMzcwMDAwMDAwMDAwMDAwMDQyMDAwMDAwMDAwMDAwMDA0ZDAwMDAwMDAwMDAwMDAwNTgwMDAwMDAwMDAwMDAwMDYzCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDY0LCAzPiwgMz4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MjE2CgkvLyBhWzFdWzFdID0gNTU1CglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50NjQsIDM+LCAzPgoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDIyYgoJcmVwbGFjZTIgMzIKCWZyYW1lX2J1cnkgMCAvLyBhOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50NjQsIDM+LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoyMTgKCS8vIHJldHVybiBhWzFdWzFdOwoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDY0LCAzPiwgMz4KCWV4dHJhY3QgMzIgOAoJYnRvaQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhkNjkxMTM1YiAvLyBtZXRob2QgInVwZGF0ZU5lc3RlZFN0YXRpY0FycmF5RWxlbWVudCgpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV91cGRhdGVOZXN0ZWRTdGF0aWNBcnJheUVsZW1lbnQKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestUpdateNestedStaticArrayElement.arc56_draft.json b/tests/contracts/artifacts/ABITestUpdateNestedStaticArrayElement.arc56_draft.json index f0f5b0985..613124f76 100644 --- a/tests/contracts/artifacts/ABITestUpdateNestedStaticArrayElement.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestUpdateNestedStaticArrayElement.arc56_draft.json @@ -498,7 +498,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdXBkYXRlTmVzdGVkU3RhdGljQXJyYXlFbGVtZW50KCl1aW50NjQKKmFiaV9yb3V0ZV91cGRhdGVOZXN0ZWRTdGF0aWNBcnJheUVsZW1lbnQ6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSB1cGRhdGVOZXN0ZWRTdGF0aWNBcnJheUVsZW1lbnQoKXVpbnQ2NAoJY2FsbHN1YiB1cGRhdGVOZXN0ZWRTdGF0aWNBcnJheUVsZW1lbnQKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gdXBkYXRlTmVzdGVkU3RhdGljQXJyYXlFbGVtZW50KCk6IHVpbnQ2NAp1cGRhdGVOZXN0ZWRTdGF0aWNBcnJheUVsZW1lbnQ6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjIxMAoJLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDY0LCAzPiwgMz4gPSBbCgkvLyAgICAgICBbMTEsIDIyLCAzM10sCgkvLyAgICAgICBbNDQsIDU1LCA2Nl0sCgkvLyAgICAgICBbNzcsIDg4LCA5OV0sCgkvLyAgICAgXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwYjAwMDAwMDAwMDAwMDAwMTYwMDAwMDAwMDAwMDAwMDIxMDAwMDAwMDAwMDAwMDAyYzAwMDAwMDAwMDAwMDAwMzcwMDAwMDAwMDAwMDAwMDQyMDAwMDAwMDAwMDAwMDA0ZDAwMDAwMDAwMDAwMDAwNTgwMDAwMDAwMDAwMDAwMDYzCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDY0LCAzPiwgMz4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MjE2CgkvLyBhWzFdWzFdID0gNTU1CglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50NjQsIDM+LCAzPgoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDIyYgoJcmVwbGFjZTIgMzIKCWZyYW1lX2J1cnkgMCAvLyBhOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50NjQsIDM+LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoyMTgKCS8vIHJldHVybiBhWzFdWzFdOwoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDY0LCAzPiwgMz4KCWV4dHJhY3QgMzIgOAoJYnRvaQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhkNjkxMTM1YiAvLyBtZXRob2QgInVwZGF0ZU5lc3RlZFN0YXRpY0FycmF5RWxlbWVudCgpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV91cGRhdGVOZXN0ZWRTdGF0aWNBcnJheUVsZW1lbnQKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdXBkYXRlTmVzdGVkU3RhdGljQXJyYXlFbGVtZW50KCl1aW50NjQKKmFiaV9yb3V0ZV91cGRhdGVOZXN0ZWRTdGF0aWNBcnJheUVsZW1lbnQ6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSB1cGRhdGVOZXN0ZWRTdGF0aWNBcnJheUVsZW1lbnQoKXVpbnQ2NAoJY2FsbHN1YiB1cGRhdGVOZXN0ZWRTdGF0aWNBcnJheUVsZW1lbnQKCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gdXBkYXRlTmVzdGVkU3RhdGljQXJyYXlFbGVtZW50KCk6IHVpbnQ2NAp1cGRhdGVOZXN0ZWRTdGF0aWNBcnJheUVsZW1lbnQ6Cglwcm90byAwIDEKCgkvLyBQdXNoIGVtcHR5IGJ5dGVzIGFmdGVyIHRoZSBmcmFtZSBwb2ludGVyIHRvIHJlc2VydmUgc3BhY2UgZm9yIGxvY2FsIHZhcmlhYmxlcwoJcHVzaGJ5dGVzIDB4CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjIxMAoJLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDY0LCAzPiwgMz4gPSBbCgkvLyAgICAgICBbMTEsIDIyLCAzM10sCgkvLyAgICAgICBbNDQsIDU1LCA2Nl0sCgkvLyAgICAgICBbNzcsIDg4LCA5OV0sCgkvLyAgICAgXQoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwYjAwMDAwMDAwMDAwMDAwMTYwMDAwMDAwMDAwMDAwMDIxMDAwMDAwMDAwMDAwMDAyYzAwMDAwMDAwMDAwMDAwMzcwMDAwMDAwMDAwMDAwMDQyMDAwMDAwMDAwMDAwMDA0ZDAwMDAwMDAwMDAwMDAwNTgwMDAwMDAwMDAwMDAwMDYzCglmcmFtZV9idXJ5IDAgLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDY0LCAzPiwgMz4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MjE2CgkvLyBhWzFdWzFdID0gNTU1CglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50NjQsIDM+LCAzPgoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDIyYgoJcmVwbGFjZTIgMzIKCWZyYW1lX2J1cnkgMCAvLyBhOiBTdGF0aWNBcnJheTxTdGF0aWNBcnJheTx1aW50NjQsIDM+LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoyMTgKCS8vIHJldHVybiBhWzFdWzFdOwoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8U3RhdGljQXJyYXk8dWludDY0LCAzPiwgMz4KCWV4dHJhY3QgMzIgOAoJYnRvaQoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHhkNjkxMTM1YiAvLyBtZXRob2QgInVwZGF0ZU5lc3RlZFN0YXRpY0FycmF5RWxlbWVudCgpdWludDY0IgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV91cGRhdGVOZXN0ZWRTdGF0aWNBcnJheUVsZW1lbnQKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestUpdateStaticArrayInStorageMap.approval.teal b/tests/contracts/artifacts/ABITestUpdateStaticArrayInStorageMap.approval.teal index 8d11e4d71..d1da40ce1 100644 --- a/tests/contracts/artifacts/ABITestUpdateStaticArrayInStorageMap.approval.teal +++ b/tests/contracts/artifacts/ABITestUpdateStaticArrayInStorageMap.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x674d6170 0x6c4d6170 0x624d6170 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestUpdateStaticArrayInStorageMap.arc32.json b/tests/contracts/artifacts/ABITestUpdateStaticArrayInStorageMap.arc32.json index 3bd8df3c4..98a4e5c48 100644 --- a/tests/contracts/artifacts/ABITestUpdateStaticArrayInStorageMap.arc32.json +++ b/tests/contracts/artifacts/ABITestUpdateStaticArrayInStorageMap.arc32.json @@ -49,7 +49,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2NzRkNjE3MCAweDZjNGQ2MTcwIDB4NjI0ZDYxNzAgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKk5PVF9JTVBMRU1FTlRFRCAqY2FsbF9PcHRJbiAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdXBkYXRlU3RhdGljQXJyYXlJblN0b3JhZ2VNYXAoKXVpbnQ2NFszXQoqYWJpX3JvdXRlX3VwZGF0ZVN0YXRpY0FycmF5SW5TdG9yYWdlTWFwOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgdXBkYXRlU3RhdGljQXJyYXlJblN0b3JhZ2VNYXAoKXVpbnQ2NFszXQoJY2FsbHN1YiB1cGRhdGVTdGF0aWNBcnJheUluU3RvcmFnZU1hcAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyB1cGRhdGVTdGF0aWNBcnJheUluU3RvcmFnZU1hcCgpOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CnVwZGF0ZVN0YXRpY0FycmF5SW5TdG9yYWdlTWFwOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCWJ5dGUgMHgKCWR1cAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNzYKCS8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4gPSBbMTEsIDIyLCAzM10KCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMGIwMDAwMDAwMDAwMDAwMDE2MDAwMDAwMDAwMDAwMDAyMQoJZnJhbWVfYnVyeSAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTc4CgkvLyB0aGlzLmdNYXAoJ2dNYXAnKS52YWx1ZSA9IGEKCWJ5dGUgMHg2NzRkNjE3MCAvLyAiZ01hcCIKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCWFwcF9nbG9iYWxfcHV0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE3OQoJLy8gdGhpcy5sTWFwKHRoaXMudHhuLnNlbmRlciwgJ2xNYXAnKS52YWx1ZSA9IGEKCXR4biBTZW5kZXIKCWJ5dGUgMHg2YzRkNjE3MCAvLyAibE1hcCIKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCWFwcF9sb2NhbF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTgwCgkvLyB0aGlzLmJNYXAoJ2JNYXAnKS52YWx1ZSA9IGEKCWJ5dGUgMHg2MjRkNjE3MCAvLyAiYk1hcCIKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCWJveF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTgyCgkvLyB0aGlzLmdNYXAoJ2dNYXAnKS52YWx1ZVsxXSA9IDExMTEKCWJ5dGUgMHg2NzRkNjE3MCAvLyAiZ01hcCIKCWFwcF9nbG9iYWxfZ2V0CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwNDU3CglyZXBsYWNlMiA4CglieXRlIDB4Njc0ZDYxNzAgLy8gImdNYXAiCglzd2FwCglhcHBfZ2xvYmFsX3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxODMKCS8vIHRoaXMubE1hcCh0aGlzLnR4bi5zZW5kZXIsICdsTWFwJykudmFsdWVbMV0gPSAyMjIyCgl0eG4gU2VuZGVyCglieXRlIDB4NmM0ZDYxNzAgLy8gImxNYXAiCglhcHBfbG9jYWxfZ2V0CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwOGFlCglyZXBsYWNlMiA4Cgl0eG4gU2VuZGVyCglieXRlIDB4NmM0ZDYxNzAgLy8gImxNYXAiCgl1bmNvdmVyIDIKCWFwcF9sb2NhbF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTg0CgkvLyB0aGlzLmJNYXAoJ2JNYXAnKS52YWx1ZVsxXSA9IDMzMzMKCWJ5dGUgMHg2MjRkNjE3MCAvLyAiYk1hcCIKCXB1c2hpbnQgOAoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMGQwNQoJYm94X3JlcGxhY2UKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTg2CgkvLyByZXQ6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4gPSBbCgkvLyAgICAgICB0aGlzLmdNYXAoJ2dNYXAnKS52YWx1ZVsxXSwKCS8vICAgICAgIHRoaXMubE1hcCh0aGlzLnR4bi5zZW5kZXIsICdsTWFwJykudmFsdWVbMV0sCgkvLyAgICAgICB0aGlzLmJNYXAoJ2JNYXAnKS52YWx1ZVsxXSwKCS8vICAgICBdCglieXRlIDB4Njc0ZDYxNzAgLy8gImdNYXAiCglhcHBfZ2xvYmFsX2dldAoJZXh0cmFjdCA4IDgKCWJ0b2kKCWl0b2IKCXR4biBTZW5kZXIKCWJ5dGUgMHg2YzRkNjE3MCAvLyAibE1hcCIKCWFwcF9sb2NhbF9nZXQKCWV4dHJhY3QgOCA4CglidG9pCglpdG9iCgljb25jYXQKCWJ5dGUgMHg2MjRkNjE3MCAvLyAiYk1hcCIKCXB1c2hpbnQgOAoJcHVzaGludCA4Cglib3hfZXh0cmFjdAoJYnRvaQoJaXRvYgoJY29uY2F0CglmcmFtZV9idXJ5IDEgLy8gcmV0OiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE5MgoJLy8gcmV0dXJuIHJldDsKCWZyYW1lX2RpZyAxIC8vIHJldDogU3RhdGljQXJyYXk8dWludDY0LCAzPgoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoKCS8vIHBvcCBhbGwgbG9jYWwgdmFyaWFibGVzIGZyb20gdGhlIHN0YWNrCglwb3BuIDEKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9PcHRJbjoKCXB1c2hieXRlcyAweGU2ODBhMGE5IC8vIG1ldGhvZCAidXBkYXRlU3RhdGljQXJyYXlJblN0b3JhZ2VNYXAoKXVpbnQ2NFszXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfdXBkYXRlU3RhdGljQXJyYXlJblN0b3JhZ2VNYXAKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBPcHRJbgoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2NzRkNjE3MCAweDZjNGQ2MTcwIDB4NjI0ZDYxNzAgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKk5PVF9JTVBMRU1FTlRFRCAqY2FsbF9PcHRJbiAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdXBkYXRlU3RhdGljQXJyYXlJblN0b3JhZ2VNYXAoKXVpbnQ2NFszXQoqYWJpX3JvdXRlX3VwZGF0ZVN0YXRpY0FycmF5SW5TdG9yYWdlTWFwOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgdXBkYXRlU3RhdGljQXJyYXlJblN0b3JhZ2VNYXAoKXVpbnQ2NFszXQoJY2FsbHN1YiB1cGRhdGVTdGF0aWNBcnJheUluU3RvcmFnZU1hcAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyB1cGRhdGVTdGF0aWNBcnJheUluU3RvcmFnZU1hcCgpOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CnVwZGF0ZVN0YXRpY0FycmF5SW5TdG9yYWdlTWFwOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCWJ5dGUgMHgKCWR1cAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNzYKCS8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4gPSBbMTEsIDIyLCAzM10KCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMGIwMDAwMDAwMDAwMDAwMDE2MDAwMDAwMDAwMDAwMDAyMQoJZnJhbWVfYnVyeSAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTc4CgkvLyB0aGlzLmdNYXAoJ2dNYXAnKS52YWx1ZSA9IGEKCWJ5dGUgMHg2NzRkNjE3MCAvLyAiZ01hcCIKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCWFwcF9nbG9iYWxfcHV0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE3OQoJLy8gdGhpcy5sTWFwKHRoaXMudHhuLnNlbmRlciwgJ2xNYXAnKS52YWx1ZSA9IGEKCXR4biBTZW5kZXIKCWJ5dGUgMHg2YzRkNjE3MCAvLyAibE1hcCIKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCWFwcF9sb2NhbF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTgwCgkvLyB0aGlzLmJNYXAoJ2JNYXAnKS52YWx1ZSA9IGEKCWJ5dGUgMHg2MjRkNjE3MCAvLyAiYk1hcCIKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCWJveF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTgyCgkvLyB0aGlzLmdNYXAoJ2dNYXAnKS52YWx1ZVsxXSA9IDExMTEKCWJ5dGUgMHg2NzRkNjE3MCAvLyAiZ01hcCIKCWFwcF9nbG9iYWxfZ2V0CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwNDU3CglyZXBsYWNlMiA4CglieXRlIDB4Njc0ZDYxNzAgLy8gImdNYXAiCglzd2FwCglhcHBfZ2xvYmFsX3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxODMKCS8vIHRoaXMubE1hcCh0aGlzLnR4bi5zZW5kZXIsICdsTWFwJykudmFsdWVbMV0gPSAyMjIyCgl0eG4gU2VuZGVyCglieXRlIDB4NmM0ZDYxNzAgLy8gImxNYXAiCglhcHBfbG9jYWxfZ2V0CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwOGFlCglyZXBsYWNlMiA4Cgl0eG4gU2VuZGVyCglieXRlIDB4NmM0ZDYxNzAgLy8gImxNYXAiCgl1bmNvdmVyIDIKCWFwcF9sb2NhbF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTg0CgkvLyB0aGlzLmJNYXAoJ2JNYXAnKS52YWx1ZVsxXSA9IDMzMzMKCWJ5dGUgMHg2MjRkNjE3MCAvLyAiYk1hcCIKCXB1c2hpbnQgOAoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMGQwNQoJYm94X3JlcGxhY2UKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTg2CgkvLyByZXQ6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4gPSBbCgkvLyAgICAgICB0aGlzLmdNYXAoJ2dNYXAnKS52YWx1ZVsxXSwKCS8vICAgICAgIHRoaXMubE1hcCh0aGlzLnR4bi5zZW5kZXIsICdsTWFwJykudmFsdWVbMV0sCgkvLyAgICAgICB0aGlzLmJNYXAoJ2JNYXAnKS52YWx1ZVsxXSwKCS8vICAgICBdCglieXRlIDB4Njc0ZDYxNzAgLy8gImdNYXAiCglhcHBfZ2xvYmFsX2dldAoJZXh0cmFjdCA4IDgKCWJ0b2kKCWl0b2IKCXR4biBTZW5kZXIKCWJ5dGUgMHg2YzRkNjE3MCAvLyAibE1hcCIKCWFwcF9sb2NhbF9nZXQKCWV4dHJhY3QgOCA4CglidG9pCglpdG9iCgljb25jYXQKCWJ5dGUgMHg2MjRkNjE3MCAvLyAiYk1hcCIKCXB1c2hpbnQgOAoJcHVzaGludCA4Cglib3hfZXh0cmFjdAoJYnRvaQoJaXRvYgoJY29uY2F0CglmcmFtZV9idXJ5IDEgLy8gcmV0OiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE5MgoJLy8gcmV0dXJuIHJldDsKCWZyYW1lX2RpZyAxIC8vIHJldDogU3RhdGljQXJyYXk8dWludDY0LCAzPgoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoKCS8vIHBvcCBhbGwgbG9jYWwgdmFyaWFibGVzIGZyb20gdGhlIHN0YWNrCglwb3BuIDEKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9PcHRJbjoKCXB1c2hieXRlcyAweGU2ODBhMGE5IC8vIG1ldGhvZCAidXBkYXRlU3RhdGljQXJyYXlJblN0b3JhZ2VNYXAoKXVpbnQ2NFszXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfdXBkYXRlU3RhdGljQXJyYXlJblN0b3JhZ2VNYXAKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBPcHRJbgoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestUpdateStaticArrayInStorageMap.arc56_draft.json b/tests/contracts/artifacts/ABITestUpdateStaticArrayInStorageMap.arc56_draft.json index bf5ad7212..1638db8e2 100644 --- a/tests/contracts/artifacts/ABITestUpdateStaticArrayInStorageMap.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestUpdateStaticArrayInStorageMap.arc56_draft.json @@ -909,7 +909,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2NzRkNjE3MCAweDZjNGQ2MTcwIDB4NjI0ZDYxNzAgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKk5PVF9JTVBMRU1FTlRFRCAqY2FsbF9PcHRJbiAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdXBkYXRlU3RhdGljQXJyYXlJblN0b3JhZ2VNYXAoKXVpbnQ2NFszXQoqYWJpX3JvdXRlX3VwZGF0ZVN0YXRpY0FycmF5SW5TdG9yYWdlTWFwOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgdXBkYXRlU3RhdGljQXJyYXlJblN0b3JhZ2VNYXAoKXVpbnQ2NFszXQoJY2FsbHN1YiB1cGRhdGVTdGF0aWNBcnJheUluU3RvcmFnZU1hcAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyB1cGRhdGVTdGF0aWNBcnJheUluU3RvcmFnZU1hcCgpOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CnVwZGF0ZVN0YXRpY0FycmF5SW5TdG9yYWdlTWFwOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCWJ5dGUgMHgKCWR1cAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNzYKCS8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4gPSBbMTEsIDIyLCAzM10KCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMGIwMDAwMDAwMDAwMDAwMDE2MDAwMDAwMDAwMDAwMDAyMQoJZnJhbWVfYnVyeSAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTc4CgkvLyB0aGlzLmdNYXAoJ2dNYXAnKS52YWx1ZSA9IGEKCWJ5dGUgMHg2NzRkNjE3MCAvLyAiZ01hcCIKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCWFwcF9nbG9iYWxfcHV0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE3OQoJLy8gdGhpcy5sTWFwKHRoaXMudHhuLnNlbmRlciwgJ2xNYXAnKS52YWx1ZSA9IGEKCXR4biBTZW5kZXIKCWJ5dGUgMHg2YzRkNjE3MCAvLyAibE1hcCIKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCWFwcF9sb2NhbF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTgwCgkvLyB0aGlzLmJNYXAoJ2JNYXAnKS52YWx1ZSA9IGEKCWJ5dGUgMHg2MjRkNjE3MCAvLyAiYk1hcCIKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCWJveF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTgyCgkvLyB0aGlzLmdNYXAoJ2dNYXAnKS52YWx1ZVsxXSA9IDExMTEKCWJ5dGUgMHg2NzRkNjE3MCAvLyAiZ01hcCIKCWFwcF9nbG9iYWxfZ2V0CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwNDU3CglyZXBsYWNlMiA4CglieXRlIDB4Njc0ZDYxNzAgLy8gImdNYXAiCglzd2FwCglhcHBfZ2xvYmFsX3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxODMKCS8vIHRoaXMubE1hcCh0aGlzLnR4bi5zZW5kZXIsICdsTWFwJykudmFsdWVbMV0gPSAyMjIyCgl0eG4gU2VuZGVyCglieXRlIDB4NmM0ZDYxNzAgLy8gImxNYXAiCglhcHBfbG9jYWxfZ2V0CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwOGFlCglyZXBsYWNlMiA4Cgl0eG4gU2VuZGVyCglieXRlIDB4NmM0ZDYxNzAgLy8gImxNYXAiCgl1bmNvdmVyIDIKCWFwcF9sb2NhbF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTg0CgkvLyB0aGlzLmJNYXAoJ2JNYXAnKS52YWx1ZVsxXSA9IDMzMzMKCWJ5dGUgMHg2MjRkNjE3MCAvLyAiYk1hcCIKCXB1c2hpbnQgOAoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMGQwNQoJYm94X3JlcGxhY2UKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTg2CgkvLyByZXQ6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4gPSBbCgkvLyAgICAgICB0aGlzLmdNYXAoJ2dNYXAnKS52YWx1ZVsxXSwKCS8vICAgICAgIHRoaXMubE1hcCh0aGlzLnR4bi5zZW5kZXIsICdsTWFwJykudmFsdWVbMV0sCgkvLyAgICAgICB0aGlzLmJNYXAoJ2JNYXAnKS52YWx1ZVsxXSwKCS8vICAgICBdCglieXRlIDB4Njc0ZDYxNzAgLy8gImdNYXAiCglhcHBfZ2xvYmFsX2dldAoJZXh0cmFjdCA4IDgKCWJ0b2kKCWl0b2IKCXR4biBTZW5kZXIKCWJ5dGUgMHg2YzRkNjE3MCAvLyAibE1hcCIKCWFwcF9sb2NhbF9nZXQKCWV4dHJhY3QgOCA4CglidG9pCglpdG9iCgljb25jYXQKCWJ5dGUgMHg2MjRkNjE3MCAvLyAiYk1hcCIKCXB1c2hpbnQgOAoJcHVzaGludCA4Cglib3hfZXh0cmFjdAoJYnRvaQoJaXRvYgoJY29uY2F0CglmcmFtZV9idXJ5IDEgLy8gcmV0OiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE5MgoJLy8gcmV0dXJuIHJldDsKCWZyYW1lX2RpZyAxIC8vIHJldDogU3RhdGljQXJyYXk8dWludDY0LCAzPgoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoKCS8vIHBvcCBhbGwgbG9jYWwgdmFyaWFibGVzIGZyb20gdGhlIHN0YWNrCglwb3BuIDEKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9PcHRJbjoKCXB1c2hieXRlcyAweGU2ODBhMGE5IC8vIG1ldGhvZCAidXBkYXRlU3RhdGljQXJyYXlJblN0b3JhZ2VNYXAoKXVpbnQ2NFszXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfdXBkYXRlU3RhdGljQXJyYXlJblN0b3JhZ2VNYXAKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBPcHRJbgoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2NzRkNjE3MCAweDZjNGQ2MTcwIDB4NjI0ZDYxNzAgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKk5PVF9JTVBMRU1FTlRFRCAqY2FsbF9PcHRJbiAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdXBkYXRlU3RhdGljQXJyYXlJblN0b3JhZ2VNYXAoKXVpbnQ2NFszXQoqYWJpX3JvdXRlX3VwZGF0ZVN0YXRpY0FycmF5SW5TdG9yYWdlTWFwOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgdXBkYXRlU3RhdGljQXJyYXlJblN0b3JhZ2VNYXAoKXVpbnQ2NFszXQoJY2FsbHN1YiB1cGRhdGVTdGF0aWNBcnJheUluU3RvcmFnZU1hcAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyB1cGRhdGVTdGF0aWNBcnJheUluU3RvcmFnZU1hcCgpOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CnVwZGF0ZVN0YXRpY0FycmF5SW5TdG9yYWdlTWFwOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCWJ5dGUgMHgKCWR1cAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxNzYKCS8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4gPSBbMTEsIDIyLCAzM10KCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMGIwMDAwMDAwMDAwMDAwMDE2MDAwMDAwMDAwMDAwMDAyMQoJZnJhbWVfYnVyeSAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTc4CgkvLyB0aGlzLmdNYXAoJ2dNYXAnKS52YWx1ZSA9IGEKCWJ5dGUgMHg2NzRkNjE3MCAvLyAiZ01hcCIKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCWFwcF9nbG9iYWxfcHV0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE3OQoJLy8gdGhpcy5sTWFwKHRoaXMudHhuLnNlbmRlciwgJ2xNYXAnKS52YWx1ZSA9IGEKCXR4biBTZW5kZXIKCWJ5dGUgMHg2YzRkNjE3MCAvLyAibE1hcCIKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCWFwcF9sb2NhbF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTgwCgkvLyB0aGlzLmJNYXAoJ2JNYXAnKS52YWx1ZSA9IGEKCWJ5dGUgMHg2MjRkNjE3MCAvLyAiYk1hcCIKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCWJveF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTgyCgkvLyB0aGlzLmdNYXAoJ2dNYXAnKS52YWx1ZVsxXSA9IDExMTEKCWJ5dGUgMHg2NzRkNjE3MCAvLyAiZ01hcCIKCWFwcF9nbG9iYWxfZ2V0CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwNDU3CglyZXBsYWNlMiA4CglieXRlIDB4Njc0ZDYxNzAgLy8gImdNYXAiCglzd2FwCglhcHBfZ2xvYmFsX3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxODMKCS8vIHRoaXMubE1hcCh0aGlzLnR4bi5zZW5kZXIsICdsTWFwJykudmFsdWVbMV0gPSAyMjIyCgl0eG4gU2VuZGVyCglieXRlIDB4NmM0ZDYxNzAgLy8gImxNYXAiCglhcHBfbG9jYWxfZ2V0CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwOGFlCglyZXBsYWNlMiA4Cgl0eG4gU2VuZGVyCglieXRlIDB4NmM0ZDYxNzAgLy8gImxNYXAiCgl1bmNvdmVyIDIKCWFwcF9sb2NhbF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTg0CgkvLyB0aGlzLmJNYXAoJ2JNYXAnKS52YWx1ZVsxXSA9IDMzMzMKCWJ5dGUgMHg2MjRkNjE3MCAvLyAiYk1hcCIKCXB1c2hpbnQgOAoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMGQwNQoJYm94X3JlcGxhY2UKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTg2CgkvLyByZXQ6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4gPSBbCgkvLyAgICAgICB0aGlzLmdNYXAoJ2dNYXAnKS52YWx1ZVsxXSwKCS8vICAgICAgIHRoaXMubE1hcCh0aGlzLnR4bi5zZW5kZXIsICdsTWFwJykudmFsdWVbMV0sCgkvLyAgICAgICB0aGlzLmJNYXAoJ2JNYXAnKS52YWx1ZVsxXSwKCS8vICAgICBdCglieXRlIDB4Njc0ZDYxNzAgLy8gImdNYXAiCglhcHBfZ2xvYmFsX2dldAoJZXh0cmFjdCA4IDgKCWJ0b2kKCWl0b2IKCXR4biBTZW5kZXIKCWJ5dGUgMHg2YzRkNjE3MCAvLyAibE1hcCIKCWFwcF9sb2NhbF9nZXQKCWV4dHJhY3QgOCA4CglidG9pCglpdG9iCgljb25jYXQKCWJ5dGUgMHg2MjRkNjE3MCAvLyAiYk1hcCIKCXB1c2hpbnQgOAoJcHVzaGludCA4Cglib3hfZXh0cmFjdAoJYnRvaQoJaXRvYgoJY29uY2F0CglmcmFtZV9idXJ5IDEgLy8gcmV0OiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE5MgoJLy8gcmV0dXJuIHJldDsKCWZyYW1lX2RpZyAxIC8vIHJldDogU3RhdGljQXJyYXk8dWludDY0LCAzPgoKCS8vIHNldCB0aGUgc3Vicm91dGluZSByZXR1cm4gdmFsdWUKCWZyYW1lX2J1cnkgMAoKCS8vIHBvcCBhbGwgbG9jYWwgdmFyaWFibGVzIGZyb20gdGhlIHN0YWNrCglwb3BuIDEKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9PcHRJbjoKCXB1c2hieXRlcyAweGU2ODBhMGE5IC8vIG1ldGhvZCAidXBkYXRlU3RhdGljQXJyYXlJblN0b3JhZ2VNYXAoKXVpbnQ2NFszXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfdXBkYXRlU3RhdGljQXJyYXlJblN0b3JhZ2VNYXAKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBPcHRJbgoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestUpdateStaticArrayInStorageRef.approval.teal b/tests/contracts/artifacts/ABITestUpdateStaticArrayInStorageRef.approval.teal index eb2001dce..a9b6f210d 100644 --- a/tests/contracts/artifacts/ABITestUpdateStaticArrayInStorageRef.approval.teal +++ b/tests/contracts/artifacts/ABITestUpdateStaticArrayInStorageRef.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x67526566 0x6c526566 0x62526566 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestUpdateStaticArrayInStorageRef.arc32.json b/tests/contracts/artifacts/ABITestUpdateStaticArrayInStorageRef.arc32.json index e40bc803b..bcaf973a1 100644 --- a/tests/contracts/artifacts/ABITestUpdateStaticArrayInStorageRef.arc32.json +++ b/tests/contracts/artifacts/ABITestUpdateStaticArrayInStorageRef.arc32.json @@ -49,7 +49,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2NzUyNjU2NiAweDZjNTI2NTY2IDB4NjI1MjY1NjYgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKk5PVF9JTVBMRU1FTlRFRCAqY2FsbF9PcHRJbiAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdXBkYXRlU3RhdGljQXJyYXlJblN0b3JhZ2VSZWYoKXVpbnQ2NFszXQoqYWJpX3JvdXRlX3VwZGF0ZVN0YXRpY0FycmF5SW5TdG9yYWdlUmVmOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgdXBkYXRlU3RhdGljQXJyYXlJblN0b3JhZ2VSZWYoKXVpbnQ2NFszXQoJY2FsbHN1YiB1cGRhdGVTdGF0aWNBcnJheUluU3RvcmFnZVJlZgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyB1cGRhdGVTdGF0aWNBcnJheUluU3RvcmFnZVJlZigpOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CnVwZGF0ZVN0YXRpY0FycmF5SW5TdG9yYWdlUmVmOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCWJ5dGUgMHgKCWR1cAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMTQKCS8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4gPSBbMTEsIDIyLCAzM10KCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMGIwMDAwMDAwMDAwMDAwMDE2MDAwMDAwMDAwMDAwMDAyMQoJZnJhbWVfYnVyeSAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTE2CgkvLyB0aGlzLmdSZWYudmFsdWUgPSBhCglieXRlIDB4Njc1MjY1NjYgLy8gImdSZWYiCglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CglhcHBfZ2xvYmFsX3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMTcKCS8vIHRoaXMubFJlZih0aGlzLnR4bi5zZW5kZXIpLnZhbHVlID0gYQoJdHhuIFNlbmRlcgoJYnl0ZSAweDZjNTI2NTY2IC8vICJsUmVmIgoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoJYXBwX2xvY2FsX3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMTgKCS8vIHRoaXMuYlJlZi52YWx1ZSA9IGEKCWJ5dGUgMHg2MjUyNjU2NiAvLyAiYlJlZiIKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCWJveF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTIwCgkvLyB0aGlzLmdSZWYudmFsdWVbMV0gPSAxMTEKCWJ5dGUgMHg2NzUyNjU2NiAvLyAiZ1JlZiIKCWFwcF9nbG9iYWxfZ2V0CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDZmCglyZXBsYWNlMiA4CglieXRlIDB4Njc1MjY1NjYgLy8gImdSZWYiCglzd2FwCglhcHBfZ2xvYmFsX3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjEKCS8vIHRoaXMubFJlZih0aGlzLnR4bi5zZW5kZXIpLnZhbHVlWzFdID0gMjIyCgl0eG4gU2VuZGVyCglieXRlIDB4NmM1MjY1NjYgLy8gImxSZWYiCglhcHBfbG9jYWxfZ2V0CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMGRlCglyZXBsYWNlMiA4Cgl0eG4gU2VuZGVyCglieXRlIDB4NmM1MjY1NjYgLy8gImxSZWYiCgl1bmNvdmVyIDIKCWFwcF9sb2NhbF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTIyCgkvLyB0aGlzLmJSZWYudmFsdWVbMV0gPSAzMzMKCWJ5dGUgMHg2MjUyNjU2NiAvLyAiYlJlZiIKCXB1c2hpbnQgOAoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDE0ZAoJYm94X3JlcGxhY2UKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTI0CgkvLyByZXQ6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4gPSBbdGhpcy5nUmVmLnZhbHVlWzFdLCB0aGlzLmxSZWYodGhpcy50eG4uc2VuZGVyKS52YWx1ZVsxXSwgdGhpcy5iUmVmLnZhbHVlWzFdXQoJYnl0ZSAweDY3NTI2NTY2IC8vICJnUmVmIgoJYXBwX2dsb2JhbF9nZXQKCWV4dHJhY3QgOCA4CglidG9pCglpdG9iCgl0eG4gU2VuZGVyCglieXRlIDB4NmM1MjY1NjYgLy8gImxSZWYiCglhcHBfbG9jYWxfZ2V0CglleHRyYWN0IDggOAoJYnRvaQoJaXRvYgoJY29uY2F0CglieXRlIDB4NjI1MjY1NjYgLy8gImJSZWYiCglwdXNoaW50IDgKCXB1c2hpbnQgOAoJYm94X2V4dHJhY3QKCWJ0b2kKCWl0b2IKCWNvbmNhdAoJZnJhbWVfYnVyeSAxIC8vIHJldDogU3RhdGljQXJyYXk8dWludDY0LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjYKCS8vIHJldHVybiByZXQ7CglmcmFtZV9kaWcgMSAvLyByZXQ6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCgkvLyBwb3AgYWxsIGxvY2FsIHZhcmlhYmxlcyBmcm9tIHRoZSBzdGFjawoJcG9wbiAxCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfT3B0SW46CglwdXNoYnl0ZXMgMHg4MGU1Yzc1OSAvLyBtZXRob2QgInVwZGF0ZVN0YXRpY0FycmF5SW5TdG9yYWdlUmVmKCl1aW50NjRbM10iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3VwZGF0ZVN0YXRpY0FycmF5SW5TdG9yYWdlUmVmCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgT3B0SW4KCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2NzUyNjU2NiAweDZjNTI2NTY2IDB4NjI1MjY1NjYgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKk5PVF9JTVBMRU1FTlRFRCAqY2FsbF9PcHRJbiAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdXBkYXRlU3RhdGljQXJyYXlJblN0b3JhZ2VSZWYoKXVpbnQ2NFszXQoqYWJpX3JvdXRlX3VwZGF0ZVN0YXRpY0FycmF5SW5TdG9yYWdlUmVmOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgdXBkYXRlU3RhdGljQXJyYXlJblN0b3JhZ2VSZWYoKXVpbnQ2NFszXQoJY2FsbHN1YiB1cGRhdGVTdGF0aWNBcnJheUluU3RvcmFnZVJlZgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyB1cGRhdGVTdGF0aWNBcnJheUluU3RvcmFnZVJlZigpOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CnVwZGF0ZVN0YXRpY0FycmF5SW5TdG9yYWdlUmVmOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCWJ5dGUgMHgKCWR1cAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMTQKCS8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4gPSBbMTEsIDIyLCAzM10KCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMGIwMDAwMDAwMDAwMDAwMDE2MDAwMDAwMDAwMDAwMDAyMQoJZnJhbWVfYnVyeSAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTE2CgkvLyB0aGlzLmdSZWYudmFsdWUgPSBhCglieXRlIDB4Njc1MjY1NjYgLy8gImdSZWYiCglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CglhcHBfZ2xvYmFsX3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMTcKCS8vIHRoaXMubFJlZih0aGlzLnR4bi5zZW5kZXIpLnZhbHVlID0gYQoJdHhuIFNlbmRlcgoJYnl0ZSAweDZjNTI2NTY2IC8vICJsUmVmIgoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoJYXBwX2xvY2FsX3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMTgKCS8vIHRoaXMuYlJlZi52YWx1ZSA9IGEKCWJ5dGUgMHg2MjUyNjU2NiAvLyAiYlJlZiIKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCWJveF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTIwCgkvLyB0aGlzLmdSZWYudmFsdWVbMV0gPSAxMTEKCWJ5dGUgMHg2NzUyNjU2NiAvLyAiZ1JlZiIKCWFwcF9nbG9iYWxfZ2V0CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDZmCglyZXBsYWNlMiA4CglieXRlIDB4Njc1MjY1NjYgLy8gImdSZWYiCglzd2FwCglhcHBfZ2xvYmFsX3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjEKCS8vIHRoaXMubFJlZih0aGlzLnR4bi5zZW5kZXIpLnZhbHVlWzFdID0gMjIyCgl0eG4gU2VuZGVyCglieXRlIDB4NmM1MjY1NjYgLy8gImxSZWYiCglhcHBfbG9jYWxfZ2V0CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMGRlCglyZXBsYWNlMiA4Cgl0eG4gU2VuZGVyCglieXRlIDB4NmM1MjY1NjYgLy8gImxSZWYiCgl1bmNvdmVyIDIKCWFwcF9sb2NhbF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTIyCgkvLyB0aGlzLmJSZWYudmFsdWVbMV0gPSAzMzMKCWJ5dGUgMHg2MjUyNjU2NiAvLyAiYlJlZiIKCXB1c2hpbnQgOAoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDE0ZAoJYm94X3JlcGxhY2UKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTI0CgkvLyByZXQ6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4gPSBbdGhpcy5nUmVmLnZhbHVlWzFdLCB0aGlzLmxSZWYodGhpcy50eG4uc2VuZGVyKS52YWx1ZVsxXSwgdGhpcy5iUmVmLnZhbHVlWzFdXQoJYnl0ZSAweDY3NTI2NTY2IC8vICJnUmVmIgoJYXBwX2dsb2JhbF9nZXQKCWV4dHJhY3QgOCA4CglidG9pCglpdG9iCgl0eG4gU2VuZGVyCglieXRlIDB4NmM1MjY1NjYgLy8gImxSZWYiCglhcHBfbG9jYWxfZ2V0CglleHRyYWN0IDggOAoJYnRvaQoJaXRvYgoJY29uY2F0CglieXRlIDB4NjI1MjY1NjYgLy8gImJSZWYiCglwdXNoaW50IDgKCXB1c2hpbnQgOAoJYm94X2V4dHJhY3QKCWJ0b2kKCWl0b2IKCWNvbmNhdAoJZnJhbWVfYnVyeSAxIC8vIHJldDogU3RhdGljQXJyYXk8dWludDY0LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjYKCS8vIHJldHVybiByZXQ7CglmcmFtZV9kaWcgMSAvLyByZXQ6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCgkvLyBwb3AgYWxsIGxvY2FsIHZhcmlhYmxlcyBmcm9tIHRoZSBzdGFjawoJcG9wbiAxCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfT3B0SW46CglwdXNoYnl0ZXMgMHg4MGU1Yzc1OSAvLyBtZXRob2QgInVwZGF0ZVN0YXRpY0FycmF5SW5TdG9yYWdlUmVmKCl1aW50NjRbM10iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3VwZGF0ZVN0YXRpY0FycmF5SW5TdG9yYWdlUmVmCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgT3B0SW4KCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestUpdateStaticArrayInStorageRef.arc56_draft.json b/tests/contracts/artifacts/ABITestUpdateStaticArrayInStorageRef.arc56_draft.json index b2dba321d..956621119 100644 --- a/tests/contracts/artifacts/ABITestUpdateStaticArrayInStorageRef.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestUpdateStaticArrayInStorageRef.arc56_draft.json @@ -909,7 +909,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2NzUyNjU2NiAweDZjNTI2NTY2IDB4NjI1MjY1NjYgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKk5PVF9JTVBMRU1FTlRFRCAqY2FsbF9PcHRJbiAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdXBkYXRlU3RhdGljQXJyYXlJblN0b3JhZ2VSZWYoKXVpbnQ2NFszXQoqYWJpX3JvdXRlX3VwZGF0ZVN0YXRpY0FycmF5SW5TdG9yYWdlUmVmOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgdXBkYXRlU3RhdGljQXJyYXlJblN0b3JhZ2VSZWYoKXVpbnQ2NFszXQoJY2FsbHN1YiB1cGRhdGVTdGF0aWNBcnJheUluU3RvcmFnZVJlZgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyB1cGRhdGVTdGF0aWNBcnJheUluU3RvcmFnZVJlZigpOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CnVwZGF0ZVN0YXRpY0FycmF5SW5TdG9yYWdlUmVmOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCWJ5dGUgMHgKCWR1cAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMTQKCS8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4gPSBbMTEsIDIyLCAzM10KCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMGIwMDAwMDAwMDAwMDAwMDE2MDAwMDAwMDAwMDAwMDAyMQoJZnJhbWVfYnVyeSAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTE2CgkvLyB0aGlzLmdSZWYudmFsdWUgPSBhCglieXRlIDB4Njc1MjY1NjYgLy8gImdSZWYiCglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CglhcHBfZ2xvYmFsX3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMTcKCS8vIHRoaXMubFJlZih0aGlzLnR4bi5zZW5kZXIpLnZhbHVlID0gYQoJdHhuIFNlbmRlcgoJYnl0ZSAweDZjNTI2NTY2IC8vICJsUmVmIgoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoJYXBwX2xvY2FsX3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMTgKCS8vIHRoaXMuYlJlZi52YWx1ZSA9IGEKCWJ5dGUgMHg2MjUyNjU2NiAvLyAiYlJlZiIKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCWJveF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTIwCgkvLyB0aGlzLmdSZWYudmFsdWVbMV0gPSAxMTEKCWJ5dGUgMHg2NzUyNjU2NiAvLyAiZ1JlZiIKCWFwcF9nbG9iYWxfZ2V0CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDZmCglyZXBsYWNlMiA4CglieXRlIDB4Njc1MjY1NjYgLy8gImdSZWYiCglzd2FwCglhcHBfZ2xvYmFsX3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjEKCS8vIHRoaXMubFJlZih0aGlzLnR4bi5zZW5kZXIpLnZhbHVlWzFdID0gMjIyCgl0eG4gU2VuZGVyCglieXRlIDB4NmM1MjY1NjYgLy8gImxSZWYiCglhcHBfbG9jYWxfZ2V0CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMGRlCglyZXBsYWNlMiA4Cgl0eG4gU2VuZGVyCglieXRlIDB4NmM1MjY1NjYgLy8gImxSZWYiCgl1bmNvdmVyIDIKCWFwcF9sb2NhbF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTIyCgkvLyB0aGlzLmJSZWYudmFsdWVbMV0gPSAzMzMKCWJ5dGUgMHg2MjUyNjU2NiAvLyAiYlJlZiIKCXB1c2hpbnQgOAoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDE0ZAoJYm94X3JlcGxhY2UKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTI0CgkvLyByZXQ6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4gPSBbdGhpcy5nUmVmLnZhbHVlWzFdLCB0aGlzLmxSZWYodGhpcy50eG4uc2VuZGVyKS52YWx1ZVsxXSwgdGhpcy5iUmVmLnZhbHVlWzFdXQoJYnl0ZSAweDY3NTI2NTY2IC8vICJnUmVmIgoJYXBwX2dsb2JhbF9nZXQKCWV4dHJhY3QgOCA4CglidG9pCglpdG9iCgl0eG4gU2VuZGVyCglieXRlIDB4NmM1MjY1NjYgLy8gImxSZWYiCglhcHBfbG9jYWxfZ2V0CglleHRyYWN0IDggOAoJYnRvaQoJaXRvYgoJY29uY2F0CglieXRlIDB4NjI1MjY1NjYgLy8gImJSZWYiCglwdXNoaW50IDgKCXB1c2hpbnQgOAoJYm94X2V4dHJhY3QKCWJ0b2kKCWl0b2IKCWNvbmNhdAoJZnJhbWVfYnVyeSAxIC8vIHJldDogU3RhdGljQXJyYXk8dWludDY0LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjYKCS8vIHJldHVybiByZXQ7CglmcmFtZV9kaWcgMSAvLyByZXQ6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCgkvLyBwb3AgYWxsIGxvY2FsIHZhcmlhYmxlcyBmcm9tIHRoZSBzdGFjawoJcG9wbiAxCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfT3B0SW46CglwdXNoYnl0ZXMgMHg4MGU1Yzc1OSAvLyBtZXRob2QgInVwZGF0ZVN0YXRpY0FycmF5SW5TdG9yYWdlUmVmKCl1aW50NjRbM10iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3VwZGF0ZVN0YXRpY0FycmF5SW5TdG9yYWdlUmVmCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgT3B0SW4KCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2NzUyNjU2NiAweDZjNTI2NTY2IDB4NjI1MjY1NjYgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKk5PVF9JTVBMRU1FTlRFRCAqY2FsbF9PcHRJbiAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdXBkYXRlU3RhdGljQXJyYXlJblN0b3JhZ2VSZWYoKXVpbnQ2NFszXQoqYWJpX3JvdXRlX3VwZGF0ZVN0YXRpY0FycmF5SW5TdG9yYWdlUmVmOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgdXBkYXRlU3RhdGljQXJyYXlJblN0b3JhZ2VSZWYoKXVpbnQ2NFszXQoJY2FsbHN1YiB1cGRhdGVTdGF0aWNBcnJheUluU3RvcmFnZVJlZgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyB1cGRhdGVTdGF0aWNBcnJheUluU3RvcmFnZVJlZigpOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CnVwZGF0ZVN0YXRpY0FycmF5SW5TdG9yYWdlUmVmOgoJcHJvdG8gMCAxCgoJLy8gUHVzaCBlbXB0eSBieXRlcyBhZnRlciB0aGUgZnJhbWUgcG9pbnRlciB0byByZXNlcnZlIHNwYWNlIGZvciBsb2NhbCB2YXJpYWJsZXMKCWJ5dGUgMHgKCWR1cAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMTQKCS8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4gPSBbMTEsIDIyLCAzM10KCXB1c2hieXRlcyAweDAwMDAwMDAwMDAwMDAwMGIwMDAwMDAwMDAwMDAwMDE2MDAwMDAwMDAwMDAwMDAyMQoJZnJhbWVfYnVyeSAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTE2CgkvLyB0aGlzLmdSZWYudmFsdWUgPSBhCglieXRlIDB4Njc1MjY1NjYgLy8gImdSZWYiCglmcmFtZV9kaWcgMCAvLyBhOiBTdGF0aWNBcnJheTx1aW50NjQsIDM+CglhcHBfZ2xvYmFsX3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMTcKCS8vIHRoaXMubFJlZih0aGlzLnR4bi5zZW5kZXIpLnZhbHVlID0gYQoJdHhuIFNlbmRlcgoJYnl0ZSAweDZjNTI2NTY2IC8vICJsUmVmIgoJZnJhbWVfZGlnIDAgLy8gYTogU3RhdGljQXJyYXk8dWludDY0LCAzPgoJYXBwX2xvY2FsX3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMTgKCS8vIHRoaXMuYlJlZi52YWx1ZSA9IGEKCWJ5dGUgMHg2MjUyNjU2NiAvLyAiYlJlZiIKCWZyYW1lX2RpZyAwIC8vIGE6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCWJveF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTIwCgkvLyB0aGlzLmdSZWYudmFsdWVbMV0gPSAxMTEKCWJ5dGUgMHg2NzUyNjU2NiAvLyAiZ1JlZiIKCWFwcF9nbG9iYWxfZ2V0CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMDZmCglyZXBsYWNlMiA4CglieXRlIDB4Njc1MjY1NjYgLy8gImdSZWYiCglzd2FwCglhcHBfZ2xvYmFsX3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjEKCS8vIHRoaXMubFJlZih0aGlzLnR4bi5zZW5kZXIpLnZhbHVlWzFdID0gMjIyCgl0eG4gU2VuZGVyCglieXRlIDB4NmM1MjY1NjYgLy8gImxSZWYiCglhcHBfbG9jYWxfZ2V0CglwdXNoYnl0ZXMgMHgwMDAwMDAwMDAwMDAwMGRlCglyZXBsYWNlMiA4Cgl0eG4gU2VuZGVyCglieXRlIDB4NmM1MjY1NjYgLy8gImxSZWYiCgl1bmNvdmVyIDIKCWFwcF9sb2NhbF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTIyCgkvLyB0aGlzLmJSZWYudmFsdWVbMV0gPSAzMzMKCWJ5dGUgMHg2MjUyNjU2NiAvLyAiYlJlZiIKCXB1c2hpbnQgOAoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDE0ZAoJYm94X3JlcGxhY2UKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTI0CgkvLyByZXQ6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4gPSBbdGhpcy5nUmVmLnZhbHVlWzFdLCB0aGlzLmxSZWYodGhpcy50eG4uc2VuZGVyKS52YWx1ZVsxXSwgdGhpcy5iUmVmLnZhbHVlWzFdXQoJYnl0ZSAweDY3NTI2NTY2IC8vICJnUmVmIgoJYXBwX2dsb2JhbF9nZXQKCWV4dHJhY3QgOCA4CglidG9pCglpdG9iCgl0eG4gU2VuZGVyCglieXRlIDB4NmM1MjY1NjYgLy8gImxSZWYiCglhcHBfbG9jYWxfZ2V0CglleHRyYWN0IDggOAoJYnRvaQoJaXRvYgoJY29uY2F0CglieXRlIDB4NjI1MjY1NjYgLy8gImJSZWYiCglwdXNoaW50IDgKCXB1c2hpbnQgOAoJYm94X2V4dHJhY3QKCWJ0b2kKCWl0b2IKCWNvbmNhdAoJZnJhbWVfYnVyeSAxIC8vIHJldDogU3RhdGljQXJyYXk8dWludDY0LCAzPgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hYmkuYWxnby50czoxMjYKCS8vIHJldHVybiByZXQ7CglmcmFtZV9kaWcgMSAvLyByZXQ6IFN0YXRpY0FycmF5PHVpbnQ2NCwgMz4KCgkvLyBzZXQgdGhlIHN1YnJvdXRpbmUgcmV0dXJuIHZhbHVlCglmcmFtZV9idXJ5IDAKCgkvLyBwb3AgYWxsIGxvY2FsIHZhcmlhYmxlcyBmcm9tIHRoZSBzdGFjawoJcG9wbiAxCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfT3B0SW46CglwdXNoYnl0ZXMgMHg4MGU1Yzc1OSAvLyBtZXRob2QgInVwZGF0ZVN0YXRpY0FycmF5SW5TdG9yYWdlUmVmKCl1aW50NjRbM10iCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3VwZGF0ZVN0YXRpY0FycmF5SW5TdG9yYWdlUmVmCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgT3B0SW4KCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestUpdateStaticFieldInDynamicObjectInBox.approval.teal b/tests/contracts/artifacts/ABITestUpdateStaticFieldInDynamicObjectInBox.approval.teal index 5f302d8c5..78803225b 100644 --- a/tests/contracts/artifacts/ABITestUpdateStaticFieldInDynamicObjectInBox.approval.teal +++ b/tests/contracts/artifacts/ABITestUpdateStaticFieldInDynamicObjectInBox.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x0004624d6170 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestUpdateStaticFieldInDynamicObjectInBox.arc32.json b/tests/contracts/artifacts/ABITestUpdateStaticFieldInDynamicObjectInBox.arc32.json index 9ba0e9ac5..149d3df8b 100644 --- a/tests/contracts/artifacts/ABITestUpdateStaticFieldInDynamicObjectInBox.arc32.json +++ b/tests/contracts/artifacts/ABITestUpdateStaticFieldInDynamicObjectInBox.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgwMDA0NjI0ZDYxNzAgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyB1cGRhdGVTdGF0aWNGaWVsZEluRHluYW1pY09iamVjdEluQm94KClzdHJpbmcKKmFiaV9yb3V0ZV91cGRhdGVTdGF0aWNGaWVsZEluRHluYW1pY09iamVjdEluQm94OgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgdXBkYXRlU3RhdGljRmllbGRJbkR5bmFtaWNPYmplY3RJbkJveCgpc3RyaW5nCgljYWxsc3ViIHVwZGF0ZVN0YXRpY0ZpZWxkSW5EeW5hbWljT2JqZWN0SW5Cb3gKCWR1cAoJbGVuCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHVwZGF0ZVN0YXRpY0ZpZWxkSW5EeW5hbWljT2JqZWN0SW5Cb3goKTogc3RyaW5nCnVwZGF0ZVN0YXRpY0ZpZWxkSW5EeW5hbWljT2JqZWN0SW5Cb3g6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTU3MwoJLy8gdGhpcy5iTWFwKCdiTWFwJykudmFsdWUgPSB7IGFkZHI6IHRoaXMudHhuLnNlbmRlciwgc3RyOiAnSGVsbG8gV29ybGQhJyB9CglieXRlIDB4MDAwNDYyNGQ2MTcwCglkdXAKCWJveF9kZWwKCXBvcAoJYnl0ZSAweCAvLyBpbml0aWFsIGhlYWQKCWJ5dGUgMHggLy8gaW5pdGlhbCB0YWlsCglwdXNoYnl0ZXMgMHgwMDIyIC8vIGluaXRpYWwgaGVhZCBvZmZzZXQKCXR4biBTZW5kZXIKCWNhbGxzdWIgKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMGM0ODY1NmM2YzZmMjA1NzZmNzI2YzY0MjEKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50Cglwb3AgLy8gcG9wIGhlYWQgb2Zmc2V0Cgljb25jYXQgLy8gY29uY2F0IGhlYWQgYW5kIHRhaWwKCWJveF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTU3NQoJLy8gdGhpcy5iTWFwKCdiTWFwJykudmFsdWUuYWRkciA9IHRoaXMudHhuLnNlbmRlcgoJYnl0ZSAweDAwMDQ2MjRkNjE3MAoJYm94X2dldAoKCS8vIGJveCB2YWx1ZSBkb2VzIG5vdCBleGlzdDogdGhpcy5iTWFwKCdiTWFwJykudmFsdWUKCWFzc2VydAoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgMAoJdHhuIFNlbmRlcgoJcmVwbGFjZTMKCWJ5dGUgMHgwMDA0NjI0ZDYxNzAKCWR1cAoJYm94X2RlbAoJcG9wCglzd2FwCglib3hfcHV0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE1NzYKCS8vIHJldHVybiB0aGlzLmJNYXAoJ2JNYXAnKS52YWx1ZS5zdHI7CglieXRlIDB4MDAwNDYyNGQ2MTcwCglib3hfZ2V0CgoJLy8gYm94IHZhbHVlIGRvZXMgbm90IGV4aXN0OiB0aGlzLmJNYXAoJ2JNYXAnKS52YWx1ZQoJYXNzZXJ0CglzdG9yZSAyNTUgLy8gZnVsbCBhcnJheQoJcHVzaGludCAzMgoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJdW5jb3ZlciAyCglleHRyYWN0X3VpbnQxNgoJZHVwIC8vIGR1cGxpY2F0ZSBzdGFydCBvZiBlbGVtZW50Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglzd2FwCglleHRyYWN0X3VpbnQxNiAvLyBnZXQgbnVtYmVyIG9mIGVsZW1lbnRzCglwdXNoaW50IDEgLy8gZ2V0IHR5cGUgbGVuZ3RoCgkqIC8vIG11bHRpcGx5IGJ5IHR5cGUgbGVuZ3RoCglwdXNoaW50IDIKCSsgLy8gYWRkIHR3byBmb3IgbGVuZ3RoCglleHRyYWN0MwoJZXh0cmFjdCAyIDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MTc3NDQzMmUgLy8gbWV0aG9kICJ1cGRhdGVTdGF0aWNGaWVsZEluRHluYW1pY09iamVjdEluQm94KClzdHJpbmciCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3VwZGF0ZVN0YXRpY0ZpZWxkSW5EeW5hbWljT2JqZWN0SW5Cb3gKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnIKCipwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50OgoJcHJvdG8gNCAzCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0xIC8vIGVsZW1lbnQKCWNvbmNhdAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3ViCgoqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCWNvbmNhdAoJZnJhbWVfYnVyeSAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJZHVwCglsZW4KCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJYnRvaQoJKwoJaXRvYgoJZXh0cmFjdCA2IDIKCWZyYW1lX2J1cnkgLTIgLy8gaGVhZCBvZmZzZXQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglzd2FwCgljb25jYXQKCWZyYW1lX2J1cnkgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCXJldHN1Yg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgwMDA0NjI0ZDYxNzAgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyB1cGRhdGVTdGF0aWNGaWVsZEluRHluYW1pY09iamVjdEluQm94KClzdHJpbmcKKmFiaV9yb3V0ZV91cGRhdGVTdGF0aWNGaWVsZEluRHluYW1pY09iamVjdEluQm94OgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgdXBkYXRlU3RhdGljRmllbGRJbkR5bmFtaWNPYmplY3RJbkJveCgpc3RyaW5nCgljYWxsc3ViIHVwZGF0ZVN0YXRpY0ZpZWxkSW5EeW5hbWljT2JqZWN0SW5Cb3gKCWR1cAoJbGVuCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHVwZGF0ZVN0YXRpY0ZpZWxkSW5EeW5hbWljT2JqZWN0SW5Cb3goKTogc3RyaW5nCnVwZGF0ZVN0YXRpY0ZpZWxkSW5EeW5hbWljT2JqZWN0SW5Cb3g6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTU3MwoJLy8gdGhpcy5iTWFwKCdiTWFwJykudmFsdWUgPSB7IGFkZHI6IHRoaXMudHhuLnNlbmRlciwgc3RyOiAnSGVsbG8gV29ybGQhJyB9CglieXRlIDB4MDAwNDYyNGQ2MTcwCglkdXAKCWJveF9kZWwKCXBvcAoJYnl0ZSAweCAvLyBpbml0aWFsIGhlYWQKCWJ5dGUgMHggLy8gaW5pdGlhbCB0YWlsCglwdXNoYnl0ZXMgMHgwMDIyIC8vIGluaXRpYWwgaGVhZCBvZmZzZXQKCXR4biBTZW5kZXIKCWNhbGxzdWIgKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMGM0ODY1NmM2YzZmMjA1NzZmNzI2YzY0MjEKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50Cglwb3AgLy8gcG9wIGhlYWQgb2Zmc2V0Cgljb25jYXQgLy8gY29uY2F0IGhlYWQgYW5kIHRhaWwKCWJveF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTU3NQoJLy8gdGhpcy5iTWFwKCdiTWFwJykudmFsdWUuYWRkciA9IHRoaXMudHhuLnNlbmRlcgoJYnl0ZSAweDAwMDQ2MjRkNjE3MAoJYm94X2dldAoKCS8vIGJveCB2YWx1ZSBkb2VzIG5vdCBleGlzdDogdGhpcy5iTWFwKCdiTWFwJykudmFsdWUKCWFzc2VydAoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgMAoJdHhuIFNlbmRlcgoJcmVwbGFjZTMKCWJ5dGUgMHgwMDA0NjI0ZDYxNzAKCWR1cAoJYm94X2RlbAoJcG9wCglzd2FwCglib3hfcHV0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE1NzYKCS8vIHJldHVybiB0aGlzLmJNYXAoJ2JNYXAnKS52YWx1ZS5zdHI7CglieXRlIDB4MDAwNDYyNGQ2MTcwCglib3hfZ2V0CgoJLy8gYm94IHZhbHVlIGRvZXMgbm90IGV4aXN0OiB0aGlzLmJNYXAoJ2JNYXAnKS52YWx1ZQoJYXNzZXJ0CglzdG9yZSAyNTUgLy8gZnVsbCBhcnJheQoJcHVzaGludCAzMgoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJdW5jb3ZlciAyCglleHRyYWN0X3VpbnQxNgoJZHVwIC8vIGR1cGxpY2F0ZSBzdGFydCBvZiBlbGVtZW50Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglzd2FwCglleHRyYWN0X3VpbnQxNiAvLyBnZXQgbnVtYmVyIG9mIGVsZW1lbnRzCglwdXNoaW50IDEgLy8gZ2V0IHR5cGUgbGVuZ3RoCgkqIC8vIG11bHRpcGx5IGJ5IHR5cGUgbGVuZ3RoCglwdXNoaW50IDIKCSsgLy8gYWRkIHR3byBmb3IgbGVuZ3RoCglleHRyYWN0MwoJZXh0cmFjdCAyIDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MTc3NDQzMmUgLy8gbWV0aG9kICJ1cGRhdGVTdGF0aWNGaWVsZEluRHluYW1pY09iamVjdEluQm94KClzdHJpbmciCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3VwZGF0ZVN0YXRpY0ZpZWxkSW5EeW5hbWljT2JqZWN0SW5Cb3gKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnIKCipwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50OgoJcHJvdG8gNCAzCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0xIC8vIGVsZW1lbnQKCWNvbmNhdAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3ViCgoqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCWNvbmNhdAoJZnJhbWVfYnVyeSAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJZHVwCglsZW4KCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJYnRvaQoJKwoJaXRvYgoJZXh0cmFjdCA2IDIKCWZyYW1lX2J1cnkgLTIgLy8gaGVhZCBvZmZzZXQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglzd2FwCgljb25jYXQKCWZyYW1lX2J1cnkgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCXJldHN1Yg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestUpdateStaticFieldInDynamicObjectInBox.arc56_draft.json b/tests/contracts/artifacts/ABITestUpdateStaticFieldInDynamicObjectInBox.arc56_draft.json index 2d5731350..d06e0f0dd 100644 --- a/tests/contracts/artifacts/ABITestUpdateStaticFieldInDynamicObjectInBox.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestUpdateStaticFieldInDynamicObjectInBox.arc56_draft.json @@ -1021,7 +1021,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgwMDA0NjI0ZDYxNzAgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyB1cGRhdGVTdGF0aWNGaWVsZEluRHluYW1pY09iamVjdEluQm94KClzdHJpbmcKKmFiaV9yb3V0ZV91cGRhdGVTdGF0aWNGaWVsZEluRHluYW1pY09iamVjdEluQm94OgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgdXBkYXRlU3RhdGljRmllbGRJbkR5bmFtaWNPYmplY3RJbkJveCgpc3RyaW5nCgljYWxsc3ViIHVwZGF0ZVN0YXRpY0ZpZWxkSW5EeW5hbWljT2JqZWN0SW5Cb3gKCWR1cAoJbGVuCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHVwZGF0ZVN0YXRpY0ZpZWxkSW5EeW5hbWljT2JqZWN0SW5Cb3goKTogc3RyaW5nCnVwZGF0ZVN0YXRpY0ZpZWxkSW5EeW5hbWljT2JqZWN0SW5Cb3g6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTU3MwoJLy8gdGhpcy5iTWFwKCdiTWFwJykudmFsdWUgPSB7IGFkZHI6IHRoaXMudHhuLnNlbmRlciwgc3RyOiAnSGVsbG8gV29ybGQhJyB9CglieXRlIDB4MDAwNDYyNGQ2MTcwCglkdXAKCWJveF9kZWwKCXBvcAoJYnl0ZSAweCAvLyBpbml0aWFsIGhlYWQKCWJ5dGUgMHggLy8gaW5pdGlhbCB0YWlsCglwdXNoYnl0ZXMgMHgwMDIyIC8vIGluaXRpYWwgaGVhZCBvZmZzZXQKCXR4biBTZW5kZXIKCWNhbGxzdWIgKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMGM0ODY1NmM2YzZmMjA1NzZmNzI2YzY0MjEKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50Cglwb3AgLy8gcG9wIGhlYWQgb2Zmc2V0Cgljb25jYXQgLy8gY29uY2F0IGhlYWQgYW5kIHRhaWwKCWJveF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTU3NQoJLy8gdGhpcy5iTWFwKCdiTWFwJykudmFsdWUuYWRkciA9IHRoaXMudHhuLnNlbmRlcgoJYnl0ZSAweDAwMDQ2MjRkNjE3MAoJYm94X2dldAoKCS8vIGJveCB2YWx1ZSBkb2VzIG5vdCBleGlzdDogdGhpcy5iTWFwKCdiTWFwJykudmFsdWUKCWFzc2VydAoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgMAoJdHhuIFNlbmRlcgoJcmVwbGFjZTMKCWJ5dGUgMHgwMDA0NjI0ZDYxNzAKCWR1cAoJYm94X2RlbAoJcG9wCglzd2FwCglib3hfcHV0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE1NzYKCS8vIHJldHVybiB0aGlzLmJNYXAoJ2JNYXAnKS52YWx1ZS5zdHI7CglieXRlIDB4MDAwNDYyNGQ2MTcwCglib3hfZ2V0CgoJLy8gYm94IHZhbHVlIGRvZXMgbm90IGV4aXN0OiB0aGlzLmJNYXAoJ2JNYXAnKS52YWx1ZQoJYXNzZXJ0CglzdG9yZSAyNTUgLy8gZnVsbCBhcnJheQoJcHVzaGludCAzMgoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJdW5jb3ZlciAyCglleHRyYWN0X3VpbnQxNgoJZHVwIC8vIGR1cGxpY2F0ZSBzdGFydCBvZiBlbGVtZW50Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglzd2FwCglleHRyYWN0X3VpbnQxNiAvLyBnZXQgbnVtYmVyIG9mIGVsZW1lbnRzCglwdXNoaW50IDEgLy8gZ2V0IHR5cGUgbGVuZ3RoCgkqIC8vIG11bHRpcGx5IGJ5IHR5cGUgbGVuZ3RoCglwdXNoaW50IDIKCSsgLy8gYWRkIHR3byBmb3IgbGVuZ3RoCglleHRyYWN0MwoJZXh0cmFjdCAyIDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MTc3NDQzMmUgLy8gbWV0aG9kICJ1cGRhdGVTdGF0aWNGaWVsZEluRHluYW1pY09iamVjdEluQm94KClzdHJpbmciCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3VwZGF0ZVN0YXRpY0ZpZWxkSW5EeW5hbWljT2JqZWN0SW5Cb3gKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnIKCipwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50OgoJcHJvdG8gNCAzCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0xIC8vIGVsZW1lbnQKCWNvbmNhdAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3ViCgoqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCWNvbmNhdAoJZnJhbWVfYnVyeSAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJZHVwCglsZW4KCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJYnRvaQoJKwoJaXRvYgoJZXh0cmFjdCA2IDIKCWZyYW1lX2J1cnkgLTIgLy8gaGVhZCBvZmZzZXQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglzd2FwCgljb25jYXQKCWZyYW1lX2J1cnkgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCXJldHN1Yg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgwMDA0NjI0ZDYxNzAgMHgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyB1cGRhdGVTdGF0aWNGaWVsZEluRHluYW1pY09iamVjdEluQm94KClzdHJpbmcKKmFiaV9yb3V0ZV91cGRhdGVTdGF0aWNGaWVsZEluRHluYW1pY09iamVjdEluQm94OgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgdXBkYXRlU3RhdGljRmllbGRJbkR5bmFtaWNPYmplY3RJbkJveCgpc3RyaW5nCgljYWxsc3ViIHVwZGF0ZVN0YXRpY0ZpZWxkSW5EeW5hbWljT2JqZWN0SW5Cb3gKCWR1cAoJbGVuCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHVwZGF0ZVN0YXRpY0ZpZWxkSW5EeW5hbWljT2JqZWN0SW5Cb3goKTogc3RyaW5nCnVwZGF0ZVN0YXRpY0ZpZWxkSW5EeW5hbWljT2JqZWN0SW5Cb3g6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTU3MwoJLy8gdGhpcy5iTWFwKCdiTWFwJykudmFsdWUgPSB7IGFkZHI6IHRoaXMudHhuLnNlbmRlciwgc3RyOiAnSGVsbG8gV29ybGQhJyB9CglieXRlIDB4MDAwNDYyNGQ2MTcwCglkdXAKCWJveF9kZWwKCXBvcAoJYnl0ZSAweCAvLyBpbml0aWFsIGhlYWQKCWJ5dGUgMHggLy8gaW5pdGlhbCB0YWlsCglwdXNoYnl0ZXMgMHgwMDIyIC8vIGluaXRpYWwgaGVhZCBvZmZzZXQKCXR4biBTZW5kZXIKCWNhbGxzdWIgKnByb2Nlc3Nfc3RhdGljX3R1cGxlX2VsZW1lbnQKCXB1c2hieXRlcyAweDAwMGM0ODY1NmM2YzZmMjA1NzZmNzI2YzY0MjEKCWNhbGxzdWIgKnByb2Nlc3NfZHluYW1pY190dXBsZV9lbGVtZW50Cglwb3AgLy8gcG9wIGhlYWQgb2Zmc2V0Cgljb25jYXQgLy8gY29uY2F0IGhlYWQgYW5kIHRhaWwKCWJveF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYWJpLmFsZ28udHM6MTU3NQoJLy8gdGhpcy5iTWFwKCdiTWFwJykudmFsdWUuYWRkciA9IHRoaXMudHhuLnNlbmRlcgoJYnl0ZSAweDAwMDQ2MjRkNjE3MAoJYm94X2dldAoKCS8vIGJveCB2YWx1ZSBkb2VzIG5vdCBleGlzdDogdGhpcy5iTWFwKCdiTWFwJykudmFsdWUKCWFzc2VydAoJc3RvcmUgMjU1IC8vIGZ1bGwgYXJyYXkKCWxvYWQgMjU1IC8vIGZ1bGwgYXJyYXkKCXB1c2hpbnQgMAoJdHhuIFNlbmRlcgoJcmVwbGFjZTMKCWJ5dGUgMHgwMDA0NjI0ZDYxNzAKCWR1cAoJYm94X2RlbAoJcG9wCglzd2FwCglib3hfcHV0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FiaS5hbGdvLnRzOjE1NzYKCS8vIHJldHVybiB0aGlzLmJNYXAoJ2JNYXAnKS52YWx1ZS5zdHI7CglieXRlIDB4MDAwNDYyNGQ2MTcwCglib3hfZ2V0CgoJLy8gYm94IHZhbHVlIGRvZXMgbm90IGV4aXN0OiB0aGlzLmJNYXAoJ2JNYXAnKS52YWx1ZQoJYXNzZXJ0CglzdG9yZSAyNTUgLy8gZnVsbCBhcnJheQoJcHVzaGludCAzMgoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJbG9hZCAyNTUgLy8gZnVsbCBhcnJheQoJdW5jb3ZlciAyCglleHRyYWN0X3VpbnQxNgoJZHVwIC8vIGR1cGxpY2F0ZSBzdGFydCBvZiBlbGVtZW50Cglsb2FkIDI1NSAvLyBmdWxsIGFycmF5Cglzd2FwCglleHRyYWN0X3VpbnQxNiAvLyBnZXQgbnVtYmVyIG9mIGVsZW1lbnRzCglwdXNoaW50IDEgLy8gZ2V0IHR5cGUgbGVuZ3RoCgkqIC8vIG11bHRpcGx5IGJ5IHR5cGUgbGVuZ3RoCglwdXNoaW50IDIKCSsgLy8gYWRkIHR3byBmb3IgbGVuZ3RoCglleHRyYWN0MwoJZXh0cmFjdCAyIDAKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MTc3NDQzMmUgLy8gbWV0aG9kICJ1cGRhdGVTdGF0aWNGaWVsZEluRHluYW1pY09iamVjdEluQm94KClzdHJpbmciCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3VwZGF0ZVN0YXRpY0ZpZWxkSW5EeW5hbWljT2JqZWN0SW5Cb3gKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnIKCipwcm9jZXNzX3N0YXRpY190dXBsZV9lbGVtZW50OgoJcHJvdG8gNCAzCglmcmFtZV9kaWcgLTQgLy8gdHVwbGUgaGVhZAoJZnJhbWVfZGlnIC0xIC8vIGVsZW1lbnQKCWNvbmNhdAoJZnJhbWVfZGlnIC0zIC8vIHR1cGxlIHRhaWwKCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJcmV0c3ViCgoqcHJvY2Vzc19keW5hbWljX3R1cGxlX2VsZW1lbnQ6Cglwcm90byA0IDMKCWZyYW1lX2RpZyAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCWNvbmNhdAoJZnJhbWVfYnVyeSAtNCAvLyB0dXBsZSBoZWFkCglmcmFtZV9kaWcgLTEgLy8gZWxlbWVudAoJZHVwCglsZW4KCWZyYW1lX2RpZyAtMiAvLyBoZWFkIG9mZnNldAoJYnRvaQoJKwoJaXRvYgoJZXh0cmFjdCA2IDIKCWZyYW1lX2J1cnkgLTIgLy8gaGVhZCBvZmZzZXQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglzd2FwCgljb25jYXQKCWZyYW1lX2J1cnkgLTMgLy8gdHVwbGUgdGFpbAoJZnJhbWVfZGlnIC00IC8vIHR1cGxlIGhlYWQKCWZyYW1lX2RpZyAtMyAvLyB0dXBsZSB0YWlsCglmcmFtZV9kaWcgLTIgLy8gaGVhZCBvZmZzZXQKCXJldHN1Yg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestUpdateStringInTuple.approval.teal b/tests/contracts/artifacts/ABITestUpdateStringInTuple.approval.teal index bf4bb85c3..7382b58ca 100644 --- a/tests/contracts/artifacts/ABITestUpdateStringInTuple.approval.teal +++ b/tests/contracts/artifacts/ABITestUpdateStringInTuple.approval.teal @@ -2,7 +2,7 @@ intcblock 2 bytecblock 0x000c48656c6c6f20576f726c6421 0x0002000a000b 0x0002000e000f 0x00021011 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestUpdateStringInTuple.arc32.json b/tests/contracts/artifacts/ABITestUpdateStringInTuple.arc32.json index b2849f48e..cd277affb 100644 --- a/tests/contracts/artifacts/ABITestUpdateStringInTuple.arc32.json +++ b/tests/contracts/artifacts/ABITestUpdateStringInTuple.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "#pragma version 10
intcblock 2
bytecblock 0x000c48656c6c6f20576f726c6421 0x0002000a000b 0x0002000e000f 0x00021011 0x

// This TEAL was generated by TEALScript v0.104.1
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// updateStringInTuple()(uint8,uint16[],string,uint16[],uint8[])
*abi_route_updateStringInTuple:
	// The ABI return prefix
	pushbytes 0x151f7c75

	// execute updateStringInTuple()(uint8,uint16[],string,uint16[],uint8[])
	callsub updateStringInTuple
	concat
	log
	pushint 1
	return

// updateStringInTuple(): [uint<8>, uint16[], string, uint16[], uint<8>[]]
updateStringInTuple:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/abi.algo.ts:560
	// a: [uint<8>, uint16[], string, uint16[], uint<8>[]] = [9, [8], 'Hi?', [6], [5]]
	byte 0x // initial head
	byte 0x // initial tail
	pushbytes 0x0009 // initial head offset
	pushbytes 0x09
	callsub *process_static_tuple_element
	pushbytes 0x00010008
	callsub *process_dynamic_tuple_element
	pushbytes 0x000348693f
	callsub *process_dynamic_tuple_element
	pushbytes 0x00010006
	callsub *process_dynamic_tuple_element
	pushbytes 0x000105
	callsub *process_dynamic_tuple_element
	pop // pop head offset
	concat // concat head and tail
	frame_bury 0 // a: [uint<8>, uint16[], string, uint16[], uint<8>[]]

	// tests/contracts/abi.algo.ts:562
	// a[0] = 99 as uint<8>
	frame_dig 0 // a: [uint<8>, uint16[], string, uint16[], uint<8>[]]
	store 255 // full array
	load 255 // full array
	pushbytes 0x63
	replace2 0
	frame_bury 0 // a: [uint<8>, uint16[], string, uint16[], uint<8>[]]

	// tests/contracts/abi.algo.ts:563
	// a[1] = [10, 11]
	frame_dig 0 // a: [uint<8>, uint16[], string, uint16[], uint<8>[]]
	store 255 // full array
	pushint 1
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 2 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x0002000a000b
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 250 // length difference
	load 251 // element head offset
	int 2
	+ // head ofset
	callsub *update_dynamic_head
	load 250 // length difference
	load 251 // element head offset
	pushint 4
	+ // head ofset
	callsub *update_dynamic_head
	load 250 // length difference
	load 251 // element head offset
	pushint 6
	+ // head ofset
	callsub *update_dynamic_head
	load 255 // full array
	frame_bury 0 // a: [uint<8>, uint16[], string, uint16[], uint<8>[]]

	// tests/contracts/abi.algo.ts:564
	// a[2] = 'Hello World!'
	frame_dig 0 // a: [uint<8>, uint16[], string, uint16[], uint<8>[]]
	store 255 // full array
	pushint 3
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	pushint 1 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x000c48656c6c6f20576f726c6421
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 250 // length difference
	load 251 // element head offset
	int 2
	+ // head ofset
	callsub *update_dynamic_head
	load 250 // length difference
	load 251 // element head offset
	pushint 4
	+ // head ofset
	callsub *update_dynamic_head
	load 255 // full array
	frame_bury 0 // a: [uint<8>, uint16[], string, uint16[], uint<8>[]]

	// tests/contracts/abi.algo.ts:565
	// a[3] = [14, 15]
	frame_dig 0 // a: [uint<8>, uint16[], string, uint16[], uint<8>[]]
	store 255 // full array
	pushint 5
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 2 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x0002000e000f
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 250 // length difference
	load 251 // element head offset
	int 2
	+ // head ofset
	callsub *update_dynamic_head
	load 255 // full array
	frame_bury 0 // a: [uint<8>, uint16[], string, uint16[], uint<8>[]]

	// tests/contracts/abi.algo.ts:566
	// a[4] = [16, 17]
	frame_dig 0 // a: [uint<8>, uint16[], string, uint16[], uint<8>[]]
	store 255 // full array
	pushint 7
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	pushint 1 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x00021011
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 255 // full array
	frame_bury 0 // a: [uint<8>, uint16[], string, uint16[], uint<8>[]]

	// tests/contracts/abi.algo.ts:568
	// return a;
	frame_dig 0 // a: [uint<8>, uint16[], string, uint16[], uint<8>[]]

	// set the subroutine return value
	frame_bury 0
	retsub

*abi_route_createApplication:
	pushint 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0xf1fc2586 // method "updateStringInTuple()(uint8,uint16[],string,uint16[],uint8[])"
	txna ApplicationArgs 0
	match *abi_route_updateStringInTuple

	// this contract does not implement the given ABI method for call NoOp
	err

*process_static_tuple_element:
	proto 4 3
	frame_dig -4 // tuple head
	frame_dig -1 // element
	concat
	frame_dig -3 // tuple tail
	frame_dig -2 // head offset
	retsub

*process_dynamic_tuple_element:
	proto 4 3
	frame_dig -4 // tuple head
	frame_dig -2 // head offset
	concat
	frame_bury -4 // tuple head
	frame_dig -1 // element
	dup
	len
	frame_dig -2 // head offset
	btoi
	+
	itob
	extract 6 2
	frame_bury -2 // head offset
	frame_dig -3 // tuple tail
	swap
	concat
	frame_bury -3 // tuple tail
	frame_dig -4 // tuple head
	frame_dig -3 // tuple tail
	frame_dig -2 // head offset
	retsub

*update_dynamic_head:
	proto 2 0
	frame_dig -2 // length difference
	load 255 // full array
	frame_dig -1 // dynamic array offset
	extract_uint16 // extract dynamic array offset
	load 249 // subtract head difference
	bz *subtract_head_difference
	+ // add difference to offset
	b *end_calc_new_head

*subtract_head_difference:
	swap
	- // subtract difference from offet

*end_calc_new_head:
	itob // convert to bytes
	extract 6 2 // convert to uint16
	load 255 // full array
	swap
	frame_dig -1 // offset
	swap
	replace3 // update offset
	store 255 // full array
	retsub

*get_length_difference:
	load 252 // new element
	len // length of new element
	load 253 // element length
	<
	bnz *swapped_difference
	load 252 // new element
	len // length of new element
	load 253 // element length
	pushint 1
	store 249 // subtract head difference
	b *get_difference

*swapped_difference:
	load 253 // element length
	load 252 // new element
	len // length of new element
	pushint 0
	store 249 // subtract head difference

*get_difference:
	- // get length difference
	store 250 // length difference
	retsub", + "approval": "#pragma version 10
intcblock 2
bytecblock 0x000c48656c6c6f20576f726c6421 0x0002000a000b 0x0002000e000f 0x00021011 0x

// This TEAL was generated by TEALScript v0.105.0
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// updateStringInTuple()(uint8,uint16[],string,uint16[],uint8[])
*abi_route_updateStringInTuple:
	// The ABI return prefix
	pushbytes 0x151f7c75

	// execute updateStringInTuple()(uint8,uint16[],string,uint16[],uint8[])
	callsub updateStringInTuple
	concat
	log
	pushint 1
	return

// updateStringInTuple(): [uint<8>, uint16[], string, uint16[], uint<8>[]]
updateStringInTuple:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/abi.algo.ts:560
	// a: [uint<8>, uint16[], string, uint16[], uint<8>[]] = [9, [8], 'Hi?', [6], [5]]
	byte 0x // initial head
	byte 0x // initial tail
	pushbytes 0x0009 // initial head offset
	pushbytes 0x09
	callsub *process_static_tuple_element
	pushbytes 0x00010008
	callsub *process_dynamic_tuple_element
	pushbytes 0x000348693f
	callsub *process_dynamic_tuple_element
	pushbytes 0x00010006
	callsub *process_dynamic_tuple_element
	pushbytes 0x000105
	callsub *process_dynamic_tuple_element
	pop // pop head offset
	concat // concat head and tail
	frame_bury 0 // a: [uint<8>, uint16[], string, uint16[], uint<8>[]]

	// tests/contracts/abi.algo.ts:562
	// a[0] = 99 as uint<8>
	frame_dig 0 // a: [uint<8>, uint16[], string, uint16[], uint<8>[]]
	store 255 // full array
	load 255 // full array
	pushbytes 0x63
	replace2 0
	frame_bury 0 // a: [uint<8>, uint16[], string, uint16[], uint<8>[]]

	// tests/contracts/abi.algo.ts:563
	// a[1] = [10, 11]
	frame_dig 0 // a: [uint<8>, uint16[], string, uint16[], uint<8>[]]
	store 255 // full array
	pushint 1
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 2 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x0002000a000b
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 250 // length difference
	load 251 // element head offset
	int 2
	+ // head ofset
	callsub *update_dynamic_head
	load 250 // length difference
	load 251 // element head offset
	pushint 4
	+ // head ofset
	callsub *update_dynamic_head
	load 250 // length difference
	load 251 // element head offset
	pushint 6
	+ // head ofset
	callsub *update_dynamic_head
	load 255 // full array
	frame_bury 0 // a: [uint<8>, uint16[], string, uint16[], uint<8>[]]

	// tests/contracts/abi.algo.ts:564
	// a[2] = 'Hello World!'
	frame_dig 0 // a: [uint<8>, uint16[], string, uint16[], uint<8>[]]
	store 255 // full array
	pushint 3
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	pushint 1 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x000c48656c6c6f20576f726c6421
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 250 // length difference
	load 251 // element head offset
	int 2
	+ // head ofset
	callsub *update_dynamic_head
	load 250 // length difference
	load 251 // element head offset
	pushint 4
	+ // head ofset
	callsub *update_dynamic_head
	load 255 // full array
	frame_bury 0 // a: [uint<8>, uint16[], string, uint16[], uint<8>[]]

	// tests/contracts/abi.algo.ts:565
	// a[3] = [14, 15]
	frame_dig 0 // a: [uint<8>, uint16[], string, uint16[], uint<8>[]]
	store 255 // full array
	pushint 5
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 2 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x0002000e000f
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 250 // length difference
	load 251 // element head offset
	int 2
	+ // head ofset
	callsub *update_dynamic_head
	load 255 // full array
	frame_bury 0 // a: [uint<8>, uint16[], string, uint16[], uint<8>[]]

	// tests/contracts/abi.algo.ts:566
	// a[4] = [16, 17]
	frame_dig 0 // a: [uint<8>, uint16[], string, uint16[], uint<8>[]]
	store 255 // full array
	pushint 7
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	pushint 1 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x00021011
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 255 // full array
	frame_bury 0 // a: [uint<8>, uint16[], string, uint16[], uint<8>[]]

	// tests/contracts/abi.algo.ts:568
	// return a;
	frame_dig 0 // a: [uint<8>, uint16[], string, uint16[], uint<8>[]]

	// set the subroutine return value
	frame_bury 0
	retsub

*abi_route_createApplication:
	pushint 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0xf1fc2586 // method "updateStringInTuple()(uint8,uint16[],string,uint16[],uint8[])"
	txna ApplicationArgs 0
	match *abi_route_updateStringInTuple

	// this contract does not implement the given ABI method for call NoOp
	err

*process_static_tuple_element:
	proto 4 3
	frame_dig -4 // tuple head
	frame_dig -1 // element
	concat
	frame_dig -3 // tuple tail
	frame_dig -2 // head offset
	retsub

*process_dynamic_tuple_element:
	proto 4 3
	frame_dig -4 // tuple head
	frame_dig -2 // head offset
	concat
	frame_bury -4 // tuple head
	frame_dig -1 // element
	dup
	len
	frame_dig -2 // head offset
	btoi
	+
	itob
	extract 6 2
	frame_bury -2 // head offset
	frame_dig -3 // tuple tail
	swap
	concat
	frame_bury -3 // tuple tail
	frame_dig -4 // tuple head
	frame_dig -3 // tuple tail
	frame_dig -2 // head offset
	retsub

*update_dynamic_head:
	proto 2 0
	frame_dig -2 // length difference
	load 255 // full array
	frame_dig -1 // dynamic array offset
	extract_uint16 // extract dynamic array offset
	load 249 // subtract head difference
	bz *subtract_head_difference
	+ // add difference to offset
	b *end_calc_new_head

*subtract_head_difference:
	swap
	- // subtract difference from offet

*end_calc_new_head:
	itob // convert to bytes
	extract 6 2 // convert to uint16
	load 255 // full array
	swap
	frame_dig -1 // offset
	swap
	replace3 // update offset
	store 255 // full array
	retsub

*get_length_difference:
	load 252 // new element
	len // length of new element
	load 253 // element length
	<
	bnz *swapped_difference
	load 252 // new element
	len // length of new element
	load 253 // element length
	pushint 1
	store 249 // subtract head difference
	b *get_difference

*swapped_difference:
	load 253 // element length
	load 252 // new element
	len // length of new element
	pushint 0
	store 249 // subtract head difference

*get_difference:
	- // get length difference
	store 250 // length difference
	retsub", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestUpdateStringInTuple.arc56_draft.json b/tests/contracts/artifacts/ABITestUpdateStringInTuple.arc56_draft.json index 8081d2635..5de91909e 100644 --- a/tests/contracts/artifacts/ABITestUpdateStringInTuple.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestUpdateStringInTuple.arc56_draft.json @@ -2619,7 +2619,7 @@ } }, "source": { - "approval": "#pragma version 10
intcblock 2
bytecblock 0x000c48656c6c6f20576f726c6421 0x0002000a000b 0x0002000e000f 0x00021011 0x

// This TEAL was generated by TEALScript v0.104.1
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// updateStringInTuple()(uint8,uint16[],string,uint16[],uint8[])
*abi_route_updateStringInTuple:
	// The ABI return prefix
	pushbytes 0x151f7c75

	// execute updateStringInTuple()(uint8,uint16[],string,uint16[],uint8[])
	callsub updateStringInTuple
	concat
	log
	pushint 1
	return

// updateStringInTuple(): [uint<8>, uint16[], string, uint16[], uint<8>[]]
updateStringInTuple:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/abi.algo.ts:560
	// a: [uint<8>, uint16[], string, uint16[], uint<8>[]] = [9, [8], 'Hi?', [6], [5]]
	byte 0x // initial head
	byte 0x // initial tail
	pushbytes 0x0009 // initial head offset
	pushbytes 0x09
	callsub *process_static_tuple_element
	pushbytes 0x00010008
	callsub *process_dynamic_tuple_element
	pushbytes 0x000348693f
	callsub *process_dynamic_tuple_element
	pushbytes 0x00010006
	callsub *process_dynamic_tuple_element
	pushbytes 0x000105
	callsub *process_dynamic_tuple_element
	pop // pop head offset
	concat // concat head and tail
	frame_bury 0 // a: [uint<8>, uint16[], string, uint16[], uint<8>[]]

	// tests/contracts/abi.algo.ts:562
	// a[0] = 99 as uint<8>
	frame_dig 0 // a: [uint<8>, uint16[], string, uint16[], uint<8>[]]
	store 255 // full array
	load 255 // full array
	pushbytes 0x63
	replace2 0
	frame_bury 0 // a: [uint<8>, uint16[], string, uint16[], uint<8>[]]

	// tests/contracts/abi.algo.ts:563
	// a[1] = [10, 11]
	frame_dig 0 // a: [uint<8>, uint16[], string, uint16[], uint<8>[]]
	store 255 // full array
	pushint 1
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 2 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x0002000a000b
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 250 // length difference
	load 251 // element head offset
	int 2
	+ // head ofset
	callsub *update_dynamic_head
	load 250 // length difference
	load 251 // element head offset
	pushint 4
	+ // head ofset
	callsub *update_dynamic_head
	load 250 // length difference
	load 251 // element head offset
	pushint 6
	+ // head ofset
	callsub *update_dynamic_head
	load 255 // full array
	frame_bury 0 // a: [uint<8>, uint16[], string, uint16[], uint<8>[]]

	// tests/contracts/abi.algo.ts:564
	// a[2] = 'Hello World!'
	frame_dig 0 // a: [uint<8>, uint16[], string, uint16[], uint<8>[]]
	store 255 // full array
	pushint 3
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	pushint 1 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x000c48656c6c6f20576f726c6421
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 250 // length difference
	load 251 // element head offset
	int 2
	+ // head ofset
	callsub *update_dynamic_head
	load 250 // length difference
	load 251 // element head offset
	pushint 4
	+ // head ofset
	callsub *update_dynamic_head
	load 255 // full array
	frame_bury 0 // a: [uint<8>, uint16[], string, uint16[], uint<8>[]]

	// tests/contracts/abi.algo.ts:565
	// a[3] = [14, 15]
	frame_dig 0 // a: [uint<8>, uint16[], string, uint16[], uint<8>[]]
	store 255 // full array
	pushint 5
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 2 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x0002000e000f
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 250 // length difference
	load 251 // element head offset
	int 2
	+ // head ofset
	callsub *update_dynamic_head
	load 255 // full array
	frame_bury 0 // a: [uint<8>, uint16[], string, uint16[], uint<8>[]]

	// tests/contracts/abi.algo.ts:566
	// a[4] = [16, 17]
	frame_dig 0 // a: [uint<8>, uint16[], string, uint16[], uint<8>[]]
	store 255 // full array
	pushint 7
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	pushint 1 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x00021011
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 255 // full array
	frame_bury 0 // a: [uint<8>, uint16[], string, uint16[], uint<8>[]]

	// tests/contracts/abi.algo.ts:568
	// return a;
	frame_dig 0 // a: [uint<8>, uint16[], string, uint16[], uint<8>[]]

	// set the subroutine return value
	frame_bury 0
	retsub

*abi_route_createApplication:
	pushint 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0xf1fc2586 // method "updateStringInTuple()(uint8,uint16[],string,uint16[],uint8[])"
	txna ApplicationArgs 0
	match *abi_route_updateStringInTuple

	// this contract does not implement the given ABI method for call NoOp
	err

*process_static_tuple_element:
	proto 4 3
	frame_dig -4 // tuple head
	frame_dig -1 // element
	concat
	frame_dig -3 // tuple tail
	frame_dig -2 // head offset
	retsub

*process_dynamic_tuple_element:
	proto 4 3
	frame_dig -4 // tuple head
	frame_dig -2 // head offset
	concat
	frame_bury -4 // tuple head
	frame_dig -1 // element
	dup
	len
	frame_dig -2 // head offset
	btoi
	+
	itob
	extract 6 2
	frame_bury -2 // head offset
	frame_dig -3 // tuple tail
	swap
	concat
	frame_bury -3 // tuple tail
	frame_dig -4 // tuple head
	frame_dig -3 // tuple tail
	frame_dig -2 // head offset
	retsub

*update_dynamic_head:
	proto 2 0
	frame_dig -2 // length difference
	load 255 // full array
	frame_dig -1 // dynamic array offset
	extract_uint16 // extract dynamic array offset
	load 249 // subtract head difference
	bz *subtract_head_difference
	+ // add difference to offset
	b *end_calc_new_head

*subtract_head_difference:
	swap
	- // subtract difference from offet

*end_calc_new_head:
	itob // convert to bytes
	extract 6 2 // convert to uint16
	load 255 // full array
	swap
	frame_dig -1 // offset
	swap
	replace3 // update offset
	store 255 // full array
	retsub

*get_length_difference:
	load 252 // new element
	len // length of new element
	load 253 // element length
	<
	bnz *swapped_difference
	load 252 // new element
	len // length of new element
	load 253 // element length
	pushint 1
	store 249 // subtract head difference
	b *get_difference

*swapped_difference:
	load 253 // element length
	load 252 // new element
	len // length of new element
	pushint 0
	store 249 // subtract head difference

*get_difference:
	- // get length difference
	store 250 // length difference
	retsub", + "approval": "#pragma version 10
intcblock 2
bytecblock 0x000c48656c6c6f20576f726c6421 0x0002000a000b 0x0002000e000f 0x00021011 0x

// This TEAL was generated by TEALScript v0.105.0
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// updateStringInTuple()(uint8,uint16[],string,uint16[],uint8[])
*abi_route_updateStringInTuple:
	// The ABI return prefix
	pushbytes 0x151f7c75

	// execute updateStringInTuple()(uint8,uint16[],string,uint16[],uint8[])
	callsub updateStringInTuple
	concat
	log
	pushint 1
	return

// updateStringInTuple(): [uint<8>, uint16[], string, uint16[], uint<8>[]]
updateStringInTuple:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/abi.algo.ts:560
	// a: [uint<8>, uint16[], string, uint16[], uint<8>[]] = [9, [8], 'Hi?', [6], [5]]
	byte 0x // initial head
	byte 0x // initial tail
	pushbytes 0x0009 // initial head offset
	pushbytes 0x09
	callsub *process_static_tuple_element
	pushbytes 0x00010008
	callsub *process_dynamic_tuple_element
	pushbytes 0x000348693f
	callsub *process_dynamic_tuple_element
	pushbytes 0x00010006
	callsub *process_dynamic_tuple_element
	pushbytes 0x000105
	callsub *process_dynamic_tuple_element
	pop // pop head offset
	concat // concat head and tail
	frame_bury 0 // a: [uint<8>, uint16[], string, uint16[], uint<8>[]]

	// tests/contracts/abi.algo.ts:562
	// a[0] = 99 as uint<8>
	frame_dig 0 // a: [uint<8>, uint16[], string, uint16[], uint<8>[]]
	store 255 // full array
	load 255 // full array
	pushbytes 0x63
	replace2 0
	frame_bury 0 // a: [uint<8>, uint16[], string, uint16[], uint<8>[]]

	// tests/contracts/abi.algo.ts:563
	// a[1] = [10, 11]
	frame_dig 0 // a: [uint<8>, uint16[], string, uint16[], uint<8>[]]
	store 255 // full array
	pushint 1
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 2 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x0002000a000b
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 250 // length difference
	load 251 // element head offset
	int 2
	+ // head ofset
	callsub *update_dynamic_head
	load 250 // length difference
	load 251 // element head offset
	pushint 4
	+ // head ofset
	callsub *update_dynamic_head
	load 250 // length difference
	load 251 // element head offset
	pushint 6
	+ // head ofset
	callsub *update_dynamic_head
	load 255 // full array
	frame_bury 0 // a: [uint<8>, uint16[], string, uint16[], uint<8>[]]

	// tests/contracts/abi.algo.ts:564
	// a[2] = 'Hello World!'
	frame_dig 0 // a: [uint<8>, uint16[], string, uint16[], uint<8>[]]
	store 255 // full array
	pushint 3
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	pushint 1 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x000c48656c6c6f20576f726c6421
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 250 // length difference
	load 251 // element head offset
	int 2
	+ // head ofset
	callsub *update_dynamic_head
	load 250 // length difference
	load 251 // element head offset
	pushint 4
	+ // head ofset
	callsub *update_dynamic_head
	load 255 // full array
	frame_bury 0 // a: [uint<8>, uint16[], string, uint16[], uint<8>[]]

	// tests/contracts/abi.algo.ts:565
	// a[3] = [14, 15]
	frame_dig 0 // a: [uint<8>, uint16[], string, uint16[], uint<8>[]]
	store 255 // full array
	pushint 5
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 2 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x0002000e000f
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 250 // length difference
	load 251 // element head offset
	int 2
	+ // head ofset
	callsub *update_dynamic_head
	load 255 // full array
	frame_bury 0 // a: [uint<8>, uint16[], string, uint16[], uint<8>[]]

	// tests/contracts/abi.algo.ts:566
	// a[4] = [16, 17]
	frame_dig 0 // a: [uint<8>, uint16[], string, uint16[], uint<8>[]]
	store 255 // full array
	pushint 7
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	pushint 1 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x00021011
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 255 // full array
	frame_bury 0 // a: [uint<8>, uint16[], string, uint16[], uint<8>[]]

	// tests/contracts/abi.algo.ts:568
	// return a;
	frame_dig 0 // a: [uint<8>, uint16[], string, uint16[], uint<8>[]]

	// set the subroutine return value
	frame_bury 0
	retsub

*abi_route_createApplication:
	pushint 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0xf1fc2586 // method "updateStringInTuple()(uint8,uint16[],string,uint16[],uint8[])"
	txna ApplicationArgs 0
	match *abi_route_updateStringInTuple

	// this contract does not implement the given ABI method for call NoOp
	err

*process_static_tuple_element:
	proto 4 3
	frame_dig -4 // tuple head
	frame_dig -1 // element
	concat
	frame_dig -3 // tuple tail
	frame_dig -2 // head offset
	retsub

*process_dynamic_tuple_element:
	proto 4 3
	frame_dig -4 // tuple head
	frame_dig -2 // head offset
	concat
	frame_bury -4 // tuple head
	frame_dig -1 // element
	dup
	len
	frame_dig -2 // head offset
	btoi
	+
	itob
	extract 6 2
	frame_bury -2 // head offset
	frame_dig -3 // tuple tail
	swap
	concat
	frame_bury -3 // tuple tail
	frame_dig -4 // tuple head
	frame_dig -3 // tuple tail
	frame_dig -2 // head offset
	retsub

*update_dynamic_head:
	proto 2 0
	frame_dig -2 // length difference
	load 255 // full array
	frame_dig -1 // dynamic array offset
	extract_uint16 // extract dynamic array offset
	load 249 // subtract head difference
	bz *subtract_head_difference
	+ // add difference to offset
	b *end_calc_new_head

*subtract_head_difference:
	swap
	- // subtract difference from offet

*end_calc_new_head:
	itob // convert to bytes
	extract 6 2 // convert to uint16
	load 255 // full array
	swap
	frame_dig -1 // offset
	swap
	replace3 // update offset
	store 255 // full array
	retsub

*get_length_difference:
	load 252 // new element
	len // length of new element
	load 253 // element length
	<
	bnz *swapped_difference
	load 252 // new element
	len // length of new element
	load 253 // element length
	pushint 1
	store 249 // subtract head difference
	b *get_difference

*swapped_difference:
	load 253 // element length
	load 252 // new element
	len // length of new element
	pushint 0
	store 249 // subtract head difference

*get_difference:
	- // get length difference
	store 250 // length difference
	retsub", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ABITestUpdateTupleWithOnlyDynamicTypes.approval.teal b/tests/contracts/artifacts/ABITestUpdateTupleWithOnlyDynamicTypes.approval.teal index bb1a14682..38aa4153e 100644 --- a/tests/contracts/artifacts/ABITestUpdateTupleWithOnlyDynamicTypes.approval.teal +++ b/tests/contracts/artifacts/ABITestUpdateTupleWithOnlyDynamicTypes.approval.teal @@ -2,7 +2,7 @@ intcblock 2 bytecblock 0x000200040005 0x000200060007 0x000200080009 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ABITestUpdateTupleWithOnlyDynamicTypes.arc32.json b/tests/contracts/artifacts/ABITestUpdateTupleWithOnlyDynamicTypes.arc32.json index 7820872b9..a01cdebd7 100644 --- a/tests/contracts/artifacts/ABITestUpdateTupleWithOnlyDynamicTypes.arc32.json +++ b/tests/contracts/artifacts/ABITestUpdateTupleWithOnlyDynamicTypes.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "#pragma version 10
intcblock 2
bytecblock 0x000200040005 0x000200060007 0x000200080009 0x

// This TEAL was generated by TEALScript v0.104.1
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// updateTupleWithOnlyDynamicTypes()(uint16[],uint16[],uint16[])
*abi_route_updateTupleWithOnlyDynamicTypes:
	// The ABI return prefix
	pushbytes 0x151f7c75

	// execute updateTupleWithOnlyDynamicTypes()(uint16[],uint16[],uint16[])
	callsub updateTupleWithOnlyDynamicTypes
	concat
	log
	pushint 1
	return

// updateTupleWithOnlyDynamicTypes(): [uint16[], uint16[], uint16[]]
updateTupleWithOnlyDynamicTypes:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/abi.algo.ts:574
	// a: [uint16[], uint16[], uint16[]] = [[1], [2], [3]]
	byte 0x // initial head
	byte 0x // initial tail
	pushbytes 0x0006 // initial head offset
	pushbytes 0x00010001
	callsub *process_dynamic_tuple_element
	pushbytes 0x00010002
	callsub *process_dynamic_tuple_element
	pushbytes 0x00010003
	callsub *process_dynamic_tuple_element
	pop // pop head offset
	concat // concat head and tail
	frame_bury 0 // a: [uint16[], uint16[], uint16[]]

	// tests/contracts/abi.algo.ts:576
	// a[0] = [4, 5]
	frame_dig 0 // a: [uint16[], uint16[], uint16[]]
	store 255 // full array
	pushint 0
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 2 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x000200040005
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 250 // length difference
	load 251 // element head offset
	int 2
	+ // head ofset
	callsub *update_dynamic_head
	load 250 // length difference
	load 251 // element head offset
	pushint 4
	+ // head ofset
	callsub *update_dynamic_head
	load 255 // full array
	frame_bury 0 // a: [uint16[], uint16[], uint16[]]

	// tests/contracts/abi.algo.ts:577
	// a[1] = [6, 7]
	frame_dig 0 // a: [uint16[], uint16[], uint16[]]
	store 255 // full array
	int 2
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 2 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x000200060007
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 250 // length difference
	load 251 // element head offset
	int 2
	+ // head ofset
	callsub *update_dynamic_head
	load 255 // full array
	frame_bury 0 // a: [uint16[], uint16[], uint16[]]

	// tests/contracts/abi.algo.ts:578
	// a[2] = [8, 9]
	frame_dig 0 // a: [uint16[], uint16[], uint16[]]
	store 255 // full array
	pushint 4
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 2 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x000200080009
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 255 // full array
	frame_bury 0 // a: [uint16[], uint16[], uint16[]]

	// tests/contracts/abi.algo.ts:580
	// return a;
	frame_dig 0 // a: [uint16[], uint16[], uint16[]]

	// set the subroutine return value
	frame_bury 0
	retsub

*abi_route_createApplication:
	pushint 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x405741a9 // method "updateTupleWithOnlyDynamicTypes()(uint16[],uint16[],uint16[])"
	txna ApplicationArgs 0
	match *abi_route_updateTupleWithOnlyDynamicTypes

	// this contract does not implement the given ABI method for call NoOp
	err

*process_dynamic_tuple_element:
	proto 4 3
	frame_dig -4 // tuple head
	frame_dig -2 // head offset
	concat
	frame_bury -4 // tuple head
	frame_dig -1 // element
	dup
	len
	frame_dig -2 // head offset
	btoi
	+
	itob
	extract 6 2
	frame_bury -2 // head offset
	frame_dig -3 // tuple tail
	swap
	concat
	frame_bury -3 // tuple tail
	frame_dig -4 // tuple head
	frame_dig -3 // tuple tail
	frame_dig -2 // head offset
	retsub

*update_dynamic_head:
	proto 2 0
	frame_dig -2 // length difference
	load 255 // full array
	frame_dig -1 // dynamic array offset
	extract_uint16 // extract dynamic array offset
	load 249 // subtract head difference
	bz *subtract_head_difference
	+ // add difference to offset
	b *end_calc_new_head

*subtract_head_difference:
	swap
	- // subtract difference from offet

*end_calc_new_head:
	itob // convert to bytes
	extract 6 2 // convert to uint16
	load 255 // full array
	swap
	frame_dig -1 // offset
	swap
	replace3 // update offset
	store 255 // full array
	retsub

*get_length_difference:
	load 252 // new element
	len // length of new element
	load 253 // element length
	<
	bnz *swapped_difference
	load 252 // new element
	len // length of new element
	load 253 // element length
	pushint 1
	store 249 // subtract head difference
	b *get_difference

*swapped_difference:
	load 253 // element length
	load 252 // new element
	len // length of new element
	pushint 0
	store 249 // subtract head difference

*get_difference:
	- // get length difference
	store 250 // length difference
	retsub", + "approval": "#pragma version 10
intcblock 2
bytecblock 0x000200040005 0x000200060007 0x000200080009 0x

// This TEAL was generated by TEALScript v0.105.0
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// updateTupleWithOnlyDynamicTypes()(uint16[],uint16[],uint16[])
*abi_route_updateTupleWithOnlyDynamicTypes:
	// The ABI return prefix
	pushbytes 0x151f7c75

	// execute updateTupleWithOnlyDynamicTypes()(uint16[],uint16[],uint16[])
	callsub updateTupleWithOnlyDynamicTypes
	concat
	log
	pushint 1
	return

// updateTupleWithOnlyDynamicTypes(): [uint16[], uint16[], uint16[]]
updateTupleWithOnlyDynamicTypes:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/abi.algo.ts:574
	// a: [uint16[], uint16[], uint16[]] = [[1], [2], [3]]
	byte 0x // initial head
	byte 0x // initial tail
	pushbytes 0x0006 // initial head offset
	pushbytes 0x00010001
	callsub *process_dynamic_tuple_element
	pushbytes 0x00010002
	callsub *process_dynamic_tuple_element
	pushbytes 0x00010003
	callsub *process_dynamic_tuple_element
	pop // pop head offset
	concat // concat head and tail
	frame_bury 0 // a: [uint16[], uint16[], uint16[]]

	// tests/contracts/abi.algo.ts:576
	// a[0] = [4, 5]
	frame_dig 0 // a: [uint16[], uint16[], uint16[]]
	store 255 // full array
	pushint 0
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 2 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x000200040005
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 250 // length difference
	load 251 // element head offset
	int 2
	+ // head ofset
	callsub *update_dynamic_head
	load 250 // length difference
	load 251 // element head offset
	pushint 4
	+ // head ofset
	callsub *update_dynamic_head
	load 255 // full array
	frame_bury 0 // a: [uint16[], uint16[], uint16[]]

	// tests/contracts/abi.algo.ts:577
	// a[1] = [6, 7]
	frame_dig 0 // a: [uint16[], uint16[], uint16[]]
	store 255 // full array
	int 2
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 2 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x000200060007
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 250 // length difference
	load 251 // element head offset
	int 2
	+ // head ofset
	callsub *update_dynamic_head
	load 255 // full array
	frame_bury 0 // a: [uint16[], uint16[], uint16[]]

	// tests/contracts/abi.algo.ts:578
	// a[2] = [8, 9]
	frame_dig 0 // a: [uint16[], uint16[], uint16[]]
	store 255 // full array
	pushint 4
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 2 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x000200080009
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 255 // full array
	frame_bury 0 // a: [uint16[], uint16[], uint16[]]

	// tests/contracts/abi.algo.ts:580
	// return a;
	frame_dig 0 // a: [uint16[], uint16[], uint16[]]

	// set the subroutine return value
	frame_bury 0
	retsub

*abi_route_createApplication:
	pushint 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x405741a9 // method "updateTupleWithOnlyDynamicTypes()(uint16[],uint16[],uint16[])"
	txna ApplicationArgs 0
	match *abi_route_updateTupleWithOnlyDynamicTypes

	// this contract does not implement the given ABI method for call NoOp
	err

*process_dynamic_tuple_element:
	proto 4 3
	frame_dig -4 // tuple head
	frame_dig -2 // head offset
	concat
	frame_bury -4 // tuple head
	frame_dig -1 // element
	dup
	len
	frame_dig -2 // head offset
	btoi
	+
	itob
	extract 6 2
	frame_bury -2 // head offset
	frame_dig -3 // tuple tail
	swap
	concat
	frame_bury -3 // tuple tail
	frame_dig -4 // tuple head
	frame_dig -3 // tuple tail
	frame_dig -2 // head offset
	retsub

*update_dynamic_head:
	proto 2 0
	frame_dig -2 // length difference
	load 255 // full array
	frame_dig -1 // dynamic array offset
	extract_uint16 // extract dynamic array offset
	load 249 // subtract head difference
	bz *subtract_head_difference
	+ // add difference to offset
	b *end_calc_new_head

*subtract_head_difference:
	swap
	- // subtract difference from offet

*end_calc_new_head:
	itob // convert to bytes
	extract 6 2 // convert to uint16
	load 255 // full array
	swap
	frame_dig -1 // offset
	swap
	replace3 // update offset
	store 255 // full array
	retsub

*get_length_difference:
	load 252 // new element
	len // length of new element
	load 253 // element length
	<
	bnz *swapped_difference
	load 252 // new element
	len // length of new element
	load 253 // element length
	pushint 1
	store 249 // subtract head difference
	b *get_difference

*swapped_difference:
	load 253 // element length
	load 252 // new element
	len // length of new element
	pushint 0
	store 249 // subtract head difference

*get_difference:
	- // get length difference
	store 250 // length difference
	retsub", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ABITestUpdateTupleWithOnlyDynamicTypes.arc56_draft.json b/tests/contracts/artifacts/ABITestUpdateTupleWithOnlyDynamicTypes.arc56_draft.json index 445cf020c..b1ebe84b0 100644 --- a/tests/contracts/artifacts/ABITestUpdateTupleWithOnlyDynamicTypes.arc56_draft.json +++ b/tests/contracts/artifacts/ABITestUpdateTupleWithOnlyDynamicTypes.arc56_draft.json @@ -2025,7 +2025,7 @@ } }, "source": { - "approval": "#pragma version 10
intcblock 2
bytecblock 0x000200040005 0x000200060007 0x000200080009 0x

// This TEAL was generated by TEALScript v0.104.1
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// updateTupleWithOnlyDynamicTypes()(uint16[],uint16[],uint16[])
*abi_route_updateTupleWithOnlyDynamicTypes:
	// The ABI return prefix
	pushbytes 0x151f7c75

	// execute updateTupleWithOnlyDynamicTypes()(uint16[],uint16[],uint16[])
	callsub updateTupleWithOnlyDynamicTypes
	concat
	log
	pushint 1
	return

// updateTupleWithOnlyDynamicTypes(): [uint16[], uint16[], uint16[]]
updateTupleWithOnlyDynamicTypes:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/abi.algo.ts:574
	// a: [uint16[], uint16[], uint16[]] = [[1], [2], [3]]
	byte 0x // initial head
	byte 0x // initial tail
	pushbytes 0x0006 // initial head offset
	pushbytes 0x00010001
	callsub *process_dynamic_tuple_element
	pushbytes 0x00010002
	callsub *process_dynamic_tuple_element
	pushbytes 0x00010003
	callsub *process_dynamic_tuple_element
	pop // pop head offset
	concat // concat head and tail
	frame_bury 0 // a: [uint16[], uint16[], uint16[]]

	// tests/contracts/abi.algo.ts:576
	// a[0] = [4, 5]
	frame_dig 0 // a: [uint16[], uint16[], uint16[]]
	store 255 // full array
	pushint 0
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 2 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x000200040005
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 250 // length difference
	load 251 // element head offset
	int 2
	+ // head ofset
	callsub *update_dynamic_head
	load 250 // length difference
	load 251 // element head offset
	pushint 4
	+ // head ofset
	callsub *update_dynamic_head
	load 255 // full array
	frame_bury 0 // a: [uint16[], uint16[], uint16[]]

	// tests/contracts/abi.algo.ts:577
	// a[1] = [6, 7]
	frame_dig 0 // a: [uint16[], uint16[], uint16[]]
	store 255 // full array
	int 2
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 2 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x000200060007
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 250 // length difference
	load 251 // element head offset
	int 2
	+ // head ofset
	callsub *update_dynamic_head
	load 255 // full array
	frame_bury 0 // a: [uint16[], uint16[], uint16[]]

	// tests/contracts/abi.algo.ts:578
	// a[2] = [8, 9]
	frame_dig 0 // a: [uint16[], uint16[], uint16[]]
	store 255 // full array
	pushint 4
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 2 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x000200080009
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 255 // full array
	frame_bury 0 // a: [uint16[], uint16[], uint16[]]

	// tests/contracts/abi.algo.ts:580
	// return a;
	frame_dig 0 // a: [uint16[], uint16[], uint16[]]

	// set the subroutine return value
	frame_bury 0
	retsub

*abi_route_createApplication:
	pushint 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x405741a9 // method "updateTupleWithOnlyDynamicTypes()(uint16[],uint16[],uint16[])"
	txna ApplicationArgs 0
	match *abi_route_updateTupleWithOnlyDynamicTypes

	// this contract does not implement the given ABI method for call NoOp
	err

*process_dynamic_tuple_element:
	proto 4 3
	frame_dig -4 // tuple head
	frame_dig -2 // head offset
	concat
	frame_bury -4 // tuple head
	frame_dig -1 // element
	dup
	len
	frame_dig -2 // head offset
	btoi
	+
	itob
	extract 6 2
	frame_bury -2 // head offset
	frame_dig -3 // tuple tail
	swap
	concat
	frame_bury -3 // tuple tail
	frame_dig -4 // tuple head
	frame_dig -3 // tuple tail
	frame_dig -2 // head offset
	retsub

*update_dynamic_head:
	proto 2 0
	frame_dig -2 // length difference
	load 255 // full array
	frame_dig -1 // dynamic array offset
	extract_uint16 // extract dynamic array offset
	load 249 // subtract head difference
	bz *subtract_head_difference
	+ // add difference to offset
	b *end_calc_new_head

*subtract_head_difference:
	swap
	- // subtract difference from offet

*end_calc_new_head:
	itob // convert to bytes
	extract 6 2 // convert to uint16
	load 255 // full array
	swap
	frame_dig -1 // offset
	swap
	replace3 // update offset
	store 255 // full array
	retsub

*get_length_difference:
	load 252 // new element
	len // length of new element
	load 253 // element length
	<
	bnz *swapped_difference
	load 252 // new element
	len // length of new element
	load 253 // element length
	pushint 1
	store 249 // subtract head difference
	b *get_difference

*swapped_difference:
	load 253 // element length
	load 252 // new element
	len // length of new element
	pushint 0
	store 249 // subtract head difference

*get_difference:
	- // get length difference
	store 250 // length difference
	retsub", + "approval": "#pragma version 10
intcblock 2
bytecblock 0x000200040005 0x000200060007 0x000200080009 0x

// This TEAL was generated by TEALScript v0.105.0
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// updateTupleWithOnlyDynamicTypes()(uint16[],uint16[],uint16[])
*abi_route_updateTupleWithOnlyDynamicTypes:
	// The ABI return prefix
	pushbytes 0x151f7c75

	// execute updateTupleWithOnlyDynamicTypes()(uint16[],uint16[],uint16[])
	callsub updateTupleWithOnlyDynamicTypes
	concat
	log
	pushint 1
	return

// updateTupleWithOnlyDynamicTypes(): [uint16[], uint16[], uint16[]]
updateTupleWithOnlyDynamicTypes:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/abi.algo.ts:574
	// a: [uint16[], uint16[], uint16[]] = [[1], [2], [3]]
	byte 0x // initial head
	byte 0x // initial tail
	pushbytes 0x0006 // initial head offset
	pushbytes 0x00010001
	callsub *process_dynamic_tuple_element
	pushbytes 0x00010002
	callsub *process_dynamic_tuple_element
	pushbytes 0x00010003
	callsub *process_dynamic_tuple_element
	pop // pop head offset
	concat // concat head and tail
	frame_bury 0 // a: [uint16[], uint16[], uint16[]]

	// tests/contracts/abi.algo.ts:576
	// a[0] = [4, 5]
	frame_dig 0 // a: [uint16[], uint16[], uint16[]]
	store 255 // full array
	pushint 0
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 2 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x000200040005
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 250 // length difference
	load 251 // element head offset
	int 2
	+ // head ofset
	callsub *update_dynamic_head
	load 250 // length difference
	load 251 // element head offset
	pushint 4
	+ // head ofset
	callsub *update_dynamic_head
	load 255 // full array
	frame_bury 0 // a: [uint16[], uint16[], uint16[]]

	// tests/contracts/abi.algo.ts:577
	// a[1] = [6, 7]
	frame_dig 0 // a: [uint16[], uint16[], uint16[]]
	store 255 // full array
	int 2
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 2 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x000200060007
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 250 // length difference
	load 251 // element head offset
	int 2
	+ // head ofset
	callsub *update_dynamic_head
	load 255 // full array
	frame_bury 0 // a: [uint16[], uint16[], uint16[]]

	// tests/contracts/abi.algo.ts:578
	// a[2] = [8, 9]
	frame_dig 0 // a: [uint16[], uint16[], uint16[]]
	store 255 // full array
	pushint 4
	dup
	store 251 // element head offset
	load 255 // full array
	load 255 // full array
	uncover 2
	extract_uint16
	dup
	store 254 // element start
	dup // duplicate start of element
	load 255 // full array
	swap
	extract_uint16 // get number of elements
	int 2 // get type length
	* // multiply by type length
	int 2
	+ // add two for length
	store 253 // element length
	load 255 // full array
	pushint 0
	load 254 // element start
	substring3
	byte 0x000200080009
	dup
	store 252 // new element
	load 255 // full array
	load 254 // element start
	load 253 // element length
	+ // get end of Element
	load 255 // full array
	len
	substring3
	concat
	concat
	store 255 // full array
	callsub *get_length_difference
	load 255 // full array
	frame_bury 0 // a: [uint16[], uint16[], uint16[]]

	// tests/contracts/abi.algo.ts:580
	// return a;
	frame_dig 0 // a: [uint16[], uint16[], uint16[]]

	// set the subroutine return value
	frame_bury 0
	retsub

*abi_route_createApplication:
	pushint 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x405741a9 // method "updateTupleWithOnlyDynamicTypes()(uint16[],uint16[],uint16[])"
	txna ApplicationArgs 0
	match *abi_route_updateTupleWithOnlyDynamicTypes

	// this contract does not implement the given ABI method for call NoOp
	err

*process_dynamic_tuple_element:
	proto 4 3
	frame_dig -4 // tuple head
	frame_dig -2 // head offset
	concat
	frame_bury -4 // tuple head
	frame_dig -1 // element
	dup
	len
	frame_dig -2 // head offset
	btoi
	+
	itob
	extract 6 2
	frame_bury -2 // head offset
	frame_dig -3 // tuple tail
	swap
	concat
	frame_bury -3 // tuple tail
	frame_dig -4 // tuple head
	frame_dig -3 // tuple tail
	frame_dig -2 // head offset
	retsub

*update_dynamic_head:
	proto 2 0
	frame_dig -2 // length difference
	load 255 // full array
	frame_dig -1 // dynamic array offset
	extract_uint16 // extract dynamic array offset
	load 249 // subtract head difference
	bz *subtract_head_difference
	+ // add difference to offset
	b *end_calc_new_head

*subtract_head_difference:
	swap
	- // subtract difference from offet

*end_calc_new_head:
	itob // convert to bytes
	extract 6 2 // convert to uint16
	load 255 // full array
	swap
	frame_dig -1 // offset
	swap
	replace3 // update offset
	store 255 // full array
	retsub

*get_length_difference:
	load 252 // new element
	len // length of new element
	load 253 // element length
	<
	bnz *swapped_difference
	load 252 // new element
	len // length of new element
	load 253 // element length
	pushint 1
	store 249 // subtract head difference
	b *get_difference

*swapped_difference:
	load 253 // element length
	load 252 // new element
	len // length of new element
	pushint 0
	store 249 // subtract head difference

*get_difference:
	- // get length difference
	store 250 // length difference
	retsub", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/AD.approval.teal b/tests/contracts/artifacts/AD.approval.teal index 002313549..2f31c3a8c 100644 --- a/tests/contracts/artifacts/AD.approval.teal +++ b/tests/contracts/artifacts/AD.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x61 0x64 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/AD.arc32.json b/tests/contracts/artifacts/AD.arc32.json index 4fdc1ead1..6dc379ba9 100644 --- a/tests/contracts/artifacts/AD.arc32.json +++ b/tests/contracts/artifacts/AD.arc32.json @@ -58,7 +58,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2MSAweDY0CgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYSgpdm9pZAoqYWJpX3JvdXRlX2E6CgkvLyBleGVjdXRlIGEoKXZvaWQKCWNhbGxzdWIgYQoJcHVzaGludCAxCglyZXR1cm4KCi8vIGEoKTogdm9pZAphOgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6MTYKCS8vIHRoaXMuYUtleS52YWx1ZSA9IDEzMzcKCWJ5dGUgMHg2MSAvLyAiYSIKCXB1c2hpbnQgMTMzNwoJYXBwX2dsb2JhbF9wdXQKCXJldHN1YgoKLy8gZCgpdm9pZAoqYWJpX3JvdXRlX2Q6CgkvLyBleGVjdXRlIGQoKXZvaWQKCWNhbGxzdWIgZAoJcHVzaGludCAxCglyZXR1cm4KCi8vIGQoKTogdm9pZApkOgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6NDAKCS8vIHRoaXMuZEtleS52YWx1ZSA9IDQyCglieXRlIDB4NjQgLy8gImQiCglwdXNoaW50IDQyCglhcHBfZ2xvYmFsX3B1dAoJcmV0c3ViCgovLyBhZCgpdm9pZAoqYWJpX3JvdXRlX2FkOgoJLy8gZXhlY3V0ZSBhZCgpdm9pZAoJY2FsbHN1YiBhZAoJcHVzaGludCAxCglyZXR1cm4KCi8vIGFkKCk6IHZvaWQKYWQ6Cglwcm90byAwIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czo0NgoJLy8gYXNzZXJ0KHRoaXMuYUtleS52YWx1ZSA9PT0gMTMzNykKCWJ5dGUgMHg2MSAvLyAiYSIKCWFwcF9nbG9iYWxfZ2V0CglwdXNoaW50IDEzMzcKCT09Cglhc3NlcnQKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czo0NwoJLy8gYXNzZXJ0KHRoaXMuZEtleS52YWx1ZSA9PT0gNDIpCglieXRlIDB4NjQgLy8gImQiCglhcHBfZ2xvYmFsX2dldAoJcHVzaGludCA0MgoJPT0KCWFzc2VydAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgxZTdhYWQxYyAvLyBtZXRob2QgImEoKXZvaWQiCglwdXNoYnl0ZXMgMHgyOWVmZDBmNiAvLyBtZXRob2QgImQoKXZvaWQiCglwdXNoYnl0ZXMgMHhiZjdlZjhhMyAvLyBtZXRob2QgImFkKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9hICphYmlfcm91dGVfZCAqYWJpX3JvdXRlX2FkCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2MSAweDY0CgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYSgpdm9pZAoqYWJpX3JvdXRlX2E6CgkvLyBleGVjdXRlIGEoKXZvaWQKCWNhbGxzdWIgYQoJcHVzaGludCAxCglyZXR1cm4KCi8vIGEoKTogdm9pZAphOgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6MTYKCS8vIHRoaXMuYUtleS52YWx1ZSA9IDEzMzcKCWJ5dGUgMHg2MSAvLyAiYSIKCXB1c2hpbnQgMTMzNwoJYXBwX2dsb2JhbF9wdXQKCXJldHN1YgoKLy8gZCgpdm9pZAoqYWJpX3JvdXRlX2Q6CgkvLyBleGVjdXRlIGQoKXZvaWQKCWNhbGxzdWIgZAoJcHVzaGludCAxCglyZXR1cm4KCi8vIGQoKTogdm9pZApkOgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6NDAKCS8vIHRoaXMuZEtleS52YWx1ZSA9IDQyCglieXRlIDB4NjQgLy8gImQiCglwdXNoaW50IDQyCglhcHBfZ2xvYmFsX3B1dAoJcmV0c3ViCgovLyBhZCgpdm9pZAoqYWJpX3JvdXRlX2FkOgoJLy8gZXhlY3V0ZSBhZCgpdm9pZAoJY2FsbHN1YiBhZAoJcHVzaGludCAxCglyZXR1cm4KCi8vIGFkKCk6IHZvaWQKYWQ6Cglwcm90byAwIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czo0NgoJLy8gYXNzZXJ0KHRoaXMuYUtleS52YWx1ZSA9PT0gMTMzNykKCWJ5dGUgMHg2MSAvLyAiYSIKCWFwcF9nbG9iYWxfZ2V0CglwdXNoaW50IDEzMzcKCT09Cglhc3NlcnQKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czo0NwoJLy8gYXNzZXJ0KHRoaXMuZEtleS52YWx1ZSA9PT0gNDIpCglieXRlIDB4NjQgLy8gImQiCglhcHBfZ2xvYmFsX2dldAoJcHVzaGludCA0MgoJPT0KCWFzc2VydAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgxZTdhYWQxYyAvLyBtZXRob2QgImEoKXZvaWQiCglwdXNoYnl0ZXMgMHgyOWVmZDBmNiAvLyBtZXRob2QgImQoKXZvaWQiCglwdXNoYnl0ZXMgMHhiZjdlZjhhMyAvLyBtZXRob2QgImFkKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9hICphYmlfcm91dGVfZCAqYWJpX3JvdXRlX2FkCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/AD.arc56_draft.json b/tests/contracts/artifacts/AD.arc56_draft.json index 9d832f488..61496fa34 100644 --- a/tests/contracts/artifacts/AD.arc56_draft.json +++ b/tests/contracts/artifacts/AD.arc56_draft.json @@ -580,7 +580,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2MSAweDY0CgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYSgpdm9pZAoqYWJpX3JvdXRlX2E6CgkvLyBleGVjdXRlIGEoKXZvaWQKCWNhbGxzdWIgYQoJcHVzaGludCAxCglyZXR1cm4KCi8vIGEoKTogdm9pZAphOgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6MTYKCS8vIHRoaXMuYUtleS52YWx1ZSA9IDEzMzcKCWJ5dGUgMHg2MSAvLyAiYSIKCXB1c2hpbnQgMTMzNwoJYXBwX2dsb2JhbF9wdXQKCXJldHN1YgoKLy8gZCgpdm9pZAoqYWJpX3JvdXRlX2Q6CgkvLyBleGVjdXRlIGQoKXZvaWQKCWNhbGxzdWIgZAoJcHVzaGludCAxCglyZXR1cm4KCi8vIGQoKTogdm9pZApkOgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6NDAKCS8vIHRoaXMuZEtleS52YWx1ZSA9IDQyCglieXRlIDB4NjQgLy8gImQiCglwdXNoaW50IDQyCglhcHBfZ2xvYmFsX3B1dAoJcmV0c3ViCgovLyBhZCgpdm9pZAoqYWJpX3JvdXRlX2FkOgoJLy8gZXhlY3V0ZSBhZCgpdm9pZAoJY2FsbHN1YiBhZAoJcHVzaGludCAxCglyZXR1cm4KCi8vIGFkKCk6IHZvaWQKYWQ6Cglwcm90byAwIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czo0NgoJLy8gYXNzZXJ0KHRoaXMuYUtleS52YWx1ZSA9PT0gMTMzNykKCWJ5dGUgMHg2MSAvLyAiYSIKCWFwcF9nbG9iYWxfZ2V0CglwdXNoaW50IDEzMzcKCT09Cglhc3NlcnQKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czo0NwoJLy8gYXNzZXJ0KHRoaXMuZEtleS52YWx1ZSA9PT0gNDIpCglieXRlIDB4NjQgLy8gImQiCglhcHBfZ2xvYmFsX2dldAoJcHVzaGludCA0MgoJPT0KCWFzc2VydAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgxZTdhYWQxYyAvLyBtZXRob2QgImEoKXZvaWQiCglwdXNoYnl0ZXMgMHgyOWVmZDBmNiAvLyBtZXRob2QgImQoKXZvaWQiCglwdXNoYnl0ZXMgMHhiZjdlZjhhMyAvLyBtZXRob2QgImFkKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9hICphYmlfcm91dGVfZCAqYWJpX3JvdXRlX2FkCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2MSAweDY0CgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYSgpdm9pZAoqYWJpX3JvdXRlX2E6CgkvLyBleGVjdXRlIGEoKXZvaWQKCWNhbGxzdWIgYQoJcHVzaGludCAxCglyZXR1cm4KCi8vIGEoKTogdm9pZAphOgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6MTYKCS8vIHRoaXMuYUtleS52YWx1ZSA9IDEzMzcKCWJ5dGUgMHg2MSAvLyAiYSIKCXB1c2hpbnQgMTMzNwoJYXBwX2dsb2JhbF9wdXQKCXJldHN1YgoKLy8gZCgpdm9pZAoqYWJpX3JvdXRlX2Q6CgkvLyBleGVjdXRlIGQoKXZvaWQKCWNhbGxzdWIgZAoJcHVzaGludCAxCglyZXR1cm4KCi8vIGQoKTogdm9pZApkOgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6NDAKCS8vIHRoaXMuZEtleS52YWx1ZSA9IDQyCglieXRlIDB4NjQgLy8gImQiCglwdXNoaW50IDQyCglhcHBfZ2xvYmFsX3B1dAoJcmV0c3ViCgovLyBhZCgpdm9pZAoqYWJpX3JvdXRlX2FkOgoJLy8gZXhlY3V0ZSBhZCgpdm9pZAoJY2FsbHN1YiBhZAoJcHVzaGludCAxCglyZXR1cm4KCi8vIGFkKCk6IHZvaWQKYWQ6Cglwcm90byAwIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czo0NgoJLy8gYXNzZXJ0KHRoaXMuYUtleS52YWx1ZSA9PT0gMTMzNykKCWJ5dGUgMHg2MSAvLyAiYSIKCWFwcF9nbG9iYWxfZ2V0CglwdXNoaW50IDEzMzcKCT09Cglhc3NlcnQKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czo0NwoJLy8gYXNzZXJ0KHRoaXMuZEtleS52YWx1ZSA9PT0gNDIpCglieXRlIDB4NjQgLy8gImQiCglhcHBfZ2xvYmFsX2dldAoJcHVzaGludCA0MgoJPT0KCWFzc2VydAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgxZTdhYWQxYyAvLyBtZXRob2QgImEoKXZvaWQiCglwdXNoYnl0ZXMgMHgyOWVmZDBmNiAvLyBtZXRob2QgImQoKXZvaWQiCglwdXNoYnl0ZXMgMHhiZjdlZjhhMyAvLyBtZXRob2QgImFkKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9hICphYmlfcm91dGVfZCAqYWJpX3JvdXRlX2FkCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ARC56Test.approval.teal b/tests/contracts/artifacts/ARC56Test.approval.teal index 8ca3dc75b..00aebb6d1 100644 --- a/tests/contracts/artifacts/ARC56Test.approval.teal +++ b/tests/contracts/artifacts/ARC56Test.approval.teal @@ -2,7 +2,7 @@ intcblock TMPL_someNumber bytecblock 0x151f7c75 0x626f784b6579 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ARC56Test.arc32.json b/tests/contracts/artifacts/ARC56Test.arc32.json index da8fe21cc..6096783ba 100644 --- a/tests/contracts/artifacts/ARC56Test.arc32.json +++ b/tests/contracts/artifacts/ARC56Test.arc32.json @@ -64,7 +64,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmludGNibG9jayBUTVBMX3NvbWVOdW1iZXIKYnl0ZWNibG9jayAweDE1MWY3Yzc1IDB4NjI2Zjc4NGI2NTc5CgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIGxpbmVzIG9mIFRFQUwgYXJlIHVzZWQgdG8gaW5pdGlhbGl6ZSB0ZW1wbGF0ZSB2YXJpYWJsZXMgaW4gc2NyYXRjaCBzbG90cwppbnRjIDAgLy8gVE1QTF9zb21lTnVtYmVyCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKmNhbGxfT3B0SW4gKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIGN1c3RvbVN0cnVjdE1ldGhvZCgodWludDY0KSkodWludDY0KQoqYWJpX3JvdXRlX2N1c3RvbVN0cnVjdE1ldGhvZDoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJYnl0ZSAweDE1MWY3Yzc1CgoJLy8gaW5wdXQ6ICh1aW50NjQpCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglkdXAKCWxlbgoJcHVzaGludCA4Cgk9PQoKCS8vIGFyZ3VtZW50IDAgKGlucHV0KSBmb3IgY3VzdG9tU3RydWN0TWV0aG9kIG11c3QgYmUgYSAodWludDY0KQoJYXNzZXJ0CgoJLy8gZXhlY3V0ZSBjdXN0b21TdHJ1Y3RNZXRob2QoKHVpbnQ2NCkpKHVpbnQ2NCkKCWNhbGxzdWIgY3VzdG9tU3RydWN0TWV0aG9kCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGN1c3RvbVN0cnVjdE1ldGhvZChpbnB1dDogQW5vdGhlckN1c3RvbVN0cnVjdCk6IEFub3RoZXJDdXN0b21TdHJ1Y3QKY3VzdG9tU3RydWN0TWV0aG9kOgoJcHJvdG8gMSAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLWV4dGVybmFsLmFsZ28udHM6MjEKCS8vIHJldHVybiBpbnB1dDsKCWZyYW1lX2RpZyAtMSAvLyBpbnB1dDogQW5vdGhlckN1c3RvbVN0cnVjdAoJcmV0c3ViCgovLyBmb28oKCh1aW50NjQsdWludDY0KSwodWludDY0LHVpbnQ2NCkpKSh1aW50NjQsdWludDY0KQoqYWJpX3JvdXRlX2ZvbzoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJYnl0ZSAweDE1MWY3Yzc1CgoJLy8gaW5wdXRzOiAoKHVpbnQ2NCx1aW50NjQpLCh1aW50NjQsdWludDY0KSkKCXR4bmEgQXBwbGljYXRpb25BcmdzIDEKCWR1cAoJbGVuCglwdXNoaW50IDMyCgk9PQoKCS8vIGFyZ3VtZW50IDAgKGlucHV0cykgZm9yIGZvbyBtdXN0IGJlIGEgKCh1aW50NjQsdWludDY0KSwodWludDY0LHVpbnQ2NCkpCglhc3NlcnQKCgkvLyBleGVjdXRlIGZvbygoKHVpbnQ2NCx1aW50NjQpLCh1aW50NjQsdWludDY0KSkpKHVpbnQ2NCx1aW50NjQpCgljYWxsc3ViIGZvbwoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBmb28oaW5wdXRzOiBJbnB1dHMpOiBPdXRwdXRzCmZvbzoKCXByb3RvIDEgMQoKCS8vICppZjBfY29uZGl0aW9uCgkvLyB0ZXN0cy9jb250cmFjdHMvYXJjNTYuYWxnby50czoyNQoJLy8gaW5wdXRzLnN1YnRyYWN0LmEgPCBpbnB1dHMuc3VidHJhY3QuYgoJZnJhbWVfZGlnIC0xIC8vIGlucHV0czogSW5wdXRzCglleHRyYWN0IDE2IDgKCWJ0b2kKCWZyYW1lX2RpZyAtMSAvLyBpbnB1dHM6IElucHV0cwoJZXh0cmFjdCAyNCA4CglidG9pCgk8CglieiAqaWYwX2VuZAoKCS8vICppZjBfY29uc2VxdWVudAoJLy8gc3VidHJhY3QuYSBtdXN0IGJlIGdyZWF0ZXIgdGhhbiBzdWJ0cmFjdC5iCgllcnIKCippZjBfZW5kOgoJLy8gdGVzdHMvY29udHJhY3RzL2FyYzU2LmFsZ28udHM6MjcKCS8vIHRoaXMuZ2xvYmFsS2V5LnZhbHVlID0gdGhpcy5zb21lTnVtYmVyCglwdXNoYnl0ZXMgMHg2NzZjNmY2MjYxNmM0YjY1NzkgLy8gImdsb2JhbEtleSIKCWludGMgMCAvLyBUTVBMX3NvbWVOdW1iZXIKCWFwcF9nbG9iYWxfcHV0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FyYzU2LmFsZ28udHM6MjgKCS8vIHRoaXMuZ2xvYmFsTWFwKCdmb28nKS52YWx1ZSA9IHsgZm9vOiAxMywgYmFyOiAzNyB9CglwdXNoYnl0ZXMgMHg3MDAwMDM2NjZmNmYKCXB1c2hieXRlcyAweDAwMGQwMDI1CglhcHBfZ2xvYmFsX3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hcmM1Ni5hbGdvLnRzOjMwCgkvLyByZXR1cm4gewoJLy8gICAgICAgc3VtOiBpbnB1dHMuYWRkLmEgKyBpbnB1dHMuYWRkLmIsCgkvLyAgICAgICBkaWZmZXJlbmNlOiBpbnB1dHMuc3VidHJhY3QuYSAtIGlucHV0cy5zdWJ0cmFjdC5iLAoJLy8gICAgIH07CglmcmFtZV9kaWcgLTEgLy8gaW5wdXRzOiBJbnB1dHMKCWV4dHJhY3QgMCA4CglidG9pCglmcmFtZV9kaWcgLTEgLy8gaW5wdXRzOiBJbnB1dHMKCWV4dHJhY3QgOCA4CglidG9pCgkrCglpdG9iCglmcmFtZV9kaWcgLTEgLy8gaW5wdXRzOiBJbnB1dHMKCWV4dHJhY3QgMTYgOAoJYnRvaQoJZnJhbWVfZGlnIC0xIC8vIGlucHV0czogSW5wdXRzCglleHRyYWN0IDI0IDgKCWJ0b2kKCS0KCWl0b2IKCWNvbmNhdAoJcmV0c3ViCgovLyBvcHRJblRvQXBwbGljYXRpb24oKXZvaWQKKmFiaV9yb3V0ZV9vcHRJblRvQXBwbGljYXRpb246CgkvLyBleGVjdXRlIG9wdEluVG9BcHBsaWNhdGlvbigpdm9pZAoJY2FsbHN1YiBvcHRJblRvQXBwbGljYXRpb24KCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBvcHRJblRvQXBwbGljYXRpb24oKTogdm9pZApvcHRJblRvQXBwbGljYXRpb246Cglwcm90byAwIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYXJjNTYuYWxnby50czozNwoJLy8gdGhpcy5sb2NhbEtleSh0aGlzLnR4bi5zZW5kZXIpLnZhbHVlID0gdGhpcy5zb21lTnVtYmVyCgl0eG4gU2VuZGVyCglwdXNoYnl0ZXMgMHg2YzZmNjM2MTZjNGI2NTc5IC8vICJsb2NhbEtleSIKCWludGMgMCAvLyBUTVBMX3NvbWVOdW1iZXIKCWFwcF9sb2NhbF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYXJjNTYuYWxnby50czozOAoJLy8gdGhpcy5sb2NhbE1hcCh0aGlzLnR4bi5zZW5kZXIsICdmb28nKS52YWx1ZSA9ICdiYXInCgl0eG4gU2VuZGVyCglwdXNoYnl0ZXMgMHg3MDY2NmY2ZgoJcHVzaGJ5dGVzIDB4MDAwMzYyNjE3MgoJYXBwX2xvY2FsX3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hcmM1Ni5hbGdvLnRzOjM5CgkvLyB0aGlzLmJveEtleS52YWx1ZSA9ICdiYXonCglieXRlIDB4NjI2Zjc4NGI2NTc5IC8vICJib3hLZXkiCglkdXAKCWJveF9kZWwKCXBvcAoJcHVzaGJ5dGVzIDB4MDAwMzYyNjE3YQoJYm94X3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hcmM1Ni5hbGdvLnRzOjQwCgkvLyB0aGlzLmJveE1hcCh7IGFkZDogeyBhOiAxLCBiOiAyIH0sIHN1YnRyYWN0OiB7IGE6IDQsIGI6IDMgfSB9KS52YWx1ZSA9IHsgc3VtOiAzLCBkaWZmZXJlbmNlOiAxIH0KCXB1c2hieXRlcyAweDcwMDAwMDAwMDAwMDAwMDAwMTAwMDAwMDAwMDAwMDAwMDIwMDAwMDAwMDAwMDAwMDA0MDAwMDAwMDAwMDAwMDAwMwoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMzAwMDAwMDAwMDAwMDAwMDEKCWJveF9wdXQKCXJldHN1YgoKLy8gY3VzdG9tVHlwZSgodWludDY0KSkodWludDY0KQoqYWJpX3JvdXRlX2N1c3RvbVR5cGU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCWJ5dGUgMHgxNTFmN2M3NQoKCS8vIGlucHV0OiAodWludDY0KQoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJZHVwCglsZW4KCXB1c2hpbnQgOAoJPT0KCgkvLyBhcmd1bWVudCAwIChpbnB1dCkgZm9yIGN1c3RvbVR5cGUgbXVzdCBiZSBhICh1aW50NjQpCglhc3NlcnQKCgkvLyBleGVjdXRlIGN1c3RvbVR5cGUoKHVpbnQ2NCkpKHVpbnQ2NCkKCWNhbGxzdWIgY3VzdG9tVHlwZQoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBjdXN0b21UeXBlKGlucHV0OiBDdXN0b21TdHJ1Y3RBc05hbWUpOiBDdXN0b21TdHJ1Y3RBc05hbWUKY3VzdG9tVHlwZToKCXByb3RvIDEgMQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hcmM1Ni5hbGdvLnRzOjQ0CgkvLyByZXR1cm4gaW5wdXQ7CglmcmFtZV9kaWcgLTEgLy8gaW5wdXQ6IEN1c3RvbVN0cnVjdEFzTmFtZQoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg4ZDIyNzM5YSAvLyBtZXRob2QgImN1c3RvbVN0cnVjdE1ldGhvZCgodWludDY0KSkodWludDY0KSIKCXB1c2hieXRlcyAweDM5NmQ1NTBlIC8vIG1ldGhvZCAiZm9vKCgodWludDY0LHVpbnQ2NCksKHVpbnQ2NCx1aW50NjQpKSkodWludDY0LHVpbnQ2NCkiCglwdXNoYnl0ZXMgMHgwZGJmMDJjNyAvLyBtZXRob2QgImN1c3RvbVR5cGUoKHVpbnQ2NCkpKHVpbnQ2NCkiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2N1c3RvbVN0cnVjdE1ldGhvZCAqYWJpX3JvdXRlX2ZvbyAqYWJpX3JvdXRlX2N1c3RvbVR5cGUKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnIKCipjYWxsX09wdEluOgoJcHVzaGJ5dGVzIDB4MDFhM2EzZmYgLy8gbWV0aG9kICJvcHRJblRvQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX29wdEluVG9BcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE9wdEluCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmludGNibG9jayBUTVBMX3NvbWVOdW1iZXIKYnl0ZWNibG9jayAweDE1MWY3Yzc1IDB4NjI2Zjc4NGI2NTc5CgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIGxpbmVzIG9mIFRFQUwgYXJlIHVzZWQgdG8gaW5pdGlhbGl6ZSB0ZW1wbGF0ZSB2YXJpYWJsZXMgaW4gc2NyYXRjaCBzbG90cwppbnRjIDAgLy8gVE1QTF9zb21lTnVtYmVyCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKmNhbGxfT3B0SW4gKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIGN1c3RvbVN0cnVjdE1ldGhvZCgodWludDY0KSkodWludDY0KQoqYWJpX3JvdXRlX2N1c3RvbVN0cnVjdE1ldGhvZDoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJYnl0ZSAweDE1MWY3Yzc1CgoJLy8gaW5wdXQ6ICh1aW50NjQpCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglkdXAKCWxlbgoJcHVzaGludCA4Cgk9PQoKCS8vIGFyZ3VtZW50IDAgKGlucHV0KSBmb3IgY3VzdG9tU3RydWN0TWV0aG9kIG11c3QgYmUgYSAodWludDY0KQoJYXNzZXJ0CgoJLy8gZXhlY3V0ZSBjdXN0b21TdHJ1Y3RNZXRob2QoKHVpbnQ2NCkpKHVpbnQ2NCkKCWNhbGxzdWIgY3VzdG9tU3RydWN0TWV0aG9kCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGN1c3RvbVN0cnVjdE1ldGhvZChpbnB1dDogQW5vdGhlckN1c3RvbVN0cnVjdCk6IEFub3RoZXJDdXN0b21TdHJ1Y3QKY3VzdG9tU3RydWN0TWV0aG9kOgoJcHJvdG8gMSAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLWV4dGVybmFsLmFsZ28udHM6MjEKCS8vIHJldHVybiBpbnB1dDsKCWZyYW1lX2RpZyAtMSAvLyBpbnB1dDogQW5vdGhlckN1c3RvbVN0cnVjdAoJcmV0c3ViCgovLyBmb28oKCh1aW50NjQsdWludDY0KSwodWludDY0LHVpbnQ2NCkpKSh1aW50NjQsdWludDY0KQoqYWJpX3JvdXRlX2ZvbzoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJYnl0ZSAweDE1MWY3Yzc1CgoJLy8gaW5wdXRzOiAoKHVpbnQ2NCx1aW50NjQpLCh1aW50NjQsdWludDY0KSkKCXR4bmEgQXBwbGljYXRpb25BcmdzIDEKCWR1cAoJbGVuCglwdXNoaW50IDMyCgk9PQoKCS8vIGFyZ3VtZW50IDAgKGlucHV0cykgZm9yIGZvbyBtdXN0IGJlIGEgKCh1aW50NjQsdWludDY0KSwodWludDY0LHVpbnQ2NCkpCglhc3NlcnQKCgkvLyBleGVjdXRlIGZvbygoKHVpbnQ2NCx1aW50NjQpLCh1aW50NjQsdWludDY0KSkpKHVpbnQ2NCx1aW50NjQpCgljYWxsc3ViIGZvbwoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBmb28oaW5wdXRzOiBJbnB1dHMpOiBPdXRwdXRzCmZvbzoKCXByb3RvIDEgMQoKCS8vICppZjBfY29uZGl0aW9uCgkvLyB0ZXN0cy9jb250cmFjdHMvYXJjNTYuYWxnby50czoyNQoJLy8gaW5wdXRzLnN1YnRyYWN0LmEgPCBpbnB1dHMuc3VidHJhY3QuYgoJZnJhbWVfZGlnIC0xIC8vIGlucHV0czogSW5wdXRzCglleHRyYWN0IDE2IDgKCWJ0b2kKCWZyYW1lX2RpZyAtMSAvLyBpbnB1dHM6IElucHV0cwoJZXh0cmFjdCAyNCA4CglidG9pCgk8CglieiAqaWYwX2VuZAoKCS8vICppZjBfY29uc2VxdWVudAoJLy8gc3VidHJhY3QuYSBtdXN0IGJlIGdyZWF0ZXIgdGhhbiBzdWJ0cmFjdC5iCgllcnIKCippZjBfZW5kOgoJLy8gdGVzdHMvY29udHJhY3RzL2FyYzU2LmFsZ28udHM6MjcKCS8vIHRoaXMuZ2xvYmFsS2V5LnZhbHVlID0gdGhpcy5zb21lTnVtYmVyCglwdXNoYnl0ZXMgMHg2NzZjNmY2MjYxNmM0YjY1NzkgLy8gImdsb2JhbEtleSIKCWludGMgMCAvLyBUTVBMX3NvbWVOdW1iZXIKCWFwcF9nbG9iYWxfcHV0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FyYzU2LmFsZ28udHM6MjgKCS8vIHRoaXMuZ2xvYmFsTWFwKCdmb28nKS52YWx1ZSA9IHsgZm9vOiAxMywgYmFyOiAzNyB9CglwdXNoYnl0ZXMgMHg3MDAwMDM2NjZmNmYKCXB1c2hieXRlcyAweDAwMGQwMDI1CglhcHBfZ2xvYmFsX3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hcmM1Ni5hbGdvLnRzOjMwCgkvLyByZXR1cm4gewoJLy8gICAgICAgc3VtOiBpbnB1dHMuYWRkLmEgKyBpbnB1dHMuYWRkLmIsCgkvLyAgICAgICBkaWZmZXJlbmNlOiBpbnB1dHMuc3VidHJhY3QuYSAtIGlucHV0cy5zdWJ0cmFjdC5iLAoJLy8gICAgIH07CglmcmFtZV9kaWcgLTEgLy8gaW5wdXRzOiBJbnB1dHMKCWV4dHJhY3QgMCA4CglidG9pCglmcmFtZV9kaWcgLTEgLy8gaW5wdXRzOiBJbnB1dHMKCWV4dHJhY3QgOCA4CglidG9pCgkrCglpdG9iCglmcmFtZV9kaWcgLTEgLy8gaW5wdXRzOiBJbnB1dHMKCWV4dHJhY3QgMTYgOAoJYnRvaQoJZnJhbWVfZGlnIC0xIC8vIGlucHV0czogSW5wdXRzCglleHRyYWN0IDI0IDgKCWJ0b2kKCS0KCWl0b2IKCWNvbmNhdAoJcmV0c3ViCgovLyBvcHRJblRvQXBwbGljYXRpb24oKXZvaWQKKmFiaV9yb3V0ZV9vcHRJblRvQXBwbGljYXRpb246CgkvLyBleGVjdXRlIG9wdEluVG9BcHBsaWNhdGlvbigpdm9pZAoJY2FsbHN1YiBvcHRJblRvQXBwbGljYXRpb24KCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBvcHRJblRvQXBwbGljYXRpb24oKTogdm9pZApvcHRJblRvQXBwbGljYXRpb246Cglwcm90byAwIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYXJjNTYuYWxnby50czozNwoJLy8gdGhpcy5sb2NhbEtleSh0aGlzLnR4bi5zZW5kZXIpLnZhbHVlID0gdGhpcy5zb21lTnVtYmVyCgl0eG4gU2VuZGVyCglwdXNoYnl0ZXMgMHg2YzZmNjM2MTZjNGI2NTc5IC8vICJsb2NhbEtleSIKCWludGMgMCAvLyBUTVBMX3NvbWVOdW1iZXIKCWFwcF9sb2NhbF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYXJjNTYuYWxnby50czozOAoJLy8gdGhpcy5sb2NhbE1hcCh0aGlzLnR4bi5zZW5kZXIsICdmb28nKS52YWx1ZSA9ICdiYXInCgl0eG4gU2VuZGVyCglwdXNoYnl0ZXMgMHg3MDY2NmY2ZgoJcHVzaGJ5dGVzIDB4MDAwMzYyNjE3MgoJYXBwX2xvY2FsX3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hcmM1Ni5hbGdvLnRzOjM5CgkvLyB0aGlzLmJveEtleS52YWx1ZSA9ICdiYXonCglieXRlIDB4NjI2Zjc4NGI2NTc5IC8vICJib3hLZXkiCglkdXAKCWJveF9kZWwKCXBvcAoJcHVzaGJ5dGVzIDB4MDAwMzYyNjE3YQoJYm94X3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hcmM1Ni5hbGdvLnRzOjQwCgkvLyB0aGlzLmJveE1hcCh7IGFkZDogeyBhOiAxLCBiOiAyIH0sIHN1YnRyYWN0OiB7IGE6IDQsIGI6IDMgfSB9KS52YWx1ZSA9IHsgc3VtOiAzLCBkaWZmZXJlbmNlOiAxIH0KCXB1c2hieXRlcyAweDcwMDAwMDAwMDAwMDAwMDAwMTAwMDAwMDAwMDAwMDAwMDIwMDAwMDAwMDAwMDAwMDA0MDAwMDAwMDAwMDAwMDAwMwoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMzAwMDAwMDAwMDAwMDAwMDEKCWJveF9wdXQKCXJldHN1YgoKLy8gY3VzdG9tVHlwZSgodWludDY0KSkodWludDY0KQoqYWJpX3JvdXRlX2N1c3RvbVR5cGU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCWJ5dGUgMHgxNTFmN2M3NQoKCS8vIGlucHV0OiAodWludDY0KQoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJZHVwCglsZW4KCXB1c2hpbnQgOAoJPT0KCgkvLyBhcmd1bWVudCAwIChpbnB1dCkgZm9yIGN1c3RvbVR5cGUgbXVzdCBiZSBhICh1aW50NjQpCglhc3NlcnQKCgkvLyBleGVjdXRlIGN1c3RvbVR5cGUoKHVpbnQ2NCkpKHVpbnQ2NCkKCWNhbGxzdWIgY3VzdG9tVHlwZQoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBjdXN0b21UeXBlKGlucHV0OiBDdXN0b21TdHJ1Y3RBc05hbWUpOiBDdXN0b21TdHJ1Y3RBc05hbWUKY3VzdG9tVHlwZToKCXByb3RvIDEgMQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hcmM1Ni5hbGdvLnRzOjQ0CgkvLyByZXR1cm4gaW5wdXQ7CglmcmFtZV9kaWcgLTEgLy8gaW5wdXQ6IEN1c3RvbVN0cnVjdEFzTmFtZQoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg4ZDIyNzM5YSAvLyBtZXRob2QgImN1c3RvbVN0cnVjdE1ldGhvZCgodWludDY0KSkodWludDY0KSIKCXB1c2hieXRlcyAweDM5NmQ1NTBlIC8vIG1ldGhvZCAiZm9vKCgodWludDY0LHVpbnQ2NCksKHVpbnQ2NCx1aW50NjQpKSkodWludDY0LHVpbnQ2NCkiCglwdXNoYnl0ZXMgMHgwZGJmMDJjNyAvLyBtZXRob2QgImN1c3RvbVR5cGUoKHVpbnQ2NCkpKHVpbnQ2NCkiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2N1c3RvbVN0cnVjdE1ldGhvZCAqYWJpX3JvdXRlX2ZvbyAqYWJpX3JvdXRlX2N1c3RvbVR5cGUKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnIKCipjYWxsX09wdEluOgoJcHVzaGJ5dGVzIDB4MDFhM2EzZmYgLy8gbWV0aG9kICJvcHRJblRvQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX29wdEluVG9BcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE9wdEluCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ARC56Test.arc56_draft.json b/tests/contracts/artifacts/ARC56Test.arc56_draft.json index 6cd956c9a..d6a98b597 100644 --- a/tests/contracts/artifacts/ARC56Test.arc56_draft.json +++ b/tests/contracts/artifacts/ARC56Test.arc56_draft.json @@ -1345,7 +1345,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmludGNibG9jayBUTVBMX3NvbWVOdW1iZXIKYnl0ZWNibG9jayAweDE1MWY3Yzc1IDB4NjI2Zjc4NGI2NTc5CgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIGxpbmVzIG9mIFRFQUwgYXJlIHVzZWQgdG8gaW5pdGlhbGl6ZSB0ZW1wbGF0ZSB2YXJpYWJsZXMgaW4gc2NyYXRjaCBzbG90cwppbnRjIDAgLy8gVE1QTF9zb21lTnVtYmVyCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKmNhbGxfT3B0SW4gKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIGN1c3RvbVN0cnVjdE1ldGhvZCgodWludDY0KSkodWludDY0KQoqYWJpX3JvdXRlX2N1c3RvbVN0cnVjdE1ldGhvZDoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJYnl0ZSAweDE1MWY3Yzc1CgoJLy8gaW5wdXQ6ICh1aW50NjQpCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglkdXAKCWxlbgoJcHVzaGludCA4Cgk9PQoKCS8vIGFyZ3VtZW50IDAgKGlucHV0KSBmb3IgY3VzdG9tU3RydWN0TWV0aG9kIG11c3QgYmUgYSAodWludDY0KQoJYXNzZXJ0CgoJLy8gZXhlY3V0ZSBjdXN0b21TdHJ1Y3RNZXRob2QoKHVpbnQ2NCkpKHVpbnQ2NCkKCWNhbGxzdWIgY3VzdG9tU3RydWN0TWV0aG9kCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGN1c3RvbVN0cnVjdE1ldGhvZChpbnB1dDogQW5vdGhlckN1c3RvbVN0cnVjdCk6IEFub3RoZXJDdXN0b21TdHJ1Y3QKY3VzdG9tU3RydWN0TWV0aG9kOgoJcHJvdG8gMSAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLWV4dGVybmFsLmFsZ28udHM6MjEKCS8vIHJldHVybiBpbnB1dDsKCWZyYW1lX2RpZyAtMSAvLyBpbnB1dDogQW5vdGhlckN1c3RvbVN0cnVjdAoJcmV0c3ViCgovLyBmb28oKCh1aW50NjQsdWludDY0KSwodWludDY0LHVpbnQ2NCkpKSh1aW50NjQsdWludDY0KQoqYWJpX3JvdXRlX2ZvbzoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJYnl0ZSAweDE1MWY3Yzc1CgoJLy8gaW5wdXRzOiAoKHVpbnQ2NCx1aW50NjQpLCh1aW50NjQsdWludDY0KSkKCXR4bmEgQXBwbGljYXRpb25BcmdzIDEKCWR1cAoJbGVuCglwdXNoaW50IDMyCgk9PQoKCS8vIGFyZ3VtZW50IDAgKGlucHV0cykgZm9yIGZvbyBtdXN0IGJlIGEgKCh1aW50NjQsdWludDY0KSwodWludDY0LHVpbnQ2NCkpCglhc3NlcnQKCgkvLyBleGVjdXRlIGZvbygoKHVpbnQ2NCx1aW50NjQpLCh1aW50NjQsdWludDY0KSkpKHVpbnQ2NCx1aW50NjQpCgljYWxsc3ViIGZvbwoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBmb28oaW5wdXRzOiBJbnB1dHMpOiBPdXRwdXRzCmZvbzoKCXByb3RvIDEgMQoKCS8vICppZjBfY29uZGl0aW9uCgkvLyB0ZXN0cy9jb250cmFjdHMvYXJjNTYuYWxnby50czoyNQoJLy8gaW5wdXRzLnN1YnRyYWN0LmEgPCBpbnB1dHMuc3VidHJhY3QuYgoJZnJhbWVfZGlnIC0xIC8vIGlucHV0czogSW5wdXRzCglleHRyYWN0IDE2IDgKCWJ0b2kKCWZyYW1lX2RpZyAtMSAvLyBpbnB1dHM6IElucHV0cwoJZXh0cmFjdCAyNCA4CglidG9pCgk8CglieiAqaWYwX2VuZAoKCS8vICppZjBfY29uc2VxdWVudAoJLy8gc3VidHJhY3QuYSBtdXN0IGJlIGdyZWF0ZXIgdGhhbiBzdWJ0cmFjdC5iCgllcnIKCippZjBfZW5kOgoJLy8gdGVzdHMvY29udHJhY3RzL2FyYzU2LmFsZ28udHM6MjcKCS8vIHRoaXMuZ2xvYmFsS2V5LnZhbHVlID0gdGhpcy5zb21lTnVtYmVyCglwdXNoYnl0ZXMgMHg2NzZjNmY2MjYxNmM0YjY1NzkgLy8gImdsb2JhbEtleSIKCWludGMgMCAvLyBUTVBMX3NvbWVOdW1iZXIKCWFwcF9nbG9iYWxfcHV0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FyYzU2LmFsZ28udHM6MjgKCS8vIHRoaXMuZ2xvYmFsTWFwKCdmb28nKS52YWx1ZSA9IHsgZm9vOiAxMywgYmFyOiAzNyB9CglwdXNoYnl0ZXMgMHg3MDAwMDM2NjZmNmYKCXB1c2hieXRlcyAweDAwMGQwMDI1CglhcHBfZ2xvYmFsX3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hcmM1Ni5hbGdvLnRzOjMwCgkvLyByZXR1cm4gewoJLy8gICAgICAgc3VtOiBpbnB1dHMuYWRkLmEgKyBpbnB1dHMuYWRkLmIsCgkvLyAgICAgICBkaWZmZXJlbmNlOiBpbnB1dHMuc3VidHJhY3QuYSAtIGlucHV0cy5zdWJ0cmFjdC5iLAoJLy8gICAgIH07CglmcmFtZV9kaWcgLTEgLy8gaW5wdXRzOiBJbnB1dHMKCWV4dHJhY3QgMCA4CglidG9pCglmcmFtZV9kaWcgLTEgLy8gaW5wdXRzOiBJbnB1dHMKCWV4dHJhY3QgOCA4CglidG9pCgkrCglpdG9iCglmcmFtZV9kaWcgLTEgLy8gaW5wdXRzOiBJbnB1dHMKCWV4dHJhY3QgMTYgOAoJYnRvaQoJZnJhbWVfZGlnIC0xIC8vIGlucHV0czogSW5wdXRzCglleHRyYWN0IDI0IDgKCWJ0b2kKCS0KCWl0b2IKCWNvbmNhdAoJcmV0c3ViCgovLyBvcHRJblRvQXBwbGljYXRpb24oKXZvaWQKKmFiaV9yb3V0ZV9vcHRJblRvQXBwbGljYXRpb246CgkvLyBleGVjdXRlIG9wdEluVG9BcHBsaWNhdGlvbigpdm9pZAoJY2FsbHN1YiBvcHRJblRvQXBwbGljYXRpb24KCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBvcHRJblRvQXBwbGljYXRpb24oKTogdm9pZApvcHRJblRvQXBwbGljYXRpb246Cglwcm90byAwIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYXJjNTYuYWxnby50czozNwoJLy8gdGhpcy5sb2NhbEtleSh0aGlzLnR4bi5zZW5kZXIpLnZhbHVlID0gdGhpcy5zb21lTnVtYmVyCgl0eG4gU2VuZGVyCglwdXNoYnl0ZXMgMHg2YzZmNjM2MTZjNGI2NTc5IC8vICJsb2NhbEtleSIKCWludGMgMCAvLyBUTVBMX3NvbWVOdW1iZXIKCWFwcF9sb2NhbF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYXJjNTYuYWxnby50czozOAoJLy8gdGhpcy5sb2NhbE1hcCh0aGlzLnR4bi5zZW5kZXIsICdmb28nKS52YWx1ZSA9ICdiYXInCgl0eG4gU2VuZGVyCglwdXNoYnl0ZXMgMHg3MDY2NmY2ZgoJcHVzaGJ5dGVzIDB4MDAwMzYyNjE3MgoJYXBwX2xvY2FsX3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hcmM1Ni5hbGdvLnRzOjM5CgkvLyB0aGlzLmJveEtleS52YWx1ZSA9ICdiYXonCglieXRlIDB4NjI2Zjc4NGI2NTc5IC8vICJib3hLZXkiCglkdXAKCWJveF9kZWwKCXBvcAoJcHVzaGJ5dGVzIDB4MDAwMzYyNjE3YQoJYm94X3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hcmM1Ni5hbGdvLnRzOjQwCgkvLyB0aGlzLmJveE1hcCh7IGFkZDogeyBhOiAxLCBiOiAyIH0sIHN1YnRyYWN0OiB7IGE6IDQsIGI6IDMgfSB9KS52YWx1ZSA9IHsgc3VtOiAzLCBkaWZmZXJlbmNlOiAxIH0KCXB1c2hieXRlcyAweDcwMDAwMDAwMDAwMDAwMDAwMTAwMDAwMDAwMDAwMDAwMDIwMDAwMDAwMDAwMDAwMDA0MDAwMDAwMDAwMDAwMDAwMwoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMzAwMDAwMDAwMDAwMDAwMDEKCWJveF9wdXQKCXJldHN1YgoKLy8gY3VzdG9tVHlwZSgodWludDY0KSkodWludDY0KQoqYWJpX3JvdXRlX2N1c3RvbVR5cGU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCWJ5dGUgMHgxNTFmN2M3NQoKCS8vIGlucHV0OiAodWludDY0KQoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJZHVwCglsZW4KCXB1c2hpbnQgOAoJPT0KCgkvLyBhcmd1bWVudCAwIChpbnB1dCkgZm9yIGN1c3RvbVR5cGUgbXVzdCBiZSBhICh1aW50NjQpCglhc3NlcnQKCgkvLyBleGVjdXRlIGN1c3RvbVR5cGUoKHVpbnQ2NCkpKHVpbnQ2NCkKCWNhbGxzdWIgY3VzdG9tVHlwZQoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBjdXN0b21UeXBlKGlucHV0OiBDdXN0b21TdHJ1Y3RBc05hbWUpOiBDdXN0b21TdHJ1Y3RBc05hbWUKY3VzdG9tVHlwZToKCXByb3RvIDEgMQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hcmM1Ni5hbGdvLnRzOjQ0CgkvLyByZXR1cm4gaW5wdXQ7CglmcmFtZV9kaWcgLTEgLy8gaW5wdXQ6IEN1c3RvbVN0cnVjdEFzTmFtZQoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg4ZDIyNzM5YSAvLyBtZXRob2QgImN1c3RvbVN0cnVjdE1ldGhvZCgodWludDY0KSkodWludDY0KSIKCXB1c2hieXRlcyAweDM5NmQ1NTBlIC8vIG1ldGhvZCAiZm9vKCgodWludDY0LHVpbnQ2NCksKHVpbnQ2NCx1aW50NjQpKSkodWludDY0LHVpbnQ2NCkiCglwdXNoYnl0ZXMgMHgwZGJmMDJjNyAvLyBtZXRob2QgImN1c3RvbVR5cGUoKHVpbnQ2NCkpKHVpbnQ2NCkiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2N1c3RvbVN0cnVjdE1ldGhvZCAqYWJpX3JvdXRlX2ZvbyAqYWJpX3JvdXRlX2N1c3RvbVR5cGUKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnIKCipjYWxsX09wdEluOgoJcHVzaGJ5dGVzIDB4MDFhM2EzZmYgLy8gbWV0aG9kICJvcHRJblRvQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX29wdEluVG9BcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE9wdEluCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmludGNibG9jayBUTVBMX3NvbWVOdW1iZXIKYnl0ZWNibG9jayAweDE1MWY3Yzc1IDB4NjI2Zjc4NGI2NTc5CgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIGxpbmVzIG9mIFRFQUwgYXJlIHVzZWQgdG8gaW5pdGlhbGl6ZSB0ZW1wbGF0ZSB2YXJpYWJsZXMgaW4gc2NyYXRjaCBzbG90cwppbnRjIDAgLy8gVE1QTF9zb21lTnVtYmVyCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKmNhbGxfT3B0SW4gKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIGN1c3RvbVN0cnVjdE1ldGhvZCgodWludDY0KSkodWludDY0KQoqYWJpX3JvdXRlX2N1c3RvbVN0cnVjdE1ldGhvZDoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJYnl0ZSAweDE1MWY3Yzc1CgoJLy8gaW5wdXQ6ICh1aW50NjQpCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglkdXAKCWxlbgoJcHVzaGludCA4Cgk9PQoKCS8vIGFyZ3VtZW50IDAgKGlucHV0KSBmb3IgY3VzdG9tU3RydWN0TWV0aG9kIG11c3QgYmUgYSAodWludDY0KQoJYXNzZXJ0CgoJLy8gZXhlY3V0ZSBjdXN0b21TdHJ1Y3RNZXRob2QoKHVpbnQ2NCkpKHVpbnQ2NCkKCWNhbGxzdWIgY3VzdG9tU3RydWN0TWV0aG9kCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGN1c3RvbVN0cnVjdE1ldGhvZChpbnB1dDogQW5vdGhlckN1c3RvbVN0cnVjdCk6IEFub3RoZXJDdXN0b21TdHJ1Y3QKY3VzdG9tU3RydWN0TWV0aG9kOgoJcHJvdG8gMSAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLWV4dGVybmFsLmFsZ28udHM6MjEKCS8vIHJldHVybiBpbnB1dDsKCWZyYW1lX2RpZyAtMSAvLyBpbnB1dDogQW5vdGhlckN1c3RvbVN0cnVjdAoJcmV0c3ViCgovLyBmb28oKCh1aW50NjQsdWludDY0KSwodWludDY0LHVpbnQ2NCkpKSh1aW50NjQsdWludDY0KQoqYWJpX3JvdXRlX2ZvbzoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJYnl0ZSAweDE1MWY3Yzc1CgoJLy8gaW5wdXRzOiAoKHVpbnQ2NCx1aW50NjQpLCh1aW50NjQsdWludDY0KSkKCXR4bmEgQXBwbGljYXRpb25BcmdzIDEKCWR1cAoJbGVuCglwdXNoaW50IDMyCgk9PQoKCS8vIGFyZ3VtZW50IDAgKGlucHV0cykgZm9yIGZvbyBtdXN0IGJlIGEgKCh1aW50NjQsdWludDY0KSwodWludDY0LHVpbnQ2NCkpCglhc3NlcnQKCgkvLyBleGVjdXRlIGZvbygoKHVpbnQ2NCx1aW50NjQpLCh1aW50NjQsdWludDY0KSkpKHVpbnQ2NCx1aW50NjQpCgljYWxsc3ViIGZvbwoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBmb28oaW5wdXRzOiBJbnB1dHMpOiBPdXRwdXRzCmZvbzoKCXByb3RvIDEgMQoKCS8vICppZjBfY29uZGl0aW9uCgkvLyB0ZXN0cy9jb250cmFjdHMvYXJjNTYuYWxnby50czoyNQoJLy8gaW5wdXRzLnN1YnRyYWN0LmEgPCBpbnB1dHMuc3VidHJhY3QuYgoJZnJhbWVfZGlnIC0xIC8vIGlucHV0czogSW5wdXRzCglleHRyYWN0IDE2IDgKCWJ0b2kKCWZyYW1lX2RpZyAtMSAvLyBpbnB1dHM6IElucHV0cwoJZXh0cmFjdCAyNCA4CglidG9pCgk8CglieiAqaWYwX2VuZAoKCS8vICppZjBfY29uc2VxdWVudAoJLy8gc3VidHJhY3QuYSBtdXN0IGJlIGdyZWF0ZXIgdGhhbiBzdWJ0cmFjdC5iCgllcnIKCippZjBfZW5kOgoJLy8gdGVzdHMvY29udHJhY3RzL2FyYzU2LmFsZ28udHM6MjcKCS8vIHRoaXMuZ2xvYmFsS2V5LnZhbHVlID0gdGhpcy5zb21lTnVtYmVyCglwdXNoYnl0ZXMgMHg2NzZjNmY2MjYxNmM0YjY1NzkgLy8gImdsb2JhbEtleSIKCWludGMgMCAvLyBUTVBMX3NvbWVOdW1iZXIKCWFwcF9nbG9iYWxfcHV0CgoJLy8gdGVzdHMvY29udHJhY3RzL2FyYzU2LmFsZ28udHM6MjgKCS8vIHRoaXMuZ2xvYmFsTWFwKCdmb28nKS52YWx1ZSA9IHsgZm9vOiAxMywgYmFyOiAzNyB9CglwdXNoYnl0ZXMgMHg3MDAwMDM2NjZmNmYKCXB1c2hieXRlcyAweDAwMGQwMDI1CglhcHBfZ2xvYmFsX3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hcmM1Ni5hbGdvLnRzOjMwCgkvLyByZXR1cm4gewoJLy8gICAgICAgc3VtOiBpbnB1dHMuYWRkLmEgKyBpbnB1dHMuYWRkLmIsCgkvLyAgICAgICBkaWZmZXJlbmNlOiBpbnB1dHMuc3VidHJhY3QuYSAtIGlucHV0cy5zdWJ0cmFjdC5iLAoJLy8gICAgIH07CglmcmFtZV9kaWcgLTEgLy8gaW5wdXRzOiBJbnB1dHMKCWV4dHJhY3QgMCA4CglidG9pCglmcmFtZV9kaWcgLTEgLy8gaW5wdXRzOiBJbnB1dHMKCWV4dHJhY3QgOCA4CglidG9pCgkrCglpdG9iCglmcmFtZV9kaWcgLTEgLy8gaW5wdXRzOiBJbnB1dHMKCWV4dHJhY3QgMTYgOAoJYnRvaQoJZnJhbWVfZGlnIC0xIC8vIGlucHV0czogSW5wdXRzCglleHRyYWN0IDI0IDgKCWJ0b2kKCS0KCWl0b2IKCWNvbmNhdAoJcmV0c3ViCgovLyBvcHRJblRvQXBwbGljYXRpb24oKXZvaWQKKmFiaV9yb3V0ZV9vcHRJblRvQXBwbGljYXRpb246CgkvLyBleGVjdXRlIG9wdEluVG9BcHBsaWNhdGlvbigpdm9pZAoJY2FsbHN1YiBvcHRJblRvQXBwbGljYXRpb24KCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBvcHRJblRvQXBwbGljYXRpb24oKTogdm9pZApvcHRJblRvQXBwbGljYXRpb246Cglwcm90byAwIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYXJjNTYuYWxnby50czozNwoJLy8gdGhpcy5sb2NhbEtleSh0aGlzLnR4bi5zZW5kZXIpLnZhbHVlID0gdGhpcy5zb21lTnVtYmVyCgl0eG4gU2VuZGVyCglwdXNoYnl0ZXMgMHg2YzZmNjM2MTZjNGI2NTc5IC8vICJsb2NhbEtleSIKCWludGMgMCAvLyBUTVBMX3NvbWVOdW1iZXIKCWFwcF9sb2NhbF9wdXQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYXJjNTYuYWxnby50czozOAoJLy8gdGhpcy5sb2NhbE1hcCh0aGlzLnR4bi5zZW5kZXIsICdmb28nKS52YWx1ZSA9ICdiYXInCgl0eG4gU2VuZGVyCglwdXNoYnl0ZXMgMHg3MDY2NmY2ZgoJcHVzaGJ5dGVzIDB4MDAwMzYyNjE3MgoJYXBwX2xvY2FsX3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hcmM1Ni5hbGdvLnRzOjM5CgkvLyB0aGlzLmJveEtleS52YWx1ZSA9ICdiYXonCglieXRlIDB4NjI2Zjc4NGI2NTc5IC8vICJib3hLZXkiCglkdXAKCWJveF9kZWwKCXBvcAoJcHVzaGJ5dGVzIDB4MDAwMzYyNjE3YQoJYm94X3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hcmM1Ni5hbGdvLnRzOjQwCgkvLyB0aGlzLmJveE1hcCh7IGFkZDogeyBhOiAxLCBiOiAyIH0sIHN1YnRyYWN0OiB7IGE6IDQsIGI6IDMgfSB9KS52YWx1ZSA9IHsgc3VtOiAzLCBkaWZmZXJlbmNlOiAxIH0KCXB1c2hieXRlcyAweDcwMDAwMDAwMDAwMDAwMDAwMTAwMDAwMDAwMDAwMDAwMDIwMDAwMDAwMDAwMDAwMDA0MDAwMDAwMDAwMDAwMDAwMwoJcHVzaGJ5dGVzIDB4MDAwMDAwMDAwMDAwMDAwMzAwMDAwMDAwMDAwMDAwMDEKCWJveF9wdXQKCXJldHN1YgoKLy8gY3VzdG9tVHlwZSgodWludDY0KSkodWludDY0KQoqYWJpX3JvdXRlX2N1c3RvbVR5cGU6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCWJ5dGUgMHgxNTFmN2M3NQoKCS8vIGlucHV0OiAodWludDY0KQoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJZHVwCglsZW4KCXB1c2hpbnQgOAoJPT0KCgkvLyBhcmd1bWVudCAwIChpbnB1dCkgZm9yIGN1c3RvbVR5cGUgbXVzdCBiZSBhICh1aW50NjQpCglhc3NlcnQKCgkvLyBleGVjdXRlIGN1c3RvbVR5cGUoKHVpbnQ2NCkpKHVpbnQ2NCkKCWNhbGxzdWIgY3VzdG9tVHlwZQoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBjdXN0b21UeXBlKGlucHV0OiBDdXN0b21TdHJ1Y3RBc05hbWUpOiBDdXN0b21TdHJ1Y3RBc05hbWUKY3VzdG9tVHlwZToKCXByb3RvIDEgMQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hcmM1Ni5hbGdvLnRzOjQ0CgkvLyByZXR1cm4gaW5wdXQ7CglmcmFtZV9kaWcgLTEgLy8gaW5wdXQ6IEN1c3RvbVN0cnVjdEFzTmFtZQoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg4ZDIyNzM5YSAvLyBtZXRob2QgImN1c3RvbVN0cnVjdE1ldGhvZCgodWludDY0KSkodWludDY0KSIKCXB1c2hieXRlcyAweDM5NmQ1NTBlIC8vIG1ldGhvZCAiZm9vKCgodWludDY0LHVpbnQ2NCksKHVpbnQ2NCx1aW50NjQpKSkodWludDY0LHVpbnQ2NCkiCglwdXNoYnl0ZXMgMHgwZGJmMDJjNyAvLyBtZXRob2QgImN1c3RvbVR5cGUoKHVpbnQ2NCkpKHVpbnQ2NCkiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2N1c3RvbVN0cnVjdE1ldGhvZCAqYWJpX3JvdXRlX2ZvbyAqYWJpX3JvdXRlX2N1c3RvbVR5cGUKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnIKCipjYWxsX09wdEluOgoJcHVzaGJ5dGVzIDB4MDFhM2EzZmYgLy8gbWV0aG9kICJvcHRJblRvQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX29wdEluVG9BcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE9wdEluCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "templateVariables": { diff --git a/tests/contracts/artifacts/ARC56TestNoTemplateVars.approval.teal b/tests/contracts/artifacts/ARC56TestNoTemplateVars.approval.teal index ee2fda28c..f8eda6915 100644 --- a/tests/contracts/artifacts/ARC56TestNoTemplateVars.approval.teal +++ b/tests/contracts/artifacts/ARC56TestNoTemplateVars.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ARC56TestNoTemplateVars.arc32.json b/tests/contracts/artifacts/ARC56TestNoTemplateVars.arc32.json index 19a99ad93..0442caef4 100644 --- a/tests/contracts/artifacts/ARC56TestNoTemplateVars.arc32.json +++ b/tests/contracts/artifacts/ARC56TestNoTemplateVars.arc32.json @@ -34,7 +34,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ARC56TestNoTemplateVars.arc56_draft.json b/tests/contracts/artifacts/ARC56TestNoTemplateVars.arc56_draft.json index b5a6eece7..bc1e307e0 100644 --- a/tests/contracts/artifacts/ARC56TestNoTemplateVars.arc56_draft.json +++ b/tests/contracts/artifacts/ARC56TestNoTemplateVars.arc56_draft.json @@ -205,7 +205,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/AVM11.approval.teal b/tests/contracts/artifacts/AVM11.approval.teal index ef8f5940d..782201f61 100644 --- a/tests/contracts/artifacts/AVM11.approval.teal +++ b/tests/contracts/artifacts/AVM11.approval.teal @@ -1,7 +1,7 @@ #pragma version 11 intcblock 1 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/AVM11.arc32.json b/tests/contracts/artifacts/AVM11.arc32.json index 22563c9ac..d7381ead1 100644 --- a/tests/contracts/artifacts/AVM11.arc32.json +++ b/tests/contracts/artifacts/AVM11.arc32.json @@ -59,7 +59,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDExCmludGNibG9jayAxCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdm90ZXJPcGNvZGVzKCl2b2lkCiphYmlfcm91dGVfdm90ZXJPcGNvZGVzOgoJLy8gZXhlY3V0ZSB2b3Rlck9wY29kZXMoKXZvaWQKCWNhbGxzdWIgdm90ZXJPcGNvZGVzCglpbnQgMQoJcmV0dXJuCgovLyB2b3Rlck9wY29kZXMoKTogdm9pZAp2b3Rlck9wY29kZXM6Cglwcm90byAwIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYXZtMTEuYWxnby50czo3CgkvLyBhc3NlcnQodGhpcy50eG4uc2VuZGVyLnZvdGVyQmFsYW5jZSkKCXR4biBTZW5kZXIKCXZvdGVyX3BhcmFtc19nZXQgVm90ZXJCYWxhbmNlCglhc3NlcnQKCXJldHN1YgoKLy8gaW5jZW50aXZlR2xvYmFscygpdm9pZAoqYWJpX3JvdXRlX2luY2VudGl2ZUdsb2JhbHM6CgkvLyBleGVjdXRlIGluY2VudGl2ZUdsb2JhbHMoKXZvaWQKCWNhbGxzdWIgaW5jZW50aXZlR2xvYmFscwoJaW50IDEKCXJldHVybgoKLy8gaW5jZW50aXZlR2xvYmFscygpOiB2b2lkCmluY2VudGl2ZUdsb2JhbHM6Cglwcm90byAwIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYXZtMTEuYWxnby50czoxMgoJLy8gYXNzZXJ0KGdsb2JhbHMucGF5b3V0c0VuYWJsZWQpCglnbG9iYWwgUGF5b3V0c0VuYWJsZWQKCWFzc2VydAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hdm0xMS5hbGdvLnRzOjEzCgkvLyBhc3NlcnQoZ2xvYmFscy5wYXlvdXRzR29PbmxpbmVGZWUpCglnbG9iYWwgUGF5b3V0c0dvT25saW5lRmVlCglhc3NlcnQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYXZtMTEuYWxnby50czoxNAoJLy8gYXNzZXJ0KGdsb2JhbHMucGF5b3V0c1BlcmNlbnQpCglnbG9iYWwgUGF5b3V0c1BlcmNlbnQKCWFzc2VydAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hdm0xMS5hbGdvLnRzOjE1CgkvLyBhc3NlcnQoZ2xvYmFscy5wYXlvdXRzTWluQmFsYW5jZSkKCWdsb2JhbCBQYXlvdXRzTWluQmFsYW5jZQoJYXNzZXJ0CgoJLy8gdGVzdHMvY29udHJhY3RzL2F2bTExLmFsZ28udHM6MTYKCS8vIGFzc2VydChnbG9iYWxzLnBheW91dHNNYXhCYWxhbmNlKQoJZ2xvYmFsIFBheW91dHNNYXhCYWxhbmNlCglhc3NlcnQKCXJldHN1YgoKLy8gb25saW5lU3Rha2VPcCgpdm9pZAoqYWJpX3JvdXRlX29ubGluZVN0YWtlT3A6CgkvLyBleGVjdXRlIG9ubGluZVN0YWtlT3AoKXZvaWQKCWNhbGxzdWIgb25saW5lU3Rha2VPcAoJaW50IDEKCXJldHVybgoKLy8gb25saW5lU3Rha2VPcCgpOiB2b2lkCm9ubGluZVN0YWtlT3A6Cglwcm90byAwIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYXZtMTEuYWxnby50czoyMAoJLy8gYXNzZXJ0KG9ubGluZVN0YWtlKCkpCglvbmxpbmVfc3Rha2UKCWFzc2VydAoJcmV0c3ViCgovLyBhY2NvdW50UGFyYW1zKCl2b2lkCiphYmlfcm91dGVfYWNjb3VudFBhcmFtczoKCS8vIGV4ZWN1dGUgYWNjb3VudFBhcmFtcygpdm9pZAoJY2FsbHN1YiBhY2NvdW50UGFyYW1zCglpbnQgMQoJcmV0dXJuCgovLyBhY2NvdW50UGFyYW1zKCk6IHZvaWQKYWNjb3VudFBhcmFtczoKCXByb3RvIDAgMAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hdm0xMS5hbGdvLnRzOjI0CgkvLyBhc3NlcnQodGhpcy50eG4uc2VuZGVyLmluY2VudGl2ZUVsaWdpYmxlKQoJdHhuIFNlbmRlcgoJYWNjdF9wYXJhbXNfZ2V0IEFjY3RJbmNlbnRpdmVFbGlnaWJsZQoJcG9wCglhc3NlcnQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYXZtMTEuYWxnby50czoyNQoJLy8gYXNzZXJ0KHRoaXMudHhuLnNlbmRlci5sYXN0SGVhcnRiZWF0KQoJdHhuIFNlbmRlcgoJYWNjdF9wYXJhbXNfZ2V0IEFjY3RMYXN0SGVhcnRiZWF0Cglwb3AKCWFzc2VydAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hdm0xMS5hbGdvLnRzOjI2CgkvLyBhc3NlcnQodGhpcy50eG4uc2VuZGVyLmxhc3RQcm9wb3NlZCkKCXR4biBTZW5kZXIKCWFjY3RfcGFyYW1zX2dldCBBY2N0TGFzdFByb3Bvc2VkCglwb3AKCWFzc2VydAoJcmV0c3ViCgovLyBibG9ja1BhcmFtcygpdm9pZAoqYWJpX3JvdXRlX2Jsb2NrUGFyYW1zOgoJLy8gZXhlY3V0ZSBibG9ja1BhcmFtcygpdm9pZAoJY2FsbHN1YiBibG9ja1BhcmFtcwoJaW50IDEKCXJldHVybgoKLy8gYmxvY2tQYXJhbXMoKTogdm9pZApibG9ja1BhcmFtczoKCXByb3RvIDAgMAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hdm0xMS5hbGdvLnRzOjMwCgkvLyBsb2coYmxvY2tzW2dsb2JhbHMucm91bmQgLSAxXS5wcm9wb3NlcikKCWdsb2JhbCBSb3VuZAoJaW50IDEKCS0KCWJsb2NrIEJsa1Byb3Bvc2VyCglsb2cKCgkvLyB0ZXN0cy9jb250cmFjdHMvYXZtMTEuYWxnby50czozMQoJLy8gYXNzZXJ0KGJsb2Nrc1tnbG9iYWxzLnJvdW5kIC0gMV0uZmVlc0NvbGxlY3RlZCkKCWdsb2JhbCBSb3VuZAoJaW50IDEKCS0KCWJsb2NrIEJsa0ZlZXNDb2xsZWN0ZWQKCWFzc2VydAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hdm0xMS5hbGdvLnRzOjMyCgkvLyBhc3NlcnQoYmxvY2tzW2dsb2JhbHMucm91bmQgLSAxXS5ib251cykKCWdsb2JhbCBSb3VuZAoJaW50IDEKCS0KCWJsb2NrIEJsa0JvbnVzCglhc3NlcnQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYXZtMTEuYWxnby50czozMwoJLy8gbG9nKGJsb2Nrc1tnbG9iYWxzLnJvdW5kIC0gMV0uYnJhbmNoKQoJZ2xvYmFsIFJvdW5kCglpbnQgMQoJLQoJYmxvY2sgQmxrQnJhbmNoCglsb2cKCgkvLyB0ZXN0cy9jb250cmFjdHMvYXZtMTEuYWxnby50czozNAoJLy8gbG9nKGJsb2Nrc1tnbG9iYWxzLnJvdW5kIC0gMV0uZmVlU2luaykKCWdsb2JhbCBSb3VuZAoJaW50IDEKCS0KCWJsb2NrIEJsa0ZlZVNpbmsKCWxvZwoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hdm0xMS5hbGdvLnRzOjM1CgkvLyBsb2coYmxvY2tzW2dsb2JhbHMucm91bmQgLSAxXS5wcm90b2NvbCkKCWdsb2JhbCBSb3VuZAoJaW50IDEKCS0KCWJsb2NrIEJsa1Byb3RvY29sCglsb2cKCgkvLyB0ZXN0cy9jb250cmFjdHMvYXZtMTEuYWxnby50czozNgoJLy8gYXNzZXJ0KGJsb2Nrc1tnbG9iYWxzLnJvdW5kIC0gMV0udHhuQ291bnRlcikKCWdsb2JhbCBSb3VuZAoJaW50IDEKCS0KCWJsb2NrIEJsa1R4bkNvdW50ZXIKCWFzc2VydAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hdm0xMS5hbGdvLnRzOjM3CgkvLyBhc3NlcnQoYmxvY2tzW2dsb2JhbHMucm91bmQgLSAxXS5wcm9wb3NlclBheW91dCkKCWdsb2JhbCBSb3VuZAoJaW50IDEKCS0KCWJsb2NrIEJsa1Byb3Bvc2VyUGF5b3V0Cglhc3NlcnQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCWludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg4ZGMxMjlmNiAvLyBtZXRob2QgInZvdGVyT3Bjb2Rlcygpdm9pZCIKCXB1c2hieXRlcyAweGE4OGJmODY3IC8vIG1ldGhvZCAiaW5jZW50aXZlR2xvYmFscygpdm9pZCIKCXB1c2hieXRlcyAweDkxM2ExZGQ0IC8vIG1ldGhvZCAib25saW5lU3Rha2VPcCgpdm9pZCIKCXB1c2hieXRlcyAweGE1YjJmZWNiIC8vIG1ldGhvZCAiYWNjb3VudFBhcmFtcygpdm9pZCIKCXB1c2hieXRlcyAweDNmNjU4MWY1IC8vIG1ldGhvZCAiYmxvY2tQYXJhbXMoKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3ZvdGVyT3Bjb2RlcyAqYWJpX3JvdXRlX2luY2VudGl2ZUdsb2JhbHMgKmFiaV9yb3V0ZV9vbmxpbmVTdGFrZU9wICphYmlfcm91dGVfYWNjb3VudFBhcmFtcyAqYWJpX3JvdXRlX2Jsb2NrUGFyYW1zCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDExCmludGNibG9jayAxCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdm90ZXJPcGNvZGVzKCl2b2lkCiphYmlfcm91dGVfdm90ZXJPcGNvZGVzOgoJLy8gZXhlY3V0ZSB2b3Rlck9wY29kZXMoKXZvaWQKCWNhbGxzdWIgdm90ZXJPcGNvZGVzCglpbnQgMQoJcmV0dXJuCgovLyB2b3Rlck9wY29kZXMoKTogdm9pZAp2b3Rlck9wY29kZXM6Cglwcm90byAwIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYXZtMTEuYWxnby50czo3CgkvLyBhc3NlcnQodGhpcy50eG4uc2VuZGVyLnZvdGVyQmFsYW5jZSkKCXR4biBTZW5kZXIKCXZvdGVyX3BhcmFtc19nZXQgVm90ZXJCYWxhbmNlCglhc3NlcnQKCXJldHN1YgoKLy8gaW5jZW50aXZlR2xvYmFscygpdm9pZAoqYWJpX3JvdXRlX2luY2VudGl2ZUdsb2JhbHM6CgkvLyBleGVjdXRlIGluY2VudGl2ZUdsb2JhbHMoKXZvaWQKCWNhbGxzdWIgaW5jZW50aXZlR2xvYmFscwoJaW50IDEKCXJldHVybgoKLy8gaW5jZW50aXZlR2xvYmFscygpOiB2b2lkCmluY2VudGl2ZUdsb2JhbHM6Cglwcm90byAwIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYXZtMTEuYWxnby50czoxMgoJLy8gYXNzZXJ0KGdsb2JhbHMucGF5b3V0c0VuYWJsZWQpCglnbG9iYWwgUGF5b3V0c0VuYWJsZWQKCWFzc2VydAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hdm0xMS5hbGdvLnRzOjEzCgkvLyBhc3NlcnQoZ2xvYmFscy5wYXlvdXRzR29PbmxpbmVGZWUpCglnbG9iYWwgUGF5b3V0c0dvT25saW5lRmVlCglhc3NlcnQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYXZtMTEuYWxnby50czoxNAoJLy8gYXNzZXJ0KGdsb2JhbHMucGF5b3V0c1BlcmNlbnQpCglnbG9iYWwgUGF5b3V0c1BlcmNlbnQKCWFzc2VydAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hdm0xMS5hbGdvLnRzOjE1CgkvLyBhc3NlcnQoZ2xvYmFscy5wYXlvdXRzTWluQmFsYW5jZSkKCWdsb2JhbCBQYXlvdXRzTWluQmFsYW5jZQoJYXNzZXJ0CgoJLy8gdGVzdHMvY29udHJhY3RzL2F2bTExLmFsZ28udHM6MTYKCS8vIGFzc2VydChnbG9iYWxzLnBheW91dHNNYXhCYWxhbmNlKQoJZ2xvYmFsIFBheW91dHNNYXhCYWxhbmNlCglhc3NlcnQKCXJldHN1YgoKLy8gb25saW5lU3Rha2VPcCgpdm9pZAoqYWJpX3JvdXRlX29ubGluZVN0YWtlT3A6CgkvLyBleGVjdXRlIG9ubGluZVN0YWtlT3AoKXZvaWQKCWNhbGxzdWIgb25saW5lU3Rha2VPcAoJaW50IDEKCXJldHVybgoKLy8gb25saW5lU3Rha2VPcCgpOiB2b2lkCm9ubGluZVN0YWtlT3A6Cglwcm90byAwIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYXZtMTEuYWxnby50czoyMAoJLy8gYXNzZXJ0KG9ubGluZVN0YWtlKCkpCglvbmxpbmVfc3Rha2UKCWFzc2VydAoJcmV0c3ViCgovLyBhY2NvdW50UGFyYW1zKCl2b2lkCiphYmlfcm91dGVfYWNjb3VudFBhcmFtczoKCS8vIGV4ZWN1dGUgYWNjb3VudFBhcmFtcygpdm9pZAoJY2FsbHN1YiBhY2NvdW50UGFyYW1zCglpbnQgMQoJcmV0dXJuCgovLyBhY2NvdW50UGFyYW1zKCk6IHZvaWQKYWNjb3VudFBhcmFtczoKCXByb3RvIDAgMAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hdm0xMS5hbGdvLnRzOjI0CgkvLyBhc3NlcnQodGhpcy50eG4uc2VuZGVyLmluY2VudGl2ZUVsaWdpYmxlKQoJdHhuIFNlbmRlcgoJYWNjdF9wYXJhbXNfZ2V0IEFjY3RJbmNlbnRpdmVFbGlnaWJsZQoJcG9wCglhc3NlcnQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYXZtMTEuYWxnby50czoyNQoJLy8gYXNzZXJ0KHRoaXMudHhuLnNlbmRlci5sYXN0SGVhcnRiZWF0KQoJdHhuIFNlbmRlcgoJYWNjdF9wYXJhbXNfZ2V0IEFjY3RMYXN0SGVhcnRiZWF0Cglwb3AKCWFzc2VydAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hdm0xMS5hbGdvLnRzOjI2CgkvLyBhc3NlcnQodGhpcy50eG4uc2VuZGVyLmxhc3RQcm9wb3NlZCkKCXR4biBTZW5kZXIKCWFjY3RfcGFyYW1zX2dldCBBY2N0TGFzdFByb3Bvc2VkCglwb3AKCWFzc2VydAoJcmV0c3ViCgovLyBibG9ja1BhcmFtcygpdm9pZAoqYWJpX3JvdXRlX2Jsb2NrUGFyYW1zOgoJLy8gZXhlY3V0ZSBibG9ja1BhcmFtcygpdm9pZAoJY2FsbHN1YiBibG9ja1BhcmFtcwoJaW50IDEKCXJldHVybgoKLy8gYmxvY2tQYXJhbXMoKTogdm9pZApibG9ja1BhcmFtczoKCXByb3RvIDAgMAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hdm0xMS5hbGdvLnRzOjMwCgkvLyBsb2coYmxvY2tzW2dsb2JhbHMucm91bmQgLSAxXS5wcm9wb3NlcikKCWdsb2JhbCBSb3VuZAoJaW50IDEKCS0KCWJsb2NrIEJsa1Byb3Bvc2VyCglsb2cKCgkvLyB0ZXN0cy9jb250cmFjdHMvYXZtMTEuYWxnby50czozMQoJLy8gYXNzZXJ0KGJsb2Nrc1tnbG9iYWxzLnJvdW5kIC0gMV0uZmVlc0NvbGxlY3RlZCkKCWdsb2JhbCBSb3VuZAoJaW50IDEKCS0KCWJsb2NrIEJsa0ZlZXNDb2xsZWN0ZWQKCWFzc2VydAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hdm0xMS5hbGdvLnRzOjMyCgkvLyBhc3NlcnQoYmxvY2tzW2dsb2JhbHMucm91bmQgLSAxXS5ib251cykKCWdsb2JhbCBSb3VuZAoJaW50IDEKCS0KCWJsb2NrIEJsa0JvbnVzCglhc3NlcnQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYXZtMTEuYWxnby50czozMwoJLy8gbG9nKGJsb2Nrc1tnbG9iYWxzLnJvdW5kIC0gMV0uYnJhbmNoKQoJZ2xvYmFsIFJvdW5kCglpbnQgMQoJLQoJYmxvY2sgQmxrQnJhbmNoCglsb2cKCgkvLyB0ZXN0cy9jb250cmFjdHMvYXZtMTEuYWxnby50czozNAoJLy8gbG9nKGJsb2Nrc1tnbG9iYWxzLnJvdW5kIC0gMV0uZmVlU2luaykKCWdsb2JhbCBSb3VuZAoJaW50IDEKCS0KCWJsb2NrIEJsa0ZlZVNpbmsKCWxvZwoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hdm0xMS5hbGdvLnRzOjM1CgkvLyBsb2coYmxvY2tzW2dsb2JhbHMucm91bmQgLSAxXS5wcm90b2NvbCkKCWdsb2JhbCBSb3VuZAoJaW50IDEKCS0KCWJsb2NrIEJsa1Byb3RvY29sCglsb2cKCgkvLyB0ZXN0cy9jb250cmFjdHMvYXZtMTEuYWxnby50czozNgoJLy8gYXNzZXJ0KGJsb2Nrc1tnbG9iYWxzLnJvdW5kIC0gMV0udHhuQ291bnRlcikKCWdsb2JhbCBSb3VuZAoJaW50IDEKCS0KCWJsb2NrIEJsa1R4bkNvdW50ZXIKCWFzc2VydAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hdm0xMS5hbGdvLnRzOjM3CgkvLyBhc3NlcnQoYmxvY2tzW2dsb2JhbHMucm91bmQgLSAxXS5wcm9wb3NlclBheW91dCkKCWdsb2JhbCBSb3VuZAoJaW50IDEKCS0KCWJsb2NrIEJsa1Byb3Bvc2VyUGF5b3V0Cglhc3NlcnQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCWludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg4ZGMxMjlmNiAvLyBtZXRob2QgInZvdGVyT3Bjb2Rlcygpdm9pZCIKCXB1c2hieXRlcyAweGE4OGJmODY3IC8vIG1ldGhvZCAiaW5jZW50aXZlR2xvYmFscygpdm9pZCIKCXB1c2hieXRlcyAweDkxM2ExZGQ0IC8vIG1ldGhvZCAib25saW5lU3Rha2VPcCgpdm9pZCIKCXB1c2hieXRlcyAweGE1YjJmZWNiIC8vIG1ldGhvZCAiYWNjb3VudFBhcmFtcygpdm9pZCIKCXB1c2hieXRlcyAweDNmNjU4MWY1IC8vIG1ldGhvZCAiYmxvY2tQYXJhbXMoKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3ZvdGVyT3Bjb2RlcyAqYWJpX3JvdXRlX2luY2VudGl2ZUdsb2JhbHMgKmFiaV9yb3V0ZV9vbmxpbmVTdGFrZU9wICphYmlfcm91dGVfYWNjb3VudFBhcmFtcyAqYWJpX3JvdXRlX2Jsb2NrUGFyYW1zCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEx" }, "contract": { diff --git a/tests/contracts/artifacts/AVM11.arc56_draft.json b/tests/contracts/artifacts/AVM11.arc56_draft.json index 40158515f..1d19f9abe 100644 --- a/tests/contracts/artifacts/AVM11.arc56_draft.json +++ b/tests/contracts/artifacts/AVM11.arc56_draft.json @@ -123,7 +123,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDExCmludGNibG9jayAxCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdm90ZXJPcGNvZGVzKCl2b2lkCiphYmlfcm91dGVfdm90ZXJPcGNvZGVzOgoJLy8gZXhlY3V0ZSB2b3Rlck9wY29kZXMoKXZvaWQKCWNhbGxzdWIgdm90ZXJPcGNvZGVzCglpbnQgMQoJcmV0dXJuCgovLyB2b3Rlck9wY29kZXMoKTogdm9pZAp2b3Rlck9wY29kZXM6Cglwcm90byAwIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYXZtMTEuYWxnby50czo3CgkvLyBhc3NlcnQodGhpcy50eG4uc2VuZGVyLnZvdGVyQmFsYW5jZSkKCXR4biBTZW5kZXIKCXZvdGVyX3BhcmFtc19nZXQgVm90ZXJCYWxhbmNlCglhc3NlcnQKCXJldHN1YgoKLy8gaW5jZW50aXZlR2xvYmFscygpdm9pZAoqYWJpX3JvdXRlX2luY2VudGl2ZUdsb2JhbHM6CgkvLyBleGVjdXRlIGluY2VudGl2ZUdsb2JhbHMoKXZvaWQKCWNhbGxzdWIgaW5jZW50aXZlR2xvYmFscwoJaW50IDEKCXJldHVybgoKLy8gaW5jZW50aXZlR2xvYmFscygpOiB2b2lkCmluY2VudGl2ZUdsb2JhbHM6Cglwcm90byAwIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYXZtMTEuYWxnby50czoxMgoJLy8gYXNzZXJ0KGdsb2JhbHMucGF5b3V0c0VuYWJsZWQpCglnbG9iYWwgUGF5b3V0c0VuYWJsZWQKCWFzc2VydAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hdm0xMS5hbGdvLnRzOjEzCgkvLyBhc3NlcnQoZ2xvYmFscy5wYXlvdXRzR29PbmxpbmVGZWUpCglnbG9iYWwgUGF5b3V0c0dvT25saW5lRmVlCglhc3NlcnQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYXZtMTEuYWxnby50czoxNAoJLy8gYXNzZXJ0KGdsb2JhbHMucGF5b3V0c1BlcmNlbnQpCglnbG9iYWwgUGF5b3V0c1BlcmNlbnQKCWFzc2VydAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hdm0xMS5hbGdvLnRzOjE1CgkvLyBhc3NlcnQoZ2xvYmFscy5wYXlvdXRzTWluQmFsYW5jZSkKCWdsb2JhbCBQYXlvdXRzTWluQmFsYW5jZQoJYXNzZXJ0CgoJLy8gdGVzdHMvY29udHJhY3RzL2F2bTExLmFsZ28udHM6MTYKCS8vIGFzc2VydChnbG9iYWxzLnBheW91dHNNYXhCYWxhbmNlKQoJZ2xvYmFsIFBheW91dHNNYXhCYWxhbmNlCglhc3NlcnQKCXJldHN1YgoKLy8gb25saW5lU3Rha2VPcCgpdm9pZAoqYWJpX3JvdXRlX29ubGluZVN0YWtlT3A6CgkvLyBleGVjdXRlIG9ubGluZVN0YWtlT3AoKXZvaWQKCWNhbGxzdWIgb25saW5lU3Rha2VPcAoJaW50IDEKCXJldHVybgoKLy8gb25saW5lU3Rha2VPcCgpOiB2b2lkCm9ubGluZVN0YWtlT3A6Cglwcm90byAwIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYXZtMTEuYWxnby50czoyMAoJLy8gYXNzZXJ0KG9ubGluZVN0YWtlKCkpCglvbmxpbmVfc3Rha2UKCWFzc2VydAoJcmV0c3ViCgovLyBhY2NvdW50UGFyYW1zKCl2b2lkCiphYmlfcm91dGVfYWNjb3VudFBhcmFtczoKCS8vIGV4ZWN1dGUgYWNjb3VudFBhcmFtcygpdm9pZAoJY2FsbHN1YiBhY2NvdW50UGFyYW1zCglpbnQgMQoJcmV0dXJuCgovLyBhY2NvdW50UGFyYW1zKCk6IHZvaWQKYWNjb3VudFBhcmFtczoKCXByb3RvIDAgMAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hdm0xMS5hbGdvLnRzOjI0CgkvLyBhc3NlcnQodGhpcy50eG4uc2VuZGVyLmluY2VudGl2ZUVsaWdpYmxlKQoJdHhuIFNlbmRlcgoJYWNjdF9wYXJhbXNfZ2V0IEFjY3RJbmNlbnRpdmVFbGlnaWJsZQoJcG9wCglhc3NlcnQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYXZtMTEuYWxnby50czoyNQoJLy8gYXNzZXJ0KHRoaXMudHhuLnNlbmRlci5sYXN0SGVhcnRiZWF0KQoJdHhuIFNlbmRlcgoJYWNjdF9wYXJhbXNfZ2V0IEFjY3RMYXN0SGVhcnRiZWF0Cglwb3AKCWFzc2VydAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hdm0xMS5hbGdvLnRzOjI2CgkvLyBhc3NlcnQodGhpcy50eG4uc2VuZGVyLmxhc3RQcm9wb3NlZCkKCXR4biBTZW5kZXIKCWFjY3RfcGFyYW1zX2dldCBBY2N0TGFzdFByb3Bvc2VkCglwb3AKCWFzc2VydAoJcmV0c3ViCgovLyBibG9ja1BhcmFtcygpdm9pZAoqYWJpX3JvdXRlX2Jsb2NrUGFyYW1zOgoJLy8gZXhlY3V0ZSBibG9ja1BhcmFtcygpdm9pZAoJY2FsbHN1YiBibG9ja1BhcmFtcwoJaW50IDEKCXJldHVybgoKLy8gYmxvY2tQYXJhbXMoKTogdm9pZApibG9ja1BhcmFtczoKCXByb3RvIDAgMAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hdm0xMS5hbGdvLnRzOjMwCgkvLyBsb2coYmxvY2tzW2dsb2JhbHMucm91bmQgLSAxXS5wcm9wb3NlcikKCWdsb2JhbCBSb3VuZAoJaW50IDEKCS0KCWJsb2NrIEJsa1Byb3Bvc2VyCglsb2cKCgkvLyB0ZXN0cy9jb250cmFjdHMvYXZtMTEuYWxnby50czozMQoJLy8gYXNzZXJ0KGJsb2Nrc1tnbG9iYWxzLnJvdW5kIC0gMV0uZmVlc0NvbGxlY3RlZCkKCWdsb2JhbCBSb3VuZAoJaW50IDEKCS0KCWJsb2NrIEJsa0ZlZXNDb2xsZWN0ZWQKCWFzc2VydAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hdm0xMS5hbGdvLnRzOjMyCgkvLyBhc3NlcnQoYmxvY2tzW2dsb2JhbHMucm91bmQgLSAxXS5ib251cykKCWdsb2JhbCBSb3VuZAoJaW50IDEKCS0KCWJsb2NrIEJsa0JvbnVzCglhc3NlcnQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYXZtMTEuYWxnby50czozMwoJLy8gbG9nKGJsb2Nrc1tnbG9iYWxzLnJvdW5kIC0gMV0uYnJhbmNoKQoJZ2xvYmFsIFJvdW5kCglpbnQgMQoJLQoJYmxvY2sgQmxrQnJhbmNoCglsb2cKCgkvLyB0ZXN0cy9jb250cmFjdHMvYXZtMTEuYWxnby50czozNAoJLy8gbG9nKGJsb2Nrc1tnbG9iYWxzLnJvdW5kIC0gMV0uZmVlU2luaykKCWdsb2JhbCBSb3VuZAoJaW50IDEKCS0KCWJsb2NrIEJsa0ZlZVNpbmsKCWxvZwoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hdm0xMS5hbGdvLnRzOjM1CgkvLyBsb2coYmxvY2tzW2dsb2JhbHMucm91bmQgLSAxXS5wcm90b2NvbCkKCWdsb2JhbCBSb3VuZAoJaW50IDEKCS0KCWJsb2NrIEJsa1Byb3RvY29sCglsb2cKCgkvLyB0ZXN0cy9jb250cmFjdHMvYXZtMTEuYWxnby50czozNgoJLy8gYXNzZXJ0KGJsb2Nrc1tnbG9iYWxzLnJvdW5kIC0gMV0udHhuQ291bnRlcikKCWdsb2JhbCBSb3VuZAoJaW50IDEKCS0KCWJsb2NrIEJsa1R4bkNvdW50ZXIKCWFzc2VydAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hdm0xMS5hbGdvLnRzOjM3CgkvLyBhc3NlcnQoYmxvY2tzW2dsb2JhbHMucm91bmQgLSAxXS5wcm9wb3NlclBheW91dCkKCWdsb2JhbCBSb3VuZAoJaW50IDEKCS0KCWJsb2NrIEJsa1Byb3Bvc2VyUGF5b3V0Cglhc3NlcnQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCWludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg4ZGMxMjlmNiAvLyBtZXRob2QgInZvdGVyT3Bjb2Rlcygpdm9pZCIKCXB1c2hieXRlcyAweGE4OGJmODY3IC8vIG1ldGhvZCAiaW5jZW50aXZlR2xvYmFscygpdm9pZCIKCXB1c2hieXRlcyAweDkxM2ExZGQ0IC8vIG1ldGhvZCAib25saW5lU3Rha2VPcCgpdm9pZCIKCXB1c2hieXRlcyAweGE1YjJmZWNiIC8vIG1ldGhvZCAiYWNjb3VudFBhcmFtcygpdm9pZCIKCXB1c2hieXRlcyAweDNmNjU4MWY1IC8vIG1ldGhvZCAiYmxvY2tQYXJhbXMoKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3ZvdGVyT3Bjb2RlcyAqYWJpX3JvdXRlX2luY2VudGl2ZUdsb2JhbHMgKmFiaV9yb3V0ZV9vbmxpbmVTdGFrZU9wICphYmlfcm91dGVfYWNjb3VudFBhcmFtcyAqYWJpX3JvdXRlX2Jsb2NrUGFyYW1zCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDExCmludGNibG9jayAxCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdm90ZXJPcGNvZGVzKCl2b2lkCiphYmlfcm91dGVfdm90ZXJPcGNvZGVzOgoJLy8gZXhlY3V0ZSB2b3Rlck9wY29kZXMoKXZvaWQKCWNhbGxzdWIgdm90ZXJPcGNvZGVzCglpbnQgMQoJcmV0dXJuCgovLyB2b3Rlck9wY29kZXMoKTogdm9pZAp2b3Rlck9wY29kZXM6Cglwcm90byAwIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYXZtMTEuYWxnby50czo3CgkvLyBhc3NlcnQodGhpcy50eG4uc2VuZGVyLnZvdGVyQmFsYW5jZSkKCXR4biBTZW5kZXIKCXZvdGVyX3BhcmFtc19nZXQgVm90ZXJCYWxhbmNlCglhc3NlcnQKCXJldHN1YgoKLy8gaW5jZW50aXZlR2xvYmFscygpdm9pZAoqYWJpX3JvdXRlX2luY2VudGl2ZUdsb2JhbHM6CgkvLyBleGVjdXRlIGluY2VudGl2ZUdsb2JhbHMoKXZvaWQKCWNhbGxzdWIgaW5jZW50aXZlR2xvYmFscwoJaW50IDEKCXJldHVybgoKLy8gaW5jZW50aXZlR2xvYmFscygpOiB2b2lkCmluY2VudGl2ZUdsb2JhbHM6Cglwcm90byAwIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYXZtMTEuYWxnby50czoxMgoJLy8gYXNzZXJ0KGdsb2JhbHMucGF5b3V0c0VuYWJsZWQpCglnbG9iYWwgUGF5b3V0c0VuYWJsZWQKCWFzc2VydAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hdm0xMS5hbGdvLnRzOjEzCgkvLyBhc3NlcnQoZ2xvYmFscy5wYXlvdXRzR29PbmxpbmVGZWUpCglnbG9iYWwgUGF5b3V0c0dvT25saW5lRmVlCglhc3NlcnQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYXZtMTEuYWxnby50czoxNAoJLy8gYXNzZXJ0KGdsb2JhbHMucGF5b3V0c1BlcmNlbnQpCglnbG9iYWwgUGF5b3V0c1BlcmNlbnQKCWFzc2VydAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hdm0xMS5hbGdvLnRzOjE1CgkvLyBhc3NlcnQoZ2xvYmFscy5wYXlvdXRzTWluQmFsYW5jZSkKCWdsb2JhbCBQYXlvdXRzTWluQmFsYW5jZQoJYXNzZXJ0CgoJLy8gdGVzdHMvY29udHJhY3RzL2F2bTExLmFsZ28udHM6MTYKCS8vIGFzc2VydChnbG9iYWxzLnBheW91dHNNYXhCYWxhbmNlKQoJZ2xvYmFsIFBheW91dHNNYXhCYWxhbmNlCglhc3NlcnQKCXJldHN1YgoKLy8gb25saW5lU3Rha2VPcCgpdm9pZAoqYWJpX3JvdXRlX29ubGluZVN0YWtlT3A6CgkvLyBleGVjdXRlIG9ubGluZVN0YWtlT3AoKXZvaWQKCWNhbGxzdWIgb25saW5lU3Rha2VPcAoJaW50IDEKCXJldHVybgoKLy8gb25saW5lU3Rha2VPcCgpOiB2b2lkCm9ubGluZVN0YWtlT3A6Cglwcm90byAwIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYXZtMTEuYWxnby50czoyMAoJLy8gYXNzZXJ0KG9ubGluZVN0YWtlKCkpCglvbmxpbmVfc3Rha2UKCWFzc2VydAoJcmV0c3ViCgovLyBhY2NvdW50UGFyYW1zKCl2b2lkCiphYmlfcm91dGVfYWNjb3VudFBhcmFtczoKCS8vIGV4ZWN1dGUgYWNjb3VudFBhcmFtcygpdm9pZAoJY2FsbHN1YiBhY2NvdW50UGFyYW1zCglpbnQgMQoJcmV0dXJuCgovLyBhY2NvdW50UGFyYW1zKCk6IHZvaWQKYWNjb3VudFBhcmFtczoKCXByb3RvIDAgMAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hdm0xMS5hbGdvLnRzOjI0CgkvLyBhc3NlcnQodGhpcy50eG4uc2VuZGVyLmluY2VudGl2ZUVsaWdpYmxlKQoJdHhuIFNlbmRlcgoJYWNjdF9wYXJhbXNfZ2V0IEFjY3RJbmNlbnRpdmVFbGlnaWJsZQoJcG9wCglhc3NlcnQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYXZtMTEuYWxnby50czoyNQoJLy8gYXNzZXJ0KHRoaXMudHhuLnNlbmRlci5sYXN0SGVhcnRiZWF0KQoJdHhuIFNlbmRlcgoJYWNjdF9wYXJhbXNfZ2V0IEFjY3RMYXN0SGVhcnRiZWF0Cglwb3AKCWFzc2VydAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hdm0xMS5hbGdvLnRzOjI2CgkvLyBhc3NlcnQodGhpcy50eG4uc2VuZGVyLmxhc3RQcm9wb3NlZCkKCXR4biBTZW5kZXIKCWFjY3RfcGFyYW1zX2dldCBBY2N0TGFzdFByb3Bvc2VkCglwb3AKCWFzc2VydAoJcmV0c3ViCgovLyBibG9ja1BhcmFtcygpdm9pZAoqYWJpX3JvdXRlX2Jsb2NrUGFyYW1zOgoJLy8gZXhlY3V0ZSBibG9ja1BhcmFtcygpdm9pZAoJY2FsbHN1YiBibG9ja1BhcmFtcwoJaW50IDEKCXJldHVybgoKLy8gYmxvY2tQYXJhbXMoKTogdm9pZApibG9ja1BhcmFtczoKCXByb3RvIDAgMAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hdm0xMS5hbGdvLnRzOjMwCgkvLyBsb2coYmxvY2tzW2dsb2JhbHMucm91bmQgLSAxXS5wcm9wb3NlcikKCWdsb2JhbCBSb3VuZAoJaW50IDEKCS0KCWJsb2NrIEJsa1Byb3Bvc2VyCglsb2cKCgkvLyB0ZXN0cy9jb250cmFjdHMvYXZtMTEuYWxnby50czozMQoJLy8gYXNzZXJ0KGJsb2Nrc1tnbG9iYWxzLnJvdW5kIC0gMV0uZmVlc0NvbGxlY3RlZCkKCWdsb2JhbCBSb3VuZAoJaW50IDEKCS0KCWJsb2NrIEJsa0ZlZXNDb2xsZWN0ZWQKCWFzc2VydAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hdm0xMS5hbGdvLnRzOjMyCgkvLyBhc3NlcnQoYmxvY2tzW2dsb2JhbHMucm91bmQgLSAxXS5ib251cykKCWdsb2JhbCBSb3VuZAoJaW50IDEKCS0KCWJsb2NrIEJsa0JvbnVzCglhc3NlcnQKCgkvLyB0ZXN0cy9jb250cmFjdHMvYXZtMTEuYWxnby50czozMwoJLy8gbG9nKGJsb2Nrc1tnbG9iYWxzLnJvdW5kIC0gMV0uYnJhbmNoKQoJZ2xvYmFsIFJvdW5kCglpbnQgMQoJLQoJYmxvY2sgQmxrQnJhbmNoCglsb2cKCgkvLyB0ZXN0cy9jb250cmFjdHMvYXZtMTEuYWxnby50czozNAoJLy8gbG9nKGJsb2Nrc1tnbG9iYWxzLnJvdW5kIC0gMV0uZmVlU2luaykKCWdsb2JhbCBSb3VuZAoJaW50IDEKCS0KCWJsb2NrIEJsa0ZlZVNpbmsKCWxvZwoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hdm0xMS5hbGdvLnRzOjM1CgkvLyBsb2coYmxvY2tzW2dsb2JhbHMucm91bmQgLSAxXS5wcm90b2NvbCkKCWdsb2JhbCBSb3VuZAoJaW50IDEKCS0KCWJsb2NrIEJsa1Byb3RvY29sCglsb2cKCgkvLyB0ZXN0cy9jb250cmFjdHMvYXZtMTEuYWxnby50czozNgoJLy8gYXNzZXJ0KGJsb2Nrc1tnbG9iYWxzLnJvdW5kIC0gMV0udHhuQ291bnRlcikKCWdsb2JhbCBSb3VuZAoJaW50IDEKCS0KCWJsb2NrIEJsa1R4bkNvdW50ZXIKCWFzc2VydAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9hdm0xMS5hbGdvLnRzOjM3CgkvLyBhc3NlcnQoYmxvY2tzW2dsb2JhbHMucm91bmQgLSAxXS5wcm9wb3NlclBheW91dCkKCWdsb2JhbCBSb3VuZAoJaW50IDEKCS0KCWJsb2NrIEJsa1Byb3Bvc2VyUGF5b3V0Cglhc3NlcnQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCWludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg4ZGMxMjlmNiAvLyBtZXRob2QgInZvdGVyT3Bjb2Rlcygpdm9pZCIKCXB1c2hieXRlcyAweGE4OGJmODY3IC8vIG1ldGhvZCAiaW5jZW50aXZlR2xvYmFscygpdm9pZCIKCXB1c2hieXRlcyAweDkxM2ExZGQ0IC8vIG1ldGhvZCAib25saW5lU3Rha2VPcCgpdm9pZCIKCXB1c2hieXRlcyAweGE1YjJmZWNiIC8vIG1ldGhvZCAiYWNjb3VudFBhcmFtcygpdm9pZCIKCXB1c2hieXRlcyAweDNmNjU4MWY1IC8vIG1ldGhvZCAiYmxvY2tQYXJhbXMoKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3ZvdGVyT3Bjb2RlcyAqYWJpX3JvdXRlX2luY2VudGl2ZUdsb2JhbHMgKmFiaV9yb3V0ZV9vbmxpbmVTdGFrZU9wICphYmlfcm91dGVfYWNjb3VudFBhcmFtcyAqYWJpX3JvdXRlX2Jsb2NrUGFyYW1zCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEx" } } \ No newline at end of file diff --git a/tests/contracts/artifacts/AccountTest.approval.teal b/tests/contracts/artifacts/AccountTest.approval.teal index 19c49483a..e816bd655 100644 --- a/tests/contracts/artifacts/AccountTest.approval.teal +++ b/tests/contracts/artifacts/AccountTest.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 intcblock 1 32 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/AccountTest.arc32.json b/tests/contracts/artifacts/AccountTest.arc32.json index 2891a7d86..5fb5d2411 100644 --- a/tests/contracts/artifacts/AccountTest.arc32.json +++ b/tests/contracts/artifacts/AccountTest.arc32.json @@ -114,7 +114,7 @@ } }, "source": { - "approval": "#pragma version 10
intcblock 1 32

// This TEAL was generated by TEALScript v0.104.1
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// hasAsset(address)void
*abi_route_hasAsset:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for hasAsset must be a address
	assert

	// execute hasAsset(address)void
	callsub hasAsset
	int 1
	return

// hasAsset(a: Address): void
hasAsset:
	proto 1 0

	// tests/contracts/account.algo.ts:6
	// assert(a.isOptedInToAsset(AssetID.fromUint64(123)))
	frame_dig -1 // a: Address
	pushint 123
	asset_holding_get AssetBalance
	swap
	pop
	assert
	retsub

// assetBalance(address)void
*abi_route_assetBalance:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for assetBalance must be a address
	assert

	// execute assetBalance(address)void
	callsub assetBalance
	int 1
	return

// assetBalance(a: Address): void
assetBalance:
	proto 1 0

	// tests/contracts/account.algo.ts:10
	// assert(a.assetBalance(AssetID.fromUint64(123)))
	frame_dig -1 // a: Address
	pushint 123
	asset_holding_get AssetBalance
	pop
	assert
	retsub

// assetFrozen(address)void
*abi_route_assetFrozen:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for assetFrozen must be a address
	assert

	// execute assetFrozen(address)void
	callsub assetFrozen
	int 1
	return

// assetFrozen(a: Address): void
assetFrozen:
	proto 1 0

	// tests/contracts/account.algo.ts:14
	// assert(a.assetFrozen(AssetID.fromUint64(123)))
	frame_dig -1 // a: Address
	pushint 123
	asset_holding_get AssetFrozen
	pop
	assert
	retsub

// hasBalance(address)void
*abi_route_hasBalance:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for hasBalance must be a address
	assert

	// execute hasBalance(address)void
	callsub hasBalance
	int 1
	return

// hasBalance(a: Address): void
hasBalance:
	proto 1 0

	// tests/contracts/account.algo.ts:18
	// assert(a.isInLedger)
	frame_dig -1 // a: Address
	acct_params_get AcctBalance
	swap
	pop
	assert
	retsub

// balance(address)void
*abi_route_balance:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for balance must be a address
	assert

	// execute balance(address)void
	callsub balance
	int 1
	return

// balance(a: Address): void
balance:
	proto 1 0

	// tests/contracts/account.algo.ts:22
	// assert(a.balance)
	frame_dig -1 // a: Address
	acct_params_get AcctBalance
	pop
	assert
	retsub

// minBalance(address)void
*abi_route_minBalance:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for minBalance must be a address
	assert

	// execute minBalance(address)void
	callsub minBalance
	int 1
	return

// minBalance(a: Address): void
minBalance:
	proto 1 0

	// tests/contracts/account.algo.ts:26
	// assert(a.minBalance)
	frame_dig -1 // a: Address
	acct_params_get AcctMinBalance
	pop
	assert
	retsub

// authAddr(address)void
*abi_route_authAddr:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for authAddr must be a address
	assert

	// execute authAddr(address)void
	callsub authAddr
	int 1
	return

// authAddr(a: Address): void
authAddr:
	proto 1 0

	// tests/contracts/account.algo.ts:30
	// log(a.authAddr)
	frame_dig -1 // a: Address
	acct_params_get AcctAuthAddr
	pop
	log
	retsub

// totalNumUint(address)void
*abi_route_totalNumUint:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for totalNumUint must be a address
	assert

	// execute totalNumUint(address)void
	callsub totalNumUint
	int 1
	return

// totalNumUint(a: Address): void
totalNumUint:
	proto 1 0

	// tests/contracts/account.algo.ts:34
	// assert(a.totalNumUint)
	frame_dig -1 // a: Address
	acct_params_get AcctTotalNumUint
	pop
	assert
	retsub

// totalNumByteSlice(address)void
*abi_route_totalNumByteSlice:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for totalNumByteSlice must be a address
	assert

	// execute totalNumByteSlice(address)void
	callsub totalNumByteSlice
	int 1
	return

// totalNumByteSlice(a: Address): void
totalNumByteSlice:
	proto 1 0

	// tests/contracts/account.algo.ts:38
	// assert(a.totalNumByteSlice)
	frame_dig -1 // a: Address
	acct_params_get AcctTotalNumByteSlice
	pop
	assert
	retsub

// totalExtraAppPages(address)void
*abi_route_totalExtraAppPages:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for totalExtraAppPages must be a address
	assert

	// execute totalExtraAppPages(address)void
	callsub totalExtraAppPages
	int 1
	return

// totalExtraAppPages(a: Address): void
totalExtraAppPages:
	proto 1 0

	// tests/contracts/account.algo.ts:42
	// assert(a.totalExtraAppPages)
	frame_dig -1 // a: Address
	acct_params_get AcctTotalExtraAppPages
	pop
	assert
	retsub

// totalAppsCreated(address)void
*abi_route_totalAppsCreated:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for totalAppsCreated must be a address
	assert

	// execute totalAppsCreated(address)void
	callsub totalAppsCreated
	int 1
	return

// totalAppsCreated(a: Address): void
totalAppsCreated:
	proto 1 0

	// tests/contracts/account.algo.ts:46
	// assert(a.totalAppsCreated)
	frame_dig -1 // a: Address
	acct_params_get AcctTotalAppsCreated
	pop
	assert
	retsub

// totalAppsOptedIn(address)void
*abi_route_totalAppsOptedIn:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for totalAppsOptedIn must be a address
	assert

	// execute totalAppsOptedIn(address)void
	callsub totalAppsOptedIn
	int 1
	return

// totalAppsOptedIn(a: Address): void
totalAppsOptedIn:
	proto 1 0

	// tests/contracts/account.algo.ts:50
	// assert(a.totalAppsOptedIn)
	frame_dig -1 // a: Address
	acct_params_get AcctTotalAppsOptedIn
	pop
	assert
	retsub

// totalAssetsCreated(address)void
*abi_route_totalAssetsCreated:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for totalAssetsCreated must be a address
	assert

	// execute totalAssetsCreated(address)void
	callsub totalAssetsCreated
	int 1
	return

// totalAssetsCreated(a: Address): void
totalAssetsCreated:
	proto 1 0

	// tests/contracts/account.algo.ts:54
	// assert(a.totalAssetsCreated)
	frame_dig -1 // a: Address
	acct_params_get AcctTotalAssetsCreated
	pop
	assert
	retsub

// totalAssets(address)void
*abi_route_totalAssets:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for totalAssets must be a address
	assert

	// execute totalAssets(address)void
	callsub totalAssets
	int 1
	return

// totalAssets(a: Address): void
totalAssets:
	proto 1 0

	// tests/contracts/account.algo.ts:58
	// assert(a.totalAssets)
	frame_dig -1 // a: Address
	acct_params_get AcctTotalAssets
	pop
	assert
	retsub

// totalBoxes(address)void
*abi_route_totalBoxes:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for totalBoxes must be a address
	assert

	// execute totalBoxes(address)void
	callsub totalBoxes
	int 1
	return

// totalBoxes(a: Address): void
totalBoxes:
	proto 1 0

	// tests/contracts/account.algo.ts:62
	// assert(a.totalBoxes)
	frame_dig -1 // a: Address
	acct_params_get AcctTotalBoxes
	pop
	assert
	retsub

// totalBoxBytes(address)void
*abi_route_totalBoxBytes:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for totalBoxBytes must be a address
	assert

	// execute totalBoxBytes(address)void
	callsub totalBoxBytes
	int 1
	return

// totalBoxBytes(a: Address): void
totalBoxBytes:
	proto 1 0

	// tests/contracts/account.algo.ts:66
	// assert(a.totalBoxBytes)
	frame_dig -1 // a: Address
	acct_params_get AcctTotalBoxBytes
	pop
	assert
	retsub

*abi_route_createApplication:
	int 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0xaa38ae91 // method "hasAsset(address)void"
	pushbytes 0x64cb0661 // method "assetBalance(address)void"
	pushbytes 0x68d18ddb // method "assetFrozen(address)void"
	pushbytes 0x2abf1ede // method "hasBalance(address)void"
	pushbytes 0x899e479d // method "balance(address)void"
	pushbytes 0x258a0fca // method "minBalance(address)void"
	pushbytes 0xbecc2183 // method "authAddr(address)void"
	pushbytes 0xfb81e109 // method "totalNumUint(address)void"
	pushbytes 0x44d215e1 // method "totalNumByteSlice(address)void"
	pushbytes 0x4b3bfef3 // method "totalExtraAppPages(address)void"
	pushbytes 0x091ad2aa // method "totalAppsCreated(address)void"
	pushbytes 0xb9bf3f95 // method "totalAppsOptedIn(address)void"
	pushbytes 0x4f8d2d2c // method "totalAssetsCreated(address)void"
	pushbytes 0x13d4a37d // method "totalAssets(address)void"
	pushbytes 0xfc8723da // method "totalBoxes(address)void"
	pushbytes 0xc4cc5e95 // method "totalBoxBytes(address)void"
	txna ApplicationArgs 0
	match *abi_route_hasAsset *abi_route_assetBalance *abi_route_assetFrozen *abi_route_hasBalance *abi_route_balance *abi_route_minBalance *abi_route_authAddr *abi_route_totalNumUint *abi_route_totalNumByteSlice *abi_route_totalExtraAppPages *abi_route_totalAppsCreated *abi_route_totalAppsOptedIn *abi_route_totalAssetsCreated *abi_route_totalAssets *abi_route_totalBoxes *abi_route_totalBoxBytes

	// this contract does not implement the given ABI method for call NoOp
	err", + "approval": "#pragma version 10
intcblock 1 32

// This TEAL was generated by TEALScript v0.105.0
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// hasAsset(address)void
*abi_route_hasAsset:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for hasAsset must be a address
	assert

	// execute hasAsset(address)void
	callsub hasAsset
	int 1
	return

// hasAsset(a: Address): void
hasAsset:
	proto 1 0

	// tests/contracts/account.algo.ts:6
	// assert(a.isOptedInToAsset(AssetID.fromUint64(123)))
	frame_dig -1 // a: Address
	pushint 123
	asset_holding_get AssetBalance
	swap
	pop
	assert
	retsub

// assetBalance(address)void
*abi_route_assetBalance:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for assetBalance must be a address
	assert

	// execute assetBalance(address)void
	callsub assetBalance
	int 1
	return

// assetBalance(a: Address): void
assetBalance:
	proto 1 0

	// tests/contracts/account.algo.ts:10
	// assert(a.assetBalance(AssetID.fromUint64(123)))
	frame_dig -1 // a: Address
	pushint 123
	asset_holding_get AssetBalance
	pop
	assert
	retsub

// assetFrozen(address)void
*abi_route_assetFrozen:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for assetFrozen must be a address
	assert

	// execute assetFrozen(address)void
	callsub assetFrozen
	int 1
	return

// assetFrozen(a: Address): void
assetFrozen:
	proto 1 0

	// tests/contracts/account.algo.ts:14
	// assert(a.assetFrozen(AssetID.fromUint64(123)))
	frame_dig -1 // a: Address
	pushint 123
	asset_holding_get AssetFrozen
	pop
	assert
	retsub

// hasBalance(address)void
*abi_route_hasBalance:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for hasBalance must be a address
	assert

	// execute hasBalance(address)void
	callsub hasBalance
	int 1
	return

// hasBalance(a: Address): void
hasBalance:
	proto 1 0

	// tests/contracts/account.algo.ts:18
	// assert(a.isInLedger)
	frame_dig -1 // a: Address
	acct_params_get AcctBalance
	swap
	pop
	assert
	retsub

// balance(address)void
*abi_route_balance:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for balance must be a address
	assert

	// execute balance(address)void
	callsub balance
	int 1
	return

// balance(a: Address): void
balance:
	proto 1 0

	// tests/contracts/account.algo.ts:22
	// assert(a.balance)
	frame_dig -1 // a: Address
	acct_params_get AcctBalance
	pop
	assert
	retsub

// minBalance(address)void
*abi_route_minBalance:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for minBalance must be a address
	assert

	// execute minBalance(address)void
	callsub minBalance
	int 1
	return

// minBalance(a: Address): void
minBalance:
	proto 1 0

	// tests/contracts/account.algo.ts:26
	// assert(a.minBalance)
	frame_dig -1 // a: Address
	acct_params_get AcctMinBalance
	pop
	assert
	retsub

// authAddr(address)void
*abi_route_authAddr:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for authAddr must be a address
	assert

	// execute authAddr(address)void
	callsub authAddr
	int 1
	return

// authAddr(a: Address): void
authAddr:
	proto 1 0

	// tests/contracts/account.algo.ts:30
	// log(a.authAddr)
	frame_dig -1 // a: Address
	acct_params_get AcctAuthAddr
	pop
	log
	retsub

// totalNumUint(address)void
*abi_route_totalNumUint:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for totalNumUint must be a address
	assert

	// execute totalNumUint(address)void
	callsub totalNumUint
	int 1
	return

// totalNumUint(a: Address): void
totalNumUint:
	proto 1 0

	// tests/contracts/account.algo.ts:34
	// assert(a.totalNumUint)
	frame_dig -1 // a: Address
	acct_params_get AcctTotalNumUint
	pop
	assert
	retsub

// totalNumByteSlice(address)void
*abi_route_totalNumByteSlice:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for totalNumByteSlice must be a address
	assert

	// execute totalNumByteSlice(address)void
	callsub totalNumByteSlice
	int 1
	return

// totalNumByteSlice(a: Address): void
totalNumByteSlice:
	proto 1 0

	// tests/contracts/account.algo.ts:38
	// assert(a.totalNumByteSlice)
	frame_dig -1 // a: Address
	acct_params_get AcctTotalNumByteSlice
	pop
	assert
	retsub

// totalExtraAppPages(address)void
*abi_route_totalExtraAppPages:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for totalExtraAppPages must be a address
	assert

	// execute totalExtraAppPages(address)void
	callsub totalExtraAppPages
	int 1
	return

// totalExtraAppPages(a: Address): void
totalExtraAppPages:
	proto 1 0

	// tests/contracts/account.algo.ts:42
	// assert(a.totalExtraAppPages)
	frame_dig -1 // a: Address
	acct_params_get AcctTotalExtraAppPages
	pop
	assert
	retsub

// totalAppsCreated(address)void
*abi_route_totalAppsCreated:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for totalAppsCreated must be a address
	assert

	// execute totalAppsCreated(address)void
	callsub totalAppsCreated
	int 1
	return

// totalAppsCreated(a: Address): void
totalAppsCreated:
	proto 1 0

	// tests/contracts/account.algo.ts:46
	// assert(a.totalAppsCreated)
	frame_dig -1 // a: Address
	acct_params_get AcctTotalAppsCreated
	pop
	assert
	retsub

// totalAppsOptedIn(address)void
*abi_route_totalAppsOptedIn:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for totalAppsOptedIn must be a address
	assert

	// execute totalAppsOptedIn(address)void
	callsub totalAppsOptedIn
	int 1
	return

// totalAppsOptedIn(a: Address): void
totalAppsOptedIn:
	proto 1 0

	// tests/contracts/account.algo.ts:50
	// assert(a.totalAppsOptedIn)
	frame_dig -1 // a: Address
	acct_params_get AcctTotalAppsOptedIn
	pop
	assert
	retsub

// totalAssetsCreated(address)void
*abi_route_totalAssetsCreated:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for totalAssetsCreated must be a address
	assert

	// execute totalAssetsCreated(address)void
	callsub totalAssetsCreated
	int 1
	return

// totalAssetsCreated(a: Address): void
totalAssetsCreated:
	proto 1 0

	// tests/contracts/account.algo.ts:54
	// assert(a.totalAssetsCreated)
	frame_dig -1 // a: Address
	acct_params_get AcctTotalAssetsCreated
	pop
	assert
	retsub

// totalAssets(address)void
*abi_route_totalAssets:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for totalAssets must be a address
	assert

	// execute totalAssets(address)void
	callsub totalAssets
	int 1
	return

// totalAssets(a: Address): void
totalAssets:
	proto 1 0

	// tests/contracts/account.algo.ts:58
	// assert(a.totalAssets)
	frame_dig -1 // a: Address
	acct_params_get AcctTotalAssets
	pop
	assert
	retsub

// totalBoxes(address)void
*abi_route_totalBoxes:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for totalBoxes must be a address
	assert

	// execute totalBoxes(address)void
	callsub totalBoxes
	int 1
	return

// totalBoxes(a: Address): void
totalBoxes:
	proto 1 0

	// tests/contracts/account.algo.ts:62
	// assert(a.totalBoxes)
	frame_dig -1 // a: Address
	acct_params_get AcctTotalBoxes
	pop
	assert
	retsub

// totalBoxBytes(address)void
*abi_route_totalBoxBytes:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for totalBoxBytes must be a address
	assert

	// execute totalBoxBytes(address)void
	callsub totalBoxBytes
	int 1
	return

// totalBoxBytes(a: Address): void
totalBoxBytes:
	proto 1 0

	// tests/contracts/account.algo.ts:66
	// assert(a.totalBoxBytes)
	frame_dig -1 // a: Address
	acct_params_get AcctTotalBoxBytes
	pop
	assert
	retsub

*abi_route_createApplication:
	int 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0xaa38ae91 // method "hasAsset(address)void"
	pushbytes 0x64cb0661 // method "assetBalance(address)void"
	pushbytes 0x68d18ddb // method "assetFrozen(address)void"
	pushbytes 0x2abf1ede // method "hasBalance(address)void"
	pushbytes 0x899e479d // method "balance(address)void"
	pushbytes 0x258a0fca // method "minBalance(address)void"
	pushbytes 0xbecc2183 // method "authAddr(address)void"
	pushbytes 0xfb81e109 // method "totalNumUint(address)void"
	pushbytes 0x44d215e1 // method "totalNumByteSlice(address)void"
	pushbytes 0x4b3bfef3 // method "totalExtraAppPages(address)void"
	pushbytes 0x091ad2aa // method "totalAppsCreated(address)void"
	pushbytes 0xb9bf3f95 // method "totalAppsOptedIn(address)void"
	pushbytes 0x4f8d2d2c // method "totalAssetsCreated(address)void"
	pushbytes 0x13d4a37d // method "totalAssets(address)void"
	pushbytes 0xfc8723da // method "totalBoxes(address)void"
	pushbytes 0xc4cc5e95 // method "totalBoxBytes(address)void"
	txna ApplicationArgs 0
	match *abi_route_hasAsset *abi_route_assetBalance *abi_route_assetFrozen *abi_route_hasBalance *abi_route_balance *abi_route_minBalance *abi_route_authAddr *abi_route_totalNumUint *abi_route_totalNumByteSlice *abi_route_totalExtraAppPages *abi_route_totalAppsCreated *abi_route_totalAppsOptedIn *abi_route_totalAssetsCreated *abi_route_totalAssets *abi_route_totalBoxes *abi_route_totalBoxBytes

	// this contract does not implement the given ABI method for call NoOp
	err", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/AccountTest.arc56_draft.json b/tests/contracts/artifacts/AccountTest.arc56_draft.json index f345e6539..4bbcdd6ed 100644 --- a/tests/contracts/artifacts/AccountTest.arc56_draft.json +++ b/tests/contracts/artifacts/AccountTest.arc56_draft.json @@ -2646,7 +2646,7 @@ } }, "source": { - "approval": "#pragma version 10
intcblock 1 32

// This TEAL was generated by TEALScript v0.104.1
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// hasAsset(address)void
*abi_route_hasAsset:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for hasAsset must be a address
	assert

	// execute hasAsset(address)void
	callsub hasAsset
	int 1
	return

// hasAsset(a: Address): void
hasAsset:
	proto 1 0

	// tests/contracts/account.algo.ts:6
	// assert(a.isOptedInToAsset(AssetID.fromUint64(123)))
	frame_dig -1 // a: Address
	pushint 123
	asset_holding_get AssetBalance
	swap
	pop
	assert
	retsub

// assetBalance(address)void
*abi_route_assetBalance:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for assetBalance must be a address
	assert

	// execute assetBalance(address)void
	callsub assetBalance
	int 1
	return

// assetBalance(a: Address): void
assetBalance:
	proto 1 0

	// tests/contracts/account.algo.ts:10
	// assert(a.assetBalance(AssetID.fromUint64(123)))
	frame_dig -1 // a: Address
	pushint 123
	asset_holding_get AssetBalance
	pop
	assert
	retsub

// assetFrozen(address)void
*abi_route_assetFrozen:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for assetFrozen must be a address
	assert

	// execute assetFrozen(address)void
	callsub assetFrozen
	int 1
	return

// assetFrozen(a: Address): void
assetFrozen:
	proto 1 0

	// tests/contracts/account.algo.ts:14
	// assert(a.assetFrozen(AssetID.fromUint64(123)))
	frame_dig -1 // a: Address
	pushint 123
	asset_holding_get AssetFrozen
	pop
	assert
	retsub

// hasBalance(address)void
*abi_route_hasBalance:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for hasBalance must be a address
	assert

	// execute hasBalance(address)void
	callsub hasBalance
	int 1
	return

// hasBalance(a: Address): void
hasBalance:
	proto 1 0

	// tests/contracts/account.algo.ts:18
	// assert(a.isInLedger)
	frame_dig -1 // a: Address
	acct_params_get AcctBalance
	swap
	pop
	assert
	retsub

// balance(address)void
*abi_route_balance:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for balance must be a address
	assert

	// execute balance(address)void
	callsub balance
	int 1
	return

// balance(a: Address): void
balance:
	proto 1 0

	// tests/contracts/account.algo.ts:22
	// assert(a.balance)
	frame_dig -1 // a: Address
	acct_params_get AcctBalance
	pop
	assert
	retsub

// minBalance(address)void
*abi_route_minBalance:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for minBalance must be a address
	assert

	// execute minBalance(address)void
	callsub minBalance
	int 1
	return

// minBalance(a: Address): void
minBalance:
	proto 1 0

	// tests/contracts/account.algo.ts:26
	// assert(a.minBalance)
	frame_dig -1 // a: Address
	acct_params_get AcctMinBalance
	pop
	assert
	retsub

// authAddr(address)void
*abi_route_authAddr:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for authAddr must be a address
	assert

	// execute authAddr(address)void
	callsub authAddr
	int 1
	return

// authAddr(a: Address): void
authAddr:
	proto 1 0

	// tests/contracts/account.algo.ts:30
	// log(a.authAddr)
	frame_dig -1 // a: Address
	acct_params_get AcctAuthAddr
	pop
	log
	retsub

// totalNumUint(address)void
*abi_route_totalNumUint:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for totalNumUint must be a address
	assert

	// execute totalNumUint(address)void
	callsub totalNumUint
	int 1
	return

// totalNumUint(a: Address): void
totalNumUint:
	proto 1 0

	// tests/contracts/account.algo.ts:34
	// assert(a.totalNumUint)
	frame_dig -1 // a: Address
	acct_params_get AcctTotalNumUint
	pop
	assert
	retsub

// totalNumByteSlice(address)void
*abi_route_totalNumByteSlice:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for totalNumByteSlice must be a address
	assert

	// execute totalNumByteSlice(address)void
	callsub totalNumByteSlice
	int 1
	return

// totalNumByteSlice(a: Address): void
totalNumByteSlice:
	proto 1 0

	// tests/contracts/account.algo.ts:38
	// assert(a.totalNumByteSlice)
	frame_dig -1 // a: Address
	acct_params_get AcctTotalNumByteSlice
	pop
	assert
	retsub

// totalExtraAppPages(address)void
*abi_route_totalExtraAppPages:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for totalExtraAppPages must be a address
	assert

	// execute totalExtraAppPages(address)void
	callsub totalExtraAppPages
	int 1
	return

// totalExtraAppPages(a: Address): void
totalExtraAppPages:
	proto 1 0

	// tests/contracts/account.algo.ts:42
	// assert(a.totalExtraAppPages)
	frame_dig -1 // a: Address
	acct_params_get AcctTotalExtraAppPages
	pop
	assert
	retsub

// totalAppsCreated(address)void
*abi_route_totalAppsCreated:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for totalAppsCreated must be a address
	assert

	// execute totalAppsCreated(address)void
	callsub totalAppsCreated
	int 1
	return

// totalAppsCreated(a: Address): void
totalAppsCreated:
	proto 1 0

	// tests/contracts/account.algo.ts:46
	// assert(a.totalAppsCreated)
	frame_dig -1 // a: Address
	acct_params_get AcctTotalAppsCreated
	pop
	assert
	retsub

// totalAppsOptedIn(address)void
*abi_route_totalAppsOptedIn:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for totalAppsOptedIn must be a address
	assert

	// execute totalAppsOptedIn(address)void
	callsub totalAppsOptedIn
	int 1
	return

// totalAppsOptedIn(a: Address): void
totalAppsOptedIn:
	proto 1 0

	// tests/contracts/account.algo.ts:50
	// assert(a.totalAppsOptedIn)
	frame_dig -1 // a: Address
	acct_params_get AcctTotalAppsOptedIn
	pop
	assert
	retsub

// totalAssetsCreated(address)void
*abi_route_totalAssetsCreated:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for totalAssetsCreated must be a address
	assert

	// execute totalAssetsCreated(address)void
	callsub totalAssetsCreated
	int 1
	return

// totalAssetsCreated(a: Address): void
totalAssetsCreated:
	proto 1 0

	// tests/contracts/account.algo.ts:54
	// assert(a.totalAssetsCreated)
	frame_dig -1 // a: Address
	acct_params_get AcctTotalAssetsCreated
	pop
	assert
	retsub

// totalAssets(address)void
*abi_route_totalAssets:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for totalAssets must be a address
	assert

	// execute totalAssets(address)void
	callsub totalAssets
	int 1
	return

// totalAssets(a: Address): void
totalAssets:
	proto 1 0

	// tests/contracts/account.algo.ts:58
	// assert(a.totalAssets)
	frame_dig -1 // a: Address
	acct_params_get AcctTotalAssets
	pop
	assert
	retsub

// totalBoxes(address)void
*abi_route_totalBoxes:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for totalBoxes must be a address
	assert

	// execute totalBoxes(address)void
	callsub totalBoxes
	int 1
	return

// totalBoxes(a: Address): void
totalBoxes:
	proto 1 0

	// tests/contracts/account.algo.ts:62
	// assert(a.totalBoxes)
	frame_dig -1 // a: Address
	acct_params_get AcctTotalBoxes
	pop
	assert
	retsub

// totalBoxBytes(address)void
*abi_route_totalBoxBytes:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for totalBoxBytes must be a address
	assert

	// execute totalBoxBytes(address)void
	callsub totalBoxBytes
	int 1
	return

// totalBoxBytes(a: Address): void
totalBoxBytes:
	proto 1 0

	// tests/contracts/account.algo.ts:66
	// assert(a.totalBoxBytes)
	frame_dig -1 // a: Address
	acct_params_get AcctTotalBoxBytes
	pop
	assert
	retsub

*abi_route_createApplication:
	int 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0xaa38ae91 // method "hasAsset(address)void"
	pushbytes 0x64cb0661 // method "assetBalance(address)void"
	pushbytes 0x68d18ddb // method "assetFrozen(address)void"
	pushbytes 0x2abf1ede // method "hasBalance(address)void"
	pushbytes 0x899e479d // method "balance(address)void"
	pushbytes 0x258a0fca // method "minBalance(address)void"
	pushbytes 0xbecc2183 // method "authAddr(address)void"
	pushbytes 0xfb81e109 // method "totalNumUint(address)void"
	pushbytes 0x44d215e1 // method "totalNumByteSlice(address)void"
	pushbytes 0x4b3bfef3 // method "totalExtraAppPages(address)void"
	pushbytes 0x091ad2aa // method "totalAppsCreated(address)void"
	pushbytes 0xb9bf3f95 // method "totalAppsOptedIn(address)void"
	pushbytes 0x4f8d2d2c // method "totalAssetsCreated(address)void"
	pushbytes 0x13d4a37d // method "totalAssets(address)void"
	pushbytes 0xfc8723da // method "totalBoxes(address)void"
	pushbytes 0xc4cc5e95 // method "totalBoxBytes(address)void"
	txna ApplicationArgs 0
	match *abi_route_hasAsset *abi_route_assetBalance *abi_route_assetFrozen *abi_route_hasBalance *abi_route_balance *abi_route_minBalance *abi_route_authAddr *abi_route_totalNumUint *abi_route_totalNumByteSlice *abi_route_totalExtraAppPages *abi_route_totalAppsCreated *abi_route_totalAppsOptedIn *abi_route_totalAssetsCreated *abi_route_totalAssets *abi_route_totalBoxes *abi_route_totalBoxBytes

	// this contract does not implement the given ABI method for call NoOp
	err", + "approval": "#pragma version 10
intcblock 1 32

// This TEAL was generated by TEALScript v0.105.0
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// hasAsset(address)void
*abi_route_hasAsset:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for hasAsset must be a address
	assert

	// execute hasAsset(address)void
	callsub hasAsset
	int 1
	return

// hasAsset(a: Address): void
hasAsset:
	proto 1 0

	// tests/contracts/account.algo.ts:6
	// assert(a.isOptedInToAsset(AssetID.fromUint64(123)))
	frame_dig -1 // a: Address
	pushint 123
	asset_holding_get AssetBalance
	swap
	pop
	assert
	retsub

// assetBalance(address)void
*abi_route_assetBalance:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for assetBalance must be a address
	assert

	// execute assetBalance(address)void
	callsub assetBalance
	int 1
	return

// assetBalance(a: Address): void
assetBalance:
	proto 1 0

	// tests/contracts/account.algo.ts:10
	// assert(a.assetBalance(AssetID.fromUint64(123)))
	frame_dig -1 // a: Address
	pushint 123
	asset_holding_get AssetBalance
	pop
	assert
	retsub

// assetFrozen(address)void
*abi_route_assetFrozen:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for assetFrozen must be a address
	assert

	// execute assetFrozen(address)void
	callsub assetFrozen
	int 1
	return

// assetFrozen(a: Address): void
assetFrozen:
	proto 1 0

	// tests/contracts/account.algo.ts:14
	// assert(a.assetFrozen(AssetID.fromUint64(123)))
	frame_dig -1 // a: Address
	pushint 123
	asset_holding_get AssetFrozen
	pop
	assert
	retsub

// hasBalance(address)void
*abi_route_hasBalance:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for hasBalance must be a address
	assert

	// execute hasBalance(address)void
	callsub hasBalance
	int 1
	return

// hasBalance(a: Address): void
hasBalance:
	proto 1 0

	// tests/contracts/account.algo.ts:18
	// assert(a.isInLedger)
	frame_dig -1 // a: Address
	acct_params_get AcctBalance
	swap
	pop
	assert
	retsub

// balance(address)void
*abi_route_balance:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for balance must be a address
	assert

	// execute balance(address)void
	callsub balance
	int 1
	return

// balance(a: Address): void
balance:
	proto 1 0

	// tests/contracts/account.algo.ts:22
	// assert(a.balance)
	frame_dig -1 // a: Address
	acct_params_get AcctBalance
	pop
	assert
	retsub

// minBalance(address)void
*abi_route_minBalance:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for minBalance must be a address
	assert

	// execute minBalance(address)void
	callsub minBalance
	int 1
	return

// minBalance(a: Address): void
minBalance:
	proto 1 0

	// tests/contracts/account.algo.ts:26
	// assert(a.minBalance)
	frame_dig -1 // a: Address
	acct_params_get AcctMinBalance
	pop
	assert
	retsub

// authAddr(address)void
*abi_route_authAddr:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for authAddr must be a address
	assert

	// execute authAddr(address)void
	callsub authAddr
	int 1
	return

// authAddr(a: Address): void
authAddr:
	proto 1 0

	// tests/contracts/account.algo.ts:30
	// log(a.authAddr)
	frame_dig -1 // a: Address
	acct_params_get AcctAuthAddr
	pop
	log
	retsub

// totalNumUint(address)void
*abi_route_totalNumUint:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for totalNumUint must be a address
	assert

	// execute totalNumUint(address)void
	callsub totalNumUint
	int 1
	return

// totalNumUint(a: Address): void
totalNumUint:
	proto 1 0

	// tests/contracts/account.algo.ts:34
	// assert(a.totalNumUint)
	frame_dig -1 // a: Address
	acct_params_get AcctTotalNumUint
	pop
	assert
	retsub

// totalNumByteSlice(address)void
*abi_route_totalNumByteSlice:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for totalNumByteSlice must be a address
	assert

	// execute totalNumByteSlice(address)void
	callsub totalNumByteSlice
	int 1
	return

// totalNumByteSlice(a: Address): void
totalNumByteSlice:
	proto 1 0

	// tests/contracts/account.algo.ts:38
	// assert(a.totalNumByteSlice)
	frame_dig -1 // a: Address
	acct_params_get AcctTotalNumByteSlice
	pop
	assert
	retsub

// totalExtraAppPages(address)void
*abi_route_totalExtraAppPages:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for totalExtraAppPages must be a address
	assert

	// execute totalExtraAppPages(address)void
	callsub totalExtraAppPages
	int 1
	return

// totalExtraAppPages(a: Address): void
totalExtraAppPages:
	proto 1 0

	// tests/contracts/account.algo.ts:42
	// assert(a.totalExtraAppPages)
	frame_dig -1 // a: Address
	acct_params_get AcctTotalExtraAppPages
	pop
	assert
	retsub

// totalAppsCreated(address)void
*abi_route_totalAppsCreated:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for totalAppsCreated must be a address
	assert

	// execute totalAppsCreated(address)void
	callsub totalAppsCreated
	int 1
	return

// totalAppsCreated(a: Address): void
totalAppsCreated:
	proto 1 0

	// tests/contracts/account.algo.ts:46
	// assert(a.totalAppsCreated)
	frame_dig -1 // a: Address
	acct_params_get AcctTotalAppsCreated
	pop
	assert
	retsub

// totalAppsOptedIn(address)void
*abi_route_totalAppsOptedIn:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for totalAppsOptedIn must be a address
	assert

	// execute totalAppsOptedIn(address)void
	callsub totalAppsOptedIn
	int 1
	return

// totalAppsOptedIn(a: Address): void
totalAppsOptedIn:
	proto 1 0

	// tests/contracts/account.algo.ts:50
	// assert(a.totalAppsOptedIn)
	frame_dig -1 // a: Address
	acct_params_get AcctTotalAppsOptedIn
	pop
	assert
	retsub

// totalAssetsCreated(address)void
*abi_route_totalAssetsCreated:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for totalAssetsCreated must be a address
	assert

	// execute totalAssetsCreated(address)void
	callsub totalAssetsCreated
	int 1
	return

// totalAssetsCreated(a: Address): void
totalAssetsCreated:
	proto 1 0

	// tests/contracts/account.algo.ts:54
	// assert(a.totalAssetsCreated)
	frame_dig -1 // a: Address
	acct_params_get AcctTotalAssetsCreated
	pop
	assert
	retsub

// totalAssets(address)void
*abi_route_totalAssets:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for totalAssets must be a address
	assert

	// execute totalAssets(address)void
	callsub totalAssets
	int 1
	return

// totalAssets(a: Address): void
totalAssets:
	proto 1 0

	// tests/contracts/account.algo.ts:58
	// assert(a.totalAssets)
	frame_dig -1 // a: Address
	acct_params_get AcctTotalAssets
	pop
	assert
	retsub

// totalBoxes(address)void
*abi_route_totalBoxes:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for totalBoxes must be a address
	assert

	// execute totalBoxes(address)void
	callsub totalBoxes
	int 1
	return

// totalBoxes(a: Address): void
totalBoxes:
	proto 1 0

	// tests/contracts/account.algo.ts:62
	// assert(a.totalBoxes)
	frame_dig -1 // a: Address
	acct_params_get AcctTotalBoxes
	pop
	assert
	retsub

// totalBoxBytes(address)void
*abi_route_totalBoxBytes:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for totalBoxBytes must be a address
	assert

	// execute totalBoxBytes(address)void
	callsub totalBoxBytes
	int 1
	return

// totalBoxBytes(a: Address): void
totalBoxBytes:
	proto 1 0

	// tests/contracts/account.algo.ts:66
	// assert(a.totalBoxBytes)
	frame_dig -1 // a: Address
	acct_params_get AcctTotalBoxBytes
	pop
	assert
	retsub

*abi_route_createApplication:
	int 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0xaa38ae91 // method "hasAsset(address)void"
	pushbytes 0x64cb0661 // method "assetBalance(address)void"
	pushbytes 0x68d18ddb // method "assetFrozen(address)void"
	pushbytes 0x2abf1ede // method "hasBalance(address)void"
	pushbytes 0x899e479d // method "balance(address)void"
	pushbytes 0x258a0fca // method "minBalance(address)void"
	pushbytes 0xbecc2183 // method "authAddr(address)void"
	pushbytes 0xfb81e109 // method "totalNumUint(address)void"
	pushbytes 0x44d215e1 // method "totalNumByteSlice(address)void"
	pushbytes 0x4b3bfef3 // method "totalExtraAppPages(address)void"
	pushbytes 0x091ad2aa // method "totalAppsCreated(address)void"
	pushbytes 0xb9bf3f95 // method "totalAppsOptedIn(address)void"
	pushbytes 0x4f8d2d2c // method "totalAssetsCreated(address)void"
	pushbytes 0x13d4a37d // method "totalAssets(address)void"
	pushbytes 0xfc8723da // method "totalBoxes(address)void"
	pushbytes 0xc4cc5e95 // method "totalBoxBytes(address)void"
	txna ApplicationArgs 0
	match *abi_route_hasAsset *abi_route_assetBalance *abi_route_assetFrozen *abi_route_hasBalance *abi_route_balance *abi_route_minBalance *abi_route_authAddr *abi_route_totalNumUint *abi_route_totalNumByteSlice *abi_route_totalExtraAppPages *abi_route_totalAppsCreated *abi_route_totalAppsOptedIn *abi_route_totalAssetsCreated *abi_route_totalAssets *abi_route_totalBoxes *abi_route_totalBoxBytes

	// this contract does not implement the given ABI method for call NoOp
	err", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/B.approval.teal b/tests/contracts/artifacts/B.approval.teal index 82a2c0c0f..a2b577c44 100644 --- a/tests/contracts/artifacts/B.approval.teal +++ b/tests/contracts/artifacts/B.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x61 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/B.arc32.json b/tests/contracts/artifacts/B.arc32.json index ed15ae93e..c078e083d 100644 --- a/tests/contracts/artifacts/B.arc32.json +++ b/tests/contracts/artifacts/B.arc32.json @@ -53,7 +53,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2MQoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDQuMQovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIGEoKXZvaWQKKmFiaV9yb3V0ZV9hOgoJLy8gZXhlY3V0ZSBhKCl2b2lkCgljYWxsc3ViIGEKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBhKCk6IHZvaWQKYToKCXByb3RvIDAgMAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS5hbGdvLnRzOjE2CgkvLyB0aGlzLmFLZXkudmFsdWUgPSAxMzM3CglieXRlIDB4NjEgLy8gImEiCglwdXNoaW50IDEzMzcKCWFwcF9nbG9iYWxfcHV0CglyZXRzdWIKCi8vIGIoKXZvaWQKKmFiaV9yb3V0ZV9iOgoJLy8gZXhlY3V0ZSBiKCl2b2lkCgljYWxsc3ViIGIKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBiKCk6IHZvaWQKYjoKCXByb3RvIDAgMAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS5hbGdvLnRzOjI0CgkvLyBhc3NlcnQodGhpcy5hS2V5LnZhbHVlID09PSAxMzM3KQoJYnl0ZSAweDYxIC8vICJhIgoJYXBwX2dsb2JhbF9nZXQKCXB1c2hpbnQgMTMzNwoJPT0KCWFzc2VydAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS5hbGdvLnRzOjI1CgkvLyB0aGlzLmJLZXkudmFsdWUgPSA0MgoJcHVzaGJ5dGVzIDB4NjIgLy8gImIiCglwdXNoaW50IDQyCglhcHBfZ2xvYmFsX3B1dAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgxZTdhYWQxYyAvLyBtZXRob2QgImEoKXZvaWQiCglwdXNoYnl0ZXMgMHgzYWM5MGIwOCAvLyBtZXRob2QgImIoKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2EgKmFiaV9yb3V0ZV9iCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2MQoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDUuMAovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIGEoKXZvaWQKKmFiaV9yb3V0ZV9hOgoJLy8gZXhlY3V0ZSBhKCl2b2lkCgljYWxsc3ViIGEKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBhKCk6IHZvaWQKYToKCXByb3RvIDAgMAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS5hbGdvLnRzOjE2CgkvLyB0aGlzLmFLZXkudmFsdWUgPSAxMzM3CglieXRlIDB4NjEgLy8gImEiCglwdXNoaW50IDEzMzcKCWFwcF9nbG9iYWxfcHV0CglyZXRzdWIKCi8vIGIoKXZvaWQKKmFiaV9yb3V0ZV9iOgoJLy8gZXhlY3V0ZSBiKCl2b2lkCgljYWxsc3ViIGIKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBiKCk6IHZvaWQKYjoKCXByb3RvIDAgMAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS5hbGdvLnRzOjI0CgkvLyBhc3NlcnQodGhpcy5hS2V5LnZhbHVlID09PSAxMzM3KQoJYnl0ZSAweDYxIC8vICJhIgoJYXBwX2dsb2JhbF9nZXQKCXB1c2hpbnQgMTMzNwoJPT0KCWFzc2VydAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS5hbGdvLnRzOjI1CgkvLyB0aGlzLmJLZXkudmFsdWUgPSA0MgoJcHVzaGJ5dGVzIDB4NjIgLy8gImIiCglwdXNoaW50IDQyCglhcHBfZ2xvYmFsX3B1dAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgxZTdhYWQxYyAvLyBtZXRob2QgImEoKXZvaWQiCglwdXNoYnl0ZXMgMHgzYWM5MGIwOCAvLyBtZXRob2QgImIoKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2EgKmFiaV9yb3V0ZV9iCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/B.arc56_draft.json b/tests/contracts/artifacts/B.arc56_draft.json index 104a4cbca..1f122beaf 100644 --- a/tests/contracts/artifacts/B.arc56_draft.json +++ b/tests/contracts/artifacts/B.arc56_draft.json @@ -473,7 +473,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2MQoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDQuMQovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIGEoKXZvaWQKKmFiaV9yb3V0ZV9hOgoJLy8gZXhlY3V0ZSBhKCl2b2lkCgljYWxsc3ViIGEKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBhKCk6IHZvaWQKYToKCXByb3RvIDAgMAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS5hbGdvLnRzOjE2CgkvLyB0aGlzLmFLZXkudmFsdWUgPSAxMzM3CglieXRlIDB4NjEgLy8gImEiCglwdXNoaW50IDEzMzcKCWFwcF9nbG9iYWxfcHV0CglyZXRzdWIKCi8vIGIoKXZvaWQKKmFiaV9yb3V0ZV9iOgoJLy8gZXhlY3V0ZSBiKCl2b2lkCgljYWxsc3ViIGIKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBiKCk6IHZvaWQKYjoKCXByb3RvIDAgMAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS5hbGdvLnRzOjI0CgkvLyBhc3NlcnQodGhpcy5hS2V5LnZhbHVlID09PSAxMzM3KQoJYnl0ZSAweDYxIC8vICJhIgoJYXBwX2dsb2JhbF9nZXQKCXB1c2hpbnQgMTMzNwoJPT0KCWFzc2VydAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS5hbGdvLnRzOjI1CgkvLyB0aGlzLmJLZXkudmFsdWUgPSA0MgoJcHVzaGJ5dGVzIDB4NjIgLy8gImIiCglwdXNoaW50IDQyCglhcHBfZ2xvYmFsX3B1dAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgxZTdhYWQxYyAvLyBtZXRob2QgImEoKXZvaWQiCglwdXNoYnl0ZXMgMHgzYWM5MGIwOCAvLyBtZXRob2QgImIoKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2EgKmFiaV9yb3V0ZV9iCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2MQoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDUuMAovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIGEoKXZvaWQKKmFiaV9yb3V0ZV9hOgoJLy8gZXhlY3V0ZSBhKCl2b2lkCgljYWxsc3ViIGEKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBhKCk6IHZvaWQKYToKCXByb3RvIDAgMAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS5hbGdvLnRzOjE2CgkvLyB0aGlzLmFLZXkudmFsdWUgPSAxMzM3CglieXRlIDB4NjEgLy8gImEiCglwdXNoaW50IDEzMzcKCWFwcF9nbG9iYWxfcHV0CglyZXRzdWIKCi8vIGIoKXZvaWQKKmFiaV9yb3V0ZV9iOgoJLy8gZXhlY3V0ZSBiKCl2b2lkCgljYWxsc3ViIGIKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBiKCk6IHZvaWQKYjoKCXByb3RvIDAgMAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS5hbGdvLnRzOjI0CgkvLyBhc3NlcnQodGhpcy5hS2V5LnZhbHVlID09PSAxMzM3KQoJYnl0ZSAweDYxIC8vICJhIgoJYXBwX2dsb2JhbF9nZXQKCXB1c2hpbnQgMTMzNwoJPT0KCWFzc2VydAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS5hbGdvLnRzOjI1CgkvLyB0aGlzLmJLZXkudmFsdWUgPSA0MgoJcHVzaGJ5dGVzIDB4NjIgLy8gImIiCglwdXNoaW50IDQyCglhcHBfZ2xvYmFsX3B1dAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgxZTdhYWQxYyAvLyBtZXRob2QgImEoKXZvaWQiCglwdXNoYnl0ZXMgMHgzYWM5MGIwOCAvLyBtZXRob2QgImIoKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2EgKmFiaV9yb3V0ZV9iCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/B2.approval.teal b/tests/contracts/artifacts/B2.approval.teal index 768b8f980..5ec4a0813 100644 --- a/tests/contracts/artifacts/B2.approval.teal +++ b/tests/contracts/artifacts/B2.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/B2.arc32.json b/tests/contracts/artifacts/B2.arc32.json index e76698149..179682fc0 100644 --- a/tests/contracts/artifacts/B2.arc32.json +++ b/tests/contracts/artifacts/B2.arc32.json @@ -49,7 +49,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYSgpdm9pZAoqYWJpX3JvdXRlX2E6CgkvLyBleGVjdXRlIGEoKXZvaWQKCWNhbGxzdWIgYQoJcHVzaGludCAxCglyZXR1cm4KCi8vIGEoKTogdm9pZAphOgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6MTYKCS8vIHRoaXMuYUtleS52YWx1ZSA9IDEzMzcKCXB1c2hieXRlcyAweDYxIC8vICJhIgoJcHVzaGludCAxMzM3CglhcHBfZ2xvYmFsX3B1dAoJcmV0c3ViCgovLyBiMigpdm9pZAoqYWJpX3JvdXRlX2IyOgoJLy8gZXhlY3V0ZSBiMigpdm9pZAoJY2FsbHN1YiBiMgoJcHVzaGludCAxCglyZXR1cm4KCi8vIGIyKCk6IHZvaWQKYjI6Cglwcm90byAwIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czo4OAoJLy8gbG9nKCdiMicpCglwdXNoYnl0ZXMgMHg2MjMyIC8vICJiMiIKCWxvZwoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgxZTdhYWQxYyAvLyBtZXRob2QgImEoKXZvaWQiCglwdXNoYnl0ZXMgMHg0NDNiMzMxOSAvLyBtZXRob2QgImIyKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9hICphYmlfcm91dGVfYjIKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYSgpdm9pZAoqYWJpX3JvdXRlX2E6CgkvLyBleGVjdXRlIGEoKXZvaWQKCWNhbGxzdWIgYQoJcHVzaGludCAxCglyZXR1cm4KCi8vIGEoKTogdm9pZAphOgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6MTYKCS8vIHRoaXMuYUtleS52YWx1ZSA9IDEzMzcKCXB1c2hieXRlcyAweDYxIC8vICJhIgoJcHVzaGludCAxMzM3CglhcHBfZ2xvYmFsX3B1dAoJcmV0c3ViCgovLyBiMigpdm9pZAoqYWJpX3JvdXRlX2IyOgoJLy8gZXhlY3V0ZSBiMigpdm9pZAoJY2FsbHN1YiBiMgoJcHVzaGludCAxCglyZXR1cm4KCi8vIGIyKCk6IHZvaWQKYjI6Cglwcm90byAwIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czo4OAoJLy8gbG9nKCdiMicpCglwdXNoYnl0ZXMgMHg2MjMyIC8vICJiMiIKCWxvZwoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgxZTdhYWQxYyAvLyBtZXRob2QgImEoKXZvaWQiCglwdXNoYnl0ZXMgMHg0NDNiMzMxOSAvLyBtZXRob2QgImIyKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9hICphYmlfcm91dGVfYjIKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/B2.arc56_draft.json b/tests/contracts/artifacts/B2.arc56_draft.json index d2397ca2f..e8885606c 100644 --- a/tests/contracts/artifacts/B2.arc56_draft.json +++ b/tests/contracts/artifacts/B2.arc56_draft.json @@ -412,7 +412,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYSgpdm9pZAoqYWJpX3JvdXRlX2E6CgkvLyBleGVjdXRlIGEoKXZvaWQKCWNhbGxzdWIgYQoJcHVzaGludCAxCglyZXR1cm4KCi8vIGEoKTogdm9pZAphOgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6MTYKCS8vIHRoaXMuYUtleS52YWx1ZSA9IDEzMzcKCXB1c2hieXRlcyAweDYxIC8vICJhIgoJcHVzaGludCAxMzM3CglhcHBfZ2xvYmFsX3B1dAoJcmV0c3ViCgovLyBiMigpdm9pZAoqYWJpX3JvdXRlX2IyOgoJLy8gZXhlY3V0ZSBiMigpdm9pZAoJY2FsbHN1YiBiMgoJcHVzaGludCAxCglyZXR1cm4KCi8vIGIyKCk6IHZvaWQKYjI6Cglwcm90byAwIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czo4OAoJLy8gbG9nKCdiMicpCglwdXNoYnl0ZXMgMHg2MjMyIC8vICJiMiIKCWxvZwoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgxZTdhYWQxYyAvLyBtZXRob2QgImEoKXZvaWQiCglwdXNoYnl0ZXMgMHg0NDNiMzMxOSAvLyBtZXRob2QgImIyKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9hICphYmlfcm91dGVfYjIKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYSgpdm9pZAoqYWJpX3JvdXRlX2E6CgkvLyBleGVjdXRlIGEoKXZvaWQKCWNhbGxzdWIgYQoJcHVzaGludCAxCglyZXR1cm4KCi8vIGEoKTogdm9pZAphOgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6MTYKCS8vIHRoaXMuYUtleS52YWx1ZSA9IDEzMzcKCXB1c2hieXRlcyAweDYxIC8vICJhIgoJcHVzaGludCAxMzM3CglhcHBfZ2xvYmFsX3B1dAoJcmV0c3ViCgovLyBiMigpdm9pZAoqYWJpX3JvdXRlX2IyOgoJLy8gZXhlY3V0ZSBiMigpdm9pZAoJY2FsbHN1YiBiMgoJcHVzaGludCAxCglyZXR1cm4KCi8vIGIyKCk6IHZvaWQKYjI6Cglwcm90byAwIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czo4OAoJLy8gbG9nKCdiMicpCglwdXNoYnl0ZXMgMHg2MjMyIC8vICJiMiIKCWxvZwoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgxZTdhYWQxYyAvLyBtZXRob2QgImEoKXZvaWQiCglwdXNoYnl0ZXMgMHg0NDNiMzMxOSAvLyBtZXRob2QgImIyKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9hICphYmlfcm91dGVfYjIKCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/BasicLsig.lsig.teal b/tests/contracts/artifacts/BasicLsig.lsig.teal index 2123a0f81..ce8dcdc9a 100644 --- a/tests/contracts/artifacts/BasicLsig.lsig.teal +++ b/tests/contracts/artifacts/BasicLsig.lsig.teal @@ -1,7 +1,7 @@ #pragma version 10 //#pragma mode logicsig -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // The address of this logic signature is 7KLVRXGH54EKIGFYDYG7ZE7D62M4MGRW5XA25HOKTVM27YKDKGFOEEFBAU diff --git a/tests/contracts/artifacts/BinaryTest.approval.teal b/tests/contracts/artifacts/BinaryTest.approval.teal index db918b8ba..f9040a144 100644 --- a/tests/contracts/artifacts/BinaryTest.approval.teal +++ b/tests/contracts/artifacts/BinaryTest.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 intcblock 1 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/BinaryTest.arc32.json b/tests/contracts/artifacts/BinaryTest.arc32.json index 6f7223c20..291c683db 100644 --- a/tests/contracts/artifacts/BinaryTest.arc32.json +++ b/tests/contracts/artifacts/BinaryTest.arc32.json @@ -74,7 +74,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmludGNibG9jayAxCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYW5kKHVpbnQ2NCx1aW50NjQpdm9pZAoqYWJpX3JvdXRlX2FuZDoKCS8vIGI6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMgoJYnRvaQoKCS8vIGE6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJYnRvaQoKCS8vIGV4ZWN1dGUgYW5kKHVpbnQ2NCx1aW50NjQpdm9pZAoJY2FsbHN1YiBhbmQKCWludCAxCglyZXR1cm4KCi8vIGFuZChhOiB1aW50NjQsIGI6IHVpbnQ2NCk6IHZvaWQKYW5kOgoJcHJvdG8gMiAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2JpbmFyeS5hbGdvLnRzOjYKCS8vIGFzc2VydChhICYmIGIpCglmcmFtZV9kaWcgLTEgLy8gYTogdWludDY0CglkdXAKCWJ6ICpza2lwX2FuZDAKCWZyYW1lX2RpZyAtMiAvLyBiOiB1aW50NjQKCSYmCgoqc2tpcF9hbmQwOgoJYXNzZXJ0CglyZXRzdWIKCi8vIG9yKHVpbnQ2NCx1aW50NjQpdm9pZAoqYWJpX3JvdXRlX29yOgoJLy8gYjogdWludDY0Cgl0eG5hIEFwcGxpY2F0aW9uQXJncyAyCglidG9pCgoJLy8gYTogdWludDY0Cgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglidG9pCgoJLy8gZXhlY3V0ZSBvcih1aW50NjQsdWludDY0KXZvaWQKCWNhbGxzdWIgb3IKCWludCAxCglyZXR1cm4KCi8vIG9yKGE6IHVpbnQ2NCwgYjogdWludDY0KTogdm9pZApvcjoKCXByb3RvIDIgMAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9iaW5hcnkuYWxnby50czoxMAoJLy8gYXNzZXJ0KGEgfHwgYikKCWZyYW1lX2RpZyAtMSAvLyBhOiB1aW50NjQKCWR1cAoJYm56ICpza2lwX29yMAoJZnJhbWVfZGlnIC0yIC8vIGI6IHVpbnQ2NAoJfHwKCipza2lwX29yMDoKCWFzc2VydAoJcmV0c3ViCgovLyBlcXVhbCh1aW50NjQsdWludDY0KXZvaWQKKmFiaV9yb3V0ZV9lcXVhbDoKCS8vIGI6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMgoJYnRvaQoKCS8vIGE6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJYnRvaQoKCS8vIGV4ZWN1dGUgZXF1YWwodWludDY0LHVpbnQ2NCl2b2lkCgljYWxsc3ViIGVxdWFsCglpbnQgMQoJcmV0dXJuCgovLyBlcXVhbChhOiB1aW50NjQsIGI6IHVpbnQ2NCk6IHZvaWQKZXF1YWw6Cglwcm90byAyIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYmluYXJ5LmFsZ28udHM6MTQKCS8vIGFzc2VydChhID09PSBiKQoJZnJhbWVfZGlnIC0xIC8vIGE6IHVpbnQ2NAoJZnJhbWVfZGlnIC0yIC8vIGI6IHVpbnQ2NAoJPT0KCWFzc2VydAoJcmV0c3ViCgovLyBub3RFcXVhbCh1aW50NjQsdWludDY0KXZvaWQKKmFiaV9yb3V0ZV9ub3RFcXVhbDoKCS8vIGI6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMgoJYnRvaQoKCS8vIGE6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJYnRvaQoKCS8vIGV4ZWN1dGUgbm90RXF1YWwodWludDY0LHVpbnQ2NCl2b2lkCgljYWxsc3ViIG5vdEVxdWFsCglpbnQgMQoJcmV0dXJuCgovLyBub3RFcXVhbChhOiB1aW50NjQsIGI6IHVpbnQ2NCk6IHZvaWQKbm90RXF1YWw6Cglwcm90byAyIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYmluYXJ5LmFsZ28udHM6MTgKCS8vIGFzc2VydChhICE9PSBiKQoJZnJhbWVfZGlnIC0xIC8vIGE6IHVpbnQ2NAoJZnJhbWVfZGlnIC0yIC8vIGI6IHVpbnQ2NAoJIT0KCWFzc2VydAoJcmV0c3ViCgovLyBiaXRBbmQodWludDY0LHVpbnQ2NCl2b2lkCiphYmlfcm91dGVfYml0QW5kOgoJLy8gYjogdWludDY0Cgl0eG5hIEFwcGxpY2F0aW9uQXJncyAyCglidG9pCgoJLy8gYTogdWludDY0Cgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglidG9pCgoJLy8gZXhlY3V0ZSBiaXRBbmQodWludDY0LHVpbnQ2NCl2b2lkCgljYWxsc3ViIGJpdEFuZAoJaW50IDEKCXJldHVybgoKLy8gYml0QW5kKGE6IHVpbnQ2NCwgYjogdWludDY0KTogdm9pZApiaXRBbmQ6Cglwcm90byAyIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYmluYXJ5LmFsZ28udHM6MjIKCS8vIGFzc2VydChhICYgYikKCWZyYW1lX2RpZyAtMSAvLyBhOiB1aW50NjQKCWZyYW1lX2RpZyAtMiAvLyBiOiB1aW50NjQKCSYKCWFzc2VydAoJcmV0c3ViCgovLyBiaXRPcih1aW50NjQsdWludDY0KXZvaWQKKmFiaV9yb3V0ZV9iaXRPcjoKCS8vIGI6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMgoJYnRvaQoKCS8vIGE6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJYnRvaQoKCS8vIGV4ZWN1dGUgYml0T3IodWludDY0LHVpbnQ2NCl2b2lkCgljYWxsc3ViIGJpdE9yCglpbnQgMQoJcmV0dXJuCgovLyBiaXRPcihhOiB1aW50NjQsIGI6IHVpbnQ2NCk6IHZvaWQKYml0T3I6Cglwcm90byAyIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYmluYXJ5LmFsZ28udHM6MjYKCS8vIGFzc2VydChhIHwgYikKCWZyYW1lX2RpZyAtMSAvLyBhOiB1aW50NjQKCWZyYW1lX2RpZyAtMiAvLyBiOiB1aW50NjQKCXwKCWFzc2VydAoJcmV0c3ViCgovLyBiaXRYb3IodWludDY0LHVpbnQ2NCl2b2lkCiphYmlfcm91dGVfYml0WG9yOgoJLy8gYjogdWludDY0Cgl0eG5hIEFwcGxpY2F0aW9uQXJncyAyCglidG9pCgoJLy8gYTogdWludDY0Cgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglidG9pCgoJLy8gZXhlY3V0ZSBiaXRYb3IodWludDY0LHVpbnQ2NCl2b2lkCgljYWxsc3ViIGJpdFhvcgoJaW50IDEKCXJldHVybgoKLy8gYml0WG9yKGE6IHVpbnQ2NCwgYjogdWludDY0KTogdm9pZApiaXRYb3I6Cglwcm90byAyIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYmluYXJ5LmFsZ28udHM6MzAKCS8vIGFzc2VydChhIF4gYikKCWZyYW1lX2RpZyAtMSAvLyBhOiB1aW50NjQKCWZyYW1lX2RpZyAtMiAvLyBiOiB1aW50NjQKCV4KCWFzc2VydAoJcmV0c3ViCgovLyBjb21ibyh1aW50NjQsdWludDY0LHVpbnQ2NCl2b2lkCiphYmlfcm91dGVfY29tYm86CgkvLyBjOiB1aW50NjQKCXR4bmEgQXBwbGljYXRpb25BcmdzIDMKCWJ0b2kKCgkvLyBiOiB1aW50NjQKCXR4bmEgQXBwbGljYXRpb25BcmdzIDIKCWJ0b2kKCgkvLyBhOiB1aW50NjQKCXR4bmEgQXBwbGljYXRpb25BcmdzIDEKCWJ0b2kKCgkvLyBleGVjdXRlIGNvbWJvKHVpbnQ2NCx1aW50NjQsdWludDY0KXZvaWQKCWNhbGxzdWIgY29tYm8KCWludCAxCglyZXR1cm4KCi8vIGNvbWJvKGE6IHVpbnQ2NCwgYjogdWludDY0LCBjOiB1aW50NjQpOiB2b2lkCmNvbWJvOgoJcHJvdG8gMyAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2JpbmFyeS5hbGdvLnRzOjM0CgkvLyBhc3NlcnQoYSB8fCAoYiAmJiBjKSkKCWZyYW1lX2RpZyAtMSAvLyBhOiB1aW50NjQKCWR1cAoJYm56ICpza2lwX29yMQoJZnJhbWVfZGlnIC0yIC8vIGI6IHVpbnQ2NAoJZHVwCglieiAqc2tpcF9hbmQxCglmcmFtZV9kaWcgLTMgLy8gYzogdWludDY0CgkmJgoKKnNraXBfYW5kMToKCXx8Cgoqc2tpcF9vcjE6Cglhc3NlcnQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCWludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg2ZmQxM2ExMyAvLyBtZXRob2QgImFuZCh1aW50NjQsdWludDY0KXZvaWQiCglwdXNoYnl0ZXMgMHg3MDBhYTg4NyAvLyBtZXRob2QgIm9yKHVpbnQ2NCx1aW50NjQpdm9pZCIKCXB1c2hieXRlcyAweDcyM2M4N2VmIC8vIG1ldGhvZCAiZXF1YWwodWludDY0LHVpbnQ2NCl2b2lkIgoJcHVzaGJ5dGVzIDB4ZTdmZmI5ZDMgLy8gbWV0aG9kICJub3RFcXVhbCh1aW50NjQsdWludDY0KXZvaWQiCglwdXNoYnl0ZXMgMHg5Mjg1MTg4ZSAvLyBtZXRob2QgImJpdEFuZCh1aW50NjQsdWludDY0KXZvaWQiCglwdXNoYnl0ZXMgMHg1OTJkYzczZiAvLyBtZXRob2QgImJpdE9yKHVpbnQ2NCx1aW50NjQpdm9pZCIKCXB1c2hieXRlcyAweDZkNDY1MDRhIC8vIG1ldGhvZCAiYml0WG9yKHVpbnQ2NCx1aW50NjQpdm9pZCIKCXB1c2hieXRlcyAweDc0ZGM1MTUwIC8vIG1ldGhvZCAiY29tYm8odWludDY0LHVpbnQ2NCx1aW50NjQpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfYW5kICphYmlfcm91dGVfb3IgKmFiaV9yb3V0ZV9lcXVhbCAqYWJpX3JvdXRlX25vdEVxdWFsICphYmlfcm91dGVfYml0QW5kICphYmlfcm91dGVfYml0T3IgKmFiaV9yb3V0ZV9iaXRYb3IgKmFiaV9yb3V0ZV9jb21ibwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmludGNibG9jayAxCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYW5kKHVpbnQ2NCx1aW50NjQpdm9pZAoqYWJpX3JvdXRlX2FuZDoKCS8vIGI6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMgoJYnRvaQoKCS8vIGE6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJYnRvaQoKCS8vIGV4ZWN1dGUgYW5kKHVpbnQ2NCx1aW50NjQpdm9pZAoJY2FsbHN1YiBhbmQKCWludCAxCglyZXR1cm4KCi8vIGFuZChhOiB1aW50NjQsIGI6IHVpbnQ2NCk6IHZvaWQKYW5kOgoJcHJvdG8gMiAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2JpbmFyeS5hbGdvLnRzOjYKCS8vIGFzc2VydChhICYmIGIpCglmcmFtZV9kaWcgLTEgLy8gYTogdWludDY0CglkdXAKCWJ6ICpza2lwX2FuZDAKCWZyYW1lX2RpZyAtMiAvLyBiOiB1aW50NjQKCSYmCgoqc2tpcF9hbmQwOgoJYXNzZXJ0CglyZXRzdWIKCi8vIG9yKHVpbnQ2NCx1aW50NjQpdm9pZAoqYWJpX3JvdXRlX29yOgoJLy8gYjogdWludDY0Cgl0eG5hIEFwcGxpY2F0aW9uQXJncyAyCglidG9pCgoJLy8gYTogdWludDY0Cgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglidG9pCgoJLy8gZXhlY3V0ZSBvcih1aW50NjQsdWludDY0KXZvaWQKCWNhbGxzdWIgb3IKCWludCAxCglyZXR1cm4KCi8vIG9yKGE6IHVpbnQ2NCwgYjogdWludDY0KTogdm9pZApvcjoKCXByb3RvIDIgMAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9iaW5hcnkuYWxnby50czoxMAoJLy8gYXNzZXJ0KGEgfHwgYikKCWZyYW1lX2RpZyAtMSAvLyBhOiB1aW50NjQKCWR1cAoJYm56ICpza2lwX29yMAoJZnJhbWVfZGlnIC0yIC8vIGI6IHVpbnQ2NAoJfHwKCipza2lwX29yMDoKCWFzc2VydAoJcmV0c3ViCgovLyBlcXVhbCh1aW50NjQsdWludDY0KXZvaWQKKmFiaV9yb3V0ZV9lcXVhbDoKCS8vIGI6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMgoJYnRvaQoKCS8vIGE6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJYnRvaQoKCS8vIGV4ZWN1dGUgZXF1YWwodWludDY0LHVpbnQ2NCl2b2lkCgljYWxsc3ViIGVxdWFsCglpbnQgMQoJcmV0dXJuCgovLyBlcXVhbChhOiB1aW50NjQsIGI6IHVpbnQ2NCk6IHZvaWQKZXF1YWw6Cglwcm90byAyIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYmluYXJ5LmFsZ28udHM6MTQKCS8vIGFzc2VydChhID09PSBiKQoJZnJhbWVfZGlnIC0xIC8vIGE6IHVpbnQ2NAoJZnJhbWVfZGlnIC0yIC8vIGI6IHVpbnQ2NAoJPT0KCWFzc2VydAoJcmV0c3ViCgovLyBub3RFcXVhbCh1aW50NjQsdWludDY0KXZvaWQKKmFiaV9yb3V0ZV9ub3RFcXVhbDoKCS8vIGI6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMgoJYnRvaQoKCS8vIGE6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJYnRvaQoKCS8vIGV4ZWN1dGUgbm90RXF1YWwodWludDY0LHVpbnQ2NCl2b2lkCgljYWxsc3ViIG5vdEVxdWFsCglpbnQgMQoJcmV0dXJuCgovLyBub3RFcXVhbChhOiB1aW50NjQsIGI6IHVpbnQ2NCk6IHZvaWQKbm90RXF1YWw6Cglwcm90byAyIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYmluYXJ5LmFsZ28udHM6MTgKCS8vIGFzc2VydChhICE9PSBiKQoJZnJhbWVfZGlnIC0xIC8vIGE6IHVpbnQ2NAoJZnJhbWVfZGlnIC0yIC8vIGI6IHVpbnQ2NAoJIT0KCWFzc2VydAoJcmV0c3ViCgovLyBiaXRBbmQodWludDY0LHVpbnQ2NCl2b2lkCiphYmlfcm91dGVfYml0QW5kOgoJLy8gYjogdWludDY0Cgl0eG5hIEFwcGxpY2F0aW9uQXJncyAyCglidG9pCgoJLy8gYTogdWludDY0Cgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglidG9pCgoJLy8gZXhlY3V0ZSBiaXRBbmQodWludDY0LHVpbnQ2NCl2b2lkCgljYWxsc3ViIGJpdEFuZAoJaW50IDEKCXJldHVybgoKLy8gYml0QW5kKGE6IHVpbnQ2NCwgYjogdWludDY0KTogdm9pZApiaXRBbmQ6Cglwcm90byAyIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYmluYXJ5LmFsZ28udHM6MjIKCS8vIGFzc2VydChhICYgYikKCWZyYW1lX2RpZyAtMSAvLyBhOiB1aW50NjQKCWZyYW1lX2RpZyAtMiAvLyBiOiB1aW50NjQKCSYKCWFzc2VydAoJcmV0c3ViCgovLyBiaXRPcih1aW50NjQsdWludDY0KXZvaWQKKmFiaV9yb3V0ZV9iaXRPcjoKCS8vIGI6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMgoJYnRvaQoKCS8vIGE6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJYnRvaQoKCS8vIGV4ZWN1dGUgYml0T3IodWludDY0LHVpbnQ2NCl2b2lkCgljYWxsc3ViIGJpdE9yCglpbnQgMQoJcmV0dXJuCgovLyBiaXRPcihhOiB1aW50NjQsIGI6IHVpbnQ2NCk6IHZvaWQKYml0T3I6Cglwcm90byAyIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYmluYXJ5LmFsZ28udHM6MjYKCS8vIGFzc2VydChhIHwgYikKCWZyYW1lX2RpZyAtMSAvLyBhOiB1aW50NjQKCWZyYW1lX2RpZyAtMiAvLyBiOiB1aW50NjQKCXwKCWFzc2VydAoJcmV0c3ViCgovLyBiaXRYb3IodWludDY0LHVpbnQ2NCl2b2lkCiphYmlfcm91dGVfYml0WG9yOgoJLy8gYjogdWludDY0Cgl0eG5hIEFwcGxpY2F0aW9uQXJncyAyCglidG9pCgoJLy8gYTogdWludDY0Cgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglidG9pCgoJLy8gZXhlY3V0ZSBiaXRYb3IodWludDY0LHVpbnQ2NCl2b2lkCgljYWxsc3ViIGJpdFhvcgoJaW50IDEKCXJldHVybgoKLy8gYml0WG9yKGE6IHVpbnQ2NCwgYjogdWludDY0KTogdm9pZApiaXRYb3I6Cglwcm90byAyIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYmluYXJ5LmFsZ28udHM6MzAKCS8vIGFzc2VydChhIF4gYikKCWZyYW1lX2RpZyAtMSAvLyBhOiB1aW50NjQKCWZyYW1lX2RpZyAtMiAvLyBiOiB1aW50NjQKCV4KCWFzc2VydAoJcmV0c3ViCgovLyBjb21ibyh1aW50NjQsdWludDY0LHVpbnQ2NCl2b2lkCiphYmlfcm91dGVfY29tYm86CgkvLyBjOiB1aW50NjQKCXR4bmEgQXBwbGljYXRpb25BcmdzIDMKCWJ0b2kKCgkvLyBiOiB1aW50NjQKCXR4bmEgQXBwbGljYXRpb25BcmdzIDIKCWJ0b2kKCgkvLyBhOiB1aW50NjQKCXR4bmEgQXBwbGljYXRpb25BcmdzIDEKCWJ0b2kKCgkvLyBleGVjdXRlIGNvbWJvKHVpbnQ2NCx1aW50NjQsdWludDY0KXZvaWQKCWNhbGxzdWIgY29tYm8KCWludCAxCglyZXR1cm4KCi8vIGNvbWJvKGE6IHVpbnQ2NCwgYjogdWludDY0LCBjOiB1aW50NjQpOiB2b2lkCmNvbWJvOgoJcHJvdG8gMyAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2JpbmFyeS5hbGdvLnRzOjM0CgkvLyBhc3NlcnQoYSB8fCAoYiAmJiBjKSkKCWZyYW1lX2RpZyAtMSAvLyBhOiB1aW50NjQKCWR1cAoJYm56ICpza2lwX29yMQoJZnJhbWVfZGlnIC0yIC8vIGI6IHVpbnQ2NAoJZHVwCglieiAqc2tpcF9hbmQxCglmcmFtZV9kaWcgLTMgLy8gYzogdWludDY0CgkmJgoKKnNraXBfYW5kMToKCXx8Cgoqc2tpcF9vcjE6Cglhc3NlcnQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCWludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg2ZmQxM2ExMyAvLyBtZXRob2QgImFuZCh1aW50NjQsdWludDY0KXZvaWQiCglwdXNoYnl0ZXMgMHg3MDBhYTg4NyAvLyBtZXRob2QgIm9yKHVpbnQ2NCx1aW50NjQpdm9pZCIKCXB1c2hieXRlcyAweDcyM2M4N2VmIC8vIG1ldGhvZCAiZXF1YWwodWludDY0LHVpbnQ2NCl2b2lkIgoJcHVzaGJ5dGVzIDB4ZTdmZmI5ZDMgLy8gbWV0aG9kICJub3RFcXVhbCh1aW50NjQsdWludDY0KXZvaWQiCglwdXNoYnl0ZXMgMHg5Mjg1MTg4ZSAvLyBtZXRob2QgImJpdEFuZCh1aW50NjQsdWludDY0KXZvaWQiCglwdXNoYnl0ZXMgMHg1OTJkYzczZiAvLyBtZXRob2QgImJpdE9yKHVpbnQ2NCx1aW50NjQpdm9pZCIKCXB1c2hieXRlcyAweDZkNDY1MDRhIC8vIG1ldGhvZCAiYml0WG9yKHVpbnQ2NCx1aW50NjQpdm9pZCIKCXB1c2hieXRlcyAweDc0ZGM1MTUwIC8vIG1ldGhvZCAiY29tYm8odWludDY0LHVpbnQ2NCx1aW50NjQpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfYW5kICphYmlfcm91dGVfb3IgKmFiaV9yb3V0ZV9lcXVhbCAqYWJpX3JvdXRlX25vdEVxdWFsICphYmlfcm91dGVfYml0QW5kICphYmlfcm91dGVfYml0T3IgKmFiaV9yb3V0ZV9iaXRYb3IgKmFiaV9yb3V0ZV9jb21ibwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/BinaryTest.arc56_draft.json b/tests/contracts/artifacts/BinaryTest.arc56_draft.json index 1d96fda34..3d226bb2c 100644 --- a/tests/contracts/artifacts/BinaryTest.arc56_draft.json +++ b/tests/contracts/artifacts/BinaryTest.arc56_draft.json @@ -1442,7 +1442,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmludGNibG9jayAxCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYW5kKHVpbnQ2NCx1aW50NjQpdm9pZAoqYWJpX3JvdXRlX2FuZDoKCS8vIGI6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMgoJYnRvaQoKCS8vIGE6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJYnRvaQoKCS8vIGV4ZWN1dGUgYW5kKHVpbnQ2NCx1aW50NjQpdm9pZAoJY2FsbHN1YiBhbmQKCWludCAxCglyZXR1cm4KCi8vIGFuZChhOiB1aW50NjQsIGI6IHVpbnQ2NCk6IHZvaWQKYW5kOgoJcHJvdG8gMiAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2JpbmFyeS5hbGdvLnRzOjYKCS8vIGFzc2VydChhICYmIGIpCglmcmFtZV9kaWcgLTEgLy8gYTogdWludDY0CglkdXAKCWJ6ICpza2lwX2FuZDAKCWZyYW1lX2RpZyAtMiAvLyBiOiB1aW50NjQKCSYmCgoqc2tpcF9hbmQwOgoJYXNzZXJ0CglyZXRzdWIKCi8vIG9yKHVpbnQ2NCx1aW50NjQpdm9pZAoqYWJpX3JvdXRlX29yOgoJLy8gYjogdWludDY0Cgl0eG5hIEFwcGxpY2F0aW9uQXJncyAyCglidG9pCgoJLy8gYTogdWludDY0Cgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglidG9pCgoJLy8gZXhlY3V0ZSBvcih1aW50NjQsdWludDY0KXZvaWQKCWNhbGxzdWIgb3IKCWludCAxCglyZXR1cm4KCi8vIG9yKGE6IHVpbnQ2NCwgYjogdWludDY0KTogdm9pZApvcjoKCXByb3RvIDIgMAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9iaW5hcnkuYWxnby50czoxMAoJLy8gYXNzZXJ0KGEgfHwgYikKCWZyYW1lX2RpZyAtMSAvLyBhOiB1aW50NjQKCWR1cAoJYm56ICpza2lwX29yMAoJZnJhbWVfZGlnIC0yIC8vIGI6IHVpbnQ2NAoJfHwKCipza2lwX29yMDoKCWFzc2VydAoJcmV0c3ViCgovLyBlcXVhbCh1aW50NjQsdWludDY0KXZvaWQKKmFiaV9yb3V0ZV9lcXVhbDoKCS8vIGI6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMgoJYnRvaQoKCS8vIGE6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJYnRvaQoKCS8vIGV4ZWN1dGUgZXF1YWwodWludDY0LHVpbnQ2NCl2b2lkCgljYWxsc3ViIGVxdWFsCglpbnQgMQoJcmV0dXJuCgovLyBlcXVhbChhOiB1aW50NjQsIGI6IHVpbnQ2NCk6IHZvaWQKZXF1YWw6Cglwcm90byAyIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYmluYXJ5LmFsZ28udHM6MTQKCS8vIGFzc2VydChhID09PSBiKQoJZnJhbWVfZGlnIC0xIC8vIGE6IHVpbnQ2NAoJZnJhbWVfZGlnIC0yIC8vIGI6IHVpbnQ2NAoJPT0KCWFzc2VydAoJcmV0c3ViCgovLyBub3RFcXVhbCh1aW50NjQsdWludDY0KXZvaWQKKmFiaV9yb3V0ZV9ub3RFcXVhbDoKCS8vIGI6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMgoJYnRvaQoKCS8vIGE6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJYnRvaQoKCS8vIGV4ZWN1dGUgbm90RXF1YWwodWludDY0LHVpbnQ2NCl2b2lkCgljYWxsc3ViIG5vdEVxdWFsCglpbnQgMQoJcmV0dXJuCgovLyBub3RFcXVhbChhOiB1aW50NjQsIGI6IHVpbnQ2NCk6IHZvaWQKbm90RXF1YWw6Cglwcm90byAyIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYmluYXJ5LmFsZ28udHM6MTgKCS8vIGFzc2VydChhICE9PSBiKQoJZnJhbWVfZGlnIC0xIC8vIGE6IHVpbnQ2NAoJZnJhbWVfZGlnIC0yIC8vIGI6IHVpbnQ2NAoJIT0KCWFzc2VydAoJcmV0c3ViCgovLyBiaXRBbmQodWludDY0LHVpbnQ2NCl2b2lkCiphYmlfcm91dGVfYml0QW5kOgoJLy8gYjogdWludDY0Cgl0eG5hIEFwcGxpY2F0aW9uQXJncyAyCglidG9pCgoJLy8gYTogdWludDY0Cgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglidG9pCgoJLy8gZXhlY3V0ZSBiaXRBbmQodWludDY0LHVpbnQ2NCl2b2lkCgljYWxsc3ViIGJpdEFuZAoJaW50IDEKCXJldHVybgoKLy8gYml0QW5kKGE6IHVpbnQ2NCwgYjogdWludDY0KTogdm9pZApiaXRBbmQ6Cglwcm90byAyIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYmluYXJ5LmFsZ28udHM6MjIKCS8vIGFzc2VydChhICYgYikKCWZyYW1lX2RpZyAtMSAvLyBhOiB1aW50NjQKCWZyYW1lX2RpZyAtMiAvLyBiOiB1aW50NjQKCSYKCWFzc2VydAoJcmV0c3ViCgovLyBiaXRPcih1aW50NjQsdWludDY0KXZvaWQKKmFiaV9yb3V0ZV9iaXRPcjoKCS8vIGI6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMgoJYnRvaQoKCS8vIGE6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJYnRvaQoKCS8vIGV4ZWN1dGUgYml0T3IodWludDY0LHVpbnQ2NCl2b2lkCgljYWxsc3ViIGJpdE9yCglpbnQgMQoJcmV0dXJuCgovLyBiaXRPcihhOiB1aW50NjQsIGI6IHVpbnQ2NCk6IHZvaWQKYml0T3I6Cglwcm90byAyIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYmluYXJ5LmFsZ28udHM6MjYKCS8vIGFzc2VydChhIHwgYikKCWZyYW1lX2RpZyAtMSAvLyBhOiB1aW50NjQKCWZyYW1lX2RpZyAtMiAvLyBiOiB1aW50NjQKCXwKCWFzc2VydAoJcmV0c3ViCgovLyBiaXRYb3IodWludDY0LHVpbnQ2NCl2b2lkCiphYmlfcm91dGVfYml0WG9yOgoJLy8gYjogdWludDY0Cgl0eG5hIEFwcGxpY2F0aW9uQXJncyAyCglidG9pCgoJLy8gYTogdWludDY0Cgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglidG9pCgoJLy8gZXhlY3V0ZSBiaXRYb3IodWludDY0LHVpbnQ2NCl2b2lkCgljYWxsc3ViIGJpdFhvcgoJaW50IDEKCXJldHVybgoKLy8gYml0WG9yKGE6IHVpbnQ2NCwgYjogdWludDY0KTogdm9pZApiaXRYb3I6Cglwcm90byAyIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYmluYXJ5LmFsZ28udHM6MzAKCS8vIGFzc2VydChhIF4gYikKCWZyYW1lX2RpZyAtMSAvLyBhOiB1aW50NjQKCWZyYW1lX2RpZyAtMiAvLyBiOiB1aW50NjQKCV4KCWFzc2VydAoJcmV0c3ViCgovLyBjb21ibyh1aW50NjQsdWludDY0LHVpbnQ2NCl2b2lkCiphYmlfcm91dGVfY29tYm86CgkvLyBjOiB1aW50NjQKCXR4bmEgQXBwbGljYXRpb25BcmdzIDMKCWJ0b2kKCgkvLyBiOiB1aW50NjQKCXR4bmEgQXBwbGljYXRpb25BcmdzIDIKCWJ0b2kKCgkvLyBhOiB1aW50NjQKCXR4bmEgQXBwbGljYXRpb25BcmdzIDEKCWJ0b2kKCgkvLyBleGVjdXRlIGNvbWJvKHVpbnQ2NCx1aW50NjQsdWludDY0KXZvaWQKCWNhbGxzdWIgY29tYm8KCWludCAxCglyZXR1cm4KCi8vIGNvbWJvKGE6IHVpbnQ2NCwgYjogdWludDY0LCBjOiB1aW50NjQpOiB2b2lkCmNvbWJvOgoJcHJvdG8gMyAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2JpbmFyeS5hbGdvLnRzOjM0CgkvLyBhc3NlcnQoYSB8fCAoYiAmJiBjKSkKCWZyYW1lX2RpZyAtMSAvLyBhOiB1aW50NjQKCWR1cAoJYm56ICpza2lwX29yMQoJZnJhbWVfZGlnIC0yIC8vIGI6IHVpbnQ2NAoJZHVwCglieiAqc2tpcF9hbmQxCglmcmFtZV9kaWcgLTMgLy8gYzogdWludDY0CgkmJgoKKnNraXBfYW5kMToKCXx8Cgoqc2tpcF9vcjE6Cglhc3NlcnQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCWludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg2ZmQxM2ExMyAvLyBtZXRob2QgImFuZCh1aW50NjQsdWludDY0KXZvaWQiCglwdXNoYnl0ZXMgMHg3MDBhYTg4NyAvLyBtZXRob2QgIm9yKHVpbnQ2NCx1aW50NjQpdm9pZCIKCXB1c2hieXRlcyAweDcyM2M4N2VmIC8vIG1ldGhvZCAiZXF1YWwodWludDY0LHVpbnQ2NCl2b2lkIgoJcHVzaGJ5dGVzIDB4ZTdmZmI5ZDMgLy8gbWV0aG9kICJub3RFcXVhbCh1aW50NjQsdWludDY0KXZvaWQiCglwdXNoYnl0ZXMgMHg5Mjg1MTg4ZSAvLyBtZXRob2QgImJpdEFuZCh1aW50NjQsdWludDY0KXZvaWQiCglwdXNoYnl0ZXMgMHg1OTJkYzczZiAvLyBtZXRob2QgImJpdE9yKHVpbnQ2NCx1aW50NjQpdm9pZCIKCXB1c2hieXRlcyAweDZkNDY1MDRhIC8vIG1ldGhvZCAiYml0WG9yKHVpbnQ2NCx1aW50NjQpdm9pZCIKCXB1c2hieXRlcyAweDc0ZGM1MTUwIC8vIG1ldGhvZCAiY29tYm8odWludDY0LHVpbnQ2NCx1aW50NjQpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfYW5kICphYmlfcm91dGVfb3IgKmFiaV9yb3V0ZV9lcXVhbCAqYWJpX3JvdXRlX25vdEVxdWFsICphYmlfcm91dGVfYml0QW5kICphYmlfcm91dGVfYml0T3IgKmFiaV9yb3V0ZV9iaXRYb3IgKmFiaV9yb3V0ZV9jb21ibwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmludGNibG9jayAxCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYW5kKHVpbnQ2NCx1aW50NjQpdm9pZAoqYWJpX3JvdXRlX2FuZDoKCS8vIGI6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMgoJYnRvaQoKCS8vIGE6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJYnRvaQoKCS8vIGV4ZWN1dGUgYW5kKHVpbnQ2NCx1aW50NjQpdm9pZAoJY2FsbHN1YiBhbmQKCWludCAxCglyZXR1cm4KCi8vIGFuZChhOiB1aW50NjQsIGI6IHVpbnQ2NCk6IHZvaWQKYW5kOgoJcHJvdG8gMiAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2JpbmFyeS5hbGdvLnRzOjYKCS8vIGFzc2VydChhICYmIGIpCglmcmFtZV9kaWcgLTEgLy8gYTogdWludDY0CglkdXAKCWJ6ICpza2lwX2FuZDAKCWZyYW1lX2RpZyAtMiAvLyBiOiB1aW50NjQKCSYmCgoqc2tpcF9hbmQwOgoJYXNzZXJ0CglyZXRzdWIKCi8vIG9yKHVpbnQ2NCx1aW50NjQpdm9pZAoqYWJpX3JvdXRlX29yOgoJLy8gYjogdWludDY0Cgl0eG5hIEFwcGxpY2F0aW9uQXJncyAyCglidG9pCgoJLy8gYTogdWludDY0Cgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglidG9pCgoJLy8gZXhlY3V0ZSBvcih1aW50NjQsdWludDY0KXZvaWQKCWNhbGxzdWIgb3IKCWludCAxCglyZXR1cm4KCi8vIG9yKGE6IHVpbnQ2NCwgYjogdWludDY0KTogdm9pZApvcjoKCXByb3RvIDIgMAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9iaW5hcnkuYWxnby50czoxMAoJLy8gYXNzZXJ0KGEgfHwgYikKCWZyYW1lX2RpZyAtMSAvLyBhOiB1aW50NjQKCWR1cAoJYm56ICpza2lwX29yMAoJZnJhbWVfZGlnIC0yIC8vIGI6IHVpbnQ2NAoJfHwKCipza2lwX29yMDoKCWFzc2VydAoJcmV0c3ViCgovLyBlcXVhbCh1aW50NjQsdWludDY0KXZvaWQKKmFiaV9yb3V0ZV9lcXVhbDoKCS8vIGI6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMgoJYnRvaQoKCS8vIGE6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJYnRvaQoKCS8vIGV4ZWN1dGUgZXF1YWwodWludDY0LHVpbnQ2NCl2b2lkCgljYWxsc3ViIGVxdWFsCglpbnQgMQoJcmV0dXJuCgovLyBlcXVhbChhOiB1aW50NjQsIGI6IHVpbnQ2NCk6IHZvaWQKZXF1YWw6Cglwcm90byAyIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYmluYXJ5LmFsZ28udHM6MTQKCS8vIGFzc2VydChhID09PSBiKQoJZnJhbWVfZGlnIC0xIC8vIGE6IHVpbnQ2NAoJZnJhbWVfZGlnIC0yIC8vIGI6IHVpbnQ2NAoJPT0KCWFzc2VydAoJcmV0c3ViCgovLyBub3RFcXVhbCh1aW50NjQsdWludDY0KXZvaWQKKmFiaV9yb3V0ZV9ub3RFcXVhbDoKCS8vIGI6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMgoJYnRvaQoKCS8vIGE6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJYnRvaQoKCS8vIGV4ZWN1dGUgbm90RXF1YWwodWludDY0LHVpbnQ2NCl2b2lkCgljYWxsc3ViIG5vdEVxdWFsCglpbnQgMQoJcmV0dXJuCgovLyBub3RFcXVhbChhOiB1aW50NjQsIGI6IHVpbnQ2NCk6IHZvaWQKbm90RXF1YWw6Cglwcm90byAyIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYmluYXJ5LmFsZ28udHM6MTgKCS8vIGFzc2VydChhICE9PSBiKQoJZnJhbWVfZGlnIC0xIC8vIGE6IHVpbnQ2NAoJZnJhbWVfZGlnIC0yIC8vIGI6IHVpbnQ2NAoJIT0KCWFzc2VydAoJcmV0c3ViCgovLyBiaXRBbmQodWludDY0LHVpbnQ2NCl2b2lkCiphYmlfcm91dGVfYml0QW5kOgoJLy8gYjogdWludDY0Cgl0eG5hIEFwcGxpY2F0aW9uQXJncyAyCglidG9pCgoJLy8gYTogdWludDY0Cgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglidG9pCgoJLy8gZXhlY3V0ZSBiaXRBbmQodWludDY0LHVpbnQ2NCl2b2lkCgljYWxsc3ViIGJpdEFuZAoJaW50IDEKCXJldHVybgoKLy8gYml0QW5kKGE6IHVpbnQ2NCwgYjogdWludDY0KTogdm9pZApiaXRBbmQ6Cglwcm90byAyIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYmluYXJ5LmFsZ28udHM6MjIKCS8vIGFzc2VydChhICYgYikKCWZyYW1lX2RpZyAtMSAvLyBhOiB1aW50NjQKCWZyYW1lX2RpZyAtMiAvLyBiOiB1aW50NjQKCSYKCWFzc2VydAoJcmV0c3ViCgovLyBiaXRPcih1aW50NjQsdWludDY0KXZvaWQKKmFiaV9yb3V0ZV9iaXRPcjoKCS8vIGI6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMgoJYnRvaQoKCS8vIGE6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJYnRvaQoKCS8vIGV4ZWN1dGUgYml0T3IodWludDY0LHVpbnQ2NCl2b2lkCgljYWxsc3ViIGJpdE9yCglpbnQgMQoJcmV0dXJuCgovLyBiaXRPcihhOiB1aW50NjQsIGI6IHVpbnQ2NCk6IHZvaWQKYml0T3I6Cglwcm90byAyIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYmluYXJ5LmFsZ28udHM6MjYKCS8vIGFzc2VydChhIHwgYikKCWZyYW1lX2RpZyAtMSAvLyBhOiB1aW50NjQKCWZyYW1lX2RpZyAtMiAvLyBiOiB1aW50NjQKCXwKCWFzc2VydAoJcmV0c3ViCgovLyBiaXRYb3IodWludDY0LHVpbnQ2NCl2b2lkCiphYmlfcm91dGVfYml0WG9yOgoJLy8gYjogdWludDY0Cgl0eG5hIEFwcGxpY2F0aW9uQXJncyAyCglidG9pCgoJLy8gYTogdWludDY0Cgl0eG5hIEFwcGxpY2F0aW9uQXJncyAxCglidG9pCgoJLy8gZXhlY3V0ZSBiaXRYb3IodWludDY0LHVpbnQ2NCl2b2lkCgljYWxsc3ViIGJpdFhvcgoJaW50IDEKCXJldHVybgoKLy8gYml0WG9yKGE6IHVpbnQ2NCwgYjogdWludDY0KTogdm9pZApiaXRYb3I6Cglwcm90byAyIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvYmluYXJ5LmFsZ28udHM6MzAKCS8vIGFzc2VydChhIF4gYikKCWZyYW1lX2RpZyAtMSAvLyBhOiB1aW50NjQKCWZyYW1lX2RpZyAtMiAvLyBiOiB1aW50NjQKCV4KCWFzc2VydAoJcmV0c3ViCgovLyBjb21ibyh1aW50NjQsdWludDY0LHVpbnQ2NCl2b2lkCiphYmlfcm91dGVfY29tYm86CgkvLyBjOiB1aW50NjQKCXR4bmEgQXBwbGljYXRpb25BcmdzIDMKCWJ0b2kKCgkvLyBiOiB1aW50NjQKCXR4bmEgQXBwbGljYXRpb25BcmdzIDIKCWJ0b2kKCgkvLyBhOiB1aW50NjQKCXR4bmEgQXBwbGljYXRpb25BcmdzIDEKCWJ0b2kKCgkvLyBleGVjdXRlIGNvbWJvKHVpbnQ2NCx1aW50NjQsdWludDY0KXZvaWQKCWNhbGxzdWIgY29tYm8KCWludCAxCglyZXR1cm4KCi8vIGNvbWJvKGE6IHVpbnQ2NCwgYjogdWludDY0LCBjOiB1aW50NjQpOiB2b2lkCmNvbWJvOgoJcHJvdG8gMyAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2JpbmFyeS5hbGdvLnRzOjM0CgkvLyBhc3NlcnQoYSB8fCAoYiAmJiBjKSkKCWZyYW1lX2RpZyAtMSAvLyBhOiB1aW50NjQKCWR1cAoJYm56ICpza2lwX29yMQoJZnJhbWVfZGlnIC0yIC8vIGI6IHVpbnQ2NAoJZHVwCglieiAqc2tpcF9hbmQxCglmcmFtZV9kaWcgLTMgLy8gYzogdWludDY0CgkmJgoKKnNraXBfYW5kMToKCXx8Cgoqc2tpcF9vcjE6Cglhc3NlcnQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCWludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg2ZmQxM2ExMyAvLyBtZXRob2QgImFuZCh1aW50NjQsdWludDY0KXZvaWQiCglwdXNoYnl0ZXMgMHg3MDBhYTg4NyAvLyBtZXRob2QgIm9yKHVpbnQ2NCx1aW50NjQpdm9pZCIKCXB1c2hieXRlcyAweDcyM2M4N2VmIC8vIG1ldGhvZCAiZXF1YWwodWludDY0LHVpbnQ2NCl2b2lkIgoJcHVzaGJ5dGVzIDB4ZTdmZmI5ZDMgLy8gbWV0aG9kICJub3RFcXVhbCh1aW50NjQsdWludDY0KXZvaWQiCglwdXNoYnl0ZXMgMHg5Mjg1MTg4ZSAvLyBtZXRob2QgImJpdEFuZCh1aW50NjQsdWludDY0KXZvaWQiCglwdXNoYnl0ZXMgMHg1OTJkYzczZiAvLyBtZXRob2QgImJpdE9yKHVpbnQ2NCx1aW50NjQpdm9pZCIKCXB1c2hieXRlcyAweDZkNDY1MDRhIC8vIG1ldGhvZCAiYml0WG9yKHVpbnQ2NCx1aW50NjQpdm9pZCIKCXB1c2hieXRlcyAweDc0ZGM1MTUwIC8vIG1ldGhvZCAiY29tYm8odWludDY0LHVpbnQ2NCx1aW50NjQpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfYW5kICphYmlfcm91dGVfb3IgKmFiaV9yb3V0ZV9lcXVhbCAqYWJpX3JvdXRlX25vdEVxdWFsICphYmlfcm91dGVfYml0QW5kICphYmlfcm91dGVfYml0T3IgKmFiaV9yb3V0ZV9iaXRYb3IgKmFiaV9yb3V0ZV9jb21ibwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/BytecblockTest.approval.teal b/tests/contracts/artifacts/BytecblockTest.approval.teal index d4ee283b2..c09932cb2 100644 --- a/tests/contracts/artifacts/BytecblockTest.approval.teal +++ b/tests/contracts/artifacts/BytecblockTest.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x6279746556616c7565 0x0a8101 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/BytecblockTest.arc32.json b/tests/contracts/artifacts/BytecblockTest.arc32.json index c1959ddff..073e86768 100644 --- a/tests/contracts/artifacts/BytecblockTest.arc32.json +++ b/tests/contracts/artifacts/BytecblockTest.arc32.json @@ -44,7 +44,7 @@ } }, "source": { - "approval": "#pragma version 10
bytecblock 0x6279746556616c7565 0x0a8101

// This TEAL was generated by TEALScript v0.104.1
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// largeBytecblock()string
*abi_route_largeBytecblock:
	// The ABI return prefix
	pushbytes 0x151f7c75

	// execute largeBytecblock()string
	callsub largeBytecblock
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	pushint 1
	return

// largeBytecblock(): string
largeBytecblock:
	proto 0 1

	// tests/contracts/cblocks.algo.ts:274
	// increaseOpcodeBudget()
	itxn_begin
	pushint 6 // appl
	itxn_field TypeEnum
	pushint 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	pushint 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

	// tests/contracts/cblocks.algo.ts:276
	// this.byteValue.value = '2'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x32 // "2"
	app_global_put

	// tests/contracts/cblocks.algo.ts:277
	// this.byteValue.value = '3'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x33 // "3"
	app_global_put

	// tests/contracts/cblocks.algo.ts:278
	// this.byteValue.value = '4'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x34 // "4"
	app_global_put

	// tests/contracts/cblocks.algo.ts:279
	// this.byteValue.value = '5'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x35 // "5"
	app_global_put

	// tests/contracts/cblocks.algo.ts:280
	// this.byteValue.value = '6'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x36 // "6"
	app_global_put

	// tests/contracts/cblocks.algo.ts:281
	// this.byteValue.value = '7'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x37 // "7"
	app_global_put

	// tests/contracts/cblocks.algo.ts:282
	// this.byteValue.value = '8'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x38 // "8"
	app_global_put

	// tests/contracts/cblocks.algo.ts:283
	// this.byteValue.value = '9'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x39 // "9"
	app_global_put

	// tests/contracts/cblocks.algo.ts:284
	// this.byteValue.value = '10'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3130 // "10"
	app_global_put

	// tests/contracts/cblocks.algo.ts:285
	// this.byteValue.value = '11'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3131 // "11"
	app_global_put

	// tests/contracts/cblocks.algo.ts:286
	// this.byteValue.value = '12'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3132 // "12"
	app_global_put

	// tests/contracts/cblocks.algo.ts:287
	// this.byteValue.value = '13'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3133 // "13"
	app_global_put

	// tests/contracts/cblocks.algo.ts:288
	// this.byteValue.value = '14'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3134 // "14"
	app_global_put

	// tests/contracts/cblocks.algo.ts:289
	// this.byteValue.value = '15'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3135 // "15"
	app_global_put

	// tests/contracts/cblocks.algo.ts:290
	// this.byteValue.value = '16'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3136 // "16"
	app_global_put

	// tests/contracts/cblocks.algo.ts:291
	// this.byteValue.value = '17'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3137 // "17"
	app_global_put

	// tests/contracts/cblocks.algo.ts:292
	// this.byteValue.value = '18'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3138 // "18"
	app_global_put

	// tests/contracts/cblocks.algo.ts:293
	// this.byteValue.value = '19'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3139 // "19"
	app_global_put

	// tests/contracts/cblocks.algo.ts:294
	// this.byteValue.value = '20'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3230 // "20"
	app_global_put

	// tests/contracts/cblocks.algo.ts:295
	// this.byteValue.value = '21'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3231 // "21"
	app_global_put

	// tests/contracts/cblocks.algo.ts:296
	// this.byteValue.value = '22'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3232 // "22"
	app_global_put

	// tests/contracts/cblocks.algo.ts:297
	// this.byteValue.value = '23'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3233 // "23"
	app_global_put

	// tests/contracts/cblocks.algo.ts:298
	// this.byteValue.value = '24'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3234 // "24"
	app_global_put

	// tests/contracts/cblocks.algo.ts:299
	// this.byteValue.value = '25'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3235 // "25"
	app_global_put

	// tests/contracts/cblocks.algo.ts:300
	// this.byteValue.value = '26'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3236 // "26"
	app_global_put

	// tests/contracts/cblocks.algo.ts:301
	// this.byteValue.value = '27'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3237 // "27"
	app_global_put

	// tests/contracts/cblocks.algo.ts:302
	// this.byteValue.value = '28'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3238 // "28"
	app_global_put

	// tests/contracts/cblocks.algo.ts:303
	// this.byteValue.value = '29'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3239 // "29"
	app_global_put

	// tests/contracts/cblocks.algo.ts:304
	// this.byteValue.value = '30'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3330 // "30"
	app_global_put

	// tests/contracts/cblocks.algo.ts:305
	// this.byteValue.value = '31'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3331 // "31"
	app_global_put

	// tests/contracts/cblocks.algo.ts:306
	// this.byteValue.value = '32'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3332 // "32"
	app_global_put

	// tests/contracts/cblocks.algo.ts:307
	// this.byteValue.value = '33'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3333 // "33"
	app_global_put

	// tests/contracts/cblocks.algo.ts:308
	// this.byteValue.value = '34'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3334 // "34"
	app_global_put

	// tests/contracts/cblocks.algo.ts:309
	// this.byteValue.value = '35'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3335 // "35"
	app_global_put

	// tests/contracts/cblocks.algo.ts:310
	// this.byteValue.value = '36'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3336 // "36"
	app_global_put

	// tests/contracts/cblocks.algo.ts:311
	// this.byteValue.value = '37'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3337 // "37"
	app_global_put

	// tests/contracts/cblocks.algo.ts:312
	// this.byteValue.value = '38'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3338 // "38"
	app_global_put

	// tests/contracts/cblocks.algo.ts:313
	// this.byteValue.value = '39'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3339 // "39"
	app_global_put

	// tests/contracts/cblocks.algo.ts:314
	// this.byteValue.value = '40'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3430 // "40"
	app_global_put

	// tests/contracts/cblocks.algo.ts:315
	// this.byteValue.value = '41'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3431 // "41"
	app_global_put

	// tests/contracts/cblocks.algo.ts:316
	// this.byteValue.value = '42'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3432 // "42"
	app_global_put

	// tests/contracts/cblocks.algo.ts:317
	// this.byteValue.value = '43'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3433 // "43"
	app_global_put

	// tests/contracts/cblocks.algo.ts:318
	// this.byteValue.value = '44'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3434 // "44"
	app_global_put

	// tests/contracts/cblocks.algo.ts:319
	// this.byteValue.value = '45'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3435 // "45"
	app_global_put

	// tests/contracts/cblocks.algo.ts:320
	// this.byteValue.value = '46'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3436 // "46"
	app_global_put

	// tests/contracts/cblocks.algo.ts:321
	// this.byteValue.value = '47'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3437 // "47"
	app_global_put

	// tests/contracts/cblocks.algo.ts:322
	// this.byteValue.value = '48'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3438 // "48"
	app_global_put

	// tests/contracts/cblocks.algo.ts:323
	// this.byteValue.value = '49'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3439 // "49"
	app_global_put

	// tests/contracts/cblocks.algo.ts:324
	// this.byteValue.value = '50'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3530 // "50"
	app_global_put

	// tests/contracts/cblocks.algo.ts:325
	// this.byteValue.value = '51'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3531 // "51"
	app_global_put

	// tests/contracts/cblocks.algo.ts:326
	// this.byteValue.value = '52'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3532 // "52"
	app_global_put

	// tests/contracts/cblocks.algo.ts:327
	// this.byteValue.value = '53'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3533 // "53"
	app_global_put

	// tests/contracts/cblocks.algo.ts:328
	// this.byteValue.value = '54'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3534 // "54"
	app_global_put

	// tests/contracts/cblocks.algo.ts:329
	// this.byteValue.value = '55'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3535 // "55"
	app_global_put

	// tests/contracts/cblocks.algo.ts:330
	// this.byteValue.value = '56'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3536 // "56"
	app_global_put

	// tests/contracts/cblocks.algo.ts:331
	// this.byteValue.value = '57'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3537 // "57"
	app_global_put

	// tests/contracts/cblocks.algo.ts:332
	// this.byteValue.value = '58'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3538 // "58"
	app_global_put

	// tests/contracts/cblocks.algo.ts:333
	// this.byteValue.value = '59'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3539 // "59"
	app_global_put

	// tests/contracts/cblocks.algo.ts:334
	// this.byteValue.value = '60'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3630 // "60"
	app_global_put

	// tests/contracts/cblocks.algo.ts:335
	// this.byteValue.value = '61'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3631 // "61"
	app_global_put

	// tests/contracts/cblocks.algo.ts:336
	// this.byteValue.value = '62'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3632 // "62"
	app_global_put

	// tests/contracts/cblocks.algo.ts:337
	// this.byteValue.value = '63'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3633 // "63"
	app_global_put

	// tests/contracts/cblocks.algo.ts:338
	// this.byteValue.value = '64'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3634 // "64"
	app_global_put

	// tests/contracts/cblocks.algo.ts:339
	// this.byteValue.value = '65'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3635 // "65"
	app_global_put

	// tests/contracts/cblocks.algo.ts:340
	// this.byteValue.value = '66'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3636 // "66"
	app_global_put

	// tests/contracts/cblocks.algo.ts:341
	// this.byteValue.value = '67'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3637 // "67"
	app_global_put

	// tests/contracts/cblocks.algo.ts:342
	// this.byteValue.value = '68'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3638 // "68"
	app_global_put

	// tests/contracts/cblocks.algo.ts:343
	// this.byteValue.value = '69'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3639 // "69"
	app_global_put

	// tests/contracts/cblocks.algo.ts:344
	// this.byteValue.value = '70'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3730 // "70"
	app_global_put

	// tests/contracts/cblocks.algo.ts:345
	// this.byteValue.value = '71'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3731 // "71"
	app_global_put

	// tests/contracts/cblocks.algo.ts:346
	// this.byteValue.value = '72'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3732 // "72"
	app_global_put

	// tests/contracts/cblocks.algo.ts:347
	// this.byteValue.value = '73'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3733 // "73"
	app_global_put

	// tests/contracts/cblocks.algo.ts:348
	// this.byteValue.value = '74'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3734 // "74"
	app_global_put

	// tests/contracts/cblocks.algo.ts:349
	// this.byteValue.value = '75'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3735 // "75"
	app_global_put

	// tests/contracts/cblocks.algo.ts:350
	// this.byteValue.value = '76'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3736 // "76"
	app_global_put

	// tests/contracts/cblocks.algo.ts:351
	// this.byteValue.value = '77'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3737 // "77"
	app_global_put

	// tests/contracts/cblocks.algo.ts:352
	// this.byteValue.value = '78'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3738 // "78"
	app_global_put

	// tests/contracts/cblocks.algo.ts:353
	// this.byteValue.value = '79'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3739 // "79"
	app_global_put

	// tests/contracts/cblocks.algo.ts:354
	// this.byteValue.value = '80'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3830 // "80"
	app_global_put

	// tests/contracts/cblocks.algo.ts:355
	// this.byteValue.value = '81'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3831 // "81"
	app_global_put

	// tests/contracts/cblocks.algo.ts:356
	// this.byteValue.value = '82'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3832 // "82"
	app_global_put

	// tests/contracts/cblocks.algo.ts:357
	// this.byteValue.value = '83'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3833 // "83"
	app_global_put

	// tests/contracts/cblocks.algo.ts:358
	// this.byteValue.value = '84'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3834 // "84"
	app_global_put

	// tests/contracts/cblocks.algo.ts:359
	// this.byteValue.value = '85'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3835 // "85"
	app_global_put

	// tests/contracts/cblocks.algo.ts:360
	// this.byteValue.value = '86'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3836 // "86"
	app_global_put

	// tests/contracts/cblocks.algo.ts:361
	// this.byteValue.value = '87'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3837 // "87"
	app_global_put

	// tests/contracts/cblocks.algo.ts:362
	// this.byteValue.value = '88'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3838 // "88"
	app_global_put

	// tests/contracts/cblocks.algo.ts:363
	// this.byteValue.value = '89'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3839 // "89"
	app_global_put

	// tests/contracts/cblocks.algo.ts:364
	// this.byteValue.value = '90'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3930 // "90"
	app_global_put

	// tests/contracts/cblocks.algo.ts:365
	// this.byteValue.value = '91'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3931 // "91"
	app_global_put

	// tests/contracts/cblocks.algo.ts:366
	// this.byteValue.value = '92'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3932 // "92"
	app_global_put

	// tests/contracts/cblocks.algo.ts:367
	// this.byteValue.value = '93'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3933 // "93"
	app_global_put

	// tests/contracts/cblocks.algo.ts:368
	// this.byteValue.value = '94'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3934 // "94"
	app_global_put

	// tests/contracts/cblocks.algo.ts:369
	// this.byteValue.value = '95'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3935 // "95"
	app_global_put

	// tests/contracts/cblocks.algo.ts:370
	// this.byteValue.value = '96'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3936 // "96"
	app_global_put

	// tests/contracts/cblocks.algo.ts:371
	// this.byteValue.value = '97'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3937 // "97"
	app_global_put

	// tests/contracts/cblocks.algo.ts:372
	// this.byteValue.value = '98'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3938 // "98"
	app_global_put

	// tests/contracts/cblocks.algo.ts:373
	// this.byteValue.value = '99'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3939 // "99"
	app_global_put

	// tests/contracts/cblocks.algo.ts:374
	// this.byteValue.value = '100'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313030 // "100"
	app_global_put

	// tests/contracts/cblocks.algo.ts:375
	// this.byteValue.value = '101'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313031 // "101"
	app_global_put

	// tests/contracts/cblocks.algo.ts:376
	// this.byteValue.value = '102'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313032 // "102"
	app_global_put

	// tests/contracts/cblocks.algo.ts:377
	// this.byteValue.value = '103'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313033 // "103"
	app_global_put

	// tests/contracts/cblocks.algo.ts:378
	// this.byteValue.value = '104'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313034 // "104"
	app_global_put

	// tests/contracts/cblocks.algo.ts:379
	// this.byteValue.value = '105'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313035 // "105"
	app_global_put

	// tests/contracts/cblocks.algo.ts:380
	// this.byteValue.value = '106'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313036 // "106"
	app_global_put

	// tests/contracts/cblocks.algo.ts:381
	// this.byteValue.value = '107'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313037 // "107"
	app_global_put

	// tests/contracts/cblocks.algo.ts:382
	// this.byteValue.value = '108'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313038 // "108"
	app_global_put

	// tests/contracts/cblocks.algo.ts:383
	// this.byteValue.value = '109'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313039 // "109"
	app_global_put

	// tests/contracts/cblocks.algo.ts:384
	// this.byteValue.value = '110'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313130 // "110"
	app_global_put

	// tests/contracts/cblocks.algo.ts:385
	// this.byteValue.value = '111'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313131 // "111"
	app_global_put

	// tests/contracts/cblocks.algo.ts:386
	// this.byteValue.value = '112'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313132 // "112"
	app_global_put

	// tests/contracts/cblocks.algo.ts:387
	// this.byteValue.value = '113'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313133 // "113"
	app_global_put

	// tests/contracts/cblocks.algo.ts:388
	// this.byteValue.value = '114'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313134 // "114"
	app_global_put

	// tests/contracts/cblocks.algo.ts:389
	// this.byteValue.value = '115'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313135 // "115"
	app_global_put

	// tests/contracts/cblocks.algo.ts:390
	// this.byteValue.value = '116'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313136 // "116"
	app_global_put

	// tests/contracts/cblocks.algo.ts:391
	// this.byteValue.value = '117'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313137 // "117"
	app_global_put

	// tests/contracts/cblocks.algo.ts:392
	// this.byteValue.value = '118'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313138 // "118"
	app_global_put

	// tests/contracts/cblocks.algo.ts:393
	// this.byteValue.value = '119'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313139 // "119"
	app_global_put

	// tests/contracts/cblocks.algo.ts:394
	// this.byteValue.value = '120'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313230 // "120"
	app_global_put

	// tests/contracts/cblocks.algo.ts:395
	// this.byteValue.value = '121'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313231 // "121"
	app_global_put

	// tests/contracts/cblocks.algo.ts:396
	// this.byteValue.value = '122'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313232 // "122"
	app_global_put

	// tests/contracts/cblocks.algo.ts:397
	// this.byteValue.value = '123'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313233 // "123"
	app_global_put

	// tests/contracts/cblocks.algo.ts:398
	// this.byteValue.value = '124'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313234 // "124"
	app_global_put

	// tests/contracts/cblocks.algo.ts:399
	// this.byteValue.value = '125'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313235 // "125"
	app_global_put

	// tests/contracts/cblocks.algo.ts:400
	// this.byteValue.value = '126'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313236 // "126"
	app_global_put

	// tests/contracts/cblocks.algo.ts:401
	// this.byteValue.value = '127'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313237 // "127"
	app_global_put

	// tests/contracts/cblocks.algo.ts:402
	// this.byteValue.value = '128'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313238 // "128"
	app_global_put

	// tests/contracts/cblocks.algo.ts:403
	// this.byteValue.value = '129'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313239 // "129"
	app_global_put

	// tests/contracts/cblocks.algo.ts:404
	// this.byteValue.value = '130'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313330 // "130"
	app_global_put

	// tests/contracts/cblocks.algo.ts:405
	// this.byteValue.value = '131'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313331 // "131"
	app_global_put

	// tests/contracts/cblocks.algo.ts:406
	// this.byteValue.value = '132'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313332 // "132"
	app_global_put

	// tests/contracts/cblocks.algo.ts:407
	// this.byteValue.value = '133'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313333 // "133"
	app_global_put

	// tests/contracts/cblocks.algo.ts:408
	// this.byteValue.value = '134'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313334 // "134"
	app_global_put

	// tests/contracts/cblocks.algo.ts:409
	// this.byteValue.value = '135'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313335 // "135"
	app_global_put

	// tests/contracts/cblocks.algo.ts:410
	// this.byteValue.value = '136'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313336 // "136"
	app_global_put

	// tests/contracts/cblocks.algo.ts:411
	// this.byteValue.value = '137'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313337 // "137"
	app_global_put

	// tests/contracts/cblocks.algo.ts:412
	// this.byteValue.value = '138'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313338 // "138"
	app_global_put

	// tests/contracts/cblocks.algo.ts:413
	// this.byteValue.value = '139'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313339 // "139"
	app_global_put

	// tests/contracts/cblocks.algo.ts:414
	// this.byteValue.value = '140'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313430 // "140"
	app_global_put

	// tests/contracts/cblocks.algo.ts:415
	// this.byteValue.value = '141'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313431 // "141"
	app_global_put

	// tests/contracts/cblocks.algo.ts:416
	// this.byteValue.value = '142'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313432 // "142"
	app_global_put

	// tests/contracts/cblocks.algo.ts:417
	// this.byteValue.value = '143'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313433 // "143"
	app_global_put

	// tests/contracts/cblocks.algo.ts:418
	// this.byteValue.value = '144'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313434 // "144"
	app_global_put

	// tests/contracts/cblocks.algo.ts:419
	// this.byteValue.value = '145'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313435 // "145"
	app_global_put

	// tests/contracts/cblocks.algo.ts:420
	// this.byteValue.value = '146'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313436 // "146"
	app_global_put

	// tests/contracts/cblocks.algo.ts:421
	// this.byteValue.value = '147'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313437 // "147"
	app_global_put

	// tests/contracts/cblocks.algo.ts:422
	// this.byteValue.value = '148'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313438 // "148"
	app_global_put

	// tests/contracts/cblocks.algo.ts:423
	// this.byteValue.value = '149'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313439 // "149"
	app_global_put

	// tests/contracts/cblocks.algo.ts:424
	// this.byteValue.value = '150'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313530 // "150"
	app_global_put

	// tests/contracts/cblocks.algo.ts:425
	// this.byteValue.value = '151'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313531 // "151"
	app_global_put

	// tests/contracts/cblocks.algo.ts:426
	// this.byteValue.value = '152'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313532 // "152"
	app_global_put

	// tests/contracts/cblocks.algo.ts:427
	// this.byteValue.value = '153'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313533 // "153"
	app_global_put

	// tests/contracts/cblocks.algo.ts:428
	// this.byteValue.value = '154'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313534 // "154"
	app_global_put

	// tests/contracts/cblocks.algo.ts:429
	// this.byteValue.value = '155'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313535 // "155"
	app_global_put

	// tests/contracts/cblocks.algo.ts:430
	// this.byteValue.value = '156'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313536 // "156"
	app_global_put

	// tests/contracts/cblocks.algo.ts:431
	// this.byteValue.value = '157'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313537 // "157"
	app_global_put

	// tests/contracts/cblocks.algo.ts:432
	// this.byteValue.value = '158'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313538 // "158"
	app_global_put

	// tests/contracts/cblocks.algo.ts:433
	// this.byteValue.value = '159'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313539 // "159"
	app_global_put

	// tests/contracts/cblocks.algo.ts:434
	// this.byteValue.value = '160'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313630 // "160"
	app_global_put

	// tests/contracts/cblocks.algo.ts:435
	// this.byteValue.value = '161'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313631 // "161"
	app_global_put

	// tests/contracts/cblocks.algo.ts:436
	// this.byteValue.value = '162'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313632 // "162"
	app_global_put

	// tests/contracts/cblocks.algo.ts:437
	// this.byteValue.value = '163'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313633 // "163"
	app_global_put

	// tests/contracts/cblocks.algo.ts:438
	// this.byteValue.value = '164'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313634 // "164"
	app_global_put

	// tests/contracts/cblocks.algo.ts:439
	// this.byteValue.value = '165'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313635 // "165"
	app_global_put

	// tests/contracts/cblocks.algo.ts:440
	// this.byteValue.value = '166'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313636 // "166"
	app_global_put

	// tests/contracts/cblocks.algo.ts:441
	// this.byteValue.value = '167'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313637 // "167"
	app_global_put

	// tests/contracts/cblocks.algo.ts:442
	// this.byteValue.value = '168'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313638 // "168"
	app_global_put

	// tests/contracts/cblocks.algo.ts:443
	// this.byteValue.value = '169'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313639 // "169"
	app_global_put

	// tests/contracts/cblocks.algo.ts:444
	// this.byteValue.value = '170'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313730 // "170"
	app_global_put

	// tests/contracts/cblocks.algo.ts:445
	// this.byteValue.value = '171'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313731 // "171"
	app_global_put

	// tests/contracts/cblocks.algo.ts:446
	// this.byteValue.value = '172'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313732 // "172"
	app_global_put

	// tests/contracts/cblocks.algo.ts:447
	// this.byteValue.value = '173'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313733 // "173"
	app_global_put

	// tests/contracts/cblocks.algo.ts:448
	// this.byteValue.value = '174'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313734 // "174"
	app_global_put

	// tests/contracts/cblocks.algo.ts:449
	// this.byteValue.value = '175'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313735 // "175"
	app_global_put

	// tests/contracts/cblocks.algo.ts:450
	// this.byteValue.value = '176'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313736 // "176"
	app_global_put

	// tests/contracts/cblocks.algo.ts:451
	// this.byteValue.value = '177'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313737 // "177"
	app_global_put

	// tests/contracts/cblocks.algo.ts:452
	// this.byteValue.value = '178'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313738 // "178"
	app_global_put

	// tests/contracts/cblocks.algo.ts:453
	// this.byteValue.value = '179'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313739 // "179"
	app_global_put

	// tests/contracts/cblocks.algo.ts:454
	// this.byteValue.value = '180'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313830 // "180"
	app_global_put

	// tests/contracts/cblocks.algo.ts:455
	// this.byteValue.value = '181'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313831 // "181"
	app_global_put

	// tests/contracts/cblocks.algo.ts:456
	// this.byteValue.value = '182'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313832 // "182"
	app_global_put

	// tests/contracts/cblocks.algo.ts:457
	// this.byteValue.value = '183'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313833 // "183"
	app_global_put

	// tests/contracts/cblocks.algo.ts:458
	// this.byteValue.value = '184'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313834 // "184"
	app_global_put

	// tests/contracts/cblocks.algo.ts:459
	// this.byteValue.value = '185'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313835 // "185"
	app_global_put

	// tests/contracts/cblocks.algo.ts:460
	// this.byteValue.value = '186'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313836 // "186"
	app_global_put

	// tests/contracts/cblocks.algo.ts:461
	// this.byteValue.value = '187'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313837 // "187"
	app_global_put

	// tests/contracts/cblocks.algo.ts:462
	// this.byteValue.value = '188'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313838 // "188"
	app_global_put

	// tests/contracts/cblocks.algo.ts:463
	// this.byteValue.value = '189'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313839 // "189"
	app_global_put

	// tests/contracts/cblocks.algo.ts:464
	// this.byteValue.value = '190'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313930 // "190"
	app_global_put

	// tests/contracts/cblocks.algo.ts:465
	// this.byteValue.value = '191'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313931 // "191"
	app_global_put

	// tests/contracts/cblocks.algo.ts:466
	// this.byteValue.value = '192'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313932 // "192"
	app_global_put

	// tests/contracts/cblocks.algo.ts:467
	// this.byteValue.value = '193'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313933 // "193"
	app_global_put

	// tests/contracts/cblocks.algo.ts:468
	// this.byteValue.value = '194'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313934 // "194"
	app_global_put

	// tests/contracts/cblocks.algo.ts:469
	// this.byteValue.value = '195'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313935 // "195"
	app_global_put

	// tests/contracts/cblocks.algo.ts:470
	// this.byteValue.value = '196'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313936 // "196"
	app_global_put

	// tests/contracts/cblocks.algo.ts:471
	// this.byteValue.value = '197'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313937 // "197"
	app_global_put

	// tests/contracts/cblocks.algo.ts:472
	// this.byteValue.value = '198'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313938 // "198"
	app_global_put

	// tests/contracts/cblocks.algo.ts:473
	// this.byteValue.value = '199'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313939 // "199"
	app_global_put

	// tests/contracts/cblocks.algo.ts:474
	// this.byteValue.value = '200'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323030 // "200"
	app_global_put

	// tests/contracts/cblocks.algo.ts:475
	// this.byteValue.value = '201'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323031 // "201"
	app_global_put

	// tests/contracts/cblocks.algo.ts:476
	// this.byteValue.value = '202'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323032 // "202"
	app_global_put

	// tests/contracts/cblocks.algo.ts:477
	// this.byteValue.value = '203'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323033 // "203"
	app_global_put

	// tests/contracts/cblocks.algo.ts:478
	// this.byteValue.value = '204'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323034 // "204"
	app_global_put

	// tests/contracts/cblocks.algo.ts:479
	// this.byteValue.value = '205'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323035 // "205"
	app_global_put

	// tests/contracts/cblocks.algo.ts:480
	// this.byteValue.value = '206'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323036 // "206"
	app_global_put

	// tests/contracts/cblocks.algo.ts:481
	// this.byteValue.value = '207'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323037 // "207"
	app_global_put

	// tests/contracts/cblocks.algo.ts:482
	// this.byteValue.value = '208'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323038 // "208"
	app_global_put

	// tests/contracts/cblocks.algo.ts:483
	// this.byteValue.value = '209'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323039 // "209"
	app_global_put

	// tests/contracts/cblocks.algo.ts:484
	// this.byteValue.value = '210'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323130 // "210"
	app_global_put

	// tests/contracts/cblocks.algo.ts:485
	// this.byteValue.value = '211'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323131 // "211"
	app_global_put

	// tests/contracts/cblocks.algo.ts:486
	// this.byteValue.value = '212'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323132 // "212"
	app_global_put

	// tests/contracts/cblocks.algo.ts:487
	// this.byteValue.value = '213'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323133 // "213"
	app_global_put

	// tests/contracts/cblocks.algo.ts:488
	// this.byteValue.value = '214'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323134 // "214"
	app_global_put

	// tests/contracts/cblocks.algo.ts:489
	// this.byteValue.value = '215'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323135 // "215"
	app_global_put

	// tests/contracts/cblocks.algo.ts:490
	// this.byteValue.value = '216'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323136 // "216"
	app_global_put

	// tests/contracts/cblocks.algo.ts:491
	// this.byteValue.value = '217'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323137 // "217"
	app_global_put

	// tests/contracts/cblocks.algo.ts:492
	// this.byteValue.value = '218'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323138 // "218"
	app_global_put

	// tests/contracts/cblocks.algo.ts:493
	// this.byteValue.value = '219'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323139 // "219"
	app_global_put

	// tests/contracts/cblocks.algo.ts:494
	// this.byteValue.value = '220'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323230 // "220"
	app_global_put

	// tests/contracts/cblocks.algo.ts:495
	// this.byteValue.value = '221'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323231 // "221"
	app_global_put

	// tests/contracts/cblocks.algo.ts:496
	// this.byteValue.value = '222'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323232 // "222"
	app_global_put

	// tests/contracts/cblocks.algo.ts:497
	// this.byteValue.value = '223'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323233 // "223"
	app_global_put

	// tests/contracts/cblocks.algo.ts:498
	// this.byteValue.value = '224'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323234 // "224"
	app_global_put

	// tests/contracts/cblocks.algo.ts:499
	// this.byteValue.value = '225'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323235 // "225"
	app_global_put

	// tests/contracts/cblocks.algo.ts:500
	// this.byteValue.value = '226'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323236 // "226"
	app_global_put

	// tests/contracts/cblocks.algo.ts:501
	// this.byteValue.value = '227'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323237 // "227"
	app_global_put

	// tests/contracts/cblocks.algo.ts:502
	// this.byteValue.value = '228'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323238 // "228"
	app_global_put

	// tests/contracts/cblocks.algo.ts:503
	// this.byteValue.value = '229'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323239 // "229"
	app_global_put

	// tests/contracts/cblocks.algo.ts:504
	// this.byteValue.value = '230'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323330 // "230"
	app_global_put

	// tests/contracts/cblocks.algo.ts:505
	// this.byteValue.value = '231'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323331 // "231"
	app_global_put

	// tests/contracts/cblocks.algo.ts:506
	// this.byteValue.value = '232'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323332 // "232"
	app_global_put

	// tests/contracts/cblocks.algo.ts:507
	// this.byteValue.value = '233'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323333 // "233"
	app_global_put

	// tests/contracts/cblocks.algo.ts:508
	// this.byteValue.value = '234'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323334 // "234"
	app_global_put

	// tests/contracts/cblocks.algo.ts:509
	// this.byteValue.value = '235'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323335 // "235"
	app_global_put

	// tests/contracts/cblocks.algo.ts:510
	// this.byteValue.value = '236'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323336 // "236"
	app_global_put

	// tests/contracts/cblocks.algo.ts:511
	// this.byteValue.value = '237'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323337 // "237"
	app_global_put

	// tests/contracts/cblocks.algo.ts:512
	// this.byteValue.value = '238'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323338 // "238"
	app_global_put

	// tests/contracts/cblocks.algo.ts:513
	// this.byteValue.value = '239'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323339 // "239"
	app_global_put

	// tests/contracts/cblocks.algo.ts:514
	// this.byteValue.value = '240'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323430 // "240"
	app_global_put

	// tests/contracts/cblocks.algo.ts:515
	// this.byteValue.value = '241'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323431 // "241"
	app_global_put

	// tests/contracts/cblocks.algo.ts:516
	// this.byteValue.value = '242'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323432 // "242"
	app_global_put

	// tests/contracts/cblocks.algo.ts:517
	// this.byteValue.value = '243'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323433 // "243"
	app_global_put

	// tests/contracts/cblocks.algo.ts:518
	// this.byteValue.value = '244'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323434 // "244"
	app_global_put

	// tests/contracts/cblocks.algo.ts:519
	// this.byteValue.value = '245'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323435 // "245"
	app_global_put

	// tests/contracts/cblocks.algo.ts:520
	// this.byteValue.value = '246'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323436 // "246"
	app_global_put

	// tests/contracts/cblocks.algo.ts:521
	// this.byteValue.value = '247'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323437 // "247"
	app_global_put

	// tests/contracts/cblocks.algo.ts:522
	// this.byteValue.value = '248'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323438 // "248"
	app_global_put

	// tests/contracts/cblocks.algo.ts:523
	// this.byteValue.value = '249'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323439 // "249"
	app_global_put

	// tests/contracts/cblocks.algo.ts:524
	// this.byteValue.value = '250'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323530 // "250"
	app_global_put

	// tests/contracts/cblocks.algo.ts:525
	// this.byteValue.value = '251'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323531 // "251"
	app_global_put

	// tests/contracts/cblocks.algo.ts:526
	// this.byteValue.value = '252'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323532 // "252"
	app_global_put

	// tests/contracts/cblocks.algo.ts:527
	// this.byteValue.value = '253'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323533 // "253"
	app_global_put

	// tests/contracts/cblocks.algo.ts:528
	// this.byteValue.value = '254'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323534 // "254"
	app_global_put

	// tests/contracts/cblocks.algo.ts:529
	// this.byteValue.value = '255'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323535 // "255"
	app_global_put

	// tests/contracts/cblocks.algo.ts:530
	// this.byteValue.value = '256'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323536 // "256"
	app_global_put

	// tests/contracts/cblocks.algo.ts:532
	// this.byteValue.value =
	//       'This is a fairly long byteslice that should be put in the consant block because it is so long'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x54686973206973206120666169726c79206c6f6e672062797465736c69636520746861742073686f756c642062652070757420696e2074686520636f6e73616e7420626c6f636b206265636175736520697420697320736f206c6f6e67 // "This is a fairly long byteslice that should be put in the consant block because it is so long"
	app_global_put

	// tests/contracts/cblocks.algo.ts:535
	// return a + b;
	pushbytes "1"
	pushbytes "257"
	concat
	retsub

*abi_route_createApplication:
	pushint 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0xb13757d2 // method "largeBytecblock()string"
	txna ApplicationArgs 0
	match *abi_route_largeBytecblock

	// this contract does not implement the given ABI method for call NoOp
	err", + "approval": "#pragma version 10
bytecblock 0x6279746556616c7565 0x0a8101

// This TEAL was generated by TEALScript v0.105.0
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// largeBytecblock()string
*abi_route_largeBytecblock:
	// The ABI return prefix
	pushbytes 0x151f7c75

	// execute largeBytecblock()string
	callsub largeBytecblock
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	pushint 1
	return

// largeBytecblock(): string
largeBytecblock:
	proto 0 1

	// tests/contracts/cblocks.algo.ts:274
	// increaseOpcodeBudget()
	itxn_begin
	pushint 6 // appl
	itxn_field TypeEnum
	pushint 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	pushint 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

	// tests/contracts/cblocks.algo.ts:276
	// this.byteValue.value = '2'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x32 // "2"
	app_global_put

	// tests/contracts/cblocks.algo.ts:277
	// this.byteValue.value = '3'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x33 // "3"
	app_global_put

	// tests/contracts/cblocks.algo.ts:278
	// this.byteValue.value = '4'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x34 // "4"
	app_global_put

	// tests/contracts/cblocks.algo.ts:279
	// this.byteValue.value = '5'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x35 // "5"
	app_global_put

	// tests/contracts/cblocks.algo.ts:280
	// this.byteValue.value = '6'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x36 // "6"
	app_global_put

	// tests/contracts/cblocks.algo.ts:281
	// this.byteValue.value = '7'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x37 // "7"
	app_global_put

	// tests/contracts/cblocks.algo.ts:282
	// this.byteValue.value = '8'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x38 // "8"
	app_global_put

	// tests/contracts/cblocks.algo.ts:283
	// this.byteValue.value = '9'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x39 // "9"
	app_global_put

	// tests/contracts/cblocks.algo.ts:284
	// this.byteValue.value = '10'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3130 // "10"
	app_global_put

	// tests/contracts/cblocks.algo.ts:285
	// this.byteValue.value = '11'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3131 // "11"
	app_global_put

	// tests/contracts/cblocks.algo.ts:286
	// this.byteValue.value = '12'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3132 // "12"
	app_global_put

	// tests/contracts/cblocks.algo.ts:287
	// this.byteValue.value = '13'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3133 // "13"
	app_global_put

	// tests/contracts/cblocks.algo.ts:288
	// this.byteValue.value = '14'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3134 // "14"
	app_global_put

	// tests/contracts/cblocks.algo.ts:289
	// this.byteValue.value = '15'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3135 // "15"
	app_global_put

	// tests/contracts/cblocks.algo.ts:290
	// this.byteValue.value = '16'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3136 // "16"
	app_global_put

	// tests/contracts/cblocks.algo.ts:291
	// this.byteValue.value = '17'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3137 // "17"
	app_global_put

	// tests/contracts/cblocks.algo.ts:292
	// this.byteValue.value = '18'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3138 // "18"
	app_global_put

	// tests/contracts/cblocks.algo.ts:293
	// this.byteValue.value = '19'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3139 // "19"
	app_global_put

	// tests/contracts/cblocks.algo.ts:294
	// this.byteValue.value = '20'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3230 // "20"
	app_global_put

	// tests/contracts/cblocks.algo.ts:295
	// this.byteValue.value = '21'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3231 // "21"
	app_global_put

	// tests/contracts/cblocks.algo.ts:296
	// this.byteValue.value = '22'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3232 // "22"
	app_global_put

	// tests/contracts/cblocks.algo.ts:297
	// this.byteValue.value = '23'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3233 // "23"
	app_global_put

	// tests/contracts/cblocks.algo.ts:298
	// this.byteValue.value = '24'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3234 // "24"
	app_global_put

	// tests/contracts/cblocks.algo.ts:299
	// this.byteValue.value = '25'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3235 // "25"
	app_global_put

	// tests/contracts/cblocks.algo.ts:300
	// this.byteValue.value = '26'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3236 // "26"
	app_global_put

	// tests/contracts/cblocks.algo.ts:301
	// this.byteValue.value = '27'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3237 // "27"
	app_global_put

	// tests/contracts/cblocks.algo.ts:302
	// this.byteValue.value = '28'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3238 // "28"
	app_global_put

	// tests/contracts/cblocks.algo.ts:303
	// this.byteValue.value = '29'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3239 // "29"
	app_global_put

	// tests/contracts/cblocks.algo.ts:304
	// this.byteValue.value = '30'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3330 // "30"
	app_global_put

	// tests/contracts/cblocks.algo.ts:305
	// this.byteValue.value = '31'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3331 // "31"
	app_global_put

	// tests/contracts/cblocks.algo.ts:306
	// this.byteValue.value = '32'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3332 // "32"
	app_global_put

	// tests/contracts/cblocks.algo.ts:307
	// this.byteValue.value = '33'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3333 // "33"
	app_global_put

	// tests/contracts/cblocks.algo.ts:308
	// this.byteValue.value = '34'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3334 // "34"
	app_global_put

	// tests/contracts/cblocks.algo.ts:309
	// this.byteValue.value = '35'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3335 // "35"
	app_global_put

	// tests/contracts/cblocks.algo.ts:310
	// this.byteValue.value = '36'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3336 // "36"
	app_global_put

	// tests/contracts/cblocks.algo.ts:311
	// this.byteValue.value = '37'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3337 // "37"
	app_global_put

	// tests/contracts/cblocks.algo.ts:312
	// this.byteValue.value = '38'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3338 // "38"
	app_global_put

	// tests/contracts/cblocks.algo.ts:313
	// this.byteValue.value = '39'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3339 // "39"
	app_global_put

	// tests/contracts/cblocks.algo.ts:314
	// this.byteValue.value = '40'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3430 // "40"
	app_global_put

	// tests/contracts/cblocks.algo.ts:315
	// this.byteValue.value = '41'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3431 // "41"
	app_global_put

	// tests/contracts/cblocks.algo.ts:316
	// this.byteValue.value = '42'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3432 // "42"
	app_global_put

	// tests/contracts/cblocks.algo.ts:317
	// this.byteValue.value = '43'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3433 // "43"
	app_global_put

	// tests/contracts/cblocks.algo.ts:318
	// this.byteValue.value = '44'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3434 // "44"
	app_global_put

	// tests/contracts/cblocks.algo.ts:319
	// this.byteValue.value = '45'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3435 // "45"
	app_global_put

	// tests/contracts/cblocks.algo.ts:320
	// this.byteValue.value = '46'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3436 // "46"
	app_global_put

	// tests/contracts/cblocks.algo.ts:321
	// this.byteValue.value = '47'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3437 // "47"
	app_global_put

	// tests/contracts/cblocks.algo.ts:322
	// this.byteValue.value = '48'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3438 // "48"
	app_global_put

	// tests/contracts/cblocks.algo.ts:323
	// this.byteValue.value = '49'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3439 // "49"
	app_global_put

	// tests/contracts/cblocks.algo.ts:324
	// this.byteValue.value = '50'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3530 // "50"
	app_global_put

	// tests/contracts/cblocks.algo.ts:325
	// this.byteValue.value = '51'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3531 // "51"
	app_global_put

	// tests/contracts/cblocks.algo.ts:326
	// this.byteValue.value = '52'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3532 // "52"
	app_global_put

	// tests/contracts/cblocks.algo.ts:327
	// this.byteValue.value = '53'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3533 // "53"
	app_global_put

	// tests/contracts/cblocks.algo.ts:328
	// this.byteValue.value = '54'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3534 // "54"
	app_global_put

	// tests/contracts/cblocks.algo.ts:329
	// this.byteValue.value = '55'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3535 // "55"
	app_global_put

	// tests/contracts/cblocks.algo.ts:330
	// this.byteValue.value = '56'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3536 // "56"
	app_global_put

	// tests/contracts/cblocks.algo.ts:331
	// this.byteValue.value = '57'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3537 // "57"
	app_global_put

	// tests/contracts/cblocks.algo.ts:332
	// this.byteValue.value = '58'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3538 // "58"
	app_global_put

	// tests/contracts/cblocks.algo.ts:333
	// this.byteValue.value = '59'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3539 // "59"
	app_global_put

	// tests/contracts/cblocks.algo.ts:334
	// this.byteValue.value = '60'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3630 // "60"
	app_global_put

	// tests/contracts/cblocks.algo.ts:335
	// this.byteValue.value = '61'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3631 // "61"
	app_global_put

	// tests/contracts/cblocks.algo.ts:336
	// this.byteValue.value = '62'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3632 // "62"
	app_global_put

	// tests/contracts/cblocks.algo.ts:337
	// this.byteValue.value = '63'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3633 // "63"
	app_global_put

	// tests/contracts/cblocks.algo.ts:338
	// this.byteValue.value = '64'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3634 // "64"
	app_global_put

	// tests/contracts/cblocks.algo.ts:339
	// this.byteValue.value = '65'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3635 // "65"
	app_global_put

	// tests/contracts/cblocks.algo.ts:340
	// this.byteValue.value = '66'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3636 // "66"
	app_global_put

	// tests/contracts/cblocks.algo.ts:341
	// this.byteValue.value = '67'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3637 // "67"
	app_global_put

	// tests/contracts/cblocks.algo.ts:342
	// this.byteValue.value = '68'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3638 // "68"
	app_global_put

	// tests/contracts/cblocks.algo.ts:343
	// this.byteValue.value = '69'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3639 // "69"
	app_global_put

	// tests/contracts/cblocks.algo.ts:344
	// this.byteValue.value = '70'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3730 // "70"
	app_global_put

	// tests/contracts/cblocks.algo.ts:345
	// this.byteValue.value = '71'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3731 // "71"
	app_global_put

	// tests/contracts/cblocks.algo.ts:346
	// this.byteValue.value = '72'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3732 // "72"
	app_global_put

	// tests/contracts/cblocks.algo.ts:347
	// this.byteValue.value = '73'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3733 // "73"
	app_global_put

	// tests/contracts/cblocks.algo.ts:348
	// this.byteValue.value = '74'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3734 // "74"
	app_global_put

	// tests/contracts/cblocks.algo.ts:349
	// this.byteValue.value = '75'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3735 // "75"
	app_global_put

	// tests/contracts/cblocks.algo.ts:350
	// this.byteValue.value = '76'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3736 // "76"
	app_global_put

	// tests/contracts/cblocks.algo.ts:351
	// this.byteValue.value = '77'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3737 // "77"
	app_global_put

	// tests/contracts/cblocks.algo.ts:352
	// this.byteValue.value = '78'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3738 // "78"
	app_global_put

	// tests/contracts/cblocks.algo.ts:353
	// this.byteValue.value = '79'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3739 // "79"
	app_global_put

	// tests/contracts/cblocks.algo.ts:354
	// this.byteValue.value = '80'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3830 // "80"
	app_global_put

	// tests/contracts/cblocks.algo.ts:355
	// this.byteValue.value = '81'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3831 // "81"
	app_global_put

	// tests/contracts/cblocks.algo.ts:356
	// this.byteValue.value = '82'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3832 // "82"
	app_global_put

	// tests/contracts/cblocks.algo.ts:357
	// this.byteValue.value = '83'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3833 // "83"
	app_global_put

	// tests/contracts/cblocks.algo.ts:358
	// this.byteValue.value = '84'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3834 // "84"
	app_global_put

	// tests/contracts/cblocks.algo.ts:359
	// this.byteValue.value = '85'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3835 // "85"
	app_global_put

	// tests/contracts/cblocks.algo.ts:360
	// this.byteValue.value = '86'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3836 // "86"
	app_global_put

	// tests/contracts/cblocks.algo.ts:361
	// this.byteValue.value = '87'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3837 // "87"
	app_global_put

	// tests/contracts/cblocks.algo.ts:362
	// this.byteValue.value = '88'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3838 // "88"
	app_global_put

	// tests/contracts/cblocks.algo.ts:363
	// this.byteValue.value = '89'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3839 // "89"
	app_global_put

	// tests/contracts/cblocks.algo.ts:364
	// this.byteValue.value = '90'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3930 // "90"
	app_global_put

	// tests/contracts/cblocks.algo.ts:365
	// this.byteValue.value = '91'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3931 // "91"
	app_global_put

	// tests/contracts/cblocks.algo.ts:366
	// this.byteValue.value = '92'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3932 // "92"
	app_global_put

	// tests/contracts/cblocks.algo.ts:367
	// this.byteValue.value = '93'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3933 // "93"
	app_global_put

	// tests/contracts/cblocks.algo.ts:368
	// this.byteValue.value = '94'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3934 // "94"
	app_global_put

	// tests/contracts/cblocks.algo.ts:369
	// this.byteValue.value = '95'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3935 // "95"
	app_global_put

	// tests/contracts/cblocks.algo.ts:370
	// this.byteValue.value = '96'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3936 // "96"
	app_global_put

	// tests/contracts/cblocks.algo.ts:371
	// this.byteValue.value = '97'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3937 // "97"
	app_global_put

	// tests/contracts/cblocks.algo.ts:372
	// this.byteValue.value = '98'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3938 // "98"
	app_global_put

	// tests/contracts/cblocks.algo.ts:373
	// this.byteValue.value = '99'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3939 // "99"
	app_global_put

	// tests/contracts/cblocks.algo.ts:374
	// this.byteValue.value = '100'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313030 // "100"
	app_global_put

	// tests/contracts/cblocks.algo.ts:375
	// this.byteValue.value = '101'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313031 // "101"
	app_global_put

	// tests/contracts/cblocks.algo.ts:376
	// this.byteValue.value = '102'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313032 // "102"
	app_global_put

	// tests/contracts/cblocks.algo.ts:377
	// this.byteValue.value = '103'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313033 // "103"
	app_global_put

	// tests/contracts/cblocks.algo.ts:378
	// this.byteValue.value = '104'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313034 // "104"
	app_global_put

	// tests/contracts/cblocks.algo.ts:379
	// this.byteValue.value = '105'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313035 // "105"
	app_global_put

	// tests/contracts/cblocks.algo.ts:380
	// this.byteValue.value = '106'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313036 // "106"
	app_global_put

	// tests/contracts/cblocks.algo.ts:381
	// this.byteValue.value = '107'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313037 // "107"
	app_global_put

	// tests/contracts/cblocks.algo.ts:382
	// this.byteValue.value = '108'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313038 // "108"
	app_global_put

	// tests/contracts/cblocks.algo.ts:383
	// this.byteValue.value = '109'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313039 // "109"
	app_global_put

	// tests/contracts/cblocks.algo.ts:384
	// this.byteValue.value = '110'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313130 // "110"
	app_global_put

	// tests/contracts/cblocks.algo.ts:385
	// this.byteValue.value = '111'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313131 // "111"
	app_global_put

	// tests/contracts/cblocks.algo.ts:386
	// this.byteValue.value = '112'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313132 // "112"
	app_global_put

	// tests/contracts/cblocks.algo.ts:387
	// this.byteValue.value = '113'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313133 // "113"
	app_global_put

	// tests/contracts/cblocks.algo.ts:388
	// this.byteValue.value = '114'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313134 // "114"
	app_global_put

	// tests/contracts/cblocks.algo.ts:389
	// this.byteValue.value = '115'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313135 // "115"
	app_global_put

	// tests/contracts/cblocks.algo.ts:390
	// this.byteValue.value = '116'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313136 // "116"
	app_global_put

	// tests/contracts/cblocks.algo.ts:391
	// this.byteValue.value = '117'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313137 // "117"
	app_global_put

	// tests/contracts/cblocks.algo.ts:392
	// this.byteValue.value = '118'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313138 // "118"
	app_global_put

	// tests/contracts/cblocks.algo.ts:393
	// this.byteValue.value = '119'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313139 // "119"
	app_global_put

	// tests/contracts/cblocks.algo.ts:394
	// this.byteValue.value = '120'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313230 // "120"
	app_global_put

	// tests/contracts/cblocks.algo.ts:395
	// this.byteValue.value = '121'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313231 // "121"
	app_global_put

	// tests/contracts/cblocks.algo.ts:396
	// this.byteValue.value = '122'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313232 // "122"
	app_global_put

	// tests/contracts/cblocks.algo.ts:397
	// this.byteValue.value = '123'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313233 // "123"
	app_global_put

	// tests/contracts/cblocks.algo.ts:398
	// this.byteValue.value = '124'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313234 // "124"
	app_global_put

	// tests/contracts/cblocks.algo.ts:399
	// this.byteValue.value = '125'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313235 // "125"
	app_global_put

	// tests/contracts/cblocks.algo.ts:400
	// this.byteValue.value = '126'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313236 // "126"
	app_global_put

	// tests/contracts/cblocks.algo.ts:401
	// this.byteValue.value = '127'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313237 // "127"
	app_global_put

	// tests/contracts/cblocks.algo.ts:402
	// this.byteValue.value = '128'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313238 // "128"
	app_global_put

	// tests/contracts/cblocks.algo.ts:403
	// this.byteValue.value = '129'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313239 // "129"
	app_global_put

	// tests/contracts/cblocks.algo.ts:404
	// this.byteValue.value = '130'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313330 // "130"
	app_global_put

	// tests/contracts/cblocks.algo.ts:405
	// this.byteValue.value = '131'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313331 // "131"
	app_global_put

	// tests/contracts/cblocks.algo.ts:406
	// this.byteValue.value = '132'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313332 // "132"
	app_global_put

	// tests/contracts/cblocks.algo.ts:407
	// this.byteValue.value = '133'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313333 // "133"
	app_global_put

	// tests/contracts/cblocks.algo.ts:408
	// this.byteValue.value = '134'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313334 // "134"
	app_global_put

	// tests/contracts/cblocks.algo.ts:409
	// this.byteValue.value = '135'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313335 // "135"
	app_global_put

	// tests/contracts/cblocks.algo.ts:410
	// this.byteValue.value = '136'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313336 // "136"
	app_global_put

	// tests/contracts/cblocks.algo.ts:411
	// this.byteValue.value = '137'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313337 // "137"
	app_global_put

	// tests/contracts/cblocks.algo.ts:412
	// this.byteValue.value = '138'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313338 // "138"
	app_global_put

	// tests/contracts/cblocks.algo.ts:413
	// this.byteValue.value = '139'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313339 // "139"
	app_global_put

	// tests/contracts/cblocks.algo.ts:414
	// this.byteValue.value = '140'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313430 // "140"
	app_global_put

	// tests/contracts/cblocks.algo.ts:415
	// this.byteValue.value = '141'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313431 // "141"
	app_global_put

	// tests/contracts/cblocks.algo.ts:416
	// this.byteValue.value = '142'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313432 // "142"
	app_global_put

	// tests/contracts/cblocks.algo.ts:417
	// this.byteValue.value = '143'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313433 // "143"
	app_global_put

	// tests/contracts/cblocks.algo.ts:418
	// this.byteValue.value = '144'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313434 // "144"
	app_global_put

	// tests/contracts/cblocks.algo.ts:419
	// this.byteValue.value = '145'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313435 // "145"
	app_global_put

	// tests/contracts/cblocks.algo.ts:420
	// this.byteValue.value = '146'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313436 // "146"
	app_global_put

	// tests/contracts/cblocks.algo.ts:421
	// this.byteValue.value = '147'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313437 // "147"
	app_global_put

	// tests/contracts/cblocks.algo.ts:422
	// this.byteValue.value = '148'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313438 // "148"
	app_global_put

	// tests/contracts/cblocks.algo.ts:423
	// this.byteValue.value = '149'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313439 // "149"
	app_global_put

	// tests/contracts/cblocks.algo.ts:424
	// this.byteValue.value = '150'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313530 // "150"
	app_global_put

	// tests/contracts/cblocks.algo.ts:425
	// this.byteValue.value = '151'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313531 // "151"
	app_global_put

	// tests/contracts/cblocks.algo.ts:426
	// this.byteValue.value = '152'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313532 // "152"
	app_global_put

	// tests/contracts/cblocks.algo.ts:427
	// this.byteValue.value = '153'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313533 // "153"
	app_global_put

	// tests/contracts/cblocks.algo.ts:428
	// this.byteValue.value = '154'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313534 // "154"
	app_global_put

	// tests/contracts/cblocks.algo.ts:429
	// this.byteValue.value = '155'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313535 // "155"
	app_global_put

	// tests/contracts/cblocks.algo.ts:430
	// this.byteValue.value = '156'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313536 // "156"
	app_global_put

	// tests/contracts/cblocks.algo.ts:431
	// this.byteValue.value = '157'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313537 // "157"
	app_global_put

	// tests/contracts/cblocks.algo.ts:432
	// this.byteValue.value = '158'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313538 // "158"
	app_global_put

	// tests/contracts/cblocks.algo.ts:433
	// this.byteValue.value = '159'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313539 // "159"
	app_global_put

	// tests/contracts/cblocks.algo.ts:434
	// this.byteValue.value = '160'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313630 // "160"
	app_global_put

	// tests/contracts/cblocks.algo.ts:435
	// this.byteValue.value = '161'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313631 // "161"
	app_global_put

	// tests/contracts/cblocks.algo.ts:436
	// this.byteValue.value = '162'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313632 // "162"
	app_global_put

	// tests/contracts/cblocks.algo.ts:437
	// this.byteValue.value = '163'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313633 // "163"
	app_global_put

	// tests/contracts/cblocks.algo.ts:438
	// this.byteValue.value = '164'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313634 // "164"
	app_global_put

	// tests/contracts/cblocks.algo.ts:439
	// this.byteValue.value = '165'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313635 // "165"
	app_global_put

	// tests/contracts/cblocks.algo.ts:440
	// this.byteValue.value = '166'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313636 // "166"
	app_global_put

	// tests/contracts/cblocks.algo.ts:441
	// this.byteValue.value = '167'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313637 // "167"
	app_global_put

	// tests/contracts/cblocks.algo.ts:442
	// this.byteValue.value = '168'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313638 // "168"
	app_global_put

	// tests/contracts/cblocks.algo.ts:443
	// this.byteValue.value = '169'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313639 // "169"
	app_global_put

	// tests/contracts/cblocks.algo.ts:444
	// this.byteValue.value = '170'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313730 // "170"
	app_global_put

	// tests/contracts/cblocks.algo.ts:445
	// this.byteValue.value = '171'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313731 // "171"
	app_global_put

	// tests/contracts/cblocks.algo.ts:446
	// this.byteValue.value = '172'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313732 // "172"
	app_global_put

	// tests/contracts/cblocks.algo.ts:447
	// this.byteValue.value = '173'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313733 // "173"
	app_global_put

	// tests/contracts/cblocks.algo.ts:448
	// this.byteValue.value = '174'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313734 // "174"
	app_global_put

	// tests/contracts/cblocks.algo.ts:449
	// this.byteValue.value = '175'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313735 // "175"
	app_global_put

	// tests/contracts/cblocks.algo.ts:450
	// this.byteValue.value = '176'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313736 // "176"
	app_global_put

	// tests/contracts/cblocks.algo.ts:451
	// this.byteValue.value = '177'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313737 // "177"
	app_global_put

	// tests/contracts/cblocks.algo.ts:452
	// this.byteValue.value = '178'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313738 // "178"
	app_global_put

	// tests/contracts/cblocks.algo.ts:453
	// this.byteValue.value = '179'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313739 // "179"
	app_global_put

	// tests/contracts/cblocks.algo.ts:454
	// this.byteValue.value = '180'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313830 // "180"
	app_global_put

	// tests/contracts/cblocks.algo.ts:455
	// this.byteValue.value = '181'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313831 // "181"
	app_global_put

	// tests/contracts/cblocks.algo.ts:456
	// this.byteValue.value = '182'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313832 // "182"
	app_global_put

	// tests/contracts/cblocks.algo.ts:457
	// this.byteValue.value = '183'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313833 // "183"
	app_global_put

	// tests/contracts/cblocks.algo.ts:458
	// this.byteValue.value = '184'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313834 // "184"
	app_global_put

	// tests/contracts/cblocks.algo.ts:459
	// this.byteValue.value = '185'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313835 // "185"
	app_global_put

	// tests/contracts/cblocks.algo.ts:460
	// this.byteValue.value = '186'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313836 // "186"
	app_global_put

	// tests/contracts/cblocks.algo.ts:461
	// this.byteValue.value = '187'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313837 // "187"
	app_global_put

	// tests/contracts/cblocks.algo.ts:462
	// this.byteValue.value = '188'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313838 // "188"
	app_global_put

	// tests/contracts/cblocks.algo.ts:463
	// this.byteValue.value = '189'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313839 // "189"
	app_global_put

	// tests/contracts/cblocks.algo.ts:464
	// this.byteValue.value = '190'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313930 // "190"
	app_global_put

	// tests/contracts/cblocks.algo.ts:465
	// this.byteValue.value = '191'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313931 // "191"
	app_global_put

	// tests/contracts/cblocks.algo.ts:466
	// this.byteValue.value = '192'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313932 // "192"
	app_global_put

	// tests/contracts/cblocks.algo.ts:467
	// this.byteValue.value = '193'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313933 // "193"
	app_global_put

	// tests/contracts/cblocks.algo.ts:468
	// this.byteValue.value = '194'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313934 // "194"
	app_global_put

	// tests/contracts/cblocks.algo.ts:469
	// this.byteValue.value = '195'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313935 // "195"
	app_global_put

	// tests/contracts/cblocks.algo.ts:470
	// this.byteValue.value = '196'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313936 // "196"
	app_global_put

	// tests/contracts/cblocks.algo.ts:471
	// this.byteValue.value = '197'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313937 // "197"
	app_global_put

	// tests/contracts/cblocks.algo.ts:472
	// this.byteValue.value = '198'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313938 // "198"
	app_global_put

	// tests/contracts/cblocks.algo.ts:473
	// this.byteValue.value = '199'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313939 // "199"
	app_global_put

	// tests/contracts/cblocks.algo.ts:474
	// this.byteValue.value = '200'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323030 // "200"
	app_global_put

	// tests/contracts/cblocks.algo.ts:475
	// this.byteValue.value = '201'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323031 // "201"
	app_global_put

	// tests/contracts/cblocks.algo.ts:476
	// this.byteValue.value = '202'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323032 // "202"
	app_global_put

	// tests/contracts/cblocks.algo.ts:477
	// this.byteValue.value = '203'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323033 // "203"
	app_global_put

	// tests/contracts/cblocks.algo.ts:478
	// this.byteValue.value = '204'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323034 // "204"
	app_global_put

	// tests/contracts/cblocks.algo.ts:479
	// this.byteValue.value = '205'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323035 // "205"
	app_global_put

	// tests/contracts/cblocks.algo.ts:480
	// this.byteValue.value = '206'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323036 // "206"
	app_global_put

	// tests/contracts/cblocks.algo.ts:481
	// this.byteValue.value = '207'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323037 // "207"
	app_global_put

	// tests/contracts/cblocks.algo.ts:482
	// this.byteValue.value = '208'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323038 // "208"
	app_global_put

	// tests/contracts/cblocks.algo.ts:483
	// this.byteValue.value = '209'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323039 // "209"
	app_global_put

	// tests/contracts/cblocks.algo.ts:484
	// this.byteValue.value = '210'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323130 // "210"
	app_global_put

	// tests/contracts/cblocks.algo.ts:485
	// this.byteValue.value = '211'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323131 // "211"
	app_global_put

	// tests/contracts/cblocks.algo.ts:486
	// this.byteValue.value = '212'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323132 // "212"
	app_global_put

	// tests/contracts/cblocks.algo.ts:487
	// this.byteValue.value = '213'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323133 // "213"
	app_global_put

	// tests/contracts/cblocks.algo.ts:488
	// this.byteValue.value = '214'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323134 // "214"
	app_global_put

	// tests/contracts/cblocks.algo.ts:489
	// this.byteValue.value = '215'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323135 // "215"
	app_global_put

	// tests/contracts/cblocks.algo.ts:490
	// this.byteValue.value = '216'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323136 // "216"
	app_global_put

	// tests/contracts/cblocks.algo.ts:491
	// this.byteValue.value = '217'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323137 // "217"
	app_global_put

	// tests/contracts/cblocks.algo.ts:492
	// this.byteValue.value = '218'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323138 // "218"
	app_global_put

	// tests/contracts/cblocks.algo.ts:493
	// this.byteValue.value = '219'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323139 // "219"
	app_global_put

	// tests/contracts/cblocks.algo.ts:494
	// this.byteValue.value = '220'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323230 // "220"
	app_global_put

	// tests/contracts/cblocks.algo.ts:495
	// this.byteValue.value = '221'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323231 // "221"
	app_global_put

	// tests/contracts/cblocks.algo.ts:496
	// this.byteValue.value = '222'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323232 // "222"
	app_global_put

	// tests/contracts/cblocks.algo.ts:497
	// this.byteValue.value = '223'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323233 // "223"
	app_global_put

	// tests/contracts/cblocks.algo.ts:498
	// this.byteValue.value = '224'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323234 // "224"
	app_global_put

	// tests/contracts/cblocks.algo.ts:499
	// this.byteValue.value = '225'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323235 // "225"
	app_global_put

	// tests/contracts/cblocks.algo.ts:500
	// this.byteValue.value = '226'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323236 // "226"
	app_global_put

	// tests/contracts/cblocks.algo.ts:501
	// this.byteValue.value = '227'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323237 // "227"
	app_global_put

	// tests/contracts/cblocks.algo.ts:502
	// this.byteValue.value = '228'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323238 // "228"
	app_global_put

	// tests/contracts/cblocks.algo.ts:503
	// this.byteValue.value = '229'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323239 // "229"
	app_global_put

	// tests/contracts/cblocks.algo.ts:504
	// this.byteValue.value = '230'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323330 // "230"
	app_global_put

	// tests/contracts/cblocks.algo.ts:505
	// this.byteValue.value = '231'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323331 // "231"
	app_global_put

	// tests/contracts/cblocks.algo.ts:506
	// this.byteValue.value = '232'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323332 // "232"
	app_global_put

	// tests/contracts/cblocks.algo.ts:507
	// this.byteValue.value = '233'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323333 // "233"
	app_global_put

	// tests/contracts/cblocks.algo.ts:508
	// this.byteValue.value = '234'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323334 // "234"
	app_global_put

	// tests/contracts/cblocks.algo.ts:509
	// this.byteValue.value = '235'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323335 // "235"
	app_global_put

	// tests/contracts/cblocks.algo.ts:510
	// this.byteValue.value = '236'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323336 // "236"
	app_global_put

	// tests/contracts/cblocks.algo.ts:511
	// this.byteValue.value = '237'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323337 // "237"
	app_global_put

	// tests/contracts/cblocks.algo.ts:512
	// this.byteValue.value = '238'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323338 // "238"
	app_global_put

	// tests/contracts/cblocks.algo.ts:513
	// this.byteValue.value = '239'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323339 // "239"
	app_global_put

	// tests/contracts/cblocks.algo.ts:514
	// this.byteValue.value = '240'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323430 // "240"
	app_global_put

	// tests/contracts/cblocks.algo.ts:515
	// this.byteValue.value = '241'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323431 // "241"
	app_global_put

	// tests/contracts/cblocks.algo.ts:516
	// this.byteValue.value = '242'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323432 // "242"
	app_global_put

	// tests/contracts/cblocks.algo.ts:517
	// this.byteValue.value = '243'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323433 // "243"
	app_global_put

	// tests/contracts/cblocks.algo.ts:518
	// this.byteValue.value = '244'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323434 // "244"
	app_global_put

	// tests/contracts/cblocks.algo.ts:519
	// this.byteValue.value = '245'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323435 // "245"
	app_global_put

	// tests/contracts/cblocks.algo.ts:520
	// this.byteValue.value = '246'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323436 // "246"
	app_global_put

	// tests/contracts/cblocks.algo.ts:521
	// this.byteValue.value = '247'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323437 // "247"
	app_global_put

	// tests/contracts/cblocks.algo.ts:522
	// this.byteValue.value = '248'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323438 // "248"
	app_global_put

	// tests/contracts/cblocks.algo.ts:523
	// this.byteValue.value = '249'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323439 // "249"
	app_global_put

	// tests/contracts/cblocks.algo.ts:524
	// this.byteValue.value = '250'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323530 // "250"
	app_global_put

	// tests/contracts/cblocks.algo.ts:525
	// this.byteValue.value = '251'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323531 // "251"
	app_global_put

	// tests/contracts/cblocks.algo.ts:526
	// this.byteValue.value = '252'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323532 // "252"
	app_global_put

	// tests/contracts/cblocks.algo.ts:527
	// this.byteValue.value = '253'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323533 // "253"
	app_global_put

	// tests/contracts/cblocks.algo.ts:528
	// this.byteValue.value = '254'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323534 // "254"
	app_global_put

	// tests/contracts/cblocks.algo.ts:529
	// this.byteValue.value = '255'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323535 // "255"
	app_global_put

	// tests/contracts/cblocks.algo.ts:530
	// this.byteValue.value = '256'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323536 // "256"
	app_global_put

	// tests/contracts/cblocks.algo.ts:532
	// this.byteValue.value =
	//       'This is a fairly long byteslice that should be put in the consant block because it is so long'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x54686973206973206120666169726c79206c6f6e672062797465736c69636520746861742073686f756c642062652070757420696e2074686520636f6e73616e7420626c6f636b206265636175736520697420697320736f206c6f6e67 // "This is a fairly long byteslice that should be put in the consant block because it is so long"
	app_global_put

	// tests/contracts/cblocks.algo.ts:535
	// return a + b;
	pushbytes "1"
	pushbytes "257"
	concat
	retsub

*abi_route_createApplication:
	pushint 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0xb13757d2 // method "largeBytecblock()string"
	txna ApplicationArgs 0
	match *abi_route_largeBytecblock

	// this contract does not implement the given ABI method for call NoOp
	err", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/BytecblockTest.arc56_draft.json b/tests/contracts/artifacts/BytecblockTest.arc56_draft.json index 8986bee68..e7016ed11 100644 --- a/tests/contracts/artifacts/BytecblockTest.arc56_draft.json +++ b/tests/contracts/artifacts/BytecblockTest.arc56_draft.json @@ -9462,7 +9462,7 @@ } }, "source": { - "approval": "#pragma version 10
bytecblock 0x6279746556616c7565 0x0a8101

// This TEAL was generated by TEALScript v0.104.1
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// largeBytecblock()string
*abi_route_largeBytecblock:
	// The ABI return prefix
	pushbytes 0x151f7c75

	// execute largeBytecblock()string
	callsub largeBytecblock
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	pushint 1
	return

// largeBytecblock(): string
largeBytecblock:
	proto 0 1

	// tests/contracts/cblocks.algo.ts:274
	// increaseOpcodeBudget()
	itxn_begin
	pushint 6 // appl
	itxn_field TypeEnum
	pushint 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	pushint 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

	// tests/contracts/cblocks.algo.ts:276
	// this.byteValue.value = '2'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x32 // "2"
	app_global_put

	// tests/contracts/cblocks.algo.ts:277
	// this.byteValue.value = '3'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x33 // "3"
	app_global_put

	// tests/contracts/cblocks.algo.ts:278
	// this.byteValue.value = '4'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x34 // "4"
	app_global_put

	// tests/contracts/cblocks.algo.ts:279
	// this.byteValue.value = '5'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x35 // "5"
	app_global_put

	// tests/contracts/cblocks.algo.ts:280
	// this.byteValue.value = '6'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x36 // "6"
	app_global_put

	// tests/contracts/cblocks.algo.ts:281
	// this.byteValue.value = '7'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x37 // "7"
	app_global_put

	// tests/contracts/cblocks.algo.ts:282
	// this.byteValue.value = '8'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x38 // "8"
	app_global_put

	// tests/contracts/cblocks.algo.ts:283
	// this.byteValue.value = '9'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x39 // "9"
	app_global_put

	// tests/contracts/cblocks.algo.ts:284
	// this.byteValue.value = '10'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3130 // "10"
	app_global_put

	// tests/contracts/cblocks.algo.ts:285
	// this.byteValue.value = '11'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3131 // "11"
	app_global_put

	// tests/contracts/cblocks.algo.ts:286
	// this.byteValue.value = '12'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3132 // "12"
	app_global_put

	// tests/contracts/cblocks.algo.ts:287
	// this.byteValue.value = '13'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3133 // "13"
	app_global_put

	// tests/contracts/cblocks.algo.ts:288
	// this.byteValue.value = '14'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3134 // "14"
	app_global_put

	// tests/contracts/cblocks.algo.ts:289
	// this.byteValue.value = '15'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3135 // "15"
	app_global_put

	// tests/contracts/cblocks.algo.ts:290
	// this.byteValue.value = '16'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3136 // "16"
	app_global_put

	// tests/contracts/cblocks.algo.ts:291
	// this.byteValue.value = '17'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3137 // "17"
	app_global_put

	// tests/contracts/cblocks.algo.ts:292
	// this.byteValue.value = '18'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3138 // "18"
	app_global_put

	// tests/contracts/cblocks.algo.ts:293
	// this.byteValue.value = '19'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3139 // "19"
	app_global_put

	// tests/contracts/cblocks.algo.ts:294
	// this.byteValue.value = '20'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3230 // "20"
	app_global_put

	// tests/contracts/cblocks.algo.ts:295
	// this.byteValue.value = '21'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3231 // "21"
	app_global_put

	// tests/contracts/cblocks.algo.ts:296
	// this.byteValue.value = '22'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3232 // "22"
	app_global_put

	// tests/contracts/cblocks.algo.ts:297
	// this.byteValue.value = '23'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3233 // "23"
	app_global_put

	// tests/contracts/cblocks.algo.ts:298
	// this.byteValue.value = '24'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3234 // "24"
	app_global_put

	// tests/contracts/cblocks.algo.ts:299
	// this.byteValue.value = '25'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3235 // "25"
	app_global_put

	// tests/contracts/cblocks.algo.ts:300
	// this.byteValue.value = '26'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3236 // "26"
	app_global_put

	// tests/contracts/cblocks.algo.ts:301
	// this.byteValue.value = '27'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3237 // "27"
	app_global_put

	// tests/contracts/cblocks.algo.ts:302
	// this.byteValue.value = '28'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3238 // "28"
	app_global_put

	// tests/contracts/cblocks.algo.ts:303
	// this.byteValue.value = '29'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3239 // "29"
	app_global_put

	// tests/contracts/cblocks.algo.ts:304
	// this.byteValue.value = '30'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3330 // "30"
	app_global_put

	// tests/contracts/cblocks.algo.ts:305
	// this.byteValue.value = '31'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3331 // "31"
	app_global_put

	// tests/contracts/cblocks.algo.ts:306
	// this.byteValue.value = '32'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3332 // "32"
	app_global_put

	// tests/contracts/cblocks.algo.ts:307
	// this.byteValue.value = '33'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3333 // "33"
	app_global_put

	// tests/contracts/cblocks.algo.ts:308
	// this.byteValue.value = '34'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3334 // "34"
	app_global_put

	// tests/contracts/cblocks.algo.ts:309
	// this.byteValue.value = '35'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3335 // "35"
	app_global_put

	// tests/contracts/cblocks.algo.ts:310
	// this.byteValue.value = '36'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3336 // "36"
	app_global_put

	// tests/contracts/cblocks.algo.ts:311
	// this.byteValue.value = '37'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3337 // "37"
	app_global_put

	// tests/contracts/cblocks.algo.ts:312
	// this.byteValue.value = '38'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3338 // "38"
	app_global_put

	// tests/contracts/cblocks.algo.ts:313
	// this.byteValue.value = '39'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3339 // "39"
	app_global_put

	// tests/contracts/cblocks.algo.ts:314
	// this.byteValue.value = '40'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3430 // "40"
	app_global_put

	// tests/contracts/cblocks.algo.ts:315
	// this.byteValue.value = '41'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3431 // "41"
	app_global_put

	// tests/contracts/cblocks.algo.ts:316
	// this.byteValue.value = '42'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3432 // "42"
	app_global_put

	// tests/contracts/cblocks.algo.ts:317
	// this.byteValue.value = '43'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3433 // "43"
	app_global_put

	// tests/contracts/cblocks.algo.ts:318
	// this.byteValue.value = '44'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3434 // "44"
	app_global_put

	// tests/contracts/cblocks.algo.ts:319
	// this.byteValue.value = '45'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3435 // "45"
	app_global_put

	// tests/contracts/cblocks.algo.ts:320
	// this.byteValue.value = '46'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3436 // "46"
	app_global_put

	// tests/contracts/cblocks.algo.ts:321
	// this.byteValue.value = '47'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3437 // "47"
	app_global_put

	// tests/contracts/cblocks.algo.ts:322
	// this.byteValue.value = '48'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3438 // "48"
	app_global_put

	// tests/contracts/cblocks.algo.ts:323
	// this.byteValue.value = '49'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3439 // "49"
	app_global_put

	// tests/contracts/cblocks.algo.ts:324
	// this.byteValue.value = '50'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3530 // "50"
	app_global_put

	// tests/contracts/cblocks.algo.ts:325
	// this.byteValue.value = '51'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3531 // "51"
	app_global_put

	// tests/contracts/cblocks.algo.ts:326
	// this.byteValue.value = '52'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3532 // "52"
	app_global_put

	// tests/contracts/cblocks.algo.ts:327
	// this.byteValue.value = '53'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3533 // "53"
	app_global_put

	// tests/contracts/cblocks.algo.ts:328
	// this.byteValue.value = '54'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3534 // "54"
	app_global_put

	// tests/contracts/cblocks.algo.ts:329
	// this.byteValue.value = '55'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3535 // "55"
	app_global_put

	// tests/contracts/cblocks.algo.ts:330
	// this.byteValue.value = '56'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3536 // "56"
	app_global_put

	// tests/contracts/cblocks.algo.ts:331
	// this.byteValue.value = '57'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3537 // "57"
	app_global_put

	// tests/contracts/cblocks.algo.ts:332
	// this.byteValue.value = '58'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3538 // "58"
	app_global_put

	// tests/contracts/cblocks.algo.ts:333
	// this.byteValue.value = '59'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3539 // "59"
	app_global_put

	// tests/contracts/cblocks.algo.ts:334
	// this.byteValue.value = '60'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3630 // "60"
	app_global_put

	// tests/contracts/cblocks.algo.ts:335
	// this.byteValue.value = '61'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3631 // "61"
	app_global_put

	// tests/contracts/cblocks.algo.ts:336
	// this.byteValue.value = '62'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3632 // "62"
	app_global_put

	// tests/contracts/cblocks.algo.ts:337
	// this.byteValue.value = '63'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3633 // "63"
	app_global_put

	// tests/contracts/cblocks.algo.ts:338
	// this.byteValue.value = '64'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3634 // "64"
	app_global_put

	// tests/contracts/cblocks.algo.ts:339
	// this.byteValue.value = '65'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3635 // "65"
	app_global_put

	// tests/contracts/cblocks.algo.ts:340
	// this.byteValue.value = '66'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3636 // "66"
	app_global_put

	// tests/contracts/cblocks.algo.ts:341
	// this.byteValue.value = '67'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3637 // "67"
	app_global_put

	// tests/contracts/cblocks.algo.ts:342
	// this.byteValue.value = '68'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3638 // "68"
	app_global_put

	// tests/contracts/cblocks.algo.ts:343
	// this.byteValue.value = '69'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3639 // "69"
	app_global_put

	// tests/contracts/cblocks.algo.ts:344
	// this.byteValue.value = '70'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3730 // "70"
	app_global_put

	// tests/contracts/cblocks.algo.ts:345
	// this.byteValue.value = '71'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3731 // "71"
	app_global_put

	// tests/contracts/cblocks.algo.ts:346
	// this.byteValue.value = '72'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3732 // "72"
	app_global_put

	// tests/contracts/cblocks.algo.ts:347
	// this.byteValue.value = '73'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3733 // "73"
	app_global_put

	// tests/contracts/cblocks.algo.ts:348
	// this.byteValue.value = '74'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3734 // "74"
	app_global_put

	// tests/contracts/cblocks.algo.ts:349
	// this.byteValue.value = '75'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3735 // "75"
	app_global_put

	// tests/contracts/cblocks.algo.ts:350
	// this.byteValue.value = '76'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3736 // "76"
	app_global_put

	// tests/contracts/cblocks.algo.ts:351
	// this.byteValue.value = '77'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3737 // "77"
	app_global_put

	// tests/contracts/cblocks.algo.ts:352
	// this.byteValue.value = '78'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3738 // "78"
	app_global_put

	// tests/contracts/cblocks.algo.ts:353
	// this.byteValue.value = '79'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3739 // "79"
	app_global_put

	// tests/contracts/cblocks.algo.ts:354
	// this.byteValue.value = '80'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3830 // "80"
	app_global_put

	// tests/contracts/cblocks.algo.ts:355
	// this.byteValue.value = '81'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3831 // "81"
	app_global_put

	// tests/contracts/cblocks.algo.ts:356
	// this.byteValue.value = '82'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3832 // "82"
	app_global_put

	// tests/contracts/cblocks.algo.ts:357
	// this.byteValue.value = '83'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3833 // "83"
	app_global_put

	// tests/contracts/cblocks.algo.ts:358
	// this.byteValue.value = '84'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3834 // "84"
	app_global_put

	// tests/contracts/cblocks.algo.ts:359
	// this.byteValue.value = '85'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3835 // "85"
	app_global_put

	// tests/contracts/cblocks.algo.ts:360
	// this.byteValue.value = '86'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3836 // "86"
	app_global_put

	// tests/contracts/cblocks.algo.ts:361
	// this.byteValue.value = '87'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3837 // "87"
	app_global_put

	// tests/contracts/cblocks.algo.ts:362
	// this.byteValue.value = '88'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3838 // "88"
	app_global_put

	// tests/contracts/cblocks.algo.ts:363
	// this.byteValue.value = '89'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3839 // "89"
	app_global_put

	// tests/contracts/cblocks.algo.ts:364
	// this.byteValue.value = '90'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3930 // "90"
	app_global_put

	// tests/contracts/cblocks.algo.ts:365
	// this.byteValue.value = '91'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3931 // "91"
	app_global_put

	// tests/contracts/cblocks.algo.ts:366
	// this.byteValue.value = '92'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3932 // "92"
	app_global_put

	// tests/contracts/cblocks.algo.ts:367
	// this.byteValue.value = '93'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3933 // "93"
	app_global_put

	// tests/contracts/cblocks.algo.ts:368
	// this.byteValue.value = '94'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3934 // "94"
	app_global_put

	// tests/contracts/cblocks.algo.ts:369
	// this.byteValue.value = '95'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3935 // "95"
	app_global_put

	// tests/contracts/cblocks.algo.ts:370
	// this.byteValue.value = '96'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3936 // "96"
	app_global_put

	// tests/contracts/cblocks.algo.ts:371
	// this.byteValue.value = '97'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3937 // "97"
	app_global_put

	// tests/contracts/cblocks.algo.ts:372
	// this.byteValue.value = '98'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3938 // "98"
	app_global_put

	// tests/contracts/cblocks.algo.ts:373
	// this.byteValue.value = '99'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3939 // "99"
	app_global_put

	// tests/contracts/cblocks.algo.ts:374
	// this.byteValue.value = '100'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313030 // "100"
	app_global_put

	// tests/contracts/cblocks.algo.ts:375
	// this.byteValue.value = '101'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313031 // "101"
	app_global_put

	// tests/contracts/cblocks.algo.ts:376
	// this.byteValue.value = '102'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313032 // "102"
	app_global_put

	// tests/contracts/cblocks.algo.ts:377
	// this.byteValue.value = '103'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313033 // "103"
	app_global_put

	// tests/contracts/cblocks.algo.ts:378
	// this.byteValue.value = '104'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313034 // "104"
	app_global_put

	// tests/contracts/cblocks.algo.ts:379
	// this.byteValue.value = '105'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313035 // "105"
	app_global_put

	// tests/contracts/cblocks.algo.ts:380
	// this.byteValue.value = '106'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313036 // "106"
	app_global_put

	// tests/contracts/cblocks.algo.ts:381
	// this.byteValue.value = '107'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313037 // "107"
	app_global_put

	// tests/contracts/cblocks.algo.ts:382
	// this.byteValue.value = '108'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313038 // "108"
	app_global_put

	// tests/contracts/cblocks.algo.ts:383
	// this.byteValue.value = '109'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313039 // "109"
	app_global_put

	// tests/contracts/cblocks.algo.ts:384
	// this.byteValue.value = '110'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313130 // "110"
	app_global_put

	// tests/contracts/cblocks.algo.ts:385
	// this.byteValue.value = '111'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313131 // "111"
	app_global_put

	// tests/contracts/cblocks.algo.ts:386
	// this.byteValue.value = '112'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313132 // "112"
	app_global_put

	// tests/contracts/cblocks.algo.ts:387
	// this.byteValue.value = '113'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313133 // "113"
	app_global_put

	// tests/contracts/cblocks.algo.ts:388
	// this.byteValue.value = '114'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313134 // "114"
	app_global_put

	// tests/contracts/cblocks.algo.ts:389
	// this.byteValue.value = '115'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313135 // "115"
	app_global_put

	// tests/contracts/cblocks.algo.ts:390
	// this.byteValue.value = '116'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313136 // "116"
	app_global_put

	// tests/contracts/cblocks.algo.ts:391
	// this.byteValue.value = '117'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313137 // "117"
	app_global_put

	// tests/contracts/cblocks.algo.ts:392
	// this.byteValue.value = '118'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313138 // "118"
	app_global_put

	// tests/contracts/cblocks.algo.ts:393
	// this.byteValue.value = '119'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313139 // "119"
	app_global_put

	// tests/contracts/cblocks.algo.ts:394
	// this.byteValue.value = '120'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313230 // "120"
	app_global_put

	// tests/contracts/cblocks.algo.ts:395
	// this.byteValue.value = '121'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313231 // "121"
	app_global_put

	// tests/contracts/cblocks.algo.ts:396
	// this.byteValue.value = '122'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313232 // "122"
	app_global_put

	// tests/contracts/cblocks.algo.ts:397
	// this.byteValue.value = '123'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313233 // "123"
	app_global_put

	// tests/contracts/cblocks.algo.ts:398
	// this.byteValue.value = '124'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313234 // "124"
	app_global_put

	// tests/contracts/cblocks.algo.ts:399
	// this.byteValue.value = '125'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313235 // "125"
	app_global_put

	// tests/contracts/cblocks.algo.ts:400
	// this.byteValue.value = '126'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313236 // "126"
	app_global_put

	// tests/contracts/cblocks.algo.ts:401
	// this.byteValue.value = '127'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313237 // "127"
	app_global_put

	// tests/contracts/cblocks.algo.ts:402
	// this.byteValue.value = '128'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313238 // "128"
	app_global_put

	// tests/contracts/cblocks.algo.ts:403
	// this.byteValue.value = '129'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313239 // "129"
	app_global_put

	// tests/contracts/cblocks.algo.ts:404
	// this.byteValue.value = '130'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313330 // "130"
	app_global_put

	// tests/contracts/cblocks.algo.ts:405
	// this.byteValue.value = '131'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313331 // "131"
	app_global_put

	// tests/contracts/cblocks.algo.ts:406
	// this.byteValue.value = '132'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313332 // "132"
	app_global_put

	// tests/contracts/cblocks.algo.ts:407
	// this.byteValue.value = '133'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313333 // "133"
	app_global_put

	// tests/contracts/cblocks.algo.ts:408
	// this.byteValue.value = '134'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313334 // "134"
	app_global_put

	// tests/contracts/cblocks.algo.ts:409
	// this.byteValue.value = '135'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313335 // "135"
	app_global_put

	// tests/contracts/cblocks.algo.ts:410
	// this.byteValue.value = '136'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313336 // "136"
	app_global_put

	// tests/contracts/cblocks.algo.ts:411
	// this.byteValue.value = '137'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313337 // "137"
	app_global_put

	// tests/contracts/cblocks.algo.ts:412
	// this.byteValue.value = '138'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313338 // "138"
	app_global_put

	// tests/contracts/cblocks.algo.ts:413
	// this.byteValue.value = '139'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313339 // "139"
	app_global_put

	// tests/contracts/cblocks.algo.ts:414
	// this.byteValue.value = '140'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313430 // "140"
	app_global_put

	// tests/contracts/cblocks.algo.ts:415
	// this.byteValue.value = '141'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313431 // "141"
	app_global_put

	// tests/contracts/cblocks.algo.ts:416
	// this.byteValue.value = '142'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313432 // "142"
	app_global_put

	// tests/contracts/cblocks.algo.ts:417
	// this.byteValue.value = '143'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313433 // "143"
	app_global_put

	// tests/contracts/cblocks.algo.ts:418
	// this.byteValue.value = '144'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313434 // "144"
	app_global_put

	// tests/contracts/cblocks.algo.ts:419
	// this.byteValue.value = '145'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313435 // "145"
	app_global_put

	// tests/contracts/cblocks.algo.ts:420
	// this.byteValue.value = '146'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313436 // "146"
	app_global_put

	// tests/contracts/cblocks.algo.ts:421
	// this.byteValue.value = '147'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313437 // "147"
	app_global_put

	// tests/contracts/cblocks.algo.ts:422
	// this.byteValue.value = '148'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313438 // "148"
	app_global_put

	// tests/contracts/cblocks.algo.ts:423
	// this.byteValue.value = '149'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313439 // "149"
	app_global_put

	// tests/contracts/cblocks.algo.ts:424
	// this.byteValue.value = '150'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313530 // "150"
	app_global_put

	// tests/contracts/cblocks.algo.ts:425
	// this.byteValue.value = '151'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313531 // "151"
	app_global_put

	// tests/contracts/cblocks.algo.ts:426
	// this.byteValue.value = '152'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313532 // "152"
	app_global_put

	// tests/contracts/cblocks.algo.ts:427
	// this.byteValue.value = '153'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313533 // "153"
	app_global_put

	// tests/contracts/cblocks.algo.ts:428
	// this.byteValue.value = '154'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313534 // "154"
	app_global_put

	// tests/contracts/cblocks.algo.ts:429
	// this.byteValue.value = '155'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313535 // "155"
	app_global_put

	// tests/contracts/cblocks.algo.ts:430
	// this.byteValue.value = '156'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313536 // "156"
	app_global_put

	// tests/contracts/cblocks.algo.ts:431
	// this.byteValue.value = '157'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313537 // "157"
	app_global_put

	// tests/contracts/cblocks.algo.ts:432
	// this.byteValue.value = '158'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313538 // "158"
	app_global_put

	// tests/contracts/cblocks.algo.ts:433
	// this.byteValue.value = '159'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313539 // "159"
	app_global_put

	// tests/contracts/cblocks.algo.ts:434
	// this.byteValue.value = '160'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313630 // "160"
	app_global_put

	// tests/contracts/cblocks.algo.ts:435
	// this.byteValue.value = '161'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313631 // "161"
	app_global_put

	// tests/contracts/cblocks.algo.ts:436
	// this.byteValue.value = '162'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313632 // "162"
	app_global_put

	// tests/contracts/cblocks.algo.ts:437
	// this.byteValue.value = '163'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313633 // "163"
	app_global_put

	// tests/contracts/cblocks.algo.ts:438
	// this.byteValue.value = '164'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313634 // "164"
	app_global_put

	// tests/contracts/cblocks.algo.ts:439
	// this.byteValue.value = '165'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313635 // "165"
	app_global_put

	// tests/contracts/cblocks.algo.ts:440
	// this.byteValue.value = '166'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313636 // "166"
	app_global_put

	// tests/contracts/cblocks.algo.ts:441
	// this.byteValue.value = '167'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313637 // "167"
	app_global_put

	// tests/contracts/cblocks.algo.ts:442
	// this.byteValue.value = '168'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313638 // "168"
	app_global_put

	// tests/contracts/cblocks.algo.ts:443
	// this.byteValue.value = '169'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313639 // "169"
	app_global_put

	// tests/contracts/cblocks.algo.ts:444
	// this.byteValue.value = '170'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313730 // "170"
	app_global_put

	// tests/contracts/cblocks.algo.ts:445
	// this.byteValue.value = '171'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313731 // "171"
	app_global_put

	// tests/contracts/cblocks.algo.ts:446
	// this.byteValue.value = '172'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313732 // "172"
	app_global_put

	// tests/contracts/cblocks.algo.ts:447
	// this.byteValue.value = '173'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313733 // "173"
	app_global_put

	// tests/contracts/cblocks.algo.ts:448
	// this.byteValue.value = '174'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313734 // "174"
	app_global_put

	// tests/contracts/cblocks.algo.ts:449
	// this.byteValue.value = '175'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313735 // "175"
	app_global_put

	// tests/contracts/cblocks.algo.ts:450
	// this.byteValue.value = '176'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313736 // "176"
	app_global_put

	// tests/contracts/cblocks.algo.ts:451
	// this.byteValue.value = '177'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313737 // "177"
	app_global_put

	// tests/contracts/cblocks.algo.ts:452
	// this.byteValue.value = '178'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313738 // "178"
	app_global_put

	// tests/contracts/cblocks.algo.ts:453
	// this.byteValue.value = '179'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313739 // "179"
	app_global_put

	// tests/contracts/cblocks.algo.ts:454
	// this.byteValue.value = '180'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313830 // "180"
	app_global_put

	// tests/contracts/cblocks.algo.ts:455
	// this.byteValue.value = '181'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313831 // "181"
	app_global_put

	// tests/contracts/cblocks.algo.ts:456
	// this.byteValue.value = '182'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313832 // "182"
	app_global_put

	// tests/contracts/cblocks.algo.ts:457
	// this.byteValue.value = '183'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313833 // "183"
	app_global_put

	// tests/contracts/cblocks.algo.ts:458
	// this.byteValue.value = '184'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313834 // "184"
	app_global_put

	// tests/contracts/cblocks.algo.ts:459
	// this.byteValue.value = '185'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313835 // "185"
	app_global_put

	// tests/contracts/cblocks.algo.ts:460
	// this.byteValue.value = '186'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313836 // "186"
	app_global_put

	// tests/contracts/cblocks.algo.ts:461
	// this.byteValue.value = '187'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313837 // "187"
	app_global_put

	// tests/contracts/cblocks.algo.ts:462
	// this.byteValue.value = '188'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313838 // "188"
	app_global_put

	// tests/contracts/cblocks.algo.ts:463
	// this.byteValue.value = '189'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313839 // "189"
	app_global_put

	// tests/contracts/cblocks.algo.ts:464
	// this.byteValue.value = '190'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313930 // "190"
	app_global_put

	// tests/contracts/cblocks.algo.ts:465
	// this.byteValue.value = '191'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313931 // "191"
	app_global_put

	// tests/contracts/cblocks.algo.ts:466
	// this.byteValue.value = '192'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313932 // "192"
	app_global_put

	// tests/contracts/cblocks.algo.ts:467
	// this.byteValue.value = '193'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313933 // "193"
	app_global_put

	// tests/contracts/cblocks.algo.ts:468
	// this.byteValue.value = '194'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313934 // "194"
	app_global_put

	// tests/contracts/cblocks.algo.ts:469
	// this.byteValue.value = '195'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313935 // "195"
	app_global_put

	// tests/contracts/cblocks.algo.ts:470
	// this.byteValue.value = '196'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313936 // "196"
	app_global_put

	// tests/contracts/cblocks.algo.ts:471
	// this.byteValue.value = '197'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313937 // "197"
	app_global_put

	// tests/contracts/cblocks.algo.ts:472
	// this.byteValue.value = '198'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313938 // "198"
	app_global_put

	// tests/contracts/cblocks.algo.ts:473
	// this.byteValue.value = '199'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313939 // "199"
	app_global_put

	// tests/contracts/cblocks.algo.ts:474
	// this.byteValue.value = '200'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323030 // "200"
	app_global_put

	// tests/contracts/cblocks.algo.ts:475
	// this.byteValue.value = '201'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323031 // "201"
	app_global_put

	// tests/contracts/cblocks.algo.ts:476
	// this.byteValue.value = '202'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323032 // "202"
	app_global_put

	// tests/contracts/cblocks.algo.ts:477
	// this.byteValue.value = '203'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323033 // "203"
	app_global_put

	// tests/contracts/cblocks.algo.ts:478
	// this.byteValue.value = '204'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323034 // "204"
	app_global_put

	// tests/contracts/cblocks.algo.ts:479
	// this.byteValue.value = '205'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323035 // "205"
	app_global_put

	// tests/contracts/cblocks.algo.ts:480
	// this.byteValue.value = '206'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323036 // "206"
	app_global_put

	// tests/contracts/cblocks.algo.ts:481
	// this.byteValue.value = '207'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323037 // "207"
	app_global_put

	// tests/contracts/cblocks.algo.ts:482
	// this.byteValue.value = '208'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323038 // "208"
	app_global_put

	// tests/contracts/cblocks.algo.ts:483
	// this.byteValue.value = '209'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323039 // "209"
	app_global_put

	// tests/contracts/cblocks.algo.ts:484
	// this.byteValue.value = '210'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323130 // "210"
	app_global_put

	// tests/contracts/cblocks.algo.ts:485
	// this.byteValue.value = '211'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323131 // "211"
	app_global_put

	// tests/contracts/cblocks.algo.ts:486
	// this.byteValue.value = '212'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323132 // "212"
	app_global_put

	// tests/contracts/cblocks.algo.ts:487
	// this.byteValue.value = '213'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323133 // "213"
	app_global_put

	// tests/contracts/cblocks.algo.ts:488
	// this.byteValue.value = '214'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323134 // "214"
	app_global_put

	// tests/contracts/cblocks.algo.ts:489
	// this.byteValue.value = '215'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323135 // "215"
	app_global_put

	// tests/contracts/cblocks.algo.ts:490
	// this.byteValue.value = '216'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323136 // "216"
	app_global_put

	// tests/contracts/cblocks.algo.ts:491
	// this.byteValue.value = '217'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323137 // "217"
	app_global_put

	// tests/contracts/cblocks.algo.ts:492
	// this.byteValue.value = '218'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323138 // "218"
	app_global_put

	// tests/contracts/cblocks.algo.ts:493
	// this.byteValue.value = '219'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323139 // "219"
	app_global_put

	// tests/contracts/cblocks.algo.ts:494
	// this.byteValue.value = '220'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323230 // "220"
	app_global_put

	// tests/contracts/cblocks.algo.ts:495
	// this.byteValue.value = '221'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323231 // "221"
	app_global_put

	// tests/contracts/cblocks.algo.ts:496
	// this.byteValue.value = '222'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323232 // "222"
	app_global_put

	// tests/contracts/cblocks.algo.ts:497
	// this.byteValue.value = '223'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323233 // "223"
	app_global_put

	// tests/contracts/cblocks.algo.ts:498
	// this.byteValue.value = '224'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323234 // "224"
	app_global_put

	// tests/contracts/cblocks.algo.ts:499
	// this.byteValue.value = '225'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323235 // "225"
	app_global_put

	// tests/contracts/cblocks.algo.ts:500
	// this.byteValue.value = '226'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323236 // "226"
	app_global_put

	// tests/contracts/cblocks.algo.ts:501
	// this.byteValue.value = '227'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323237 // "227"
	app_global_put

	// tests/contracts/cblocks.algo.ts:502
	// this.byteValue.value = '228'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323238 // "228"
	app_global_put

	// tests/contracts/cblocks.algo.ts:503
	// this.byteValue.value = '229'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323239 // "229"
	app_global_put

	// tests/contracts/cblocks.algo.ts:504
	// this.byteValue.value = '230'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323330 // "230"
	app_global_put

	// tests/contracts/cblocks.algo.ts:505
	// this.byteValue.value = '231'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323331 // "231"
	app_global_put

	// tests/contracts/cblocks.algo.ts:506
	// this.byteValue.value = '232'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323332 // "232"
	app_global_put

	// tests/contracts/cblocks.algo.ts:507
	// this.byteValue.value = '233'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323333 // "233"
	app_global_put

	// tests/contracts/cblocks.algo.ts:508
	// this.byteValue.value = '234'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323334 // "234"
	app_global_put

	// tests/contracts/cblocks.algo.ts:509
	// this.byteValue.value = '235'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323335 // "235"
	app_global_put

	// tests/contracts/cblocks.algo.ts:510
	// this.byteValue.value = '236'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323336 // "236"
	app_global_put

	// tests/contracts/cblocks.algo.ts:511
	// this.byteValue.value = '237'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323337 // "237"
	app_global_put

	// tests/contracts/cblocks.algo.ts:512
	// this.byteValue.value = '238'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323338 // "238"
	app_global_put

	// tests/contracts/cblocks.algo.ts:513
	// this.byteValue.value = '239'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323339 // "239"
	app_global_put

	// tests/contracts/cblocks.algo.ts:514
	// this.byteValue.value = '240'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323430 // "240"
	app_global_put

	// tests/contracts/cblocks.algo.ts:515
	// this.byteValue.value = '241'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323431 // "241"
	app_global_put

	// tests/contracts/cblocks.algo.ts:516
	// this.byteValue.value = '242'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323432 // "242"
	app_global_put

	// tests/contracts/cblocks.algo.ts:517
	// this.byteValue.value = '243'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323433 // "243"
	app_global_put

	// tests/contracts/cblocks.algo.ts:518
	// this.byteValue.value = '244'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323434 // "244"
	app_global_put

	// tests/contracts/cblocks.algo.ts:519
	// this.byteValue.value = '245'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323435 // "245"
	app_global_put

	// tests/contracts/cblocks.algo.ts:520
	// this.byteValue.value = '246'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323436 // "246"
	app_global_put

	// tests/contracts/cblocks.algo.ts:521
	// this.byteValue.value = '247'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323437 // "247"
	app_global_put

	// tests/contracts/cblocks.algo.ts:522
	// this.byteValue.value = '248'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323438 // "248"
	app_global_put

	// tests/contracts/cblocks.algo.ts:523
	// this.byteValue.value = '249'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323439 // "249"
	app_global_put

	// tests/contracts/cblocks.algo.ts:524
	// this.byteValue.value = '250'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323530 // "250"
	app_global_put

	// tests/contracts/cblocks.algo.ts:525
	// this.byteValue.value = '251'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323531 // "251"
	app_global_put

	// tests/contracts/cblocks.algo.ts:526
	// this.byteValue.value = '252'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323532 // "252"
	app_global_put

	// tests/contracts/cblocks.algo.ts:527
	// this.byteValue.value = '253'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323533 // "253"
	app_global_put

	// tests/contracts/cblocks.algo.ts:528
	// this.byteValue.value = '254'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323534 // "254"
	app_global_put

	// tests/contracts/cblocks.algo.ts:529
	// this.byteValue.value = '255'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323535 // "255"
	app_global_put

	// tests/contracts/cblocks.algo.ts:530
	// this.byteValue.value = '256'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323536 // "256"
	app_global_put

	// tests/contracts/cblocks.algo.ts:532
	// this.byteValue.value =
	//       'This is a fairly long byteslice that should be put in the consant block because it is so long'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x54686973206973206120666169726c79206c6f6e672062797465736c69636520746861742073686f756c642062652070757420696e2074686520636f6e73616e7420626c6f636b206265636175736520697420697320736f206c6f6e67 // "This is a fairly long byteslice that should be put in the consant block because it is so long"
	app_global_put

	// tests/contracts/cblocks.algo.ts:535
	// return a + b;
	pushbytes "1"
	pushbytes "257"
	concat
	retsub

*abi_route_createApplication:
	pushint 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0xb13757d2 // method "largeBytecblock()string"
	txna ApplicationArgs 0
	match *abi_route_largeBytecblock

	// this contract does not implement the given ABI method for call NoOp
	err", + "approval": "#pragma version 10
bytecblock 0x6279746556616c7565 0x0a8101

// This TEAL was generated by TEALScript v0.105.0
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// largeBytecblock()string
*abi_route_largeBytecblock:
	// The ABI return prefix
	pushbytes 0x151f7c75

	// execute largeBytecblock()string
	callsub largeBytecblock
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	pushint 1
	return

// largeBytecblock(): string
largeBytecblock:
	proto 0 1

	// tests/contracts/cblocks.algo.ts:274
	// increaseOpcodeBudget()
	itxn_begin
	pushint 6 // appl
	itxn_field TypeEnum
	pushint 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	pushint 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

	// tests/contracts/cblocks.algo.ts:276
	// this.byteValue.value = '2'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x32 // "2"
	app_global_put

	// tests/contracts/cblocks.algo.ts:277
	// this.byteValue.value = '3'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x33 // "3"
	app_global_put

	// tests/contracts/cblocks.algo.ts:278
	// this.byteValue.value = '4'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x34 // "4"
	app_global_put

	// tests/contracts/cblocks.algo.ts:279
	// this.byteValue.value = '5'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x35 // "5"
	app_global_put

	// tests/contracts/cblocks.algo.ts:280
	// this.byteValue.value = '6'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x36 // "6"
	app_global_put

	// tests/contracts/cblocks.algo.ts:281
	// this.byteValue.value = '7'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x37 // "7"
	app_global_put

	// tests/contracts/cblocks.algo.ts:282
	// this.byteValue.value = '8'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x38 // "8"
	app_global_put

	// tests/contracts/cblocks.algo.ts:283
	// this.byteValue.value = '9'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x39 // "9"
	app_global_put

	// tests/contracts/cblocks.algo.ts:284
	// this.byteValue.value = '10'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3130 // "10"
	app_global_put

	// tests/contracts/cblocks.algo.ts:285
	// this.byteValue.value = '11'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3131 // "11"
	app_global_put

	// tests/contracts/cblocks.algo.ts:286
	// this.byteValue.value = '12'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3132 // "12"
	app_global_put

	// tests/contracts/cblocks.algo.ts:287
	// this.byteValue.value = '13'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3133 // "13"
	app_global_put

	// tests/contracts/cblocks.algo.ts:288
	// this.byteValue.value = '14'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3134 // "14"
	app_global_put

	// tests/contracts/cblocks.algo.ts:289
	// this.byteValue.value = '15'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3135 // "15"
	app_global_put

	// tests/contracts/cblocks.algo.ts:290
	// this.byteValue.value = '16'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3136 // "16"
	app_global_put

	// tests/contracts/cblocks.algo.ts:291
	// this.byteValue.value = '17'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3137 // "17"
	app_global_put

	// tests/contracts/cblocks.algo.ts:292
	// this.byteValue.value = '18'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3138 // "18"
	app_global_put

	// tests/contracts/cblocks.algo.ts:293
	// this.byteValue.value = '19'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3139 // "19"
	app_global_put

	// tests/contracts/cblocks.algo.ts:294
	// this.byteValue.value = '20'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3230 // "20"
	app_global_put

	// tests/contracts/cblocks.algo.ts:295
	// this.byteValue.value = '21'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3231 // "21"
	app_global_put

	// tests/contracts/cblocks.algo.ts:296
	// this.byteValue.value = '22'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3232 // "22"
	app_global_put

	// tests/contracts/cblocks.algo.ts:297
	// this.byteValue.value = '23'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3233 // "23"
	app_global_put

	// tests/contracts/cblocks.algo.ts:298
	// this.byteValue.value = '24'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3234 // "24"
	app_global_put

	// tests/contracts/cblocks.algo.ts:299
	// this.byteValue.value = '25'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3235 // "25"
	app_global_put

	// tests/contracts/cblocks.algo.ts:300
	// this.byteValue.value = '26'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3236 // "26"
	app_global_put

	// tests/contracts/cblocks.algo.ts:301
	// this.byteValue.value = '27'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3237 // "27"
	app_global_put

	// tests/contracts/cblocks.algo.ts:302
	// this.byteValue.value = '28'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3238 // "28"
	app_global_put

	// tests/contracts/cblocks.algo.ts:303
	// this.byteValue.value = '29'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3239 // "29"
	app_global_put

	// tests/contracts/cblocks.algo.ts:304
	// this.byteValue.value = '30'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3330 // "30"
	app_global_put

	// tests/contracts/cblocks.algo.ts:305
	// this.byteValue.value = '31'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3331 // "31"
	app_global_put

	// tests/contracts/cblocks.algo.ts:306
	// this.byteValue.value = '32'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3332 // "32"
	app_global_put

	// tests/contracts/cblocks.algo.ts:307
	// this.byteValue.value = '33'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3333 // "33"
	app_global_put

	// tests/contracts/cblocks.algo.ts:308
	// this.byteValue.value = '34'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3334 // "34"
	app_global_put

	// tests/contracts/cblocks.algo.ts:309
	// this.byteValue.value = '35'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3335 // "35"
	app_global_put

	// tests/contracts/cblocks.algo.ts:310
	// this.byteValue.value = '36'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3336 // "36"
	app_global_put

	// tests/contracts/cblocks.algo.ts:311
	// this.byteValue.value = '37'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3337 // "37"
	app_global_put

	// tests/contracts/cblocks.algo.ts:312
	// this.byteValue.value = '38'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3338 // "38"
	app_global_put

	// tests/contracts/cblocks.algo.ts:313
	// this.byteValue.value = '39'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3339 // "39"
	app_global_put

	// tests/contracts/cblocks.algo.ts:314
	// this.byteValue.value = '40'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3430 // "40"
	app_global_put

	// tests/contracts/cblocks.algo.ts:315
	// this.byteValue.value = '41'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3431 // "41"
	app_global_put

	// tests/contracts/cblocks.algo.ts:316
	// this.byteValue.value = '42'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3432 // "42"
	app_global_put

	// tests/contracts/cblocks.algo.ts:317
	// this.byteValue.value = '43'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3433 // "43"
	app_global_put

	// tests/contracts/cblocks.algo.ts:318
	// this.byteValue.value = '44'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3434 // "44"
	app_global_put

	// tests/contracts/cblocks.algo.ts:319
	// this.byteValue.value = '45'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3435 // "45"
	app_global_put

	// tests/contracts/cblocks.algo.ts:320
	// this.byteValue.value = '46'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3436 // "46"
	app_global_put

	// tests/contracts/cblocks.algo.ts:321
	// this.byteValue.value = '47'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3437 // "47"
	app_global_put

	// tests/contracts/cblocks.algo.ts:322
	// this.byteValue.value = '48'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3438 // "48"
	app_global_put

	// tests/contracts/cblocks.algo.ts:323
	// this.byteValue.value = '49'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3439 // "49"
	app_global_put

	// tests/contracts/cblocks.algo.ts:324
	// this.byteValue.value = '50'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3530 // "50"
	app_global_put

	// tests/contracts/cblocks.algo.ts:325
	// this.byteValue.value = '51'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3531 // "51"
	app_global_put

	// tests/contracts/cblocks.algo.ts:326
	// this.byteValue.value = '52'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3532 // "52"
	app_global_put

	// tests/contracts/cblocks.algo.ts:327
	// this.byteValue.value = '53'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3533 // "53"
	app_global_put

	// tests/contracts/cblocks.algo.ts:328
	// this.byteValue.value = '54'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3534 // "54"
	app_global_put

	// tests/contracts/cblocks.algo.ts:329
	// this.byteValue.value = '55'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3535 // "55"
	app_global_put

	// tests/contracts/cblocks.algo.ts:330
	// this.byteValue.value = '56'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3536 // "56"
	app_global_put

	// tests/contracts/cblocks.algo.ts:331
	// this.byteValue.value = '57'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3537 // "57"
	app_global_put

	// tests/contracts/cblocks.algo.ts:332
	// this.byteValue.value = '58'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3538 // "58"
	app_global_put

	// tests/contracts/cblocks.algo.ts:333
	// this.byteValue.value = '59'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3539 // "59"
	app_global_put

	// tests/contracts/cblocks.algo.ts:334
	// this.byteValue.value = '60'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3630 // "60"
	app_global_put

	// tests/contracts/cblocks.algo.ts:335
	// this.byteValue.value = '61'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3631 // "61"
	app_global_put

	// tests/contracts/cblocks.algo.ts:336
	// this.byteValue.value = '62'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3632 // "62"
	app_global_put

	// tests/contracts/cblocks.algo.ts:337
	// this.byteValue.value = '63'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3633 // "63"
	app_global_put

	// tests/contracts/cblocks.algo.ts:338
	// this.byteValue.value = '64'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3634 // "64"
	app_global_put

	// tests/contracts/cblocks.algo.ts:339
	// this.byteValue.value = '65'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3635 // "65"
	app_global_put

	// tests/contracts/cblocks.algo.ts:340
	// this.byteValue.value = '66'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3636 // "66"
	app_global_put

	// tests/contracts/cblocks.algo.ts:341
	// this.byteValue.value = '67'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3637 // "67"
	app_global_put

	// tests/contracts/cblocks.algo.ts:342
	// this.byteValue.value = '68'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3638 // "68"
	app_global_put

	// tests/contracts/cblocks.algo.ts:343
	// this.byteValue.value = '69'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3639 // "69"
	app_global_put

	// tests/contracts/cblocks.algo.ts:344
	// this.byteValue.value = '70'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3730 // "70"
	app_global_put

	// tests/contracts/cblocks.algo.ts:345
	// this.byteValue.value = '71'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3731 // "71"
	app_global_put

	// tests/contracts/cblocks.algo.ts:346
	// this.byteValue.value = '72'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3732 // "72"
	app_global_put

	// tests/contracts/cblocks.algo.ts:347
	// this.byteValue.value = '73'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3733 // "73"
	app_global_put

	// tests/contracts/cblocks.algo.ts:348
	// this.byteValue.value = '74'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3734 // "74"
	app_global_put

	// tests/contracts/cblocks.algo.ts:349
	// this.byteValue.value = '75'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3735 // "75"
	app_global_put

	// tests/contracts/cblocks.algo.ts:350
	// this.byteValue.value = '76'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3736 // "76"
	app_global_put

	// tests/contracts/cblocks.algo.ts:351
	// this.byteValue.value = '77'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3737 // "77"
	app_global_put

	// tests/contracts/cblocks.algo.ts:352
	// this.byteValue.value = '78'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3738 // "78"
	app_global_put

	// tests/contracts/cblocks.algo.ts:353
	// this.byteValue.value = '79'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3739 // "79"
	app_global_put

	// tests/contracts/cblocks.algo.ts:354
	// this.byteValue.value = '80'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3830 // "80"
	app_global_put

	// tests/contracts/cblocks.algo.ts:355
	// this.byteValue.value = '81'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3831 // "81"
	app_global_put

	// tests/contracts/cblocks.algo.ts:356
	// this.byteValue.value = '82'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3832 // "82"
	app_global_put

	// tests/contracts/cblocks.algo.ts:357
	// this.byteValue.value = '83'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3833 // "83"
	app_global_put

	// tests/contracts/cblocks.algo.ts:358
	// this.byteValue.value = '84'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3834 // "84"
	app_global_put

	// tests/contracts/cblocks.algo.ts:359
	// this.byteValue.value = '85'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3835 // "85"
	app_global_put

	// tests/contracts/cblocks.algo.ts:360
	// this.byteValue.value = '86'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3836 // "86"
	app_global_put

	// tests/contracts/cblocks.algo.ts:361
	// this.byteValue.value = '87'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3837 // "87"
	app_global_put

	// tests/contracts/cblocks.algo.ts:362
	// this.byteValue.value = '88'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3838 // "88"
	app_global_put

	// tests/contracts/cblocks.algo.ts:363
	// this.byteValue.value = '89'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3839 // "89"
	app_global_put

	// tests/contracts/cblocks.algo.ts:364
	// this.byteValue.value = '90'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3930 // "90"
	app_global_put

	// tests/contracts/cblocks.algo.ts:365
	// this.byteValue.value = '91'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3931 // "91"
	app_global_put

	// tests/contracts/cblocks.algo.ts:366
	// this.byteValue.value = '92'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3932 // "92"
	app_global_put

	// tests/contracts/cblocks.algo.ts:367
	// this.byteValue.value = '93'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3933 // "93"
	app_global_put

	// tests/contracts/cblocks.algo.ts:368
	// this.byteValue.value = '94'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3934 // "94"
	app_global_put

	// tests/contracts/cblocks.algo.ts:369
	// this.byteValue.value = '95'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3935 // "95"
	app_global_put

	// tests/contracts/cblocks.algo.ts:370
	// this.byteValue.value = '96'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3936 // "96"
	app_global_put

	// tests/contracts/cblocks.algo.ts:371
	// this.byteValue.value = '97'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3937 // "97"
	app_global_put

	// tests/contracts/cblocks.algo.ts:372
	// this.byteValue.value = '98'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3938 // "98"
	app_global_put

	// tests/contracts/cblocks.algo.ts:373
	// this.byteValue.value = '99'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x3939 // "99"
	app_global_put

	// tests/contracts/cblocks.algo.ts:374
	// this.byteValue.value = '100'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313030 // "100"
	app_global_put

	// tests/contracts/cblocks.algo.ts:375
	// this.byteValue.value = '101'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313031 // "101"
	app_global_put

	// tests/contracts/cblocks.algo.ts:376
	// this.byteValue.value = '102'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313032 // "102"
	app_global_put

	// tests/contracts/cblocks.algo.ts:377
	// this.byteValue.value = '103'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313033 // "103"
	app_global_put

	// tests/contracts/cblocks.algo.ts:378
	// this.byteValue.value = '104'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313034 // "104"
	app_global_put

	// tests/contracts/cblocks.algo.ts:379
	// this.byteValue.value = '105'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313035 // "105"
	app_global_put

	// tests/contracts/cblocks.algo.ts:380
	// this.byteValue.value = '106'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313036 // "106"
	app_global_put

	// tests/contracts/cblocks.algo.ts:381
	// this.byteValue.value = '107'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313037 // "107"
	app_global_put

	// tests/contracts/cblocks.algo.ts:382
	// this.byteValue.value = '108'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313038 // "108"
	app_global_put

	// tests/contracts/cblocks.algo.ts:383
	// this.byteValue.value = '109'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313039 // "109"
	app_global_put

	// tests/contracts/cblocks.algo.ts:384
	// this.byteValue.value = '110'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313130 // "110"
	app_global_put

	// tests/contracts/cblocks.algo.ts:385
	// this.byteValue.value = '111'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313131 // "111"
	app_global_put

	// tests/contracts/cblocks.algo.ts:386
	// this.byteValue.value = '112'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313132 // "112"
	app_global_put

	// tests/contracts/cblocks.algo.ts:387
	// this.byteValue.value = '113'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313133 // "113"
	app_global_put

	// tests/contracts/cblocks.algo.ts:388
	// this.byteValue.value = '114'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313134 // "114"
	app_global_put

	// tests/contracts/cblocks.algo.ts:389
	// this.byteValue.value = '115'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313135 // "115"
	app_global_put

	// tests/contracts/cblocks.algo.ts:390
	// this.byteValue.value = '116'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313136 // "116"
	app_global_put

	// tests/contracts/cblocks.algo.ts:391
	// this.byteValue.value = '117'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313137 // "117"
	app_global_put

	// tests/contracts/cblocks.algo.ts:392
	// this.byteValue.value = '118'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313138 // "118"
	app_global_put

	// tests/contracts/cblocks.algo.ts:393
	// this.byteValue.value = '119'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313139 // "119"
	app_global_put

	// tests/contracts/cblocks.algo.ts:394
	// this.byteValue.value = '120'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313230 // "120"
	app_global_put

	// tests/contracts/cblocks.algo.ts:395
	// this.byteValue.value = '121'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313231 // "121"
	app_global_put

	// tests/contracts/cblocks.algo.ts:396
	// this.byteValue.value = '122'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313232 // "122"
	app_global_put

	// tests/contracts/cblocks.algo.ts:397
	// this.byteValue.value = '123'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313233 // "123"
	app_global_put

	// tests/contracts/cblocks.algo.ts:398
	// this.byteValue.value = '124'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313234 // "124"
	app_global_put

	// tests/contracts/cblocks.algo.ts:399
	// this.byteValue.value = '125'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313235 // "125"
	app_global_put

	// tests/contracts/cblocks.algo.ts:400
	// this.byteValue.value = '126'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313236 // "126"
	app_global_put

	// tests/contracts/cblocks.algo.ts:401
	// this.byteValue.value = '127'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313237 // "127"
	app_global_put

	// tests/contracts/cblocks.algo.ts:402
	// this.byteValue.value = '128'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313238 // "128"
	app_global_put

	// tests/contracts/cblocks.algo.ts:403
	// this.byteValue.value = '129'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313239 // "129"
	app_global_put

	// tests/contracts/cblocks.algo.ts:404
	// this.byteValue.value = '130'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313330 // "130"
	app_global_put

	// tests/contracts/cblocks.algo.ts:405
	// this.byteValue.value = '131'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313331 // "131"
	app_global_put

	// tests/contracts/cblocks.algo.ts:406
	// this.byteValue.value = '132'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313332 // "132"
	app_global_put

	// tests/contracts/cblocks.algo.ts:407
	// this.byteValue.value = '133'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313333 // "133"
	app_global_put

	// tests/contracts/cblocks.algo.ts:408
	// this.byteValue.value = '134'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313334 // "134"
	app_global_put

	// tests/contracts/cblocks.algo.ts:409
	// this.byteValue.value = '135'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313335 // "135"
	app_global_put

	// tests/contracts/cblocks.algo.ts:410
	// this.byteValue.value = '136'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313336 // "136"
	app_global_put

	// tests/contracts/cblocks.algo.ts:411
	// this.byteValue.value = '137'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313337 // "137"
	app_global_put

	// tests/contracts/cblocks.algo.ts:412
	// this.byteValue.value = '138'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313338 // "138"
	app_global_put

	// tests/contracts/cblocks.algo.ts:413
	// this.byteValue.value = '139'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313339 // "139"
	app_global_put

	// tests/contracts/cblocks.algo.ts:414
	// this.byteValue.value = '140'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313430 // "140"
	app_global_put

	// tests/contracts/cblocks.algo.ts:415
	// this.byteValue.value = '141'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313431 // "141"
	app_global_put

	// tests/contracts/cblocks.algo.ts:416
	// this.byteValue.value = '142'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313432 // "142"
	app_global_put

	// tests/contracts/cblocks.algo.ts:417
	// this.byteValue.value = '143'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313433 // "143"
	app_global_put

	// tests/contracts/cblocks.algo.ts:418
	// this.byteValue.value = '144'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313434 // "144"
	app_global_put

	// tests/contracts/cblocks.algo.ts:419
	// this.byteValue.value = '145'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313435 // "145"
	app_global_put

	// tests/contracts/cblocks.algo.ts:420
	// this.byteValue.value = '146'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313436 // "146"
	app_global_put

	// tests/contracts/cblocks.algo.ts:421
	// this.byteValue.value = '147'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313437 // "147"
	app_global_put

	// tests/contracts/cblocks.algo.ts:422
	// this.byteValue.value = '148'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313438 // "148"
	app_global_put

	// tests/contracts/cblocks.algo.ts:423
	// this.byteValue.value = '149'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313439 // "149"
	app_global_put

	// tests/contracts/cblocks.algo.ts:424
	// this.byteValue.value = '150'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313530 // "150"
	app_global_put

	// tests/contracts/cblocks.algo.ts:425
	// this.byteValue.value = '151'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313531 // "151"
	app_global_put

	// tests/contracts/cblocks.algo.ts:426
	// this.byteValue.value = '152'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313532 // "152"
	app_global_put

	// tests/contracts/cblocks.algo.ts:427
	// this.byteValue.value = '153'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313533 // "153"
	app_global_put

	// tests/contracts/cblocks.algo.ts:428
	// this.byteValue.value = '154'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313534 // "154"
	app_global_put

	// tests/contracts/cblocks.algo.ts:429
	// this.byteValue.value = '155'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313535 // "155"
	app_global_put

	// tests/contracts/cblocks.algo.ts:430
	// this.byteValue.value = '156'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313536 // "156"
	app_global_put

	// tests/contracts/cblocks.algo.ts:431
	// this.byteValue.value = '157'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313537 // "157"
	app_global_put

	// tests/contracts/cblocks.algo.ts:432
	// this.byteValue.value = '158'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313538 // "158"
	app_global_put

	// tests/contracts/cblocks.algo.ts:433
	// this.byteValue.value = '159'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313539 // "159"
	app_global_put

	// tests/contracts/cblocks.algo.ts:434
	// this.byteValue.value = '160'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313630 // "160"
	app_global_put

	// tests/contracts/cblocks.algo.ts:435
	// this.byteValue.value = '161'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313631 // "161"
	app_global_put

	// tests/contracts/cblocks.algo.ts:436
	// this.byteValue.value = '162'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313632 // "162"
	app_global_put

	// tests/contracts/cblocks.algo.ts:437
	// this.byteValue.value = '163'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313633 // "163"
	app_global_put

	// tests/contracts/cblocks.algo.ts:438
	// this.byteValue.value = '164'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313634 // "164"
	app_global_put

	// tests/contracts/cblocks.algo.ts:439
	// this.byteValue.value = '165'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313635 // "165"
	app_global_put

	// tests/contracts/cblocks.algo.ts:440
	// this.byteValue.value = '166'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313636 // "166"
	app_global_put

	// tests/contracts/cblocks.algo.ts:441
	// this.byteValue.value = '167'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313637 // "167"
	app_global_put

	// tests/contracts/cblocks.algo.ts:442
	// this.byteValue.value = '168'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313638 // "168"
	app_global_put

	// tests/contracts/cblocks.algo.ts:443
	// this.byteValue.value = '169'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313639 // "169"
	app_global_put

	// tests/contracts/cblocks.algo.ts:444
	// this.byteValue.value = '170'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313730 // "170"
	app_global_put

	// tests/contracts/cblocks.algo.ts:445
	// this.byteValue.value = '171'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313731 // "171"
	app_global_put

	// tests/contracts/cblocks.algo.ts:446
	// this.byteValue.value = '172'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313732 // "172"
	app_global_put

	// tests/contracts/cblocks.algo.ts:447
	// this.byteValue.value = '173'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313733 // "173"
	app_global_put

	// tests/contracts/cblocks.algo.ts:448
	// this.byteValue.value = '174'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313734 // "174"
	app_global_put

	// tests/contracts/cblocks.algo.ts:449
	// this.byteValue.value = '175'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313735 // "175"
	app_global_put

	// tests/contracts/cblocks.algo.ts:450
	// this.byteValue.value = '176'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313736 // "176"
	app_global_put

	// tests/contracts/cblocks.algo.ts:451
	// this.byteValue.value = '177'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313737 // "177"
	app_global_put

	// tests/contracts/cblocks.algo.ts:452
	// this.byteValue.value = '178'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313738 // "178"
	app_global_put

	// tests/contracts/cblocks.algo.ts:453
	// this.byteValue.value = '179'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313739 // "179"
	app_global_put

	// tests/contracts/cblocks.algo.ts:454
	// this.byteValue.value = '180'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313830 // "180"
	app_global_put

	// tests/contracts/cblocks.algo.ts:455
	// this.byteValue.value = '181'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313831 // "181"
	app_global_put

	// tests/contracts/cblocks.algo.ts:456
	// this.byteValue.value = '182'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313832 // "182"
	app_global_put

	// tests/contracts/cblocks.algo.ts:457
	// this.byteValue.value = '183'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313833 // "183"
	app_global_put

	// tests/contracts/cblocks.algo.ts:458
	// this.byteValue.value = '184'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313834 // "184"
	app_global_put

	// tests/contracts/cblocks.algo.ts:459
	// this.byteValue.value = '185'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313835 // "185"
	app_global_put

	// tests/contracts/cblocks.algo.ts:460
	// this.byteValue.value = '186'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313836 // "186"
	app_global_put

	// tests/contracts/cblocks.algo.ts:461
	// this.byteValue.value = '187'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313837 // "187"
	app_global_put

	// tests/contracts/cblocks.algo.ts:462
	// this.byteValue.value = '188'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313838 // "188"
	app_global_put

	// tests/contracts/cblocks.algo.ts:463
	// this.byteValue.value = '189'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313839 // "189"
	app_global_put

	// tests/contracts/cblocks.algo.ts:464
	// this.byteValue.value = '190'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313930 // "190"
	app_global_put

	// tests/contracts/cblocks.algo.ts:465
	// this.byteValue.value = '191'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313931 // "191"
	app_global_put

	// tests/contracts/cblocks.algo.ts:466
	// this.byteValue.value = '192'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313932 // "192"
	app_global_put

	// tests/contracts/cblocks.algo.ts:467
	// this.byteValue.value = '193'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313933 // "193"
	app_global_put

	// tests/contracts/cblocks.algo.ts:468
	// this.byteValue.value = '194'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313934 // "194"
	app_global_put

	// tests/contracts/cblocks.algo.ts:469
	// this.byteValue.value = '195'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313935 // "195"
	app_global_put

	// tests/contracts/cblocks.algo.ts:470
	// this.byteValue.value = '196'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313936 // "196"
	app_global_put

	// tests/contracts/cblocks.algo.ts:471
	// this.byteValue.value = '197'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313937 // "197"
	app_global_put

	// tests/contracts/cblocks.algo.ts:472
	// this.byteValue.value = '198'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313938 // "198"
	app_global_put

	// tests/contracts/cblocks.algo.ts:473
	// this.byteValue.value = '199'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x313939 // "199"
	app_global_put

	// tests/contracts/cblocks.algo.ts:474
	// this.byteValue.value = '200'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323030 // "200"
	app_global_put

	// tests/contracts/cblocks.algo.ts:475
	// this.byteValue.value = '201'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323031 // "201"
	app_global_put

	// tests/contracts/cblocks.algo.ts:476
	// this.byteValue.value = '202'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323032 // "202"
	app_global_put

	// tests/contracts/cblocks.algo.ts:477
	// this.byteValue.value = '203'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323033 // "203"
	app_global_put

	// tests/contracts/cblocks.algo.ts:478
	// this.byteValue.value = '204'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323034 // "204"
	app_global_put

	// tests/contracts/cblocks.algo.ts:479
	// this.byteValue.value = '205'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323035 // "205"
	app_global_put

	// tests/contracts/cblocks.algo.ts:480
	// this.byteValue.value = '206'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323036 // "206"
	app_global_put

	// tests/contracts/cblocks.algo.ts:481
	// this.byteValue.value = '207'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323037 // "207"
	app_global_put

	// tests/contracts/cblocks.algo.ts:482
	// this.byteValue.value = '208'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323038 // "208"
	app_global_put

	// tests/contracts/cblocks.algo.ts:483
	// this.byteValue.value = '209'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323039 // "209"
	app_global_put

	// tests/contracts/cblocks.algo.ts:484
	// this.byteValue.value = '210'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323130 // "210"
	app_global_put

	// tests/contracts/cblocks.algo.ts:485
	// this.byteValue.value = '211'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323131 // "211"
	app_global_put

	// tests/contracts/cblocks.algo.ts:486
	// this.byteValue.value = '212'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323132 // "212"
	app_global_put

	// tests/contracts/cblocks.algo.ts:487
	// this.byteValue.value = '213'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323133 // "213"
	app_global_put

	// tests/contracts/cblocks.algo.ts:488
	// this.byteValue.value = '214'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323134 // "214"
	app_global_put

	// tests/contracts/cblocks.algo.ts:489
	// this.byteValue.value = '215'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323135 // "215"
	app_global_put

	// tests/contracts/cblocks.algo.ts:490
	// this.byteValue.value = '216'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323136 // "216"
	app_global_put

	// tests/contracts/cblocks.algo.ts:491
	// this.byteValue.value = '217'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323137 // "217"
	app_global_put

	// tests/contracts/cblocks.algo.ts:492
	// this.byteValue.value = '218'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323138 // "218"
	app_global_put

	// tests/contracts/cblocks.algo.ts:493
	// this.byteValue.value = '219'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323139 // "219"
	app_global_put

	// tests/contracts/cblocks.algo.ts:494
	// this.byteValue.value = '220'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323230 // "220"
	app_global_put

	// tests/contracts/cblocks.algo.ts:495
	// this.byteValue.value = '221'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323231 // "221"
	app_global_put

	// tests/contracts/cblocks.algo.ts:496
	// this.byteValue.value = '222'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323232 // "222"
	app_global_put

	// tests/contracts/cblocks.algo.ts:497
	// this.byteValue.value = '223'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323233 // "223"
	app_global_put

	// tests/contracts/cblocks.algo.ts:498
	// this.byteValue.value = '224'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323234 // "224"
	app_global_put

	// tests/contracts/cblocks.algo.ts:499
	// this.byteValue.value = '225'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323235 // "225"
	app_global_put

	// tests/contracts/cblocks.algo.ts:500
	// this.byteValue.value = '226'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323236 // "226"
	app_global_put

	// tests/contracts/cblocks.algo.ts:501
	// this.byteValue.value = '227'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323237 // "227"
	app_global_put

	// tests/contracts/cblocks.algo.ts:502
	// this.byteValue.value = '228'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323238 // "228"
	app_global_put

	// tests/contracts/cblocks.algo.ts:503
	// this.byteValue.value = '229'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323239 // "229"
	app_global_put

	// tests/contracts/cblocks.algo.ts:504
	// this.byteValue.value = '230'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323330 // "230"
	app_global_put

	// tests/contracts/cblocks.algo.ts:505
	// this.byteValue.value = '231'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323331 // "231"
	app_global_put

	// tests/contracts/cblocks.algo.ts:506
	// this.byteValue.value = '232'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323332 // "232"
	app_global_put

	// tests/contracts/cblocks.algo.ts:507
	// this.byteValue.value = '233'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323333 // "233"
	app_global_put

	// tests/contracts/cblocks.algo.ts:508
	// this.byteValue.value = '234'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323334 // "234"
	app_global_put

	// tests/contracts/cblocks.algo.ts:509
	// this.byteValue.value = '235'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323335 // "235"
	app_global_put

	// tests/contracts/cblocks.algo.ts:510
	// this.byteValue.value = '236'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323336 // "236"
	app_global_put

	// tests/contracts/cblocks.algo.ts:511
	// this.byteValue.value = '237'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323337 // "237"
	app_global_put

	// tests/contracts/cblocks.algo.ts:512
	// this.byteValue.value = '238'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323338 // "238"
	app_global_put

	// tests/contracts/cblocks.algo.ts:513
	// this.byteValue.value = '239'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323339 // "239"
	app_global_put

	// tests/contracts/cblocks.algo.ts:514
	// this.byteValue.value = '240'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323430 // "240"
	app_global_put

	// tests/contracts/cblocks.algo.ts:515
	// this.byteValue.value = '241'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323431 // "241"
	app_global_put

	// tests/contracts/cblocks.algo.ts:516
	// this.byteValue.value = '242'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323432 // "242"
	app_global_put

	// tests/contracts/cblocks.algo.ts:517
	// this.byteValue.value = '243'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323433 // "243"
	app_global_put

	// tests/contracts/cblocks.algo.ts:518
	// this.byteValue.value = '244'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323434 // "244"
	app_global_put

	// tests/contracts/cblocks.algo.ts:519
	// this.byteValue.value = '245'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323435 // "245"
	app_global_put

	// tests/contracts/cblocks.algo.ts:520
	// this.byteValue.value = '246'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323436 // "246"
	app_global_put

	// tests/contracts/cblocks.algo.ts:521
	// this.byteValue.value = '247'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323437 // "247"
	app_global_put

	// tests/contracts/cblocks.algo.ts:522
	// this.byteValue.value = '248'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323438 // "248"
	app_global_put

	// tests/contracts/cblocks.algo.ts:523
	// this.byteValue.value = '249'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323439 // "249"
	app_global_put

	// tests/contracts/cblocks.algo.ts:524
	// this.byteValue.value = '250'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323530 // "250"
	app_global_put

	// tests/contracts/cblocks.algo.ts:525
	// this.byteValue.value = '251'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323531 // "251"
	app_global_put

	// tests/contracts/cblocks.algo.ts:526
	// this.byteValue.value = '252'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323532 // "252"
	app_global_put

	// tests/contracts/cblocks.algo.ts:527
	// this.byteValue.value = '253'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323533 // "253"
	app_global_put

	// tests/contracts/cblocks.algo.ts:528
	// this.byteValue.value = '254'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323534 // "254"
	app_global_put

	// tests/contracts/cblocks.algo.ts:529
	// this.byteValue.value = '255'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323535 // "255"
	app_global_put

	// tests/contracts/cblocks.algo.ts:530
	// this.byteValue.value = '256'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x323536 // "256"
	app_global_put

	// tests/contracts/cblocks.algo.ts:532
	// this.byteValue.value =
	//       'This is a fairly long byteslice that should be put in the consant block because it is so long'
	byte 0x6279746556616c7565 // "byteValue"
	pushbytes 0x54686973206973206120666169726c79206c6f6e672062797465736c69636520746861742073686f756c642062652070757420696e2074686520636f6e73616e7420626c6f636b206265636175736520697420697320736f206c6f6e67 // "This is a fairly long byteslice that should be put in the consant block because it is so long"
	app_global_put

	// tests/contracts/cblocks.algo.ts:535
	// return a + b;
	pushbytes "1"
	pushbytes "257"
	concat
	retsub

*abi_route_createApplication:
	pushint 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0xb13757d2 // method "largeBytecblock()string"
	txna ApplicationArgs 0
	match *abi_route_largeBytecblock

	// this contract does not implement the given ABI method for call NoOp
	err", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/C.approval.teal b/tests/contracts/artifacts/C.approval.teal index e6daa4de3..c8f800ed8 100644 --- a/tests/contracts/artifacts/C.approval.teal +++ b/tests/contracts/artifacts/C.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x61 0x62 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/C.arc32.json b/tests/contracts/artifacts/C.arc32.json index 498aea57e..42481cb65 100644 --- a/tests/contracts/artifacts/C.arc32.json +++ b/tests/contracts/artifacts/C.arc32.json @@ -58,7 +58,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2MSAweDYyCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYSgpdm9pZAoqYWJpX3JvdXRlX2E6CgkvLyBleGVjdXRlIGEoKXZvaWQKCWNhbGxzdWIgYQoJcHVzaGludCAxCglyZXR1cm4KCi8vIGEoKTogdm9pZAphOgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6MTYKCS8vIHRoaXMuYUtleS52YWx1ZSA9IDEzMzcKCWJ5dGUgMHg2MSAvLyAiYSIKCXB1c2hpbnQgMTMzNwoJYXBwX2dsb2JhbF9wdXQKCXJldHN1YgoKLy8gYigpdm9pZAoqYWJpX3JvdXRlX2I6CgkvLyBleGVjdXRlIGIoKXZvaWQKCWNhbGxzdWIgYgoJcHVzaGludCAxCglyZXR1cm4KCi8vIGIoKTogdm9pZApiOgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6MjQKCS8vIGFzc2VydCh0aGlzLmFLZXkudmFsdWUgPT09IDEzMzcpCglieXRlIDB4NjEgLy8gImEiCglhcHBfZ2xvYmFsX2dldAoJcHVzaGludCAxMzM3Cgk9PQoJYXNzZXJ0CgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6MjUKCS8vIHRoaXMuYktleS52YWx1ZSA9IDQyCglieXRlIDB4NjIgLy8gImIiCglwdXNoaW50IDQyCglhcHBfZ2xvYmFsX3B1dAoJcmV0c3ViCgovLyBjKCl2b2lkCiphYmlfcm91dGVfYzoKCS8vIGV4ZWN1dGUgYygpdm9pZAoJY2FsbHN1YiBjCglwdXNoaW50IDEKCXJldHVybgoKLy8gYygpOiB2b2lkCmM6Cglwcm90byAwIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czozMQoJLy8gYXNzZXJ0KHRoaXMuYktleS52YWx1ZSA9PT0gNDIpCglieXRlIDB4NjIgLy8gImIiCglhcHBfZ2xvYmFsX2dldAoJcHVzaGludCA0MgoJPT0KCWFzc2VydAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS5hbGdvLnRzOjMyCgkvLyBhc3NlcnQodGhpcy5hS2V5LnZhbHVlID09PSAxMzM3KQoJYnl0ZSAweDYxIC8vICJhIgoJYXBwX2dsb2JhbF9nZXQKCXB1c2hpbnQgMTMzNwoJPT0KCWFzc2VydAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgxZTdhYWQxYyAvLyBtZXRob2QgImEoKXZvaWQiCglwdXNoYnl0ZXMgMHgzYWM5MGIwOCAvLyBtZXRob2QgImIoKXZvaWQiCglwdXNoYnl0ZXMgMHg4YzY5NjZmMCAvLyBtZXRob2QgImMoKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2EgKmFiaV9yb3V0ZV9iICphYmlfcm91dGVfYwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2MSAweDYyCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYSgpdm9pZAoqYWJpX3JvdXRlX2E6CgkvLyBleGVjdXRlIGEoKXZvaWQKCWNhbGxzdWIgYQoJcHVzaGludCAxCglyZXR1cm4KCi8vIGEoKTogdm9pZAphOgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6MTYKCS8vIHRoaXMuYUtleS52YWx1ZSA9IDEzMzcKCWJ5dGUgMHg2MSAvLyAiYSIKCXB1c2hpbnQgMTMzNwoJYXBwX2dsb2JhbF9wdXQKCXJldHN1YgoKLy8gYigpdm9pZAoqYWJpX3JvdXRlX2I6CgkvLyBleGVjdXRlIGIoKXZvaWQKCWNhbGxzdWIgYgoJcHVzaGludCAxCglyZXR1cm4KCi8vIGIoKTogdm9pZApiOgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6MjQKCS8vIGFzc2VydCh0aGlzLmFLZXkudmFsdWUgPT09IDEzMzcpCglieXRlIDB4NjEgLy8gImEiCglhcHBfZ2xvYmFsX2dldAoJcHVzaGludCAxMzM3Cgk9PQoJYXNzZXJ0CgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6MjUKCS8vIHRoaXMuYktleS52YWx1ZSA9IDQyCglieXRlIDB4NjIgLy8gImIiCglwdXNoaW50IDQyCglhcHBfZ2xvYmFsX3B1dAoJcmV0c3ViCgovLyBjKCl2b2lkCiphYmlfcm91dGVfYzoKCS8vIGV4ZWN1dGUgYygpdm9pZAoJY2FsbHN1YiBjCglwdXNoaW50IDEKCXJldHVybgoKLy8gYygpOiB2b2lkCmM6Cglwcm90byAwIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czozMQoJLy8gYXNzZXJ0KHRoaXMuYktleS52YWx1ZSA9PT0gNDIpCglieXRlIDB4NjIgLy8gImIiCglhcHBfZ2xvYmFsX2dldAoJcHVzaGludCA0MgoJPT0KCWFzc2VydAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS5hbGdvLnRzOjMyCgkvLyBhc3NlcnQodGhpcy5hS2V5LnZhbHVlID09PSAxMzM3KQoJYnl0ZSAweDYxIC8vICJhIgoJYXBwX2dsb2JhbF9nZXQKCXB1c2hpbnQgMTMzNwoJPT0KCWFzc2VydAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgxZTdhYWQxYyAvLyBtZXRob2QgImEoKXZvaWQiCglwdXNoYnl0ZXMgMHgzYWM5MGIwOCAvLyBtZXRob2QgImIoKXZvaWQiCglwdXNoYnl0ZXMgMHg4YzY5NjZmMCAvLyBtZXRob2QgImMoKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2EgKmFiaV9yb3V0ZV9iICphYmlfcm91dGVfYwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/C.arc56_draft.json b/tests/contracts/artifacts/C.arc56_draft.json index 453cb66f2..b27d5a5ed 100644 --- a/tests/contracts/artifacts/C.arc56_draft.json +++ b/tests/contracts/artifacts/C.arc56_draft.json @@ -619,7 +619,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2MSAweDYyCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYSgpdm9pZAoqYWJpX3JvdXRlX2E6CgkvLyBleGVjdXRlIGEoKXZvaWQKCWNhbGxzdWIgYQoJcHVzaGludCAxCglyZXR1cm4KCi8vIGEoKTogdm9pZAphOgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6MTYKCS8vIHRoaXMuYUtleS52YWx1ZSA9IDEzMzcKCWJ5dGUgMHg2MSAvLyAiYSIKCXB1c2hpbnQgMTMzNwoJYXBwX2dsb2JhbF9wdXQKCXJldHN1YgoKLy8gYigpdm9pZAoqYWJpX3JvdXRlX2I6CgkvLyBleGVjdXRlIGIoKXZvaWQKCWNhbGxzdWIgYgoJcHVzaGludCAxCglyZXR1cm4KCi8vIGIoKTogdm9pZApiOgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6MjQKCS8vIGFzc2VydCh0aGlzLmFLZXkudmFsdWUgPT09IDEzMzcpCglieXRlIDB4NjEgLy8gImEiCglhcHBfZ2xvYmFsX2dldAoJcHVzaGludCAxMzM3Cgk9PQoJYXNzZXJ0CgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6MjUKCS8vIHRoaXMuYktleS52YWx1ZSA9IDQyCglieXRlIDB4NjIgLy8gImIiCglwdXNoaW50IDQyCglhcHBfZ2xvYmFsX3B1dAoJcmV0c3ViCgovLyBjKCl2b2lkCiphYmlfcm91dGVfYzoKCS8vIGV4ZWN1dGUgYygpdm9pZAoJY2FsbHN1YiBjCglwdXNoaW50IDEKCXJldHVybgoKLy8gYygpOiB2b2lkCmM6Cglwcm90byAwIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czozMQoJLy8gYXNzZXJ0KHRoaXMuYktleS52YWx1ZSA9PT0gNDIpCglieXRlIDB4NjIgLy8gImIiCglhcHBfZ2xvYmFsX2dldAoJcHVzaGludCA0MgoJPT0KCWFzc2VydAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS5hbGdvLnRzOjMyCgkvLyBhc3NlcnQodGhpcy5hS2V5LnZhbHVlID09PSAxMzM3KQoJYnl0ZSAweDYxIC8vICJhIgoJYXBwX2dsb2JhbF9nZXQKCXB1c2hpbnQgMTMzNwoJPT0KCWFzc2VydAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgxZTdhYWQxYyAvLyBtZXRob2QgImEoKXZvaWQiCglwdXNoYnl0ZXMgMHgzYWM5MGIwOCAvLyBtZXRob2QgImIoKXZvaWQiCglwdXNoYnl0ZXMgMHg4YzY5NjZmMCAvLyBtZXRob2QgImMoKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2EgKmFiaV9yb3V0ZV9iICphYmlfcm91dGVfYwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2MSAweDYyCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gYSgpdm9pZAoqYWJpX3JvdXRlX2E6CgkvLyBleGVjdXRlIGEoKXZvaWQKCWNhbGxzdWIgYQoJcHVzaGludCAxCglyZXR1cm4KCi8vIGEoKTogdm9pZAphOgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6MTYKCS8vIHRoaXMuYUtleS52YWx1ZSA9IDEzMzcKCWJ5dGUgMHg2MSAvLyAiYSIKCXB1c2hpbnQgMTMzNwoJYXBwX2dsb2JhbF9wdXQKCXJldHN1YgoKLy8gYigpdm9pZAoqYWJpX3JvdXRlX2I6CgkvLyBleGVjdXRlIGIoKXZvaWQKCWNhbGxzdWIgYgoJcHVzaGludCAxCglyZXR1cm4KCi8vIGIoKTogdm9pZApiOgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6MjQKCS8vIGFzc2VydCh0aGlzLmFLZXkudmFsdWUgPT09IDEzMzcpCglieXRlIDB4NjEgLy8gImEiCglhcHBfZ2xvYmFsX2dldAoJcHVzaGludCAxMzM3Cgk9PQoJYXNzZXJ0CgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6MjUKCS8vIHRoaXMuYktleS52YWx1ZSA9IDQyCglieXRlIDB4NjIgLy8gImIiCglwdXNoaW50IDQyCglhcHBfZ2xvYmFsX3B1dAoJcmV0c3ViCgovLyBjKCl2b2lkCiphYmlfcm91dGVfYzoKCS8vIGV4ZWN1dGUgYygpdm9pZAoJY2FsbHN1YiBjCglwdXNoaW50IDEKCXJldHVybgoKLy8gYygpOiB2b2lkCmM6Cglwcm90byAwIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czozMQoJLy8gYXNzZXJ0KHRoaXMuYktleS52YWx1ZSA9PT0gNDIpCglieXRlIDB4NjIgLy8gImIiCglhcHBfZ2xvYmFsX2dldAoJcHVzaGludCA0MgoJPT0KCWFzc2VydAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS5hbGdvLnRzOjMyCgkvLyBhc3NlcnQodGhpcy5hS2V5LnZhbHVlID09PSAxMzM3KQoJYnl0ZSAweDYxIC8vICJhIgoJYXBwX2dsb2JhbF9nZXQKCXB1c2hpbnQgMTMzNwoJPT0KCWFzc2VydAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgxZTdhYWQxYyAvLyBtZXRob2QgImEoKXZvaWQiCglwdXNoYnl0ZXMgMHgzYWM5MGIwOCAvLyBtZXRob2QgImIoKXZvaWQiCglwdXNoYnl0ZXMgMHg4YzY5NjZmMCAvLyBtZXRob2QgImMoKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2EgKmFiaV9yb3V0ZV9iICphYmlfcm91dGVfYwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ContractWithCustomStruct.approval.teal b/tests/contracts/artifacts/ContractWithCustomStruct.approval.teal index cc349aad7..fd9f27352 100644 --- a/tests/contracts/artifacts/ContractWithCustomStruct.approval.teal +++ b/tests/contracts/artifacts/ContractWithCustomStruct.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ContractWithCustomStruct.arc32.json b/tests/contracts/artifacts/ContractWithCustomStruct.arc32.json index cbc222926..8e0c84d2f 100644 --- a/tests/contracts/artifacts/ContractWithCustomStruct.arc32.json +++ b/tests/contracts/artifacts/ContractWithCustomStruct.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gY3VzdG9tU3RydWN0TWV0aG9kKCh1aW50NjQpKSh1aW50NjQpCiphYmlfcm91dGVfY3VzdG9tU3RydWN0TWV0aG9kOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGlucHV0OiAodWludDY0KQoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJZHVwCglsZW4KCXB1c2hpbnQgOAoJPT0KCgkvLyBhcmd1bWVudCAwIChpbnB1dCkgZm9yIGN1c3RvbVN0cnVjdE1ldGhvZCBtdXN0IGJlIGEgKHVpbnQ2NCkKCWFzc2VydAoKCS8vIGV4ZWN1dGUgY3VzdG9tU3RydWN0TWV0aG9kKCh1aW50NjQpKSh1aW50NjQpCgljYWxsc3ViIGN1c3RvbVN0cnVjdE1ldGhvZAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBjdXN0b21TdHJ1Y3RNZXRob2QoaW5wdXQ6IEFub3RoZXJDdXN0b21TdHJ1Y3QpOiBBbm90aGVyQ3VzdG9tU3RydWN0CmN1c3RvbVN0cnVjdE1ldGhvZDoKCXByb3RvIDEgMQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS1leHRlcm5hbC5hbGdvLnRzOjIxCgkvLyByZXR1cm4gaW5wdXQ7CglmcmFtZV9kaWcgLTEgLy8gaW5wdXQ6IEFub3RoZXJDdXN0b21TdHJ1Y3QKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4OGQyMjczOWEgLy8gbWV0aG9kICJjdXN0b21TdHJ1Y3RNZXRob2QoKHVpbnQ2NCkpKHVpbnQ2NCkiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2N1c3RvbVN0cnVjdE1ldGhvZAoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gY3VzdG9tU3RydWN0TWV0aG9kKCh1aW50NjQpKSh1aW50NjQpCiphYmlfcm91dGVfY3VzdG9tU3RydWN0TWV0aG9kOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGlucHV0OiAodWludDY0KQoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJZHVwCglsZW4KCXB1c2hpbnQgOAoJPT0KCgkvLyBhcmd1bWVudCAwIChpbnB1dCkgZm9yIGN1c3RvbVN0cnVjdE1ldGhvZCBtdXN0IGJlIGEgKHVpbnQ2NCkKCWFzc2VydAoKCS8vIGV4ZWN1dGUgY3VzdG9tU3RydWN0TWV0aG9kKCh1aW50NjQpKSh1aW50NjQpCgljYWxsc3ViIGN1c3RvbVN0cnVjdE1ldGhvZAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBjdXN0b21TdHJ1Y3RNZXRob2QoaW5wdXQ6IEFub3RoZXJDdXN0b21TdHJ1Y3QpOiBBbm90aGVyQ3VzdG9tU3RydWN0CmN1c3RvbVN0cnVjdE1ldGhvZDoKCXByb3RvIDEgMQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS1leHRlcm5hbC5hbGdvLnRzOjIxCgkvLyByZXR1cm4gaW5wdXQ7CglmcmFtZV9kaWcgLTEgLy8gaW5wdXQ6IEFub3RoZXJDdXN0b21TdHJ1Y3QKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4OGQyMjczOWEgLy8gbWV0aG9kICJjdXN0b21TdHJ1Y3RNZXRob2QoKHVpbnQ2NCkpKHVpbnQ2NCkiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2N1c3RvbVN0cnVjdE1ldGhvZAoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ContractWithCustomStruct.arc56_draft.json b/tests/contracts/artifacts/ContractWithCustomStruct.arc56_draft.json index 7cbb18654..96dff06af 100644 --- a/tests/contracts/artifacts/ContractWithCustomStruct.arc56_draft.json +++ b/tests/contracts/artifacts/ContractWithCustomStruct.arc56_draft.json @@ -391,7 +391,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gY3VzdG9tU3RydWN0TWV0aG9kKCh1aW50NjQpKSh1aW50NjQpCiphYmlfcm91dGVfY3VzdG9tU3RydWN0TWV0aG9kOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGlucHV0OiAodWludDY0KQoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJZHVwCglsZW4KCXB1c2hpbnQgOAoJPT0KCgkvLyBhcmd1bWVudCAwIChpbnB1dCkgZm9yIGN1c3RvbVN0cnVjdE1ldGhvZCBtdXN0IGJlIGEgKHVpbnQ2NCkKCWFzc2VydAoKCS8vIGV4ZWN1dGUgY3VzdG9tU3RydWN0TWV0aG9kKCh1aW50NjQpKSh1aW50NjQpCgljYWxsc3ViIGN1c3RvbVN0cnVjdE1ldGhvZAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBjdXN0b21TdHJ1Y3RNZXRob2QoaW5wdXQ6IEFub3RoZXJDdXN0b21TdHJ1Y3QpOiBBbm90aGVyQ3VzdG9tU3RydWN0CmN1c3RvbVN0cnVjdE1ldGhvZDoKCXByb3RvIDEgMQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS1leHRlcm5hbC5hbGdvLnRzOjIxCgkvLyByZXR1cm4gaW5wdXQ7CglmcmFtZV9kaWcgLTEgLy8gaW5wdXQ6IEFub3RoZXJDdXN0b21TdHJ1Y3QKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4OGQyMjczOWEgLy8gbWV0aG9kICJjdXN0b21TdHJ1Y3RNZXRob2QoKHVpbnQ2NCkpKHVpbnQ2NCkiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2N1c3RvbVN0cnVjdE1ldGhvZAoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gY3VzdG9tU3RydWN0TWV0aG9kKCh1aW50NjQpKSh1aW50NjQpCiphYmlfcm91dGVfY3VzdG9tU3RydWN0TWV0aG9kOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGlucHV0OiAodWludDY0KQoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJZHVwCglsZW4KCXB1c2hpbnQgOAoJPT0KCgkvLyBhcmd1bWVudCAwIChpbnB1dCkgZm9yIGN1c3RvbVN0cnVjdE1ldGhvZCBtdXN0IGJlIGEgKHVpbnQ2NCkKCWFzc2VydAoKCS8vIGV4ZWN1dGUgY3VzdG9tU3RydWN0TWV0aG9kKCh1aW50NjQpKSh1aW50NjQpCgljYWxsc3ViIGN1c3RvbVN0cnVjdE1ldGhvZAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBjdXN0b21TdHJ1Y3RNZXRob2QoaW5wdXQ6IEFub3RoZXJDdXN0b21TdHJ1Y3QpOiBBbm90aGVyQ3VzdG9tU3RydWN0CmN1c3RvbVN0cnVjdE1ldGhvZDoKCXByb3RvIDEgMQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS1leHRlcm5hbC5hbGdvLnRzOjIxCgkvLyByZXR1cm4gaW5wdXQ7CglmcmFtZV9kaWcgLTEgLy8gaW5wdXQ6IEFub3RoZXJDdXN0b21TdHJ1Y3QKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4OGQyMjczOWEgLy8gbWV0aG9kICJjdXN0b21TdHJ1Y3RNZXRob2QoKHVpbnQ2NCkpKHVpbnQ2NCkiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2N1c3RvbVN0cnVjdE1ldGhvZAoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ContractWithLsigProgram.approval.teal b/tests/contracts/artifacts/ContractWithLsigProgram.approval.teal index 7dc39c8e6..102ff7681 100644 --- a/tests/contracts/artifacts/ContractWithLsigProgram.approval.teal +++ b/tests/contracts/artifacts/ContractWithLsigProgram.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ContractWithLsigProgram.arc32.json b/tests/contracts/artifacts/ContractWithLsigProgram.arc32.json index 729400681..783e8d4bb 100644 --- a/tests/contracts/artifacts/ContractWithLsigProgram.arc32.json +++ b/tests/contracts/artifacts/ContractWithLsigProgram.arc32.json @@ -34,7 +34,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gY3JlYXRlQXBwbGljYXRpb24oKXZvaWQKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCS8vIGV4ZWN1dGUgY3JlYXRlQXBwbGljYXRpb24oKXZvaWQKCWNhbGxzdWIgY3JlYXRlQXBwbGljYXRpb24KCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBjcmVhdGVBcHBsaWNhdGlvbigpOiB2b2lkCmNyZWF0ZUFwcGxpY2F0aW9uOgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2xzaWcuYWxnby50czozMgoJLy8gbG9nKEJhc2ljTHNpZy5wcm9ncmFtKCkpCglwdXNoYnl0ZXMgMHgwYTQyMDAwMDg4MDAwMzgxMDE0MzhhMDAwMDgxMDE0NDg5Cglsb2cKCXJldHN1YgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gY3JlYXRlQXBwbGljYXRpb24oKXZvaWQKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCS8vIGV4ZWN1dGUgY3JlYXRlQXBwbGljYXRpb24oKXZvaWQKCWNhbGxzdWIgY3JlYXRlQXBwbGljYXRpb24KCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBjcmVhdGVBcHBsaWNhdGlvbigpOiB2b2lkCmNyZWF0ZUFwcGxpY2F0aW9uOgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2xzaWcuYWxnby50czozMgoJLy8gbG9nKEJhc2ljTHNpZy5wcm9ncmFtKCkpCglwdXNoYnl0ZXMgMHgwYTQyMDAwMDg4MDAwMzgxMDE0MzhhMDAwMDgxMDE0NDg5Cglsb2cKCXJldHN1YgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ContractWithLsigProgram.arc56_draft.json b/tests/contracts/artifacts/ContractWithLsigProgram.arc56_draft.json index 79299a7b2..4da73a377 100644 --- a/tests/contracts/artifacts/ContractWithLsigProgram.arc56_draft.json +++ b/tests/contracts/artifacts/ContractWithLsigProgram.arc56_draft.json @@ -262,7 +262,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gY3JlYXRlQXBwbGljYXRpb24oKXZvaWQKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCS8vIGV4ZWN1dGUgY3JlYXRlQXBwbGljYXRpb24oKXZvaWQKCWNhbGxzdWIgY3JlYXRlQXBwbGljYXRpb24KCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBjcmVhdGVBcHBsaWNhdGlvbigpOiB2b2lkCmNyZWF0ZUFwcGxpY2F0aW9uOgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2xzaWcuYWxnby50czozMgoJLy8gbG9nKEJhc2ljTHNpZy5wcm9ncmFtKCkpCglwdXNoYnl0ZXMgMHgwYTQyMDAwMDg4MDAwMzgxMDE0MzhhMDAwMDgxMDE0NDg5Cglsb2cKCXJldHN1YgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gY3JlYXRlQXBwbGljYXRpb24oKXZvaWQKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCS8vIGV4ZWN1dGUgY3JlYXRlQXBwbGljYXRpb24oKXZvaWQKCWNhbGxzdWIgY3JlYXRlQXBwbGljYXRpb24KCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBjcmVhdGVBcHBsaWNhdGlvbigpOiB2b2lkCmNyZWF0ZUFwcGxpY2F0aW9uOgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2xzaWcuYWxnby50czozMgoJLy8gbG9nKEJhc2ljTHNpZy5wcm9ncmFtKCkpCglwdXNoYnl0ZXMgMHgwYTQyMDAwMDg4MDAwMzgxMDE0MzhhMDAwMDgxMDE0NDg5Cglsb2cKCXJldHN1YgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ContratWithLsigAddress.approval.teal b/tests/contracts/artifacts/ContratWithLsigAddress.approval.teal index 09f38ca44..b2f03553f 100644 --- a/tests/contracts/artifacts/ContratWithLsigAddress.approval.teal +++ b/tests/contracts/artifacts/ContratWithLsigAddress.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ContratWithLsigAddress.arc32.json b/tests/contracts/artifacts/ContratWithLsigAddress.arc32.json index 18671e5d7..9435aa83f 100644 --- a/tests/contracts/artifacts/ContratWithLsigAddress.arc32.json +++ b/tests/contracts/artifacts/ContratWithLsigAddress.arc32.json @@ -34,7 +34,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gY3JlYXRlQXBwbGljYXRpb24oKXZvaWQKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCS8vIGV4ZWN1dGUgY3JlYXRlQXBwbGljYXRpb24oKXZvaWQKCWNhbGxzdWIgY3JlYXRlQXBwbGljYXRpb24KCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBjcmVhdGVBcHBsaWNhdGlvbigpOiB2b2lkCmNyZWF0ZUFwcGxpY2F0aW9uOgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2xzaWcuYWxnby50czozOQoJLy8gbG9nKEJhc2ljTHNpZy5hZGRyZXNzKCkpCglwdXNoYnl0ZXMgMHhmYTk3NThkY2M3ZWYwOGE0MThiODFlMGRmYzkzZTNmNjk5YzYxYTM2ZWRjMWFlOWRjYTlkNTlhZmUxNDM1MThhIC8vIGFkZHIgIjdLTFZSWEdINTRFS0lHRllEWUc3WkU3RDYyTTRNR1JXNVhBMjVIT0tUVk0yN1lLREtHRk9FRUZCQVUiCglsb2cKCXJldHN1YgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gY3JlYXRlQXBwbGljYXRpb24oKXZvaWQKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCS8vIGV4ZWN1dGUgY3JlYXRlQXBwbGljYXRpb24oKXZvaWQKCWNhbGxzdWIgY3JlYXRlQXBwbGljYXRpb24KCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBjcmVhdGVBcHBsaWNhdGlvbigpOiB2b2lkCmNyZWF0ZUFwcGxpY2F0aW9uOgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2xzaWcuYWxnby50czozOQoJLy8gbG9nKEJhc2ljTHNpZy5hZGRyZXNzKCkpCglwdXNoYnl0ZXMgMHhmYTk3NThkY2M3ZWYwOGE0MThiODFlMGRmYzkzZTNmNjk5YzYxYTM2ZWRjMWFlOWRjYTlkNTlhZmUxNDM1MThhIC8vIGFkZHIgIjdLTFZSWEdINTRFS0lHRllEWUc3WkU3RDYyTTRNR1JXNVhBMjVIT0tUVk0yN1lLREtHRk9FRUZCQVUiCglsb2cKCXJldHN1YgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ContratWithLsigAddress.arc56_draft.json b/tests/contracts/artifacts/ContratWithLsigAddress.arc56_draft.json index ac7047306..2bdfebcc5 100644 --- a/tests/contracts/artifacts/ContratWithLsigAddress.arc56_draft.json +++ b/tests/contracts/artifacts/ContratWithLsigAddress.arc56_draft.json @@ -277,7 +277,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gY3JlYXRlQXBwbGljYXRpb24oKXZvaWQKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCS8vIGV4ZWN1dGUgY3JlYXRlQXBwbGljYXRpb24oKXZvaWQKCWNhbGxzdWIgY3JlYXRlQXBwbGljYXRpb24KCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBjcmVhdGVBcHBsaWNhdGlvbigpOiB2b2lkCmNyZWF0ZUFwcGxpY2F0aW9uOgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2xzaWcuYWxnby50czozOQoJLy8gbG9nKEJhc2ljTHNpZy5hZGRyZXNzKCkpCglwdXNoYnl0ZXMgMHhmYTk3NThkY2M3ZWYwOGE0MThiODFlMGRmYzkzZTNmNjk5YzYxYTM2ZWRjMWFlOWRjYTlkNTlhZmUxNDM1MThhIC8vIGFkZHIgIjdLTFZSWEdINTRFS0lHRllEWUc3WkU3RDYyTTRNR1JXNVhBMjVIT0tUVk0yN1lLREtHRk9FRUZCQVUiCglsb2cKCXJldHN1YgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gY3JlYXRlQXBwbGljYXRpb24oKXZvaWQKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCS8vIGV4ZWN1dGUgY3JlYXRlQXBwbGljYXRpb24oKXZvaWQKCWNhbGxzdWIgY3JlYXRlQXBwbGljYXRpb24KCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBjcmVhdGVBcHBsaWNhdGlvbigpOiB2b2lkCmNyZWF0ZUFwcGxpY2F0aW9uOgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2xzaWcuYWxnby50czozOQoJLy8gbG9nKEJhc2ljTHNpZy5hZGRyZXNzKCkpCglwdXNoYnl0ZXMgMHhmYTk3NThkY2M3ZWYwOGE0MThiODFlMGRmYzkzZTNmNjk5YzYxYTM2ZWRjMWFlOWRjYTlkNTlhZmUxNDM1MThhIC8vIGFkZHIgIjdLTFZSWEdINTRFS0lHRllEWUc3WkU3RDYyTTRNR1JXNVhBMjVIT0tUVk0yN1lLREtHRk9FRUZCQVUiCglsb2cKCXJldHN1YgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/D.approval.teal b/tests/contracts/artifacts/D.approval.teal index 8ef64f3df..9922e4f04 100644 --- a/tests/contracts/artifacts/D.approval.teal +++ b/tests/contracts/artifacts/D.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/D.arc32.json b/tests/contracts/artifacts/D.arc32.json index 7a8eb6ed3..4ba20f6a2 100644 --- a/tests/contracts/artifacts/D.arc32.json +++ b/tests/contracts/artifacts/D.arc32.json @@ -44,7 +44,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZCgpdm9pZAoqYWJpX3JvdXRlX2Q6CgkvLyBleGVjdXRlIGQoKXZvaWQKCWNhbGxzdWIgZAoJcHVzaGludCAxCglyZXR1cm4KCi8vIGQoKTogdm9pZApkOgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6NDAKCS8vIHRoaXMuZEtleS52YWx1ZSA9IDQyCglwdXNoYnl0ZXMgMHg2NCAvLyAiZCIKCXB1c2hpbnQgNDIKCWFwcF9nbG9iYWxfcHV0CglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDI5ZWZkMGY2IC8vIG1ldGhvZCAiZCgpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfZAoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZCgpdm9pZAoqYWJpX3JvdXRlX2Q6CgkvLyBleGVjdXRlIGQoKXZvaWQKCWNhbGxzdWIgZAoJcHVzaGludCAxCglyZXR1cm4KCi8vIGQoKTogdm9pZApkOgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6NDAKCS8vIHRoaXMuZEtleS52YWx1ZSA9IDQyCglwdXNoYnl0ZXMgMHg2NCAvLyAiZCIKCXB1c2hpbnQgNDIKCWFwcF9nbG9iYWxfcHV0CglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDI5ZWZkMGY2IC8vIG1ldGhvZCAiZCgpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfZAoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/D.arc56_draft.json b/tests/contracts/artifacts/D.arc56_draft.json index 4f2b0f7fe..0f563e24b 100644 --- a/tests/contracts/artifacts/D.arc56_draft.json +++ b/tests/contracts/artifacts/D.arc56_draft.json @@ -327,7 +327,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZCgpdm9pZAoqYWJpX3JvdXRlX2Q6CgkvLyBleGVjdXRlIGQoKXZvaWQKCWNhbGxzdWIgZAoJcHVzaGludCAxCglyZXR1cm4KCi8vIGQoKTogdm9pZApkOgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6NDAKCS8vIHRoaXMuZEtleS52YWx1ZSA9IDQyCglwdXNoYnl0ZXMgMHg2NCAvLyAiZCIKCXB1c2hpbnQgNDIKCWFwcF9nbG9iYWxfcHV0CglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDI5ZWZkMGY2IC8vIG1ldGhvZCAiZCgpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfZAoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZCgpdm9pZAoqYWJpX3JvdXRlX2Q6CgkvLyBleGVjdXRlIGQoKXZvaWQKCWNhbGxzdWIgZAoJcHVzaGludCAxCglyZXR1cm4KCi8vIGQoKTogdm9pZApkOgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6NDAKCS8vIHRoaXMuZEtleS52YWx1ZSA9IDQyCglwdXNoYnl0ZXMgMHg2NCAvLyAiZCIKCXB1c2hpbnQgNDIKCWFwcF9nbG9iYWxfcHV0CglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweDI5ZWZkMGY2IC8vIG1ldGhvZCAiZCgpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfZAoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/DummyContract.approval.teal b/tests/contracts/artifacts/DummyContract.approval.teal index ee2fda28c..f8eda6915 100644 --- a/tests/contracts/artifacts/DummyContract.approval.teal +++ b/tests/contracts/artifacts/DummyContract.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/DummyContract.arc32.json b/tests/contracts/artifacts/DummyContract.arc32.json index 0f9d12db9..8636265cb 100644 --- a/tests/contracts/artifacts/DummyContract.arc32.json +++ b/tests/contracts/artifacts/DummyContract.arc32.json @@ -34,7 +34,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/DummyContract.arc56_draft.json b/tests/contracts/artifacts/DummyContract.arc56_draft.json index bc78c88e3..a6dac3de7 100644 --- a/tests/contracts/artifacts/DummyContract.arc56_draft.json +++ b/tests/contracts/artifacts/DummyContract.arc56_draft.json @@ -205,7 +205,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/E.approval.teal b/tests/contracts/artifacts/E.approval.teal index 23cb17ce3..c1e945df2 100644 --- a/tests/contracts/artifacts/E.approval.teal +++ b/tests/contracts/artifacts/E.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x0000000000000000000000000000000000000000000000000000000000000141 0x65787465726e616c4b6579 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/E.arc32.json b/tests/contracts/artifacts/E.arc32.json index fea9269c6..fe174c93e 100644 --- a/tests/contracts/artifacts/E.arc32.json +++ b/tests/contracts/artifacts/E.arc32.json @@ -49,7 +49,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMTQxIDB4NjU3ODc0NjU3MjZlNjE2YzRiNjU3OSAweAoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDQuMQovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIGV4dGVybmFsTWV0aG9kKCl1aW50OAoqYWJpX3JvdXRlX2V4dGVybmFsTWV0aG9kOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgZXh0ZXJuYWxNZXRob2QoKXVpbnQ4CgljYWxsc3ViIGV4dGVybmFsTWV0aG9kCglpdG9iCglkdXAKCWJpdGxlbgoJcHVzaGludCA4Cgk8PQoKCS8vIGV4dGVybmFsTWV0aG9kIHJldHVybiB2YWx1ZSBvdmVyZmxvd2VkIDggYml0cwoJYXNzZXJ0CglleHRyYWN0IDcgMQoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBleHRlcm5hbE1ldGhvZCgpOiBDdXN0b21UeXBlCmV4dGVybmFsTWV0aG9kOgoJcHJvdG8gMCAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLWV4dGVybmFsLmFsZ28udHM6MTEKCS8vIHRoaXMuZXh0ZXJuYWxLZXkudmFsdWUgPSA8Q3VzdG9tVHlwZT4xMjMKCWJ5dGUgMHg2NTc4NzQ2NTcyNmU2MTZjNGI2NTc5IC8vICJleHRlcm5hbEtleSIKCXB1c2hieXRlcyAweDdiCglhcHBfZ2xvYmFsX3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS1leHRlcm5hbC5hbGdvLnRzOjEyCgkvLyByZXR1cm4gdGhpcy5leHRlcm5hbEtleS52YWx1ZTsKCWJ5dGUgMHg2NTc4NzQ2NTcyNmU2MTZjNGI2NTc5IC8vICJleHRlcm5hbEtleSIKCWFwcF9nbG9iYWxfZ2V0CglidG9pCglyZXRzdWIKCi8vIGUoKXZvaWQKKmFiaV9yb3V0ZV9lOgoJLy8gZXhlY3V0ZSBlKCl2b2lkCgljYWxsc3ViIGUKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBlKCk6IHZvaWQKZToKCXByb3RvIDAgMAoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXBuIDIKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czo1MwoJLy8gdmFsOiBFeHRlcm5hbEN1c3RvbVR5cGUgPSA8RXh0ZXJuYWxDdXN0b21UeXBlPjEyMwoJcHVzaGludCAxMjMKCWZyYW1lX2J1cnkgMCAvLyB2YWw6IEV4dGVybmFsQ3VzdG9tVHlwZQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS5hbGdvLnRzOjU0CgkvLyBhc3NlcnQodGhpcy5leHRlcm5hbEtleS52YWx1ZSA9PT0gdmFsKQoJYnl0ZSAweDY1Nzg3NDY1NzI2ZTYxNmM0YjY1NzkgLy8gImV4dGVybmFsS2V5IgoJYXBwX2dsb2JhbF9nZXQKCWJ0b2kKCXB1c2hpbnQgMTIzIC8vIHZhbDogRXh0ZXJuYWxDdXN0b21UeXBlCgk9PQoJYXNzZXJ0CgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6NTUKCS8vIHggPSA8dWludDI1Nj4zMjEKCWJ5dGUgMHgwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMTQxCglmcmFtZV9idXJ5IDEgLy8geDogdWludDI1NgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS5hbGdvLnRzOjU2CgkvLyB5ID0gPEN1c3RvbVR5cGU+MzIxCglieXRlIDB4MDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDE0MQoJZnJhbWVfYnVyeSAyIC8vIHk6IHVpbnQyNTYKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czo1OAoJLy8gYXNzZXJ0KHggPT09IHkpCglieXRlIDB4MDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDE0MSAvLyB4OiB1aW50MjU2CglieXRlIDB4MDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDE0MSAvLyB5OiB1aW50MjU2CgliPT0KCWFzc2VydAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS5hbGdvLnRzOjYwCgkvLyBhc3NlcnQoTVlfQ09OU1QgPT09IDQ1NikKCXB1c2hpbnQgNDU2CglwdXNoaW50IDQ1NgoJPT0KCWFzc2VydAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS5hbGdvLnRzOjYxCgkvLyBhc3NlcnQoRVhURVJOQUxfQ09OU1QgPT09IDY1NCkKCXB1c2hpbnQgNjU0CglwdXNoaW50IDY1NAoJPT0KCWFzc2VydAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgxN2JlYTRiYiAvLyBtZXRob2QgImV4dGVybmFsTWV0aG9kKCl1aW50OCIKCXB1c2hieXRlcyAweDI3NzYzMGZjIC8vIG1ldGhvZCAiZSgpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfZXh0ZXJuYWxNZXRob2QgKmFiaV9yb3V0ZV9lCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMTQxIDB4NjU3ODc0NjU3MjZlNjE2YzRiNjU3OSAweAoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDUuMAovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIGV4dGVybmFsTWV0aG9kKCl1aW50OAoqYWJpX3JvdXRlX2V4dGVybmFsTWV0aG9kOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgZXh0ZXJuYWxNZXRob2QoKXVpbnQ4CgljYWxsc3ViIGV4dGVybmFsTWV0aG9kCglpdG9iCglkdXAKCWJpdGxlbgoJcHVzaGludCA4Cgk8PQoKCS8vIGV4dGVybmFsTWV0aG9kIHJldHVybiB2YWx1ZSBvdmVyZmxvd2VkIDggYml0cwoJYXNzZXJ0CglleHRyYWN0IDcgMQoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBleHRlcm5hbE1ldGhvZCgpOiBDdXN0b21UeXBlCmV4dGVybmFsTWV0aG9kOgoJcHJvdG8gMCAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLWV4dGVybmFsLmFsZ28udHM6MTEKCS8vIHRoaXMuZXh0ZXJuYWxLZXkudmFsdWUgPSA8Q3VzdG9tVHlwZT4xMjMKCWJ5dGUgMHg2NTc4NzQ2NTcyNmU2MTZjNGI2NTc5IC8vICJleHRlcm5hbEtleSIKCXB1c2hieXRlcyAweDdiCglhcHBfZ2xvYmFsX3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS1leHRlcm5hbC5hbGdvLnRzOjEyCgkvLyByZXR1cm4gdGhpcy5leHRlcm5hbEtleS52YWx1ZTsKCWJ5dGUgMHg2NTc4NzQ2NTcyNmU2MTZjNGI2NTc5IC8vICJleHRlcm5hbEtleSIKCWFwcF9nbG9iYWxfZ2V0CglidG9pCglyZXRzdWIKCi8vIGUoKXZvaWQKKmFiaV9yb3V0ZV9lOgoJLy8gZXhlY3V0ZSBlKCl2b2lkCgljYWxsc3ViIGUKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBlKCk6IHZvaWQKZToKCXByb3RvIDAgMAoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXBuIDIKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czo1MwoJLy8gdmFsOiBFeHRlcm5hbEN1c3RvbVR5cGUgPSA8RXh0ZXJuYWxDdXN0b21UeXBlPjEyMwoJcHVzaGludCAxMjMKCWZyYW1lX2J1cnkgMCAvLyB2YWw6IEV4dGVybmFsQ3VzdG9tVHlwZQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS5hbGdvLnRzOjU0CgkvLyBhc3NlcnQodGhpcy5leHRlcm5hbEtleS52YWx1ZSA9PT0gdmFsKQoJYnl0ZSAweDY1Nzg3NDY1NzI2ZTYxNmM0YjY1NzkgLy8gImV4dGVybmFsS2V5IgoJYXBwX2dsb2JhbF9nZXQKCWJ0b2kKCXB1c2hpbnQgMTIzIC8vIHZhbDogRXh0ZXJuYWxDdXN0b21UeXBlCgk9PQoJYXNzZXJ0CgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6NTUKCS8vIHggPSA8dWludDI1Nj4zMjEKCWJ5dGUgMHgwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMTQxCglmcmFtZV9idXJ5IDEgLy8geDogdWludDI1NgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS5hbGdvLnRzOjU2CgkvLyB5ID0gPEN1c3RvbVR5cGU+MzIxCglieXRlIDB4MDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDE0MQoJZnJhbWVfYnVyeSAyIC8vIHk6IHVpbnQyNTYKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czo1OAoJLy8gYXNzZXJ0KHggPT09IHkpCglieXRlIDB4MDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDE0MSAvLyB4OiB1aW50MjU2CglieXRlIDB4MDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDE0MSAvLyB5OiB1aW50MjU2CgliPT0KCWFzc2VydAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS5hbGdvLnRzOjYwCgkvLyBhc3NlcnQoTVlfQ09OU1QgPT09IDQ1NikKCXB1c2hpbnQgNDU2CglwdXNoaW50IDQ1NgoJPT0KCWFzc2VydAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS5hbGdvLnRzOjYxCgkvLyBhc3NlcnQoRVhURVJOQUxfQ09OU1QgPT09IDY1NCkKCXB1c2hpbnQgNjU0CglwdXNoaW50IDY1NAoJPT0KCWFzc2VydAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgxN2JlYTRiYiAvLyBtZXRob2QgImV4dGVybmFsTWV0aG9kKCl1aW50OCIKCXB1c2hieXRlcyAweDI3NzYzMGZjIC8vIG1ldGhvZCAiZSgpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfZXh0ZXJuYWxNZXRob2QgKmFiaV9yb3V0ZV9lCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/E.arc56_draft.json b/tests/contracts/artifacts/E.arc56_draft.json index 9bb27b69e..856ac4e9f 100644 --- a/tests/contracts/artifacts/E.arc56_draft.json +++ b/tests/contracts/artifacts/E.arc56_draft.json @@ -912,7 +912,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMTQxIDB4NjU3ODc0NjU3MjZlNjE2YzRiNjU3OSAweAoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDQuMQovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIGV4dGVybmFsTWV0aG9kKCl1aW50OAoqYWJpX3JvdXRlX2V4dGVybmFsTWV0aG9kOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgZXh0ZXJuYWxNZXRob2QoKXVpbnQ4CgljYWxsc3ViIGV4dGVybmFsTWV0aG9kCglpdG9iCglkdXAKCWJpdGxlbgoJcHVzaGludCA4Cgk8PQoKCS8vIGV4dGVybmFsTWV0aG9kIHJldHVybiB2YWx1ZSBvdmVyZmxvd2VkIDggYml0cwoJYXNzZXJ0CglleHRyYWN0IDcgMQoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBleHRlcm5hbE1ldGhvZCgpOiBDdXN0b21UeXBlCmV4dGVybmFsTWV0aG9kOgoJcHJvdG8gMCAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLWV4dGVybmFsLmFsZ28udHM6MTEKCS8vIHRoaXMuZXh0ZXJuYWxLZXkudmFsdWUgPSA8Q3VzdG9tVHlwZT4xMjMKCWJ5dGUgMHg2NTc4NzQ2NTcyNmU2MTZjNGI2NTc5IC8vICJleHRlcm5hbEtleSIKCXB1c2hieXRlcyAweDdiCglhcHBfZ2xvYmFsX3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS1leHRlcm5hbC5hbGdvLnRzOjEyCgkvLyByZXR1cm4gdGhpcy5leHRlcm5hbEtleS52YWx1ZTsKCWJ5dGUgMHg2NTc4NzQ2NTcyNmU2MTZjNGI2NTc5IC8vICJleHRlcm5hbEtleSIKCWFwcF9nbG9iYWxfZ2V0CglidG9pCglyZXRzdWIKCi8vIGUoKXZvaWQKKmFiaV9yb3V0ZV9lOgoJLy8gZXhlY3V0ZSBlKCl2b2lkCgljYWxsc3ViIGUKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBlKCk6IHZvaWQKZToKCXByb3RvIDAgMAoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXBuIDIKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czo1MwoJLy8gdmFsOiBFeHRlcm5hbEN1c3RvbVR5cGUgPSA8RXh0ZXJuYWxDdXN0b21UeXBlPjEyMwoJcHVzaGludCAxMjMKCWZyYW1lX2J1cnkgMCAvLyB2YWw6IEV4dGVybmFsQ3VzdG9tVHlwZQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS5hbGdvLnRzOjU0CgkvLyBhc3NlcnQodGhpcy5leHRlcm5hbEtleS52YWx1ZSA9PT0gdmFsKQoJYnl0ZSAweDY1Nzg3NDY1NzI2ZTYxNmM0YjY1NzkgLy8gImV4dGVybmFsS2V5IgoJYXBwX2dsb2JhbF9nZXQKCWJ0b2kKCXB1c2hpbnQgMTIzIC8vIHZhbDogRXh0ZXJuYWxDdXN0b21UeXBlCgk9PQoJYXNzZXJ0CgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6NTUKCS8vIHggPSA8dWludDI1Nj4zMjEKCWJ5dGUgMHgwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMTQxCglmcmFtZV9idXJ5IDEgLy8geDogdWludDI1NgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS5hbGdvLnRzOjU2CgkvLyB5ID0gPEN1c3RvbVR5cGU+MzIxCglieXRlIDB4MDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDE0MQoJZnJhbWVfYnVyeSAyIC8vIHk6IHVpbnQyNTYKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czo1OAoJLy8gYXNzZXJ0KHggPT09IHkpCglieXRlIDB4MDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDE0MSAvLyB4OiB1aW50MjU2CglieXRlIDB4MDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDE0MSAvLyB5OiB1aW50MjU2CgliPT0KCWFzc2VydAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS5hbGdvLnRzOjYwCgkvLyBhc3NlcnQoTVlfQ09OU1QgPT09IDQ1NikKCXB1c2hpbnQgNDU2CglwdXNoaW50IDQ1NgoJPT0KCWFzc2VydAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS5hbGdvLnRzOjYxCgkvLyBhc3NlcnQoRVhURVJOQUxfQ09OU1QgPT09IDY1NCkKCXB1c2hpbnQgNjU0CglwdXNoaW50IDY1NAoJPT0KCWFzc2VydAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgxN2JlYTRiYiAvLyBtZXRob2QgImV4dGVybmFsTWV0aG9kKCl1aW50OCIKCXB1c2hieXRlcyAweDI3NzYzMGZjIC8vIG1ldGhvZCAiZSgpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfZXh0ZXJuYWxNZXRob2QgKmFiaV9yb3V0ZV9lCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMTQxIDB4NjU3ODc0NjU3MjZlNjE2YzRiNjU3OSAweAoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDUuMAovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIGV4dGVybmFsTWV0aG9kKCl1aW50OAoqYWJpX3JvdXRlX2V4dGVybmFsTWV0aG9kOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgZXh0ZXJuYWxNZXRob2QoKXVpbnQ4CgljYWxsc3ViIGV4dGVybmFsTWV0aG9kCglpdG9iCglkdXAKCWJpdGxlbgoJcHVzaGludCA4Cgk8PQoKCS8vIGV4dGVybmFsTWV0aG9kIHJldHVybiB2YWx1ZSBvdmVyZmxvd2VkIDggYml0cwoJYXNzZXJ0CglleHRyYWN0IDcgMQoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBleHRlcm5hbE1ldGhvZCgpOiBDdXN0b21UeXBlCmV4dGVybmFsTWV0aG9kOgoJcHJvdG8gMCAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLWV4dGVybmFsLmFsZ28udHM6MTEKCS8vIHRoaXMuZXh0ZXJuYWxLZXkudmFsdWUgPSA8Q3VzdG9tVHlwZT4xMjMKCWJ5dGUgMHg2NTc4NzQ2NTcyNmU2MTZjNGI2NTc5IC8vICJleHRlcm5hbEtleSIKCXB1c2hieXRlcyAweDdiCglhcHBfZ2xvYmFsX3B1dAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS1leHRlcm5hbC5hbGdvLnRzOjEyCgkvLyByZXR1cm4gdGhpcy5leHRlcm5hbEtleS52YWx1ZTsKCWJ5dGUgMHg2NTc4NzQ2NTcyNmU2MTZjNGI2NTc5IC8vICJleHRlcm5hbEtleSIKCWFwcF9nbG9iYWxfZ2V0CglidG9pCglyZXRzdWIKCi8vIGUoKXZvaWQKKmFiaV9yb3V0ZV9lOgoJLy8gZXhlY3V0ZSBlKCl2b2lkCgljYWxsc3ViIGUKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBlKCk6IHZvaWQKZToKCXByb3RvIDAgMAoKCS8vIFB1c2ggZW1wdHkgYnl0ZXMgYWZ0ZXIgdGhlIGZyYW1lIHBvaW50ZXIgdG8gcmVzZXJ2ZSBzcGFjZSBmb3IgbG9jYWwgdmFyaWFibGVzCglieXRlIDB4CglkdXBuIDIKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czo1MwoJLy8gdmFsOiBFeHRlcm5hbEN1c3RvbVR5cGUgPSA8RXh0ZXJuYWxDdXN0b21UeXBlPjEyMwoJcHVzaGludCAxMjMKCWZyYW1lX2J1cnkgMCAvLyB2YWw6IEV4dGVybmFsQ3VzdG9tVHlwZQoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS5hbGdvLnRzOjU0CgkvLyBhc3NlcnQodGhpcy5leHRlcm5hbEtleS52YWx1ZSA9PT0gdmFsKQoJYnl0ZSAweDY1Nzg3NDY1NzI2ZTYxNmM0YjY1NzkgLy8gImV4dGVybmFsS2V5IgoJYXBwX2dsb2JhbF9nZXQKCWJ0b2kKCXB1c2hpbnQgMTIzIC8vIHZhbDogRXh0ZXJuYWxDdXN0b21UeXBlCgk9PQoJYXNzZXJ0CgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6NTUKCS8vIHggPSA8dWludDI1Nj4zMjEKCWJ5dGUgMHgwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMTQxCglmcmFtZV9idXJ5IDEgLy8geDogdWludDI1NgoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS5hbGdvLnRzOjU2CgkvLyB5ID0gPEN1c3RvbVR5cGU+MzIxCglieXRlIDB4MDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDE0MQoJZnJhbWVfYnVyeSAyIC8vIHk6IHVpbnQyNTYKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czo1OAoJLy8gYXNzZXJ0KHggPT09IHkpCglieXRlIDB4MDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDE0MSAvLyB4OiB1aW50MjU2CglieXRlIDB4MDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDE0MSAvLyB5OiB1aW50MjU2CgliPT0KCWFzc2VydAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS5hbGdvLnRzOjYwCgkvLyBhc3NlcnQoTVlfQ09OU1QgPT09IDQ1NikKCXB1c2hpbnQgNDU2CglwdXNoaW50IDQ1NgoJPT0KCWFzc2VydAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS5hbGdvLnRzOjYxCgkvLyBhc3NlcnQoRVhURVJOQUxfQ09OU1QgPT09IDY1NCkKCXB1c2hpbnQgNjU0CglwdXNoaW50IDY1NAoJPT0KCWFzc2VydAoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHgxN2JlYTRiYiAvLyBtZXRob2QgImV4dGVybmFsTWV0aG9kKCl1aW50OCIKCXB1c2hieXRlcyAweDI3NzYzMGZjIC8vIG1ldGhvZCAiZSgpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfZXh0ZXJuYWxNZXRob2QgKmFiaV9yb3V0ZV9lCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ExternalContract.approval.teal b/tests/contracts/artifacts/ExternalContract.approval.teal index 66a5083fb..ce3ba2631 100644 --- a/tests/contracts/artifacts/ExternalContract.approval.teal +++ b/tests/contracts/artifacts/ExternalContract.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x65787465726e616c4b6579 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ExternalContract.arc32.json b/tests/contracts/artifacts/ExternalContract.arc32.json index a4b2d77af..c264f9365 100644 --- a/tests/contracts/artifacts/ExternalContract.arc32.json +++ b/tests/contracts/artifacts/ExternalContract.arc32.json @@ -44,7 +44,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2NTc4NzQ2NTcyNmU2MTZjNGI2NTc5CgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZXh0ZXJuYWxNZXRob2QoKXVpbnQ4CiphYmlfcm91dGVfZXh0ZXJuYWxNZXRob2Q6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBleHRlcm5hbE1ldGhvZCgpdWludDgKCWNhbGxzdWIgZXh0ZXJuYWxNZXRob2QKCWl0b2IKCWR1cAoJYml0bGVuCglwdXNoaW50IDgKCTw9CgoJLy8gZXh0ZXJuYWxNZXRob2QgcmV0dXJuIHZhbHVlIG92ZXJmbG93ZWQgOCBiaXRzCglhc3NlcnQKCWV4dHJhY3QgNyAxCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGV4dGVybmFsTWV0aG9kKCk6IEN1c3RvbVR5cGUKZXh0ZXJuYWxNZXRob2Q6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UtZXh0ZXJuYWwuYWxnby50czoxMQoJLy8gdGhpcy5leHRlcm5hbEtleS52YWx1ZSA9IDxDdXN0b21UeXBlPjEyMwoJYnl0ZSAweDY1Nzg3NDY1NzI2ZTYxNmM0YjY1NzkgLy8gImV4dGVybmFsS2V5IgoJcHVzaGJ5dGVzIDB4N2IKCWFwcF9nbG9iYWxfcHV0CgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLWV4dGVybmFsLmFsZ28udHM6MTIKCS8vIHJldHVybiB0aGlzLmV4dGVybmFsS2V5LnZhbHVlOwoJYnl0ZSAweDY1Nzg3NDY1NzI2ZTYxNmM0YjY1NzkgLy8gImV4dGVybmFsS2V5IgoJYXBwX2dsb2JhbF9nZXQKCWJ0b2kKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MTdiZWE0YmIgLy8gbWV0aG9kICJleHRlcm5hbE1ldGhvZCgpdWludDgiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2V4dGVybmFsTWV0aG9kCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2NTc4NzQ2NTcyNmU2MTZjNGI2NTc5CgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZXh0ZXJuYWxNZXRob2QoKXVpbnQ4CiphYmlfcm91dGVfZXh0ZXJuYWxNZXRob2Q6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBleHRlcm5hbE1ldGhvZCgpdWludDgKCWNhbGxzdWIgZXh0ZXJuYWxNZXRob2QKCWl0b2IKCWR1cAoJYml0bGVuCglwdXNoaW50IDgKCTw9CgoJLy8gZXh0ZXJuYWxNZXRob2QgcmV0dXJuIHZhbHVlIG92ZXJmbG93ZWQgOCBiaXRzCglhc3NlcnQKCWV4dHJhY3QgNyAxCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGV4dGVybmFsTWV0aG9kKCk6IEN1c3RvbVR5cGUKZXh0ZXJuYWxNZXRob2Q6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UtZXh0ZXJuYWwuYWxnby50czoxMQoJLy8gdGhpcy5leHRlcm5hbEtleS52YWx1ZSA9IDxDdXN0b21UeXBlPjEyMwoJYnl0ZSAweDY1Nzg3NDY1NzI2ZTYxNmM0YjY1NzkgLy8gImV4dGVybmFsS2V5IgoJcHVzaGJ5dGVzIDB4N2IKCWFwcF9nbG9iYWxfcHV0CgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLWV4dGVybmFsLmFsZ28udHM6MTIKCS8vIHJldHVybiB0aGlzLmV4dGVybmFsS2V5LnZhbHVlOwoJYnl0ZSAweDY1Nzg3NDY1NzI2ZTYxNmM0YjY1NzkgLy8gImV4dGVybmFsS2V5IgoJYXBwX2dsb2JhbF9nZXQKCWJ0b2kKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MTdiZWE0YmIgLy8gbWV0aG9kICJleHRlcm5hbE1ldGhvZCgpdWludDgiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2V4dGVybmFsTWV0aG9kCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ExternalContract.arc56_draft.json b/tests/contracts/artifacts/ExternalContract.arc56_draft.json index 2e448903b..6df93313f 100644 --- a/tests/contracts/artifacts/ExternalContract.arc56_draft.json +++ b/tests/contracts/artifacts/ExternalContract.arc56_draft.json @@ -470,7 +470,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2NTc4NzQ2NTcyNmU2MTZjNGI2NTc5CgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZXh0ZXJuYWxNZXRob2QoKXVpbnQ4CiphYmlfcm91dGVfZXh0ZXJuYWxNZXRob2Q6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBleHRlcm5hbE1ldGhvZCgpdWludDgKCWNhbGxzdWIgZXh0ZXJuYWxNZXRob2QKCWl0b2IKCWR1cAoJYml0bGVuCglwdXNoaW50IDgKCTw9CgoJLy8gZXh0ZXJuYWxNZXRob2QgcmV0dXJuIHZhbHVlIG92ZXJmbG93ZWQgOCBiaXRzCglhc3NlcnQKCWV4dHJhY3QgNyAxCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGV4dGVybmFsTWV0aG9kKCk6IEN1c3RvbVR5cGUKZXh0ZXJuYWxNZXRob2Q6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UtZXh0ZXJuYWwuYWxnby50czoxMQoJLy8gdGhpcy5leHRlcm5hbEtleS52YWx1ZSA9IDxDdXN0b21UeXBlPjEyMwoJYnl0ZSAweDY1Nzg3NDY1NzI2ZTYxNmM0YjY1NzkgLy8gImV4dGVybmFsS2V5IgoJcHVzaGJ5dGVzIDB4N2IKCWFwcF9nbG9iYWxfcHV0CgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLWV4dGVybmFsLmFsZ28udHM6MTIKCS8vIHJldHVybiB0aGlzLmV4dGVybmFsS2V5LnZhbHVlOwoJYnl0ZSAweDY1Nzg3NDY1NzI2ZTYxNmM0YjY1NzkgLy8gImV4dGVybmFsS2V5IgoJYXBwX2dsb2JhbF9nZXQKCWJ0b2kKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MTdiZWE0YmIgLy8gbWV0aG9kICJleHRlcm5hbE1ldGhvZCgpdWludDgiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2V4dGVybmFsTWV0aG9kCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2NTc4NzQ2NTcyNmU2MTZjNGI2NTc5CgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gZXh0ZXJuYWxNZXRob2QoKXVpbnQ4CiphYmlfcm91dGVfZXh0ZXJuYWxNZXRob2Q6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBleHRlcm5hbE1ldGhvZCgpdWludDgKCWNhbGxzdWIgZXh0ZXJuYWxNZXRob2QKCWl0b2IKCWR1cAoJYml0bGVuCglwdXNoaW50IDgKCTw9CgoJLy8gZXh0ZXJuYWxNZXRob2QgcmV0dXJuIHZhbHVlIG92ZXJmbG93ZWQgOCBiaXRzCglhc3NlcnQKCWV4dHJhY3QgNyAxCgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIGV4dGVybmFsTWV0aG9kKCk6IEN1c3RvbVR5cGUKZXh0ZXJuYWxNZXRob2Q6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UtZXh0ZXJuYWwuYWxnby50czoxMQoJLy8gdGhpcy5leHRlcm5hbEtleS52YWx1ZSA9IDxDdXN0b21UeXBlPjEyMwoJYnl0ZSAweDY1Nzg3NDY1NzI2ZTYxNmM0YjY1NzkgLy8gImV4dGVybmFsS2V5IgoJcHVzaGJ5dGVzIDB4N2IKCWFwcF9nbG9iYWxfcHV0CgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLWV4dGVybmFsLmFsZ28udHM6MTIKCS8vIHJldHVybiB0aGlzLmV4dGVybmFsS2V5LnZhbHVlOwoJYnl0ZSAweDY1Nzg3NDY1NzI2ZTYxNmM0YjY1NzkgLy8gImV4dGVybmFsS2V5IgoJYXBwX2dsb2JhbF9nZXQKCWJ0b2kKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MTdiZWE0YmIgLy8gbWV0aG9kICJleHRlcm5hbE1ldGhvZCgpdWludDgiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2V4dGVybmFsTWV0aG9kCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/F.approval.teal b/tests/contracts/artifacts/F.approval.teal index 7c8c43430..1f8fa05d1 100644 --- a/tests/contracts/artifacts/F.approval.teal +++ b/tests/contracts/artifacts/F.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/F.arc32.json b/tests/contracts/artifacts/F.arc32.json index e351bc1c7..fad695000 100644 --- a/tests/contracts/artifacts/F.arc32.json +++ b/tests/contracts/artifacts/F.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcHVibGljTWV0aG9kKClzdHJpbmcKKmFiaV9yb3V0ZV9wdWJsaWNNZXRob2Q6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBwdWJsaWNNZXRob2QoKXN0cmluZwoJY2FsbHN1YiBwdWJsaWNNZXRob2QKCWR1cAoJbGVuCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHB1YmxpY01ldGhvZCgpOiBzdHJpbmcKcHVibGljTWV0aG9kOgoJcHJvdG8gMCAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6NjcKCS8vIHJldHVybiAncHVibGljJzsKCXB1c2hieXRlcyAweDcwNzU2MjZjNjk2MyAvLyAicHVibGljIgoJcmV0c3ViCgovLyBwcml2YXRlTWV0aG9kKCk6IHN0cmluZwpwcml2YXRlTWV0aG9kOgoJcHJvdG8gMCAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6NzEKCS8vIHJldHVybiAncHJpdmF0ZSc7CglwdXNoYnl0ZXMgMHg3MDcyNjk3NjYxNzQ2NSAvLyAicHJpdmF0ZSIKCXJldHN1YgoKLy8gcHJvdGVjdGVkTWV0aG9kKCk6IHN0cmluZwpwcm90ZWN0ZWRNZXRob2Q6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czo3NQoJLy8gcmV0dXJuICdwcm90ZWN0ZWQnOwoJcHVzaGJ5dGVzIDB4NzA3MjZmNzQ2NTYzNzQ2NTY0IC8vICJwcm90ZWN0ZWQiCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGUwNDE4YzU0IC8vIG1ldGhvZCAicHVibGljTWV0aG9kKClzdHJpbmciCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3B1YmxpY01ldGhvZAoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcHVibGljTWV0aG9kKClzdHJpbmcKKmFiaV9yb3V0ZV9wdWJsaWNNZXRob2Q6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBwdWJsaWNNZXRob2QoKXN0cmluZwoJY2FsbHN1YiBwdWJsaWNNZXRob2QKCWR1cAoJbGVuCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHB1YmxpY01ldGhvZCgpOiBzdHJpbmcKcHVibGljTWV0aG9kOgoJcHJvdG8gMCAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6NjcKCS8vIHJldHVybiAncHVibGljJzsKCXB1c2hieXRlcyAweDcwNzU2MjZjNjk2MyAvLyAicHVibGljIgoJcmV0c3ViCgovLyBwcml2YXRlTWV0aG9kKCk6IHN0cmluZwpwcml2YXRlTWV0aG9kOgoJcHJvdG8gMCAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6NzEKCS8vIHJldHVybiAncHJpdmF0ZSc7CglwdXNoYnl0ZXMgMHg3MDcyNjk3NjYxNzQ2NSAvLyAicHJpdmF0ZSIKCXJldHN1YgoKLy8gcHJvdGVjdGVkTWV0aG9kKCk6IHN0cmluZwpwcm90ZWN0ZWRNZXRob2Q6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czo3NQoJLy8gcmV0dXJuICdwcm90ZWN0ZWQnOwoJcHVzaGJ5dGVzIDB4NzA3MjZmNzQ2NTYzNzQ2NTY0IC8vICJwcm90ZWN0ZWQiCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGUwNDE4YzU0IC8vIG1ldGhvZCAicHVibGljTWV0aG9kKClzdHJpbmciCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3B1YmxpY01ldGhvZAoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/F.arc56_draft.json b/tests/contracts/artifacts/F.arc56_draft.json index 284c8a1f6..514680fca 100644 --- a/tests/contracts/artifacts/F.arc56_draft.json +++ b/tests/contracts/artifacts/F.arc56_draft.json @@ -445,7 +445,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcHVibGljTWV0aG9kKClzdHJpbmcKKmFiaV9yb3V0ZV9wdWJsaWNNZXRob2Q6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBwdWJsaWNNZXRob2QoKXN0cmluZwoJY2FsbHN1YiBwdWJsaWNNZXRob2QKCWR1cAoJbGVuCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHB1YmxpY01ldGhvZCgpOiBzdHJpbmcKcHVibGljTWV0aG9kOgoJcHJvdG8gMCAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6NjcKCS8vIHJldHVybiAncHVibGljJzsKCXB1c2hieXRlcyAweDcwNzU2MjZjNjk2MyAvLyAicHVibGljIgoJcmV0c3ViCgovLyBwcml2YXRlTWV0aG9kKCk6IHN0cmluZwpwcml2YXRlTWV0aG9kOgoJcHJvdG8gMCAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6NzEKCS8vIHJldHVybiAncHJpdmF0ZSc7CglwdXNoYnl0ZXMgMHg3MDcyNjk3NjYxNzQ2NSAvLyAicHJpdmF0ZSIKCXJldHN1YgoKLy8gcHJvdGVjdGVkTWV0aG9kKCk6IHN0cmluZwpwcm90ZWN0ZWRNZXRob2Q6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czo3NQoJLy8gcmV0dXJuICdwcm90ZWN0ZWQnOwoJcHVzaGJ5dGVzIDB4NzA3MjZmNzQ2NTYzNzQ2NTY0IC8vICJwcm90ZWN0ZWQiCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGUwNDE4YzU0IC8vIG1ldGhvZCAicHVibGljTWV0aG9kKClzdHJpbmciCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3B1YmxpY01ldGhvZAoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcHVibGljTWV0aG9kKClzdHJpbmcKKmFiaV9yb3V0ZV9wdWJsaWNNZXRob2Q6CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCXB1c2hieXRlcyAweDE1MWY3Yzc1CgoJLy8gZXhlY3V0ZSBwdWJsaWNNZXRob2QoKXN0cmluZwoJY2FsbHN1YiBwdWJsaWNNZXRob2QKCWR1cAoJbGVuCglpdG9iCglleHRyYWN0IDYgMgoJc3dhcAoJY29uY2F0Cgljb25jYXQKCWxvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHB1YmxpY01ldGhvZCgpOiBzdHJpbmcKcHVibGljTWV0aG9kOgoJcHJvdG8gMCAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6NjcKCS8vIHJldHVybiAncHVibGljJzsKCXB1c2hieXRlcyAweDcwNzU2MjZjNjk2MyAvLyAicHVibGljIgoJcmV0c3ViCgovLyBwcml2YXRlTWV0aG9kKCk6IHN0cmluZwpwcml2YXRlTWV0aG9kOgoJcHJvdG8gMCAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6NzEKCS8vIHJldHVybiAncHJpdmF0ZSc7CglwdXNoYnl0ZXMgMHg3MDcyNjk3NjYxNzQ2NSAvLyAicHJpdmF0ZSIKCXJldHN1YgoKLy8gcHJvdGVjdGVkTWV0aG9kKCk6IHN0cmluZwpwcm90ZWN0ZWRNZXRob2Q6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czo3NQoJLy8gcmV0dXJuICdwcm90ZWN0ZWQnOwoJcHVzaGJ5dGVzIDB4NzA3MjZmNzQ2NTYzNzQ2NTY0IC8vICJwcm90ZWN0ZWQiCglyZXRzdWIKCiphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb246CglwdXNoaW50IDEKCXJldHVybgoKKmNyZWF0ZV9Ob09wOgoJcHVzaGJ5dGVzIDB4Yjg0NDdiMzYgLy8gbWV0aG9kICJjcmVhdGVBcHBsaWNhdGlvbigpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY3JlYXRlQXBwbGljYXRpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY3JlYXRlIE5vT3AKCWVycgoKKmNhbGxfTm9PcDoKCXB1c2hieXRlcyAweGUwNDE4YzU0IC8vIG1ldGhvZCAicHVibGljTWV0aG9kKClzdHJpbmciCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX3B1YmxpY01ldGhvZAoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/FunctionsTest.approval.teal b/tests/contracts/artifacts/FunctionsTest.approval.teal index 5137842a2..8cc5c8738 100644 --- a/tests/contracts/artifacts/FunctionsTest.approval.teal +++ b/tests/contracts/artifacts/FunctionsTest.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x151f7c75 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/FunctionsTest.arc32.json b/tests/contracts/artifacts/FunctionsTest.arc32.json index fd54c186d..6210dfc45 100644 --- a/tests/contracts/artifacts/FunctionsTest.arc32.json +++ b/tests/contracts/artifacts/FunctionsTest.arc32.json @@ -49,7 +49,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgxNTFmN2M3NQoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDQuMQovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIGNhbGxOb25DbGFzc0Z1bmN0aW9uKHVpbnQ2NCx1aW50NjQpdWludDY0CiphYmlfcm91dGVfY2FsbE5vbkNsYXNzRnVuY3Rpb246CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCWJ5dGUgMHgxNTFmN2M3NQoKCS8vIGI6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMgoJYnRvaQoKCS8vIGE6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJYnRvaQoKCS8vIGV4ZWN1dGUgY2FsbE5vbkNsYXNzRnVuY3Rpb24odWludDY0LHVpbnQ2NCl1aW50NjQKCWNhbGxzdWIgY2FsbE5vbkNsYXNzRnVuY3Rpb24KCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gY2FsbE5vbkNsYXNzRnVuY3Rpb24oYTogdWludDY0LCBiOiB1aW50NjQpOiB1aW50NjQKY2FsbE5vbkNsYXNzRnVuY3Rpb246Cglwcm90byAyIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvZnVuY3Rpb25zLmFsZ28udHM6MTIKCS8vIHJldHVybiBub25DbGFzc0Z1bmN0aW9uKGEsIGIpOwoJZnJhbWVfZGlnIC0yIC8vIGI6IHVpbnQ2NAoJZnJhbWVfZGlnIC0xIC8vIGE6IHVpbnQ2NAoJY2FsbHN1YiBub25DbGFzc0Z1bmN0aW9uCglyZXRzdWIKCi8vIGNhbGxFeHRlcm5hbEZ1bmN0aW9uKHVpbnQ2NCx1aW50NjQpdWludDY0CiphYmlfcm91dGVfY2FsbEV4dGVybmFsRnVuY3Rpb246CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCWJ5dGUgMHgxNTFmN2M3NQoKCS8vIGI6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMgoJYnRvaQoKCS8vIGE6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJYnRvaQoKCS8vIGV4ZWN1dGUgY2FsbEV4dGVybmFsRnVuY3Rpb24odWludDY0LHVpbnQ2NCl1aW50NjQKCWNhbGxzdWIgY2FsbEV4dGVybmFsRnVuY3Rpb24KCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gY2FsbEV4dGVybmFsRnVuY3Rpb24oYTogdWludDY0LCBiOiB1aW50NjQpOiB1aW50NjQKY2FsbEV4dGVybmFsRnVuY3Rpb246Cglwcm90byAyIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvZnVuY3Rpb25zLmFsZ28udHM6MTYKCS8vIHJldHVybiBleHRlcm5hbEZ1bmN0aW9uKGEsIGIpOwoJZnJhbWVfZGlnIC0yIC8vIGI6IHVpbnQ2NAoJZnJhbWVfZGlnIC0xIC8vIGE6IHVpbnQ2NAoJY2FsbHN1YiBleHRlcm5hbEZ1bmN0aW9uCglyZXRzdWIKCi8vIGNhbGxQYWNrYWdlRnVuY3Rpb24odWludDY0LHVpbnQ2NCl1aW50NjQKKmFiaV9yb3V0ZV9jYWxsUGFja2FnZUZ1bmN0aW9uOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglieXRlIDB4MTUxZjdjNzUKCgkvLyBiOiB1aW50NjQKCXR4bmEgQXBwbGljYXRpb25BcmdzIDIKCWJ0b2kKCgkvLyBhOiB1aW50NjQKCXR4bmEgQXBwbGljYXRpb25BcmdzIDEKCWJ0b2kKCgkvLyBleGVjdXRlIGNhbGxQYWNrYWdlRnVuY3Rpb24odWludDY0LHVpbnQ2NCl1aW50NjQKCWNhbGxzdWIgY2FsbFBhY2thZ2VGdW5jdGlvbgoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBjYWxsUGFja2FnZUZ1bmN0aW9uKGE6IHVpbnQ2NCwgYjogdWludDY0KTogdWludDY0CmNhbGxQYWNrYWdlRnVuY3Rpb246Cglwcm90byAyIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvZnVuY3Rpb25zLmFsZ28udHM6MjAKCS8vIHJldHVybiBwYWNrYWdlRnVuY3Rpb24oYSwgYik7CglmcmFtZV9kaWcgLTIgLy8gYjogdWludDY0CglmcmFtZV9kaWcgLTEgLy8gYTogdWludDY0CgljYWxsc3ViIHBhY2thZ2VGdW5jdGlvbgoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg4ZmQyM2I0OCAvLyBtZXRob2QgImNhbGxOb25DbGFzc0Z1bmN0aW9uKHVpbnQ2NCx1aW50NjQpdWludDY0IgoJcHVzaGJ5dGVzIDB4ZjVkYjNiNDEgLy8gbWV0aG9kICJjYWxsRXh0ZXJuYWxGdW5jdGlvbih1aW50NjQsdWludDY0KXVpbnQ2NCIKCXB1c2hieXRlcyAweDhiNzg5MTk2IC8vIG1ldGhvZCAiY2FsbFBhY2thZ2VGdW5jdGlvbih1aW50NjQsdWludDY0KXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY2FsbE5vbkNsYXNzRnVuY3Rpb24gKmFiaV9yb3V0ZV9jYWxsRXh0ZXJuYWxGdW5jdGlvbiAqYWJpX3JvdXRlX2NhbGxQYWNrYWdlRnVuY3Rpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnIKCi8vIHBhY2thZ2VGdW5jdGlvbihhOiB1aW50NjQsIGI6IHVpbnQ2NCk6IHVpbnQ2NApwYWNrYWdlRnVuY3Rpb246Cglwcm90byAyIDEKCgkvLyBub2RlX21vZHVsZXMvdGVhbHNjcmlwdF90ZXN0X3BhY2thZ2UvaW5kZXgudHM6NAoJLy8gcmV0dXJuIGEgKyBiOwoJZnJhbWVfZGlnIC0xIC8vIGE6IHVpbnQ2NAoJZnJhbWVfZGlnIC0yIC8vIGI6IHVpbnQ2NAoJKwoJcmV0c3ViCgovLyBleHRlcm5hbEZ1bmN0aW9uKGE6IHVpbnQ2NCwgYjogdWludDY0KTogdWludDY0CmV4dGVybmFsRnVuY3Rpb246Cglwcm90byAyIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvZnVuY3Rpb25zLWV4dGVybmFsLmFsZ28udHM6MgoJLy8gcmV0dXJuIGEgKyBiOwoJZnJhbWVfZGlnIC0xIC8vIGE6IHVpbnQ2NAoJZnJhbWVfZGlnIC0yIC8vIGI6IHVpbnQ2NAoJKwoJcmV0c3ViCgovLyBub25DbGFzc0Z1bmN0aW9uKGE6IHVpbnQ2NCwgYjogdWludDY0KTogdWludDY0Cm5vbkNsYXNzRnVuY3Rpb246Cglwcm90byAyIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvZnVuY3Rpb25zLmFsZ28udHM6NwoJLy8gcmV0dXJuIGEgKyBiOwoJZnJhbWVfZGlnIC0xIC8vIGE6IHVpbnQ2NAoJZnJhbWVfZGlnIC0yIC8vIGI6IHVpbnQ2NAoJKwoJcmV0c3Vi", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgxNTFmN2M3NQoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDUuMAovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIGNhbGxOb25DbGFzc0Z1bmN0aW9uKHVpbnQ2NCx1aW50NjQpdWludDY0CiphYmlfcm91dGVfY2FsbE5vbkNsYXNzRnVuY3Rpb246CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCWJ5dGUgMHgxNTFmN2M3NQoKCS8vIGI6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMgoJYnRvaQoKCS8vIGE6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJYnRvaQoKCS8vIGV4ZWN1dGUgY2FsbE5vbkNsYXNzRnVuY3Rpb24odWludDY0LHVpbnQ2NCl1aW50NjQKCWNhbGxzdWIgY2FsbE5vbkNsYXNzRnVuY3Rpb24KCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gY2FsbE5vbkNsYXNzRnVuY3Rpb24oYTogdWludDY0LCBiOiB1aW50NjQpOiB1aW50NjQKY2FsbE5vbkNsYXNzRnVuY3Rpb246Cglwcm90byAyIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvZnVuY3Rpb25zLmFsZ28udHM6MTIKCS8vIHJldHVybiBub25DbGFzc0Z1bmN0aW9uKGEsIGIpOwoJZnJhbWVfZGlnIC0yIC8vIGI6IHVpbnQ2NAoJZnJhbWVfZGlnIC0xIC8vIGE6IHVpbnQ2NAoJY2FsbHN1YiBub25DbGFzc0Z1bmN0aW9uCglyZXRzdWIKCi8vIGNhbGxFeHRlcm5hbEZ1bmN0aW9uKHVpbnQ2NCx1aW50NjQpdWludDY0CiphYmlfcm91dGVfY2FsbEV4dGVybmFsRnVuY3Rpb246CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCWJ5dGUgMHgxNTFmN2M3NQoKCS8vIGI6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMgoJYnRvaQoKCS8vIGE6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJYnRvaQoKCS8vIGV4ZWN1dGUgY2FsbEV4dGVybmFsRnVuY3Rpb24odWludDY0LHVpbnQ2NCl1aW50NjQKCWNhbGxzdWIgY2FsbEV4dGVybmFsRnVuY3Rpb24KCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gY2FsbEV4dGVybmFsRnVuY3Rpb24oYTogdWludDY0LCBiOiB1aW50NjQpOiB1aW50NjQKY2FsbEV4dGVybmFsRnVuY3Rpb246Cglwcm90byAyIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvZnVuY3Rpb25zLmFsZ28udHM6MTYKCS8vIHJldHVybiBleHRlcm5hbEZ1bmN0aW9uKGEsIGIpOwoJZnJhbWVfZGlnIC0yIC8vIGI6IHVpbnQ2NAoJZnJhbWVfZGlnIC0xIC8vIGE6IHVpbnQ2NAoJY2FsbHN1YiBleHRlcm5hbEZ1bmN0aW9uCglyZXRzdWIKCi8vIGNhbGxQYWNrYWdlRnVuY3Rpb24odWludDY0LHVpbnQ2NCl1aW50NjQKKmFiaV9yb3V0ZV9jYWxsUGFja2FnZUZ1bmN0aW9uOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglieXRlIDB4MTUxZjdjNzUKCgkvLyBiOiB1aW50NjQKCXR4bmEgQXBwbGljYXRpb25BcmdzIDIKCWJ0b2kKCgkvLyBhOiB1aW50NjQKCXR4bmEgQXBwbGljYXRpb25BcmdzIDEKCWJ0b2kKCgkvLyBleGVjdXRlIGNhbGxQYWNrYWdlRnVuY3Rpb24odWludDY0LHVpbnQ2NCl1aW50NjQKCWNhbGxzdWIgY2FsbFBhY2thZ2VGdW5jdGlvbgoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBjYWxsUGFja2FnZUZ1bmN0aW9uKGE6IHVpbnQ2NCwgYjogdWludDY0KTogdWludDY0CmNhbGxQYWNrYWdlRnVuY3Rpb246Cglwcm90byAyIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvZnVuY3Rpb25zLmFsZ28udHM6MjAKCS8vIHJldHVybiBwYWNrYWdlRnVuY3Rpb24oYSwgYik7CglmcmFtZV9kaWcgLTIgLy8gYjogdWludDY0CglmcmFtZV9kaWcgLTEgLy8gYTogdWludDY0CgljYWxsc3ViIHBhY2thZ2VGdW5jdGlvbgoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg4ZmQyM2I0OCAvLyBtZXRob2QgImNhbGxOb25DbGFzc0Z1bmN0aW9uKHVpbnQ2NCx1aW50NjQpdWludDY0IgoJcHVzaGJ5dGVzIDB4ZjVkYjNiNDEgLy8gbWV0aG9kICJjYWxsRXh0ZXJuYWxGdW5jdGlvbih1aW50NjQsdWludDY0KXVpbnQ2NCIKCXB1c2hieXRlcyAweDhiNzg5MTk2IC8vIG1ldGhvZCAiY2FsbFBhY2thZ2VGdW5jdGlvbih1aW50NjQsdWludDY0KXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY2FsbE5vbkNsYXNzRnVuY3Rpb24gKmFiaV9yb3V0ZV9jYWxsRXh0ZXJuYWxGdW5jdGlvbiAqYWJpX3JvdXRlX2NhbGxQYWNrYWdlRnVuY3Rpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnIKCi8vIHBhY2thZ2VGdW5jdGlvbihhOiB1aW50NjQsIGI6IHVpbnQ2NCk6IHVpbnQ2NApwYWNrYWdlRnVuY3Rpb246Cglwcm90byAyIDEKCgkvLyBub2RlX21vZHVsZXMvdGVhbHNjcmlwdF90ZXN0X3BhY2thZ2UvaW5kZXgudHM6NAoJLy8gcmV0dXJuIGEgKyBiOwoJZnJhbWVfZGlnIC0xIC8vIGE6IHVpbnQ2NAoJZnJhbWVfZGlnIC0yIC8vIGI6IHVpbnQ2NAoJKwoJcmV0c3ViCgovLyBleHRlcm5hbEZ1bmN0aW9uKGE6IHVpbnQ2NCwgYjogdWludDY0KTogdWludDY0CmV4dGVybmFsRnVuY3Rpb246Cglwcm90byAyIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvZnVuY3Rpb25zLWV4dGVybmFsLmFsZ28udHM6MgoJLy8gcmV0dXJuIGEgKyBiOwoJZnJhbWVfZGlnIC0xIC8vIGE6IHVpbnQ2NAoJZnJhbWVfZGlnIC0yIC8vIGI6IHVpbnQ2NAoJKwoJcmV0c3ViCgovLyBub25DbGFzc0Z1bmN0aW9uKGE6IHVpbnQ2NCwgYjogdWludDY0KTogdWludDY0Cm5vbkNsYXNzRnVuY3Rpb246Cglwcm90byAyIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvZnVuY3Rpb25zLmFsZ28udHM6NwoJLy8gcmV0dXJuIGEgKyBiOwoJZnJhbWVfZGlnIC0xIC8vIGE6IHVpbnQ2NAoJZnJhbWVfZGlnIC0yIC8vIGI6IHVpbnQ2NAoJKwoJcmV0c3Vi", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/FunctionsTest.arc56_draft.json b/tests/contracts/artifacts/FunctionsTest.arc56_draft.json index 865951e5b..15e10bbb2 100644 --- a/tests/contracts/artifacts/FunctionsTest.arc56_draft.json +++ b/tests/contracts/artifacts/FunctionsTest.arc56_draft.json @@ -858,7 +858,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgxNTFmN2M3NQoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDQuMQovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIGNhbGxOb25DbGFzc0Z1bmN0aW9uKHVpbnQ2NCx1aW50NjQpdWludDY0CiphYmlfcm91dGVfY2FsbE5vbkNsYXNzRnVuY3Rpb246CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCWJ5dGUgMHgxNTFmN2M3NQoKCS8vIGI6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMgoJYnRvaQoKCS8vIGE6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJYnRvaQoKCS8vIGV4ZWN1dGUgY2FsbE5vbkNsYXNzRnVuY3Rpb24odWludDY0LHVpbnQ2NCl1aW50NjQKCWNhbGxzdWIgY2FsbE5vbkNsYXNzRnVuY3Rpb24KCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gY2FsbE5vbkNsYXNzRnVuY3Rpb24oYTogdWludDY0LCBiOiB1aW50NjQpOiB1aW50NjQKY2FsbE5vbkNsYXNzRnVuY3Rpb246Cglwcm90byAyIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvZnVuY3Rpb25zLmFsZ28udHM6MTIKCS8vIHJldHVybiBub25DbGFzc0Z1bmN0aW9uKGEsIGIpOwoJZnJhbWVfZGlnIC0yIC8vIGI6IHVpbnQ2NAoJZnJhbWVfZGlnIC0xIC8vIGE6IHVpbnQ2NAoJY2FsbHN1YiBub25DbGFzc0Z1bmN0aW9uCglyZXRzdWIKCi8vIGNhbGxFeHRlcm5hbEZ1bmN0aW9uKHVpbnQ2NCx1aW50NjQpdWludDY0CiphYmlfcm91dGVfY2FsbEV4dGVybmFsRnVuY3Rpb246CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCWJ5dGUgMHgxNTFmN2M3NQoKCS8vIGI6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMgoJYnRvaQoKCS8vIGE6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJYnRvaQoKCS8vIGV4ZWN1dGUgY2FsbEV4dGVybmFsRnVuY3Rpb24odWludDY0LHVpbnQ2NCl1aW50NjQKCWNhbGxzdWIgY2FsbEV4dGVybmFsRnVuY3Rpb24KCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gY2FsbEV4dGVybmFsRnVuY3Rpb24oYTogdWludDY0LCBiOiB1aW50NjQpOiB1aW50NjQKY2FsbEV4dGVybmFsRnVuY3Rpb246Cglwcm90byAyIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvZnVuY3Rpb25zLmFsZ28udHM6MTYKCS8vIHJldHVybiBleHRlcm5hbEZ1bmN0aW9uKGEsIGIpOwoJZnJhbWVfZGlnIC0yIC8vIGI6IHVpbnQ2NAoJZnJhbWVfZGlnIC0xIC8vIGE6IHVpbnQ2NAoJY2FsbHN1YiBleHRlcm5hbEZ1bmN0aW9uCglyZXRzdWIKCi8vIGNhbGxQYWNrYWdlRnVuY3Rpb24odWludDY0LHVpbnQ2NCl1aW50NjQKKmFiaV9yb3V0ZV9jYWxsUGFja2FnZUZ1bmN0aW9uOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglieXRlIDB4MTUxZjdjNzUKCgkvLyBiOiB1aW50NjQKCXR4bmEgQXBwbGljYXRpb25BcmdzIDIKCWJ0b2kKCgkvLyBhOiB1aW50NjQKCXR4bmEgQXBwbGljYXRpb25BcmdzIDEKCWJ0b2kKCgkvLyBleGVjdXRlIGNhbGxQYWNrYWdlRnVuY3Rpb24odWludDY0LHVpbnQ2NCl1aW50NjQKCWNhbGxzdWIgY2FsbFBhY2thZ2VGdW5jdGlvbgoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBjYWxsUGFja2FnZUZ1bmN0aW9uKGE6IHVpbnQ2NCwgYjogdWludDY0KTogdWludDY0CmNhbGxQYWNrYWdlRnVuY3Rpb246Cglwcm90byAyIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvZnVuY3Rpb25zLmFsZ28udHM6MjAKCS8vIHJldHVybiBwYWNrYWdlRnVuY3Rpb24oYSwgYik7CglmcmFtZV9kaWcgLTIgLy8gYjogdWludDY0CglmcmFtZV9kaWcgLTEgLy8gYTogdWludDY0CgljYWxsc3ViIHBhY2thZ2VGdW5jdGlvbgoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg4ZmQyM2I0OCAvLyBtZXRob2QgImNhbGxOb25DbGFzc0Z1bmN0aW9uKHVpbnQ2NCx1aW50NjQpdWludDY0IgoJcHVzaGJ5dGVzIDB4ZjVkYjNiNDEgLy8gbWV0aG9kICJjYWxsRXh0ZXJuYWxGdW5jdGlvbih1aW50NjQsdWludDY0KXVpbnQ2NCIKCXB1c2hieXRlcyAweDhiNzg5MTk2IC8vIG1ldGhvZCAiY2FsbFBhY2thZ2VGdW5jdGlvbih1aW50NjQsdWludDY0KXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY2FsbE5vbkNsYXNzRnVuY3Rpb24gKmFiaV9yb3V0ZV9jYWxsRXh0ZXJuYWxGdW5jdGlvbiAqYWJpX3JvdXRlX2NhbGxQYWNrYWdlRnVuY3Rpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnIKCi8vIHBhY2thZ2VGdW5jdGlvbihhOiB1aW50NjQsIGI6IHVpbnQ2NCk6IHVpbnQ2NApwYWNrYWdlRnVuY3Rpb246Cglwcm90byAyIDEKCgkvLyBub2RlX21vZHVsZXMvdGVhbHNjcmlwdF90ZXN0X3BhY2thZ2UvaW5kZXgudHM6NAoJLy8gcmV0dXJuIGEgKyBiOwoJZnJhbWVfZGlnIC0xIC8vIGE6IHVpbnQ2NAoJZnJhbWVfZGlnIC0yIC8vIGI6IHVpbnQ2NAoJKwoJcmV0c3ViCgovLyBleHRlcm5hbEZ1bmN0aW9uKGE6IHVpbnQ2NCwgYjogdWludDY0KTogdWludDY0CmV4dGVybmFsRnVuY3Rpb246Cglwcm90byAyIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvZnVuY3Rpb25zLWV4dGVybmFsLmFsZ28udHM6MgoJLy8gcmV0dXJuIGEgKyBiOwoJZnJhbWVfZGlnIC0xIC8vIGE6IHVpbnQ2NAoJZnJhbWVfZGlnIC0yIC8vIGI6IHVpbnQ2NAoJKwoJcmV0c3ViCgovLyBub25DbGFzc0Z1bmN0aW9uKGE6IHVpbnQ2NCwgYjogdWludDY0KTogdWludDY0Cm5vbkNsYXNzRnVuY3Rpb246Cglwcm90byAyIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvZnVuY3Rpb25zLmFsZ28udHM6NwoJLy8gcmV0dXJuIGEgKyBiOwoJZnJhbWVfZGlnIC0xIC8vIGE6IHVpbnQ2NAoJZnJhbWVfZGlnIC0yIC8vIGI6IHVpbnQ2NAoJKwoJcmV0c3Vi", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHgxNTFmN2M3NQoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDUuMAovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIGNhbGxOb25DbGFzc0Z1bmN0aW9uKHVpbnQ2NCx1aW50NjQpdWludDY0CiphYmlfcm91dGVfY2FsbE5vbkNsYXNzRnVuY3Rpb246CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCWJ5dGUgMHgxNTFmN2M3NQoKCS8vIGI6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMgoJYnRvaQoKCS8vIGE6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJYnRvaQoKCS8vIGV4ZWN1dGUgY2FsbE5vbkNsYXNzRnVuY3Rpb24odWludDY0LHVpbnQ2NCl1aW50NjQKCWNhbGxzdWIgY2FsbE5vbkNsYXNzRnVuY3Rpb24KCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gY2FsbE5vbkNsYXNzRnVuY3Rpb24oYTogdWludDY0LCBiOiB1aW50NjQpOiB1aW50NjQKY2FsbE5vbkNsYXNzRnVuY3Rpb246Cglwcm90byAyIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvZnVuY3Rpb25zLmFsZ28udHM6MTIKCS8vIHJldHVybiBub25DbGFzc0Z1bmN0aW9uKGEsIGIpOwoJZnJhbWVfZGlnIC0yIC8vIGI6IHVpbnQ2NAoJZnJhbWVfZGlnIC0xIC8vIGE6IHVpbnQ2NAoJY2FsbHN1YiBub25DbGFzc0Z1bmN0aW9uCglyZXRzdWIKCi8vIGNhbGxFeHRlcm5hbEZ1bmN0aW9uKHVpbnQ2NCx1aW50NjQpdWludDY0CiphYmlfcm91dGVfY2FsbEV4dGVybmFsRnVuY3Rpb246CgkvLyBUaGUgQUJJIHJldHVybiBwcmVmaXgKCWJ5dGUgMHgxNTFmN2M3NQoKCS8vIGI6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMgoJYnRvaQoKCS8vIGE6IHVpbnQ2NAoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMQoJYnRvaQoKCS8vIGV4ZWN1dGUgY2FsbEV4dGVybmFsRnVuY3Rpb24odWludDY0LHVpbnQ2NCl1aW50NjQKCWNhbGxzdWIgY2FsbEV4dGVybmFsRnVuY3Rpb24KCWl0b2IKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gY2FsbEV4dGVybmFsRnVuY3Rpb24oYTogdWludDY0LCBiOiB1aW50NjQpOiB1aW50NjQKY2FsbEV4dGVybmFsRnVuY3Rpb246Cglwcm90byAyIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvZnVuY3Rpb25zLmFsZ28udHM6MTYKCS8vIHJldHVybiBleHRlcm5hbEZ1bmN0aW9uKGEsIGIpOwoJZnJhbWVfZGlnIC0yIC8vIGI6IHVpbnQ2NAoJZnJhbWVfZGlnIC0xIC8vIGE6IHVpbnQ2NAoJY2FsbHN1YiBleHRlcm5hbEZ1bmN0aW9uCglyZXRzdWIKCi8vIGNhbGxQYWNrYWdlRnVuY3Rpb24odWludDY0LHVpbnQ2NCl1aW50NjQKKmFiaV9yb3V0ZV9jYWxsUGFja2FnZUZ1bmN0aW9uOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglieXRlIDB4MTUxZjdjNzUKCgkvLyBiOiB1aW50NjQKCXR4bmEgQXBwbGljYXRpb25BcmdzIDIKCWJ0b2kKCgkvLyBhOiB1aW50NjQKCXR4bmEgQXBwbGljYXRpb25BcmdzIDEKCWJ0b2kKCgkvLyBleGVjdXRlIGNhbGxQYWNrYWdlRnVuY3Rpb24odWludDY0LHVpbnQ2NCl1aW50NjQKCWNhbGxzdWIgY2FsbFBhY2thZ2VGdW5jdGlvbgoJaXRvYgoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBjYWxsUGFja2FnZUZ1bmN0aW9uKGE6IHVpbnQ2NCwgYjogdWludDY0KTogdWludDY0CmNhbGxQYWNrYWdlRnVuY3Rpb246Cglwcm90byAyIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvZnVuY3Rpb25zLmFsZ28udHM6MjAKCS8vIHJldHVybiBwYWNrYWdlRnVuY3Rpb24oYSwgYik7CglmcmFtZV9kaWcgLTIgLy8gYjogdWludDY0CglmcmFtZV9kaWcgLTEgLy8gYTogdWludDY0CgljYWxsc3ViIHBhY2thZ2VGdW5jdGlvbgoJcmV0c3ViCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnIKCipjYWxsX05vT3A6CglwdXNoYnl0ZXMgMHg4ZmQyM2I0OCAvLyBtZXRob2QgImNhbGxOb25DbGFzc0Z1bmN0aW9uKHVpbnQ2NCx1aW50NjQpdWludDY0IgoJcHVzaGJ5dGVzIDB4ZjVkYjNiNDEgLy8gbWV0aG9kICJjYWxsRXh0ZXJuYWxGdW5jdGlvbih1aW50NjQsdWludDY0KXVpbnQ2NCIKCXB1c2hieXRlcyAweDhiNzg5MTk2IC8vIG1ldGhvZCAiY2FsbFBhY2thZ2VGdW5jdGlvbih1aW50NjQsdWludDY0KXVpbnQ2NCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfY2FsbE5vbkNsYXNzRnVuY3Rpb24gKmFiaV9yb3V0ZV9jYWxsRXh0ZXJuYWxGdW5jdGlvbiAqYWJpX3JvdXRlX2NhbGxQYWNrYWdlRnVuY3Rpb24KCgkvLyB0aGlzIGNvbnRyYWN0IGRvZXMgbm90IGltcGxlbWVudCB0aGUgZ2l2ZW4gQUJJIG1ldGhvZCBmb3IgY2FsbCBOb09wCgllcnIKCi8vIHBhY2thZ2VGdW5jdGlvbihhOiB1aW50NjQsIGI6IHVpbnQ2NCk6IHVpbnQ2NApwYWNrYWdlRnVuY3Rpb246Cglwcm90byAyIDEKCgkvLyBub2RlX21vZHVsZXMvdGVhbHNjcmlwdF90ZXN0X3BhY2thZ2UvaW5kZXgudHM6NAoJLy8gcmV0dXJuIGEgKyBiOwoJZnJhbWVfZGlnIC0xIC8vIGE6IHVpbnQ2NAoJZnJhbWVfZGlnIC0yIC8vIGI6IHVpbnQ2NAoJKwoJcmV0c3ViCgovLyBleHRlcm5hbEZ1bmN0aW9uKGE6IHVpbnQ2NCwgYjogdWludDY0KTogdWludDY0CmV4dGVybmFsRnVuY3Rpb246Cglwcm90byAyIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvZnVuY3Rpb25zLWV4dGVybmFsLmFsZ28udHM6MgoJLy8gcmV0dXJuIGEgKyBiOwoJZnJhbWVfZGlnIC0xIC8vIGE6IHVpbnQ2NAoJZnJhbWVfZGlnIC0yIC8vIGI6IHVpbnQ2NAoJKwoJcmV0c3ViCgovLyBub25DbGFzc0Z1bmN0aW9uKGE6IHVpbnQ2NCwgYjogdWludDY0KTogdWludDY0Cm5vbkNsYXNzRnVuY3Rpb246Cglwcm90byAyIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvZnVuY3Rpb25zLmFsZ28udHM6NwoJLy8gcmV0dXJuIGEgKyBiOwoJZnJhbWVfZGlnIC0xIC8vIGE6IHVpbnQ2NAoJZnJhbWVfZGlnIC0yIC8vIGI6IHVpbnQ2NAoJKwoJcmV0c3Vi", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/G.approval.teal b/tests/contracts/artifacts/G.approval.teal index 518683f91..6ce3d168b 100644 --- a/tests/contracts/artifacts/G.approval.teal +++ b/tests/contracts/artifacts/G.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x70726f746563746564 0x7075626c6963 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/G.arc32.json b/tests/contracts/artifacts/G.arc32.json index 9315b98f1..173dda0ee 100644 --- a/tests/contracts/artifacts/G.arc32.json +++ b/tests/contracts/artifacts/G.arc32.json @@ -44,7 +44,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg3MDcyNmY3NDY1NjM3NDY1NjQgMHg3MDc1NjI2YzY5NjMKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBwdWJsaWNNZXRob2QoKXN0cmluZwoqYWJpX3JvdXRlX3B1YmxpY01ldGhvZDoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHB1YmxpY01ldGhvZCgpc3RyaW5nCgljYWxsc3ViIHB1YmxpY01ldGhvZAoJZHVwCglsZW4KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gcHVibGljTWV0aG9kKCk6IHN0cmluZwpwdWJsaWNNZXRob2Q6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czo2NwoJLy8gcmV0dXJuICdwdWJsaWMnOwoJYnl0ZSAweDcwNzU2MjZjNjk2MyAvLyAicHVibGljIgoJcmV0c3ViCgovLyBwcml2YXRlTWV0aG9kKCk6IHN0cmluZwpwcml2YXRlTWV0aG9kOgoJcHJvdG8gMCAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6NzEKCS8vIHJldHVybiAncHJpdmF0ZSc7CglwdXNoYnl0ZXMgMHg3MDcyNjk3NjYxNzQ2NSAvLyAicHJpdmF0ZSIKCXJldHN1YgoKLy8gcHJvdGVjdGVkTWV0aG9kKCk6IHN0cmluZwpwcm90ZWN0ZWRNZXRob2Q6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czo3NQoJLy8gcmV0dXJuICdwcm90ZWN0ZWQnOwoJYnl0ZSAweDcwNzI2Zjc0NjU2Mzc0NjU2NCAvLyAicHJvdGVjdGVkIgoJcmV0c3ViCgovLyBnKCl2b2lkCiphYmlfcm91dGVfZzoKCS8vIGV4ZWN1dGUgZygpdm9pZAoJY2FsbHN1YiBnCglwdXNoaW50IDEKCXJldHVybgoKLy8gZygpOiB2b2lkCmc6Cglwcm90byAwIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czo4MQoJLy8gYXNzZXJ0KHRoaXMucHJvdGVjdGVkTWV0aG9kKCkgPT09ICdwcm90ZWN0ZWQnKQoJY2FsbHN1YiBwcm90ZWN0ZWRNZXRob2QKCWJ5dGUgMHg3MDcyNmY3NDY1NjM3NDY1NjQgLy8gInByb3RlY3RlZCIKCT09Cglhc3NlcnQKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czo4MgoJLy8gYXNzZXJ0KHRoaXMucHVibGljTWV0aG9kKCkgPT09ICdwdWJsaWMnKQoJY2FsbHN1YiBwdWJsaWNNZXRob2QKCWJ5dGUgMHg3MDc1NjI2YzY5NjMgLy8gInB1YmxpYyIKCT09Cglhc3NlcnQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZTA0MThjNTQgLy8gbWV0aG9kICJwdWJsaWNNZXRob2QoKXN0cmluZyIKCXB1c2hieXRlcyAweGYyYjY1ZjI3IC8vIG1ldGhvZCAiZygpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfcHVibGljTWV0aG9kICphYmlfcm91dGVfZwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg3MDcyNmY3NDY1NjM3NDY1NjQgMHg3MDc1NjI2YzY5NjMKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBwdWJsaWNNZXRob2QoKXN0cmluZwoqYWJpX3JvdXRlX3B1YmxpY01ldGhvZDoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHB1YmxpY01ldGhvZCgpc3RyaW5nCgljYWxsc3ViIHB1YmxpY01ldGhvZAoJZHVwCglsZW4KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gcHVibGljTWV0aG9kKCk6IHN0cmluZwpwdWJsaWNNZXRob2Q6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czo2NwoJLy8gcmV0dXJuICdwdWJsaWMnOwoJYnl0ZSAweDcwNzU2MjZjNjk2MyAvLyAicHVibGljIgoJcmV0c3ViCgovLyBwcml2YXRlTWV0aG9kKCk6IHN0cmluZwpwcml2YXRlTWV0aG9kOgoJcHJvdG8gMCAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6NzEKCS8vIHJldHVybiAncHJpdmF0ZSc7CglwdXNoYnl0ZXMgMHg3MDcyNjk3NjYxNzQ2NSAvLyAicHJpdmF0ZSIKCXJldHN1YgoKLy8gcHJvdGVjdGVkTWV0aG9kKCk6IHN0cmluZwpwcm90ZWN0ZWRNZXRob2Q6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czo3NQoJLy8gcmV0dXJuICdwcm90ZWN0ZWQnOwoJYnl0ZSAweDcwNzI2Zjc0NjU2Mzc0NjU2NCAvLyAicHJvdGVjdGVkIgoJcmV0c3ViCgovLyBnKCl2b2lkCiphYmlfcm91dGVfZzoKCS8vIGV4ZWN1dGUgZygpdm9pZAoJY2FsbHN1YiBnCglwdXNoaW50IDEKCXJldHVybgoKLy8gZygpOiB2b2lkCmc6Cglwcm90byAwIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czo4MQoJLy8gYXNzZXJ0KHRoaXMucHJvdGVjdGVkTWV0aG9kKCkgPT09ICdwcm90ZWN0ZWQnKQoJY2FsbHN1YiBwcm90ZWN0ZWRNZXRob2QKCWJ5dGUgMHg3MDcyNmY3NDY1NjM3NDY1NjQgLy8gInByb3RlY3RlZCIKCT09Cglhc3NlcnQKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czo4MgoJLy8gYXNzZXJ0KHRoaXMucHVibGljTWV0aG9kKCkgPT09ICdwdWJsaWMnKQoJY2FsbHN1YiBwdWJsaWNNZXRob2QKCWJ5dGUgMHg3MDc1NjI2YzY5NjMgLy8gInB1YmxpYyIKCT09Cglhc3NlcnQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZTA0MThjNTQgLy8gbWV0aG9kICJwdWJsaWNNZXRob2QoKXN0cmluZyIKCXB1c2hieXRlcyAweGYyYjY1ZjI3IC8vIG1ldGhvZCAiZygpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfcHVibGljTWV0aG9kICphYmlfcm91dGVfZwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/G.arc56_draft.json b/tests/contracts/artifacts/G.arc56_draft.json index 019af0649..1370a2f1d 100644 --- a/tests/contracts/artifacts/G.arc56_draft.json +++ b/tests/contracts/artifacts/G.arc56_draft.json @@ -614,7 +614,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg3MDcyNmY3NDY1NjM3NDY1NjQgMHg3MDc1NjI2YzY5NjMKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBwdWJsaWNNZXRob2QoKXN0cmluZwoqYWJpX3JvdXRlX3B1YmxpY01ldGhvZDoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHB1YmxpY01ldGhvZCgpc3RyaW5nCgljYWxsc3ViIHB1YmxpY01ldGhvZAoJZHVwCglsZW4KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gcHVibGljTWV0aG9kKCk6IHN0cmluZwpwdWJsaWNNZXRob2Q6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czo2NwoJLy8gcmV0dXJuICdwdWJsaWMnOwoJYnl0ZSAweDcwNzU2MjZjNjk2MyAvLyAicHVibGljIgoJcmV0c3ViCgovLyBwcml2YXRlTWV0aG9kKCk6IHN0cmluZwpwcml2YXRlTWV0aG9kOgoJcHJvdG8gMCAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6NzEKCS8vIHJldHVybiAncHJpdmF0ZSc7CglwdXNoYnl0ZXMgMHg3MDcyNjk3NjYxNzQ2NSAvLyAicHJpdmF0ZSIKCXJldHN1YgoKLy8gcHJvdGVjdGVkTWV0aG9kKCk6IHN0cmluZwpwcm90ZWN0ZWRNZXRob2Q6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czo3NQoJLy8gcmV0dXJuICdwcm90ZWN0ZWQnOwoJYnl0ZSAweDcwNzI2Zjc0NjU2Mzc0NjU2NCAvLyAicHJvdGVjdGVkIgoJcmV0c3ViCgovLyBnKCl2b2lkCiphYmlfcm91dGVfZzoKCS8vIGV4ZWN1dGUgZygpdm9pZAoJY2FsbHN1YiBnCglwdXNoaW50IDEKCXJldHVybgoKLy8gZygpOiB2b2lkCmc6Cglwcm90byAwIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czo4MQoJLy8gYXNzZXJ0KHRoaXMucHJvdGVjdGVkTWV0aG9kKCkgPT09ICdwcm90ZWN0ZWQnKQoJY2FsbHN1YiBwcm90ZWN0ZWRNZXRob2QKCWJ5dGUgMHg3MDcyNmY3NDY1NjM3NDY1NjQgLy8gInByb3RlY3RlZCIKCT09Cglhc3NlcnQKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czo4MgoJLy8gYXNzZXJ0KHRoaXMucHVibGljTWV0aG9kKCkgPT09ICdwdWJsaWMnKQoJY2FsbHN1YiBwdWJsaWNNZXRob2QKCWJ5dGUgMHg3MDc1NjI2YzY5NjMgLy8gInB1YmxpYyIKCT09Cglhc3NlcnQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZTA0MThjNTQgLy8gbWV0aG9kICJwdWJsaWNNZXRob2QoKXN0cmluZyIKCXB1c2hieXRlcyAweGYyYjY1ZjI3IC8vIG1ldGhvZCAiZygpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfcHVibGljTWV0aG9kICphYmlfcm91dGVfZwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg3MDcyNmY3NDY1NjM3NDY1NjQgMHg3MDc1NjI2YzY5NjMKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKmNhbGxfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgovLyBwdWJsaWNNZXRob2QoKXN0cmluZwoqYWJpX3JvdXRlX3B1YmxpY01ldGhvZDoKCS8vIFRoZSBBQkkgcmV0dXJuIHByZWZpeAoJcHVzaGJ5dGVzIDB4MTUxZjdjNzUKCgkvLyBleGVjdXRlIHB1YmxpY01ldGhvZCgpc3RyaW5nCgljYWxsc3ViIHB1YmxpY01ldGhvZAoJZHVwCglsZW4KCWl0b2IKCWV4dHJhY3QgNiAyCglzd2FwCgljb25jYXQKCWNvbmNhdAoJbG9nCglwdXNoaW50IDEKCXJldHVybgoKLy8gcHVibGljTWV0aG9kKCk6IHN0cmluZwpwdWJsaWNNZXRob2Q6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czo2NwoJLy8gcmV0dXJuICdwdWJsaWMnOwoJYnl0ZSAweDcwNzU2MjZjNjk2MyAvLyAicHVibGljIgoJcmV0c3ViCgovLyBwcml2YXRlTWV0aG9kKCk6IHN0cmluZwpwcml2YXRlTWV0aG9kOgoJcHJvdG8gMCAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6NzEKCS8vIHJldHVybiAncHJpdmF0ZSc7CglwdXNoYnl0ZXMgMHg3MDcyNjk3NjYxNzQ2NSAvLyAicHJpdmF0ZSIKCXJldHN1YgoKLy8gcHJvdGVjdGVkTWV0aG9kKCk6IHN0cmluZwpwcm90ZWN0ZWRNZXRob2Q6Cglwcm90byAwIDEKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czo3NQoJLy8gcmV0dXJuICdwcm90ZWN0ZWQnOwoJYnl0ZSAweDcwNzI2Zjc0NjU2Mzc0NjU2NCAvLyAicHJvdGVjdGVkIgoJcmV0c3ViCgovLyBnKCl2b2lkCiphYmlfcm91dGVfZzoKCS8vIGV4ZWN1dGUgZygpdm9pZAoJY2FsbHN1YiBnCglwdXNoaW50IDEKCXJldHVybgoKLy8gZygpOiB2b2lkCmc6Cglwcm90byAwIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czo4MQoJLy8gYXNzZXJ0KHRoaXMucHJvdGVjdGVkTWV0aG9kKCkgPT09ICdwcm90ZWN0ZWQnKQoJY2FsbHN1YiBwcm90ZWN0ZWRNZXRob2QKCWJ5dGUgMHg3MDcyNmY3NDY1NjM3NDY1NjQgLy8gInByb3RlY3RlZCIKCT09Cglhc3NlcnQKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czo4MgoJLy8gYXNzZXJ0KHRoaXMucHVibGljTWV0aG9kKCkgPT09ICdwdWJsaWMnKQoJY2FsbHN1YiBwdWJsaWNNZXRob2QKCWJ5dGUgMHg3MDc1NjI2YzY5NjMgLy8gInB1YmxpYyIKCT09Cglhc3NlcnQKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ZTA0MThjNTQgLy8gbWV0aG9kICJwdWJsaWNNZXRob2QoKXN0cmluZyIKCXB1c2hieXRlcyAweGYyYjY1ZjI3IC8vIG1ldGhvZCAiZygpdm9pZCIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfcHVibGljTWV0aG9kICphYmlfcm91dGVfZwoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjYWxsIE5vT3AKCWVycg==", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/GeneralTest.approval.teal b/tests/contracts/artifacts/GeneralTest.approval.teal index 3d84b72fb..b4878beeb 100644 --- a/tests/contracts/artifacts/GeneralTest.approval.teal +++ b/tests/contracts/artifacts/GeneralTest.approval.teal @@ -2,7 +2,7 @@ intcblock 1 0 6 1337 2 5 123 4 bytecblock 0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 0x0000000000000000000000000000000000000000000000000000000000000000 0x000000000000000100000000000000020000000000000003 0x151f7c75 0x0a8101 0x73746f726167654172726179 0x 0x666f6f 0x000000000000000000 0x0000000000000001 0x706167654f6e65 0x7061676554776f 0x674b6579 0x2c636eeb 0x626172 0x627965 0x0000 0x30 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // !!!! WARNING: This contract is *NOT* ARC4 compliant. It may contain ABI methods, but it also allows app calls where the first argument does NOT match an ABI selector diff --git a/tests/contracts/artifacts/GeneralTest.arc32.json b/tests/contracts/artifacts/GeneralTest.arc32.json index 4af32ad12..e81e1fc5e 100644 --- a/tests/contracts/artifacts/GeneralTest.arc32.json +++ b/tests/contracts/artifacts/GeneralTest.arc32.json @@ -413,7 +413,7 @@ } }, "source": { - "approval": "#pragma version 10
intcblock 1 0 6 1337 2 5 123 4
bytecblock 0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 0x0000000000000000000000000000000000000000000000000000000000000000 0x000000000000000100000000000000020000000000000003 0x151f7c75 0x0a8101 0x73746f726167654172726179 0x 0x666f6f 0x000000000000000000 0x0000000000000001 0x706167654f6e65 0x7061676554776f 0x674b6579 0x2c636eeb 0x626172 0x627965 0x0000 0x30

// This TEAL was generated by TEALScript v0.104.1
// https://github.com/algorandfoundation/TEALScript

// !!!! WARNING: This contract is *NOT* ARC4 compliant. It may contain ABI methods, but it also allows app calls where the first argument does NOT match an ABI selector

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
int 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// txnTypeEnum()void
*abi_route_txnTypeEnum:
	// execute txnTypeEnum()void
	callsub txnTypeEnum
	int 1
	return

// txnTypeEnum(): void
txnTypeEnum:
	proto 0 0

	// tests/contracts/general.algo.ts:69
	// assert(this.txnGroup[0].typeEnum === TransactionType.ApplicationCall)
	int 0
	gtxns TypeEnum
	int 6 // appl
	==
	assert
	retsub

// txnGroupLength()void
*abi_route_txnGroupLength:
	// execute txnGroupLength()void
	callsub txnGroupLength
	int 1
	return

// txnGroupLength(): void
txnGroupLength:
	proto 0 0

	// tests/contracts/general.algo.ts:73
	// assert(this.txnGroup.length === 1)
	global GroupSize
	int 1
	==
	assert
	retsub

// asserts(bool,bool)void
*abi_route_asserts:
	// arg2: bool
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 0 (arg2) for asserts must be a bool
	assert
	int 0
	getbit

	// arg1: bool
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 1 (arg1) for asserts must be a bool
	assert
	int 0
	getbit

	// execute asserts(bool,bool)void
	callsub asserts
	int 1
	return

// asserts(arg1: boolean, arg2: boolean): void
asserts:
	proto 2 0

	// tests/contracts/general.algo.ts:77
	// asserts(arg1, arg2, arg1 === arg2)
	frame_dig -1 // arg1: boolean

	// asserts failed: asserts(arg1, arg2, arg1 === arg2)
	assert
	frame_dig -2 // arg2: boolean

	// asserts failed: asserts(arg1, arg2, arg1 === arg2)
	assert
	frame_dig -1 // arg1: boolean
	frame_dig -2 // arg2: boolean
	==

	// asserts failed: asserts(arg1, arg2, arg1 === arg2)
	assert
	retsub

// verifyTxnFromArg(pay)void
*abi_route_verifyTxnFromArg:
	// somePay: pay
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// argument 0 (somePay) for verifyTxnFromArg must be a pay transaction
	assert

	// execute verifyTxnFromArg(pay)void
	callsub verifyTxnFromArg
	int 1
	return

// verifyTxnFromArg(somePay: PayTxn): void
verifyTxnFromArg:
	proto 1 0

	// tests/contracts/general.algo.ts:81
	// verifyTxn(somePay, { receiver: this.app.address, amount: 100_000 })
	// verify receiver
	frame_dig -1 // somePay: PayTxn
	gtxns Receiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"somePay","field":"receiver","expected":"this.app.address"}
	assert

	// verify amount
	frame_dig -1 // somePay: PayTxn
	gtxns Amount
	pushint 100_000
	==

	// transaction verification failed: {"txn":"somePay","field":"amount","expected":"100_000"}
	assert
	retsub

// verifyTxnFromTxnGroup()void
*abi_route_verifyTxnFromTxnGroup:
	// execute verifyTxnFromTxnGroup()void
	callsub verifyTxnFromTxnGroup
	int 1
	return

// verifyTxnFromTxnGroup(): void
verifyTxnFromTxnGroup:
	proto 0 0

	// tests/contracts/general.algo.ts:85
	// verifyTxn(this.txnGroup[0], { sender: this.txn.sender })
	// verify sender
	int 0
	gtxns Sender
	txn Sender
	==

	// transaction verification failed: {"txn":"this.txnGroup[0]","field":"sender","expected":"this.txn.sender"}
	assert
	retsub

// verifyTxnCondition()void
*abi_route_verifyTxnCondition:
	// execute verifyTxnCondition()void
	callsub verifyTxnCondition
	int 1
	return

// verifyTxnCondition(): void
verifyTxnCondition:
	proto 0 0

	// tests/contracts/general.algo.ts:89
	// verifyTxn(this.txn, {
	//       applicationID: { greaterThan: 1 },
	//     })
	// verify applicationID
	txn ApplicationID
	int 1
	>

	// transaction verification failed: {"txn":"this.txn","field":"applicationID","condition":"greaterThan","expected":">1"}
	assert
	retsub

// verifyTxnIncludedIn()void
*abi_route_verifyTxnIncludedIn:
	// execute verifyTxnIncludedIn()void
	callsub verifyTxnIncludedIn
	int 1
	return

// verifyTxnIncludedIn(): void
verifyTxnIncludedIn:
	proto 0 0

	// tests/contracts/general.algo.ts:95
	// verifyTxn(this.txn, {
	//       sender: { includedIn: [this.txn.sender] },
	//     })
	// verify sender
	txn Sender
	txn Sender
	==

	// transaction verification failed: {"txn":{"txnText":"this.txn"},"field":"sender","condition":"includedIn","expected":"[this.txn.sender]"}
	assert
	retsub

// verifyTxnNotIncludedIn()void
*abi_route_verifyTxnNotIncludedIn:
	// execute verifyTxnNotIncludedIn()void
	callsub verifyTxnNotIncludedIn
	int 1
	return

// verifyTxnNotIncludedIn(): void
verifyTxnNotIncludedIn:
	proto 0 0

	// tests/contracts/general.algo.ts:101
	// verifyTxn(this.txn, {
	//       sender: { notIncludedIn: [globals.zeroAddress] },
	//     })
	// verify sender
	txn Sender
	global ZeroAddress
	!=

	// transaction verification failed: {"txn":{"txnText":"this.txn"},"field":"sender","condition":"notIncludedIn","expected":"[globals.zeroAddress]"}
	assert
	retsub

// submitPendingGroup()void
*abi_route_submitPendingGroup:
	// execute submitPendingGroup()void
	callsub submitPendingGroup
	int 1
	return

// submitPendingGroup(): void
submitPendingGroup:
	proto 0 0

	// tests/contracts/general.algo.ts:107
	// this.pendingGroup.addPayment({ amount: 0, receiver: this.app.address, isFirstTxn: true })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// tests/contracts/general.algo.ts:107
	// amount: 0
	int 0
	itxn_field Amount

	// tests/contracts/general.algo.ts:107
	// receiver: this.app.address
	global CurrentApplicationAddress
	itxn_field Receiver

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// tests/contracts/general.algo.ts:108
	// this.pendingGroup.addPayment({ amount: 0, receiver: this.app.address, note: 'foo' })
	itxn_next
	int 1 // pay
	itxn_field TypeEnum

	// tests/contracts/general.algo.ts:108
	// amount: 0
	int 0
	itxn_field Amount

	// tests/contracts/general.algo.ts:108
	// receiver: this.app.address
	global CurrentApplicationAddress
	itxn_field Receiver

	// tests/contracts/general.algo.ts:108
	// note: 'foo'
	byte 0x666f6f // "foo"
	itxn_field Note

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// tests/contracts/general.algo.ts:109
	// this.pendingGroup.submit()
	itxn_submit
	retsub

// methodWithTxnArgs()void
*abi_route_methodWithTxnArgs:
	// execute methodWithTxnArgs()void
	callsub methodWithTxnArgs
	int 1
	return

// methodWithTxnArgs(): void
methodWithTxnArgs:
	proto 0 0

	// tests/contracts/general.algo.ts:113
	// sendMethodCall<[PayTxn, MethodCall<[uint64], void>], void>({
	//       name: 'foo',
	//       methodArgs: [
	//         { amount: 100_000, receiver: this.txn.sender },
	//         {
	//           name: 'bar',
	//           applicationID: AppID.fromUint64(1337),
	//           methodArgs: [1],
	//         },
	//       ],
	//     })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// tests/contracts/general.algo.ts:116
	// amount: 100_000
	pushint 100_000
	itxn_field Amount

	// tests/contracts/general.algo.ts:116
	// receiver: this.txn.sender
	txn Sender
	itxn_field Receiver

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee
	itxn_next
	int 6 // appl
	itxn_field TypeEnum
	pushbytes 0x0e8cb9f6 // method "bar(uint64)void"
	itxn_field ApplicationArgs

	// tests/contracts/general.algo.ts:119
	// applicationID: AppID.fromUint64(1337)
	int 1337
	itxn_field ApplicationID

	// tests/contracts/general.algo.ts:120
	// methodArgs: [1]
	byte 0x0000000000000001
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee
	itxn_next
	int 6 // appl
	itxn_field TypeEnum
	pushbytes 0x6c6f7a08 // method "foo(pay,appl)void"
	itxn_field ApplicationArgs

	// tests/contracts/general.algo.ts:115
	// methodArgs: [
	//         { amount: 100_000, receiver: this.txn.sender },
	//         {
	//           name: 'bar',
	//           applicationID: AppID.fromUint64(1337),
	//           methodArgs: [1],
	//         },
	//       ]
	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// shift()void
*abi_route_shift:
	// execute shift()void
	callsub shift
	int 1
	return

// shift(): void
shift:
	proto 0 0

	// tests/contracts/general.algo.ts:127
	// assert(1 << 2 === 4)
	int 1
	int 2
	shl
	int 4
	==
	assert

	// tests/contracts/general.algo.ts:128
	// assert(4 >> 1 === 2)
	int 4
	int 1
	shr
	int 2
	==
	assert
	retsub

// fromBytes()void
*abi_route_fromBytes:
	// execute fromBytes()void
	callsub fromBytes
	int 1
	return

// fromBytes(): void
fromBytes:
	proto 0 0

	// tests/contracts/general.algo.ts:132
	// assert(Address.fromBytes('abc').minBalance)
	pushbytes 0x616263 // "abc"
	acct_params_get AcctMinBalance
	pop
	assert
	retsub

// fromUint64()void
*abi_route_fromUint64:
	// execute fromUint64()void
	callsub fromUint64
	int 1
	return

// fromUint64(): void
fromUint64:
	proto 0 0

	// tests/contracts/general.algo.ts:136
	// log(AppID.fromUint64(123).creator)
	int 123
	app_params_get AppCreator
	pop
	log

	// tests/contracts/general.algo.ts:137
	// log(AssetID.fromUint64(123).creator)
	int 123
	asset_params_get AssetCreator
	pop
	log
	retsub

// bzeroFunction()void
*abi_route_bzeroFunction:
	// execute bzeroFunction()void
	callsub bzeroFunction
	int 1
	return

// bzeroFunction(): void
bzeroFunction:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// tests/contracts/general.algo.ts:142
	// x: bytes = bzero(2)
	byte 0x0000
	frame_bury 0 // x: bytes

	// tests/contracts/general.algo.ts:143
	// y: bytes = bzero(n)
	int 1
	bzero
	frame_bury 1 // y: bytes

	// tests/contracts/general.algo.ts:144
	// z: [uint64, uint<8>] = bzero<[uint64, uint<8>]>()
	byte 0x000000000000000000
	frame_bury 2 // z: [uint64, uint<8>]

	// tests/contracts/general.algo.ts:145
	// assert(len(x + y + z) === 12)
	byte 0x0000 // x: bytes
	frame_dig 1 // y: bytes
	concat
	byte 0x000000000000000000 // z: [uint64, uint<8>]
	concat
	len
	pushint 12
	==
	assert
	retsub

// events()void
*abi_route_events:
	// execute events()void
	callsub events
	int 1
	return

// events(): void
events:
	proto 0 0

	// tests/contracts/general.algo.ts:160
	// this.myEvent.log({ app: this.app, num: 1 })
	pushbytes 0x87528196 // myEvent(uint64,uint64)
	txna Applications 0
	itob
	byte 0x0000000000000001
	concat
	concat
	log
	retsub

// letOptimization(uint64[])uint64[]
*abi_route_letOptimization:
	// The ABI return prefix
	byte 0x151f7c75

	// a: uint64[]
	txna ApplicationArgs 1
	extract 2 0

	// execute letOptimization(uint64[])uint64[]
	callsub letOptimization
	dup
	len
	pushint 8
	/
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// letOptimization(a: uint64[]): uint64[]
letOptimization:
	proto 1 1

	// tests/contracts/general.algo.ts:164
	// assert(a[0])
	frame_dig -1 // a: uint64[]
	store 255 // full array
	load 255 // full array
	extract 0 8
	btoi
	assert

	// tests/contracts/general.algo.ts:166
	// b = [1, 2, 3]
	byte 0x000000000000000100000000000000020000000000000003
	frame_bury -1 // b: uint64[]

	// tests/contracts/general.algo.ts:168
	// return b;
	frame_dig -1 // a: uint64[]
	retsub

// staticContractProperties()void
*abi_route_staticContractProperties:
	// execute staticContractProperties()void
	callsub staticContractProperties
	int 1
	return

// staticContractProperties(): void
staticContractProperties:
	proto 0 0

	// tests/contracts/general.algo.ts:172
	// sendAppCall({
	//       onCompletion: OnCompletion.NoOp,
	//       approvalProgram: DummyContract.approvalProgram(),
	//       clearStateProgram: DummyContract.clearProgram(),
	//       localNumByteSlice: DummyContract.schema.local.numByteSlice,
	//       localNumUint: DummyContract.schema.local.numUint,
	//       globalNumByteSlice: DummyContract.schema.global.numByteSlice,
	//       globalNumUint: DummyContract.schema.global.numUint,
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum

	// tests/contracts/general.algo.ts:173
	// onCompletion: OnCompletion.NoOp
	int 0 // NoOp
	itxn_field OnCompletion

	// tests/contracts/general.algo.ts:174
	// approvalProgram: DummyContract.approvalProgram()
	pushbytes 0x0a31181481060b3119088d0c000000000000000000000000000400000000000000000000008101438004b8447b36361a008e01fff000
	itxn_field ApprovalProgram

	// tests/contracts/general.algo.ts:175
	// clearStateProgram: DummyContract.clearProgram()
	pushbytes 0x0a
	itxn_field ClearStateProgram

	// tests/contracts/general.algo.ts:176
	// localNumByteSlice: DummyContract.schema.local.numByteSlice
	int 0
	itxn_field LocalNumByteSlice

	// tests/contracts/general.algo.ts:177
	// localNumUint: DummyContract.schema.local.numUint
	int 0
	itxn_field LocalNumUint

	// tests/contracts/general.algo.ts:178
	// globalNumByteSlice: DummyContract.schema.global.numByteSlice
	int 0
	itxn_field GlobalNumByteSlice

	// tests/contracts/general.algo.ts:179
	// globalNumUint: DummyContract.schema.global.numUint
	int 0
	itxn_field GlobalNumUint

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// numberToString()void
*abi_route_numberToString:
	// execute numberToString()void
	callsub numberToString
	int 1
	return

// numberToString(): void
numberToString:
	proto 0 0

	// tests/contracts/general.algo.ts:186
	// assert(n.toString() === s)
	int 1
	callsub *itoa
	pushbytes "1"
	==
	assert
	retsub

// methodOnParens()void
*abi_route_methodOnParens:
	// execute methodOnParens()void
	callsub methodOnParens
	int 1
	return

// methodOnParens(): void
methodOnParens:
	proto 0 0

	// tests/contracts/general.algo.ts:190
	// assert((1 + 2).toString() === '3')
	pushint 3
	callsub *itoa
	pushbytes 0x33 // "3"
	==
	assert
	retsub

// stringSubstring()void
*abi_route_stringSubstring:
	// execute stringSubstring()void
	callsub stringSubstring
	int 1
	return

// stringSubstring(): void
stringSubstring:
	proto 0 0

	// tests/contracts/general.algo.ts:195
	// assert(s.substring(1, 3) === 'bc')
	pushbytes "abcdef"
	substring 1 3
	pushbytes 0x6263 // "bc"
	==
	assert
	retsub

// idProperty()void
*abi_route_idProperty:
	// execute idProperty()void
	callsub idProperty
	int 1
	return

// idProperty(): void
idProperty:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// tests/contracts/general.algo.ts:199
	// app = AppID.zeroIndex
	int 0
	frame_bury 0 // app: uint64

	// tests/contracts/general.algo.ts:200
	// assert(AppID.fromUint64(app.id) === app)
	int 0 // app: uint64
	dup
	==
	assert

	// tests/contracts/general.algo.ts:202
	// asa = AssetID.zeroIndex
	int 0
	frame_bury 1 // asa: uint64

	// tests/contracts/general.algo.ts:203
	// assert(AssetID.fromUint64(asa.id) === asa)
	int 0 // asa: uint64
	dup
	==
	assert
	retsub

// scratchSlot()void
*abi_route_scratchSlot:
	// execute scratchSlot()void
	callsub scratchSlot
	int 1
	return

// scratchSlot(): void
scratchSlot:
	proto 0 0

	// tests/contracts/general.algo.ts:207
	// this.scratch.value = 1337
	int 1337
	store 0

	// tests/contracts/general.algo.ts:208
	// assert(this.scratch.value === 1337)
	load 0
	int 1337
	==
	assert
	retsub

// ecdsa()void
*abi_route_ecdsa:
	// execute ecdsa()void
	callsub ecdsa
	int 1
	return

// ecdsa(): void
ecdsa:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 3

	// tests/contracts/general.algo.ts:212
	// ecdsaVerify('Secp256k1', '' as bytes32, '' as bytes32, '' as bytes32, '' as bytes32, '' as bytes32)
	byte 0x0000000000000000000000000000000000000000000000000000000000000000 // ""
	dupn 4
	ecdsa_verify Secp256k1

	// tests/contracts/general.algo.ts:213
	// d = ecdsaPkDecompress('Secp256k1', '' as bytes<33>)
	pushbytes 0x000000000000000000000000000000000000000000000000000000000000000000 // ""
	ecdsa_pk_decompress Secp256k1
	frame_bury 0 // d y component: byte[]
	frame_bury 1 // d x component: byte[]

	// tests/contracts/general.algo.ts:214
	// log(d.y)
	frame_dig 0 // d y component: byte[]
	log

	// tests/contracts/general.algo.ts:215
	// log(d.x)
	frame_dig 1 // d x component: byte[]
	log

	// tests/contracts/general.algo.ts:217
	// r = ecdsaPkRecover('Secp256k1', '' as bytes32, 1, '' as bytes32, '' as bytes32)
	byte 0x0000000000000000000000000000000000000000000000000000000000000000 // ""
	int 1
	byte 0x0000000000000000000000000000000000000000000000000000000000000000 // ""
	dup
	ecdsa_pk_recover Secp256k1
	frame_bury 2 // r y component: byte[]
	frame_bury 3 // r x component: byte[]

	// tests/contracts/general.algo.ts:218
	// log(r.y)
	frame_dig 2 // r y component: byte[]
	log

	// tests/contracts/general.algo.ts:219
	// log(r.x)
	frame_dig 3 // r x component: byte[]
	log
	retsub

// verifyTxnTypes()void
*abi_route_verifyTxnTypes:
	// execute verifyTxnTypes()void
	callsub verifyTxnTypes
	int 1
	return

// verifyTxnTypes(): void
verifyTxnTypes:
	proto 0 0

	// tests/contracts/general.algo.ts:223
	// verifyPayTxn(this.txnGroup[0], {
	//       amount: { greaterThan: 0 },
	//     })
	// verify pay
	int 0
	gtxns TypeEnum
	int 1 // pay
	==

	// transaction verification failed: {"txn":"this.txnGroup[0]","field":"typeEnum","expected":"pay"}
	assert

	// verify amount
	int 0
	gtxns Amount
	int 0
	>

	// transaction verification failed: {"txn":"this.txnGroup[0]","field":"amount","condition":"greaterThan","expected":">0"}
	assert

	// tests/contracts/general.algo.ts:227
	// verifyAppCallTxn(this.txnGroup[0], {
	//       applicationID: AppID.fromUint64(0),
	//       applicationArgs: {
	//         0: 'foo',
	//         1: {
	//           includedIn: ['bar', 'baz'],
	//         },
	//       },
	//     })
	// verify appl
	int 0
	gtxns TypeEnum
	int 6 // appl
	==

	// transaction verification failed: {"txn":"this.txnGroup[0]","field":"typeEnum","expected":"appl"}
	assert

	// verify applicationID
	int 0
	gtxns ApplicationID
	int 0
	==

	// transaction verification failed: {"txn":"this.txnGroup[0]","field":"applicationID","expected":"AppID.fromUint64(0)"}
	assert

	// verify applicationArgs
	// verify applicationArgs 0
	int 0
	gtxns ApplicationArgs 0
	byte 0x666f6f // "foo"
	==

	// transaction verification failed: {"txn":"this.txnGroup[0]","field":"applicationArgs","index":"0","expected":"'foo'"}
	assert

	// verify applicationArgs 1
	int 0
	gtxns ApplicationArgs 1
	byte 0x626172 // "bar"
	==
	int 0
	gtxns ApplicationArgs 1
	pushbytes 0x62617a // "baz"
	==
	||

	// transaction verification failed: {"txn":{"txnText":"this.txnGroup[0]"},"field":"applicationArgs 1","condition":"includedIn","expected":"['bar', 'baz']"}
	assert

	// tests/contracts/general.algo.ts:237
	// verifyAssetTransferTxn(this.txnGroup[0], {
	//       assetReceiver: this.app.address,
	//     })
	// verify axfer
	int 0
	gtxns TypeEnum
	int 4 // axfer
	==

	// transaction verification failed: {"txn":"this.txnGroup[0]","field":"typeEnum","expected":"axfer"}
	assert

	// verify assetReceiver
	int 0
	gtxns AssetReceiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"this.txnGroup[0]","field":"assetReceiver","expected":"this.app.address"}
	assert

	// tests/contracts/general.algo.ts:241
	// verifyAssetConfigTxn(this.txnGroup[0], {
	//       configAsset: AssetID.fromUint64(0),
	//     })
	// verify acfg
	int 0
	gtxns TypeEnum
	pushint 3 // acfg
	==

	// transaction verification failed: {"txn":"this.txnGroup[0]","field":"typeEnum","expected":"acfg"}
	assert

	// verify configAsset
	int 0
	gtxns ConfigAsset
	int 0
	==

	// transaction verification failed: {"txn":"this.txnGroup[0]","field":"configAsset","expected":"AssetID.fromUint64(0)"}
	assert

	// tests/contracts/general.algo.ts:245
	// verifyKeyRegTxn(this.txnGroup[0], {
	//       voteFirst: 1337,
	//     })
	// verify keyreg
	int 0
	gtxns TypeEnum
	int 2 // keyreg
	==

	// transaction verification failed: {"txn":"this.txnGroup[0]","field":"typeEnum","expected":"keyreg"}
	assert

	// verify voteFirst
	int 0
	gtxns VoteFirst
	int 1337
	==

	// transaction verification failed: {"txn":"this.txnGroup[0]","field":"voteFirst","expected":"1337"}
	assert
	retsub

// stringPlusEquals()void
*abi_route_stringPlusEquals:
	// execute stringPlusEquals()void
	callsub stringPlusEquals
	int 1
	return

// stringPlusEquals(): void
stringPlusEquals:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/general.algo.ts:251
	// s = 'foo'
	byte 0x666f6f // "foo"
	frame_bury 0 // s: byte[]

	// tests/contracts/general.algo.ts:252
	// s += 'bar'
	frame_dig 0 // s: byte[]
	byte 0x626172 // "bar"
	concat
	frame_bury 0 // s: byte[]

	// tests/contracts/general.algo.ts:253
	// assert(s === 'foobar')
	frame_dig 0 // s: byte[]
	pushbytes 0x666f6f626172 // "foobar"
	==
	assert
	retsub

// importedProgram()byte[]
*abi_route_importedProgram:
	// The ABI return prefix
	byte 0x151f7c75

	// execute importedProgram()byte[]
	callsub importedProgram
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// importedProgram(): bytes
importedProgram:
	proto 0 1

	// tests/contracts/general.algo.ts:257
	// return IfTest.approvalProgram();
	pushbytes 0x0a20020100260904151f7c7504656c736502696609656c7365206966203109656c7365206966203207656c736520696603656e6403666f6f0031181481060b3119088d0c041900000000000000000000040b00000000000000000000008004151f7c75361a0149158101124481005388000d4915165706024c5050b08101438a01018bff41000580026966898003656e64898004151f7c75361a0149158101124481005388000d4915165706024c5050b08101438a01018bff41000880026966894200078004656c736589898004151f7c75361a02491581011244810053361a0149158101124481005388000d4915165706024c5050b08101438a02018bff410008800269668942000f8bfe41000a8007656c7365206966898003656e64898004151f7c75361a02491581011244810053361a0149158101124481005388000d4915165706024c5050b08101438a02018bff41000880026966894200198bfe41000d8007656c7365206966894200078004656c736589898004151f7c75361a03491581011244810053361a02491581011244810053361a0149158101124481005388000d4915165706024c5050b08101438a03018bff41000880026966894200258bfe41000f8009656c73652069662031894200118bfd41000c8009656c73652069662032898003656e64898004151f7c75361a03491581011244810053361a02491581011244810053361a0149158101124481005388000d4915165706024c5050b08101438a03018bff410008800269668942002f8bfe41000f8009656c736520696620318942001b8bfd41000f8009656c73652069662032894200078004656c736589898004151f7c75361a02491581011244810053361a0149158101124481005388000d4915165706024c5050b08101438a02018bff4100198bfe41000c80096e65737465642069668980026966894200078004656c736589898004151f7c75361a0149158101124481005388000d4915165706024c5050b08101438a01018bff41000880026966894200078004656c736589898004151f7c75361a02491581011244810053361a014915810112448100538800061650b08101438a02018bff410005810142000c8bfe41000581024200028103898004151f7c75361a015702008800061650b08101438a01018bff8000a94100038101898102898004151f7c75361a015702008800061650b08101438a01018bff8000a94100058101420002810289361a01491581021244178800038101438a01008bff8000a94100068003666f6fb089361a0249158102124417361a01491581021244178800038101438a02008bff8bfe0e4100068003666f6fb089361a02491581201244361a014915812012448800038101438a02008bff8bfea64100068003666f6fb0898004151f7c75361a02491581011244810053361a0149158101124481005388000d4915165706024c5050b08101438a02018bff4100198bfe41000d80076120616e64206289420004800161894200168bfe4100078001628942000a80076e65697468657289898101438004b8447b36361a008e01fff0008004436ec1c280041c7a0d5e80045e0fb6cf80045e1c6c50800458d0ba9280045d2f4f028004845729d980048fe76ca880041a3c7878800474bcc86880044212f905800495ddaebf80043147b866800442897f618004534be2b7361a008e0ffb6bfba0fbdafc2dfc85fcfafd74fdcbfe05fe46fe6cfe94feb6fee2ff0c00
	retsub

// callPrivateDefinedLater()void
*abi_route_callPrivateDefinedLater:
	// execute callPrivateDefinedLater()void
	callsub callPrivateDefinedLater
	int 1
	return

// callPrivateDefinedLater(): void
callPrivateDefinedLater:
	proto 0 0

	// tests/contracts/general.algo.ts:261
	// log(this.privateMethod('hello'))
	pushbytes 0x68656c6c6f // "hello"
	callsub privateMethod
	log
	retsub

// privateMethod(msg: string): string
privateMethod:
	proto 1 1

	// tests/contracts/general.algo.ts:265
	// return msg;
	frame_dig -1 // msg: string
	retsub

// interalPublicMethod(uint64,uint64)uint64
*abi_route_interalPublicMethod:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute interalPublicMethod(uint64,uint64)uint64
	callsub interalPublicMethod
	itob
	concat
	log
	int 1
	return

// interalPublicMethod(a: uint64, b: uint64): uint64
interalPublicMethod:
	proto 2 1

	// tests/contracts/general.algo.ts:269
	// return a + b;
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	+
	retsub

// callInternalPublicMethod()void
*abi_route_callInternalPublicMethod:
	// execute callInternalPublicMethod()void
	callsub callInternalPublicMethod
	int 1
	return

// callInternalPublicMethod(): void
callInternalPublicMethod:
	proto 0 0

	// tests/contracts/general.algo.ts:273
	// assert(this.interalPublicMethod(1, 2) === 3)
	int 2
	int 1
	callsub interalPublicMethod
	pushint 3
	==
	assert
	retsub

// appLoadScratch()void
*abi_route_appLoadScratch:
	// execute appLoadScratch()void
	callsub appLoadScratch
	int 1
	return

// appLoadScratch(): void
appLoadScratch:
	proto 0 0

	// tests/contracts/general.algo.ts:277
	// log(this.txnGroup[1].loadScratch(2) as bytes)
	gload 1 2
	log
	retsub

// uintNWithUnderscore()uint256
*abi_route_uintNWithUnderscore:
	// The ABI return prefix
	byte 0x151f7c75

	// execute uintNWithUnderscore()uint256
	callsub uintNWithUnderscore
	dup
	bitlen
	pushint 256
	<=

	// uintNWithUnderscore return value overflowed 256 bits
	assert
	pushbytes 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	pushint 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// uintNWithUnderscore(): uint256
uintNWithUnderscore:
	proto 0 1

	// tests/contracts/general.algo.ts:281
	// return <uint256>123_456;
	pushbytes 0x000000000000000000000000000000000000000000000000000000000001e240
	retsub

// opUp()void
*abi_route_opUp:
	// execute opUp()void
	callsub opUp
	int 1
	return

// opUp(): void
opUp:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/general.algo.ts:285
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	int 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

	// tests/contracts/general.algo.ts:286
	// for (let i = 1; i < 75; i += 1)
	int 1
	frame_bury 0 // i: uint64

*for_0:
	// tests/contracts/general.algo.ts:286
	// i < 75
	frame_dig 0 // i: uint64
	pushint 75
	<
	bz *for_0_end

	// tests/contracts/general.algo.ts:287
	// assert(i)
	frame_dig 0 // i: uint64
	assert

*for_0_continue:
	// tests/contracts/general.algo.ts:286
	// i += 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64
	b *for_0

*for_0_end:
	retsub

// returnValueOnAssignment()string
*abi_route_returnValueOnAssignment:
	// The ABI return prefix
	byte 0x151f7c75

	// execute returnValueOnAssignment()string
	callsub returnValueOnAssignment
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// returnValueOnAssignment(): string
returnValueOnAssignment:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/general.algo.ts:292
	// message = 'hi'
	pushbytes 0x6869 // "hi"
	frame_bury 0 // message: byte[]

	// *if0_condition
	// tests/contracts/general.algo.ts:294
	// this.txn.sender === this.app.address
	txn Sender
	global CurrentApplicationAddress
	==
	bz *if0_end

	// *if0_consequent
	// tests/contracts/general.algo.ts:295
	// message = 'in block'
	pushbytes 0x696e20626c6f636b // "in block"
	frame_bury 0 // message: byte[]

*if0_end:
	// tests/contracts/general.algo.ts:298
	// return (message = 'bye');
	byte 0x627965 // "bye"
	dup
	frame_bury 0 // message: byte[]

	// set the subroutine return value
	frame_bury 0
	retsub

// returnArrayValueOnAssignment()uint64
*abi_route_returnArrayValueOnAssignment:
	// The ABI return prefix
	byte 0x151f7c75

	// execute returnArrayValueOnAssignment()uint64
	callsub returnArrayValueOnAssignment
	itob
	concat
	log
	int 1
	return

// returnArrayValueOnAssignment(): uint64
returnArrayValueOnAssignment:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/general.algo.ts:302
	// a: StaticArray<uint64, 3> = [1, 2, 3]
	byte 0x000000000000000100000000000000020000000000000003
	frame_bury 0 // a: StaticArray<uint64, 3>

	// tests/contracts/general.algo.ts:304
	// return (a[0] = 4);
	frame_dig 0 // a: StaticArray<uint64, 3>
	int 0
	int 4
	dup
	store 245 // assignment value
	itob
	replace3
	frame_bury 0 // a: StaticArray<uint64, 3>
	load 245 // assignment value

	// set the subroutine return value
	frame_bury 0
	retsub

// returnStorageValueOnAssignment()uint64
*abi_route_returnStorageValueOnAssignment:
	// The ABI return prefix
	byte 0x151f7c75

	// execute returnStorageValueOnAssignment()uint64
	callsub returnStorageValueOnAssignment
	itob
	concat
	log
	int 1
	return

// returnStorageValueOnAssignment(): uint64
returnStorageValueOnAssignment:
	proto 0 1

	// tests/contracts/general.algo.ts:308
	// this.gKey.value = 1
	byte 0x674b6579 // "gKey"
	int 1
	app_global_put

	// tests/contracts/general.algo.ts:310
	// return (this.gKey.value = 2);
	byte 0x674b6579 // "gKey"
	int 2
	dup
	store 245 // assignment value
	app_global_put
	load 245 // assignment value
	retsub

// returnOperatorAssignmentValue()uint64
*abi_route_returnOperatorAssignmentValue:
	// The ABI return prefix
	byte 0x151f7c75

	// execute returnOperatorAssignmentValue()uint64
	callsub returnOperatorAssignmentValue
	itob
	concat
	log
	int 1
	return

// returnOperatorAssignmentValue(): uint64
returnOperatorAssignmentValue:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/general.algo.ts:314
	// a = 1
	int 1
	frame_bury 0 // a: uint64

	// tests/contracts/general.algo.ts:316
	// return (a += 2);
	frame_dig 0 // a: uint64
	int 2
	+
	dup
	store 245 // assignment value
	frame_bury 0 // a: uint64
	load 245 // assignment value

	// set the subroutine return value
	frame_bury 0
	retsub

// returnArrayValueOnOperatorAssignment()uint64
*abi_route_returnArrayValueOnOperatorAssignment:
	// The ABI return prefix
	byte 0x151f7c75

	// execute returnArrayValueOnOperatorAssignment()uint64
	callsub returnArrayValueOnOperatorAssignment
	itob
	concat
	log
	int 1
	return

// returnArrayValueOnOperatorAssignment(): uint64
returnArrayValueOnOperatorAssignment:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/general.algo.ts:320
	// a: StaticArray<uint64, 3> = [1, 2, 3]
	byte 0x000000000000000100000000000000020000000000000003
	frame_bury 0 // a: StaticArray<uint64, 3>

	// tests/contracts/general.algo.ts:322
	// return (a[0] += 4);
	frame_dig 0 // a: StaticArray<uint64, 3>
	int 0
	frame_dig 0 // a: StaticArray<uint64, 3>
	extract 0 8
	btoi
	int 4
	+
	dup
	store 245 // assignment value
	itob
	replace3
	frame_bury 0 // a: StaticArray<uint64, 3>
	load 245 // assignment value

	// set the subroutine return value
	frame_bury 0
	retsub

// returnArrayInStorageValueOnOperatorAssignment()uint64
*abi_route_returnArrayInStorageValueOnOperatorAssignment:
	// The ABI return prefix
	byte 0x151f7c75

	// execute returnArrayInStorageValueOnOperatorAssignment()uint64
	callsub returnArrayInStorageValueOnOperatorAssignment
	itob
	concat
	log
	int 1
	return

// returnArrayInStorageValueOnOperatorAssignment(): uint64
returnArrayInStorageValueOnOperatorAssignment:
	proto 0 1

	// tests/contracts/general.algo.ts:326
	// this.storageArray.value = [1, 2, 3]
	byte 0x73746f726167654172726179 // "storageArray"
	byte 0x000000000000000100000000000000020000000000000003
	app_global_put

	// tests/contracts/general.algo.ts:328
	// return (this.storageArray.value[0] += 4);
	byte 0x73746f726167654172726179 // "storageArray"
	app_global_get
	int 0
	byte 0x73746f726167654172726179 // "storageArray"
	app_global_get
	extract 0 8
	btoi
	int 4
	+
	dup
	store 245 // assignment value
	itob
	replace3
	byte 0x73746f726167654172726179 // "storageArray"
	swap
	app_global_put
	load 245 // assignment value
	retsub

// consts()void
*abi_route_consts:
	// execute consts()void
	callsub consts
	int 1
	return

// consts(): void
consts:
	proto 0 0

	// tests/contracts/general.algo.ts:332
	// assert(STRING_CONST === 'foo')
	pushbytes "foo"
	byte 0x666f6f // "foo"
	==
	assert

	// tests/contracts/general.algo.ts:333
	// assert(NUM_CONST === 123)
	int 123
	dup
	==
	assert

	// tests/contracts/general.algo.ts:334
	// assert(NESTED_CONST === 123)
	int 123
	dup
	==
	assert
	retsub

// assertWithMessage()void
*abi_route_assertWithMessage:
	// execute assertWithMessage()void
	callsub assertWithMessage
	int 1
	return

// assertWithMessage(): void
assertWithMessage:
	proto 0 0

	// tests/contracts/general.algo.ts:338
	// assert(false, 'this is false')
	int 0

	// this is false
	assert
	retsub

// opcodeAliases()void
*abi_route_opcodeAliases:
	// execute opcodeAliases()void
	callsub opcodeAliases
	int 1
	return

// opcodeAliases(): void
opcodeAliases:
	proto 0 0

	// tests/contracts/general.algo.ts:342
	// extractUint16(bzero(64), 0)
	byte 0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000
	int 0
	extract_uint16

	// tests/contracts/general.algo.ts:343
	// extractUint32(bzero(64), 0)
	byte 0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000
	int 0
	extract_uint32

	// tests/contracts/general.algo.ts:344
	// extractUint64(bzero(64), 0)
	byte 0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000
	int 0
	extract_uint64

	// tests/contracts/general.algo.ts:345
	// ed25519VerifyBare(bzero(64), bzero(64), bzero(32))
	byte 0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000
	dup
	byte 0x0000000000000000000000000000000000000000000000000000000000000000
	ed25519verify_bare

	// tests/contracts/general.algo.ts:346
	// ed25519Verify(bzero(64), bzero(64), bzero(32))
	byte 0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000
	dup
	byte 0x0000000000000000000000000000000000000000000000000000000000000000
	ed25519verify
	retsub

// vrfVerifyOp()void
*abi_route_vrfVerifyOp:
	// execute vrfVerifyOp()void
	callsub vrfVerifyOp
	int 1
	return

// vrfVerifyOp(): void
vrfVerifyOp:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// tests/contracts/general.algo.ts:350
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	int 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

	// tests/contracts/general.algo.ts:351
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	int 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

	// tests/contracts/general.algo.ts:352
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	int 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

	// tests/contracts/general.algo.ts:353
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	int 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

	// tests/contracts/general.algo.ts:354
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	int 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

	// tests/contracts/general.algo.ts:355
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	int 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

	// tests/contracts/general.algo.ts:356
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	int 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

	// tests/contracts/general.algo.ts:357
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	int 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

	// tests/contracts/general.algo.ts:358
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	int 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

	// tests/contracts/general.algo.ts:360
	// r = vrfVefiry('VrfAlgorand', bzero(32) as bytes, bzero(80), bzero(32))
	byte 0x0000000000000000000000000000000000000000000000000000000000000000
	pushbytes 0x0000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000
	byte 0x0000000000000000000000000000000000000000000000000000000000000000
	vrf_verify VrfAlgorand
	frame_bury 0 // r verified: bool
	frame_bury 1 // r output: byte[]

	// tests/contracts/general.algo.ts:361
	// assert(!r.verified)
	frame_dig 0 // r verified: bool
	!
	assert

	// tests/contracts/general.algo.ts:362
	// log(r.output)
	frame_dig 1 // r output: byte[]
	log
	retsub

// ecMath()void
*abi_route_ecMath:
	// execute ecMath()void
	callsub ecMath
	int 1
	return

// ecMath(): void
ecMath:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/general.algo.ts:366
	// ecScalarMul('BN254g1', '', '')
	byte 0x // ""
	dup
	ec_scalar_mul BN254g1

	// tests/contracts/general.algo.ts:367
	// ecPairingCheck('BN254g1', '', '')
	byte 0x // ""
	dup
	ec_pairing_check BN254g1

	// tests/contracts/general.algo.ts:368
	// scalars: bytes32[] = [bzero(32), bzero(32)]
	byte 0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000
	frame_bury 0 // scalars: bytes32[]

	// tests/contracts/general.algo.ts:369
	// ecMultiScalarMul('BN254g1', '', scalars)
	byte 0x // ""
	byte 0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 // scalars: bytes32[]
	ec_multi_scalar_mul BN254g1

	// tests/contracts/general.algo.ts:370
	// ecSubgroupCheck('BN254g1', '')
	byte 0x // ""
	ec_subgroup_check BN254g1

	// tests/contracts/general.algo.ts:371
	// ecMapTo('BN254g1', '')
	byte 0x // ""
	ec_map_to BN254g1

	// tests/contracts/general.algo.ts:372
	// ecAdd('BN254g1', '', '')
	byte 0x // ""
	dup
	ec_add BN254g1
	retsub

// gitxn()void
*abi_route_gitxn:
	// execute gitxn()void
	callsub gitxn
	int 1
	return

// gitxn(): void
gitxn:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/general.algo.ts:376
	// log(this.lastInnerGroup[0].sender)
	gitxn 0 Sender
	log

	// tests/contracts/general.algo.ts:378
	// anotherTxn = this.lastInnerGroup[1]
	int 1
	frame_bury 0 // anotherTxn: gitxn

	// tests/contracts/general.algo.ts:380
	// log(anotherTxn.sender)
	gitxn 1 Sender
	log
	retsub

// getSetBytes()void
*abi_route_getSetBytes:
	// execute getSetBytes()void
	callsub getSetBytes
	int 1
	return

// getSetBytes(): void
getSetBytes:
	proto 0 0

	// tests/contracts/general.algo.ts:384
	// log(setbit('foo', 0, true))
	byte 0x666f6f // "foo"
	int 0
	int 1
	setbit
	log

	// tests/contracts/general.algo.ts:385
	// getbit('foo', 0)
	byte 0x666f6f // "foo"
	int 0
	getbit

	// tests/contracts/general.algo.ts:386
	// getbyte('foo', 0)
	byte 0x666f6f // "foo"
	int 0
	getbyte

	// tests/contracts/general.algo.ts:387
	// setbyte('foo', 0, 1)
	byte 0x666f6f // "foo"
	int 0
	int 1
	setbyte
	retsub

// getSetUint64()void
*abi_route_getSetUint64:
	// execute getSetUint64()void
	callsub getSetUint64
	int 1
	return

// getSetUint64(): void
getSetUint64:
	proto 0 0

	// tests/contracts/general.algo.ts:391
	// assert(setbit(123, 0, true))
	int 123
	int 0
	int 1
	setbit
	assert

	// tests/contracts/general.algo.ts:392
	// getbit(123, 0)
	int 123
	int 0
	getbit
	retsub

// blockOp()void
*abi_route_blockOp:
	// execute blockOp()void
	callsub blockOp
	int 1
	return

// blockOp(): void
blockOp:
	proto 0 0

	// tests/contracts/general.algo.ts:396
	// log(blocks[globals.round - 1].seed)
	global Round
	int 1
	-
	block BlkSeed
	log

	// tests/contracts/general.algo.ts:397
	// assert(blocks[globals.round - 1].timestamp)
	global Round
	int 1
	-
	block BlkTimestamp
	assert
	retsub

// b64()void
*abi_route_b64:
	// execute b64()void
	callsub b64
	int 1
	return

// b64(): void
b64:
	proto 0 0

	// tests/contracts/general.algo.ts:401
	// log(base64Decode('StdEncoding', ''))
	byte 0x // ""
	base64_decode StdEncoding
	log
	retsub

// json()void
*abi_route_json:
	// execute json()void
	callsub json
	int 1
	return

// json(): void
json:
	proto 0 0

	// tests/contracts/general.algo.ts:405
	// log(jsonRef('JSONObject', '', ''))
	byte 0x // ""
	dup
	json_ref JSONObject
	log

	// tests/contracts/general.algo.ts:406
	// log(jsonRef('JSONString', '', ''))
	byte 0x // ""
	dup
	json_ref JSONString
	log

	// tests/contracts/general.algo.ts:407
	// assert(jsonRef('JSONUint64', '', ''))
	byte 0x // ""
	dup
	json_ref JSONUint64
	assert
	retsub

// bitlenOp()void
*abi_route_bitlenOp:
	// execute bitlenOp()void
	callsub bitlenOp
	int 1
	return

// bitlenOp(): void
bitlenOp:
	proto 0 0

	// tests/contracts/general.algo.ts:411
	// bitlen(123)
	int 123
	bitlen

	// tests/contracts/general.algo.ts:412
	// bitlen('foo')
	byte 0x666f6f // "foo"
	bitlen
	retsub

// computedConst()void
*abi_route_computedConst:
	// execute computedConst()void
	callsub computedConst
	int 1
	return

// computedConst(): void
computedConst:
	proto 0 0

	// tests/contracts/general.algo.ts:416
	// assert(COMPUTED_CONST)
	pushint 246
	assert
	retsub

// multiComputedConst()void
*abi_route_multiComputedConst:
	// execute multiComputedConst()void
	callsub multiComputedConst
	int 1
	return

// multiComputedConst(): void
multiComputedConst:
	proto 0 0

	// tests/contracts/general.algo.ts:420
	// assert(MUTLI_COMPUTED_CONST)
	pushint 30381
	assert
	retsub

// readSchema()void
*abi_route_readSchema:
	// execute readSchema()void
	callsub readSchema
	int 1
	return

// readSchema(): void
readSchema:
	proto 0 0

	// tests/contracts/general.algo.ts:424
	// assert(SchemaContract.schema.global.numUint === 1)
	int 1
	dup
	==
	assert

	// tests/contracts/general.algo.ts:425
	// assert(SchemaContract.schema.global.numByteSlice === 2)
	int 2
	dup
	==
	assert

	// tests/contracts/general.algo.ts:426
	// assert(SchemaContract.schema.local.numUint === 3)
	pushint 3
	pushint 3
	==
	assert

	// tests/contracts/general.algo.ts:427
	// assert(SchemaContract.schema.local.numByteSlice === 4)
	int 4
	dup
	==
	assert
	retsub

// comparisonOr()bool
*abi_route_comparisonOr:
	// The ABI return prefix
	byte 0x151f7c75

	// execute comparisonOr()bool
	callsub comparisonOr
	pushbytes 0x00
	int 0
	uncover 2
	setbit
	concat
	log
	int 1
	return

// comparisonOr(): boolean
comparisonOr:
	proto 0 1

	// tests/contracts/general.algo.ts:431
	// return this.txn.sender === globals.zeroAddress || this.txn.sender === globals.zeroAddress;
	txn Sender
	global ZeroAddress
	==
	dup
	bnz *skip_or0
	txn Sender
	global ZeroAddress
	==
	||

*skip_or0:
	retsub

// txnArgsMethod(pay)void
*abi_route_txnArgsMethod:
	// _pay1: pay
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// argument 0 (_pay1) for txnArgsMethod must be a pay transaction
	assert

	// execute txnArgsMethod(pay)void
	callsub txnArgsMethod
	int 1
	return

// txnArgsMethod(_pay1: PayTxn): void
txnArgsMethod:
	proto 1 0
	retsub

// callTxnArgsMethod()void
*abi_route_callTxnArgsMethod:
	// execute callTxnArgsMethod()void
	callsub callTxnArgsMethod
	int 1
	return

// callTxnArgsMethod(): void
callTxnArgsMethod:
	proto 0 0

	// tests/contracts/general.algo.ts:438
	// sendMethodCall<typeof GeneralTest.prototype.txnArgsMethod>({
	//       methodArgs: [{ receiver: this.app.address, amount: 0 }],
	//     })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// tests/contracts/general.algo.ts:439
	// receiver: this.app.address
	global CurrentApplicationAddress
	itxn_field Receiver

	// tests/contracts/general.algo.ts:439
	// amount: 0
	int 0
	itxn_field Amount

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee
	itxn_next
	int 6 // appl
	itxn_field TypeEnum
	byte 0x2c636eeb // method "txnArgsMethod(pay)void"
	itxn_field ApplicationArgs

	// tests/contracts/general.algo.ts:439
	// methodArgs: [{ receiver: this.app.address, amount: 0 }]
	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// staticValueLen(uint256)void
*abi_route_staticValueLen:
	// x: uint256
	txna ApplicationArgs 1
	dup
	len
	pushint 32
	==

	// argument 0 (x) for staticValueLen must be a uint256
	assert

	// execute staticValueLen(uint256)void
	callsub staticValueLen
	int 1
	return

// staticValueLen(x: uint256): void
staticValueLen:
	proto 1 0

	// tests/contracts/general.algo.ts:444
	// assert(len(x))
	pushint 32
	assert
	retsub

// staticTypeLen()void
*abi_route_staticTypeLen:
	// execute staticTypeLen()void
	callsub staticTypeLen
	int 1
	return

// staticTypeLen(): void
staticTypeLen:
	proto 0 0

	// tests/contracts/general.algo.ts:448
	// assert(len<uint256>())
	pushint 32
	assert
	retsub

// dynamicScratchSlot()void
*abi_route_dynamicScratchSlot:
	// execute dynamicScratchSlot()void
	callsub dynamicScratchSlot
	int 1
	return

// dynamicScratchSlot(): void
dynamicScratchSlot:
	proto 0 0

	// tests/contracts/general.algo.ts:452
	// this.dynamicScratch(1).value = 1337
	int 1
	int 1337
	stores

	// tests/contracts/general.algo.ts:453
	// assert(this.dynamicScratch(1).value === 1337)
	int 1
	loads
	int 1337
	==
	assert
	retsub

// incrementScratchSlot()void
*abi_route_incrementScratchSlot:
	// execute incrementScratchSlot()void
	callsub incrementScratchSlot
	int 1
	return

// incrementScratchSlot(): void
incrementScratchSlot:
	proto 0 0

	// tests/contracts/general.algo.ts:457
	// this.scratch.value = 1337
	int 1337
	store 0

	// tests/contracts/general.algo.ts:458
	// this.scratch.value += 1
	load 0
	int 1
	+
	store 0

	// tests/contracts/general.algo.ts:459
	// assert(this.scratch.value === 1338)
	load 0
	pushint 1338
	==
	assert
	retsub

// incrementDynamicScratchSlot()void
*abi_route_incrementDynamicScratchSlot:
	// execute incrementDynamicScratchSlot()void
	callsub incrementDynamicScratchSlot
	int 1
	return

// incrementDynamicScratchSlot(): void
incrementDynamicScratchSlot:
	proto 0 0

	// tests/contracts/general.algo.ts:463
	// this.dynamicScratch(2).value = 1337
	int 2
	int 1337
	stores

	// tests/contracts/general.algo.ts:464
	// this.dynamicScratch(2).value += 1
	int 2
	loads
	int 1
	+
	int 2
	swap
	stores

	// tests/contracts/general.algo.ts:465
	// assert(this.dynamicScratch(2).value === 1338)
	int 2
	loads
	pushint 1338
	==
	assert
	retsub

// fromAddress()void
*abi_route_fromAddress:
	// execute fromAddress()void
	callsub fromAddress
	int 1
	return

// fromAddress(): void
fromAddress:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/general.algo.ts:469
	// a = Address.fromAddress('AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAY5HFKQ')
	byte 0x0000000000000000000000000000000000000000000000000000000000000000 // addr "AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAY5HFKQ"
	frame_bury 0 // a: address

	// tests/contracts/general.algo.ts:470
	// assert(a === Address.zeroAddress)
	frame_dig 0 // a: address
	global ZeroAddress
	==
	assert
	retsub

// earlyReturn(uint64)uint64
*abi_route_earlyReturn:
	// The ABI return prefix
	byte 0x151f7c75

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute earlyReturn(uint64)uint64
	callsub earlyReturn
	itob
	concat
	log
	int 1
	return

// earlyReturn(a: uint64): uint64
earlyReturn:
	proto 1 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// *if1_condition
	// tests/contracts/general.algo.ts:474
	// a === 1
	frame_dig -1 // a: uint64
	int 1
	==
	bz *if1_end

	// *if1_consequent
	// tests/contracts/general.algo.ts:475
	// return 2;
	int 2
	b *earlyReturn*return

*if1_end:
	// tests/contracts/general.algo.ts:477
	// b = a + 1
	frame_dig -1 // a: uint64
	int 1
	+
	frame_bury 0 // b: uint64

	// tests/contracts/general.algo.ts:478
	// return b;
	frame_dig 0 // b: uint64

*earlyReturn*return:
	// set the subroutine return value
	frame_bury 0
	retsub

// assetMethodArgs()void
*abi_route_assetMethodArgs:
	// execute assetMethodArgs()void
	callsub assetMethodArgs
	int 1
	return

// assetMethodArgs(): void
assetMethodArgs:
	proto 0 0

	// tests/contracts/general.algo.ts:482
	// sendMethodCall<[AssetReference], void>({
	//       name: 'foo',
	//       methodArgs: [AssetID.fromUint64(1)],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	pushbytes 0xa15316de // method "foo(asset)void"
	itxn_field ApplicationArgs

	// tests/contracts/general.algo.ts:484
	// methodArgs: [AssetID.fromUint64(1)]
	int 1
	itxn_field Assets
	pushbytes 0x0000000000000000
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// multipleProgramPages()void
*abi_route_multipleProgramPages:
	// execute multipleProgramPages()void
	callsub multipleProgramPages
	int 1
	return

// multipleProgramPages(): void
multipleProgramPages:
	proto 0 0

	// tests/contracts/general.algo.ts:493
	// sendAppCall({
	//       approvalProgram: [this.pageOne.value, this.pageTwo.value],
	//       clearStateProgram: [this.pageOne.value, this.pageTwo.value],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum

	// tests/contracts/general.algo.ts:494
	// approvalProgram: [this.pageOne.value, this.pageTwo.value]
	byte 0x706167654f6e65 // "pageOne"
	box_get

	// box value does not exist: this.pageOne.value
	assert
	itxn_field ApprovalProgramPages
	byte 0x7061676554776f // "pageTwo"
	box_get

	// box value does not exist: this.pageTwo.value
	assert
	itxn_field ApprovalProgramPages

	// tests/contracts/general.algo.ts:495
	// clearStateProgram: [this.pageOne.value, this.pageTwo.value]
	byte 0x706167654f6e65 // "pageOne"
	box_get

	// box value does not exist: this.pageOne.value
	assert
	itxn_field ClearStateProgramPages
	byte 0x7061676554776f // "pageTwo"
	box_get

	// box value does not exist: this.pageTwo.value
	assert
	itxn_field ClearStateProgramPages

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// assertComment()void
*abi_route_assertComment:
	// execute assertComment()void
	callsub assertComment
	int 1
	return

// assertComment(): void
assertComment:
	proto 0 0

	// tests/contracts/general.algo.ts:500
	// assert(false, 'this is false')
	int 0

	// this is false
	assert
	retsub

// throwErrorMessage()void
*abi_route_throwErrorMessage:
	// execute throwErrorMessage()void
	callsub throwErrorMessage
	int 1
	return

// throwErrorMessage(): void
throwErrorMessage:
	proto 0 0

	// this is an error
	err
	retsub

// orLiteralType(uint64,uint64)void
*abi_route_orLiteralType:
	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute orLiteralType(uint64,uint64)void
	callsub orLiteralType
	int 1
	return

// orLiteralType(a: uint64, b: uint64): void
orLiteralType:
	proto 2 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// tests/contracts/general.algo.ts:508
	// foo = a && b === 1 ? 2 : 0
	frame_dig -1 // a: uint64
	dup
	bz *skip_and0
	frame_dig -2 // b: uint64
	int 1
	==
	&&

*skip_and0:
	bz *ternary0_false
	int 2
	b *ternary0_end

*ternary0_false:
	int 0

*ternary0_end:
	frame_bury 0 // foo: uint64

	// tests/contracts/general.algo.ts:509
	// assert(foo)
	frame_dig 0 // foo: uint64
	assert

	// tests/contracts/general.algo.ts:511
	// bar = a && b === 0 ? '2' : '0'
	frame_dig -1 // a: uint64
	dup
	bz *skip_and1
	frame_dig -2 // b: uint64
	int 0
	==
	&&

*skip_and1:
	bz *ternary1_false
	pushbytes 0x32 // "2"
	b *ternary1_end

*ternary1_false:
	byte 0x30 // "0"

*ternary1_end:
	frame_bury 1 // bar: byte[]

	// tests/contracts/general.algo.ts:512
	// log(bar)
	frame_dig 1 // bar: byte[]
	log
	retsub

// nonAbi(): void
nonAbi:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/general.algo.ts:517
	// assert(this.txn.applicationArgs!.length)
	txn NumAppArgs
	assert

	// tests/contracts/general.algo.ts:519
	// for (let i = 0; i < this.txn.applicationArgs!.length; i += 1)
	int 0
	frame_bury 0 // i: uint64

*for_1:
	// tests/contracts/general.algo.ts:519
	// i < this.txn.applicationArgs!.length
	frame_dig 0 // i: uint64
	txn NumAppArgs
	<
	bz *for_1_end

	// tests/contracts/general.algo.ts:520
	// log(this.txn.applicationArgs![i])
	frame_dig 0 // i: uint64
	txnas ApplicationArgs
	log

*for_1_continue:
	// tests/contracts/general.algo.ts:519
	// i += 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64
	b *for_1

*for_1_end:
	retsub

// multilineFunctionCall()void
*abi_route_multilineFunctionCall:
	// execute multilineFunctionCall()void
	callsub multilineFunctionCall
	int 1
	return

// multilineFunctionCall(): void
multilineFunctionCall:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// tests/contracts/general.algo.ts:525
	// app = AppID.zeroIndex
	int 0
	frame_bury 0 // app: uint64

	// tests/contracts/general.algo.ts:526
	// addr = Address.zeroAddress
	global ZeroAddress
	frame_bury 1 // addr: address

	// tests/contracts/general.algo.ts:528
	// app.localState(
	//       addr,
	//       'key'
	//     )
	frame_dig 1 // addr: address
	int 0 // app: uint64
	pushbytes 0x6b6579 // "key"
	app_local_get_ex

	// local state value does not exist: app.localState( addr, 'key' )
	assert
	retsub

// a()uint64
*abi_route_a:
	// The ABI return prefix
	byte 0x151f7c75

	// execute a()uint64
	callsub a
	itob
	concat
	log
	int 1
	return

// a(): uint64
a:
	proto 0 1

	// tests/contracts/general.algo.ts:535
	// return 3;
	pushint 3
	retsub

// b()uint64
*abi_route_b:
	// The ABI return prefix
	byte 0x151f7c75

	// execute b()uint64
	callsub b
	itob
	concat
	log
	int 1
	return

// b(): uint64
b:
	proto 0 1

	// tests/contracts/general.algo.ts:539
	// return 5;
	int 5
	retsub

// unusedMethodValue()uint64
*abi_route_unusedMethodValue:
	// The ABI return prefix
	byte 0x151f7c75

	// execute unusedMethodValue()uint64
	callsub unusedMethodValue
	itob
	concat
	log
	int 1
	return

// unusedMethodValue(): uint64
unusedMethodValue:
	proto 0 1

	// tests/contracts/general.algo.ts:543
	// this.a()
	callsub a
	pop

	// tests/contracts/general.algo.ts:544
	// return this.b();
	callsub b
	retsub

// reassignedNonFirstVar()uint64
*abi_route_reassignedNonFirstVar:
	// The ABI return prefix
	byte 0x151f7c75

	// execute reassignedNonFirstVar()uint64
	callsub reassignedNonFirstVar
	itob
	concat
	log
	int 1
	return

// reassignedNonFirstVar(): uint64
reassignedNonFirstVar:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// tests/contracts/general.algo.ts:555
	// a = 1 as uint64
	int 1
	frame_bury 0 // a: uint64

	// tests/contracts/general.algo.ts:556
	// b = this.app.id
	txna Applications 0
	frame_bury 1 // b: uint64

	// *if2_condition
	// tests/contracts/general.algo.ts:557
	// a
	frame_dig 0 // a: uint64
	bz *if2_end

	// *if2_consequent
	// tests/contracts/general.algo.ts:558
	// b = 2
	int 2
	frame_bury 1 // b: uint64

*if2_end:
	// tests/contracts/general.algo.ts:561
	// return b;
	frame_dig 1 // b: uint64

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 1
	retsub

// fvLv()void
*abi_route_fvLv:
	// execute fvLv()void
	callsub fvLv
	int 1
	return

// fvLv(): void
fvLv:
	proto 0 0

	// tests/contracts/general.algo.ts:565
	// assert(this.txn.firstValid)
	txn FirstValid
	assert

	// tests/contracts/general.algo.ts:566
	// assert(this.txn.lastValid)
	txn LastValid
	assert
	retsub

*abi_route_createApplication:
	int 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x624264a3 // method "txnTypeEnum()void"
	pushbytes 0xb205edc9 // method "txnGroupLength()void"
	pushbytes 0xe6e97d5b // method "asserts(bool,bool)void"
	pushbytes 0xdd6fa7c8 // method "verifyTxnFromArg(pay)void"
	pushbytes 0x0ea644fb // method "verifyTxnFromTxnGroup()void"
	pushbytes 0xec0d9094 // method "verifyTxnCondition()void"
	pushbytes 0x68848d97 // method "verifyTxnIncludedIn()void"
	pushbytes 0x18bd23dc // method "verifyTxnNotIncludedIn()void"
	pushbytes 0x806bfb93 // method "submitPendingGroup()void"
	pushbytes 0x3be5f82e // method "methodWithTxnArgs()void"
	pushbytes 0x1295d683 // method "shift()void"
	pushbytes 0xb3b8c472 // method "fromBytes()void"
	pushbytes 0x53e0b6f0 // method "fromUint64()void"
	pushbytes 0x4b3eb877 // method "bzeroFunction()void"
	pushbytes 0xdac2e7a5 // method "events()void"
	pushbytes 0xa3db6704 // method "letOptimization(uint64[])uint64[]"
	pushbytes 0xae21c172 // method "staticContractProperties()void"
	pushbytes 0xdab4d1c4 // method "numberToString()void"
	pushbytes 0xa7b4ae9a // method "methodOnParens()void"
	pushbytes 0x6d4485ba // method "stringSubstring()void"
	pushbytes 0xef6262e9 // method "idProperty()void"
	pushbytes 0x8d2b668b // method "scratchSlot()void"
	pushbytes 0xe6c154fc // method "ecdsa()void"
	pushbytes 0xa9764197 // method "verifyTxnTypes()void"
	pushbytes 0x9dbbc42c // method "stringPlusEquals()void"
	pushbytes 0x4c0ddec1 // method "importedProgram()byte[]"
	pushbytes 0x30ecfb41 // method "callPrivateDefinedLater()void"
	pushbytes 0x14a49919 // method "interalPublicMethod(uint64,uint64)uint64"
	pushbytes 0xb71c179a // method "callInternalPublicMethod()void"
	pushbytes 0x98481093 // method "appLoadScratch()void"
	pushbytes 0xf572d1c1 // method "uintNWithUnderscore()uint256"
	pushbytes 0x854dede0 // method "opUp()void"
	pushbytes 0x681599fa // method "returnValueOnAssignment()string"
	pushbytes 0x5e1477e8 // method "returnArrayValueOnAssignment()uint64"
	pushbytes 0xe07b3be9 // method "returnStorageValueOnAssignment()uint64"
	pushbytes 0x16e46657 // method "returnOperatorAssignmentValue()uint64"
	pushbytes 0x2c836f46 // method "returnArrayValueOnOperatorAssignment()uint64"
	pushbytes 0xa93c56f9 // method "returnArrayInStorageValueOnOperatorAssignment()uint64"
	pushbytes 0xf936952d // method "consts()void"
	pushbytes 0x88f39c99 // method "assertWithMessage()void"
	pushbytes 0x58794cf4 // method "opcodeAliases()void"
	pushbytes 0x35044ad8 // method "vrfVerifyOp()void"
	pushbytes 0x7d279e8e // method "ecMath()void"
	pushbytes 0x3dfa18c8 // method "gitxn()void"
	pushbytes 0x78ca5c4e // method "getSetBytes()void"
	pushbytes 0x0e67e957 // method "getSetUint64()void"
	pushbytes 0x3b446eef // method "blockOp()void"
	pushbytes 0xae82e875 // method "b64()void"
	pushbytes 0xd69af530 // method "json()void"
	pushbytes 0x4d52f33d // method "bitlenOp()void"
	pushbytes 0x2c0cd201 // method "computedConst()void"
	pushbytes 0x70e0afe5 // method "multiComputedConst()void"
	pushbytes 0x30a2fef4 // method "readSchema()void"
	pushbytes 0xf3971dca // method "comparisonOr()bool"
	byte 0x2c636eeb // method "txnArgsMethod(pay)void"
	pushbytes 0x9e40d34b // method "callTxnArgsMethod()void"
	pushbytes 0x91cf2b58 // method "staticValueLen(uint256)void"
	pushbytes 0xb1c8b45c // method "staticTypeLen()void"
	pushbytes 0x9c0e1bdb // method "dynamicScratchSlot()void"
	pushbytes 0x0a319504 // method "incrementScratchSlot()void"
	pushbytes 0x84b260fa // method "incrementDynamicScratchSlot()void"
	pushbytes 0x4a908856 // method "fromAddress()void"
	pushbytes 0x8deb32d3 // method "earlyReturn(uint64)uint64"
	pushbytes 0x67de156f // method "assetMethodArgs()void"
	pushbytes 0x1e428412 // method "multipleProgramPages()void"
	pushbytes 0x278fd8b8 // method "assertComment()void"
	pushbytes 0xbfc36208 // method "throwErrorMessage()void"
	pushbytes 0x04eedf79 // method "orLiteralType(uint64,uint64)void"
	pushbytes 0x35d5fbc7 // method "multilineFunctionCall()void"
	pushbytes 0xf9522e2f // method "a()uint64"
	pushbytes 0x8c9379e6 // method "b()uint64"
	pushbytes 0xf9a13552 // method "unusedMethodValue()uint64"
	pushbytes 0x94f2049a // method "reassignedNonFirstVar()uint64"
	pushbytes 0x56264215 // method "fvLv()void"
	txna ApplicationArgs 0
	match *abi_route_txnTypeEnum *abi_route_txnGroupLength *abi_route_asserts *abi_route_verifyTxnFromArg *abi_route_verifyTxnFromTxnGroup *abi_route_verifyTxnCondition *abi_route_verifyTxnIncludedIn *abi_route_verifyTxnNotIncludedIn *abi_route_submitPendingGroup *abi_route_methodWithTxnArgs *abi_route_shift *abi_route_fromBytes *abi_route_fromUint64 *abi_route_bzeroFunction *abi_route_events *abi_route_letOptimization *abi_route_staticContractProperties *abi_route_numberToString *abi_route_methodOnParens *abi_route_stringSubstring *abi_route_idProperty *abi_route_scratchSlot *abi_route_ecdsa *abi_route_verifyTxnTypes *abi_route_stringPlusEquals *abi_route_importedProgram *abi_route_callPrivateDefinedLater *abi_route_interalPublicMethod *abi_route_callInternalPublicMethod *abi_route_appLoadScratch *abi_route_uintNWithUnderscore *abi_route_opUp *abi_route_returnValueOnAssignment *abi_route_returnArrayValueOnAssignment *abi_route_returnStorageValueOnAssignment *abi_route_returnOperatorAssignmentValue *abi_route_returnArrayValueOnOperatorAssignment *abi_route_returnArrayInStorageValueOnOperatorAssignment *abi_route_consts *abi_route_assertWithMessage *abi_route_opcodeAliases *abi_route_vrfVerifyOp *abi_route_ecMath *abi_route_gitxn *abi_route_getSetBytes *abi_route_getSetUint64 *abi_route_blockOp *abi_route_b64 *abi_route_json *abi_route_bitlenOp *abi_route_computedConst *abi_route_multiComputedConst *abi_route_readSchema *abi_route_comparisonOr *abi_route_txnArgsMethod *abi_route_callTxnArgsMethod *abi_route_staticValueLen *abi_route_staticTypeLen *abi_route_dynamicScratchSlot *abi_route_incrementScratchSlot *abi_route_incrementDynamicScratchSlot *abi_route_fromAddress *abi_route_earlyReturn *abi_route_assetMethodArgs *abi_route_multipleProgramPages *abi_route_assertComment *abi_route_throwErrorMessage *abi_route_orLiteralType *abi_route_multilineFunctionCall *abi_route_a *abi_route_b *abi_route_unusedMethodValue *abi_route_reassignedNonFirstVar *abi_route_fvLv

	// !!!! WARNING: non-ABI routing
	callsub nonAbi
	int 1
	return

*intToAscii:
	proto 1 1
	pushbytes 0x30313233343536373839 // "0123456789"
	frame_dig -1 // i: uint64
	int 1
	extract3
	retsub
	

*itoa:
	proto 1 1
	frame_dig -1 // i: uint64
	int 0
	==
	bz *itoa_if_end
	byte 0x30
	retsub

*itoa_if_end:
	frame_dig -1 // i: uint64
	pushint 10
	/
	int 0
	>
	bz *itoa_ternary_false
	frame_dig -1 // i: uint64
	pushint 10
	/
	callsub *itoa
	b *itoa_ternary_end

*itoa_ternary_false:
	byte 0x // ""

*itoa_ternary_end:
	frame_dig -1 // i: uint64
	pushint 10
	%
	callsub *intToAscii
	concat
	retsub", + "approval": "#pragma version 10
intcblock 1 0 6 1337 2 5 123 4
bytecblock 0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 0x0000000000000000000000000000000000000000000000000000000000000000 0x000000000000000100000000000000020000000000000003 0x151f7c75 0x0a8101 0x73746f726167654172726179 0x 0x666f6f 0x000000000000000000 0x0000000000000001 0x706167654f6e65 0x7061676554776f 0x674b6579 0x2c636eeb 0x626172 0x627965 0x0000 0x30

// This TEAL was generated by TEALScript v0.105.0
// https://github.com/algorandfoundation/TEALScript

// !!!! WARNING: This contract is *NOT* ARC4 compliant. It may contain ABI methods, but it also allows app calls where the first argument does NOT match an ABI selector

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
int 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// txnTypeEnum()void
*abi_route_txnTypeEnum:
	// execute txnTypeEnum()void
	callsub txnTypeEnum
	int 1
	return

// txnTypeEnum(): void
txnTypeEnum:
	proto 0 0

	// tests/contracts/general.algo.ts:69
	// assert(this.txnGroup[0].typeEnum === TransactionType.ApplicationCall)
	int 0
	gtxns TypeEnum
	int 6 // appl
	==
	assert
	retsub

// txnGroupLength()void
*abi_route_txnGroupLength:
	// execute txnGroupLength()void
	callsub txnGroupLength
	int 1
	return

// txnGroupLength(): void
txnGroupLength:
	proto 0 0

	// tests/contracts/general.algo.ts:73
	// assert(this.txnGroup.length === 1)
	global GroupSize
	int 1
	==
	assert
	retsub

// asserts(bool,bool)void
*abi_route_asserts:
	// arg2: bool
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 0 (arg2) for asserts must be a bool
	assert
	int 0
	getbit

	// arg1: bool
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 1 (arg1) for asserts must be a bool
	assert
	int 0
	getbit

	// execute asserts(bool,bool)void
	callsub asserts
	int 1
	return

// asserts(arg1: boolean, arg2: boolean): void
asserts:
	proto 2 0

	// tests/contracts/general.algo.ts:77
	// asserts(arg1, arg2, arg1 === arg2)
	frame_dig -1 // arg1: boolean

	// asserts failed: asserts(arg1, arg2, arg1 === arg2)
	assert
	frame_dig -2 // arg2: boolean

	// asserts failed: asserts(arg1, arg2, arg1 === arg2)
	assert
	frame_dig -1 // arg1: boolean
	frame_dig -2 // arg2: boolean
	==

	// asserts failed: asserts(arg1, arg2, arg1 === arg2)
	assert
	retsub

// verifyTxnFromArg(pay)void
*abi_route_verifyTxnFromArg:
	// somePay: pay
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// argument 0 (somePay) for verifyTxnFromArg must be a pay transaction
	assert

	// execute verifyTxnFromArg(pay)void
	callsub verifyTxnFromArg
	int 1
	return

// verifyTxnFromArg(somePay: PayTxn): void
verifyTxnFromArg:
	proto 1 0

	// tests/contracts/general.algo.ts:81
	// verifyTxn(somePay, { receiver: this.app.address, amount: 100_000 })
	// verify receiver
	frame_dig -1 // somePay: PayTxn
	gtxns Receiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"somePay","field":"receiver","expected":"this.app.address"}
	assert

	// verify amount
	frame_dig -1 // somePay: PayTxn
	gtxns Amount
	pushint 100_000
	==

	// transaction verification failed: {"txn":"somePay","field":"amount","expected":"100_000"}
	assert
	retsub

// verifyTxnFromTxnGroup()void
*abi_route_verifyTxnFromTxnGroup:
	// execute verifyTxnFromTxnGroup()void
	callsub verifyTxnFromTxnGroup
	int 1
	return

// verifyTxnFromTxnGroup(): void
verifyTxnFromTxnGroup:
	proto 0 0

	// tests/contracts/general.algo.ts:85
	// verifyTxn(this.txnGroup[0], { sender: this.txn.sender })
	// verify sender
	int 0
	gtxns Sender
	txn Sender
	==

	// transaction verification failed: {"txn":"this.txnGroup[0]","field":"sender","expected":"this.txn.sender"}
	assert
	retsub

// verifyTxnCondition()void
*abi_route_verifyTxnCondition:
	// execute verifyTxnCondition()void
	callsub verifyTxnCondition
	int 1
	return

// verifyTxnCondition(): void
verifyTxnCondition:
	proto 0 0

	// tests/contracts/general.algo.ts:89
	// verifyTxn(this.txn, {
	//       applicationID: { greaterThan: 1 },
	//     })
	// verify applicationID
	txn ApplicationID
	int 1
	>

	// transaction verification failed: {"txn":"this.txn","field":"applicationID","condition":"greaterThan","expected":">1"}
	assert
	retsub

// verifyTxnIncludedIn()void
*abi_route_verifyTxnIncludedIn:
	// execute verifyTxnIncludedIn()void
	callsub verifyTxnIncludedIn
	int 1
	return

// verifyTxnIncludedIn(): void
verifyTxnIncludedIn:
	proto 0 0

	// tests/contracts/general.algo.ts:95
	// verifyTxn(this.txn, {
	//       sender: { includedIn: [this.txn.sender] },
	//     })
	// verify sender
	txn Sender
	txn Sender
	==

	// transaction verification failed: {"txn":{"txnText":"this.txn"},"field":"sender","condition":"includedIn","expected":"[this.txn.sender]"}
	assert
	retsub

// verifyTxnNotIncludedIn()void
*abi_route_verifyTxnNotIncludedIn:
	// execute verifyTxnNotIncludedIn()void
	callsub verifyTxnNotIncludedIn
	int 1
	return

// verifyTxnNotIncludedIn(): void
verifyTxnNotIncludedIn:
	proto 0 0

	// tests/contracts/general.algo.ts:101
	// verifyTxn(this.txn, {
	//       sender: { notIncludedIn: [globals.zeroAddress] },
	//     })
	// verify sender
	txn Sender
	global ZeroAddress
	!=

	// transaction verification failed: {"txn":{"txnText":"this.txn"},"field":"sender","condition":"notIncludedIn","expected":"[globals.zeroAddress]"}
	assert
	retsub

// submitPendingGroup()void
*abi_route_submitPendingGroup:
	// execute submitPendingGroup()void
	callsub submitPendingGroup
	int 1
	return

// submitPendingGroup(): void
submitPendingGroup:
	proto 0 0

	// tests/contracts/general.algo.ts:107
	// this.pendingGroup.addPayment({ amount: 0, receiver: this.app.address, isFirstTxn: true })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// tests/contracts/general.algo.ts:107
	// amount: 0
	int 0
	itxn_field Amount

	// tests/contracts/general.algo.ts:107
	// receiver: this.app.address
	global CurrentApplicationAddress
	itxn_field Receiver

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// tests/contracts/general.algo.ts:108
	// this.pendingGroup.addPayment({ amount: 0, receiver: this.app.address, note: 'foo' })
	itxn_next
	int 1 // pay
	itxn_field TypeEnum

	// tests/contracts/general.algo.ts:108
	// amount: 0
	int 0
	itxn_field Amount

	// tests/contracts/general.algo.ts:108
	// receiver: this.app.address
	global CurrentApplicationAddress
	itxn_field Receiver

	// tests/contracts/general.algo.ts:108
	// note: 'foo'
	byte 0x666f6f // "foo"
	itxn_field Note

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// tests/contracts/general.algo.ts:109
	// this.pendingGroup.submit()
	itxn_submit
	retsub

// methodWithTxnArgs()void
*abi_route_methodWithTxnArgs:
	// execute methodWithTxnArgs()void
	callsub methodWithTxnArgs
	int 1
	return

// methodWithTxnArgs(): void
methodWithTxnArgs:
	proto 0 0

	// tests/contracts/general.algo.ts:113
	// sendMethodCall<[PayTxn, MethodCall<[uint64], void>], void>({
	//       name: 'foo',
	//       methodArgs: [
	//         { amount: 100_000, receiver: this.txn.sender },
	//         {
	//           name: 'bar',
	//           applicationID: AppID.fromUint64(1337),
	//           methodArgs: [1],
	//         },
	//       ],
	//     })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// tests/contracts/general.algo.ts:116
	// amount: 100_000
	pushint 100_000
	itxn_field Amount

	// tests/contracts/general.algo.ts:116
	// receiver: this.txn.sender
	txn Sender
	itxn_field Receiver

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee
	itxn_next
	int 6 // appl
	itxn_field TypeEnum
	pushbytes 0x0e8cb9f6 // method "bar(uint64)void"
	itxn_field ApplicationArgs

	// tests/contracts/general.algo.ts:119
	// applicationID: AppID.fromUint64(1337)
	int 1337
	itxn_field ApplicationID

	// tests/contracts/general.algo.ts:120
	// methodArgs: [1]
	byte 0x0000000000000001
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee
	itxn_next
	int 6 // appl
	itxn_field TypeEnum
	pushbytes 0x6c6f7a08 // method "foo(pay,appl)void"
	itxn_field ApplicationArgs

	// tests/contracts/general.algo.ts:115
	// methodArgs: [
	//         { amount: 100_000, receiver: this.txn.sender },
	//         {
	//           name: 'bar',
	//           applicationID: AppID.fromUint64(1337),
	//           methodArgs: [1],
	//         },
	//       ]
	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// shift()void
*abi_route_shift:
	// execute shift()void
	callsub shift
	int 1
	return

// shift(): void
shift:
	proto 0 0

	// tests/contracts/general.algo.ts:127
	// assert(1 << 2 === 4)
	int 1
	int 2
	shl
	int 4
	==
	assert

	// tests/contracts/general.algo.ts:128
	// assert(4 >> 1 === 2)
	int 4
	int 1
	shr
	int 2
	==
	assert
	retsub

// fromBytes()void
*abi_route_fromBytes:
	// execute fromBytes()void
	callsub fromBytes
	int 1
	return

// fromBytes(): void
fromBytes:
	proto 0 0

	// tests/contracts/general.algo.ts:132
	// assert(Address.fromBytes('abc').minBalance)
	pushbytes 0x616263 // "abc"
	acct_params_get AcctMinBalance
	pop
	assert
	retsub

// fromUint64()void
*abi_route_fromUint64:
	// execute fromUint64()void
	callsub fromUint64
	int 1
	return

// fromUint64(): void
fromUint64:
	proto 0 0

	// tests/contracts/general.algo.ts:136
	// log(AppID.fromUint64(123).creator)
	int 123
	app_params_get AppCreator
	pop
	log

	// tests/contracts/general.algo.ts:137
	// log(AssetID.fromUint64(123).creator)
	int 123
	asset_params_get AssetCreator
	pop
	log
	retsub

// bzeroFunction()void
*abi_route_bzeroFunction:
	// execute bzeroFunction()void
	callsub bzeroFunction
	int 1
	return

// bzeroFunction(): void
bzeroFunction:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// tests/contracts/general.algo.ts:142
	// x: bytes = bzero(2)
	byte 0x0000
	frame_bury 0 // x: bytes

	// tests/contracts/general.algo.ts:143
	// y: bytes = bzero(n)
	int 1
	bzero
	frame_bury 1 // y: bytes

	// tests/contracts/general.algo.ts:144
	// z: [uint64, uint<8>] = bzero<[uint64, uint<8>]>()
	byte 0x000000000000000000
	frame_bury 2 // z: [uint64, uint<8>]

	// tests/contracts/general.algo.ts:145
	// assert(len(x + y + z) === 12)
	byte 0x0000 // x: bytes
	frame_dig 1 // y: bytes
	concat
	byte 0x000000000000000000 // z: [uint64, uint<8>]
	concat
	len
	pushint 12
	==
	assert
	retsub

// events()void
*abi_route_events:
	// execute events()void
	callsub events
	int 1
	return

// events(): void
events:
	proto 0 0

	// tests/contracts/general.algo.ts:160
	// this.myEvent.log({ app: this.app, num: 1 })
	pushbytes 0x87528196 // myEvent(uint64,uint64)
	txna Applications 0
	itob
	byte 0x0000000000000001
	concat
	concat
	log
	retsub

// letOptimization(uint64[])uint64[]
*abi_route_letOptimization:
	// The ABI return prefix
	byte 0x151f7c75

	// a: uint64[]
	txna ApplicationArgs 1
	extract 2 0

	// execute letOptimization(uint64[])uint64[]
	callsub letOptimization
	dup
	len
	pushint 8
	/
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// letOptimization(a: uint64[]): uint64[]
letOptimization:
	proto 1 1

	// tests/contracts/general.algo.ts:164
	// assert(a[0])
	frame_dig -1 // a: uint64[]
	store 255 // full array
	load 255 // full array
	extract 0 8
	btoi
	assert

	// tests/contracts/general.algo.ts:166
	// b = [1, 2, 3]
	byte 0x000000000000000100000000000000020000000000000003
	frame_bury -1 // b: uint64[]

	// tests/contracts/general.algo.ts:168
	// return b;
	frame_dig -1 // a: uint64[]
	retsub

// staticContractProperties()void
*abi_route_staticContractProperties:
	// execute staticContractProperties()void
	callsub staticContractProperties
	int 1
	return

// staticContractProperties(): void
staticContractProperties:
	proto 0 0

	// tests/contracts/general.algo.ts:172
	// sendAppCall({
	//       onCompletion: OnCompletion.NoOp,
	//       approvalProgram: DummyContract.approvalProgram(),
	//       clearStateProgram: DummyContract.clearProgram(),
	//       localNumByteSlice: DummyContract.schema.local.numByteSlice,
	//       localNumUint: DummyContract.schema.local.numUint,
	//       globalNumByteSlice: DummyContract.schema.global.numByteSlice,
	//       globalNumUint: DummyContract.schema.global.numUint,
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum

	// tests/contracts/general.algo.ts:173
	// onCompletion: OnCompletion.NoOp
	int 0 // NoOp
	itxn_field OnCompletion

	// tests/contracts/general.algo.ts:174
	// approvalProgram: DummyContract.approvalProgram()
	pushbytes 0x0a31181481060b3119088d0c000000000000000000000000000400000000000000000000008101438004b8447b36361a008e01fff000
	itxn_field ApprovalProgram

	// tests/contracts/general.algo.ts:175
	// clearStateProgram: DummyContract.clearProgram()
	pushbytes 0x0a
	itxn_field ClearStateProgram

	// tests/contracts/general.algo.ts:176
	// localNumByteSlice: DummyContract.schema.local.numByteSlice
	int 0
	itxn_field LocalNumByteSlice

	// tests/contracts/general.algo.ts:177
	// localNumUint: DummyContract.schema.local.numUint
	int 0
	itxn_field LocalNumUint

	// tests/contracts/general.algo.ts:178
	// globalNumByteSlice: DummyContract.schema.global.numByteSlice
	int 0
	itxn_field GlobalNumByteSlice

	// tests/contracts/general.algo.ts:179
	// globalNumUint: DummyContract.schema.global.numUint
	int 0
	itxn_field GlobalNumUint

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// numberToString()void
*abi_route_numberToString:
	// execute numberToString()void
	callsub numberToString
	int 1
	return

// numberToString(): void
numberToString:
	proto 0 0

	// tests/contracts/general.algo.ts:186
	// assert(n.toString() === s)
	int 1
	callsub *itoa
	pushbytes "1"
	==
	assert
	retsub

// methodOnParens()void
*abi_route_methodOnParens:
	// execute methodOnParens()void
	callsub methodOnParens
	int 1
	return

// methodOnParens(): void
methodOnParens:
	proto 0 0

	// tests/contracts/general.algo.ts:190
	// assert((1 + 2).toString() === '3')
	pushint 3
	callsub *itoa
	pushbytes 0x33 // "3"
	==
	assert
	retsub

// stringSubstring()void
*abi_route_stringSubstring:
	// execute stringSubstring()void
	callsub stringSubstring
	int 1
	return

// stringSubstring(): void
stringSubstring:
	proto 0 0

	// tests/contracts/general.algo.ts:195
	// assert(s.substring(1, 3) === 'bc')
	pushbytes "abcdef"
	substring 1 3
	pushbytes 0x6263 // "bc"
	==
	assert
	retsub

// idProperty()void
*abi_route_idProperty:
	// execute idProperty()void
	callsub idProperty
	int 1
	return

// idProperty(): void
idProperty:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// tests/contracts/general.algo.ts:199
	// app = AppID.zeroIndex
	int 0
	frame_bury 0 // app: uint64

	// tests/contracts/general.algo.ts:200
	// assert(AppID.fromUint64(app.id) === app)
	int 0 // app: uint64
	dup
	==
	assert

	// tests/contracts/general.algo.ts:202
	// asa = AssetID.zeroIndex
	int 0
	frame_bury 1 // asa: uint64

	// tests/contracts/general.algo.ts:203
	// assert(AssetID.fromUint64(asa.id) === asa)
	int 0 // asa: uint64
	dup
	==
	assert
	retsub

// scratchSlot()void
*abi_route_scratchSlot:
	// execute scratchSlot()void
	callsub scratchSlot
	int 1
	return

// scratchSlot(): void
scratchSlot:
	proto 0 0

	// tests/contracts/general.algo.ts:207
	// this.scratch.value = 1337
	int 1337
	store 0

	// tests/contracts/general.algo.ts:208
	// assert(this.scratch.value === 1337)
	load 0
	int 1337
	==
	assert
	retsub

// ecdsa()void
*abi_route_ecdsa:
	// execute ecdsa()void
	callsub ecdsa
	int 1
	return

// ecdsa(): void
ecdsa:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 3

	// tests/contracts/general.algo.ts:212
	// ecdsaVerify('Secp256k1', '' as bytes32, '' as bytes32, '' as bytes32, '' as bytes32, '' as bytes32)
	byte 0x0000000000000000000000000000000000000000000000000000000000000000 // ""
	dupn 4
	ecdsa_verify Secp256k1

	// tests/contracts/general.algo.ts:213
	// d = ecdsaPkDecompress('Secp256k1', '' as bytes<33>)
	pushbytes 0x000000000000000000000000000000000000000000000000000000000000000000 // ""
	ecdsa_pk_decompress Secp256k1
	frame_bury 0 // d y component: byte[]
	frame_bury 1 // d x component: byte[]

	// tests/contracts/general.algo.ts:214
	// log(d.y)
	frame_dig 0 // d y component: byte[]
	log

	// tests/contracts/general.algo.ts:215
	// log(d.x)
	frame_dig 1 // d x component: byte[]
	log

	// tests/contracts/general.algo.ts:217
	// r = ecdsaPkRecover('Secp256k1', '' as bytes32, 1, '' as bytes32, '' as bytes32)
	byte 0x0000000000000000000000000000000000000000000000000000000000000000 // ""
	int 1
	byte 0x0000000000000000000000000000000000000000000000000000000000000000 // ""
	dup
	ecdsa_pk_recover Secp256k1
	frame_bury 2 // r y component: byte[]
	frame_bury 3 // r x component: byte[]

	// tests/contracts/general.algo.ts:218
	// log(r.y)
	frame_dig 2 // r y component: byte[]
	log

	// tests/contracts/general.algo.ts:219
	// log(r.x)
	frame_dig 3 // r x component: byte[]
	log
	retsub

// verifyTxnTypes()void
*abi_route_verifyTxnTypes:
	// execute verifyTxnTypes()void
	callsub verifyTxnTypes
	int 1
	return

// verifyTxnTypes(): void
verifyTxnTypes:
	proto 0 0

	// tests/contracts/general.algo.ts:223
	// verifyPayTxn(this.txnGroup[0], {
	//       amount: { greaterThan: 0 },
	//     })
	// verify pay
	int 0
	gtxns TypeEnum
	int 1 // pay
	==

	// transaction verification failed: {"txn":"this.txnGroup[0]","field":"typeEnum","expected":"pay"}
	assert

	// verify amount
	int 0
	gtxns Amount
	int 0
	>

	// transaction verification failed: {"txn":"this.txnGroup[0]","field":"amount","condition":"greaterThan","expected":">0"}
	assert

	// tests/contracts/general.algo.ts:227
	// verifyAppCallTxn(this.txnGroup[0], {
	//       applicationID: AppID.fromUint64(0),
	//       applicationArgs: {
	//         0: 'foo',
	//         1: {
	//           includedIn: ['bar', 'baz'],
	//         },
	//       },
	//     })
	// verify appl
	int 0
	gtxns TypeEnum
	int 6 // appl
	==

	// transaction verification failed: {"txn":"this.txnGroup[0]","field":"typeEnum","expected":"appl"}
	assert

	// verify applicationID
	int 0
	gtxns ApplicationID
	int 0
	==

	// transaction verification failed: {"txn":"this.txnGroup[0]","field":"applicationID","expected":"AppID.fromUint64(0)"}
	assert

	// verify applicationArgs
	// verify applicationArgs 0
	int 0
	gtxns ApplicationArgs 0
	byte 0x666f6f // "foo"
	==

	// transaction verification failed: {"txn":"this.txnGroup[0]","field":"applicationArgs","index":"0","expected":"'foo'"}
	assert

	// verify applicationArgs 1
	int 0
	gtxns ApplicationArgs 1
	byte 0x626172 // "bar"
	==
	int 0
	gtxns ApplicationArgs 1
	pushbytes 0x62617a // "baz"
	==
	||

	// transaction verification failed: {"txn":{"txnText":"this.txnGroup[0]"},"field":"applicationArgs 1","condition":"includedIn","expected":"['bar', 'baz']"}
	assert

	// tests/contracts/general.algo.ts:237
	// verifyAssetTransferTxn(this.txnGroup[0], {
	//       assetReceiver: this.app.address,
	//     })
	// verify axfer
	int 0
	gtxns TypeEnum
	int 4 // axfer
	==

	// transaction verification failed: {"txn":"this.txnGroup[0]","field":"typeEnum","expected":"axfer"}
	assert

	// verify assetReceiver
	int 0
	gtxns AssetReceiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"this.txnGroup[0]","field":"assetReceiver","expected":"this.app.address"}
	assert

	// tests/contracts/general.algo.ts:241
	// verifyAssetConfigTxn(this.txnGroup[0], {
	//       configAsset: AssetID.fromUint64(0),
	//     })
	// verify acfg
	int 0
	gtxns TypeEnum
	pushint 3 // acfg
	==

	// transaction verification failed: {"txn":"this.txnGroup[0]","field":"typeEnum","expected":"acfg"}
	assert

	// verify configAsset
	int 0
	gtxns ConfigAsset
	int 0
	==

	// transaction verification failed: {"txn":"this.txnGroup[0]","field":"configAsset","expected":"AssetID.fromUint64(0)"}
	assert

	// tests/contracts/general.algo.ts:245
	// verifyKeyRegTxn(this.txnGroup[0], {
	//       voteFirst: 1337,
	//     })
	// verify keyreg
	int 0
	gtxns TypeEnum
	int 2 // keyreg
	==

	// transaction verification failed: {"txn":"this.txnGroup[0]","field":"typeEnum","expected":"keyreg"}
	assert

	// verify voteFirst
	int 0
	gtxns VoteFirst
	int 1337
	==

	// transaction verification failed: {"txn":"this.txnGroup[0]","field":"voteFirst","expected":"1337"}
	assert
	retsub

// stringPlusEquals()void
*abi_route_stringPlusEquals:
	// execute stringPlusEquals()void
	callsub stringPlusEquals
	int 1
	return

// stringPlusEquals(): void
stringPlusEquals:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/general.algo.ts:251
	// s = 'foo'
	byte 0x666f6f // "foo"
	frame_bury 0 // s: byte[]

	// tests/contracts/general.algo.ts:252
	// s += 'bar'
	frame_dig 0 // s: byte[]
	byte 0x626172 // "bar"
	concat
	frame_bury 0 // s: byte[]

	// tests/contracts/general.algo.ts:253
	// assert(s === 'foobar')
	frame_dig 0 // s: byte[]
	pushbytes 0x666f6f626172 // "foobar"
	==
	assert
	retsub

// importedProgram()byte[]
*abi_route_importedProgram:
	// The ABI return prefix
	byte 0x151f7c75

	// execute importedProgram()byte[]
	callsub importedProgram
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// importedProgram(): bytes
importedProgram:
	proto 0 1

	// tests/contracts/general.algo.ts:257
	// return IfTest.approvalProgram();
	pushbytes 0x0a20020100260904151f7c7504656c736502696609656c7365206966203109656c7365206966203207656c736520696603656e6403666f6f0031181481060b3119088d0c041900000000000000000000040b00000000000000000000008004151f7c75361a0149158101124481005388000d4915165706024c5050b08101438a01018bff41000580026966898003656e64898004151f7c75361a0149158101124481005388000d4915165706024c5050b08101438a01018bff41000880026966894200078004656c736589898004151f7c75361a02491581011244810053361a0149158101124481005388000d4915165706024c5050b08101438a02018bff410008800269668942000f8bfe41000a8007656c7365206966898003656e64898004151f7c75361a02491581011244810053361a0149158101124481005388000d4915165706024c5050b08101438a02018bff41000880026966894200198bfe41000d8007656c7365206966894200078004656c736589898004151f7c75361a03491581011244810053361a02491581011244810053361a0149158101124481005388000d4915165706024c5050b08101438a03018bff41000880026966894200258bfe41000f8009656c73652069662031894200118bfd41000c8009656c73652069662032898003656e64898004151f7c75361a03491581011244810053361a02491581011244810053361a0149158101124481005388000d4915165706024c5050b08101438a03018bff410008800269668942002f8bfe41000f8009656c736520696620318942001b8bfd41000f8009656c73652069662032894200078004656c736589898004151f7c75361a02491581011244810053361a0149158101124481005388000d4915165706024c5050b08101438a02018bff4100198bfe41000c80096e65737465642069668980026966894200078004656c736589898004151f7c75361a0149158101124481005388000d4915165706024c5050b08101438a01018bff41000880026966894200078004656c736589898004151f7c75361a02491581011244810053361a014915810112448100538800061650b08101438a02018bff410005810142000c8bfe41000581024200028103898004151f7c75361a015702008800061650b08101438a01018bff8000a94100038101898102898004151f7c75361a015702008800061650b08101438a01018bff8000a94100058101420002810289361a01491581021244178800038101438a01008bff8000a94100068003666f6fb089361a0249158102124417361a01491581021244178800038101438a02008bff8bfe0e4100068003666f6fb089361a02491581201244361a014915812012448800038101438a02008bff8bfea64100068003666f6fb0898004151f7c75361a02491581011244810053361a0149158101124481005388000d4915165706024c5050b08101438a02018bff4100198bfe41000d80076120616e64206289420004800161894200168bfe4100078001628942000a80076e65697468657289898101438004b8447b36361a008e01fff0008004436ec1c280041c7a0d5e80045e0fb6cf80045e1c6c50800458d0ba9280045d2f4f028004845729d980048fe76ca880041a3c7878800474bcc86880044212f905800495ddaebf80043147b866800442897f618004534be2b7361a008e0ffb6bfba0fbdafc2dfc85fcfafd74fdcbfe05fe46fe6cfe94feb6fee2ff0c00
	retsub

// callPrivateDefinedLater()void
*abi_route_callPrivateDefinedLater:
	// execute callPrivateDefinedLater()void
	callsub callPrivateDefinedLater
	int 1
	return

// callPrivateDefinedLater(): void
callPrivateDefinedLater:
	proto 0 0

	// tests/contracts/general.algo.ts:261
	// log(this.privateMethod('hello'))
	pushbytes 0x68656c6c6f // "hello"
	callsub privateMethod
	log
	retsub

// privateMethod(msg: string): string
privateMethod:
	proto 1 1

	// tests/contracts/general.algo.ts:265
	// return msg;
	frame_dig -1 // msg: string
	retsub

// interalPublicMethod(uint64,uint64)uint64
*abi_route_interalPublicMethod:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute interalPublicMethod(uint64,uint64)uint64
	callsub interalPublicMethod
	itob
	concat
	log
	int 1
	return

// interalPublicMethod(a: uint64, b: uint64): uint64
interalPublicMethod:
	proto 2 1

	// tests/contracts/general.algo.ts:269
	// return a + b;
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	+
	retsub

// callInternalPublicMethod()void
*abi_route_callInternalPublicMethod:
	// execute callInternalPublicMethod()void
	callsub callInternalPublicMethod
	int 1
	return

// callInternalPublicMethod(): void
callInternalPublicMethod:
	proto 0 0

	// tests/contracts/general.algo.ts:273
	// assert(this.interalPublicMethod(1, 2) === 3)
	int 2
	int 1
	callsub interalPublicMethod
	pushint 3
	==
	assert
	retsub

// appLoadScratch()void
*abi_route_appLoadScratch:
	// execute appLoadScratch()void
	callsub appLoadScratch
	int 1
	return

// appLoadScratch(): void
appLoadScratch:
	proto 0 0

	// tests/contracts/general.algo.ts:277
	// log(this.txnGroup[1].loadScratch(2) as bytes)
	gload 1 2
	log
	retsub

// uintNWithUnderscore()uint256
*abi_route_uintNWithUnderscore:
	// The ABI return prefix
	byte 0x151f7c75

	// execute uintNWithUnderscore()uint256
	callsub uintNWithUnderscore
	dup
	bitlen
	pushint 256
	<=

	// uintNWithUnderscore return value overflowed 256 bits
	assert
	pushbytes 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	pushint 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// uintNWithUnderscore(): uint256
uintNWithUnderscore:
	proto 0 1

	// tests/contracts/general.algo.ts:281
	// return <uint256>123_456;
	pushbytes 0x000000000000000000000000000000000000000000000000000000000001e240
	retsub

// opUp()void
*abi_route_opUp:
	// execute opUp()void
	callsub opUp
	int 1
	return

// opUp(): void
opUp:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/general.algo.ts:285
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	int 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

	// tests/contracts/general.algo.ts:286
	// for (let i = 1; i < 75; i += 1)
	int 1
	frame_bury 0 // i: uint64

*for_0:
	// tests/contracts/general.algo.ts:286
	// i < 75
	frame_dig 0 // i: uint64
	pushint 75
	<
	bz *for_0_end

	// tests/contracts/general.algo.ts:287
	// assert(i)
	frame_dig 0 // i: uint64
	assert

*for_0_continue:
	// tests/contracts/general.algo.ts:286
	// i += 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64
	b *for_0

*for_0_end:
	retsub

// returnValueOnAssignment()string
*abi_route_returnValueOnAssignment:
	// The ABI return prefix
	byte 0x151f7c75

	// execute returnValueOnAssignment()string
	callsub returnValueOnAssignment
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// returnValueOnAssignment(): string
returnValueOnAssignment:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/general.algo.ts:292
	// message = 'hi'
	pushbytes 0x6869 // "hi"
	frame_bury 0 // message: byte[]

	// *if0_condition
	// tests/contracts/general.algo.ts:294
	// this.txn.sender === this.app.address
	txn Sender
	global CurrentApplicationAddress
	==
	bz *if0_end

	// *if0_consequent
	// tests/contracts/general.algo.ts:295
	// message = 'in block'
	pushbytes 0x696e20626c6f636b // "in block"
	frame_bury 0 // message: byte[]

*if0_end:
	// tests/contracts/general.algo.ts:298
	// return (message = 'bye');
	byte 0x627965 // "bye"
	dup
	frame_bury 0 // message: byte[]

	// set the subroutine return value
	frame_bury 0
	retsub

// returnArrayValueOnAssignment()uint64
*abi_route_returnArrayValueOnAssignment:
	// The ABI return prefix
	byte 0x151f7c75

	// execute returnArrayValueOnAssignment()uint64
	callsub returnArrayValueOnAssignment
	itob
	concat
	log
	int 1
	return

// returnArrayValueOnAssignment(): uint64
returnArrayValueOnAssignment:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/general.algo.ts:302
	// a: StaticArray<uint64, 3> = [1, 2, 3]
	byte 0x000000000000000100000000000000020000000000000003
	frame_bury 0 // a: StaticArray<uint64, 3>

	// tests/contracts/general.algo.ts:304
	// return (a[0] = 4);
	frame_dig 0 // a: StaticArray<uint64, 3>
	int 0
	int 4
	dup
	store 245 // assignment value
	itob
	replace3
	frame_bury 0 // a: StaticArray<uint64, 3>
	load 245 // assignment value

	// set the subroutine return value
	frame_bury 0
	retsub

// returnStorageValueOnAssignment()uint64
*abi_route_returnStorageValueOnAssignment:
	// The ABI return prefix
	byte 0x151f7c75

	// execute returnStorageValueOnAssignment()uint64
	callsub returnStorageValueOnAssignment
	itob
	concat
	log
	int 1
	return

// returnStorageValueOnAssignment(): uint64
returnStorageValueOnAssignment:
	proto 0 1

	// tests/contracts/general.algo.ts:308
	// this.gKey.value = 1
	byte 0x674b6579 // "gKey"
	int 1
	app_global_put

	// tests/contracts/general.algo.ts:310
	// return (this.gKey.value = 2);
	byte 0x674b6579 // "gKey"
	int 2
	dup
	store 245 // assignment value
	app_global_put
	load 245 // assignment value
	retsub

// returnOperatorAssignmentValue()uint64
*abi_route_returnOperatorAssignmentValue:
	// The ABI return prefix
	byte 0x151f7c75

	// execute returnOperatorAssignmentValue()uint64
	callsub returnOperatorAssignmentValue
	itob
	concat
	log
	int 1
	return

// returnOperatorAssignmentValue(): uint64
returnOperatorAssignmentValue:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/general.algo.ts:314
	// a = 1
	int 1
	frame_bury 0 // a: uint64

	// tests/contracts/general.algo.ts:316
	// return (a += 2);
	frame_dig 0 // a: uint64
	int 2
	+
	dup
	store 245 // assignment value
	frame_bury 0 // a: uint64
	load 245 // assignment value

	// set the subroutine return value
	frame_bury 0
	retsub

// returnArrayValueOnOperatorAssignment()uint64
*abi_route_returnArrayValueOnOperatorAssignment:
	// The ABI return prefix
	byte 0x151f7c75

	// execute returnArrayValueOnOperatorAssignment()uint64
	callsub returnArrayValueOnOperatorAssignment
	itob
	concat
	log
	int 1
	return

// returnArrayValueOnOperatorAssignment(): uint64
returnArrayValueOnOperatorAssignment:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/general.algo.ts:320
	// a: StaticArray<uint64, 3> = [1, 2, 3]
	byte 0x000000000000000100000000000000020000000000000003
	frame_bury 0 // a: StaticArray<uint64, 3>

	// tests/contracts/general.algo.ts:322
	// return (a[0] += 4);
	frame_dig 0 // a: StaticArray<uint64, 3>
	int 0
	frame_dig 0 // a: StaticArray<uint64, 3>
	extract 0 8
	btoi
	int 4
	+
	dup
	store 245 // assignment value
	itob
	replace3
	frame_bury 0 // a: StaticArray<uint64, 3>
	load 245 // assignment value

	// set the subroutine return value
	frame_bury 0
	retsub

// returnArrayInStorageValueOnOperatorAssignment()uint64
*abi_route_returnArrayInStorageValueOnOperatorAssignment:
	// The ABI return prefix
	byte 0x151f7c75

	// execute returnArrayInStorageValueOnOperatorAssignment()uint64
	callsub returnArrayInStorageValueOnOperatorAssignment
	itob
	concat
	log
	int 1
	return

// returnArrayInStorageValueOnOperatorAssignment(): uint64
returnArrayInStorageValueOnOperatorAssignment:
	proto 0 1

	// tests/contracts/general.algo.ts:326
	// this.storageArray.value = [1, 2, 3]
	byte 0x73746f726167654172726179 // "storageArray"
	byte 0x000000000000000100000000000000020000000000000003
	app_global_put

	// tests/contracts/general.algo.ts:328
	// return (this.storageArray.value[0] += 4);
	byte 0x73746f726167654172726179 // "storageArray"
	app_global_get
	int 0
	byte 0x73746f726167654172726179 // "storageArray"
	app_global_get
	extract 0 8
	btoi
	int 4
	+
	dup
	store 245 // assignment value
	itob
	replace3
	byte 0x73746f726167654172726179 // "storageArray"
	swap
	app_global_put
	load 245 // assignment value
	retsub

// consts()void
*abi_route_consts:
	// execute consts()void
	callsub consts
	int 1
	return

// consts(): void
consts:
	proto 0 0

	// tests/contracts/general.algo.ts:332
	// assert(STRING_CONST === 'foo')
	pushbytes "foo"
	byte 0x666f6f // "foo"
	==
	assert

	// tests/contracts/general.algo.ts:333
	// assert(NUM_CONST === 123)
	int 123
	dup
	==
	assert

	// tests/contracts/general.algo.ts:334
	// assert(NESTED_CONST === 123)
	int 123
	dup
	==
	assert
	retsub

// assertWithMessage()void
*abi_route_assertWithMessage:
	// execute assertWithMessage()void
	callsub assertWithMessage
	int 1
	return

// assertWithMessage(): void
assertWithMessage:
	proto 0 0

	// tests/contracts/general.algo.ts:338
	// assert(false, 'this is false')
	int 0

	// this is false
	assert
	retsub

// opcodeAliases()void
*abi_route_opcodeAliases:
	// execute opcodeAliases()void
	callsub opcodeAliases
	int 1
	return

// opcodeAliases(): void
opcodeAliases:
	proto 0 0

	// tests/contracts/general.algo.ts:342
	// extractUint16(bzero(64), 0)
	byte 0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000
	int 0
	extract_uint16

	// tests/contracts/general.algo.ts:343
	// extractUint32(bzero(64), 0)
	byte 0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000
	int 0
	extract_uint32

	// tests/contracts/general.algo.ts:344
	// extractUint64(bzero(64), 0)
	byte 0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000
	int 0
	extract_uint64

	// tests/contracts/general.algo.ts:345
	// ed25519VerifyBare(bzero(64), bzero(64), bzero(32))
	byte 0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000
	dup
	byte 0x0000000000000000000000000000000000000000000000000000000000000000
	ed25519verify_bare

	// tests/contracts/general.algo.ts:346
	// ed25519Verify(bzero(64), bzero(64), bzero(32))
	byte 0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000
	dup
	byte 0x0000000000000000000000000000000000000000000000000000000000000000
	ed25519verify
	retsub

// vrfVerifyOp()void
*abi_route_vrfVerifyOp:
	// execute vrfVerifyOp()void
	callsub vrfVerifyOp
	int 1
	return

// vrfVerifyOp(): void
vrfVerifyOp:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// tests/contracts/general.algo.ts:350
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	int 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

	// tests/contracts/general.algo.ts:351
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	int 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

	// tests/contracts/general.algo.ts:352
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	int 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

	// tests/contracts/general.algo.ts:353
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	int 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

	// tests/contracts/general.algo.ts:354
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	int 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

	// tests/contracts/general.algo.ts:355
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	int 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

	// tests/contracts/general.algo.ts:356
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	int 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

	// tests/contracts/general.algo.ts:357
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	int 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

	// tests/contracts/general.algo.ts:358
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	int 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

	// tests/contracts/general.algo.ts:360
	// r = vrfVefiry('VrfAlgorand', bzero(32) as bytes, bzero(80), bzero(32))
	byte 0x0000000000000000000000000000000000000000000000000000000000000000
	pushbytes 0x0000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000
	byte 0x0000000000000000000000000000000000000000000000000000000000000000
	vrf_verify VrfAlgorand
	frame_bury 0 // r verified: bool
	frame_bury 1 // r output: byte[]

	// tests/contracts/general.algo.ts:361
	// assert(!r.verified)
	frame_dig 0 // r verified: bool
	!
	assert

	// tests/contracts/general.algo.ts:362
	// log(r.output)
	frame_dig 1 // r output: byte[]
	log
	retsub

// ecMath()void
*abi_route_ecMath:
	// execute ecMath()void
	callsub ecMath
	int 1
	return

// ecMath(): void
ecMath:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/general.algo.ts:366
	// ecScalarMul('BN254g1', '', '')
	byte 0x // ""
	dup
	ec_scalar_mul BN254g1

	// tests/contracts/general.algo.ts:367
	// ecPairingCheck('BN254g1', '', '')
	byte 0x // ""
	dup
	ec_pairing_check BN254g1

	// tests/contracts/general.algo.ts:368
	// scalars: bytes32[] = [bzero(32), bzero(32)]
	byte 0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000
	frame_bury 0 // scalars: bytes32[]

	// tests/contracts/general.algo.ts:369
	// ecMultiScalarMul('BN254g1', '', scalars)
	byte 0x // ""
	byte 0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 // scalars: bytes32[]
	ec_multi_scalar_mul BN254g1

	// tests/contracts/general.algo.ts:370
	// ecSubgroupCheck('BN254g1', '')
	byte 0x // ""
	ec_subgroup_check BN254g1

	// tests/contracts/general.algo.ts:371
	// ecMapTo('BN254g1', '')
	byte 0x // ""
	ec_map_to BN254g1

	// tests/contracts/general.algo.ts:372
	// ecAdd('BN254g1', '', '')
	byte 0x // ""
	dup
	ec_add BN254g1
	retsub

// gitxn()void
*abi_route_gitxn:
	// execute gitxn()void
	callsub gitxn
	int 1
	return

// gitxn(): void
gitxn:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/general.algo.ts:376
	// log(this.lastInnerGroup[0].sender)
	gitxn 0 Sender
	log

	// tests/contracts/general.algo.ts:378
	// anotherTxn = this.lastInnerGroup[1]
	int 1
	frame_bury 0 // anotherTxn: gitxn

	// tests/contracts/general.algo.ts:380
	// log(anotherTxn.sender)
	gitxn 1 Sender
	log
	retsub

// getSetBytes()void
*abi_route_getSetBytes:
	// execute getSetBytes()void
	callsub getSetBytes
	int 1
	return

// getSetBytes(): void
getSetBytes:
	proto 0 0

	// tests/contracts/general.algo.ts:384
	// log(setbit('foo', 0, true))
	byte 0x666f6f // "foo"
	int 0
	int 1
	setbit
	log

	// tests/contracts/general.algo.ts:385
	// getbit('foo', 0)
	byte 0x666f6f // "foo"
	int 0
	getbit

	// tests/contracts/general.algo.ts:386
	// getbyte('foo', 0)
	byte 0x666f6f // "foo"
	int 0
	getbyte

	// tests/contracts/general.algo.ts:387
	// setbyte('foo', 0, 1)
	byte 0x666f6f // "foo"
	int 0
	int 1
	setbyte
	retsub

// getSetUint64()void
*abi_route_getSetUint64:
	// execute getSetUint64()void
	callsub getSetUint64
	int 1
	return

// getSetUint64(): void
getSetUint64:
	proto 0 0

	// tests/contracts/general.algo.ts:391
	// assert(setbit(123, 0, true))
	int 123
	int 0
	int 1
	setbit
	assert

	// tests/contracts/general.algo.ts:392
	// getbit(123, 0)
	int 123
	int 0
	getbit
	retsub

// blockOp()void
*abi_route_blockOp:
	// execute blockOp()void
	callsub blockOp
	int 1
	return

// blockOp(): void
blockOp:
	proto 0 0

	// tests/contracts/general.algo.ts:396
	// log(blocks[globals.round - 1].seed)
	global Round
	int 1
	-
	block BlkSeed
	log

	// tests/contracts/general.algo.ts:397
	// assert(blocks[globals.round - 1].timestamp)
	global Round
	int 1
	-
	block BlkTimestamp
	assert
	retsub

// b64()void
*abi_route_b64:
	// execute b64()void
	callsub b64
	int 1
	return

// b64(): void
b64:
	proto 0 0

	// tests/contracts/general.algo.ts:401
	// log(base64Decode('StdEncoding', ''))
	byte 0x // ""
	base64_decode StdEncoding
	log
	retsub

// json()void
*abi_route_json:
	// execute json()void
	callsub json
	int 1
	return

// json(): void
json:
	proto 0 0

	// tests/contracts/general.algo.ts:405
	// log(jsonRef('JSONObject', '', ''))
	byte 0x // ""
	dup
	json_ref JSONObject
	log

	// tests/contracts/general.algo.ts:406
	// log(jsonRef('JSONString', '', ''))
	byte 0x // ""
	dup
	json_ref JSONString
	log

	// tests/contracts/general.algo.ts:407
	// assert(jsonRef('JSONUint64', '', ''))
	byte 0x // ""
	dup
	json_ref JSONUint64
	assert
	retsub

// bitlenOp()void
*abi_route_bitlenOp:
	// execute bitlenOp()void
	callsub bitlenOp
	int 1
	return

// bitlenOp(): void
bitlenOp:
	proto 0 0

	// tests/contracts/general.algo.ts:411
	// bitlen(123)
	int 123
	bitlen

	// tests/contracts/general.algo.ts:412
	// bitlen('foo')
	byte 0x666f6f // "foo"
	bitlen
	retsub

// computedConst()void
*abi_route_computedConst:
	// execute computedConst()void
	callsub computedConst
	int 1
	return

// computedConst(): void
computedConst:
	proto 0 0

	// tests/contracts/general.algo.ts:416
	// assert(COMPUTED_CONST)
	pushint 246
	assert
	retsub

// multiComputedConst()void
*abi_route_multiComputedConst:
	// execute multiComputedConst()void
	callsub multiComputedConst
	int 1
	return

// multiComputedConst(): void
multiComputedConst:
	proto 0 0

	// tests/contracts/general.algo.ts:420
	// assert(MUTLI_COMPUTED_CONST)
	pushint 30381
	assert
	retsub

// readSchema()void
*abi_route_readSchema:
	// execute readSchema()void
	callsub readSchema
	int 1
	return

// readSchema(): void
readSchema:
	proto 0 0

	// tests/contracts/general.algo.ts:424
	// assert(SchemaContract.schema.global.numUint === 1)
	int 1
	dup
	==
	assert

	// tests/contracts/general.algo.ts:425
	// assert(SchemaContract.schema.global.numByteSlice === 2)
	int 2
	dup
	==
	assert

	// tests/contracts/general.algo.ts:426
	// assert(SchemaContract.schema.local.numUint === 3)
	pushint 3
	pushint 3
	==
	assert

	// tests/contracts/general.algo.ts:427
	// assert(SchemaContract.schema.local.numByteSlice === 4)
	int 4
	dup
	==
	assert
	retsub

// comparisonOr()bool
*abi_route_comparisonOr:
	// The ABI return prefix
	byte 0x151f7c75

	// execute comparisonOr()bool
	callsub comparisonOr
	pushbytes 0x00
	int 0
	uncover 2
	setbit
	concat
	log
	int 1
	return

// comparisonOr(): boolean
comparisonOr:
	proto 0 1

	// tests/contracts/general.algo.ts:431
	// return this.txn.sender === globals.zeroAddress || this.txn.sender === globals.zeroAddress;
	txn Sender
	global ZeroAddress
	==
	dup
	bnz *skip_or0
	txn Sender
	global ZeroAddress
	==
	||

*skip_or0:
	retsub

// txnArgsMethod(pay)void
*abi_route_txnArgsMethod:
	// _pay1: pay
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// argument 0 (_pay1) for txnArgsMethod must be a pay transaction
	assert

	// execute txnArgsMethod(pay)void
	callsub txnArgsMethod
	int 1
	return

// txnArgsMethod(_pay1: PayTxn): void
txnArgsMethod:
	proto 1 0
	retsub

// callTxnArgsMethod()void
*abi_route_callTxnArgsMethod:
	// execute callTxnArgsMethod()void
	callsub callTxnArgsMethod
	int 1
	return

// callTxnArgsMethod(): void
callTxnArgsMethod:
	proto 0 0

	// tests/contracts/general.algo.ts:438
	// sendMethodCall<typeof GeneralTest.prototype.txnArgsMethod>({
	//       methodArgs: [{ receiver: this.app.address, amount: 0 }],
	//     })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// tests/contracts/general.algo.ts:439
	// receiver: this.app.address
	global CurrentApplicationAddress
	itxn_field Receiver

	// tests/contracts/general.algo.ts:439
	// amount: 0
	int 0
	itxn_field Amount

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee
	itxn_next
	int 6 // appl
	itxn_field TypeEnum
	byte 0x2c636eeb // method "txnArgsMethod(pay)void"
	itxn_field ApplicationArgs

	// tests/contracts/general.algo.ts:439
	// methodArgs: [{ receiver: this.app.address, amount: 0 }]
	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// staticValueLen(uint256)void
*abi_route_staticValueLen:
	// x: uint256
	txna ApplicationArgs 1
	dup
	len
	pushint 32
	==

	// argument 0 (x) for staticValueLen must be a uint256
	assert

	// execute staticValueLen(uint256)void
	callsub staticValueLen
	int 1
	return

// staticValueLen(x: uint256): void
staticValueLen:
	proto 1 0

	// tests/contracts/general.algo.ts:444
	// assert(len(x))
	pushint 32
	assert
	retsub

// staticTypeLen()void
*abi_route_staticTypeLen:
	// execute staticTypeLen()void
	callsub staticTypeLen
	int 1
	return

// staticTypeLen(): void
staticTypeLen:
	proto 0 0

	// tests/contracts/general.algo.ts:448
	// assert(len<uint256>())
	pushint 32
	assert
	retsub

// dynamicScratchSlot()void
*abi_route_dynamicScratchSlot:
	// execute dynamicScratchSlot()void
	callsub dynamicScratchSlot
	int 1
	return

// dynamicScratchSlot(): void
dynamicScratchSlot:
	proto 0 0

	// tests/contracts/general.algo.ts:452
	// this.dynamicScratch(1).value = 1337
	int 1
	int 1337
	stores

	// tests/contracts/general.algo.ts:453
	// assert(this.dynamicScratch(1).value === 1337)
	int 1
	loads
	int 1337
	==
	assert
	retsub

// incrementScratchSlot()void
*abi_route_incrementScratchSlot:
	// execute incrementScratchSlot()void
	callsub incrementScratchSlot
	int 1
	return

// incrementScratchSlot(): void
incrementScratchSlot:
	proto 0 0

	// tests/contracts/general.algo.ts:457
	// this.scratch.value = 1337
	int 1337
	store 0

	// tests/contracts/general.algo.ts:458
	// this.scratch.value += 1
	load 0
	int 1
	+
	store 0

	// tests/contracts/general.algo.ts:459
	// assert(this.scratch.value === 1338)
	load 0
	pushint 1338
	==
	assert
	retsub

// incrementDynamicScratchSlot()void
*abi_route_incrementDynamicScratchSlot:
	// execute incrementDynamicScratchSlot()void
	callsub incrementDynamicScratchSlot
	int 1
	return

// incrementDynamicScratchSlot(): void
incrementDynamicScratchSlot:
	proto 0 0

	// tests/contracts/general.algo.ts:463
	// this.dynamicScratch(2).value = 1337
	int 2
	int 1337
	stores

	// tests/contracts/general.algo.ts:464
	// this.dynamicScratch(2).value += 1
	int 2
	loads
	int 1
	+
	int 2
	swap
	stores

	// tests/contracts/general.algo.ts:465
	// assert(this.dynamicScratch(2).value === 1338)
	int 2
	loads
	pushint 1338
	==
	assert
	retsub

// fromAddress()void
*abi_route_fromAddress:
	// execute fromAddress()void
	callsub fromAddress
	int 1
	return

// fromAddress(): void
fromAddress:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/general.algo.ts:469
	// a = Address.fromAddress('AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAY5HFKQ')
	byte 0x0000000000000000000000000000000000000000000000000000000000000000 // addr "AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAY5HFKQ"
	frame_bury 0 // a: address

	// tests/contracts/general.algo.ts:470
	// assert(a === Address.zeroAddress)
	frame_dig 0 // a: address
	global ZeroAddress
	==
	assert
	retsub

// earlyReturn(uint64)uint64
*abi_route_earlyReturn:
	// The ABI return prefix
	byte 0x151f7c75

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute earlyReturn(uint64)uint64
	callsub earlyReturn
	itob
	concat
	log
	int 1
	return

// earlyReturn(a: uint64): uint64
earlyReturn:
	proto 1 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// *if1_condition
	// tests/contracts/general.algo.ts:474
	// a === 1
	frame_dig -1 // a: uint64
	int 1
	==
	bz *if1_end

	// *if1_consequent
	// tests/contracts/general.algo.ts:475
	// return 2;
	int 2
	b *earlyReturn*return

*if1_end:
	// tests/contracts/general.algo.ts:477
	// b = a + 1
	frame_dig -1 // a: uint64
	int 1
	+
	frame_bury 0 // b: uint64

	// tests/contracts/general.algo.ts:478
	// return b;
	frame_dig 0 // b: uint64

*earlyReturn*return:
	// set the subroutine return value
	frame_bury 0
	retsub

// assetMethodArgs()void
*abi_route_assetMethodArgs:
	// execute assetMethodArgs()void
	callsub assetMethodArgs
	int 1
	return

// assetMethodArgs(): void
assetMethodArgs:
	proto 0 0

	// tests/contracts/general.algo.ts:482
	// sendMethodCall<[AssetReference], void>({
	//       name: 'foo',
	//       methodArgs: [AssetID.fromUint64(1)],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	pushbytes 0xa15316de // method "foo(asset)void"
	itxn_field ApplicationArgs

	// tests/contracts/general.algo.ts:484
	// methodArgs: [AssetID.fromUint64(1)]
	int 1
	itxn_field Assets
	pushbytes 0x0000000000000000
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// multipleProgramPages()void
*abi_route_multipleProgramPages:
	// execute multipleProgramPages()void
	callsub multipleProgramPages
	int 1
	return

// multipleProgramPages(): void
multipleProgramPages:
	proto 0 0

	// tests/contracts/general.algo.ts:493
	// sendAppCall({
	//       approvalProgram: [this.pageOne.value, this.pageTwo.value],
	//       clearStateProgram: [this.pageOne.value, this.pageTwo.value],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum

	// tests/contracts/general.algo.ts:494
	// approvalProgram: [this.pageOne.value, this.pageTwo.value]
	byte 0x706167654f6e65 // "pageOne"
	box_get

	// box value does not exist: this.pageOne.value
	assert
	itxn_field ApprovalProgramPages
	byte 0x7061676554776f // "pageTwo"
	box_get

	// box value does not exist: this.pageTwo.value
	assert
	itxn_field ApprovalProgramPages

	// tests/contracts/general.algo.ts:495
	// clearStateProgram: [this.pageOne.value, this.pageTwo.value]
	byte 0x706167654f6e65 // "pageOne"
	box_get

	// box value does not exist: this.pageOne.value
	assert
	itxn_field ClearStateProgramPages
	byte 0x7061676554776f // "pageTwo"
	box_get

	// box value does not exist: this.pageTwo.value
	assert
	itxn_field ClearStateProgramPages

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// assertComment()void
*abi_route_assertComment:
	// execute assertComment()void
	callsub assertComment
	int 1
	return

// assertComment(): void
assertComment:
	proto 0 0

	// tests/contracts/general.algo.ts:500
	// assert(false, 'this is false')
	int 0

	// this is false
	assert
	retsub

// throwErrorMessage()void
*abi_route_throwErrorMessage:
	// execute throwErrorMessage()void
	callsub throwErrorMessage
	int 1
	return

// throwErrorMessage(): void
throwErrorMessage:
	proto 0 0

	// this is an error
	err
	retsub

// orLiteralType(uint64,uint64)void
*abi_route_orLiteralType:
	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute orLiteralType(uint64,uint64)void
	callsub orLiteralType
	int 1
	return

// orLiteralType(a: uint64, b: uint64): void
orLiteralType:
	proto 2 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// tests/contracts/general.algo.ts:508
	// foo = a && b === 1 ? 2 : 0
	frame_dig -1 // a: uint64
	dup
	bz *skip_and0
	frame_dig -2 // b: uint64
	int 1
	==
	&&

*skip_and0:
	bz *ternary0_false
	int 2
	b *ternary0_end

*ternary0_false:
	int 0

*ternary0_end:
	frame_bury 0 // foo: uint64

	// tests/contracts/general.algo.ts:509
	// assert(foo)
	frame_dig 0 // foo: uint64
	assert

	// tests/contracts/general.algo.ts:511
	// bar = a && b === 0 ? '2' : '0'
	frame_dig -1 // a: uint64
	dup
	bz *skip_and1
	frame_dig -2 // b: uint64
	int 0
	==
	&&

*skip_and1:
	bz *ternary1_false
	pushbytes 0x32 // "2"
	b *ternary1_end

*ternary1_false:
	byte 0x30 // "0"

*ternary1_end:
	frame_bury 1 // bar: byte[]

	// tests/contracts/general.algo.ts:512
	// log(bar)
	frame_dig 1 // bar: byte[]
	log
	retsub

// nonAbi(): void
nonAbi:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/general.algo.ts:517
	// assert(this.txn.applicationArgs!.length)
	txn NumAppArgs
	assert

	// tests/contracts/general.algo.ts:519
	// for (let i = 0; i < this.txn.applicationArgs!.length; i += 1)
	int 0
	frame_bury 0 // i: uint64

*for_1:
	// tests/contracts/general.algo.ts:519
	// i < this.txn.applicationArgs!.length
	frame_dig 0 // i: uint64
	txn NumAppArgs
	<
	bz *for_1_end

	// tests/contracts/general.algo.ts:520
	// log(this.txn.applicationArgs![i])
	frame_dig 0 // i: uint64
	txnas ApplicationArgs
	log

*for_1_continue:
	// tests/contracts/general.algo.ts:519
	// i += 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64
	b *for_1

*for_1_end:
	retsub

// multilineFunctionCall()void
*abi_route_multilineFunctionCall:
	// execute multilineFunctionCall()void
	callsub multilineFunctionCall
	int 1
	return

// multilineFunctionCall(): void
multilineFunctionCall:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// tests/contracts/general.algo.ts:525
	// app = AppID.zeroIndex
	int 0
	frame_bury 0 // app: uint64

	// tests/contracts/general.algo.ts:526
	// addr = Address.zeroAddress
	global ZeroAddress
	frame_bury 1 // addr: address

	// tests/contracts/general.algo.ts:528
	// app.localState(
	//       addr,
	//       'key'
	//     )
	frame_dig 1 // addr: address
	int 0 // app: uint64
	pushbytes 0x6b6579 // "key"
	app_local_get_ex

	// local state value does not exist: app.localState( addr, 'key' )
	assert
	retsub

// a()uint64
*abi_route_a:
	// The ABI return prefix
	byte 0x151f7c75

	// execute a()uint64
	callsub a
	itob
	concat
	log
	int 1
	return

// a(): uint64
a:
	proto 0 1

	// tests/contracts/general.algo.ts:535
	// return 3;
	pushint 3
	retsub

// b()uint64
*abi_route_b:
	// The ABI return prefix
	byte 0x151f7c75

	// execute b()uint64
	callsub b
	itob
	concat
	log
	int 1
	return

// b(): uint64
b:
	proto 0 1

	// tests/contracts/general.algo.ts:539
	// return 5;
	int 5
	retsub

// unusedMethodValue()uint64
*abi_route_unusedMethodValue:
	// The ABI return prefix
	byte 0x151f7c75

	// execute unusedMethodValue()uint64
	callsub unusedMethodValue
	itob
	concat
	log
	int 1
	return

// unusedMethodValue(): uint64
unusedMethodValue:
	proto 0 1

	// tests/contracts/general.algo.ts:543
	// this.a()
	callsub a
	pop

	// tests/contracts/general.algo.ts:544
	// return this.b();
	callsub b
	retsub

// reassignedNonFirstVar()uint64
*abi_route_reassignedNonFirstVar:
	// The ABI return prefix
	byte 0x151f7c75

	// execute reassignedNonFirstVar()uint64
	callsub reassignedNonFirstVar
	itob
	concat
	log
	int 1
	return

// reassignedNonFirstVar(): uint64
reassignedNonFirstVar:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// tests/contracts/general.algo.ts:555
	// a = 1 as uint64
	int 1
	frame_bury 0 // a: uint64

	// tests/contracts/general.algo.ts:556
	// b = this.app.id
	txna Applications 0
	frame_bury 1 // b: uint64

	// *if2_condition
	// tests/contracts/general.algo.ts:557
	// a
	frame_dig 0 // a: uint64
	bz *if2_end

	// *if2_consequent
	// tests/contracts/general.algo.ts:558
	// b = 2
	int 2
	frame_bury 1 // b: uint64

*if2_end:
	// tests/contracts/general.algo.ts:561
	// return b;
	frame_dig 1 // b: uint64

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 1
	retsub

// fvLv()void
*abi_route_fvLv:
	// execute fvLv()void
	callsub fvLv
	int 1
	return

// fvLv(): void
fvLv:
	proto 0 0

	// tests/contracts/general.algo.ts:565
	// assert(this.txn.firstValid)
	txn FirstValid
	assert

	// tests/contracts/general.algo.ts:566
	// assert(this.txn.lastValid)
	txn LastValid
	assert
	retsub

*abi_route_createApplication:
	int 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x624264a3 // method "txnTypeEnum()void"
	pushbytes 0xb205edc9 // method "txnGroupLength()void"
	pushbytes 0xe6e97d5b // method "asserts(bool,bool)void"
	pushbytes 0xdd6fa7c8 // method "verifyTxnFromArg(pay)void"
	pushbytes 0x0ea644fb // method "verifyTxnFromTxnGroup()void"
	pushbytes 0xec0d9094 // method "verifyTxnCondition()void"
	pushbytes 0x68848d97 // method "verifyTxnIncludedIn()void"
	pushbytes 0x18bd23dc // method "verifyTxnNotIncludedIn()void"
	pushbytes 0x806bfb93 // method "submitPendingGroup()void"
	pushbytes 0x3be5f82e // method "methodWithTxnArgs()void"
	pushbytes 0x1295d683 // method "shift()void"
	pushbytes 0xb3b8c472 // method "fromBytes()void"
	pushbytes 0x53e0b6f0 // method "fromUint64()void"
	pushbytes 0x4b3eb877 // method "bzeroFunction()void"
	pushbytes 0xdac2e7a5 // method "events()void"
	pushbytes 0xa3db6704 // method "letOptimization(uint64[])uint64[]"
	pushbytes 0xae21c172 // method "staticContractProperties()void"
	pushbytes 0xdab4d1c4 // method "numberToString()void"
	pushbytes 0xa7b4ae9a // method "methodOnParens()void"
	pushbytes 0x6d4485ba // method "stringSubstring()void"
	pushbytes 0xef6262e9 // method "idProperty()void"
	pushbytes 0x8d2b668b // method "scratchSlot()void"
	pushbytes 0xe6c154fc // method "ecdsa()void"
	pushbytes 0xa9764197 // method "verifyTxnTypes()void"
	pushbytes 0x9dbbc42c // method "stringPlusEquals()void"
	pushbytes 0x4c0ddec1 // method "importedProgram()byte[]"
	pushbytes 0x30ecfb41 // method "callPrivateDefinedLater()void"
	pushbytes 0x14a49919 // method "interalPublicMethod(uint64,uint64)uint64"
	pushbytes 0xb71c179a // method "callInternalPublicMethod()void"
	pushbytes 0x98481093 // method "appLoadScratch()void"
	pushbytes 0xf572d1c1 // method "uintNWithUnderscore()uint256"
	pushbytes 0x854dede0 // method "opUp()void"
	pushbytes 0x681599fa // method "returnValueOnAssignment()string"
	pushbytes 0x5e1477e8 // method "returnArrayValueOnAssignment()uint64"
	pushbytes 0xe07b3be9 // method "returnStorageValueOnAssignment()uint64"
	pushbytes 0x16e46657 // method "returnOperatorAssignmentValue()uint64"
	pushbytes 0x2c836f46 // method "returnArrayValueOnOperatorAssignment()uint64"
	pushbytes 0xa93c56f9 // method "returnArrayInStorageValueOnOperatorAssignment()uint64"
	pushbytes 0xf936952d // method "consts()void"
	pushbytes 0x88f39c99 // method "assertWithMessage()void"
	pushbytes 0x58794cf4 // method "opcodeAliases()void"
	pushbytes 0x35044ad8 // method "vrfVerifyOp()void"
	pushbytes 0x7d279e8e // method "ecMath()void"
	pushbytes 0x3dfa18c8 // method "gitxn()void"
	pushbytes 0x78ca5c4e // method "getSetBytes()void"
	pushbytes 0x0e67e957 // method "getSetUint64()void"
	pushbytes 0x3b446eef // method "blockOp()void"
	pushbytes 0xae82e875 // method "b64()void"
	pushbytes 0xd69af530 // method "json()void"
	pushbytes 0x4d52f33d // method "bitlenOp()void"
	pushbytes 0x2c0cd201 // method "computedConst()void"
	pushbytes 0x70e0afe5 // method "multiComputedConst()void"
	pushbytes 0x30a2fef4 // method "readSchema()void"
	pushbytes 0xf3971dca // method "comparisonOr()bool"
	byte 0x2c636eeb // method "txnArgsMethod(pay)void"
	pushbytes 0x9e40d34b // method "callTxnArgsMethod()void"
	pushbytes 0x91cf2b58 // method "staticValueLen(uint256)void"
	pushbytes 0xb1c8b45c // method "staticTypeLen()void"
	pushbytes 0x9c0e1bdb // method "dynamicScratchSlot()void"
	pushbytes 0x0a319504 // method "incrementScratchSlot()void"
	pushbytes 0x84b260fa // method "incrementDynamicScratchSlot()void"
	pushbytes 0x4a908856 // method "fromAddress()void"
	pushbytes 0x8deb32d3 // method "earlyReturn(uint64)uint64"
	pushbytes 0x67de156f // method "assetMethodArgs()void"
	pushbytes 0x1e428412 // method "multipleProgramPages()void"
	pushbytes 0x278fd8b8 // method "assertComment()void"
	pushbytes 0xbfc36208 // method "throwErrorMessage()void"
	pushbytes 0x04eedf79 // method "orLiteralType(uint64,uint64)void"
	pushbytes 0x35d5fbc7 // method "multilineFunctionCall()void"
	pushbytes 0xf9522e2f // method "a()uint64"
	pushbytes 0x8c9379e6 // method "b()uint64"
	pushbytes 0xf9a13552 // method "unusedMethodValue()uint64"
	pushbytes 0x94f2049a // method "reassignedNonFirstVar()uint64"
	pushbytes 0x56264215 // method "fvLv()void"
	txna ApplicationArgs 0
	match *abi_route_txnTypeEnum *abi_route_txnGroupLength *abi_route_asserts *abi_route_verifyTxnFromArg *abi_route_verifyTxnFromTxnGroup *abi_route_verifyTxnCondition *abi_route_verifyTxnIncludedIn *abi_route_verifyTxnNotIncludedIn *abi_route_submitPendingGroup *abi_route_methodWithTxnArgs *abi_route_shift *abi_route_fromBytes *abi_route_fromUint64 *abi_route_bzeroFunction *abi_route_events *abi_route_letOptimization *abi_route_staticContractProperties *abi_route_numberToString *abi_route_methodOnParens *abi_route_stringSubstring *abi_route_idProperty *abi_route_scratchSlot *abi_route_ecdsa *abi_route_verifyTxnTypes *abi_route_stringPlusEquals *abi_route_importedProgram *abi_route_callPrivateDefinedLater *abi_route_interalPublicMethod *abi_route_callInternalPublicMethod *abi_route_appLoadScratch *abi_route_uintNWithUnderscore *abi_route_opUp *abi_route_returnValueOnAssignment *abi_route_returnArrayValueOnAssignment *abi_route_returnStorageValueOnAssignment *abi_route_returnOperatorAssignmentValue *abi_route_returnArrayValueOnOperatorAssignment *abi_route_returnArrayInStorageValueOnOperatorAssignment *abi_route_consts *abi_route_assertWithMessage *abi_route_opcodeAliases *abi_route_vrfVerifyOp *abi_route_ecMath *abi_route_gitxn *abi_route_getSetBytes *abi_route_getSetUint64 *abi_route_blockOp *abi_route_b64 *abi_route_json *abi_route_bitlenOp *abi_route_computedConst *abi_route_multiComputedConst *abi_route_readSchema *abi_route_comparisonOr *abi_route_txnArgsMethod *abi_route_callTxnArgsMethod *abi_route_staticValueLen *abi_route_staticTypeLen *abi_route_dynamicScratchSlot *abi_route_incrementScratchSlot *abi_route_incrementDynamicScratchSlot *abi_route_fromAddress *abi_route_earlyReturn *abi_route_assetMethodArgs *abi_route_multipleProgramPages *abi_route_assertComment *abi_route_throwErrorMessage *abi_route_orLiteralType *abi_route_multilineFunctionCall *abi_route_a *abi_route_b *abi_route_unusedMethodValue *abi_route_reassignedNonFirstVar *abi_route_fvLv

	// !!!! WARNING: non-ABI routing
	callsub nonAbi
	int 1
	return

*intToAscii:
	proto 1 1
	pushbytes 0x30313233343536373839 // "0123456789"
	frame_dig -1 // i: uint64
	int 1
	extract3
	retsub
	

*itoa:
	proto 1 1
	frame_dig -1 // i: uint64
	int 0
	==
	bz *itoa_if_end
	byte 0x30
	retsub

*itoa_if_end:
	frame_dig -1 // i: uint64
	pushint 10
	/
	int 0
	>
	bz *itoa_ternary_false
	frame_dig -1 // i: uint64
	pushint 10
	/
	callsub *itoa
	b *itoa_ternary_end

*itoa_ternary_false:
	byte 0x // ""

*itoa_ternary_end:
	frame_dig -1 // i: uint64
	pushint 10
	%
	callsub *intToAscii
	concat
	retsub", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/GeneralTest.arc56_draft.json b/tests/contracts/artifacts/GeneralTest.arc56_draft.json index 6e4d6ea34..2ac4ac790 100644 --- a/tests/contracts/artifacts/GeneralTest.arc56_draft.json +++ b/tests/contracts/artifacts/GeneralTest.arc56_draft.json @@ -16408,7 +16408,7 @@ } }, "source": { - "approval": "#pragma version 10
intcblock 1 0 6 1337 2 5 123 4
bytecblock 0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 0x0000000000000000000000000000000000000000000000000000000000000000 0x000000000000000100000000000000020000000000000003 0x151f7c75 0x0a8101 0x73746f726167654172726179 0x 0x666f6f 0x000000000000000000 0x0000000000000001 0x706167654f6e65 0x7061676554776f 0x674b6579 0x2c636eeb 0x626172 0x627965 0x0000 0x30

// This TEAL was generated by TEALScript v0.104.1
// https://github.com/algorandfoundation/TEALScript

// !!!! WARNING: This contract is *NOT* ARC4 compliant. It may contain ABI methods, but it also allows app calls where the first argument does NOT match an ABI selector

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
int 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// txnTypeEnum()void
*abi_route_txnTypeEnum:
	// execute txnTypeEnum()void
	callsub txnTypeEnum
	int 1
	return

// txnTypeEnum(): void
txnTypeEnum:
	proto 0 0

	// tests/contracts/general.algo.ts:69
	// assert(this.txnGroup[0].typeEnum === TransactionType.ApplicationCall)
	int 0
	gtxns TypeEnum
	int 6 // appl
	==
	assert
	retsub

// txnGroupLength()void
*abi_route_txnGroupLength:
	// execute txnGroupLength()void
	callsub txnGroupLength
	int 1
	return

// txnGroupLength(): void
txnGroupLength:
	proto 0 0

	// tests/contracts/general.algo.ts:73
	// assert(this.txnGroup.length === 1)
	global GroupSize
	int 1
	==
	assert
	retsub

// asserts(bool,bool)void
*abi_route_asserts:
	// arg2: bool
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 0 (arg2) for asserts must be a bool
	assert
	int 0
	getbit

	// arg1: bool
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 1 (arg1) for asserts must be a bool
	assert
	int 0
	getbit

	// execute asserts(bool,bool)void
	callsub asserts
	int 1
	return

// asserts(arg1: boolean, arg2: boolean): void
asserts:
	proto 2 0

	// tests/contracts/general.algo.ts:77
	// asserts(arg1, arg2, arg1 === arg2)
	frame_dig -1 // arg1: boolean

	// asserts failed: asserts(arg1, arg2, arg1 === arg2)
	assert
	frame_dig -2 // arg2: boolean

	// asserts failed: asserts(arg1, arg2, arg1 === arg2)
	assert
	frame_dig -1 // arg1: boolean
	frame_dig -2 // arg2: boolean
	==

	// asserts failed: asserts(arg1, arg2, arg1 === arg2)
	assert
	retsub

// verifyTxnFromArg(pay)void
*abi_route_verifyTxnFromArg:
	// somePay: pay
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// argument 0 (somePay) for verifyTxnFromArg must be a pay transaction
	assert

	// execute verifyTxnFromArg(pay)void
	callsub verifyTxnFromArg
	int 1
	return

// verifyTxnFromArg(somePay: PayTxn): void
verifyTxnFromArg:
	proto 1 0

	// tests/contracts/general.algo.ts:81
	// verifyTxn(somePay, { receiver: this.app.address, amount: 100_000 })
	// verify receiver
	frame_dig -1 // somePay: PayTxn
	gtxns Receiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"somePay","field":"receiver","expected":"this.app.address"}
	assert

	// verify amount
	frame_dig -1 // somePay: PayTxn
	gtxns Amount
	pushint 100_000
	==

	// transaction verification failed: {"txn":"somePay","field":"amount","expected":"100_000"}
	assert
	retsub

// verifyTxnFromTxnGroup()void
*abi_route_verifyTxnFromTxnGroup:
	// execute verifyTxnFromTxnGroup()void
	callsub verifyTxnFromTxnGroup
	int 1
	return

// verifyTxnFromTxnGroup(): void
verifyTxnFromTxnGroup:
	proto 0 0

	// tests/contracts/general.algo.ts:85
	// verifyTxn(this.txnGroup[0], { sender: this.txn.sender })
	// verify sender
	int 0
	gtxns Sender
	txn Sender
	==

	// transaction verification failed: {"txn":"this.txnGroup[0]","field":"sender","expected":"this.txn.sender"}
	assert
	retsub

// verifyTxnCondition()void
*abi_route_verifyTxnCondition:
	// execute verifyTxnCondition()void
	callsub verifyTxnCondition
	int 1
	return

// verifyTxnCondition(): void
verifyTxnCondition:
	proto 0 0

	// tests/contracts/general.algo.ts:89
	// verifyTxn(this.txn, {
	//       applicationID: { greaterThan: 1 },
	//     })
	// verify applicationID
	txn ApplicationID
	int 1
	>

	// transaction verification failed: {"txn":"this.txn","field":"applicationID","condition":"greaterThan","expected":">1"}
	assert
	retsub

// verifyTxnIncludedIn()void
*abi_route_verifyTxnIncludedIn:
	// execute verifyTxnIncludedIn()void
	callsub verifyTxnIncludedIn
	int 1
	return

// verifyTxnIncludedIn(): void
verifyTxnIncludedIn:
	proto 0 0

	// tests/contracts/general.algo.ts:95
	// verifyTxn(this.txn, {
	//       sender: { includedIn: [this.txn.sender] },
	//     })
	// verify sender
	txn Sender
	txn Sender
	==

	// transaction verification failed: {"txn":{"txnText":"this.txn"},"field":"sender","condition":"includedIn","expected":"[this.txn.sender]"}
	assert
	retsub

// verifyTxnNotIncludedIn()void
*abi_route_verifyTxnNotIncludedIn:
	// execute verifyTxnNotIncludedIn()void
	callsub verifyTxnNotIncludedIn
	int 1
	return

// verifyTxnNotIncludedIn(): void
verifyTxnNotIncludedIn:
	proto 0 0

	// tests/contracts/general.algo.ts:101
	// verifyTxn(this.txn, {
	//       sender: { notIncludedIn: [globals.zeroAddress] },
	//     })
	// verify sender
	txn Sender
	global ZeroAddress
	!=

	// transaction verification failed: {"txn":{"txnText":"this.txn"},"field":"sender","condition":"notIncludedIn","expected":"[globals.zeroAddress]"}
	assert
	retsub

// submitPendingGroup()void
*abi_route_submitPendingGroup:
	// execute submitPendingGroup()void
	callsub submitPendingGroup
	int 1
	return

// submitPendingGroup(): void
submitPendingGroup:
	proto 0 0

	// tests/contracts/general.algo.ts:107
	// this.pendingGroup.addPayment({ amount: 0, receiver: this.app.address, isFirstTxn: true })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// tests/contracts/general.algo.ts:107
	// amount: 0
	int 0
	itxn_field Amount

	// tests/contracts/general.algo.ts:107
	// receiver: this.app.address
	global CurrentApplicationAddress
	itxn_field Receiver

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// tests/contracts/general.algo.ts:108
	// this.pendingGroup.addPayment({ amount: 0, receiver: this.app.address, note: 'foo' })
	itxn_next
	int 1 // pay
	itxn_field TypeEnum

	// tests/contracts/general.algo.ts:108
	// amount: 0
	int 0
	itxn_field Amount

	// tests/contracts/general.algo.ts:108
	// receiver: this.app.address
	global CurrentApplicationAddress
	itxn_field Receiver

	// tests/contracts/general.algo.ts:108
	// note: 'foo'
	byte 0x666f6f // "foo"
	itxn_field Note

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// tests/contracts/general.algo.ts:109
	// this.pendingGroup.submit()
	itxn_submit
	retsub

// methodWithTxnArgs()void
*abi_route_methodWithTxnArgs:
	// execute methodWithTxnArgs()void
	callsub methodWithTxnArgs
	int 1
	return

// methodWithTxnArgs(): void
methodWithTxnArgs:
	proto 0 0

	// tests/contracts/general.algo.ts:113
	// sendMethodCall<[PayTxn, MethodCall<[uint64], void>], void>({
	//       name: 'foo',
	//       methodArgs: [
	//         { amount: 100_000, receiver: this.txn.sender },
	//         {
	//           name: 'bar',
	//           applicationID: AppID.fromUint64(1337),
	//           methodArgs: [1],
	//         },
	//       ],
	//     })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// tests/contracts/general.algo.ts:116
	// amount: 100_000
	pushint 100_000
	itxn_field Amount

	// tests/contracts/general.algo.ts:116
	// receiver: this.txn.sender
	txn Sender
	itxn_field Receiver

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee
	itxn_next
	int 6 // appl
	itxn_field TypeEnum
	pushbytes 0x0e8cb9f6 // method "bar(uint64)void"
	itxn_field ApplicationArgs

	// tests/contracts/general.algo.ts:119
	// applicationID: AppID.fromUint64(1337)
	int 1337
	itxn_field ApplicationID

	// tests/contracts/general.algo.ts:120
	// methodArgs: [1]
	byte 0x0000000000000001
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee
	itxn_next
	int 6 // appl
	itxn_field TypeEnum
	pushbytes 0x6c6f7a08 // method "foo(pay,appl)void"
	itxn_field ApplicationArgs

	// tests/contracts/general.algo.ts:115
	// methodArgs: [
	//         { amount: 100_000, receiver: this.txn.sender },
	//         {
	//           name: 'bar',
	//           applicationID: AppID.fromUint64(1337),
	//           methodArgs: [1],
	//         },
	//       ]
	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// shift()void
*abi_route_shift:
	// execute shift()void
	callsub shift
	int 1
	return

// shift(): void
shift:
	proto 0 0

	// tests/contracts/general.algo.ts:127
	// assert(1 << 2 === 4)
	int 1
	int 2
	shl
	int 4
	==
	assert

	// tests/contracts/general.algo.ts:128
	// assert(4 >> 1 === 2)
	int 4
	int 1
	shr
	int 2
	==
	assert
	retsub

// fromBytes()void
*abi_route_fromBytes:
	// execute fromBytes()void
	callsub fromBytes
	int 1
	return

// fromBytes(): void
fromBytes:
	proto 0 0

	// tests/contracts/general.algo.ts:132
	// assert(Address.fromBytes('abc').minBalance)
	pushbytes 0x616263 // "abc"
	acct_params_get AcctMinBalance
	pop
	assert
	retsub

// fromUint64()void
*abi_route_fromUint64:
	// execute fromUint64()void
	callsub fromUint64
	int 1
	return

// fromUint64(): void
fromUint64:
	proto 0 0

	// tests/contracts/general.algo.ts:136
	// log(AppID.fromUint64(123).creator)
	int 123
	app_params_get AppCreator
	pop
	log

	// tests/contracts/general.algo.ts:137
	// log(AssetID.fromUint64(123).creator)
	int 123
	asset_params_get AssetCreator
	pop
	log
	retsub

// bzeroFunction()void
*abi_route_bzeroFunction:
	// execute bzeroFunction()void
	callsub bzeroFunction
	int 1
	return

// bzeroFunction(): void
bzeroFunction:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// tests/contracts/general.algo.ts:142
	// x: bytes = bzero(2)
	byte 0x0000
	frame_bury 0 // x: bytes

	// tests/contracts/general.algo.ts:143
	// y: bytes = bzero(n)
	int 1
	bzero
	frame_bury 1 // y: bytes

	// tests/contracts/general.algo.ts:144
	// z: [uint64, uint<8>] = bzero<[uint64, uint<8>]>()
	byte 0x000000000000000000
	frame_bury 2 // z: [uint64, uint<8>]

	// tests/contracts/general.algo.ts:145
	// assert(len(x + y + z) === 12)
	byte 0x0000 // x: bytes
	frame_dig 1 // y: bytes
	concat
	byte 0x000000000000000000 // z: [uint64, uint<8>]
	concat
	len
	pushint 12
	==
	assert
	retsub

// events()void
*abi_route_events:
	// execute events()void
	callsub events
	int 1
	return

// events(): void
events:
	proto 0 0

	// tests/contracts/general.algo.ts:160
	// this.myEvent.log({ app: this.app, num: 1 })
	pushbytes 0x87528196 // myEvent(uint64,uint64)
	txna Applications 0
	itob
	byte 0x0000000000000001
	concat
	concat
	log
	retsub

// letOptimization(uint64[])uint64[]
*abi_route_letOptimization:
	// The ABI return prefix
	byte 0x151f7c75

	// a: uint64[]
	txna ApplicationArgs 1
	extract 2 0

	// execute letOptimization(uint64[])uint64[]
	callsub letOptimization
	dup
	len
	pushint 8
	/
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// letOptimization(a: uint64[]): uint64[]
letOptimization:
	proto 1 1

	// tests/contracts/general.algo.ts:164
	// assert(a[0])
	frame_dig -1 // a: uint64[]
	store 255 // full array
	load 255 // full array
	extract 0 8
	btoi
	assert

	// tests/contracts/general.algo.ts:166
	// b = [1, 2, 3]
	byte 0x000000000000000100000000000000020000000000000003
	frame_bury -1 // b: uint64[]

	// tests/contracts/general.algo.ts:168
	// return b;
	frame_dig -1 // a: uint64[]
	retsub

// staticContractProperties()void
*abi_route_staticContractProperties:
	// execute staticContractProperties()void
	callsub staticContractProperties
	int 1
	return

// staticContractProperties(): void
staticContractProperties:
	proto 0 0

	// tests/contracts/general.algo.ts:172
	// sendAppCall({
	//       onCompletion: OnCompletion.NoOp,
	//       approvalProgram: DummyContract.approvalProgram(),
	//       clearStateProgram: DummyContract.clearProgram(),
	//       localNumByteSlice: DummyContract.schema.local.numByteSlice,
	//       localNumUint: DummyContract.schema.local.numUint,
	//       globalNumByteSlice: DummyContract.schema.global.numByteSlice,
	//       globalNumUint: DummyContract.schema.global.numUint,
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum

	// tests/contracts/general.algo.ts:173
	// onCompletion: OnCompletion.NoOp
	int 0 // NoOp
	itxn_field OnCompletion

	// tests/contracts/general.algo.ts:174
	// approvalProgram: DummyContract.approvalProgram()
	pushbytes 0x0a31181481060b3119088d0c000000000000000000000000000400000000000000000000008101438004b8447b36361a008e01fff000
	itxn_field ApprovalProgram

	// tests/contracts/general.algo.ts:175
	// clearStateProgram: DummyContract.clearProgram()
	pushbytes 0x0a
	itxn_field ClearStateProgram

	// tests/contracts/general.algo.ts:176
	// localNumByteSlice: DummyContract.schema.local.numByteSlice
	int 0
	itxn_field LocalNumByteSlice

	// tests/contracts/general.algo.ts:177
	// localNumUint: DummyContract.schema.local.numUint
	int 0
	itxn_field LocalNumUint

	// tests/contracts/general.algo.ts:178
	// globalNumByteSlice: DummyContract.schema.global.numByteSlice
	int 0
	itxn_field GlobalNumByteSlice

	// tests/contracts/general.algo.ts:179
	// globalNumUint: DummyContract.schema.global.numUint
	int 0
	itxn_field GlobalNumUint

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// numberToString()void
*abi_route_numberToString:
	// execute numberToString()void
	callsub numberToString
	int 1
	return

// numberToString(): void
numberToString:
	proto 0 0

	// tests/contracts/general.algo.ts:186
	// assert(n.toString() === s)
	int 1
	callsub *itoa
	pushbytes "1"
	==
	assert
	retsub

// methodOnParens()void
*abi_route_methodOnParens:
	// execute methodOnParens()void
	callsub methodOnParens
	int 1
	return

// methodOnParens(): void
methodOnParens:
	proto 0 0

	// tests/contracts/general.algo.ts:190
	// assert((1 + 2).toString() === '3')
	pushint 3
	callsub *itoa
	pushbytes 0x33 // "3"
	==
	assert
	retsub

// stringSubstring()void
*abi_route_stringSubstring:
	// execute stringSubstring()void
	callsub stringSubstring
	int 1
	return

// stringSubstring(): void
stringSubstring:
	proto 0 0

	// tests/contracts/general.algo.ts:195
	// assert(s.substring(1, 3) === 'bc')
	pushbytes "abcdef"
	substring 1 3
	pushbytes 0x6263 // "bc"
	==
	assert
	retsub

// idProperty()void
*abi_route_idProperty:
	// execute idProperty()void
	callsub idProperty
	int 1
	return

// idProperty(): void
idProperty:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// tests/contracts/general.algo.ts:199
	// app = AppID.zeroIndex
	int 0
	frame_bury 0 // app: uint64

	// tests/contracts/general.algo.ts:200
	// assert(AppID.fromUint64(app.id) === app)
	int 0 // app: uint64
	dup
	==
	assert

	// tests/contracts/general.algo.ts:202
	// asa = AssetID.zeroIndex
	int 0
	frame_bury 1 // asa: uint64

	// tests/contracts/general.algo.ts:203
	// assert(AssetID.fromUint64(asa.id) === asa)
	int 0 // asa: uint64
	dup
	==
	assert
	retsub

// scratchSlot()void
*abi_route_scratchSlot:
	// execute scratchSlot()void
	callsub scratchSlot
	int 1
	return

// scratchSlot(): void
scratchSlot:
	proto 0 0

	// tests/contracts/general.algo.ts:207
	// this.scratch.value = 1337
	int 1337
	store 0

	// tests/contracts/general.algo.ts:208
	// assert(this.scratch.value === 1337)
	load 0
	int 1337
	==
	assert
	retsub

// ecdsa()void
*abi_route_ecdsa:
	// execute ecdsa()void
	callsub ecdsa
	int 1
	return

// ecdsa(): void
ecdsa:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 3

	// tests/contracts/general.algo.ts:212
	// ecdsaVerify('Secp256k1', '' as bytes32, '' as bytes32, '' as bytes32, '' as bytes32, '' as bytes32)
	byte 0x0000000000000000000000000000000000000000000000000000000000000000 // ""
	dupn 4
	ecdsa_verify Secp256k1

	// tests/contracts/general.algo.ts:213
	// d = ecdsaPkDecompress('Secp256k1', '' as bytes<33>)
	pushbytes 0x000000000000000000000000000000000000000000000000000000000000000000 // ""
	ecdsa_pk_decompress Secp256k1
	frame_bury 0 // d y component: byte[]
	frame_bury 1 // d x component: byte[]

	// tests/contracts/general.algo.ts:214
	// log(d.y)
	frame_dig 0 // d y component: byte[]
	log

	// tests/contracts/general.algo.ts:215
	// log(d.x)
	frame_dig 1 // d x component: byte[]
	log

	// tests/contracts/general.algo.ts:217
	// r = ecdsaPkRecover('Secp256k1', '' as bytes32, 1, '' as bytes32, '' as bytes32)
	byte 0x0000000000000000000000000000000000000000000000000000000000000000 // ""
	int 1
	byte 0x0000000000000000000000000000000000000000000000000000000000000000 // ""
	dup
	ecdsa_pk_recover Secp256k1
	frame_bury 2 // r y component: byte[]
	frame_bury 3 // r x component: byte[]

	// tests/contracts/general.algo.ts:218
	// log(r.y)
	frame_dig 2 // r y component: byte[]
	log

	// tests/contracts/general.algo.ts:219
	// log(r.x)
	frame_dig 3 // r x component: byte[]
	log
	retsub

// verifyTxnTypes()void
*abi_route_verifyTxnTypes:
	// execute verifyTxnTypes()void
	callsub verifyTxnTypes
	int 1
	return

// verifyTxnTypes(): void
verifyTxnTypes:
	proto 0 0

	// tests/contracts/general.algo.ts:223
	// verifyPayTxn(this.txnGroup[0], {
	//       amount: { greaterThan: 0 },
	//     })
	// verify pay
	int 0
	gtxns TypeEnum
	int 1 // pay
	==

	// transaction verification failed: {"txn":"this.txnGroup[0]","field":"typeEnum","expected":"pay"}
	assert

	// verify amount
	int 0
	gtxns Amount
	int 0
	>

	// transaction verification failed: {"txn":"this.txnGroup[0]","field":"amount","condition":"greaterThan","expected":">0"}
	assert

	// tests/contracts/general.algo.ts:227
	// verifyAppCallTxn(this.txnGroup[0], {
	//       applicationID: AppID.fromUint64(0),
	//       applicationArgs: {
	//         0: 'foo',
	//         1: {
	//           includedIn: ['bar', 'baz'],
	//         },
	//       },
	//     })
	// verify appl
	int 0
	gtxns TypeEnum
	int 6 // appl
	==

	// transaction verification failed: {"txn":"this.txnGroup[0]","field":"typeEnum","expected":"appl"}
	assert

	// verify applicationID
	int 0
	gtxns ApplicationID
	int 0
	==

	// transaction verification failed: {"txn":"this.txnGroup[0]","field":"applicationID","expected":"AppID.fromUint64(0)"}
	assert

	// verify applicationArgs
	// verify applicationArgs 0
	int 0
	gtxns ApplicationArgs 0
	byte 0x666f6f // "foo"
	==

	// transaction verification failed: {"txn":"this.txnGroup[0]","field":"applicationArgs","index":"0","expected":"'foo'"}
	assert

	// verify applicationArgs 1
	int 0
	gtxns ApplicationArgs 1
	byte 0x626172 // "bar"
	==
	int 0
	gtxns ApplicationArgs 1
	pushbytes 0x62617a // "baz"
	==
	||

	// transaction verification failed: {"txn":{"txnText":"this.txnGroup[0]"},"field":"applicationArgs 1","condition":"includedIn","expected":"['bar', 'baz']"}
	assert

	// tests/contracts/general.algo.ts:237
	// verifyAssetTransferTxn(this.txnGroup[0], {
	//       assetReceiver: this.app.address,
	//     })
	// verify axfer
	int 0
	gtxns TypeEnum
	int 4 // axfer
	==

	// transaction verification failed: {"txn":"this.txnGroup[0]","field":"typeEnum","expected":"axfer"}
	assert

	// verify assetReceiver
	int 0
	gtxns AssetReceiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"this.txnGroup[0]","field":"assetReceiver","expected":"this.app.address"}
	assert

	// tests/contracts/general.algo.ts:241
	// verifyAssetConfigTxn(this.txnGroup[0], {
	//       configAsset: AssetID.fromUint64(0),
	//     })
	// verify acfg
	int 0
	gtxns TypeEnum
	pushint 3 // acfg
	==

	// transaction verification failed: {"txn":"this.txnGroup[0]","field":"typeEnum","expected":"acfg"}
	assert

	// verify configAsset
	int 0
	gtxns ConfigAsset
	int 0
	==

	// transaction verification failed: {"txn":"this.txnGroup[0]","field":"configAsset","expected":"AssetID.fromUint64(0)"}
	assert

	// tests/contracts/general.algo.ts:245
	// verifyKeyRegTxn(this.txnGroup[0], {
	//       voteFirst: 1337,
	//     })
	// verify keyreg
	int 0
	gtxns TypeEnum
	int 2 // keyreg
	==

	// transaction verification failed: {"txn":"this.txnGroup[0]","field":"typeEnum","expected":"keyreg"}
	assert

	// verify voteFirst
	int 0
	gtxns VoteFirst
	int 1337
	==

	// transaction verification failed: {"txn":"this.txnGroup[0]","field":"voteFirst","expected":"1337"}
	assert
	retsub

// stringPlusEquals()void
*abi_route_stringPlusEquals:
	// execute stringPlusEquals()void
	callsub stringPlusEquals
	int 1
	return

// stringPlusEquals(): void
stringPlusEquals:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/general.algo.ts:251
	// s = 'foo'
	byte 0x666f6f // "foo"
	frame_bury 0 // s: byte[]

	// tests/contracts/general.algo.ts:252
	// s += 'bar'
	frame_dig 0 // s: byte[]
	byte 0x626172 // "bar"
	concat
	frame_bury 0 // s: byte[]

	// tests/contracts/general.algo.ts:253
	// assert(s === 'foobar')
	frame_dig 0 // s: byte[]
	pushbytes 0x666f6f626172 // "foobar"
	==
	assert
	retsub

// importedProgram()byte[]
*abi_route_importedProgram:
	// The ABI return prefix
	byte 0x151f7c75

	// execute importedProgram()byte[]
	callsub importedProgram
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// importedProgram(): bytes
importedProgram:
	proto 0 1

	// tests/contracts/general.algo.ts:257
	// return IfTest.approvalProgram();
	pushbytes 0x0a20020100260904151f7c7504656c736502696609656c7365206966203109656c7365206966203207656c736520696603656e6403666f6f0031181481060b3119088d0c041900000000000000000000040b00000000000000000000008004151f7c75361a0149158101124481005388000d4915165706024c5050b08101438a01018bff41000580026966898003656e64898004151f7c75361a0149158101124481005388000d4915165706024c5050b08101438a01018bff41000880026966894200078004656c736589898004151f7c75361a02491581011244810053361a0149158101124481005388000d4915165706024c5050b08101438a02018bff410008800269668942000f8bfe41000a8007656c7365206966898003656e64898004151f7c75361a02491581011244810053361a0149158101124481005388000d4915165706024c5050b08101438a02018bff41000880026966894200198bfe41000d8007656c7365206966894200078004656c736589898004151f7c75361a03491581011244810053361a02491581011244810053361a0149158101124481005388000d4915165706024c5050b08101438a03018bff41000880026966894200258bfe41000f8009656c73652069662031894200118bfd41000c8009656c73652069662032898003656e64898004151f7c75361a03491581011244810053361a02491581011244810053361a0149158101124481005388000d4915165706024c5050b08101438a03018bff410008800269668942002f8bfe41000f8009656c736520696620318942001b8bfd41000f8009656c73652069662032894200078004656c736589898004151f7c75361a02491581011244810053361a0149158101124481005388000d4915165706024c5050b08101438a02018bff4100198bfe41000c80096e65737465642069668980026966894200078004656c736589898004151f7c75361a0149158101124481005388000d4915165706024c5050b08101438a01018bff41000880026966894200078004656c736589898004151f7c75361a02491581011244810053361a014915810112448100538800061650b08101438a02018bff410005810142000c8bfe41000581024200028103898004151f7c75361a015702008800061650b08101438a01018bff8000a94100038101898102898004151f7c75361a015702008800061650b08101438a01018bff8000a94100058101420002810289361a01491581021244178800038101438a01008bff8000a94100068003666f6fb089361a0249158102124417361a01491581021244178800038101438a02008bff8bfe0e4100068003666f6fb089361a02491581201244361a014915812012448800038101438a02008bff8bfea64100068003666f6fb0898004151f7c75361a02491581011244810053361a0149158101124481005388000d4915165706024c5050b08101438a02018bff4100198bfe41000d80076120616e64206289420004800161894200168bfe4100078001628942000a80076e65697468657289898101438004b8447b36361a008e01fff0008004436ec1c280041c7a0d5e80045e0fb6cf80045e1c6c50800458d0ba9280045d2f4f028004845729d980048fe76ca880041a3c7878800474bcc86880044212f905800495ddaebf80043147b866800442897f618004534be2b7361a008e0ffb6bfba0fbdafc2dfc85fcfafd74fdcbfe05fe46fe6cfe94feb6fee2ff0c00
	retsub

// callPrivateDefinedLater()void
*abi_route_callPrivateDefinedLater:
	// execute callPrivateDefinedLater()void
	callsub callPrivateDefinedLater
	int 1
	return

// callPrivateDefinedLater(): void
callPrivateDefinedLater:
	proto 0 0

	// tests/contracts/general.algo.ts:261
	// log(this.privateMethod('hello'))
	pushbytes 0x68656c6c6f // "hello"
	callsub privateMethod
	log
	retsub

// privateMethod(msg: string): string
privateMethod:
	proto 1 1

	// tests/contracts/general.algo.ts:265
	// return msg;
	frame_dig -1 // msg: string
	retsub

// interalPublicMethod(uint64,uint64)uint64
*abi_route_interalPublicMethod:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute interalPublicMethod(uint64,uint64)uint64
	callsub interalPublicMethod
	itob
	concat
	log
	int 1
	return

// interalPublicMethod(a: uint64, b: uint64): uint64
interalPublicMethod:
	proto 2 1

	// tests/contracts/general.algo.ts:269
	// return a + b;
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	+
	retsub

// callInternalPublicMethod()void
*abi_route_callInternalPublicMethod:
	// execute callInternalPublicMethod()void
	callsub callInternalPublicMethod
	int 1
	return

// callInternalPublicMethod(): void
callInternalPublicMethod:
	proto 0 0

	// tests/contracts/general.algo.ts:273
	// assert(this.interalPublicMethod(1, 2) === 3)
	int 2
	int 1
	callsub interalPublicMethod
	pushint 3
	==
	assert
	retsub

// appLoadScratch()void
*abi_route_appLoadScratch:
	// execute appLoadScratch()void
	callsub appLoadScratch
	int 1
	return

// appLoadScratch(): void
appLoadScratch:
	proto 0 0

	// tests/contracts/general.algo.ts:277
	// log(this.txnGroup[1].loadScratch(2) as bytes)
	gload 1 2
	log
	retsub

// uintNWithUnderscore()uint256
*abi_route_uintNWithUnderscore:
	// The ABI return prefix
	byte 0x151f7c75

	// execute uintNWithUnderscore()uint256
	callsub uintNWithUnderscore
	dup
	bitlen
	pushint 256
	<=

	// uintNWithUnderscore return value overflowed 256 bits
	assert
	pushbytes 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	pushint 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// uintNWithUnderscore(): uint256
uintNWithUnderscore:
	proto 0 1

	// tests/contracts/general.algo.ts:281
	// return <uint256>123_456;
	pushbytes 0x000000000000000000000000000000000000000000000000000000000001e240
	retsub

// opUp()void
*abi_route_opUp:
	// execute opUp()void
	callsub opUp
	int 1
	return

// opUp(): void
opUp:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/general.algo.ts:285
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	int 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

	// tests/contracts/general.algo.ts:286
	// for (let i = 1; i < 75; i += 1)
	int 1
	frame_bury 0 // i: uint64

*for_0:
	// tests/contracts/general.algo.ts:286
	// i < 75
	frame_dig 0 // i: uint64
	pushint 75
	<
	bz *for_0_end

	// tests/contracts/general.algo.ts:287
	// assert(i)
	frame_dig 0 // i: uint64
	assert

*for_0_continue:
	// tests/contracts/general.algo.ts:286
	// i += 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64
	b *for_0

*for_0_end:
	retsub

// returnValueOnAssignment()string
*abi_route_returnValueOnAssignment:
	// The ABI return prefix
	byte 0x151f7c75

	// execute returnValueOnAssignment()string
	callsub returnValueOnAssignment
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// returnValueOnAssignment(): string
returnValueOnAssignment:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/general.algo.ts:292
	// message = 'hi'
	pushbytes 0x6869 // "hi"
	frame_bury 0 // message: byte[]

	// *if0_condition
	// tests/contracts/general.algo.ts:294
	// this.txn.sender === this.app.address
	txn Sender
	global CurrentApplicationAddress
	==
	bz *if0_end

	// *if0_consequent
	// tests/contracts/general.algo.ts:295
	// message = 'in block'
	pushbytes 0x696e20626c6f636b // "in block"
	frame_bury 0 // message: byte[]

*if0_end:
	// tests/contracts/general.algo.ts:298
	// return (message = 'bye');
	byte 0x627965 // "bye"
	dup
	frame_bury 0 // message: byte[]

	// set the subroutine return value
	frame_bury 0
	retsub

// returnArrayValueOnAssignment()uint64
*abi_route_returnArrayValueOnAssignment:
	// The ABI return prefix
	byte 0x151f7c75

	// execute returnArrayValueOnAssignment()uint64
	callsub returnArrayValueOnAssignment
	itob
	concat
	log
	int 1
	return

// returnArrayValueOnAssignment(): uint64
returnArrayValueOnAssignment:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/general.algo.ts:302
	// a: StaticArray<uint64, 3> = [1, 2, 3]
	byte 0x000000000000000100000000000000020000000000000003
	frame_bury 0 // a: StaticArray<uint64, 3>

	// tests/contracts/general.algo.ts:304
	// return (a[0] = 4);
	frame_dig 0 // a: StaticArray<uint64, 3>
	int 0
	int 4
	dup
	store 245 // assignment value
	itob
	replace3
	frame_bury 0 // a: StaticArray<uint64, 3>
	load 245 // assignment value

	// set the subroutine return value
	frame_bury 0
	retsub

// returnStorageValueOnAssignment()uint64
*abi_route_returnStorageValueOnAssignment:
	// The ABI return prefix
	byte 0x151f7c75

	// execute returnStorageValueOnAssignment()uint64
	callsub returnStorageValueOnAssignment
	itob
	concat
	log
	int 1
	return

// returnStorageValueOnAssignment(): uint64
returnStorageValueOnAssignment:
	proto 0 1

	// tests/contracts/general.algo.ts:308
	// this.gKey.value = 1
	byte 0x674b6579 // "gKey"
	int 1
	app_global_put

	// tests/contracts/general.algo.ts:310
	// return (this.gKey.value = 2);
	byte 0x674b6579 // "gKey"
	int 2
	dup
	store 245 // assignment value
	app_global_put
	load 245 // assignment value
	retsub

// returnOperatorAssignmentValue()uint64
*abi_route_returnOperatorAssignmentValue:
	// The ABI return prefix
	byte 0x151f7c75

	// execute returnOperatorAssignmentValue()uint64
	callsub returnOperatorAssignmentValue
	itob
	concat
	log
	int 1
	return

// returnOperatorAssignmentValue(): uint64
returnOperatorAssignmentValue:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/general.algo.ts:314
	// a = 1
	int 1
	frame_bury 0 // a: uint64

	// tests/contracts/general.algo.ts:316
	// return (a += 2);
	frame_dig 0 // a: uint64
	int 2
	+
	dup
	store 245 // assignment value
	frame_bury 0 // a: uint64
	load 245 // assignment value

	// set the subroutine return value
	frame_bury 0
	retsub

// returnArrayValueOnOperatorAssignment()uint64
*abi_route_returnArrayValueOnOperatorAssignment:
	// The ABI return prefix
	byte 0x151f7c75

	// execute returnArrayValueOnOperatorAssignment()uint64
	callsub returnArrayValueOnOperatorAssignment
	itob
	concat
	log
	int 1
	return

// returnArrayValueOnOperatorAssignment(): uint64
returnArrayValueOnOperatorAssignment:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/general.algo.ts:320
	// a: StaticArray<uint64, 3> = [1, 2, 3]
	byte 0x000000000000000100000000000000020000000000000003
	frame_bury 0 // a: StaticArray<uint64, 3>

	// tests/contracts/general.algo.ts:322
	// return (a[0] += 4);
	frame_dig 0 // a: StaticArray<uint64, 3>
	int 0
	frame_dig 0 // a: StaticArray<uint64, 3>
	extract 0 8
	btoi
	int 4
	+
	dup
	store 245 // assignment value
	itob
	replace3
	frame_bury 0 // a: StaticArray<uint64, 3>
	load 245 // assignment value

	// set the subroutine return value
	frame_bury 0
	retsub

// returnArrayInStorageValueOnOperatorAssignment()uint64
*abi_route_returnArrayInStorageValueOnOperatorAssignment:
	// The ABI return prefix
	byte 0x151f7c75

	// execute returnArrayInStorageValueOnOperatorAssignment()uint64
	callsub returnArrayInStorageValueOnOperatorAssignment
	itob
	concat
	log
	int 1
	return

// returnArrayInStorageValueOnOperatorAssignment(): uint64
returnArrayInStorageValueOnOperatorAssignment:
	proto 0 1

	// tests/contracts/general.algo.ts:326
	// this.storageArray.value = [1, 2, 3]
	byte 0x73746f726167654172726179 // "storageArray"
	byte 0x000000000000000100000000000000020000000000000003
	app_global_put

	// tests/contracts/general.algo.ts:328
	// return (this.storageArray.value[0] += 4);
	byte 0x73746f726167654172726179 // "storageArray"
	app_global_get
	int 0
	byte 0x73746f726167654172726179 // "storageArray"
	app_global_get
	extract 0 8
	btoi
	int 4
	+
	dup
	store 245 // assignment value
	itob
	replace3
	byte 0x73746f726167654172726179 // "storageArray"
	swap
	app_global_put
	load 245 // assignment value
	retsub

// consts()void
*abi_route_consts:
	// execute consts()void
	callsub consts
	int 1
	return

// consts(): void
consts:
	proto 0 0

	// tests/contracts/general.algo.ts:332
	// assert(STRING_CONST === 'foo')
	pushbytes "foo"
	byte 0x666f6f // "foo"
	==
	assert

	// tests/contracts/general.algo.ts:333
	// assert(NUM_CONST === 123)
	int 123
	dup
	==
	assert

	// tests/contracts/general.algo.ts:334
	// assert(NESTED_CONST === 123)
	int 123
	dup
	==
	assert
	retsub

// assertWithMessage()void
*abi_route_assertWithMessage:
	// execute assertWithMessage()void
	callsub assertWithMessage
	int 1
	return

// assertWithMessage(): void
assertWithMessage:
	proto 0 0

	// tests/contracts/general.algo.ts:338
	// assert(false, 'this is false')
	int 0

	// this is false
	assert
	retsub

// opcodeAliases()void
*abi_route_opcodeAliases:
	// execute opcodeAliases()void
	callsub opcodeAliases
	int 1
	return

// opcodeAliases(): void
opcodeAliases:
	proto 0 0

	// tests/contracts/general.algo.ts:342
	// extractUint16(bzero(64), 0)
	byte 0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000
	int 0
	extract_uint16

	// tests/contracts/general.algo.ts:343
	// extractUint32(bzero(64), 0)
	byte 0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000
	int 0
	extract_uint32

	// tests/contracts/general.algo.ts:344
	// extractUint64(bzero(64), 0)
	byte 0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000
	int 0
	extract_uint64

	// tests/contracts/general.algo.ts:345
	// ed25519VerifyBare(bzero(64), bzero(64), bzero(32))
	byte 0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000
	dup
	byte 0x0000000000000000000000000000000000000000000000000000000000000000
	ed25519verify_bare

	// tests/contracts/general.algo.ts:346
	// ed25519Verify(bzero(64), bzero(64), bzero(32))
	byte 0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000
	dup
	byte 0x0000000000000000000000000000000000000000000000000000000000000000
	ed25519verify
	retsub

// vrfVerifyOp()void
*abi_route_vrfVerifyOp:
	// execute vrfVerifyOp()void
	callsub vrfVerifyOp
	int 1
	return

// vrfVerifyOp(): void
vrfVerifyOp:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// tests/contracts/general.algo.ts:350
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	int 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

	// tests/contracts/general.algo.ts:351
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	int 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

	// tests/contracts/general.algo.ts:352
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	int 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

	// tests/contracts/general.algo.ts:353
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	int 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

	// tests/contracts/general.algo.ts:354
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	int 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

	// tests/contracts/general.algo.ts:355
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	int 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

	// tests/contracts/general.algo.ts:356
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	int 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

	// tests/contracts/general.algo.ts:357
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	int 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

	// tests/contracts/general.algo.ts:358
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	int 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

	// tests/contracts/general.algo.ts:360
	// r = vrfVefiry('VrfAlgorand', bzero(32) as bytes, bzero(80), bzero(32))
	byte 0x0000000000000000000000000000000000000000000000000000000000000000
	pushbytes 0x0000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000
	byte 0x0000000000000000000000000000000000000000000000000000000000000000
	vrf_verify VrfAlgorand
	frame_bury 0 // r verified: bool
	frame_bury 1 // r output: byte[]

	// tests/contracts/general.algo.ts:361
	// assert(!r.verified)
	frame_dig 0 // r verified: bool
	!
	assert

	// tests/contracts/general.algo.ts:362
	// log(r.output)
	frame_dig 1 // r output: byte[]
	log
	retsub

// ecMath()void
*abi_route_ecMath:
	// execute ecMath()void
	callsub ecMath
	int 1
	return

// ecMath(): void
ecMath:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/general.algo.ts:366
	// ecScalarMul('BN254g1', '', '')
	byte 0x // ""
	dup
	ec_scalar_mul BN254g1

	// tests/contracts/general.algo.ts:367
	// ecPairingCheck('BN254g1', '', '')
	byte 0x // ""
	dup
	ec_pairing_check BN254g1

	// tests/contracts/general.algo.ts:368
	// scalars: bytes32[] = [bzero(32), bzero(32)]
	byte 0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000
	frame_bury 0 // scalars: bytes32[]

	// tests/contracts/general.algo.ts:369
	// ecMultiScalarMul('BN254g1', '', scalars)
	byte 0x // ""
	byte 0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 // scalars: bytes32[]
	ec_multi_scalar_mul BN254g1

	// tests/contracts/general.algo.ts:370
	// ecSubgroupCheck('BN254g1', '')
	byte 0x // ""
	ec_subgroup_check BN254g1

	// tests/contracts/general.algo.ts:371
	// ecMapTo('BN254g1', '')
	byte 0x // ""
	ec_map_to BN254g1

	// tests/contracts/general.algo.ts:372
	// ecAdd('BN254g1', '', '')
	byte 0x // ""
	dup
	ec_add BN254g1
	retsub

// gitxn()void
*abi_route_gitxn:
	// execute gitxn()void
	callsub gitxn
	int 1
	return

// gitxn(): void
gitxn:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/general.algo.ts:376
	// log(this.lastInnerGroup[0].sender)
	gitxn 0 Sender
	log

	// tests/contracts/general.algo.ts:378
	// anotherTxn = this.lastInnerGroup[1]
	int 1
	frame_bury 0 // anotherTxn: gitxn

	// tests/contracts/general.algo.ts:380
	// log(anotherTxn.sender)
	gitxn 1 Sender
	log
	retsub

// getSetBytes()void
*abi_route_getSetBytes:
	// execute getSetBytes()void
	callsub getSetBytes
	int 1
	return

// getSetBytes(): void
getSetBytes:
	proto 0 0

	// tests/contracts/general.algo.ts:384
	// log(setbit('foo', 0, true))
	byte 0x666f6f // "foo"
	int 0
	int 1
	setbit
	log

	// tests/contracts/general.algo.ts:385
	// getbit('foo', 0)
	byte 0x666f6f // "foo"
	int 0
	getbit

	// tests/contracts/general.algo.ts:386
	// getbyte('foo', 0)
	byte 0x666f6f // "foo"
	int 0
	getbyte

	// tests/contracts/general.algo.ts:387
	// setbyte('foo', 0, 1)
	byte 0x666f6f // "foo"
	int 0
	int 1
	setbyte
	retsub

// getSetUint64()void
*abi_route_getSetUint64:
	// execute getSetUint64()void
	callsub getSetUint64
	int 1
	return

// getSetUint64(): void
getSetUint64:
	proto 0 0

	// tests/contracts/general.algo.ts:391
	// assert(setbit(123, 0, true))
	int 123
	int 0
	int 1
	setbit
	assert

	// tests/contracts/general.algo.ts:392
	// getbit(123, 0)
	int 123
	int 0
	getbit
	retsub

// blockOp()void
*abi_route_blockOp:
	// execute blockOp()void
	callsub blockOp
	int 1
	return

// blockOp(): void
blockOp:
	proto 0 0

	// tests/contracts/general.algo.ts:396
	// log(blocks[globals.round - 1].seed)
	global Round
	int 1
	-
	block BlkSeed
	log

	// tests/contracts/general.algo.ts:397
	// assert(blocks[globals.round - 1].timestamp)
	global Round
	int 1
	-
	block BlkTimestamp
	assert
	retsub

// b64()void
*abi_route_b64:
	// execute b64()void
	callsub b64
	int 1
	return

// b64(): void
b64:
	proto 0 0

	// tests/contracts/general.algo.ts:401
	// log(base64Decode('StdEncoding', ''))
	byte 0x // ""
	base64_decode StdEncoding
	log
	retsub

// json()void
*abi_route_json:
	// execute json()void
	callsub json
	int 1
	return

// json(): void
json:
	proto 0 0

	// tests/contracts/general.algo.ts:405
	// log(jsonRef('JSONObject', '', ''))
	byte 0x // ""
	dup
	json_ref JSONObject
	log

	// tests/contracts/general.algo.ts:406
	// log(jsonRef('JSONString', '', ''))
	byte 0x // ""
	dup
	json_ref JSONString
	log

	// tests/contracts/general.algo.ts:407
	// assert(jsonRef('JSONUint64', '', ''))
	byte 0x // ""
	dup
	json_ref JSONUint64
	assert
	retsub

// bitlenOp()void
*abi_route_bitlenOp:
	// execute bitlenOp()void
	callsub bitlenOp
	int 1
	return

// bitlenOp(): void
bitlenOp:
	proto 0 0

	// tests/contracts/general.algo.ts:411
	// bitlen(123)
	int 123
	bitlen

	// tests/contracts/general.algo.ts:412
	// bitlen('foo')
	byte 0x666f6f // "foo"
	bitlen
	retsub

// computedConst()void
*abi_route_computedConst:
	// execute computedConst()void
	callsub computedConst
	int 1
	return

// computedConst(): void
computedConst:
	proto 0 0

	// tests/contracts/general.algo.ts:416
	// assert(COMPUTED_CONST)
	pushint 246
	assert
	retsub

// multiComputedConst()void
*abi_route_multiComputedConst:
	// execute multiComputedConst()void
	callsub multiComputedConst
	int 1
	return

// multiComputedConst(): void
multiComputedConst:
	proto 0 0

	// tests/contracts/general.algo.ts:420
	// assert(MUTLI_COMPUTED_CONST)
	pushint 30381
	assert
	retsub

// readSchema()void
*abi_route_readSchema:
	// execute readSchema()void
	callsub readSchema
	int 1
	return

// readSchema(): void
readSchema:
	proto 0 0

	// tests/contracts/general.algo.ts:424
	// assert(SchemaContract.schema.global.numUint === 1)
	int 1
	dup
	==
	assert

	// tests/contracts/general.algo.ts:425
	// assert(SchemaContract.schema.global.numByteSlice === 2)
	int 2
	dup
	==
	assert

	// tests/contracts/general.algo.ts:426
	// assert(SchemaContract.schema.local.numUint === 3)
	pushint 3
	pushint 3
	==
	assert

	// tests/contracts/general.algo.ts:427
	// assert(SchemaContract.schema.local.numByteSlice === 4)
	int 4
	dup
	==
	assert
	retsub

// comparisonOr()bool
*abi_route_comparisonOr:
	// The ABI return prefix
	byte 0x151f7c75

	// execute comparisonOr()bool
	callsub comparisonOr
	pushbytes 0x00
	int 0
	uncover 2
	setbit
	concat
	log
	int 1
	return

// comparisonOr(): boolean
comparisonOr:
	proto 0 1

	// tests/contracts/general.algo.ts:431
	// return this.txn.sender === globals.zeroAddress || this.txn.sender === globals.zeroAddress;
	txn Sender
	global ZeroAddress
	==
	dup
	bnz *skip_or0
	txn Sender
	global ZeroAddress
	==
	||

*skip_or0:
	retsub

// txnArgsMethod(pay)void
*abi_route_txnArgsMethod:
	// _pay1: pay
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// argument 0 (_pay1) for txnArgsMethod must be a pay transaction
	assert

	// execute txnArgsMethod(pay)void
	callsub txnArgsMethod
	int 1
	return

// txnArgsMethod(_pay1: PayTxn): void
txnArgsMethod:
	proto 1 0
	retsub

// callTxnArgsMethod()void
*abi_route_callTxnArgsMethod:
	// execute callTxnArgsMethod()void
	callsub callTxnArgsMethod
	int 1
	return

// callTxnArgsMethod(): void
callTxnArgsMethod:
	proto 0 0

	// tests/contracts/general.algo.ts:438
	// sendMethodCall<typeof GeneralTest.prototype.txnArgsMethod>({
	//       methodArgs: [{ receiver: this.app.address, amount: 0 }],
	//     })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// tests/contracts/general.algo.ts:439
	// receiver: this.app.address
	global CurrentApplicationAddress
	itxn_field Receiver

	// tests/contracts/general.algo.ts:439
	// amount: 0
	int 0
	itxn_field Amount

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee
	itxn_next
	int 6 // appl
	itxn_field TypeEnum
	byte 0x2c636eeb // method "txnArgsMethod(pay)void"
	itxn_field ApplicationArgs

	// tests/contracts/general.algo.ts:439
	// methodArgs: [{ receiver: this.app.address, amount: 0 }]
	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// staticValueLen(uint256)void
*abi_route_staticValueLen:
	// x: uint256
	txna ApplicationArgs 1
	dup
	len
	pushint 32
	==

	// argument 0 (x) for staticValueLen must be a uint256
	assert

	// execute staticValueLen(uint256)void
	callsub staticValueLen
	int 1
	return

// staticValueLen(x: uint256): void
staticValueLen:
	proto 1 0

	// tests/contracts/general.algo.ts:444
	// assert(len(x))
	pushint 32
	assert
	retsub

// staticTypeLen()void
*abi_route_staticTypeLen:
	// execute staticTypeLen()void
	callsub staticTypeLen
	int 1
	return

// staticTypeLen(): void
staticTypeLen:
	proto 0 0

	// tests/contracts/general.algo.ts:448
	// assert(len<uint256>())
	pushint 32
	assert
	retsub

// dynamicScratchSlot()void
*abi_route_dynamicScratchSlot:
	// execute dynamicScratchSlot()void
	callsub dynamicScratchSlot
	int 1
	return

// dynamicScratchSlot(): void
dynamicScratchSlot:
	proto 0 0

	// tests/contracts/general.algo.ts:452
	// this.dynamicScratch(1).value = 1337
	int 1
	int 1337
	stores

	// tests/contracts/general.algo.ts:453
	// assert(this.dynamicScratch(1).value === 1337)
	int 1
	loads
	int 1337
	==
	assert
	retsub

// incrementScratchSlot()void
*abi_route_incrementScratchSlot:
	// execute incrementScratchSlot()void
	callsub incrementScratchSlot
	int 1
	return

// incrementScratchSlot(): void
incrementScratchSlot:
	proto 0 0

	// tests/contracts/general.algo.ts:457
	// this.scratch.value = 1337
	int 1337
	store 0

	// tests/contracts/general.algo.ts:458
	// this.scratch.value += 1
	load 0
	int 1
	+
	store 0

	// tests/contracts/general.algo.ts:459
	// assert(this.scratch.value === 1338)
	load 0
	pushint 1338
	==
	assert
	retsub

// incrementDynamicScratchSlot()void
*abi_route_incrementDynamicScratchSlot:
	// execute incrementDynamicScratchSlot()void
	callsub incrementDynamicScratchSlot
	int 1
	return

// incrementDynamicScratchSlot(): void
incrementDynamicScratchSlot:
	proto 0 0

	// tests/contracts/general.algo.ts:463
	// this.dynamicScratch(2).value = 1337
	int 2
	int 1337
	stores

	// tests/contracts/general.algo.ts:464
	// this.dynamicScratch(2).value += 1
	int 2
	loads
	int 1
	+
	int 2
	swap
	stores

	// tests/contracts/general.algo.ts:465
	// assert(this.dynamicScratch(2).value === 1338)
	int 2
	loads
	pushint 1338
	==
	assert
	retsub

// fromAddress()void
*abi_route_fromAddress:
	// execute fromAddress()void
	callsub fromAddress
	int 1
	return

// fromAddress(): void
fromAddress:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/general.algo.ts:469
	// a = Address.fromAddress('AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAY5HFKQ')
	byte 0x0000000000000000000000000000000000000000000000000000000000000000 // addr "AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAY5HFKQ"
	frame_bury 0 // a: address

	// tests/contracts/general.algo.ts:470
	// assert(a === Address.zeroAddress)
	frame_dig 0 // a: address
	global ZeroAddress
	==
	assert
	retsub

// earlyReturn(uint64)uint64
*abi_route_earlyReturn:
	// The ABI return prefix
	byte 0x151f7c75

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute earlyReturn(uint64)uint64
	callsub earlyReturn
	itob
	concat
	log
	int 1
	return

// earlyReturn(a: uint64): uint64
earlyReturn:
	proto 1 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// *if1_condition
	// tests/contracts/general.algo.ts:474
	// a === 1
	frame_dig -1 // a: uint64
	int 1
	==
	bz *if1_end

	// *if1_consequent
	// tests/contracts/general.algo.ts:475
	// return 2;
	int 2
	b *earlyReturn*return

*if1_end:
	// tests/contracts/general.algo.ts:477
	// b = a + 1
	frame_dig -1 // a: uint64
	int 1
	+
	frame_bury 0 // b: uint64

	// tests/contracts/general.algo.ts:478
	// return b;
	frame_dig 0 // b: uint64

*earlyReturn*return:
	// set the subroutine return value
	frame_bury 0
	retsub

// assetMethodArgs()void
*abi_route_assetMethodArgs:
	// execute assetMethodArgs()void
	callsub assetMethodArgs
	int 1
	return

// assetMethodArgs(): void
assetMethodArgs:
	proto 0 0

	// tests/contracts/general.algo.ts:482
	// sendMethodCall<[AssetReference], void>({
	//       name: 'foo',
	//       methodArgs: [AssetID.fromUint64(1)],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	pushbytes 0xa15316de // method "foo(asset)void"
	itxn_field ApplicationArgs

	// tests/contracts/general.algo.ts:484
	// methodArgs: [AssetID.fromUint64(1)]
	int 1
	itxn_field Assets
	pushbytes 0x0000000000000000
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// multipleProgramPages()void
*abi_route_multipleProgramPages:
	// execute multipleProgramPages()void
	callsub multipleProgramPages
	int 1
	return

// multipleProgramPages(): void
multipleProgramPages:
	proto 0 0

	// tests/contracts/general.algo.ts:493
	// sendAppCall({
	//       approvalProgram: [this.pageOne.value, this.pageTwo.value],
	//       clearStateProgram: [this.pageOne.value, this.pageTwo.value],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum

	// tests/contracts/general.algo.ts:494
	// approvalProgram: [this.pageOne.value, this.pageTwo.value]
	byte 0x706167654f6e65 // "pageOne"
	box_get

	// box value does not exist: this.pageOne.value
	assert
	itxn_field ApprovalProgramPages
	byte 0x7061676554776f // "pageTwo"
	box_get

	// box value does not exist: this.pageTwo.value
	assert
	itxn_field ApprovalProgramPages

	// tests/contracts/general.algo.ts:495
	// clearStateProgram: [this.pageOne.value, this.pageTwo.value]
	byte 0x706167654f6e65 // "pageOne"
	box_get

	// box value does not exist: this.pageOne.value
	assert
	itxn_field ClearStateProgramPages
	byte 0x7061676554776f // "pageTwo"
	box_get

	// box value does not exist: this.pageTwo.value
	assert
	itxn_field ClearStateProgramPages

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// assertComment()void
*abi_route_assertComment:
	// execute assertComment()void
	callsub assertComment
	int 1
	return

// assertComment(): void
assertComment:
	proto 0 0

	// tests/contracts/general.algo.ts:500
	// assert(false, 'this is false')
	int 0

	// this is false
	assert
	retsub

// throwErrorMessage()void
*abi_route_throwErrorMessage:
	// execute throwErrorMessage()void
	callsub throwErrorMessage
	int 1
	return

// throwErrorMessage(): void
throwErrorMessage:
	proto 0 0

	// this is an error
	err
	retsub

// orLiteralType(uint64,uint64)void
*abi_route_orLiteralType:
	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute orLiteralType(uint64,uint64)void
	callsub orLiteralType
	int 1
	return

// orLiteralType(a: uint64, b: uint64): void
orLiteralType:
	proto 2 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// tests/contracts/general.algo.ts:508
	// foo = a && b === 1 ? 2 : 0
	frame_dig -1 // a: uint64
	dup
	bz *skip_and0
	frame_dig -2 // b: uint64
	int 1
	==
	&&

*skip_and0:
	bz *ternary0_false
	int 2
	b *ternary0_end

*ternary0_false:
	int 0

*ternary0_end:
	frame_bury 0 // foo: uint64

	// tests/contracts/general.algo.ts:509
	// assert(foo)
	frame_dig 0 // foo: uint64
	assert

	// tests/contracts/general.algo.ts:511
	// bar = a && b === 0 ? '2' : '0'
	frame_dig -1 // a: uint64
	dup
	bz *skip_and1
	frame_dig -2 // b: uint64
	int 0
	==
	&&

*skip_and1:
	bz *ternary1_false
	pushbytes 0x32 // "2"
	b *ternary1_end

*ternary1_false:
	byte 0x30 // "0"

*ternary1_end:
	frame_bury 1 // bar: byte[]

	// tests/contracts/general.algo.ts:512
	// log(bar)
	frame_dig 1 // bar: byte[]
	log
	retsub

// nonAbi(): void
nonAbi:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/general.algo.ts:517
	// assert(this.txn.applicationArgs!.length)
	txn NumAppArgs
	assert

	// tests/contracts/general.algo.ts:519
	// for (let i = 0; i < this.txn.applicationArgs!.length; i += 1)
	int 0
	frame_bury 0 // i: uint64

*for_1:
	// tests/contracts/general.algo.ts:519
	// i < this.txn.applicationArgs!.length
	frame_dig 0 // i: uint64
	txn NumAppArgs
	<
	bz *for_1_end

	// tests/contracts/general.algo.ts:520
	// log(this.txn.applicationArgs![i])
	frame_dig 0 // i: uint64
	txnas ApplicationArgs
	log

*for_1_continue:
	// tests/contracts/general.algo.ts:519
	// i += 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64
	b *for_1

*for_1_end:
	retsub

// multilineFunctionCall()void
*abi_route_multilineFunctionCall:
	// execute multilineFunctionCall()void
	callsub multilineFunctionCall
	int 1
	return

// multilineFunctionCall(): void
multilineFunctionCall:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// tests/contracts/general.algo.ts:525
	// app = AppID.zeroIndex
	int 0
	frame_bury 0 // app: uint64

	// tests/contracts/general.algo.ts:526
	// addr = Address.zeroAddress
	global ZeroAddress
	frame_bury 1 // addr: address

	// tests/contracts/general.algo.ts:528
	// app.localState(
	//       addr,
	//       'key'
	//     )
	frame_dig 1 // addr: address
	int 0 // app: uint64
	pushbytes 0x6b6579 // "key"
	app_local_get_ex

	// local state value does not exist: app.localState( addr, 'key' )
	assert
	retsub

// a()uint64
*abi_route_a:
	// The ABI return prefix
	byte 0x151f7c75

	// execute a()uint64
	callsub a
	itob
	concat
	log
	int 1
	return

// a(): uint64
a:
	proto 0 1

	// tests/contracts/general.algo.ts:535
	// return 3;
	pushint 3
	retsub

// b()uint64
*abi_route_b:
	// The ABI return prefix
	byte 0x151f7c75

	// execute b()uint64
	callsub b
	itob
	concat
	log
	int 1
	return

// b(): uint64
b:
	proto 0 1

	// tests/contracts/general.algo.ts:539
	// return 5;
	int 5
	retsub

// unusedMethodValue()uint64
*abi_route_unusedMethodValue:
	// The ABI return prefix
	byte 0x151f7c75

	// execute unusedMethodValue()uint64
	callsub unusedMethodValue
	itob
	concat
	log
	int 1
	return

// unusedMethodValue(): uint64
unusedMethodValue:
	proto 0 1

	// tests/contracts/general.algo.ts:543
	// this.a()
	callsub a
	pop

	// tests/contracts/general.algo.ts:544
	// return this.b();
	callsub b
	retsub

// reassignedNonFirstVar()uint64
*abi_route_reassignedNonFirstVar:
	// The ABI return prefix
	byte 0x151f7c75

	// execute reassignedNonFirstVar()uint64
	callsub reassignedNonFirstVar
	itob
	concat
	log
	int 1
	return

// reassignedNonFirstVar(): uint64
reassignedNonFirstVar:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// tests/contracts/general.algo.ts:555
	// a = 1 as uint64
	int 1
	frame_bury 0 // a: uint64

	// tests/contracts/general.algo.ts:556
	// b = this.app.id
	txna Applications 0
	frame_bury 1 // b: uint64

	// *if2_condition
	// tests/contracts/general.algo.ts:557
	// a
	frame_dig 0 // a: uint64
	bz *if2_end

	// *if2_consequent
	// tests/contracts/general.algo.ts:558
	// b = 2
	int 2
	frame_bury 1 // b: uint64

*if2_end:
	// tests/contracts/general.algo.ts:561
	// return b;
	frame_dig 1 // b: uint64

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 1
	retsub

// fvLv()void
*abi_route_fvLv:
	// execute fvLv()void
	callsub fvLv
	int 1
	return

// fvLv(): void
fvLv:
	proto 0 0

	// tests/contracts/general.algo.ts:565
	// assert(this.txn.firstValid)
	txn FirstValid
	assert

	// tests/contracts/general.algo.ts:566
	// assert(this.txn.lastValid)
	txn LastValid
	assert
	retsub

*abi_route_createApplication:
	int 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x624264a3 // method "txnTypeEnum()void"
	pushbytes 0xb205edc9 // method "txnGroupLength()void"
	pushbytes 0xe6e97d5b // method "asserts(bool,bool)void"
	pushbytes 0xdd6fa7c8 // method "verifyTxnFromArg(pay)void"
	pushbytes 0x0ea644fb // method "verifyTxnFromTxnGroup()void"
	pushbytes 0xec0d9094 // method "verifyTxnCondition()void"
	pushbytes 0x68848d97 // method "verifyTxnIncludedIn()void"
	pushbytes 0x18bd23dc // method "verifyTxnNotIncludedIn()void"
	pushbytes 0x806bfb93 // method "submitPendingGroup()void"
	pushbytes 0x3be5f82e // method "methodWithTxnArgs()void"
	pushbytes 0x1295d683 // method "shift()void"
	pushbytes 0xb3b8c472 // method "fromBytes()void"
	pushbytes 0x53e0b6f0 // method "fromUint64()void"
	pushbytes 0x4b3eb877 // method "bzeroFunction()void"
	pushbytes 0xdac2e7a5 // method "events()void"
	pushbytes 0xa3db6704 // method "letOptimization(uint64[])uint64[]"
	pushbytes 0xae21c172 // method "staticContractProperties()void"
	pushbytes 0xdab4d1c4 // method "numberToString()void"
	pushbytes 0xa7b4ae9a // method "methodOnParens()void"
	pushbytes 0x6d4485ba // method "stringSubstring()void"
	pushbytes 0xef6262e9 // method "idProperty()void"
	pushbytes 0x8d2b668b // method "scratchSlot()void"
	pushbytes 0xe6c154fc // method "ecdsa()void"
	pushbytes 0xa9764197 // method "verifyTxnTypes()void"
	pushbytes 0x9dbbc42c // method "stringPlusEquals()void"
	pushbytes 0x4c0ddec1 // method "importedProgram()byte[]"
	pushbytes 0x30ecfb41 // method "callPrivateDefinedLater()void"
	pushbytes 0x14a49919 // method "interalPublicMethod(uint64,uint64)uint64"
	pushbytes 0xb71c179a // method "callInternalPublicMethod()void"
	pushbytes 0x98481093 // method "appLoadScratch()void"
	pushbytes 0xf572d1c1 // method "uintNWithUnderscore()uint256"
	pushbytes 0x854dede0 // method "opUp()void"
	pushbytes 0x681599fa // method "returnValueOnAssignment()string"
	pushbytes 0x5e1477e8 // method "returnArrayValueOnAssignment()uint64"
	pushbytes 0xe07b3be9 // method "returnStorageValueOnAssignment()uint64"
	pushbytes 0x16e46657 // method "returnOperatorAssignmentValue()uint64"
	pushbytes 0x2c836f46 // method "returnArrayValueOnOperatorAssignment()uint64"
	pushbytes 0xa93c56f9 // method "returnArrayInStorageValueOnOperatorAssignment()uint64"
	pushbytes 0xf936952d // method "consts()void"
	pushbytes 0x88f39c99 // method "assertWithMessage()void"
	pushbytes 0x58794cf4 // method "opcodeAliases()void"
	pushbytes 0x35044ad8 // method "vrfVerifyOp()void"
	pushbytes 0x7d279e8e // method "ecMath()void"
	pushbytes 0x3dfa18c8 // method "gitxn()void"
	pushbytes 0x78ca5c4e // method "getSetBytes()void"
	pushbytes 0x0e67e957 // method "getSetUint64()void"
	pushbytes 0x3b446eef // method "blockOp()void"
	pushbytes 0xae82e875 // method "b64()void"
	pushbytes 0xd69af530 // method "json()void"
	pushbytes 0x4d52f33d // method "bitlenOp()void"
	pushbytes 0x2c0cd201 // method "computedConst()void"
	pushbytes 0x70e0afe5 // method "multiComputedConst()void"
	pushbytes 0x30a2fef4 // method "readSchema()void"
	pushbytes 0xf3971dca // method "comparisonOr()bool"
	byte 0x2c636eeb // method "txnArgsMethod(pay)void"
	pushbytes 0x9e40d34b // method "callTxnArgsMethod()void"
	pushbytes 0x91cf2b58 // method "staticValueLen(uint256)void"
	pushbytes 0xb1c8b45c // method "staticTypeLen()void"
	pushbytes 0x9c0e1bdb // method "dynamicScratchSlot()void"
	pushbytes 0x0a319504 // method "incrementScratchSlot()void"
	pushbytes 0x84b260fa // method "incrementDynamicScratchSlot()void"
	pushbytes 0x4a908856 // method "fromAddress()void"
	pushbytes 0x8deb32d3 // method "earlyReturn(uint64)uint64"
	pushbytes 0x67de156f // method "assetMethodArgs()void"
	pushbytes 0x1e428412 // method "multipleProgramPages()void"
	pushbytes 0x278fd8b8 // method "assertComment()void"
	pushbytes 0xbfc36208 // method "throwErrorMessage()void"
	pushbytes 0x04eedf79 // method "orLiteralType(uint64,uint64)void"
	pushbytes 0x35d5fbc7 // method "multilineFunctionCall()void"
	pushbytes 0xf9522e2f // method "a()uint64"
	pushbytes 0x8c9379e6 // method "b()uint64"
	pushbytes 0xf9a13552 // method "unusedMethodValue()uint64"
	pushbytes 0x94f2049a // method "reassignedNonFirstVar()uint64"
	pushbytes 0x56264215 // method "fvLv()void"
	txna ApplicationArgs 0
	match *abi_route_txnTypeEnum *abi_route_txnGroupLength *abi_route_asserts *abi_route_verifyTxnFromArg *abi_route_verifyTxnFromTxnGroup *abi_route_verifyTxnCondition *abi_route_verifyTxnIncludedIn *abi_route_verifyTxnNotIncludedIn *abi_route_submitPendingGroup *abi_route_methodWithTxnArgs *abi_route_shift *abi_route_fromBytes *abi_route_fromUint64 *abi_route_bzeroFunction *abi_route_events *abi_route_letOptimization *abi_route_staticContractProperties *abi_route_numberToString *abi_route_methodOnParens *abi_route_stringSubstring *abi_route_idProperty *abi_route_scratchSlot *abi_route_ecdsa *abi_route_verifyTxnTypes *abi_route_stringPlusEquals *abi_route_importedProgram *abi_route_callPrivateDefinedLater *abi_route_interalPublicMethod *abi_route_callInternalPublicMethod *abi_route_appLoadScratch *abi_route_uintNWithUnderscore *abi_route_opUp *abi_route_returnValueOnAssignment *abi_route_returnArrayValueOnAssignment *abi_route_returnStorageValueOnAssignment *abi_route_returnOperatorAssignmentValue *abi_route_returnArrayValueOnOperatorAssignment *abi_route_returnArrayInStorageValueOnOperatorAssignment *abi_route_consts *abi_route_assertWithMessage *abi_route_opcodeAliases *abi_route_vrfVerifyOp *abi_route_ecMath *abi_route_gitxn *abi_route_getSetBytes *abi_route_getSetUint64 *abi_route_blockOp *abi_route_b64 *abi_route_json *abi_route_bitlenOp *abi_route_computedConst *abi_route_multiComputedConst *abi_route_readSchema *abi_route_comparisonOr *abi_route_txnArgsMethod *abi_route_callTxnArgsMethod *abi_route_staticValueLen *abi_route_staticTypeLen *abi_route_dynamicScratchSlot *abi_route_incrementScratchSlot *abi_route_incrementDynamicScratchSlot *abi_route_fromAddress *abi_route_earlyReturn *abi_route_assetMethodArgs *abi_route_multipleProgramPages *abi_route_assertComment *abi_route_throwErrorMessage *abi_route_orLiteralType *abi_route_multilineFunctionCall *abi_route_a *abi_route_b *abi_route_unusedMethodValue *abi_route_reassignedNonFirstVar *abi_route_fvLv

	// !!!! WARNING: non-ABI routing
	callsub nonAbi
	int 1
	return

*intToAscii:
	proto 1 1
	pushbytes 0x30313233343536373839 // "0123456789"
	frame_dig -1 // i: uint64
	int 1
	extract3
	retsub
	

*itoa:
	proto 1 1
	frame_dig -1 // i: uint64
	int 0
	==
	bz *itoa_if_end
	byte 0x30
	retsub

*itoa_if_end:
	frame_dig -1 // i: uint64
	pushint 10
	/
	int 0
	>
	bz *itoa_ternary_false
	frame_dig -1 // i: uint64
	pushint 10
	/
	callsub *itoa
	b *itoa_ternary_end

*itoa_ternary_false:
	byte 0x // ""

*itoa_ternary_end:
	frame_dig -1 // i: uint64
	pushint 10
	%
	callsub *intToAscii
	concat
	retsub", + "approval": "#pragma version 10
intcblock 1 0 6 1337 2 5 123 4
bytecblock 0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 0x0000000000000000000000000000000000000000000000000000000000000000 0x000000000000000100000000000000020000000000000003 0x151f7c75 0x0a8101 0x73746f726167654172726179 0x 0x666f6f 0x000000000000000000 0x0000000000000001 0x706167654f6e65 0x7061676554776f 0x674b6579 0x2c636eeb 0x626172 0x627965 0x0000 0x30

// This TEAL was generated by TEALScript v0.105.0
// https://github.com/algorandfoundation/TEALScript

// !!!! WARNING: This contract is *NOT* ARC4 compliant. It may contain ABI methods, but it also allows app calls where the first argument does NOT match an ABI selector

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
int 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// txnTypeEnum()void
*abi_route_txnTypeEnum:
	// execute txnTypeEnum()void
	callsub txnTypeEnum
	int 1
	return

// txnTypeEnum(): void
txnTypeEnum:
	proto 0 0

	// tests/contracts/general.algo.ts:69
	// assert(this.txnGroup[0].typeEnum === TransactionType.ApplicationCall)
	int 0
	gtxns TypeEnum
	int 6 // appl
	==
	assert
	retsub

// txnGroupLength()void
*abi_route_txnGroupLength:
	// execute txnGroupLength()void
	callsub txnGroupLength
	int 1
	return

// txnGroupLength(): void
txnGroupLength:
	proto 0 0

	// tests/contracts/general.algo.ts:73
	// assert(this.txnGroup.length === 1)
	global GroupSize
	int 1
	==
	assert
	retsub

// asserts(bool,bool)void
*abi_route_asserts:
	// arg2: bool
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 0 (arg2) for asserts must be a bool
	assert
	int 0
	getbit

	// arg1: bool
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 1 (arg1) for asserts must be a bool
	assert
	int 0
	getbit

	// execute asserts(bool,bool)void
	callsub asserts
	int 1
	return

// asserts(arg1: boolean, arg2: boolean): void
asserts:
	proto 2 0

	// tests/contracts/general.algo.ts:77
	// asserts(arg1, arg2, arg1 === arg2)
	frame_dig -1 // arg1: boolean

	// asserts failed: asserts(arg1, arg2, arg1 === arg2)
	assert
	frame_dig -2 // arg2: boolean

	// asserts failed: asserts(arg1, arg2, arg1 === arg2)
	assert
	frame_dig -1 // arg1: boolean
	frame_dig -2 // arg2: boolean
	==

	// asserts failed: asserts(arg1, arg2, arg1 === arg2)
	assert
	retsub

// verifyTxnFromArg(pay)void
*abi_route_verifyTxnFromArg:
	// somePay: pay
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// argument 0 (somePay) for verifyTxnFromArg must be a pay transaction
	assert

	// execute verifyTxnFromArg(pay)void
	callsub verifyTxnFromArg
	int 1
	return

// verifyTxnFromArg(somePay: PayTxn): void
verifyTxnFromArg:
	proto 1 0

	// tests/contracts/general.algo.ts:81
	// verifyTxn(somePay, { receiver: this.app.address, amount: 100_000 })
	// verify receiver
	frame_dig -1 // somePay: PayTxn
	gtxns Receiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"somePay","field":"receiver","expected":"this.app.address"}
	assert

	// verify amount
	frame_dig -1 // somePay: PayTxn
	gtxns Amount
	pushint 100_000
	==

	// transaction verification failed: {"txn":"somePay","field":"amount","expected":"100_000"}
	assert
	retsub

// verifyTxnFromTxnGroup()void
*abi_route_verifyTxnFromTxnGroup:
	// execute verifyTxnFromTxnGroup()void
	callsub verifyTxnFromTxnGroup
	int 1
	return

// verifyTxnFromTxnGroup(): void
verifyTxnFromTxnGroup:
	proto 0 0

	// tests/contracts/general.algo.ts:85
	// verifyTxn(this.txnGroup[0], { sender: this.txn.sender })
	// verify sender
	int 0
	gtxns Sender
	txn Sender
	==

	// transaction verification failed: {"txn":"this.txnGroup[0]","field":"sender","expected":"this.txn.sender"}
	assert
	retsub

// verifyTxnCondition()void
*abi_route_verifyTxnCondition:
	// execute verifyTxnCondition()void
	callsub verifyTxnCondition
	int 1
	return

// verifyTxnCondition(): void
verifyTxnCondition:
	proto 0 0

	// tests/contracts/general.algo.ts:89
	// verifyTxn(this.txn, {
	//       applicationID: { greaterThan: 1 },
	//     })
	// verify applicationID
	txn ApplicationID
	int 1
	>

	// transaction verification failed: {"txn":"this.txn","field":"applicationID","condition":"greaterThan","expected":">1"}
	assert
	retsub

// verifyTxnIncludedIn()void
*abi_route_verifyTxnIncludedIn:
	// execute verifyTxnIncludedIn()void
	callsub verifyTxnIncludedIn
	int 1
	return

// verifyTxnIncludedIn(): void
verifyTxnIncludedIn:
	proto 0 0

	// tests/contracts/general.algo.ts:95
	// verifyTxn(this.txn, {
	//       sender: { includedIn: [this.txn.sender] },
	//     })
	// verify sender
	txn Sender
	txn Sender
	==

	// transaction verification failed: {"txn":{"txnText":"this.txn"},"field":"sender","condition":"includedIn","expected":"[this.txn.sender]"}
	assert
	retsub

// verifyTxnNotIncludedIn()void
*abi_route_verifyTxnNotIncludedIn:
	// execute verifyTxnNotIncludedIn()void
	callsub verifyTxnNotIncludedIn
	int 1
	return

// verifyTxnNotIncludedIn(): void
verifyTxnNotIncludedIn:
	proto 0 0

	// tests/contracts/general.algo.ts:101
	// verifyTxn(this.txn, {
	//       sender: { notIncludedIn: [globals.zeroAddress] },
	//     })
	// verify sender
	txn Sender
	global ZeroAddress
	!=

	// transaction verification failed: {"txn":{"txnText":"this.txn"},"field":"sender","condition":"notIncludedIn","expected":"[globals.zeroAddress]"}
	assert
	retsub

// submitPendingGroup()void
*abi_route_submitPendingGroup:
	// execute submitPendingGroup()void
	callsub submitPendingGroup
	int 1
	return

// submitPendingGroup(): void
submitPendingGroup:
	proto 0 0

	// tests/contracts/general.algo.ts:107
	// this.pendingGroup.addPayment({ amount: 0, receiver: this.app.address, isFirstTxn: true })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// tests/contracts/general.algo.ts:107
	// amount: 0
	int 0
	itxn_field Amount

	// tests/contracts/general.algo.ts:107
	// receiver: this.app.address
	global CurrentApplicationAddress
	itxn_field Receiver

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// tests/contracts/general.algo.ts:108
	// this.pendingGroup.addPayment({ amount: 0, receiver: this.app.address, note: 'foo' })
	itxn_next
	int 1 // pay
	itxn_field TypeEnum

	// tests/contracts/general.algo.ts:108
	// amount: 0
	int 0
	itxn_field Amount

	// tests/contracts/general.algo.ts:108
	// receiver: this.app.address
	global CurrentApplicationAddress
	itxn_field Receiver

	// tests/contracts/general.algo.ts:108
	// note: 'foo'
	byte 0x666f6f // "foo"
	itxn_field Note

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// tests/contracts/general.algo.ts:109
	// this.pendingGroup.submit()
	itxn_submit
	retsub

// methodWithTxnArgs()void
*abi_route_methodWithTxnArgs:
	// execute methodWithTxnArgs()void
	callsub methodWithTxnArgs
	int 1
	return

// methodWithTxnArgs(): void
methodWithTxnArgs:
	proto 0 0

	// tests/contracts/general.algo.ts:113
	// sendMethodCall<[PayTxn, MethodCall<[uint64], void>], void>({
	//       name: 'foo',
	//       methodArgs: [
	//         { amount: 100_000, receiver: this.txn.sender },
	//         {
	//           name: 'bar',
	//           applicationID: AppID.fromUint64(1337),
	//           methodArgs: [1],
	//         },
	//       ],
	//     })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// tests/contracts/general.algo.ts:116
	// amount: 100_000
	pushint 100_000
	itxn_field Amount

	// tests/contracts/general.algo.ts:116
	// receiver: this.txn.sender
	txn Sender
	itxn_field Receiver

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee
	itxn_next
	int 6 // appl
	itxn_field TypeEnum
	pushbytes 0x0e8cb9f6 // method "bar(uint64)void"
	itxn_field ApplicationArgs

	// tests/contracts/general.algo.ts:119
	// applicationID: AppID.fromUint64(1337)
	int 1337
	itxn_field ApplicationID

	// tests/contracts/general.algo.ts:120
	// methodArgs: [1]
	byte 0x0000000000000001
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee
	itxn_next
	int 6 // appl
	itxn_field TypeEnum
	pushbytes 0x6c6f7a08 // method "foo(pay,appl)void"
	itxn_field ApplicationArgs

	// tests/contracts/general.algo.ts:115
	// methodArgs: [
	//         { amount: 100_000, receiver: this.txn.sender },
	//         {
	//           name: 'bar',
	//           applicationID: AppID.fromUint64(1337),
	//           methodArgs: [1],
	//         },
	//       ]
	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// shift()void
*abi_route_shift:
	// execute shift()void
	callsub shift
	int 1
	return

// shift(): void
shift:
	proto 0 0

	// tests/contracts/general.algo.ts:127
	// assert(1 << 2 === 4)
	int 1
	int 2
	shl
	int 4
	==
	assert

	// tests/contracts/general.algo.ts:128
	// assert(4 >> 1 === 2)
	int 4
	int 1
	shr
	int 2
	==
	assert
	retsub

// fromBytes()void
*abi_route_fromBytes:
	// execute fromBytes()void
	callsub fromBytes
	int 1
	return

// fromBytes(): void
fromBytes:
	proto 0 0

	// tests/contracts/general.algo.ts:132
	// assert(Address.fromBytes('abc').minBalance)
	pushbytes 0x616263 // "abc"
	acct_params_get AcctMinBalance
	pop
	assert
	retsub

// fromUint64()void
*abi_route_fromUint64:
	// execute fromUint64()void
	callsub fromUint64
	int 1
	return

// fromUint64(): void
fromUint64:
	proto 0 0

	// tests/contracts/general.algo.ts:136
	// log(AppID.fromUint64(123).creator)
	int 123
	app_params_get AppCreator
	pop
	log

	// tests/contracts/general.algo.ts:137
	// log(AssetID.fromUint64(123).creator)
	int 123
	asset_params_get AssetCreator
	pop
	log
	retsub

// bzeroFunction()void
*abi_route_bzeroFunction:
	// execute bzeroFunction()void
	callsub bzeroFunction
	int 1
	return

// bzeroFunction(): void
bzeroFunction:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// tests/contracts/general.algo.ts:142
	// x: bytes = bzero(2)
	byte 0x0000
	frame_bury 0 // x: bytes

	// tests/contracts/general.algo.ts:143
	// y: bytes = bzero(n)
	int 1
	bzero
	frame_bury 1 // y: bytes

	// tests/contracts/general.algo.ts:144
	// z: [uint64, uint<8>] = bzero<[uint64, uint<8>]>()
	byte 0x000000000000000000
	frame_bury 2 // z: [uint64, uint<8>]

	// tests/contracts/general.algo.ts:145
	// assert(len(x + y + z) === 12)
	byte 0x0000 // x: bytes
	frame_dig 1 // y: bytes
	concat
	byte 0x000000000000000000 // z: [uint64, uint<8>]
	concat
	len
	pushint 12
	==
	assert
	retsub

// events()void
*abi_route_events:
	// execute events()void
	callsub events
	int 1
	return

// events(): void
events:
	proto 0 0

	// tests/contracts/general.algo.ts:160
	// this.myEvent.log({ app: this.app, num: 1 })
	pushbytes 0x87528196 // myEvent(uint64,uint64)
	txna Applications 0
	itob
	byte 0x0000000000000001
	concat
	concat
	log
	retsub

// letOptimization(uint64[])uint64[]
*abi_route_letOptimization:
	// The ABI return prefix
	byte 0x151f7c75

	// a: uint64[]
	txna ApplicationArgs 1
	extract 2 0

	// execute letOptimization(uint64[])uint64[]
	callsub letOptimization
	dup
	len
	pushint 8
	/
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// letOptimization(a: uint64[]): uint64[]
letOptimization:
	proto 1 1

	// tests/contracts/general.algo.ts:164
	// assert(a[0])
	frame_dig -1 // a: uint64[]
	store 255 // full array
	load 255 // full array
	extract 0 8
	btoi
	assert

	// tests/contracts/general.algo.ts:166
	// b = [1, 2, 3]
	byte 0x000000000000000100000000000000020000000000000003
	frame_bury -1 // b: uint64[]

	// tests/contracts/general.algo.ts:168
	// return b;
	frame_dig -1 // a: uint64[]
	retsub

// staticContractProperties()void
*abi_route_staticContractProperties:
	// execute staticContractProperties()void
	callsub staticContractProperties
	int 1
	return

// staticContractProperties(): void
staticContractProperties:
	proto 0 0

	// tests/contracts/general.algo.ts:172
	// sendAppCall({
	//       onCompletion: OnCompletion.NoOp,
	//       approvalProgram: DummyContract.approvalProgram(),
	//       clearStateProgram: DummyContract.clearProgram(),
	//       localNumByteSlice: DummyContract.schema.local.numByteSlice,
	//       localNumUint: DummyContract.schema.local.numUint,
	//       globalNumByteSlice: DummyContract.schema.global.numByteSlice,
	//       globalNumUint: DummyContract.schema.global.numUint,
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum

	// tests/contracts/general.algo.ts:173
	// onCompletion: OnCompletion.NoOp
	int 0 // NoOp
	itxn_field OnCompletion

	// tests/contracts/general.algo.ts:174
	// approvalProgram: DummyContract.approvalProgram()
	pushbytes 0x0a31181481060b3119088d0c000000000000000000000000000400000000000000000000008101438004b8447b36361a008e01fff000
	itxn_field ApprovalProgram

	// tests/contracts/general.algo.ts:175
	// clearStateProgram: DummyContract.clearProgram()
	pushbytes 0x0a
	itxn_field ClearStateProgram

	// tests/contracts/general.algo.ts:176
	// localNumByteSlice: DummyContract.schema.local.numByteSlice
	int 0
	itxn_field LocalNumByteSlice

	// tests/contracts/general.algo.ts:177
	// localNumUint: DummyContract.schema.local.numUint
	int 0
	itxn_field LocalNumUint

	// tests/contracts/general.algo.ts:178
	// globalNumByteSlice: DummyContract.schema.global.numByteSlice
	int 0
	itxn_field GlobalNumByteSlice

	// tests/contracts/general.algo.ts:179
	// globalNumUint: DummyContract.schema.global.numUint
	int 0
	itxn_field GlobalNumUint

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// numberToString()void
*abi_route_numberToString:
	// execute numberToString()void
	callsub numberToString
	int 1
	return

// numberToString(): void
numberToString:
	proto 0 0

	// tests/contracts/general.algo.ts:186
	// assert(n.toString() === s)
	int 1
	callsub *itoa
	pushbytes "1"
	==
	assert
	retsub

// methodOnParens()void
*abi_route_methodOnParens:
	// execute methodOnParens()void
	callsub methodOnParens
	int 1
	return

// methodOnParens(): void
methodOnParens:
	proto 0 0

	// tests/contracts/general.algo.ts:190
	// assert((1 + 2).toString() === '3')
	pushint 3
	callsub *itoa
	pushbytes 0x33 // "3"
	==
	assert
	retsub

// stringSubstring()void
*abi_route_stringSubstring:
	// execute stringSubstring()void
	callsub stringSubstring
	int 1
	return

// stringSubstring(): void
stringSubstring:
	proto 0 0

	// tests/contracts/general.algo.ts:195
	// assert(s.substring(1, 3) === 'bc')
	pushbytes "abcdef"
	substring 1 3
	pushbytes 0x6263 // "bc"
	==
	assert
	retsub

// idProperty()void
*abi_route_idProperty:
	// execute idProperty()void
	callsub idProperty
	int 1
	return

// idProperty(): void
idProperty:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// tests/contracts/general.algo.ts:199
	// app = AppID.zeroIndex
	int 0
	frame_bury 0 // app: uint64

	// tests/contracts/general.algo.ts:200
	// assert(AppID.fromUint64(app.id) === app)
	int 0 // app: uint64
	dup
	==
	assert

	// tests/contracts/general.algo.ts:202
	// asa = AssetID.zeroIndex
	int 0
	frame_bury 1 // asa: uint64

	// tests/contracts/general.algo.ts:203
	// assert(AssetID.fromUint64(asa.id) === asa)
	int 0 // asa: uint64
	dup
	==
	assert
	retsub

// scratchSlot()void
*abi_route_scratchSlot:
	// execute scratchSlot()void
	callsub scratchSlot
	int 1
	return

// scratchSlot(): void
scratchSlot:
	proto 0 0

	// tests/contracts/general.algo.ts:207
	// this.scratch.value = 1337
	int 1337
	store 0

	// tests/contracts/general.algo.ts:208
	// assert(this.scratch.value === 1337)
	load 0
	int 1337
	==
	assert
	retsub

// ecdsa()void
*abi_route_ecdsa:
	// execute ecdsa()void
	callsub ecdsa
	int 1
	return

// ecdsa(): void
ecdsa:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 3

	// tests/contracts/general.algo.ts:212
	// ecdsaVerify('Secp256k1', '' as bytes32, '' as bytes32, '' as bytes32, '' as bytes32, '' as bytes32)
	byte 0x0000000000000000000000000000000000000000000000000000000000000000 // ""
	dupn 4
	ecdsa_verify Secp256k1

	// tests/contracts/general.algo.ts:213
	// d = ecdsaPkDecompress('Secp256k1', '' as bytes<33>)
	pushbytes 0x000000000000000000000000000000000000000000000000000000000000000000 // ""
	ecdsa_pk_decompress Secp256k1
	frame_bury 0 // d y component: byte[]
	frame_bury 1 // d x component: byte[]

	// tests/contracts/general.algo.ts:214
	// log(d.y)
	frame_dig 0 // d y component: byte[]
	log

	// tests/contracts/general.algo.ts:215
	// log(d.x)
	frame_dig 1 // d x component: byte[]
	log

	// tests/contracts/general.algo.ts:217
	// r = ecdsaPkRecover('Secp256k1', '' as bytes32, 1, '' as bytes32, '' as bytes32)
	byte 0x0000000000000000000000000000000000000000000000000000000000000000 // ""
	int 1
	byte 0x0000000000000000000000000000000000000000000000000000000000000000 // ""
	dup
	ecdsa_pk_recover Secp256k1
	frame_bury 2 // r y component: byte[]
	frame_bury 3 // r x component: byte[]

	// tests/contracts/general.algo.ts:218
	// log(r.y)
	frame_dig 2 // r y component: byte[]
	log

	// tests/contracts/general.algo.ts:219
	// log(r.x)
	frame_dig 3 // r x component: byte[]
	log
	retsub

// verifyTxnTypes()void
*abi_route_verifyTxnTypes:
	// execute verifyTxnTypes()void
	callsub verifyTxnTypes
	int 1
	return

// verifyTxnTypes(): void
verifyTxnTypes:
	proto 0 0

	// tests/contracts/general.algo.ts:223
	// verifyPayTxn(this.txnGroup[0], {
	//       amount: { greaterThan: 0 },
	//     })
	// verify pay
	int 0
	gtxns TypeEnum
	int 1 // pay
	==

	// transaction verification failed: {"txn":"this.txnGroup[0]","field":"typeEnum","expected":"pay"}
	assert

	// verify amount
	int 0
	gtxns Amount
	int 0
	>

	// transaction verification failed: {"txn":"this.txnGroup[0]","field":"amount","condition":"greaterThan","expected":">0"}
	assert

	// tests/contracts/general.algo.ts:227
	// verifyAppCallTxn(this.txnGroup[0], {
	//       applicationID: AppID.fromUint64(0),
	//       applicationArgs: {
	//         0: 'foo',
	//         1: {
	//           includedIn: ['bar', 'baz'],
	//         },
	//       },
	//     })
	// verify appl
	int 0
	gtxns TypeEnum
	int 6 // appl
	==

	// transaction verification failed: {"txn":"this.txnGroup[0]","field":"typeEnum","expected":"appl"}
	assert

	// verify applicationID
	int 0
	gtxns ApplicationID
	int 0
	==

	// transaction verification failed: {"txn":"this.txnGroup[0]","field":"applicationID","expected":"AppID.fromUint64(0)"}
	assert

	// verify applicationArgs
	// verify applicationArgs 0
	int 0
	gtxns ApplicationArgs 0
	byte 0x666f6f // "foo"
	==

	// transaction verification failed: {"txn":"this.txnGroup[0]","field":"applicationArgs","index":"0","expected":"'foo'"}
	assert

	// verify applicationArgs 1
	int 0
	gtxns ApplicationArgs 1
	byte 0x626172 // "bar"
	==
	int 0
	gtxns ApplicationArgs 1
	pushbytes 0x62617a // "baz"
	==
	||

	// transaction verification failed: {"txn":{"txnText":"this.txnGroup[0]"},"field":"applicationArgs 1","condition":"includedIn","expected":"['bar', 'baz']"}
	assert

	// tests/contracts/general.algo.ts:237
	// verifyAssetTransferTxn(this.txnGroup[0], {
	//       assetReceiver: this.app.address,
	//     })
	// verify axfer
	int 0
	gtxns TypeEnum
	int 4 // axfer
	==

	// transaction verification failed: {"txn":"this.txnGroup[0]","field":"typeEnum","expected":"axfer"}
	assert

	// verify assetReceiver
	int 0
	gtxns AssetReceiver
	global CurrentApplicationAddress
	==

	// transaction verification failed: {"txn":"this.txnGroup[0]","field":"assetReceiver","expected":"this.app.address"}
	assert

	// tests/contracts/general.algo.ts:241
	// verifyAssetConfigTxn(this.txnGroup[0], {
	//       configAsset: AssetID.fromUint64(0),
	//     })
	// verify acfg
	int 0
	gtxns TypeEnum
	pushint 3 // acfg
	==

	// transaction verification failed: {"txn":"this.txnGroup[0]","field":"typeEnum","expected":"acfg"}
	assert

	// verify configAsset
	int 0
	gtxns ConfigAsset
	int 0
	==

	// transaction verification failed: {"txn":"this.txnGroup[0]","field":"configAsset","expected":"AssetID.fromUint64(0)"}
	assert

	// tests/contracts/general.algo.ts:245
	// verifyKeyRegTxn(this.txnGroup[0], {
	//       voteFirst: 1337,
	//     })
	// verify keyreg
	int 0
	gtxns TypeEnum
	int 2 // keyreg
	==

	// transaction verification failed: {"txn":"this.txnGroup[0]","field":"typeEnum","expected":"keyreg"}
	assert

	// verify voteFirst
	int 0
	gtxns VoteFirst
	int 1337
	==

	// transaction verification failed: {"txn":"this.txnGroup[0]","field":"voteFirst","expected":"1337"}
	assert
	retsub

// stringPlusEquals()void
*abi_route_stringPlusEquals:
	// execute stringPlusEquals()void
	callsub stringPlusEquals
	int 1
	return

// stringPlusEquals(): void
stringPlusEquals:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/general.algo.ts:251
	// s = 'foo'
	byte 0x666f6f // "foo"
	frame_bury 0 // s: byte[]

	// tests/contracts/general.algo.ts:252
	// s += 'bar'
	frame_dig 0 // s: byte[]
	byte 0x626172 // "bar"
	concat
	frame_bury 0 // s: byte[]

	// tests/contracts/general.algo.ts:253
	// assert(s === 'foobar')
	frame_dig 0 // s: byte[]
	pushbytes 0x666f6f626172 // "foobar"
	==
	assert
	retsub

// importedProgram()byte[]
*abi_route_importedProgram:
	// The ABI return prefix
	byte 0x151f7c75

	// execute importedProgram()byte[]
	callsub importedProgram
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// importedProgram(): bytes
importedProgram:
	proto 0 1

	// tests/contracts/general.algo.ts:257
	// return IfTest.approvalProgram();
	pushbytes 0x0a20020100260904151f7c7504656c736502696609656c7365206966203109656c7365206966203207656c736520696603656e6403666f6f0031181481060b3119088d0c041900000000000000000000040b00000000000000000000008004151f7c75361a0149158101124481005388000d4915165706024c5050b08101438a01018bff41000580026966898003656e64898004151f7c75361a0149158101124481005388000d4915165706024c5050b08101438a01018bff41000880026966894200078004656c736589898004151f7c75361a02491581011244810053361a0149158101124481005388000d4915165706024c5050b08101438a02018bff410008800269668942000f8bfe41000a8007656c7365206966898003656e64898004151f7c75361a02491581011244810053361a0149158101124481005388000d4915165706024c5050b08101438a02018bff41000880026966894200198bfe41000d8007656c7365206966894200078004656c736589898004151f7c75361a03491581011244810053361a02491581011244810053361a0149158101124481005388000d4915165706024c5050b08101438a03018bff41000880026966894200258bfe41000f8009656c73652069662031894200118bfd41000c8009656c73652069662032898003656e64898004151f7c75361a03491581011244810053361a02491581011244810053361a0149158101124481005388000d4915165706024c5050b08101438a03018bff410008800269668942002f8bfe41000f8009656c736520696620318942001b8bfd41000f8009656c73652069662032894200078004656c736589898004151f7c75361a02491581011244810053361a0149158101124481005388000d4915165706024c5050b08101438a02018bff4100198bfe41000c80096e65737465642069668980026966894200078004656c736589898004151f7c75361a0149158101124481005388000d4915165706024c5050b08101438a01018bff41000880026966894200078004656c736589898004151f7c75361a02491581011244810053361a014915810112448100538800061650b08101438a02018bff410005810142000c8bfe41000581024200028103898004151f7c75361a015702008800061650b08101438a01018bff8000a94100038101898102898004151f7c75361a015702008800061650b08101438a01018bff8000a94100058101420002810289361a01491581021244178800038101438a01008bff8000a94100068003666f6fb089361a0249158102124417361a01491581021244178800038101438a02008bff8bfe0e4100068003666f6fb089361a02491581201244361a014915812012448800038101438a02008bff8bfea64100068003666f6fb0898004151f7c75361a02491581011244810053361a0149158101124481005388000d4915165706024c5050b08101438a02018bff4100198bfe41000d80076120616e64206289420004800161894200168bfe4100078001628942000a80076e65697468657289898101438004b8447b36361a008e01fff0008004436ec1c280041c7a0d5e80045e0fb6cf80045e1c6c50800458d0ba9280045d2f4f028004845729d980048fe76ca880041a3c7878800474bcc86880044212f905800495ddaebf80043147b866800442897f618004534be2b7361a008e0ffb6bfba0fbdafc2dfc85fcfafd74fdcbfe05fe46fe6cfe94feb6fee2ff0c00
	retsub

// callPrivateDefinedLater()void
*abi_route_callPrivateDefinedLater:
	// execute callPrivateDefinedLater()void
	callsub callPrivateDefinedLater
	int 1
	return

// callPrivateDefinedLater(): void
callPrivateDefinedLater:
	proto 0 0

	// tests/contracts/general.algo.ts:261
	// log(this.privateMethod('hello'))
	pushbytes 0x68656c6c6f // "hello"
	callsub privateMethod
	log
	retsub

// privateMethod(msg: string): string
privateMethod:
	proto 1 1

	// tests/contracts/general.algo.ts:265
	// return msg;
	frame_dig -1 // msg: string
	retsub

// interalPublicMethod(uint64,uint64)uint64
*abi_route_interalPublicMethod:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute interalPublicMethod(uint64,uint64)uint64
	callsub interalPublicMethod
	itob
	concat
	log
	int 1
	return

// interalPublicMethod(a: uint64, b: uint64): uint64
interalPublicMethod:
	proto 2 1

	// tests/contracts/general.algo.ts:269
	// return a + b;
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	+
	retsub

// callInternalPublicMethod()void
*abi_route_callInternalPublicMethod:
	// execute callInternalPublicMethod()void
	callsub callInternalPublicMethod
	int 1
	return

// callInternalPublicMethod(): void
callInternalPublicMethod:
	proto 0 0

	// tests/contracts/general.algo.ts:273
	// assert(this.interalPublicMethod(1, 2) === 3)
	int 2
	int 1
	callsub interalPublicMethod
	pushint 3
	==
	assert
	retsub

// appLoadScratch()void
*abi_route_appLoadScratch:
	// execute appLoadScratch()void
	callsub appLoadScratch
	int 1
	return

// appLoadScratch(): void
appLoadScratch:
	proto 0 0

	// tests/contracts/general.algo.ts:277
	// log(this.txnGroup[1].loadScratch(2) as bytes)
	gload 1 2
	log
	retsub

// uintNWithUnderscore()uint256
*abi_route_uintNWithUnderscore:
	// The ABI return prefix
	byte 0x151f7c75

	// execute uintNWithUnderscore()uint256
	callsub uintNWithUnderscore
	dup
	bitlen
	pushint 256
	<=

	// uintNWithUnderscore return value overflowed 256 bits
	assert
	pushbytes 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	pushint 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// uintNWithUnderscore(): uint256
uintNWithUnderscore:
	proto 0 1

	// tests/contracts/general.algo.ts:281
	// return <uint256>123_456;
	pushbytes 0x000000000000000000000000000000000000000000000000000000000001e240
	retsub

// opUp()void
*abi_route_opUp:
	// execute opUp()void
	callsub opUp
	int 1
	return

// opUp(): void
opUp:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/general.algo.ts:285
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	int 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

	// tests/contracts/general.algo.ts:286
	// for (let i = 1; i < 75; i += 1)
	int 1
	frame_bury 0 // i: uint64

*for_0:
	// tests/contracts/general.algo.ts:286
	// i < 75
	frame_dig 0 // i: uint64
	pushint 75
	<
	bz *for_0_end

	// tests/contracts/general.algo.ts:287
	// assert(i)
	frame_dig 0 // i: uint64
	assert

*for_0_continue:
	// tests/contracts/general.algo.ts:286
	// i += 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64
	b *for_0

*for_0_end:
	retsub

// returnValueOnAssignment()string
*abi_route_returnValueOnAssignment:
	// The ABI return prefix
	byte 0x151f7c75

	// execute returnValueOnAssignment()string
	callsub returnValueOnAssignment
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// returnValueOnAssignment(): string
returnValueOnAssignment:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/general.algo.ts:292
	// message = 'hi'
	pushbytes 0x6869 // "hi"
	frame_bury 0 // message: byte[]

	// *if0_condition
	// tests/contracts/general.algo.ts:294
	// this.txn.sender === this.app.address
	txn Sender
	global CurrentApplicationAddress
	==
	bz *if0_end

	// *if0_consequent
	// tests/contracts/general.algo.ts:295
	// message = 'in block'
	pushbytes 0x696e20626c6f636b // "in block"
	frame_bury 0 // message: byte[]

*if0_end:
	// tests/contracts/general.algo.ts:298
	// return (message = 'bye');
	byte 0x627965 // "bye"
	dup
	frame_bury 0 // message: byte[]

	// set the subroutine return value
	frame_bury 0
	retsub

// returnArrayValueOnAssignment()uint64
*abi_route_returnArrayValueOnAssignment:
	// The ABI return prefix
	byte 0x151f7c75

	// execute returnArrayValueOnAssignment()uint64
	callsub returnArrayValueOnAssignment
	itob
	concat
	log
	int 1
	return

// returnArrayValueOnAssignment(): uint64
returnArrayValueOnAssignment:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/general.algo.ts:302
	// a: StaticArray<uint64, 3> = [1, 2, 3]
	byte 0x000000000000000100000000000000020000000000000003
	frame_bury 0 // a: StaticArray<uint64, 3>

	// tests/contracts/general.algo.ts:304
	// return (a[0] = 4);
	frame_dig 0 // a: StaticArray<uint64, 3>
	int 0
	int 4
	dup
	store 245 // assignment value
	itob
	replace3
	frame_bury 0 // a: StaticArray<uint64, 3>
	load 245 // assignment value

	// set the subroutine return value
	frame_bury 0
	retsub

// returnStorageValueOnAssignment()uint64
*abi_route_returnStorageValueOnAssignment:
	// The ABI return prefix
	byte 0x151f7c75

	// execute returnStorageValueOnAssignment()uint64
	callsub returnStorageValueOnAssignment
	itob
	concat
	log
	int 1
	return

// returnStorageValueOnAssignment(): uint64
returnStorageValueOnAssignment:
	proto 0 1

	// tests/contracts/general.algo.ts:308
	// this.gKey.value = 1
	byte 0x674b6579 // "gKey"
	int 1
	app_global_put

	// tests/contracts/general.algo.ts:310
	// return (this.gKey.value = 2);
	byte 0x674b6579 // "gKey"
	int 2
	dup
	store 245 // assignment value
	app_global_put
	load 245 // assignment value
	retsub

// returnOperatorAssignmentValue()uint64
*abi_route_returnOperatorAssignmentValue:
	// The ABI return prefix
	byte 0x151f7c75

	// execute returnOperatorAssignmentValue()uint64
	callsub returnOperatorAssignmentValue
	itob
	concat
	log
	int 1
	return

// returnOperatorAssignmentValue(): uint64
returnOperatorAssignmentValue:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/general.algo.ts:314
	// a = 1
	int 1
	frame_bury 0 // a: uint64

	// tests/contracts/general.algo.ts:316
	// return (a += 2);
	frame_dig 0 // a: uint64
	int 2
	+
	dup
	store 245 // assignment value
	frame_bury 0 // a: uint64
	load 245 // assignment value

	// set the subroutine return value
	frame_bury 0
	retsub

// returnArrayValueOnOperatorAssignment()uint64
*abi_route_returnArrayValueOnOperatorAssignment:
	// The ABI return prefix
	byte 0x151f7c75

	// execute returnArrayValueOnOperatorAssignment()uint64
	callsub returnArrayValueOnOperatorAssignment
	itob
	concat
	log
	int 1
	return

// returnArrayValueOnOperatorAssignment(): uint64
returnArrayValueOnOperatorAssignment:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/general.algo.ts:320
	// a: StaticArray<uint64, 3> = [1, 2, 3]
	byte 0x000000000000000100000000000000020000000000000003
	frame_bury 0 // a: StaticArray<uint64, 3>

	// tests/contracts/general.algo.ts:322
	// return (a[0] += 4);
	frame_dig 0 // a: StaticArray<uint64, 3>
	int 0
	frame_dig 0 // a: StaticArray<uint64, 3>
	extract 0 8
	btoi
	int 4
	+
	dup
	store 245 // assignment value
	itob
	replace3
	frame_bury 0 // a: StaticArray<uint64, 3>
	load 245 // assignment value

	// set the subroutine return value
	frame_bury 0
	retsub

// returnArrayInStorageValueOnOperatorAssignment()uint64
*abi_route_returnArrayInStorageValueOnOperatorAssignment:
	// The ABI return prefix
	byte 0x151f7c75

	// execute returnArrayInStorageValueOnOperatorAssignment()uint64
	callsub returnArrayInStorageValueOnOperatorAssignment
	itob
	concat
	log
	int 1
	return

// returnArrayInStorageValueOnOperatorAssignment(): uint64
returnArrayInStorageValueOnOperatorAssignment:
	proto 0 1

	// tests/contracts/general.algo.ts:326
	// this.storageArray.value = [1, 2, 3]
	byte 0x73746f726167654172726179 // "storageArray"
	byte 0x000000000000000100000000000000020000000000000003
	app_global_put

	// tests/contracts/general.algo.ts:328
	// return (this.storageArray.value[0] += 4);
	byte 0x73746f726167654172726179 // "storageArray"
	app_global_get
	int 0
	byte 0x73746f726167654172726179 // "storageArray"
	app_global_get
	extract 0 8
	btoi
	int 4
	+
	dup
	store 245 // assignment value
	itob
	replace3
	byte 0x73746f726167654172726179 // "storageArray"
	swap
	app_global_put
	load 245 // assignment value
	retsub

// consts()void
*abi_route_consts:
	// execute consts()void
	callsub consts
	int 1
	return

// consts(): void
consts:
	proto 0 0

	// tests/contracts/general.algo.ts:332
	// assert(STRING_CONST === 'foo')
	pushbytes "foo"
	byte 0x666f6f // "foo"
	==
	assert

	// tests/contracts/general.algo.ts:333
	// assert(NUM_CONST === 123)
	int 123
	dup
	==
	assert

	// tests/contracts/general.algo.ts:334
	// assert(NESTED_CONST === 123)
	int 123
	dup
	==
	assert
	retsub

// assertWithMessage()void
*abi_route_assertWithMessage:
	// execute assertWithMessage()void
	callsub assertWithMessage
	int 1
	return

// assertWithMessage(): void
assertWithMessage:
	proto 0 0

	// tests/contracts/general.algo.ts:338
	// assert(false, 'this is false')
	int 0

	// this is false
	assert
	retsub

// opcodeAliases()void
*abi_route_opcodeAliases:
	// execute opcodeAliases()void
	callsub opcodeAliases
	int 1
	return

// opcodeAliases(): void
opcodeAliases:
	proto 0 0

	// tests/contracts/general.algo.ts:342
	// extractUint16(bzero(64), 0)
	byte 0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000
	int 0
	extract_uint16

	// tests/contracts/general.algo.ts:343
	// extractUint32(bzero(64), 0)
	byte 0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000
	int 0
	extract_uint32

	// tests/contracts/general.algo.ts:344
	// extractUint64(bzero(64), 0)
	byte 0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000
	int 0
	extract_uint64

	// tests/contracts/general.algo.ts:345
	// ed25519VerifyBare(bzero(64), bzero(64), bzero(32))
	byte 0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000
	dup
	byte 0x0000000000000000000000000000000000000000000000000000000000000000
	ed25519verify_bare

	// tests/contracts/general.algo.ts:346
	// ed25519Verify(bzero(64), bzero(64), bzero(32))
	byte 0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000
	dup
	byte 0x0000000000000000000000000000000000000000000000000000000000000000
	ed25519verify
	retsub

// vrfVerifyOp()void
*abi_route_vrfVerifyOp:
	// execute vrfVerifyOp()void
	callsub vrfVerifyOp
	int 1
	return

// vrfVerifyOp(): void
vrfVerifyOp:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// tests/contracts/general.algo.ts:350
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	int 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

	// tests/contracts/general.algo.ts:351
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	int 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

	// tests/contracts/general.algo.ts:352
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	int 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

	// tests/contracts/general.algo.ts:353
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	int 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

	// tests/contracts/general.algo.ts:354
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	int 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

	// tests/contracts/general.algo.ts:355
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	int 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

	// tests/contracts/general.algo.ts:356
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	int 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

	// tests/contracts/general.algo.ts:357
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	int 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

	// tests/contracts/general.algo.ts:358
	// increaseOpcodeBudget()
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	int 0
	itxn_field Fee
	byte 0x0a8101 // #pragma version 10; int 1
	dup
	itxn_field ApprovalProgram
	itxn_field ClearStateProgram
	int 5 // DeleteApplication
	itxn_field OnCompletion
	itxn_submit

	// tests/contracts/general.algo.ts:360
	// r = vrfVefiry('VrfAlgorand', bzero(32) as bytes, bzero(80), bzero(32))
	byte 0x0000000000000000000000000000000000000000000000000000000000000000
	pushbytes 0x0000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000
	byte 0x0000000000000000000000000000000000000000000000000000000000000000
	vrf_verify VrfAlgorand
	frame_bury 0 // r verified: bool
	frame_bury 1 // r output: byte[]

	// tests/contracts/general.algo.ts:361
	// assert(!r.verified)
	frame_dig 0 // r verified: bool
	!
	assert

	// tests/contracts/general.algo.ts:362
	// log(r.output)
	frame_dig 1 // r output: byte[]
	log
	retsub

// ecMath()void
*abi_route_ecMath:
	// execute ecMath()void
	callsub ecMath
	int 1
	return

// ecMath(): void
ecMath:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/general.algo.ts:366
	// ecScalarMul('BN254g1', '', '')
	byte 0x // ""
	dup
	ec_scalar_mul BN254g1

	// tests/contracts/general.algo.ts:367
	// ecPairingCheck('BN254g1', '', '')
	byte 0x // ""
	dup
	ec_pairing_check BN254g1

	// tests/contracts/general.algo.ts:368
	// scalars: bytes32[] = [bzero(32), bzero(32)]
	byte 0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000
	frame_bury 0 // scalars: bytes32[]

	// tests/contracts/general.algo.ts:369
	// ecMultiScalarMul('BN254g1', '', scalars)
	byte 0x // ""
	byte 0x00000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000 // scalars: bytes32[]
	ec_multi_scalar_mul BN254g1

	// tests/contracts/general.algo.ts:370
	// ecSubgroupCheck('BN254g1', '')
	byte 0x // ""
	ec_subgroup_check BN254g1

	// tests/contracts/general.algo.ts:371
	// ecMapTo('BN254g1', '')
	byte 0x // ""
	ec_map_to BN254g1

	// tests/contracts/general.algo.ts:372
	// ecAdd('BN254g1', '', '')
	byte 0x // ""
	dup
	ec_add BN254g1
	retsub

// gitxn()void
*abi_route_gitxn:
	// execute gitxn()void
	callsub gitxn
	int 1
	return

// gitxn(): void
gitxn:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/general.algo.ts:376
	// log(this.lastInnerGroup[0].sender)
	gitxn 0 Sender
	log

	// tests/contracts/general.algo.ts:378
	// anotherTxn = this.lastInnerGroup[1]
	int 1
	frame_bury 0 // anotherTxn: gitxn

	// tests/contracts/general.algo.ts:380
	// log(anotherTxn.sender)
	gitxn 1 Sender
	log
	retsub

// getSetBytes()void
*abi_route_getSetBytes:
	// execute getSetBytes()void
	callsub getSetBytes
	int 1
	return

// getSetBytes(): void
getSetBytes:
	proto 0 0

	// tests/contracts/general.algo.ts:384
	// log(setbit('foo', 0, true))
	byte 0x666f6f // "foo"
	int 0
	int 1
	setbit
	log

	// tests/contracts/general.algo.ts:385
	// getbit('foo', 0)
	byte 0x666f6f // "foo"
	int 0
	getbit

	// tests/contracts/general.algo.ts:386
	// getbyte('foo', 0)
	byte 0x666f6f // "foo"
	int 0
	getbyte

	// tests/contracts/general.algo.ts:387
	// setbyte('foo', 0, 1)
	byte 0x666f6f // "foo"
	int 0
	int 1
	setbyte
	retsub

// getSetUint64()void
*abi_route_getSetUint64:
	// execute getSetUint64()void
	callsub getSetUint64
	int 1
	return

// getSetUint64(): void
getSetUint64:
	proto 0 0

	// tests/contracts/general.algo.ts:391
	// assert(setbit(123, 0, true))
	int 123
	int 0
	int 1
	setbit
	assert

	// tests/contracts/general.algo.ts:392
	// getbit(123, 0)
	int 123
	int 0
	getbit
	retsub

// blockOp()void
*abi_route_blockOp:
	// execute blockOp()void
	callsub blockOp
	int 1
	return

// blockOp(): void
blockOp:
	proto 0 0

	// tests/contracts/general.algo.ts:396
	// log(blocks[globals.round - 1].seed)
	global Round
	int 1
	-
	block BlkSeed
	log

	// tests/contracts/general.algo.ts:397
	// assert(blocks[globals.round - 1].timestamp)
	global Round
	int 1
	-
	block BlkTimestamp
	assert
	retsub

// b64()void
*abi_route_b64:
	// execute b64()void
	callsub b64
	int 1
	return

// b64(): void
b64:
	proto 0 0

	// tests/contracts/general.algo.ts:401
	// log(base64Decode('StdEncoding', ''))
	byte 0x // ""
	base64_decode StdEncoding
	log
	retsub

// json()void
*abi_route_json:
	// execute json()void
	callsub json
	int 1
	return

// json(): void
json:
	proto 0 0

	// tests/contracts/general.algo.ts:405
	// log(jsonRef('JSONObject', '', ''))
	byte 0x // ""
	dup
	json_ref JSONObject
	log

	// tests/contracts/general.algo.ts:406
	// log(jsonRef('JSONString', '', ''))
	byte 0x // ""
	dup
	json_ref JSONString
	log

	// tests/contracts/general.algo.ts:407
	// assert(jsonRef('JSONUint64', '', ''))
	byte 0x // ""
	dup
	json_ref JSONUint64
	assert
	retsub

// bitlenOp()void
*abi_route_bitlenOp:
	// execute bitlenOp()void
	callsub bitlenOp
	int 1
	return

// bitlenOp(): void
bitlenOp:
	proto 0 0

	// tests/contracts/general.algo.ts:411
	// bitlen(123)
	int 123
	bitlen

	// tests/contracts/general.algo.ts:412
	// bitlen('foo')
	byte 0x666f6f // "foo"
	bitlen
	retsub

// computedConst()void
*abi_route_computedConst:
	// execute computedConst()void
	callsub computedConst
	int 1
	return

// computedConst(): void
computedConst:
	proto 0 0

	// tests/contracts/general.algo.ts:416
	// assert(COMPUTED_CONST)
	pushint 246
	assert
	retsub

// multiComputedConst()void
*abi_route_multiComputedConst:
	// execute multiComputedConst()void
	callsub multiComputedConst
	int 1
	return

// multiComputedConst(): void
multiComputedConst:
	proto 0 0

	// tests/contracts/general.algo.ts:420
	// assert(MUTLI_COMPUTED_CONST)
	pushint 30381
	assert
	retsub

// readSchema()void
*abi_route_readSchema:
	// execute readSchema()void
	callsub readSchema
	int 1
	return

// readSchema(): void
readSchema:
	proto 0 0

	// tests/contracts/general.algo.ts:424
	// assert(SchemaContract.schema.global.numUint === 1)
	int 1
	dup
	==
	assert

	// tests/contracts/general.algo.ts:425
	// assert(SchemaContract.schema.global.numByteSlice === 2)
	int 2
	dup
	==
	assert

	// tests/contracts/general.algo.ts:426
	// assert(SchemaContract.schema.local.numUint === 3)
	pushint 3
	pushint 3
	==
	assert

	// tests/contracts/general.algo.ts:427
	// assert(SchemaContract.schema.local.numByteSlice === 4)
	int 4
	dup
	==
	assert
	retsub

// comparisonOr()bool
*abi_route_comparisonOr:
	// The ABI return prefix
	byte 0x151f7c75

	// execute comparisonOr()bool
	callsub comparisonOr
	pushbytes 0x00
	int 0
	uncover 2
	setbit
	concat
	log
	int 1
	return

// comparisonOr(): boolean
comparisonOr:
	proto 0 1

	// tests/contracts/general.algo.ts:431
	// return this.txn.sender === globals.zeroAddress || this.txn.sender === globals.zeroAddress;
	txn Sender
	global ZeroAddress
	==
	dup
	bnz *skip_or0
	txn Sender
	global ZeroAddress
	==
	||

*skip_or0:
	retsub

// txnArgsMethod(pay)void
*abi_route_txnArgsMethod:
	// _pay1: pay
	txn GroupIndex
	int 1
	-
	dup
	gtxns TypeEnum
	int 1 // pay
	==

	// argument 0 (_pay1) for txnArgsMethod must be a pay transaction
	assert

	// execute txnArgsMethod(pay)void
	callsub txnArgsMethod
	int 1
	return

// txnArgsMethod(_pay1: PayTxn): void
txnArgsMethod:
	proto 1 0
	retsub

// callTxnArgsMethod()void
*abi_route_callTxnArgsMethod:
	// execute callTxnArgsMethod()void
	callsub callTxnArgsMethod
	int 1
	return

// callTxnArgsMethod(): void
callTxnArgsMethod:
	proto 0 0

	// tests/contracts/general.algo.ts:438
	// sendMethodCall<typeof GeneralTest.prototype.txnArgsMethod>({
	//       methodArgs: [{ receiver: this.app.address, amount: 0 }],
	//     })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// tests/contracts/general.algo.ts:439
	// receiver: this.app.address
	global CurrentApplicationAddress
	itxn_field Receiver

	// tests/contracts/general.algo.ts:439
	// amount: 0
	int 0
	itxn_field Amount

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee
	itxn_next
	int 6 // appl
	itxn_field TypeEnum
	byte 0x2c636eeb // method "txnArgsMethod(pay)void"
	itxn_field ApplicationArgs

	// tests/contracts/general.algo.ts:439
	// methodArgs: [{ receiver: this.app.address, amount: 0 }]
	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// staticValueLen(uint256)void
*abi_route_staticValueLen:
	// x: uint256
	txna ApplicationArgs 1
	dup
	len
	pushint 32
	==

	// argument 0 (x) for staticValueLen must be a uint256
	assert

	// execute staticValueLen(uint256)void
	callsub staticValueLen
	int 1
	return

// staticValueLen(x: uint256): void
staticValueLen:
	proto 1 0

	// tests/contracts/general.algo.ts:444
	// assert(len(x))
	pushint 32
	assert
	retsub

// staticTypeLen()void
*abi_route_staticTypeLen:
	// execute staticTypeLen()void
	callsub staticTypeLen
	int 1
	return

// staticTypeLen(): void
staticTypeLen:
	proto 0 0

	// tests/contracts/general.algo.ts:448
	// assert(len<uint256>())
	pushint 32
	assert
	retsub

// dynamicScratchSlot()void
*abi_route_dynamicScratchSlot:
	// execute dynamicScratchSlot()void
	callsub dynamicScratchSlot
	int 1
	return

// dynamicScratchSlot(): void
dynamicScratchSlot:
	proto 0 0

	// tests/contracts/general.algo.ts:452
	// this.dynamicScratch(1).value = 1337
	int 1
	int 1337
	stores

	// tests/contracts/general.algo.ts:453
	// assert(this.dynamicScratch(1).value === 1337)
	int 1
	loads
	int 1337
	==
	assert
	retsub

// incrementScratchSlot()void
*abi_route_incrementScratchSlot:
	// execute incrementScratchSlot()void
	callsub incrementScratchSlot
	int 1
	return

// incrementScratchSlot(): void
incrementScratchSlot:
	proto 0 0

	// tests/contracts/general.algo.ts:457
	// this.scratch.value = 1337
	int 1337
	store 0

	// tests/contracts/general.algo.ts:458
	// this.scratch.value += 1
	load 0
	int 1
	+
	store 0

	// tests/contracts/general.algo.ts:459
	// assert(this.scratch.value === 1338)
	load 0
	pushint 1338
	==
	assert
	retsub

// incrementDynamicScratchSlot()void
*abi_route_incrementDynamicScratchSlot:
	// execute incrementDynamicScratchSlot()void
	callsub incrementDynamicScratchSlot
	int 1
	return

// incrementDynamicScratchSlot(): void
incrementDynamicScratchSlot:
	proto 0 0

	// tests/contracts/general.algo.ts:463
	// this.dynamicScratch(2).value = 1337
	int 2
	int 1337
	stores

	// tests/contracts/general.algo.ts:464
	// this.dynamicScratch(2).value += 1
	int 2
	loads
	int 1
	+
	int 2
	swap
	stores

	// tests/contracts/general.algo.ts:465
	// assert(this.dynamicScratch(2).value === 1338)
	int 2
	loads
	pushint 1338
	==
	assert
	retsub

// fromAddress()void
*abi_route_fromAddress:
	// execute fromAddress()void
	callsub fromAddress
	int 1
	return

// fromAddress(): void
fromAddress:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/general.algo.ts:469
	// a = Address.fromAddress('AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAY5HFKQ')
	byte 0x0000000000000000000000000000000000000000000000000000000000000000 // addr "AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAY5HFKQ"
	frame_bury 0 // a: address

	// tests/contracts/general.algo.ts:470
	// assert(a === Address.zeroAddress)
	frame_dig 0 // a: address
	global ZeroAddress
	==
	assert
	retsub

// earlyReturn(uint64)uint64
*abi_route_earlyReturn:
	// The ABI return prefix
	byte 0x151f7c75

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute earlyReturn(uint64)uint64
	callsub earlyReturn
	itob
	concat
	log
	int 1
	return

// earlyReturn(a: uint64): uint64
earlyReturn:
	proto 1 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// *if1_condition
	// tests/contracts/general.algo.ts:474
	// a === 1
	frame_dig -1 // a: uint64
	int 1
	==
	bz *if1_end

	// *if1_consequent
	// tests/contracts/general.algo.ts:475
	// return 2;
	int 2
	b *earlyReturn*return

*if1_end:
	// tests/contracts/general.algo.ts:477
	// b = a + 1
	frame_dig -1 // a: uint64
	int 1
	+
	frame_bury 0 // b: uint64

	// tests/contracts/general.algo.ts:478
	// return b;
	frame_dig 0 // b: uint64

*earlyReturn*return:
	// set the subroutine return value
	frame_bury 0
	retsub

// assetMethodArgs()void
*abi_route_assetMethodArgs:
	// execute assetMethodArgs()void
	callsub assetMethodArgs
	int 1
	return

// assetMethodArgs(): void
assetMethodArgs:
	proto 0 0

	// tests/contracts/general.algo.ts:482
	// sendMethodCall<[AssetReference], void>({
	//       name: 'foo',
	//       methodArgs: [AssetID.fromUint64(1)],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum
	pushbytes 0xa15316de // method "foo(asset)void"
	itxn_field ApplicationArgs

	// tests/contracts/general.algo.ts:484
	// methodArgs: [AssetID.fromUint64(1)]
	int 1
	itxn_field Assets
	pushbytes 0x0000000000000000
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// multipleProgramPages()void
*abi_route_multipleProgramPages:
	// execute multipleProgramPages()void
	callsub multipleProgramPages
	int 1
	return

// multipleProgramPages(): void
multipleProgramPages:
	proto 0 0

	// tests/contracts/general.algo.ts:493
	// sendAppCall({
	//       approvalProgram: [this.pageOne.value, this.pageTwo.value],
	//       clearStateProgram: [this.pageOne.value, this.pageTwo.value],
	//     })
	itxn_begin
	int 6 // appl
	itxn_field TypeEnum

	// tests/contracts/general.algo.ts:494
	// approvalProgram: [this.pageOne.value, this.pageTwo.value]
	byte 0x706167654f6e65 // "pageOne"
	box_get

	// box value does not exist: this.pageOne.value
	assert
	itxn_field ApprovalProgramPages
	byte 0x7061676554776f // "pageTwo"
	box_get

	// box value does not exist: this.pageTwo.value
	assert
	itxn_field ApprovalProgramPages

	// tests/contracts/general.algo.ts:495
	// clearStateProgram: [this.pageOne.value, this.pageTwo.value]
	byte 0x706167654f6e65 // "pageOne"
	box_get

	// box value does not exist: this.pageOne.value
	assert
	itxn_field ClearStateProgramPages
	byte 0x7061676554776f // "pageTwo"
	box_get

	// box value does not exist: this.pageTwo.value
	assert
	itxn_field ClearStateProgramPages

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// assertComment()void
*abi_route_assertComment:
	// execute assertComment()void
	callsub assertComment
	int 1
	return

// assertComment(): void
assertComment:
	proto 0 0

	// tests/contracts/general.algo.ts:500
	// assert(false, 'this is false')
	int 0

	// this is false
	assert
	retsub

// throwErrorMessage()void
*abi_route_throwErrorMessage:
	// execute throwErrorMessage()void
	callsub throwErrorMessage
	int 1
	return

// throwErrorMessage(): void
throwErrorMessage:
	proto 0 0

	// this is an error
	err
	retsub

// orLiteralType(uint64,uint64)void
*abi_route_orLiteralType:
	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute orLiteralType(uint64,uint64)void
	callsub orLiteralType
	int 1
	return

// orLiteralType(a: uint64, b: uint64): void
orLiteralType:
	proto 2 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// tests/contracts/general.algo.ts:508
	// foo = a && b === 1 ? 2 : 0
	frame_dig -1 // a: uint64
	dup
	bz *skip_and0
	frame_dig -2 // b: uint64
	int 1
	==
	&&

*skip_and0:
	bz *ternary0_false
	int 2
	b *ternary0_end

*ternary0_false:
	int 0

*ternary0_end:
	frame_bury 0 // foo: uint64

	// tests/contracts/general.algo.ts:509
	// assert(foo)
	frame_dig 0 // foo: uint64
	assert

	// tests/contracts/general.algo.ts:511
	// bar = a && b === 0 ? '2' : '0'
	frame_dig -1 // a: uint64
	dup
	bz *skip_and1
	frame_dig -2 // b: uint64
	int 0
	==
	&&

*skip_and1:
	bz *ternary1_false
	pushbytes 0x32 // "2"
	b *ternary1_end

*ternary1_false:
	byte 0x30 // "0"

*ternary1_end:
	frame_bury 1 // bar: byte[]

	// tests/contracts/general.algo.ts:512
	// log(bar)
	frame_dig 1 // bar: byte[]
	log
	retsub

// nonAbi(): void
nonAbi:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/general.algo.ts:517
	// assert(this.txn.applicationArgs!.length)
	txn NumAppArgs
	assert

	// tests/contracts/general.algo.ts:519
	// for (let i = 0; i < this.txn.applicationArgs!.length; i += 1)
	int 0
	frame_bury 0 // i: uint64

*for_1:
	// tests/contracts/general.algo.ts:519
	// i < this.txn.applicationArgs!.length
	frame_dig 0 // i: uint64
	txn NumAppArgs
	<
	bz *for_1_end

	// tests/contracts/general.algo.ts:520
	// log(this.txn.applicationArgs![i])
	frame_dig 0 // i: uint64
	txnas ApplicationArgs
	log

*for_1_continue:
	// tests/contracts/general.algo.ts:519
	// i += 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64
	b *for_1

*for_1_end:
	retsub

// multilineFunctionCall()void
*abi_route_multilineFunctionCall:
	// execute multilineFunctionCall()void
	callsub multilineFunctionCall
	int 1
	return

// multilineFunctionCall(): void
multilineFunctionCall:
	proto 0 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// tests/contracts/general.algo.ts:525
	// app = AppID.zeroIndex
	int 0
	frame_bury 0 // app: uint64

	// tests/contracts/general.algo.ts:526
	// addr = Address.zeroAddress
	global ZeroAddress
	frame_bury 1 // addr: address

	// tests/contracts/general.algo.ts:528
	// app.localState(
	//       addr,
	//       'key'
	//     )
	frame_dig 1 // addr: address
	int 0 // app: uint64
	pushbytes 0x6b6579 // "key"
	app_local_get_ex

	// local state value does not exist: app.localState( addr, 'key' )
	assert
	retsub

// a()uint64
*abi_route_a:
	// The ABI return prefix
	byte 0x151f7c75

	// execute a()uint64
	callsub a
	itob
	concat
	log
	int 1
	return

// a(): uint64
a:
	proto 0 1

	// tests/contracts/general.algo.ts:535
	// return 3;
	pushint 3
	retsub

// b()uint64
*abi_route_b:
	// The ABI return prefix
	byte 0x151f7c75

	// execute b()uint64
	callsub b
	itob
	concat
	log
	int 1
	return

// b(): uint64
b:
	proto 0 1

	// tests/contracts/general.algo.ts:539
	// return 5;
	int 5
	retsub

// unusedMethodValue()uint64
*abi_route_unusedMethodValue:
	// The ABI return prefix
	byte 0x151f7c75

	// execute unusedMethodValue()uint64
	callsub unusedMethodValue
	itob
	concat
	log
	int 1
	return

// unusedMethodValue(): uint64
unusedMethodValue:
	proto 0 1

	// tests/contracts/general.algo.ts:543
	// this.a()
	callsub a
	pop

	// tests/contracts/general.algo.ts:544
	// return this.b();
	callsub b
	retsub

// reassignedNonFirstVar()uint64
*abi_route_reassignedNonFirstVar:
	// The ABI return prefix
	byte 0x151f7c75

	// execute reassignedNonFirstVar()uint64
	callsub reassignedNonFirstVar
	itob
	concat
	log
	int 1
	return

// reassignedNonFirstVar(): uint64
reassignedNonFirstVar:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// tests/contracts/general.algo.ts:555
	// a = 1 as uint64
	int 1
	frame_bury 0 // a: uint64

	// tests/contracts/general.algo.ts:556
	// b = this.app.id
	txna Applications 0
	frame_bury 1 // b: uint64

	// *if2_condition
	// tests/contracts/general.algo.ts:557
	// a
	frame_dig 0 // a: uint64
	bz *if2_end

	// *if2_consequent
	// tests/contracts/general.algo.ts:558
	// b = 2
	int 2
	frame_bury 1 // b: uint64

*if2_end:
	// tests/contracts/general.algo.ts:561
	// return b;
	frame_dig 1 // b: uint64

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 1
	retsub

// fvLv()void
*abi_route_fvLv:
	// execute fvLv()void
	callsub fvLv
	int 1
	return

// fvLv(): void
fvLv:
	proto 0 0

	// tests/contracts/general.algo.ts:565
	// assert(this.txn.firstValid)
	txn FirstValid
	assert

	// tests/contracts/general.algo.ts:566
	// assert(this.txn.lastValid)
	txn LastValid
	assert
	retsub

*abi_route_createApplication:
	int 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x624264a3 // method "txnTypeEnum()void"
	pushbytes 0xb205edc9 // method "txnGroupLength()void"
	pushbytes 0xe6e97d5b // method "asserts(bool,bool)void"
	pushbytes 0xdd6fa7c8 // method "verifyTxnFromArg(pay)void"
	pushbytes 0x0ea644fb // method "verifyTxnFromTxnGroup()void"
	pushbytes 0xec0d9094 // method "verifyTxnCondition()void"
	pushbytes 0x68848d97 // method "verifyTxnIncludedIn()void"
	pushbytes 0x18bd23dc // method "verifyTxnNotIncludedIn()void"
	pushbytes 0x806bfb93 // method "submitPendingGroup()void"
	pushbytes 0x3be5f82e // method "methodWithTxnArgs()void"
	pushbytes 0x1295d683 // method "shift()void"
	pushbytes 0xb3b8c472 // method "fromBytes()void"
	pushbytes 0x53e0b6f0 // method "fromUint64()void"
	pushbytes 0x4b3eb877 // method "bzeroFunction()void"
	pushbytes 0xdac2e7a5 // method "events()void"
	pushbytes 0xa3db6704 // method "letOptimization(uint64[])uint64[]"
	pushbytes 0xae21c172 // method "staticContractProperties()void"
	pushbytes 0xdab4d1c4 // method "numberToString()void"
	pushbytes 0xa7b4ae9a // method "methodOnParens()void"
	pushbytes 0x6d4485ba // method "stringSubstring()void"
	pushbytes 0xef6262e9 // method "idProperty()void"
	pushbytes 0x8d2b668b // method "scratchSlot()void"
	pushbytes 0xe6c154fc // method "ecdsa()void"
	pushbytes 0xa9764197 // method "verifyTxnTypes()void"
	pushbytes 0x9dbbc42c // method "stringPlusEquals()void"
	pushbytes 0x4c0ddec1 // method "importedProgram()byte[]"
	pushbytes 0x30ecfb41 // method "callPrivateDefinedLater()void"
	pushbytes 0x14a49919 // method "interalPublicMethod(uint64,uint64)uint64"
	pushbytes 0xb71c179a // method "callInternalPublicMethod()void"
	pushbytes 0x98481093 // method "appLoadScratch()void"
	pushbytes 0xf572d1c1 // method "uintNWithUnderscore()uint256"
	pushbytes 0x854dede0 // method "opUp()void"
	pushbytes 0x681599fa // method "returnValueOnAssignment()string"
	pushbytes 0x5e1477e8 // method "returnArrayValueOnAssignment()uint64"
	pushbytes 0xe07b3be9 // method "returnStorageValueOnAssignment()uint64"
	pushbytes 0x16e46657 // method "returnOperatorAssignmentValue()uint64"
	pushbytes 0x2c836f46 // method "returnArrayValueOnOperatorAssignment()uint64"
	pushbytes 0xa93c56f9 // method "returnArrayInStorageValueOnOperatorAssignment()uint64"
	pushbytes 0xf936952d // method "consts()void"
	pushbytes 0x88f39c99 // method "assertWithMessage()void"
	pushbytes 0x58794cf4 // method "opcodeAliases()void"
	pushbytes 0x35044ad8 // method "vrfVerifyOp()void"
	pushbytes 0x7d279e8e // method "ecMath()void"
	pushbytes 0x3dfa18c8 // method "gitxn()void"
	pushbytes 0x78ca5c4e // method "getSetBytes()void"
	pushbytes 0x0e67e957 // method "getSetUint64()void"
	pushbytes 0x3b446eef // method "blockOp()void"
	pushbytes 0xae82e875 // method "b64()void"
	pushbytes 0xd69af530 // method "json()void"
	pushbytes 0x4d52f33d // method "bitlenOp()void"
	pushbytes 0x2c0cd201 // method "computedConst()void"
	pushbytes 0x70e0afe5 // method "multiComputedConst()void"
	pushbytes 0x30a2fef4 // method "readSchema()void"
	pushbytes 0xf3971dca // method "comparisonOr()bool"
	byte 0x2c636eeb // method "txnArgsMethod(pay)void"
	pushbytes 0x9e40d34b // method "callTxnArgsMethod()void"
	pushbytes 0x91cf2b58 // method "staticValueLen(uint256)void"
	pushbytes 0xb1c8b45c // method "staticTypeLen()void"
	pushbytes 0x9c0e1bdb // method "dynamicScratchSlot()void"
	pushbytes 0x0a319504 // method "incrementScratchSlot()void"
	pushbytes 0x84b260fa // method "incrementDynamicScratchSlot()void"
	pushbytes 0x4a908856 // method "fromAddress()void"
	pushbytes 0x8deb32d3 // method "earlyReturn(uint64)uint64"
	pushbytes 0x67de156f // method "assetMethodArgs()void"
	pushbytes 0x1e428412 // method "multipleProgramPages()void"
	pushbytes 0x278fd8b8 // method "assertComment()void"
	pushbytes 0xbfc36208 // method "throwErrorMessage()void"
	pushbytes 0x04eedf79 // method "orLiteralType(uint64,uint64)void"
	pushbytes 0x35d5fbc7 // method "multilineFunctionCall()void"
	pushbytes 0xf9522e2f // method "a()uint64"
	pushbytes 0x8c9379e6 // method "b()uint64"
	pushbytes 0xf9a13552 // method "unusedMethodValue()uint64"
	pushbytes 0x94f2049a // method "reassignedNonFirstVar()uint64"
	pushbytes 0x56264215 // method "fvLv()void"
	txna ApplicationArgs 0
	match *abi_route_txnTypeEnum *abi_route_txnGroupLength *abi_route_asserts *abi_route_verifyTxnFromArg *abi_route_verifyTxnFromTxnGroup *abi_route_verifyTxnCondition *abi_route_verifyTxnIncludedIn *abi_route_verifyTxnNotIncludedIn *abi_route_submitPendingGroup *abi_route_methodWithTxnArgs *abi_route_shift *abi_route_fromBytes *abi_route_fromUint64 *abi_route_bzeroFunction *abi_route_events *abi_route_letOptimization *abi_route_staticContractProperties *abi_route_numberToString *abi_route_methodOnParens *abi_route_stringSubstring *abi_route_idProperty *abi_route_scratchSlot *abi_route_ecdsa *abi_route_verifyTxnTypes *abi_route_stringPlusEquals *abi_route_importedProgram *abi_route_callPrivateDefinedLater *abi_route_interalPublicMethod *abi_route_callInternalPublicMethod *abi_route_appLoadScratch *abi_route_uintNWithUnderscore *abi_route_opUp *abi_route_returnValueOnAssignment *abi_route_returnArrayValueOnAssignment *abi_route_returnStorageValueOnAssignment *abi_route_returnOperatorAssignmentValue *abi_route_returnArrayValueOnOperatorAssignment *abi_route_returnArrayInStorageValueOnOperatorAssignment *abi_route_consts *abi_route_assertWithMessage *abi_route_opcodeAliases *abi_route_vrfVerifyOp *abi_route_ecMath *abi_route_gitxn *abi_route_getSetBytes *abi_route_getSetUint64 *abi_route_blockOp *abi_route_b64 *abi_route_json *abi_route_bitlenOp *abi_route_computedConst *abi_route_multiComputedConst *abi_route_readSchema *abi_route_comparisonOr *abi_route_txnArgsMethod *abi_route_callTxnArgsMethod *abi_route_staticValueLen *abi_route_staticTypeLen *abi_route_dynamicScratchSlot *abi_route_incrementScratchSlot *abi_route_incrementDynamicScratchSlot *abi_route_fromAddress *abi_route_earlyReturn *abi_route_assetMethodArgs *abi_route_multipleProgramPages *abi_route_assertComment *abi_route_throwErrorMessage *abi_route_orLiteralType *abi_route_multilineFunctionCall *abi_route_a *abi_route_b *abi_route_unusedMethodValue *abi_route_reassignedNonFirstVar *abi_route_fvLv

	// !!!! WARNING: non-ABI routing
	callsub nonAbi
	int 1
	return

*intToAscii:
	proto 1 1
	pushbytes 0x30313233343536373839 // "0123456789"
	frame_dig -1 // i: uint64
	int 1
	extract3
	retsub
	

*itoa:
	proto 1 1
	frame_dig -1 // i: uint64
	int 0
	==
	bz *itoa_if_end
	byte 0x30
	retsub

*itoa_if_end:
	frame_dig -1 // i: uint64
	pushint 10
	/
	int 0
	>
	bz *itoa_ternary_false
	frame_dig -1 // i: uint64
	pushint 10
	/
	callsub *itoa
	b *itoa_ternary_end

*itoa_ternary_false:
	byte 0x // ""

*itoa_ternary_end:
	frame_dig -1 // i: uint64
	pushint 10
	%
	callsub *intToAscii
	concat
	retsub", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "scratchVariables": { diff --git a/tests/contracts/artifacts/IfTest.approval.teal b/tests/contracts/artifacts/IfTest.approval.teal index 68317923d..5a9b3c6b0 100644 --- a/tests/contracts/artifacts/IfTest.approval.teal +++ b/tests/contracts/artifacts/IfTest.approval.teal @@ -2,7 +2,7 @@ intcblock 1 0 bytecblock 0x151f7c75 0x656c7365 0x6966 0x656c73652069662031 0x656c73652069662032 0x656c7365206966 0x656e64 0x666f6f 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/IfTest.arc32.json b/tests/contracts/artifacts/IfTest.arc32.json index 9bc18472e..49dadb327 100644 --- a/tests/contracts/artifacts/IfTest.arc32.json +++ b/tests/contracts/artifacts/IfTest.arc32.json @@ -109,7 +109,7 @@ } }, "source": { - "approval": "#pragma version 10
intcblock 1 0
bytecblock 0x151f7c75 0x656c7365 0x6966 0x656c73652069662031 0x656c73652069662032 0x656c7365206966 0x656e64 0x666f6f 0x

// This TEAL was generated by TEALScript v0.104.1
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// singleIf(bool)string
*abi_route_singleIf:
	// The ABI return prefix
	byte 0x151f7c75

	// arg0: bool
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 0 (arg0) for singleIf must be a bool
	assert
	int 0
	getbit

	// execute singleIf(bool)string
	callsub singleIf
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// singleIf(arg0: boolean): string
singleIf:
	proto 1 1

	// *if0_condition
	// tests/contracts/if.algo.ts:7
	// arg0
	frame_dig -1 // arg0: boolean
	bz *if0_end

	// *if0_consequent
	// tests/contracts/if.algo.ts:8
	// return 'if';
	byte 0x6966 // "if"
	retsub

*if0_end:
	// tests/contracts/if.algo.ts:11
	// return 'end';
	byte 0x656e64 // "end"
	retsub

// ifElse(bool)string
*abi_route_ifElse:
	// The ABI return prefix
	byte 0x151f7c75

	// arg0: bool
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 0 (arg0) for ifElse must be a bool
	assert
	int 0
	getbit

	// execute ifElse(bool)string
	callsub ifElse
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// ifElse(arg0: boolean): string
ifElse:
	proto 1 1

	// *if1_condition
	// tests/contracts/if.algo.ts:15
	// arg0
	frame_dig -1 // arg0: boolean
	bz *if1_else

	// *if1_consequent
	// tests/contracts/if.algo.ts:16
	// return 'if';
	byte 0x6966 // "if"
	retsub
	b *if1_end

*if1_else:
	// tests/contracts/if.algo.ts:18
	// return 'else';
	byte 0x656c7365 // "else"
	retsub

*if1_end:
	retsub

// ifElseIf(bool,bool)string
*abi_route_ifElseIf:
	// The ABI return prefix
	byte 0x151f7c75

	// arg1: bool
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 0 (arg1) for ifElseIf must be a bool
	assert
	int 0
	getbit

	// arg0: bool
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 1 (arg0) for ifElseIf must be a bool
	assert
	int 0
	getbit

	// execute ifElseIf(bool,bool)string
	callsub ifElseIf
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// ifElseIf(arg0: boolean, arg1: boolean): string
ifElseIf:
	proto 2 1

	// *if2_condition
	// tests/contracts/if.algo.ts:23
	// arg0
	frame_dig -1 // arg0: boolean
	bz *if2_elseif1_condition

	// *if2_consequent
	// tests/contracts/if.algo.ts:24
	// return 'if';
	byte 0x6966 // "if"
	retsub
	b *if2_end

*if2_elseif1_condition:
	// tests/contracts/if.algo.ts:25
	// arg1
	frame_dig -2 // arg1: boolean
	bz *if2_end

	// *if2_elseif1_consequent
	// tests/contracts/if.algo.ts:26
	// return 'else if';
	byte 0x656c7365206966 // "else if"
	retsub

*if2_end:
	// tests/contracts/if.algo.ts:29
	// return 'end';
	byte 0x656e64 // "end"
	retsub

// ifElseIfElse(bool,bool)string
*abi_route_ifElseIfElse:
	// The ABI return prefix
	byte 0x151f7c75

	// arg1: bool
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 0 (arg1) for ifElseIfElse must be a bool
	assert
	int 0
	getbit

	// arg0: bool
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 1 (arg0) for ifElseIfElse must be a bool
	assert
	int 0
	getbit

	// execute ifElseIfElse(bool,bool)string
	callsub ifElseIfElse
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// ifElseIfElse(arg0: boolean, arg1: boolean): string
ifElseIfElse:
	proto 2 1

	// *if3_condition
	// tests/contracts/if.algo.ts:33
	// arg0
	frame_dig -1 // arg0: boolean
	bz *if3_elseif1_condition

	// *if3_consequent
	// tests/contracts/if.algo.ts:34
	// return 'if';
	byte 0x6966 // "if"
	retsub
	b *if3_end

*if3_elseif1_condition:
	// tests/contracts/if.algo.ts:35
	// arg1
	frame_dig -2 // arg1: boolean
	bz *if3_else

	// *if3_elseif1_consequent
	// tests/contracts/if.algo.ts:36
	// return 'else if';
	byte 0x656c7365206966 // "else if"
	retsub
	b *if3_end

*if3_else:
	// tests/contracts/if.algo.ts:38
	// return 'else';
	byte 0x656c7365 // "else"
	retsub

*if3_end:
	retsub

// ifElseIfElseIf(bool,bool,bool)string
*abi_route_ifElseIfElseIf:
	// The ABI return prefix
	byte 0x151f7c75

	// arg2: bool
	txna ApplicationArgs 3
	dup
	len
	int 1
	==

	// argument 0 (arg2) for ifElseIfElseIf must be a bool
	assert
	int 0
	getbit

	// arg1: bool
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 1 (arg1) for ifElseIfElseIf must be a bool
	assert
	int 0
	getbit

	// arg0: bool
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 2 (arg0) for ifElseIfElseIf must be a bool
	assert
	int 0
	getbit

	// execute ifElseIfElseIf(bool,bool,bool)string
	callsub ifElseIfElseIf
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// ifElseIfElseIf(arg0: boolean, arg1: boolean, arg2: boolean): string
ifElseIfElseIf:
	proto 3 1

	// *if4_condition
	// tests/contracts/if.algo.ts:43
	// arg0
	frame_dig -1 // arg0: boolean
	bz *if4_elseif1_condition

	// *if4_consequent
	// tests/contracts/if.algo.ts:44
	// return 'if';
	byte 0x6966 // "if"
	retsub
	b *if4_end

*if4_elseif1_condition:
	// tests/contracts/if.algo.ts:45
	// arg1
	frame_dig -2 // arg1: boolean
	bz *if4_elseif2_condition

	// *if4_elseif1_consequent
	// tests/contracts/if.algo.ts:46
	// return 'else if 1';
	byte 0x656c73652069662031 // "else if 1"
	retsub
	b *if4_end

*if4_elseif2_condition:
	// tests/contracts/if.algo.ts:47
	// arg2
	frame_dig -3 // arg2: boolean
	bz *if4_end

	// *if4_elseif2_consequent
	// tests/contracts/if.algo.ts:48
	// return 'else if 2';
	byte 0x656c73652069662032 // "else if 2"
	retsub

*if4_end:
	// tests/contracts/if.algo.ts:51
	// return 'end';
	byte 0x656e64 // "end"
	retsub

// ifElseIfElseIfElse(bool,bool,bool)string
*abi_route_ifElseIfElseIfElse:
	// The ABI return prefix
	byte 0x151f7c75

	// arg2: bool
	txna ApplicationArgs 3
	dup
	len
	int 1
	==

	// argument 0 (arg2) for ifElseIfElseIfElse must be a bool
	assert
	int 0
	getbit

	// arg1: bool
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 1 (arg1) for ifElseIfElseIfElse must be a bool
	assert
	int 0
	getbit

	// arg0: bool
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 2 (arg0) for ifElseIfElseIfElse must be a bool
	assert
	int 0
	getbit

	// execute ifElseIfElseIfElse(bool,bool,bool)string
	callsub ifElseIfElseIfElse
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// ifElseIfElseIfElse(arg0: boolean, arg1: boolean, arg2: boolean): string
ifElseIfElseIfElse:
	proto 3 1

	// *if5_condition
	// tests/contracts/if.algo.ts:55
	// arg0
	frame_dig -1 // arg0: boolean
	bz *if5_elseif1_condition

	// *if5_consequent
	// tests/contracts/if.algo.ts:56
	// return 'if';
	byte 0x6966 // "if"
	retsub
	b *if5_end

*if5_elseif1_condition:
	// tests/contracts/if.algo.ts:57
	// arg1
	frame_dig -2 // arg1: boolean
	bz *if5_elseif2_condition

	// *if5_elseif1_consequent
	// tests/contracts/if.algo.ts:58
	// return 'else if 1';
	byte 0x656c73652069662031 // "else if 1"
	retsub
	b *if5_end

*if5_elseif2_condition:
	// tests/contracts/if.algo.ts:59
	// arg2
	frame_dig -3 // arg2: boolean
	bz *if5_else

	// *if5_elseif2_consequent
	// tests/contracts/if.algo.ts:60
	// return 'else if 2';
	byte 0x656c73652069662032 // "else if 2"
	retsub
	b *if5_end

*if5_else:
	// tests/contracts/if.algo.ts:62
	// return 'else';
	byte 0x656c7365 // "else"
	retsub

*if5_end:
	retsub

// nestedIf(bool,bool)string
*abi_route_nestedIf:
	// The ABI return prefix
	byte 0x151f7c75

	// arg1: bool
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 0 (arg1) for nestedIf must be a bool
	assert
	int 0
	getbit

	// arg0: bool
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 1 (arg0) for nestedIf must be a bool
	assert
	int 0
	getbit

	// execute nestedIf(bool,bool)string
	callsub nestedIf
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// nestedIf(arg0: boolean, arg1: boolean): string
nestedIf:
	proto 2 1

	// *if6_condition
	// tests/contracts/if.algo.ts:67
	// arg0
	frame_dig -1 // arg0: boolean
	bz *if6_else

	// *if6_consequent
	// *if7_condition
	// tests/contracts/if.algo.ts:68
	// arg1
	frame_dig -2 // arg1: boolean
	bz *if7_end

	// *if7_consequent
	// tests/contracts/if.algo.ts:69
	// return 'nested if';
	pushbytes 0x6e6573746564206966 // "nested if"
	retsub

*if7_end:
	// tests/contracts/if.algo.ts:71
	// return 'if';
	byte 0x6966 // "if"
	retsub
	b *if6_end

*if6_else:
	// tests/contracts/if.algo.ts:73
	// return 'else';
	byte 0x656c7365 // "else"
	retsub

*if6_end:
	retsub

// bracketlessIfElse(bool)string
*abi_route_bracketlessIfElse:
	// The ABI return prefix
	byte 0x151f7c75

	// arg0: bool
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 0 (arg0) for bracketlessIfElse must be a bool
	assert
	int 0
	getbit

	// execute bracketlessIfElse(bool)string
	callsub bracketlessIfElse
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// bracketlessIfElse(arg0: boolean): string
bracketlessIfElse:
	proto 1 1

	// *if8_condition
	// tests/contracts/if.algo.ts:78
	// arg0
	frame_dig -1 // arg0: boolean
	bz *if8_else

	// *if8_consequent
	// tests/contracts/if.algo.ts:78
	// return 'if';
	byte 0x6966 // "if"
	retsub
	b *if8_end

*if8_else:
	// tests/contracts/if.algo.ts:79
	// return 'else';
	byte 0x656c7365 // "else"
	retsub

*if8_end:
	retsub

// nestedTernary(bool,bool)uint64
*abi_route_nestedTernary:
	// The ABI return prefix
	byte 0x151f7c75

	// arg1: bool
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 0 (arg1) for nestedTernary must be a bool
	assert
	int 0
	getbit

	// arg0: bool
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 1 (arg0) for nestedTernary must be a bool
	assert
	int 0
	getbit

	// execute nestedTernary(bool,bool)uint64
	callsub nestedTernary
	itob
	concat
	log
	int 1
	return

// nestedTernary(arg0: boolean, arg1: boolean): uint64
nestedTernary:
	proto 2 1

	// tests/contracts/if.algo.ts:84
	// return arg0 ? 1 : arg1 ? 2 : 3;
	frame_dig -1 // arg0: boolean
	bz *ternary0_false
	int 1
	b *ternary0_end

*ternary0_false:
	frame_dig -2 // arg1: boolean
	bz *ternary1_false
	pushint 2
	b *ternary1_end

*ternary1_false:
	pushint 3

*ternary1_end:

*ternary0_end:
	retsub

// stringIf(string)uint64
*abi_route_stringIf:
	// The ABI return prefix
	byte 0x151f7c75

	// arg0: string
	txna ApplicationArgs 1
	extract 2 0

	// execute stringIf(string)uint64
	callsub stringIf
	itob
	concat
	log
	int 1
	return

// stringIf(arg0: string): uint64
stringIf:
	proto 1 1

	// *if9_condition
	// tests/contracts/if.algo.ts:88
	// arg0
	frame_dig -1 // arg0: string
	byte 0x
	b!=
	bz *if9_end

	// *if9_consequent
	// tests/contracts/if.algo.ts:89
	// return 1;
	int 1
	retsub

*if9_end:
	// tests/contracts/if.algo.ts:92
	// return 2;
	pushint 2
	retsub

// stringTernary(string)uint64
*abi_route_stringTernary:
	// The ABI return prefix
	byte 0x151f7c75

	// arg0: string
	txna ApplicationArgs 1
	extract 2 0

	// execute stringTernary(string)uint64
	callsub stringTernary
	itob
	concat
	log
	int 1
	return

// stringTernary(arg0: string): uint64
stringTernary:
	proto 1 1

	// tests/contracts/if.algo.ts:96
	// return arg0 ? 1 : 2;
	frame_dig -1 // arg0: string
	byte 0x
	b!=
	bz *ternary2_false
	int 1
	b *ternary2_end

*ternary2_false:
	pushint 2

*ternary2_end:
	retsub

// smallUintConditional(uint16)void
*abi_route_smallUintConditional:
	// a: uint16
	txna ApplicationArgs 1
	dup
	len
	pushint 2
	==

	// argument 0 (a) for smallUintConditional must be a uint16
	assert
	btoi

	// execute smallUintConditional(uint16)void
	callsub smallUintConditional
	int 1
	return

// smallUintConditional(a: uint16): void
smallUintConditional:
	proto 1 0

	// *if10_condition
	// tests/contracts/if.algo.ts:100
	// a
	frame_dig -1 // a: uint16
	byte 0x
	b!=
	bz *if10_end

	// *if10_consequent
	// tests/contracts/if.algo.ts:101
	// log('foo')
	byte 0x666f6f // "foo"
	log

*if10_end:
	retsub

// smallUintComparisonConditional(uint16,uint16)void
*abi_route_smallUintComparisonConditional:
	// b: uint16
	txna ApplicationArgs 2
	dup
	len
	pushint 2
	==

	// argument 0 (b) for smallUintComparisonConditional must be a uint16
	assert
	btoi

	// a: uint16
	txna ApplicationArgs 1
	dup
	len
	pushint 2
	==

	// argument 1 (a) for smallUintComparisonConditional must be a uint16
	assert
	btoi

	// execute smallUintComparisonConditional(uint16,uint16)void
	callsub smallUintComparisonConditional
	int 1
	return

// smallUintComparisonConditional(a: uint16, b: uint16): void
smallUintComparisonConditional:
	proto 2 0

	// *if11_condition
	// tests/contracts/if.algo.ts:106
	// a <= b
	frame_dig -1 // a: uint16
	frame_dig -2 // b: uint16
	<=
	bz *if11_end

	// *if11_consequent
	// tests/contracts/if.algo.ts:107
	// log('foo')
	byte 0x666f6f // "foo"
	log

*if11_end:
	retsub

// uint256ComparsionConditional(uint256,uint256)void
*abi_route_uint256ComparsionConditional:
	// b: uint256
	txna ApplicationArgs 2
	dup
	len
	pushint 32
	==

	// argument 0 (b) for uint256ComparsionConditional must be a uint256
	assert

	// a: uint256
	txna ApplicationArgs 1
	dup
	len
	pushint 32
	==

	// argument 1 (a) for uint256ComparsionConditional must be a uint256
	assert

	// execute uint256ComparsionConditional(uint256,uint256)void
	callsub uint256ComparsionConditional
	int 1
	return

// uint256ComparsionConditional(a: uint256, b: uint256): void
uint256ComparsionConditional:
	proto 2 0

	// *if12_condition
	// tests/contracts/if.algo.ts:112
	// a <= b
	frame_dig -1 // a: uint256
	frame_dig -2 // b: uint256
	b<=
	bz *if12_end

	// *if12_consequent
	// tests/contracts/if.algo.ts:113
	// log('foo')
	byte 0x666f6f // "foo"
	log

*if12_end:
	retsub

// nestedIfInElseIf(bool,bool)string
*abi_route_nestedIfInElseIf:
	// The ABI return prefix
	byte 0x151f7c75

	// b: bool
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 0 (b) for nestedIfInElseIf must be a bool
	assert
	int 0
	getbit

	// a: bool
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 1 (a) for nestedIfInElseIf must be a bool
	assert
	int 0
	getbit

	// execute nestedIfInElseIf(bool,bool)string
	callsub nestedIfInElseIf
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// nestedIfInElseIf(a: boolean, b: boolean): string
nestedIfInElseIf:
	proto 2 1

	// *if13_condition
	// tests/contracts/if.algo.ts:118
	// a
	frame_dig -1 // a: boolean
	bz *if13_elseif1_condition

	// *if13_consequent
	// *if14_condition
	// tests/contracts/if.algo.ts:119
	// b
	frame_dig -2 // b: boolean
	bz *if14_else

	// *if14_consequent
	// tests/contracts/if.algo.ts:120
	// return 'a and b';
	pushbytes 0x6120616e642062 // "a and b"
	retsub
	b *if14_end

*if14_else:
	// tests/contracts/if.algo.ts:122
	// return 'a';
	pushbytes 0x61 // "a"
	retsub

*if14_end:
	b *if13_end

*if13_elseif1_condition:
	// tests/contracts/if.algo.ts:124
	// b
	frame_dig -2 // b: boolean
	bz *if13_else

	// *if13_elseif1_consequent
	// tests/contracts/if.algo.ts:125
	// return 'b';
	pushbytes 0x62 // "b"
	retsub
	b *if13_end

*if13_else:
	// tests/contracts/if.algo.ts:127
	// return 'neither';
	pushbytes 0x6e656974686572 // "neither"
	retsub

*if13_end:
	retsub

*abi_route_createApplication:
	int 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x436ec1c2 // method "singleIf(bool)string"
	pushbytes 0x1c7a0d5e // method "ifElse(bool)string"
	pushbytes 0x5e0fb6cf // method "ifElseIf(bool,bool)string"
	pushbytes 0x5e1c6c50 // method "ifElseIfElse(bool,bool)string"
	pushbytes 0x58d0ba92 // method "ifElseIfElseIf(bool,bool,bool)string"
	pushbytes 0x5d2f4f02 // method "ifElseIfElseIfElse(bool,bool,bool)string"
	pushbytes 0x845729d9 // method "nestedIf(bool,bool)string"
	pushbytes 0x8fe76ca8 // method "bracketlessIfElse(bool)string"
	pushbytes 0x1a3c7878 // method "nestedTernary(bool,bool)uint64"
	pushbytes 0x74bcc868 // method "stringIf(string)uint64"
	pushbytes 0x4212f905 // method "stringTernary(string)uint64"
	pushbytes 0x95ddaebf // method "smallUintConditional(uint16)void"
	pushbytes 0x3147b866 // method "smallUintComparisonConditional(uint16,uint16)void"
	pushbytes 0x42897f61 // method "uint256ComparsionConditional(uint256,uint256)void"
	pushbytes 0x534be2b7 // method "nestedIfInElseIf(bool,bool)string"
	txna ApplicationArgs 0
	match *abi_route_singleIf *abi_route_ifElse *abi_route_ifElseIf *abi_route_ifElseIfElse *abi_route_ifElseIfElseIf *abi_route_ifElseIfElseIfElse *abi_route_nestedIf *abi_route_bracketlessIfElse *abi_route_nestedTernary *abi_route_stringIf *abi_route_stringTernary *abi_route_smallUintConditional *abi_route_smallUintComparisonConditional *abi_route_uint256ComparsionConditional *abi_route_nestedIfInElseIf

	// this contract does not implement the given ABI method for call NoOp
	err", + "approval": "#pragma version 10
intcblock 1 0
bytecblock 0x151f7c75 0x656c7365 0x6966 0x656c73652069662031 0x656c73652069662032 0x656c7365206966 0x656e64 0x666f6f 0x

// This TEAL was generated by TEALScript v0.105.0
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// singleIf(bool)string
*abi_route_singleIf:
	// The ABI return prefix
	byte 0x151f7c75

	// arg0: bool
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 0 (arg0) for singleIf must be a bool
	assert
	int 0
	getbit

	// execute singleIf(bool)string
	callsub singleIf
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// singleIf(arg0: boolean): string
singleIf:
	proto 1 1

	// *if0_condition
	// tests/contracts/if.algo.ts:7
	// arg0
	frame_dig -1 // arg0: boolean
	bz *if0_end

	// *if0_consequent
	// tests/contracts/if.algo.ts:8
	// return 'if';
	byte 0x6966 // "if"
	retsub

*if0_end:
	// tests/contracts/if.algo.ts:11
	// return 'end';
	byte 0x656e64 // "end"
	retsub

// ifElse(bool)string
*abi_route_ifElse:
	// The ABI return prefix
	byte 0x151f7c75

	// arg0: bool
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 0 (arg0) for ifElse must be a bool
	assert
	int 0
	getbit

	// execute ifElse(bool)string
	callsub ifElse
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// ifElse(arg0: boolean): string
ifElse:
	proto 1 1

	// *if1_condition
	// tests/contracts/if.algo.ts:15
	// arg0
	frame_dig -1 // arg0: boolean
	bz *if1_else

	// *if1_consequent
	// tests/contracts/if.algo.ts:16
	// return 'if';
	byte 0x6966 // "if"
	retsub
	b *if1_end

*if1_else:
	// tests/contracts/if.algo.ts:18
	// return 'else';
	byte 0x656c7365 // "else"
	retsub

*if1_end:
	retsub

// ifElseIf(bool,bool)string
*abi_route_ifElseIf:
	// The ABI return prefix
	byte 0x151f7c75

	// arg1: bool
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 0 (arg1) for ifElseIf must be a bool
	assert
	int 0
	getbit

	// arg0: bool
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 1 (arg0) for ifElseIf must be a bool
	assert
	int 0
	getbit

	// execute ifElseIf(bool,bool)string
	callsub ifElseIf
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// ifElseIf(arg0: boolean, arg1: boolean): string
ifElseIf:
	proto 2 1

	// *if2_condition
	// tests/contracts/if.algo.ts:23
	// arg0
	frame_dig -1 // arg0: boolean
	bz *if2_elseif1_condition

	// *if2_consequent
	// tests/contracts/if.algo.ts:24
	// return 'if';
	byte 0x6966 // "if"
	retsub
	b *if2_end

*if2_elseif1_condition:
	// tests/contracts/if.algo.ts:25
	// arg1
	frame_dig -2 // arg1: boolean
	bz *if2_end

	// *if2_elseif1_consequent
	// tests/contracts/if.algo.ts:26
	// return 'else if';
	byte 0x656c7365206966 // "else if"
	retsub

*if2_end:
	// tests/contracts/if.algo.ts:29
	// return 'end';
	byte 0x656e64 // "end"
	retsub

// ifElseIfElse(bool,bool)string
*abi_route_ifElseIfElse:
	// The ABI return prefix
	byte 0x151f7c75

	// arg1: bool
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 0 (arg1) for ifElseIfElse must be a bool
	assert
	int 0
	getbit

	// arg0: bool
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 1 (arg0) for ifElseIfElse must be a bool
	assert
	int 0
	getbit

	// execute ifElseIfElse(bool,bool)string
	callsub ifElseIfElse
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// ifElseIfElse(arg0: boolean, arg1: boolean): string
ifElseIfElse:
	proto 2 1

	// *if3_condition
	// tests/contracts/if.algo.ts:33
	// arg0
	frame_dig -1 // arg0: boolean
	bz *if3_elseif1_condition

	// *if3_consequent
	// tests/contracts/if.algo.ts:34
	// return 'if';
	byte 0x6966 // "if"
	retsub
	b *if3_end

*if3_elseif1_condition:
	// tests/contracts/if.algo.ts:35
	// arg1
	frame_dig -2 // arg1: boolean
	bz *if3_else

	// *if3_elseif1_consequent
	// tests/contracts/if.algo.ts:36
	// return 'else if';
	byte 0x656c7365206966 // "else if"
	retsub
	b *if3_end

*if3_else:
	// tests/contracts/if.algo.ts:38
	// return 'else';
	byte 0x656c7365 // "else"
	retsub

*if3_end:
	retsub

// ifElseIfElseIf(bool,bool,bool)string
*abi_route_ifElseIfElseIf:
	// The ABI return prefix
	byte 0x151f7c75

	// arg2: bool
	txna ApplicationArgs 3
	dup
	len
	int 1
	==

	// argument 0 (arg2) for ifElseIfElseIf must be a bool
	assert
	int 0
	getbit

	// arg1: bool
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 1 (arg1) for ifElseIfElseIf must be a bool
	assert
	int 0
	getbit

	// arg0: bool
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 2 (arg0) for ifElseIfElseIf must be a bool
	assert
	int 0
	getbit

	// execute ifElseIfElseIf(bool,bool,bool)string
	callsub ifElseIfElseIf
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// ifElseIfElseIf(arg0: boolean, arg1: boolean, arg2: boolean): string
ifElseIfElseIf:
	proto 3 1

	// *if4_condition
	// tests/contracts/if.algo.ts:43
	// arg0
	frame_dig -1 // arg0: boolean
	bz *if4_elseif1_condition

	// *if4_consequent
	// tests/contracts/if.algo.ts:44
	// return 'if';
	byte 0x6966 // "if"
	retsub
	b *if4_end

*if4_elseif1_condition:
	// tests/contracts/if.algo.ts:45
	// arg1
	frame_dig -2 // arg1: boolean
	bz *if4_elseif2_condition

	// *if4_elseif1_consequent
	// tests/contracts/if.algo.ts:46
	// return 'else if 1';
	byte 0x656c73652069662031 // "else if 1"
	retsub
	b *if4_end

*if4_elseif2_condition:
	// tests/contracts/if.algo.ts:47
	// arg2
	frame_dig -3 // arg2: boolean
	bz *if4_end

	// *if4_elseif2_consequent
	// tests/contracts/if.algo.ts:48
	// return 'else if 2';
	byte 0x656c73652069662032 // "else if 2"
	retsub

*if4_end:
	// tests/contracts/if.algo.ts:51
	// return 'end';
	byte 0x656e64 // "end"
	retsub

// ifElseIfElseIfElse(bool,bool,bool)string
*abi_route_ifElseIfElseIfElse:
	// The ABI return prefix
	byte 0x151f7c75

	// arg2: bool
	txna ApplicationArgs 3
	dup
	len
	int 1
	==

	// argument 0 (arg2) for ifElseIfElseIfElse must be a bool
	assert
	int 0
	getbit

	// arg1: bool
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 1 (arg1) for ifElseIfElseIfElse must be a bool
	assert
	int 0
	getbit

	// arg0: bool
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 2 (arg0) for ifElseIfElseIfElse must be a bool
	assert
	int 0
	getbit

	// execute ifElseIfElseIfElse(bool,bool,bool)string
	callsub ifElseIfElseIfElse
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// ifElseIfElseIfElse(arg0: boolean, arg1: boolean, arg2: boolean): string
ifElseIfElseIfElse:
	proto 3 1

	// *if5_condition
	// tests/contracts/if.algo.ts:55
	// arg0
	frame_dig -1 // arg0: boolean
	bz *if5_elseif1_condition

	// *if5_consequent
	// tests/contracts/if.algo.ts:56
	// return 'if';
	byte 0x6966 // "if"
	retsub
	b *if5_end

*if5_elseif1_condition:
	// tests/contracts/if.algo.ts:57
	// arg1
	frame_dig -2 // arg1: boolean
	bz *if5_elseif2_condition

	// *if5_elseif1_consequent
	// tests/contracts/if.algo.ts:58
	// return 'else if 1';
	byte 0x656c73652069662031 // "else if 1"
	retsub
	b *if5_end

*if5_elseif2_condition:
	// tests/contracts/if.algo.ts:59
	// arg2
	frame_dig -3 // arg2: boolean
	bz *if5_else

	// *if5_elseif2_consequent
	// tests/contracts/if.algo.ts:60
	// return 'else if 2';
	byte 0x656c73652069662032 // "else if 2"
	retsub
	b *if5_end

*if5_else:
	// tests/contracts/if.algo.ts:62
	// return 'else';
	byte 0x656c7365 // "else"
	retsub

*if5_end:
	retsub

// nestedIf(bool,bool)string
*abi_route_nestedIf:
	// The ABI return prefix
	byte 0x151f7c75

	// arg1: bool
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 0 (arg1) for nestedIf must be a bool
	assert
	int 0
	getbit

	// arg0: bool
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 1 (arg0) for nestedIf must be a bool
	assert
	int 0
	getbit

	// execute nestedIf(bool,bool)string
	callsub nestedIf
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// nestedIf(arg0: boolean, arg1: boolean): string
nestedIf:
	proto 2 1

	// *if6_condition
	// tests/contracts/if.algo.ts:67
	// arg0
	frame_dig -1 // arg0: boolean
	bz *if6_else

	// *if6_consequent
	// *if7_condition
	// tests/contracts/if.algo.ts:68
	// arg1
	frame_dig -2 // arg1: boolean
	bz *if7_end

	// *if7_consequent
	// tests/contracts/if.algo.ts:69
	// return 'nested if';
	pushbytes 0x6e6573746564206966 // "nested if"
	retsub

*if7_end:
	// tests/contracts/if.algo.ts:71
	// return 'if';
	byte 0x6966 // "if"
	retsub
	b *if6_end

*if6_else:
	// tests/contracts/if.algo.ts:73
	// return 'else';
	byte 0x656c7365 // "else"
	retsub

*if6_end:
	retsub

// bracketlessIfElse(bool)string
*abi_route_bracketlessIfElse:
	// The ABI return prefix
	byte 0x151f7c75

	// arg0: bool
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 0 (arg0) for bracketlessIfElse must be a bool
	assert
	int 0
	getbit

	// execute bracketlessIfElse(bool)string
	callsub bracketlessIfElse
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// bracketlessIfElse(arg0: boolean): string
bracketlessIfElse:
	proto 1 1

	// *if8_condition
	// tests/contracts/if.algo.ts:78
	// arg0
	frame_dig -1 // arg0: boolean
	bz *if8_else

	// *if8_consequent
	// tests/contracts/if.algo.ts:78
	// return 'if';
	byte 0x6966 // "if"
	retsub
	b *if8_end

*if8_else:
	// tests/contracts/if.algo.ts:79
	// return 'else';
	byte 0x656c7365 // "else"
	retsub

*if8_end:
	retsub

// nestedTernary(bool,bool)uint64
*abi_route_nestedTernary:
	// The ABI return prefix
	byte 0x151f7c75

	// arg1: bool
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 0 (arg1) for nestedTernary must be a bool
	assert
	int 0
	getbit

	// arg0: bool
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 1 (arg0) for nestedTernary must be a bool
	assert
	int 0
	getbit

	// execute nestedTernary(bool,bool)uint64
	callsub nestedTernary
	itob
	concat
	log
	int 1
	return

// nestedTernary(arg0: boolean, arg1: boolean): uint64
nestedTernary:
	proto 2 1

	// tests/contracts/if.algo.ts:84
	// return arg0 ? 1 : arg1 ? 2 : 3;
	frame_dig -1 // arg0: boolean
	bz *ternary0_false
	int 1
	b *ternary0_end

*ternary0_false:
	frame_dig -2 // arg1: boolean
	bz *ternary1_false
	pushint 2
	b *ternary1_end

*ternary1_false:
	pushint 3

*ternary1_end:

*ternary0_end:
	retsub

// stringIf(string)uint64
*abi_route_stringIf:
	// The ABI return prefix
	byte 0x151f7c75

	// arg0: string
	txna ApplicationArgs 1
	extract 2 0

	// execute stringIf(string)uint64
	callsub stringIf
	itob
	concat
	log
	int 1
	return

// stringIf(arg0: string): uint64
stringIf:
	proto 1 1

	// *if9_condition
	// tests/contracts/if.algo.ts:88
	// arg0
	frame_dig -1 // arg0: string
	byte 0x
	b!=
	bz *if9_end

	// *if9_consequent
	// tests/contracts/if.algo.ts:89
	// return 1;
	int 1
	retsub

*if9_end:
	// tests/contracts/if.algo.ts:92
	// return 2;
	pushint 2
	retsub

// stringTernary(string)uint64
*abi_route_stringTernary:
	// The ABI return prefix
	byte 0x151f7c75

	// arg0: string
	txna ApplicationArgs 1
	extract 2 0

	// execute stringTernary(string)uint64
	callsub stringTernary
	itob
	concat
	log
	int 1
	return

// stringTernary(arg0: string): uint64
stringTernary:
	proto 1 1

	// tests/contracts/if.algo.ts:96
	// return arg0 ? 1 : 2;
	frame_dig -1 // arg0: string
	byte 0x
	b!=
	bz *ternary2_false
	int 1
	b *ternary2_end

*ternary2_false:
	pushint 2

*ternary2_end:
	retsub

// smallUintConditional(uint16)void
*abi_route_smallUintConditional:
	// a: uint16
	txna ApplicationArgs 1
	dup
	len
	pushint 2
	==

	// argument 0 (a) for smallUintConditional must be a uint16
	assert
	btoi

	// execute smallUintConditional(uint16)void
	callsub smallUintConditional
	int 1
	return

// smallUintConditional(a: uint16): void
smallUintConditional:
	proto 1 0

	// *if10_condition
	// tests/contracts/if.algo.ts:100
	// a
	frame_dig -1 // a: uint16
	byte 0x
	b!=
	bz *if10_end

	// *if10_consequent
	// tests/contracts/if.algo.ts:101
	// log('foo')
	byte 0x666f6f // "foo"
	log

*if10_end:
	retsub

// smallUintComparisonConditional(uint16,uint16)void
*abi_route_smallUintComparisonConditional:
	// b: uint16
	txna ApplicationArgs 2
	dup
	len
	pushint 2
	==

	// argument 0 (b) for smallUintComparisonConditional must be a uint16
	assert
	btoi

	// a: uint16
	txna ApplicationArgs 1
	dup
	len
	pushint 2
	==

	// argument 1 (a) for smallUintComparisonConditional must be a uint16
	assert
	btoi

	// execute smallUintComparisonConditional(uint16,uint16)void
	callsub smallUintComparisonConditional
	int 1
	return

// smallUintComparisonConditional(a: uint16, b: uint16): void
smallUintComparisonConditional:
	proto 2 0

	// *if11_condition
	// tests/contracts/if.algo.ts:106
	// a <= b
	frame_dig -1 // a: uint16
	frame_dig -2 // b: uint16
	<=
	bz *if11_end

	// *if11_consequent
	// tests/contracts/if.algo.ts:107
	// log('foo')
	byte 0x666f6f // "foo"
	log

*if11_end:
	retsub

// uint256ComparsionConditional(uint256,uint256)void
*abi_route_uint256ComparsionConditional:
	// b: uint256
	txna ApplicationArgs 2
	dup
	len
	pushint 32
	==

	// argument 0 (b) for uint256ComparsionConditional must be a uint256
	assert

	// a: uint256
	txna ApplicationArgs 1
	dup
	len
	pushint 32
	==

	// argument 1 (a) for uint256ComparsionConditional must be a uint256
	assert

	// execute uint256ComparsionConditional(uint256,uint256)void
	callsub uint256ComparsionConditional
	int 1
	return

// uint256ComparsionConditional(a: uint256, b: uint256): void
uint256ComparsionConditional:
	proto 2 0

	// *if12_condition
	// tests/contracts/if.algo.ts:112
	// a <= b
	frame_dig -1 // a: uint256
	frame_dig -2 // b: uint256
	b<=
	bz *if12_end

	// *if12_consequent
	// tests/contracts/if.algo.ts:113
	// log('foo')
	byte 0x666f6f // "foo"
	log

*if12_end:
	retsub

// nestedIfInElseIf(bool,bool)string
*abi_route_nestedIfInElseIf:
	// The ABI return prefix
	byte 0x151f7c75

	// b: bool
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 0 (b) for nestedIfInElseIf must be a bool
	assert
	int 0
	getbit

	// a: bool
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 1 (a) for nestedIfInElseIf must be a bool
	assert
	int 0
	getbit

	// execute nestedIfInElseIf(bool,bool)string
	callsub nestedIfInElseIf
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// nestedIfInElseIf(a: boolean, b: boolean): string
nestedIfInElseIf:
	proto 2 1

	// *if13_condition
	// tests/contracts/if.algo.ts:118
	// a
	frame_dig -1 // a: boolean
	bz *if13_elseif1_condition

	// *if13_consequent
	// *if14_condition
	// tests/contracts/if.algo.ts:119
	// b
	frame_dig -2 // b: boolean
	bz *if14_else

	// *if14_consequent
	// tests/contracts/if.algo.ts:120
	// return 'a and b';
	pushbytes 0x6120616e642062 // "a and b"
	retsub
	b *if14_end

*if14_else:
	// tests/contracts/if.algo.ts:122
	// return 'a';
	pushbytes 0x61 // "a"
	retsub

*if14_end:
	b *if13_end

*if13_elseif1_condition:
	// tests/contracts/if.algo.ts:124
	// b
	frame_dig -2 // b: boolean
	bz *if13_else

	// *if13_elseif1_consequent
	// tests/contracts/if.algo.ts:125
	// return 'b';
	pushbytes 0x62 // "b"
	retsub
	b *if13_end

*if13_else:
	// tests/contracts/if.algo.ts:127
	// return 'neither';
	pushbytes 0x6e656974686572 // "neither"
	retsub

*if13_end:
	retsub

*abi_route_createApplication:
	int 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x436ec1c2 // method "singleIf(bool)string"
	pushbytes 0x1c7a0d5e // method "ifElse(bool)string"
	pushbytes 0x5e0fb6cf // method "ifElseIf(bool,bool)string"
	pushbytes 0x5e1c6c50 // method "ifElseIfElse(bool,bool)string"
	pushbytes 0x58d0ba92 // method "ifElseIfElseIf(bool,bool,bool)string"
	pushbytes 0x5d2f4f02 // method "ifElseIfElseIfElse(bool,bool,bool)string"
	pushbytes 0x845729d9 // method "nestedIf(bool,bool)string"
	pushbytes 0x8fe76ca8 // method "bracketlessIfElse(bool)string"
	pushbytes 0x1a3c7878 // method "nestedTernary(bool,bool)uint64"
	pushbytes 0x74bcc868 // method "stringIf(string)uint64"
	pushbytes 0x4212f905 // method "stringTernary(string)uint64"
	pushbytes 0x95ddaebf // method "smallUintConditional(uint16)void"
	pushbytes 0x3147b866 // method "smallUintComparisonConditional(uint16,uint16)void"
	pushbytes 0x42897f61 // method "uint256ComparsionConditional(uint256,uint256)void"
	pushbytes 0x534be2b7 // method "nestedIfInElseIf(bool,bool)string"
	txna ApplicationArgs 0
	match *abi_route_singleIf *abi_route_ifElse *abi_route_ifElseIf *abi_route_ifElseIfElse *abi_route_ifElseIfElseIf *abi_route_ifElseIfElseIfElse *abi_route_nestedIf *abi_route_bracketlessIfElse *abi_route_nestedTernary *abi_route_stringIf *abi_route_stringTernary *abi_route_smallUintConditional *abi_route_smallUintComparisonConditional *abi_route_uint256ComparsionConditional *abi_route_nestedIfInElseIf

	// this contract does not implement the given ABI method for call NoOp
	err", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/IfTest.arc56_draft.json b/tests/contracts/artifacts/IfTest.arc56_draft.json index 31dd5d2a1..46707cb18 100644 --- a/tests/contracts/artifacts/IfTest.arc56_draft.json +++ b/tests/contracts/artifacts/IfTest.arc56_draft.json @@ -4871,7 +4871,7 @@ } }, "source": { - "approval": "#pragma version 10
intcblock 1 0
bytecblock 0x151f7c75 0x656c7365 0x6966 0x656c73652069662031 0x656c73652069662032 0x656c7365206966 0x656e64 0x666f6f 0x

// This TEAL was generated by TEALScript v0.104.1
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// singleIf(bool)string
*abi_route_singleIf:
	// The ABI return prefix
	byte 0x151f7c75

	// arg0: bool
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 0 (arg0) for singleIf must be a bool
	assert
	int 0
	getbit

	// execute singleIf(bool)string
	callsub singleIf
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// singleIf(arg0: boolean): string
singleIf:
	proto 1 1

	// *if0_condition
	// tests/contracts/if.algo.ts:7
	// arg0
	frame_dig -1 // arg0: boolean
	bz *if0_end

	// *if0_consequent
	// tests/contracts/if.algo.ts:8
	// return 'if';
	byte 0x6966 // "if"
	retsub

*if0_end:
	// tests/contracts/if.algo.ts:11
	// return 'end';
	byte 0x656e64 // "end"
	retsub

// ifElse(bool)string
*abi_route_ifElse:
	// The ABI return prefix
	byte 0x151f7c75

	// arg0: bool
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 0 (arg0) for ifElse must be a bool
	assert
	int 0
	getbit

	// execute ifElse(bool)string
	callsub ifElse
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// ifElse(arg0: boolean): string
ifElse:
	proto 1 1

	// *if1_condition
	// tests/contracts/if.algo.ts:15
	// arg0
	frame_dig -1 // arg0: boolean
	bz *if1_else

	// *if1_consequent
	// tests/contracts/if.algo.ts:16
	// return 'if';
	byte 0x6966 // "if"
	retsub
	b *if1_end

*if1_else:
	// tests/contracts/if.algo.ts:18
	// return 'else';
	byte 0x656c7365 // "else"
	retsub

*if1_end:
	retsub

// ifElseIf(bool,bool)string
*abi_route_ifElseIf:
	// The ABI return prefix
	byte 0x151f7c75

	// arg1: bool
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 0 (arg1) for ifElseIf must be a bool
	assert
	int 0
	getbit

	// arg0: bool
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 1 (arg0) for ifElseIf must be a bool
	assert
	int 0
	getbit

	// execute ifElseIf(bool,bool)string
	callsub ifElseIf
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// ifElseIf(arg0: boolean, arg1: boolean): string
ifElseIf:
	proto 2 1

	// *if2_condition
	// tests/contracts/if.algo.ts:23
	// arg0
	frame_dig -1 // arg0: boolean
	bz *if2_elseif1_condition

	// *if2_consequent
	// tests/contracts/if.algo.ts:24
	// return 'if';
	byte 0x6966 // "if"
	retsub
	b *if2_end

*if2_elseif1_condition:
	// tests/contracts/if.algo.ts:25
	// arg1
	frame_dig -2 // arg1: boolean
	bz *if2_end

	// *if2_elseif1_consequent
	// tests/contracts/if.algo.ts:26
	// return 'else if';
	byte 0x656c7365206966 // "else if"
	retsub

*if2_end:
	// tests/contracts/if.algo.ts:29
	// return 'end';
	byte 0x656e64 // "end"
	retsub

// ifElseIfElse(bool,bool)string
*abi_route_ifElseIfElse:
	// The ABI return prefix
	byte 0x151f7c75

	// arg1: bool
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 0 (arg1) for ifElseIfElse must be a bool
	assert
	int 0
	getbit

	// arg0: bool
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 1 (arg0) for ifElseIfElse must be a bool
	assert
	int 0
	getbit

	// execute ifElseIfElse(bool,bool)string
	callsub ifElseIfElse
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// ifElseIfElse(arg0: boolean, arg1: boolean): string
ifElseIfElse:
	proto 2 1

	// *if3_condition
	// tests/contracts/if.algo.ts:33
	// arg0
	frame_dig -1 // arg0: boolean
	bz *if3_elseif1_condition

	// *if3_consequent
	// tests/contracts/if.algo.ts:34
	// return 'if';
	byte 0x6966 // "if"
	retsub
	b *if3_end

*if3_elseif1_condition:
	// tests/contracts/if.algo.ts:35
	// arg1
	frame_dig -2 // arg1: boolean
	bz *if3_else

	// *if3_elseif1_consequent
	// tests/contracts/if.algo.ts:36
	// return 'else if';
	byte 0x656c7365206966 // "else if"
	retsub
	b *if3_end

*if3_else:
	// tests/contracts/if.algo.ts:38
	// return 'else';
	byte 0x656c7365 // "else"
	retsub

*if3_end:
	retsub

// ifElseIfElseIf(bool,bool,bool)string
*abi_route_ifElseIfElseIf:
	// The ABI return prefix
	byte 0x151f7c75

	// arg2: bool
	txna ApplicationArgs 3
	dup
	len
	int 1
	==

	// argument 0 (arg2) for ifElseIfElseIf must be a bool
	assert
	int 0
	getbit

	// arg1: bool
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 1 (arg1) for ifElseIfElseIf must be a bool
	assert
	int 0
	getbit

	// arg0: bool
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 2 (arg0) for ifElseIfElseIf must be a bool
	assert
	int 0
	getbit

	// execute ifElseIfElseIf(bool,bool,bool)string
	callsub ifElseIfElseIf
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// ifElseIfElseIf(arg0: boolean, arg1: boolean, arg2: boolean): string
ifElseIfElseIf:
	proto 3 1

	// *if4_condition
	// tests/contracts/if.algo.ts:43
	// arg0
	frame_dig -1 // arg0: boolean
	bz *if4_elseif1_condition

	// *if4_consequent
	// tests/contracts/if.algo.ts:44
	// return 'if';
	byte 0x6966 // "if"
	retsub
	b *if4_end

*if4_elseif1_condition:
	// tests/contracts/if.algo.ts:45
	// arg1
	frame_dig -2 // arg1: boolean
	bz *if4_elseif2_condition

	// *if4_elseif1_consequent
	// tests/contracts/if.algo.ts:46
	// return 'else if 1';
	byte 0x656c73652069662031 // "else if 1"
	retsub
	b *if4_end

*if4_elseif2_condition:
	// tests/contracts/if.algo.ts:47
	// arg2
	frame_dig -3 // arg2: boolean
	bz *if4_end

	// *if4_elseif2_consequent
	// tests/contracts/if.algo.ts:48
	// return 'else if 2';
	byte 0x656c73652069662032 // "else if 2"
	retsub

*if4_end:
	// tests/contracts/if.algo.ts:51
	// return 'end';
	byte 0x656e64 // "end"
	retsub

// ifElseIfElseIfElse(bool,bool,bool)string
*abi_route_ifElseIfElseIfElse:
	// The ABI return prefix
	byte 0x151f7c75

	// arg2: bool
	txna ApplicationArgs 3
	dup
	len
	int 1
	==

	// argument 0 (arg2) for ifElseIfElseIfElse must be a bool
	assert
	int 0
	getbit

	// arg1: bool
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 1 (arg1) for ifElseIfElseIfElse must be a bool
	assert
	int 0
	getbit

	// arg0: bool
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 2 (arg0) for ifElseIfElseIfElse must be a bool
	assert
	int 0
	getbit

	// execute ifElseIfElseIfElse(bool,bool,bool)string
	callsub ifElseIfElseIfElse
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// ifElseIfElseIfElse(arg0: boolean, arg1: boolean, arg2: boolean): string
ifElseIfElseIfElse:
	proto 3 1

	// *if5_condition
	// tests/contracts/if.algo.ts:55
	// arg0
	frame_dig -1 // arg0: boolean
	bz *if5_elseif1_condition

	// *if5_consequent
	// tests/contracts/if.algo.ts:56
	// return 'if';
	byte 0x6966 // "if"
	retsub
	b *if5_end

*if5_elseif1_condition:
	// tests/contracts/if.algo.ts:57
	// arg1
	frame_dig -2 // arg1: boolean
	bz *if5_elseif2_condition

	// *if5_elseif1_consequent
	// tests/contracts/if.algo.ts:58
	// return 'else if 1';
	byte 0x656c73652069662031 // "else if 1"
	retsub
	b *if5_end

*if5_elseif2_condition:
	// tests/contracts/if.algo.ts:59
	// arg2
	frame_dig -3 // arg2: boolean
	bz *if5_else

	// *if5_elseif2_consequent
	// tests/contracts/if.algo.ts:60
	// return 'else if 2';
	byte 0x656c73652069662032 // "else if 2"
	retsub
	b *if5_end

*if5_else:
	// tests/contracts/if.algo.ts:62
	// return 'else';
	byte 0x656c7365 // "else"
	retsub

*if5_end:
	retsub

// nestedIf(bool,bool)string
*abi_route_nestedIf:
	// The ABI return prefix
	byte 0x151f7c75

	// arg1: bool
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 0 (arg1) for nestedIf must be a bool
	assert
	int 0
	getbit

	// arg0: bool
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 1 (arg0) for nestedIf must be a bool
	assert
	int 0
	getbit

	// execute nestedIf(bool,bool)string
	callsub nestedIf
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// nestedIf(arg0: boolean, arg1: boolean): string
nestedIf:
	proto 2 1

	// *if6_condition
	// tests/contracts/if.algo.ts:67
	// arg0
	frame_dig -1 // arg0: boolean
	bz *if6_else

	// *if6_consequent
	// *if7_condition
	// tests/contracts/if.algo.ts:68
	// arg1
	frame_dig -2 // arg1: boolean
	bz *if7_end

	// *if7_consequent
	// tests/contracts/if.algo.ts:69
	// return 'nested if';
	pushbytes 0x6e6573746564206966 // "nested if"
	retsub

*if7_end:
	// tests/contracts/if.algo.ts:71
	// return 'if';
	byte 0x6966 // "if"
	retsub
	b *if6_end

*if6_else:
	// tests/contracts/if.algo.ts:73
	// return 'else';
	byte 0x656c7365 // "else"
	retsub

*if6_end:
	retsub

// bracketlessIfElse(bool)string
*abi_route_bracketlessIfElse:
	// The ABI return prefix
	byte 0x151f7c75

	// arg0: bool
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 0 (arg0) for bracketlessIfElse must be a bool
	assert
	int 0
	getbit

	// execute bracketlessIfElse(bool)string
	callsub bracketlessIfElse
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// bracketlessIfElse(arg0: boolean): string
bracketlessIfElse:
	proto 1 1

	// *if8_condition
	// tests/contracts/if.algo.ts:78
	// arg0
	frame_dig -1 // arg0: boolean
	bz *if8_else

	// *if8_consequent
	// tests/contracts/if.algo.ts:78
	// return 'if';
	byte 0x6966 // "if"
	retsub
	b *if8_end

*if8_else:
	// tests/contracts/if.algo.ts:79
	// return 'else';
	byte 0x656c7365 // "else"
	retsub

*if8_end:
	retsub

// nestedTernary(bool,bool)uint64
*abi_route_nestedTernary:
	// The ABI return prefix
	byte 0x151f7c75

	// arg1: bool
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 0 (arg1) for nestedTernary must be a bool
	assert
	int 0
	getbit

	// arg0: bool
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 1 (arg0) for nestedTernary must be a bool
	assert
	int 0
	getbit

	// execute nestedTernary(bool,bool)uint64
	callsub nestedTernary
	itob
	concat
	log
	int 1
	return

// nestedTernary(arg0: boolean, arg1: boolean): uint64
nestedTernary:
	proto 2 1

	// tests/contracts/if.algo.ts:84
	// return arg0 ? 1 : arg1 ? 2 : 3;
	frame_dig -1 // arg0: boolean
	bz *ternary0_false
	int 1
	b *ternary0_end

*ternary0_false:
	frame_dig -2 // arg1: boolean
	bz *ternary1_false
	pushint 2
	b *ternary1_end

*ternary1_false:
	pushint 3

*ternary1_end:

*ternary0_end:
	retsub

// stringIf(string)uint64
*abi_route_stringIf:
	// The ABI return prefix
	byte 0x151f7c75

	// arg0: string
	txna ApplicationArgs 1
	extract 2 0

	// execute stringIf(string)uint64
	callsub stringIf
	itob
	concat
	log
	int 1
	return

// stringIf(arg0: string): uint64
stringIf:
	proto 1 1

	// *if9_condition
	// tests/contracts/if.algo.ts:88
	// arg0
	frame_dig -1 // arg0: string
	byte 0x
	b!=
	bz *if9_end

	// *if9_consequent
	// tests/contracts/if.algo.ts:89
	// return 1;
	int 1
	retsub

*if9_end:
	// tests/contracts/if.algo.ts:92
	// return 2;
	pushint 2
	retsub

// stringTernary(string)uint64
*abi_route_stringTernary:
	// The ABI return prefix
	byte 0x151f7c75

	// arg0: string
	txna ApplicationArgs 1
	extract 2 0

	// execute stringTernary(string)uint64
	callsub stringTernary
	itob
	concat
	log
	int 1
	return

// stringTernary(arg0: string): uint64
stringTernary:
	proto 1 1

	// tests/contracts/if.algo.ts:96
	// return arg0 ? 1 : 2;
	frame_dig -1 // arg0: string
	byte 0x
	b!=
	bz *ternary2_false
	int 1
	b *ternary2_end

*ternary2_false:
	pushint 2

*ternary2_end:
	retsub

// smallUintConditional(uint16)void
*abi_route_smallUintConditional:
	// a: uint16
	txna ApplicationArgs 1
	dup
	len
	pushint 2
	==

	// argument 0 (a) for smallUintConditional must be a uint16
	assert
	btoi

	// execute smallUintConditional(uint16)void
	callsub smallUintConditional
	int 1
	return

// smallUintConditional(a: uint16): void
smallUintConditional:
	proto 1 0

	// *if10_condition
	// tests/contracts/if.algo.ts:100
	// a
	frame_dig -1 // a: uint16
	byte 0x
	b!=
	bz *if10_end

	// *if10_consequent
	// tests/contracts/if.algo.ts:101
	// log('foo')
	byte 0x666f6f // "foo"
	log

*if10_end:
	retsub

// smallUintComparisonConditional(uint16,uint16)void
*abi_route_smallUintComparisonConditional:
	// b: uint16
	txna ApplicationArgs 2
	dup
	len
	pushint 2
	==

	// argument 0 (b) for smallUintComparisonConditional must be a uint16
	assert
	btoi

	// a: uint16
	txna ApplicationArgs 1
	dup
	len
	pushint 2
	==

	// argument 1 (a) for smallUintComparisonConditional must be a uint16
	assert
	btoi

	// execute smallUintComparisonConditional(uint16,uint16)void
	callsub smallUintComparisonConditional
	int 1
	return

// smallUintComparisonConditional(a: uint16, b: uint16): void
smallUintComparisonConditional:
	proto 2 0

	// *if11_condition
	// tests/contracts/if.algo.ts:106
	// a <= b
	frame_dig -1 // a: uint16
	frame_dig -2 // b: uint16
	<=
	bz *if11_end

	// *if11_consequent
	// tests/contracts/if.algo.ts:107
	// log('foo')
	byte 0x666f6f // "foo"
	log

*if11_end:
	retsub

// uint256ComparsionConditional(uint256,uint256)void
*abi_route_uint256ComparsionConditional:
	// b: uint256
	txna ApplicationArgs 2
	dup
	len
	pushint 32
	==

	// argument 0 (b) for uint256ComparsionConditional must be a uint256
	assert

	// a: uint256
	txna ApplicationArgs 1
	dup
	len
	pushint 32
	==

	// argument 1 (a) for uint256ComparsionConditional must be a uint256
	assert

	// execute uint256ComparsionConditional(uint256,uint256)void
	callsub uint256ComparsionConditional
	int 1
	return

// uint256ComparsionConditional(a: uint256, b: uint256): void
uint256ComparsionConditional:
	proto 2 0

	// *if12_condition
	// tests/contracts/if.algo.ts:112
	// a <= b
	frame_dig -1 // a: uint256
	frame_dig -2 // b: uint256
	b<=
	bz *if12_end

	// *if12_consequent
	// tests/contracts/if.algo.ts:113
	// log('foo')
	byte 0x666f6f // "foo"
	log

*if12_end:
	retsub

// nestedIfInElseIf(bool,bool)string
*abi_route_nestedIfInElseIf:
	// The ABI return prefix
	byte 0x151f7c75

	// b: bool
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 0 (b) for nestedIfInElseIf must be a bool
	assert
	int 0
	getbit

	// a: bool
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 1 (a) for nestedIfInElseIf must be a bool
	assert
	int 0
	getbit

	// execute nestedIfInElseIf(bool,bool)string
	callsub nestedIfInElseIf
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// nestedIfInElseIf(a: boolean, b: boolean): string
nestedIfInElseIf:
	proto 2 1

	// *if13_condition
	// tests/contracts/if.algo.ts:118
	// a
	frame_dig -1 // a: boolean
	bz *if13_elseif1_condition

	// *if13_consequent
	// *if14_condition
	// tests/contracts/if.algo.ts:119
	// b
	frame_dig -2 // b: boolean
	bz *if14_else

	// *if14_consequent
	// tests/contracts/if.algo.ts:120
	// return 'a and b';
	pushbytes 0x6120616e642062 // "a and b"
	retsub
	b *if14_end

*if14_else:
	// tests/contracts/if.algo.ts:122
	// return 'a';
	pushbytes 0x61 // "a"
	retsub

*if14_end:
	b *if13_end

*if13_elseif1_condition:
	// tests/contracts/if.algo.ts:124
	// b
	frame_dig -2 // b: boolean
	bz *if13_else

	// *if13_elseif1_consequent
	// tests/contracts/if.algo.ts:125
	// return 'b';
	pushbytes 0x62 // "b"
	retsub
	b *if13_end

*if13_else:
	// tests/contracts/if.algo.ts:127
	// return 'neither';
	pushbytes 0x6e656974686572 // "neither"
	retsub

*if13_end:
	retsub

*abi_route_createApplication:
	int 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x436ec1c2 // method "singleIf(bool)string"
	pushbytes 0x1c7a0d5e // method "ifElse(bool)string"
	pushbytes 0x5e0fb6cf // method "ifElseIf(bool,bool)string"
	pushbytes 0x5e1c6c50 // method "ifElseIfElse(bool,bool)string"
	pushbytes 0x58d0ba92 // method "ifElseIfElseIf(bool,bool,bool)string"
	pushbytes 0x5d2f4f02 // method "ifElseIfElseIfElse(bool,bool,bool)string"
	pushbytes 0x845729d9 // method "nestedIf(bool,bool)string"
	pushbytes 0x8fe76ca8 // method "bracketlessIfElse(bool)string"
	pushbytes 0x1a3c7878 // method "nestedTernary(bool,bool)uint64"
	pushbytes 0x74bcc868 // method "stringIf(string)uint64"
	pushbytes 0x4212f905 // method "stringTernary(string)uint64"
	pushbytes 0x95ddaebf // method "smallUintConditional(uint16)void"
	pushbytes 0x3147b866 // method "smallUintComparisonConditional(uint16,uint16)void"
	pushbytes 0x42897f61 // method "uint256ComparsionConditional(uint256,uint256)void"
	pushbytes 0x534be2b7 // method "nestedIfInElseIf(bool,bool)string"
	txna ApplicationArgs 0
	match *abi_route_singleIf *abi_route_ifElse *abi_route_ifElseIf *abi_route_ifElseIfElse *abi_route_ifElseIfElseIf *abi_route_ifElseIfElseIfElse *abi_route_nestedIf *abi_route_bracketlessIfElse *abi_route_nestedTernary *abi_route_stringIf *abi_route_stringTernary *abi_route_smallUintConditional *abi_route_smallUintComparisonConditional *abi_route_uint256ComparsionConditional *abi_route_nestedIfInElseIf

	// this contract does not implement the given ABI method for call NoOp
	err", + "approval": "#pragma version 10
intcblock 1 0
bytecblock 0x151f7c75 0x656c7365 0x6966 0x656c73652069662031 0x656c73652069662032 0x656c7365206966 0x656e64 0x666f6f 0x

// This TEAL was generated by TEALScript v0.105.0
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// singleIf(bool)string
*abi_route_singleIf:
	// The ABI return prefix
	byte 0x151f7c75

	// arg0: bool
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 0 (arg0) for singleIf must be a bool
	assert
	int 0
	getbit

	// execute singleIf(bool)string
	callsub singleIf
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// singleIf(arg0: boolean): string
singleIf:
	proto 1 1

	// *if0_condition
	// tests/contracts/if.algo.ts:7
	// arg0
	frame_dig -1 // arg0: boolean
	bz *if0_end

	// *if0_consequent
	// tests/contracts/if.algo.ts:8
	// return 'if';
	byte 0x6966 // "if"
	retsub

*if0_end:
	// tests/contracts/if.algo.ts:11
	// return 'end';
	byte 0x656e64 // "end"
	retsub

// ifElse(bool)string
*abi_route_ifElse:
	// The ABI return prefix
	byte 0x151f7c75

	// arg0: bool
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 0 (arg0) for ifElse must be a bool
	assert
	int 0
	getbit

	// execute ifElse(bool)string
	callsub ifElse
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// ifElse(arg0: boolean): string
ifElse:
	proto 1 1

	// *if1_condition
	// tests/contracts/if.algo.ts:15
	// arg0
	frame_dig -1 // arg0: boolean
	bz *if1_else

	// *if1_consequent
	// tests/contracts/if.algo.ts:16
	// return 'if';
	byte 0x6966 // "if"
	retsub
	b *if1_end

*if1_else:
	// tests/contracts/if.algo.ts:18
	// return 'else';
	byte 0x656c7365 // "else"
	retsub

*if1_end:
	retsub

// ifElseIf(bool,bool)string
*abi_route_ifElseIf:
	// The ABI return prefix
	byte 0x151f7c75

	// arg1: bool
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 0 (arg1) for ifElseIf must be a bool
	assert
	int 0
	getbit

	// arg0: bool
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 1 (arg0) for ifElseIf must be a bool
	assert
	int 0
	getbit

	// execute ifElseIf(bool,bool)string
	callsub ifElseIf
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// ifElseIf(arg0: boolean, arg1: boolean): string
ifElseIf:
	proto 2 1

	// *if2_condition
	// tests/contracts/if.algo.ts:23
	// arg0
	frame_dig -1 // arg0: boolean
	bz *if2_elseif1_condition

	// *if2_consequent
	// tests/contracts/if.algo.ts:24
	// return 'if';
	byte 0x6966 // "if"
	retsub
	b *if2_end

*if2_elseif1_condition:
	// tests/contracts/if.algo.ts:25
	// arg1
	frame_dig -2 // arg1: boolean
	bz *if2_end

	// *if2_elseif1_consequent
	// tests/contracts/if.algo.ts:26
	// return 'else if';
	byte 0x656c7365206966 // "else if"
	retsub

*if2_end:
	// tests/contracts/if.algo.ts:29
	// return 'end';
	byte 0x656e64 // "end"
	retsub

// ifElseIfElse(bool,bool)string
*abi_route_ifElseIfElse:
	// The ABI return prefix
	byte 0x151f7c75

	// arg1: bool
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 0 (arg1) for ifElseIfElse must be a bool
	assert
	int 0
	getbit

	// arg0: bool
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 1 (arg0) for ifElseIfElse must be a bool
	assert
	int 0
	getbit

	// execute ifElseIfElse(bool,bool)string
	callsub ifElseIfElse
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// ifElseIfElse(arg0: boolean, arg1: boolean): string
ifElseIfElse:
	proto 2 1

	// *if3_condition
	// tests/contracts/if.algo.ts:33
	// arg0
	frame_dig -1 // arg0: boolean
	bz *if3_elseif1_condition

	// *if3_consequent
	// tests/contracts/if.algo.ts:34
	// return 'if';
	byte 0x6966 // "if"
	retsub
	b *if3_end

*if3_elseif1_condition:
	// tests/contracts/if.algo.ts:35
	// arg1
	frame_dig -2 // arg1: boolean
	bz *if3_else

	// *if3_elseif1_consequent
	// tests/contracts/if.algo.ts:36
	// return 'else if';
	byte 0x656c7365206966 // "else if"
	retsub
	b *if3_end

*if3_else:
	// tests/contracts/if.algo.ts:38
	// return 'else';
	byte 0x656c7365 // "else"
	retsub

*if3_end:
	retsub

// ifElseIfElseIf(bool,bool,bool)string
*abi_route_ifElseIfElseIf:
	// The ABI return prefix
	byte 0x151f7c75

	// arg2: bool
	txna ApplicationArgs 3
	dup
	len
	int 1
	==

	// argument 0 (arg2) for ifElseIfElseIf must be a bool
	assert
	int 0
	getbit

	// arg1: bool
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 1 (arg1) for ifElseIfElseIf must be a bool
	assert
	int 0
	getbit

	// arg0: bool
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 2 (arg0) for ifElseIfElseIf must be a bool
	assert
	int 0
	getbit

	// execute ifElseIfElseIf(bool,bool,bool)string
	callsub ifElseIfElseIf
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// ifElseIfElseIf(arg0: boolean, arg1: boolean, arg2: boolean): string
ifElseIfElseIf:
	proto 3 1

	// *if4_condition
	// tests/contracts/if.algo.ts:43
	// arg0
	frame_dig -1 // arg0: boolean
	bz *if4_elseif1_condition

	// *if4_consequent
	// tests/contracts/if.algo.ts:44
	// return 'if';
	byte 0x6966 // "if"
	retsub
	b *if4_end

*if4_elseif1_condition:
	// tests/contracts/if.algo.ts:45
	// arg1
	frame_dig -2 // arg1: boolean
	bz *if4_elseif2_condition

	// *if4_elseif1_consequent
	// tests/contracts/if.algo.ts:46
	// return 'else if 1';
	byte 0x656c73652069662031 // "else if 1"
	retsub
	b *if4_end

*if4_elseif2_condition:
	// tests/contracts/if.algo.ts:47
	// arg2
	frame_dig -3 // arg2: boolean
	bz *if4_end

	// *if4_elseif2_consequent
	// tests/contracts/if.algo.ts:48
	// return 'else if 2';
	byte 0x656c73652069662032 // "else if 2"
	retsub

*if4_end:
	// tests/contracts/if.algo.ts:51
	// return 'end';
	byte 0x656e64 // "end"
	retsub

// ifElseIfElseIfElse(bool,bool,bool)string
*abi_route_ifElseIfElseIfElse:
	// The ABI return prefix
	byte 0x151f7c75

	// arg2: bool
	txna ApplicationArgs 3
	dup
	len
	int 1
	==

	// argument 0 (arg2) for ifElseIfElseIfElse must be a bool
	assert
	int 0
	getbit

	// arg1: bool
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 1 (arg1) for ifElseIfElseIfElse must be a bool
	assert
	int 0
	getbit

	// arg0: bool
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 2 (arg0) for ifElseIfElseIfElse must be a bool
	assert
	int 0
	getbit

	// execute ifElseIfElseIfElse(bool,bool,bool)string
	callsub ifElseIfElseIfElse
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// ifElseIfElseIfElse(arg0: boolean, arg1: boolean, arg2: boolean): string
ifElseIfElseIfElse:
	proto 3 1

	// *if5_condition
	// tests/contracts/if.algo.ts:55
	// arg0
	frame_dig -1 // arg0: boolean
	bz *if5_elseif1_condition

	// *if5_consequent
	// tests/contracts/if.algo.ts:56
	// return 'if';
	byte 0x6966 // "if"
	retsub
	b *if5_end

*if5_elseif1_condition:
	// tests/contracts/if.algo.ts:57
	// arg1
	frame_dig -2 // arg1: boolean
	bz *if5_elseif2_condition

	// *if5_elseif1_consequent
	// tests/contracts/if.algo.ts:58
	// return 'else if 1';
	byte 0x656c73652069662031 // "else if 1"
	retsub
	b *if5_end

*if5_elseif2_condition:
	// tests/contracts/if.algo.ts:59
	// arg2
	frame_dig -3 // arg2: boolean
	bz *if5_else

	// *if5_elseif2_consequent
	// tests/contracts/if.algo.ts:60
	// return 'else if 2';
	byte 0x656c73652069662032 // "else if 2"
	retsub
	b *if5_end

*if5_else:
	// tests/contracts/if.algo.ts:62
	// return 'else';
	byte 0x656c7365 // "else"
	retsub

*if5_end:
	retsub

// nestedIf(bool,bool)string
*abi_route_nestedIf:
	// The ABI return prefix
	byte 0x151f7c75

	// arg1: bool
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 0 (arg1) for nestedIf must be a bool
	assert
	int 0
	getbit

	// arg0: bool
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 1 (arg0) for nestedIf must be a bool
	assert
	int 0
	getbit

	// execute nestedIf(bool,bool)string
	callsub nestedIf
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// nestedIf(arg0: boolean, arg1: boolean): string
nestedIf:
	proto 2 1

	// *if6_condition
	// tests/contracts/if.algo.ts:67
	// arg0
	frame_dig -1 // arg0: boolean
	bz *if6_else

	// *if6_consequent
	// *if7_condition
	// tests/contracts/if.algo.ts:68
	// arg1
	frame_dig -2 // arg1: boolean
	bz *if7_end

	// *if7_consequent
	// tests/contracts/if.algo.ts:69
	// return 'nested if';
	pushbytes 0x6e6573746564206966 // "nested if"
	retsub

*if7_end:
	// tests/contracts/if.algo.ts:71
	// return 'if';
	byte 0x6966 // "if"
	retsub
	b *if6_end

*if6_else:
	// tests/contracts/if.algo.ts:73
	// return 'else';
	byte 0x656c7365 // "else"
	retsub

*if6_end:
	retsub

// bracketlessIfElse(bool)string
*abi_route_bracketlessIfElse:
	// The ABI return prefix
	byte 0x151f7c75

	// arg0: bool
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 0 (arg0) for bracketlessIfElse must be a bool
	assert
	int 0
	getbit

	// execute bracketlessIfElse(bool)string
	callsub bracketlessIfElse
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// bracketlessIfElse(arg0: boolean): string
bracketlessIfElse:
	proto 1 1

	// *if8_condition
	// tests/contracts/if.algo.ts:78
	// arg0
	frame_dig -1 // arg0: boolean
	bz *if8_else

	// *if8_consequent
	// tests/contracts/if.algo.ts:78
	// return 'if';
	byte 0x6966 // "if"
	retsub
	b *if8_end

*if8_else:
	// tests/contracts/if.algo.ts:79
	// return 'else';
	byte 0x656c7365 // "else"
	retsub

*if8_end:
	retsub

// nestedTernary(bool,bool)uint64
*abi_route_nestedTernary:
	// The ABI return prefix
	byte 0x151f7c75

	// arg1: bool
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 0 (arg1) for nestedTernary must be a bool
	assert
	int 0
	getbit

	// arg0: bool
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 1 (arg0) for nestedTernary must be a bool
	assert
	int 0
	getbit

	// execute nestedTernary(bool,bool)uint64
	callsub nestedTernary
	itob
	concat
	log
	int 1
	return

// nestedTernary(arg0: boolean, arg1: boolean): uint64
nestedTernary:
	proto 2 1

	// tests/contracts/if.algo.ts:84
	// return arg0 ? 1 : arg1 ? 2 : 3;
	frame_dig -1 // arg0: boolean
	bz *ternary0_false
	int 1
	b *ternary0_end

*ternary0_false:
	frame_dig -2 // arg1: boolean
	bz *ternary1_false
	pushint 2
	b *ternary1_end

*ternary1_false:
	pushint 3

*ternary1_end:

*ternary0_end:
	retsub

// stringIf(string)uint64
*abi_route_stringIf:
	// The ABI return prefix
	byte 0x151f7c75

	// arg0: string
	txna ApplicationArgs 1
	extract 2 0

	// execute stringIf(string)uint64
	callsub stringIf
	itob
	concat
	log
	int 1
	return

// stringIf(arg0: string): uint64
stringIf:
	proto 1 1

	// *if9_condition
	// tests/contracts/if.algo.ts:88
	// arg0
	frame_dig -1 // arg0: string
	byte 0x
	b!=
	bz *if9_end

	// *if9_consequent
	// tests/contracts/if.algo.ts:89
	// return 1;
	int 1
	retsub

*if9_end:
	// tests/contracts/if.algo.ts:92
	// return 2;
	pushint 2
	retsub

// stringTernary(string)uint64
*abi_route_stringTernary:
	// The ABI return prefix
	byte 0x151f7c75

	// arg0: string
	txna ApplicationArgs 1
	extract 2 0

	// execute stringTernary(string)uint64
	callsub stringTernary
	itob
	concat
	log
	int 1
	return

// stringTernary(arg0: string): uint64
stringTernary:
	proto 1 1

	// tests/contracts/if.algo.ts:96
	// return arg0 ? 1 : 2;
	frame_dig -1 // arg0: string
	byte 0x
	b!=
	bz *ternary2_false
	int 1
	b *ternary2_end

*ternary2_false:
	pushint 2

*ternary2_end:
	retsub

// smallUintConditional(uint16)void
*abi_route_smallUintConditional:
	// a: uint16
	txna ApplicationArgs 1
	dup
	len
	pushint 2
	==

	// argument 0 (a) for smallUintConditional must be a uint16
	assert
	btoi

	// execute smallUintConditional(uint16)void
	callsub smallUintConditional
	int 1
	return

// smallUintConditional(a: uint16): void
smallUintConditional:
	proto 1 0

	// *if10_condition
	// tests/contracts/if.algo.ts:100
	// a
	frame_dig -1 // a: uint16
	byte 0x
	b!=
	bz *if10_end

	// *if10_consequent
	// tests/contracts/if.algo.ts:101
	// log('foo')
	byte 0x666f6f // "foo"
	log

*if10_end:
	retsub

// smallUintComparisonConditional(uint16,uint16)void
*abi_route_smallUintComparisonConditional:
	// b: uint16
	txna ApplicationArgs 2
	dup
	len
	pushint 2
	==

	// argument 0 (b) for smallUintComparisonConditional must be a uint16
	assert
	btoi

	// a: uint16
	txna ApplicationArgs 1
	dup
	len
	pushint 2
	==

	// argument 1 (a) for smallUintComparisonConditional must be a uint16
	assert
	btoi

	// execute smallUintComparisonConditional(uint16,uint16)void
	callsub smallUintComparisonConditional
	int 1
	return

// smallUintComparisonConditional(a: uint16, b: uint16): void
smallUintComparisonConditional:
	proto 2 0

	// *if11_condition
	// tests/contracts/if.algo.ts:106
	// a <= b
	frame_dig -1 // a: uint16
	frame_dig -2 // b: uint16
	<=
	bz *if11_end

	// *if11_consequent
	// tests/contracts/if.algo.ts:107
	// log('foo')
	byte 0x666f6f // "foo"
	log

*if11_end:
	retsub

// uint256ComparsionConditional(uint256,uint256)void
*abi_route_uint256ComparsionConditional:
	// b: uint256
	txna ApplicationArgs 2
	dup
	len
	pushint 32
	==

	// argument 0 (b) for uint256ComparsionConditional must be a uint256
	assert

	// a: uint256
	txna ApplicationArgs 1
	dup
	len
	pushint 32
	==

	// argument 1 (a) for uint256ComparsionConditional must be a uint256
	assert

	// execute uint256ComparsionConditional(uint256,uint256)void
	callsub uint256ComparsionConditional
	int 1
	return

// uint256ComparsionConditional(a: uint256, b: uint256): void
uint256ComparsionConditional:
	proto 2 0

	// *if12_condition
	// tests/contracts/if.algo.ts:112
	// a <= b
	frame_dig -1 // a: uint256
	frame_dig -2 // b: uint256
	b<=
	bz *if12_end

	// *if12_consequent
	// tests/contracts/if.algo.ts:113
	// log('foo')
	byte 0x666f6f // "foo"
	log

*if12_end:
	retsub

// nestedIfInElseIf(bool,bool)string
*abi_route_nestedIfInElseIf:
	// The ABI return prefix
	byte 0x151f7c75

	// b: bool
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 0 (b) for nestedIfInElseIf must be a bool
	assert
	int 0
	getbit

	// a: bool
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 1 (a) for nestedIfInElseIf must be a bool
	assert
	int 0
	getbit

	// execute nestedIfInElseIf(bool,bool)string
	callsub nestedIfInElseIf
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// nestedIfInElseIf(a: boolean, b: boolean): string
nestedIfInElseIf:
	proto 2 1

	// *if13_condition
	// tests/contracts/if.algo.ts:118
	// a
	frame_dig -1 // a: boolean
	bz *if13_elseif1_condition

	// *if13_consequent
	// *if14_condition
	// tests/contracts/if.algo.ts:119
	// b
	frame_dig -2 // b: boolean
	bz *if14_else

	// *if14_consequent
	// tests/contracts/if.algo.ts:120
	// return 'a and b';
	pushbytes 0x6120616e642062 // "a and b"
	retsub
	b *if14_end

*if14_else:
	// tests/contracts/if.algo.ts:122
	// return 'a';
	pushbytes 0x61 // "a"
	retsub

*if14_end:
	b *if13_end

*if13_elseif1_condition:
	// tests/contracts/if.algo.ts:124
	// b
	frame_dig -2 // b: boolean
	bz *if13_else

	// *if13_elseif1_consequent
	// tests/contracts/if.algo.ts:125
	// return 'b';
	pushbytes 0x62 // "b"
	retsub
	b *if13_end

*if13_else:
	// tests/contracts/if.algo.ts:127
	// return 'neither';
	pushbytes 0x6e656974686572 // "neither"
	retsub

*if13_end:
	retsub

*abi_route_createApplication:
	int 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x436ec1c2 // method "singleIf(bool)string"
	pushbytes 0x1c7a0d5e // method "ifElse(bool)string"
	pushbytes 0x5e0fb6cf // method "ifElseIf(bool,bool)string"
	pushbytes 0x5e1c6c50 // method "ifElseIfElse(bool,bool)string"
	pushbytes 0x58d0ba92 // method "ifElseIfElseIf(bool,bool,bool)string"
	pushbytes 0x5d2f4f02 // method "ifElseIfElseIfElse(bool,bool,bool)string"
	pushbytes 0x845729d9 // method "nestedIf(bool,bool)string"
	pushbytes 0x8fe76ca8 // method "bracketlessIfElse(bool)string"
	pushbytes 0x1a3c7878 // method "nestedTernary(bool,bool)uint64"
	pushbytes 0x74bcc868 // method "stringIf(string)uint64"
	pushbytes 0x4212f905 // method "stringTernary(string)uint64"
	pushbytes 0x95ddaebf // method "smallUintConditional(uint16)void"
	pushbytes 0x3147b866 // method "smallUintComparisonConditional(uint16,uint16)void"
	pushbytes 0x42897f61 // method "uint256ComparsionConditional(uint256,uint256)void"
	pushbytes 0x534be2b7 // method "nestedIfInElseIf(bool,bool)string"
	txna ApplicationArgs 0
	match *abi_route_singleIf *abi_route_ifElse *abi_route_ifElseIf *abi_route_ifElseIfElse *abi_route_ifElseIfElseIf *abi_route_ifElseIfElseIfElse *abi_route_nestedIf *abi_route_bracketlessIfElse *abi_route_nestedTernary *abi_route_stringIf *abi_route_stringTernary *abi_route_smallUintConditional *abi_route_smallUintComparisonConditional *abi_route_uint256ComparsionConditional *abi_route_nestedIfInElseIf

	// this contract does not implement the given ABI method for call NoOp
	err", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/IntcblockTest.approval.teal b/tests/contracts/artifacts/IntcblockTest.approval.teal index e42d5d96d..95a9e3932 100644 --- a/tests/contracts/artifacts/IntcblockTest.approval.teal +++ b/tests/contracts/artifacts/IntcblockTest.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/IntcblockTest.arc32.json b/tests/contracts/artifacts/IntcblockTest.arc32.json index 4fa63936f..d109e2b35 100644 --- a/tests/contracts/artifacts/IntcblockTest.arc32.json +++ b/tests/contracts/artifacts/IntcblockTest.arc32.json @@ -44,7 +44,7 @@ } }, "source": { - "approval": "#pragma version 10

// This TEAL was generated by TEALScript v0.104.1
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// largeIntcblock()uint64
*abi_route_largeIntcblock:
	// The ABI return prefix
	pushbytes 0x151f7c75

	// execute largeIntcblock()uint64
	callsub largeIntcblock
	itob
	concat
	log
	pushint 1
	return

// largeIntcblock(): uint64
largeIntcblock:
	proto 0 1

	// tests/contracts/cblocks.algo.ts:9
	// assert(2)
	pushint 2
	assert

	// tests/contracts/cblocks.algo.ts:10
	// assert(3)
	pushint 3
	assert

	// tests/contracts/cblocks.algo.ts:11
	// assert(4)
	pushint 4
	assert

	// tests/contracts/cblocks.algo.ts:12
	// assert(5)
	pushint 5
	assert

	// tests/contracts/cblocks.algo.ts:13
	// assert(6)
	pushint 6
	assert

	// tests/contracts/cblocks.algo.ts:14
	// assert(7)
	pushint 7
	assert

	// tests/contracts/cblocks.algo.ts:15
	// assert(8)
	pushint 8
	assert

	// tests/contracts/cblocks.algo.ts:16
	// assert(9)
	pushint 9
	assert

	// tests/contracts/cblocks.algo.ts:17
	// assert(10)
	pushint 10
	assert

	// tests/contracts/cblocks.algo.ts:18
	// assert(11)
	pushint 11
	assert

	// tests/contracts/cblocks.algo.ts:19
	// assert(12)
	pushint 12
	assert

	// tests/contracts/cblocks.algo.ts:20
	// assert(13)
	pushint 13
	assert

	// tests/contracts/cblocks.algo.ts:21
	// assert(14)
	pushint 14
	assert

	// tests/contracts/cblocks.algo.ts:22
	// assert(15)
	pushint 15
	assert

	// tests/contracts/cblocks.algo.ts:23
	// assert(16)
	pushint 16
	assert

	// tests/contracts/cblocks.algo.ts:24
	// assert(17)
	pushint 17
	assert

	// tests/contracts/cblocks.algo.ts:25
	// assert(18)
	pushint 18
	assert

	// tests/contracts/cblocks.algo.ts:26
	// assert(19)
	pushint 19
	assert

	// tests/contracts/cblocks.algo.ts:27
	// assert(20)
	pushint 20
	assert

	// tests/contracts/cblocks.algo.ts:28
	// assert(21)
	pushint 21
	assert

	// tests/contracts/cblocks.algo.ts:29
	// assert(22)
	pushint 22
	assert

	// tests/contracts/cblocks.algo.ts:30
	// assert(23)
	pushint 23
	assert

	// tests/contracts/cblocks.algo.ts:31
	// assert(24)
	pushint 24
	assert

	// tests/contracts/cblocks.algo.ts:32
	// assert(25)
	pushint 25
	assert

	// tests/contracts/cblocks.algo.ts:33
	// assert(26)
	pushint 26
	assert

	// tests/contracts/cblocks.algo.ts:34
	// assert(27)
	pushint 27
	assert

	// tests/contracts/cblocks.algo.ts:35
	// assert(28)
	pushint 28
	assert

	// tests/contracts/cblocks.algo.ts:36
	// assert(29)
	pushint 29
	assert

	// tests/contracts/cblocks.algo.ts:37
	// assert(30)
	pushint 30
	assert

	// tests/contracts/cblocks.algo.ts:38
	// assert(31)
	pushint 31
	assert

	// tests/contracts/cblocks.algo.ts:39
	// assert(32)
	pushint 32
	assert

	// tests/contracts/cblocks.algo.ts:40
	// assert(33)
	pushint 33
	assert

	// tests/contracts/cblocks.algo.ts:41
	// assert(34)
	pushint 34
	assert

	// tests/contracts/cblocks.algo.ts:42
	// assert(35)
	pushint 35
	assert

	// tests/contracts/cblocks.algo.ts:43
	// assert(36)
	pushint 36
	assert

	// tests/contracts/cblocks.algo.ts:44
	// assert(37)
	pushint 37
	assert

	// tests/contracts/cblocks.algo.ts:45
	// assert(38)
	pushint 38
	assert

	// tests/contracts/cblocks.algo.ts:46
	// assert(39)
	pushint 39
	assert

	// tests/contracts/cblocks.algo.ts:47
	// assert(40)
	pushint 40
	assert

	// tests/contracts/cblocks.algo.ts:48
	// assert(41)
	pushint 41
	assert

	// tests/contracts/cblocks.algo.ts:49
	// assert(42)
	pushint 42
	assert

	// tests/contracts/cblocks.algo.ts:50
	// assert(43)
	pushint 43
	assert

	// tests/contracts/cblocks.algo.ts:51
	// assert(44)
	pushint 44
	assert

	// tests/contracts/cblocks.algo.ts:52
	// assert(45)
	pushint 45
	assert

	// tests/contracts/cblocks.algo.ts:53
	// assert(46)
	pushint 46
	assert

	// tests/contracts/cblocks.algo.ts:54
	// assert(47)
	pushint 47
	assert

	// tests/contracts/cblocks.algo.ts:55
	// assert(48)
	pushint 48
	assert

	// tests/contracts/cblocks.algo.ts:56
	// assert(49)
	pushint 49
	assert

	// tests/contracts/cblocks.algo.ts:57
	// assert(50)
	pushint 50
	assert

	// tests/contracts/cblocks.algo.ts:58
	// assert(51)
	pushint 51
	assert

	// tests/contracts/cblocks.algo.ts:59
	// assert(52)
	pushint 52
	assert

	// tests/contracts/cblocks.algo.ts:60
	// assert(53)
	pushint 53
	assert

	// tests/contracts/cblocks.algo.ts:61
	// assert(54)
	pushint 54
	assert

	// tests/contracts/cblocks.algo.ts:62
	// assert(55)
	pushint 55
	assert

	// tests/contracts/cblocks.algo.ts:63
	// assert(56)
	pushint 56
	assert

	// tests/contracts/cblocks.algo.ts:64
	// assert(57)
	pushint 57
	assert

	// tests/contracts/cblocks.algo.ts:65
	// assert(58)
	pushint 58
	assert

	// tests/contracts/cblocks.algo.ts:66
	// assert(59)
	pushint 59
	assert

	// tests/contracts/cblocks.algo.ts:67
	// assert(60)
	pushint 60
	assert

	// tests/contracts/cblocks.algo.ts:68
	// assert(61)
	pushint 61
	assert

	// tests/contracts/cblocks.algo.ts:69
	// assert(62)
	pushint 62
	assert

	// tests/contracts/cblocks.algo.ts:70
	// assert(63)
	pushint 63
	assert

	// tests/contracts/cblocks.algo.ts:71
	// assert(64)
	pushint 64
	assert

	// tests/contracts/cblocks.algo.ts:72
	// assert(65)
	pushint 65
	assert

	// tests/contracts/cblocks.algo.ts:73
	// assert(66)
	pushint 66
	assert

	// tests/contracts/cblocks.algo.ts:74
	// assert(67)
	pushint 67
	assert

	// tests/contracts/cblocks.algo.ts:75
	// assert(68)
	pushint 68
	assert

	// tests/contracts/cblocks.algo.ts:76
	// assert(69)
	pushint 69
	assert

	// tests/contracts/cblocks.algo.ts:77
	// assert(70)
	pushint 70
	assert

	// tests/contracts/cblocks.algo.ts:78
	// assert(71)
	pushint 71
	assert

	// tests/contracts/cblocks.algo.ts:79
	// assert(72)
	pushint 72
	assert

	// tests/contracts/cblocks.algo.ts:80
	// assert(73)
	pushint 73
	assert

	// tests/contracts/cblocks.algo.ts:81
	// assert(74)
	pushint 74
	assert

	// tests/contracts/cblocks.algo.ts:82
	// assert(75)
	pushint 75
	assert

	// tests/contracts/cblocks.algo.ts:83
	// assert(76)
	pushint 76
	assert

	// tests/contracts/cblocks.algo.ts:84
	// assert(77)
	pushint 77
	assert

	// tests/contracts/cblocks.algo.ts:85
	// assert(78)
	pushint 78
	assert

	// tests/contracts/cblocks.algo.ts:86
	// assert(79)
	pushint 79
	assert

	// tests/contracts/cblocks.algo.ts:87
	// assert(80)
	pushint 80
	assert

	// tests/contracts/cblocks.algo.ts:88
	// assert(81)
	pushint 81
	assert

	// tests/contracts/cblocks.algo.ts:89
	// assert(82)
	pushint 82
	assert

	// tests/contracts/cblocks.algo.ts:90
	// assert(83)
	pushint 83
	assert

	// tests/contracts/cblocks.algo.ts:91
	// assert(84)
	pushint 84
	assert

	// tests/contracts/cblocks.algo.ts:92
	// assert(85)
	pushint 85
	assert

	// tests/contracts/cblocks.algo.ts:93
	// assert(86)
	pushint 86
	assert

	// tests/contracts/cblocks.algo.ts:94
	// assert(87)
	pushint 87
	assert

	// tests/contracts/cblocks.algo.ts:95
	// assert(88)
	pushint 88
	assert

	// tests/contracts/cblocks.algo.ts:96
	// assert(89)
	pushint 89
	assert

	// tests/contracts/cblocks.algo.ts:97
	// assert(90)
	pushint 90
	assert

	// tests/contracts/cblocks.algo.ts:98
	// assert(91)
	pushint 91
	assert

	// tests/contracts/cblocks.algo.ts:99
	// assert(92)
	pushint 92
	assert

	// tests/contracts/cblocks.algo.ts:100
	// assert(93)
	pushint 93
	assert

	// tests/contracts/cblocks.algo.ts:101
	// assert(94)
	pushint 94
	assert

	// tests/contracts/cblocks.algo.ts:102
	// assert(95)
	pushint 95
	assert

	// tests/contracts/cblocks.algo.ts:103
	// assert(96)
	pushint 96
	assert

	// tests/contracts/cblocks.algo.ts:104
	// assert(97)
	pushint 97
	assert

	// tests/contracts/cblocks.algo.ts:105
	// assert(98)
	pushint 98
	assert

	// tests/contracts/cblocks.algo.ts:106
	// assert(99)
	pushint 99
	assert

	// tests/contracts/cblocks.algo.ts:107
	// assert(100)
	pushint 100
	assert

	// tests/contracts/cblocks.algo.ts:108
	// assert(101)
	pushint 101
	assert

	// tests/contracts/cblocks.algo.ts:109
	// assert(102)
	pushint 102
	assert

	// tests/contracts/cblocks.algo.ts:110
	// assert(103)
	pushint 103
	assert

	// tests/contracts/cblocks.algo.ts:111
	// assert(104)
	pushint 104
	assert

	// tests/contracts/cblocks.algo.ts:112
	// assert(105)
	pushint 105
	assert

	// tests/contracts/cblocks.algo.ts:113
	// assert(106)
	pushint 106
	assert

	// tests/contracts/cblocks.algo.ts:114
	// assert(107)
	pushint 107
	assert

	// tests/contracts/cblocks.algo.ts:115
	// assert(108)
	pushint 108
	assert

	// tests/contracts/cblocks.algo.ts:116
	// assert(109)
	pushint 109
	assert

	// tests/contracts/cblocks.algo.ts:117
	// assert(110)
	pushint 110
	assert

	// tests/contracts/cblocks.algo.ts:118
	// assert(111)
	pushint 111
	assert

	// tests/contracts/cblocks.algo.ts:119
	// assert(112)
	pushint 112
	assert

	// tests/contracts/cblocks.algo.ts:120
	// assert(113)
	pushint 113
	assert

	// tests/contracts/cblocks.algo.ts:121
	// assert(114)
	pushint 114
	assert

	// tests/contracts/cblocks.algo.ts:122
	// assert(115)
	pushint 115
	assert

	// tests/contracts/cblocks.algo.ts:123
	// assert(116)
	pushint 116
	assert

	// tests/contracts/cblocks.algo.ts:124
	// assert(117)
	pushint 117
	assert

	// tests/contracts/cblocks.algo.ts:125
	// assert(118)
	pushint 118
	assert

	// tests/contracts/cblocks.algo.ts:126
	// assert(119)
	pushint 119
	assert

	// tests/contracts/cblocks.algo.ts:127
	// assert(120)
	pushint 120
	assert

	// tests/contracts/cblocks.algo.ts:128
	// assert(121)
	pushint 121
	assert

	// tests/contracts/cblocks.algo.ts:129
	// assert(122)
	pushint 122
	assert

	// tests/contracts/cblocks.algo.ts:130
	// assert(123)
	pushint 123
	assert

	// tests/contracts/cblocks.algo.ts:131
	// assert(124)
	pushint 124
	assert

	// tests/contracts/cblocks.algo.ts:132
	// assert(125)
	pushint 125
	assert

	// tests/contracts/cblocks.algo.ts:133
	// assert(126)
	pushint 126
	assert

	// tests/contracts/cblocks.algo.ts:134
	// assert(127)
	pushint 127
	assert

	// tests/contracts/cblocks.algo.ts:135
	// assert(128)
	pushint 128
	assert

	// tests/contracts/cblocks.algo.ts:136
	// assert(129)
	pushint 129
	assert

	// tests/contracts/cblocks.algo.ts:137
	// assert(130)
	pushint 130
	assert

	// tests/contracts/cblocks.algo.ts:138
	// assert(131)
	pushint 131
	assert

	// tests/contracts/cblocks.algo.ts:139
	// assert(132)
	pushint 132
	assert

	// tests/contracts/cblocks.algo.ts:140
	// assert(133)
	pushint 133
	assert

	// tests/contracts/cblocks.algo.ts:141
	// assert(134)
	pushint 134
	assert

	// tests/contracts/cblocks.algo.ts:142
	// assert(135)
	pushint 135
	assert

	// tests/contracts/cblocks.algo.ts:143
	// assert(136)
	pushint 136
	assert

	// tests/contracts/cblocks.algo.ts:144
	// assert(137)
	pushint 137
	assert

	// tests/contracts/cblocks.algo.ts:145
	// assert(138)
	pushint 138
	assert

	// tests/contracts/cblocks.algo.ts:146
	// assert(139)
	pushint 139
	assert

	// tests/contracts/cblocks.algo.ts:147
	// assert(140)
	pushint 140
	assert

	// tests/contracts/cblocks.algo.ts:148
	// assert(141)
	pushint 141
	assert

	// tests/contracts/cblocks.algo.ts:149
	// assert(142)
	pushint 142
	assert

	// tests/contracts/cblocks.algo.ts:150
	// assert(143)
	pushint 143
	assert

	// tests/contracts/cblocks.algo.ts:151
	// assert(144)
	pushint 144
	assert

	// tests/contracts/cblocks.algo.ts:152
	// assert(145)
	pushint 145
	assert

	// tests/contracts/cblocks.algo.ts:153
	// assert(146)
	pushint 146
	assert

	// tests/contracts/cblocks.algo.ts:154
	// assert(147)
	pushint 147
	assert

	// tests/contracts/cblocks.algo.ts:155
	// assert(148)
	pushint 148
	assert

	// tests/contracts/cblocks.algo.ts:156
	// assert(149)
	pushint 149
	assert

	// tests/contracts/cblocks.algo.ts:157
	// assert(150)
	pushint 150
	assert

	// tests/contracts/cblocks.algo.ts:158
	// assert(151)
	pushint 151
	assert

	// tests/contracts/cblocks.algo.ts:159
	// assert(152)
	pushint 152
	assert

	// tests/contracts/cblocks.algo.ts:160
	// assert(153)
	pushint 153
	assert

	// tests/contracts/cblocks.algo.ts:161
	// assert(154)
	pushint 154
	assert

	// tests/contracts/cblocks.algo.ts:162
	// assert(155)
	pushint 155
	assert

	// tests/contracts/cblocks.algo.ts:163
	// assert(156)
	pushint 156
	assert

	// tests/contracts/cblocks.algo.ts:164
	// assert(157)
	pushint 157
	assert

	// tests/contracts/cblocks.algo.ts:165
	// assert(158)
	pushint 158
	assert

	// tests/contracts/cblocks.algo.ts:166
	// assert(159)
	pushint 159
	assert

	// tests/contracts/cblocks.algo.ts:167
	// assert(160)
	pushint 160
	assert

	// tests/contracts/cblocks.algo.ts:168
	// assert(161)
	pushint 161
	assert

	// tests/contracts/cblocks.algo.ts:169
	// assert(162)
	pushint 162
	assert

	// tests/contracts/cblocks.algo.ts:170
	// assert(163)
	pushint 163
	assert

	// tests/contracts/cblocks.algo.ts:171
	// assert(164)
	pushint 164
	assert

	// tests/contracts/cblocks.algo.ts:172
	// assert(165)
	pushint 165
	assert

	// tests/contracts/cblocks.algo.ts:173
	// assert(166)
	pushint 166
	assert

	// tests/contracts/cblocks.algo.ts:174
	// assert(167)
	pushint 167
	assert

	// tests/contracts/cblocks.algo.ts:175
	// assert(168)
	pushint 168
	assert

	// tests/contracts/cblocks.algo.ts:176
	// assert(169)
	pushint 169
	assert

	// tests/contracts/cblocks.algo.ts:177
	// assert(170)
	pushint 170
	assert

	// tests/contracts/cblocks.algo.ts:178
	// assert(171)
	pushint 171
	assert

	// tests/contracts/cblocks.algo.ts:179
	// assert(172)
	pushint 172
	assert

	// tests/contracts/cblocks.algo.ts:180
	// assert(173)
	pushint 173
	assert

	// tests/contracts/cblocks.algo.ts:181
	// assert(174)
	pushint 174
	assert

	// tests/contracts/cblocks.algo.ts:182
	// assert(175)
	pushint 175
	assert

	// tests/contracts/cblocks.algo.ts:183
	// assert(176)
	pushint 176
	assert

	// tests/contracts/cblocks.algo.ts:184
	// assert(177)
	pushint 177
	assert

	// tests/contracts/cblocks.algo.ts:185
	// assert(178)
	pushint 178
	assert

	// tests/contracts/cblocks.algo.ts:186
	// assert(179)
	pushint 179
	assert

	// tests/contracts/cblocks.algo.ts:187
	// assert(180)
	pushint 180
	assert

	// tests/contracts/cblocks.algo.ts:188
	// assert(181)
	pushint 181
	assert

	// tests/contracts/cblocks.algo.ts:189
	// assert(182)
	pushint 182
	assert

	// tests/contracts/cblocks.algo.ts:190
	// assert(183)
	pushint 183
	assert

	// tests/contracts/cblocks.algo.ts:191
	// assert(184)
	pushint 184
	assert

	// tests/contracts/cblocks.algo.ts:192
	// assert(185)
	pushint 185
	assert

	// tests/contracts/cblocks.algo.ts:193
	// assert(186)
	pushint 186
	assert

	// tests/contracts/cblocks.algo.ts:194
	// assert(187)
	pushint 187
	assert

	// tests/contracts/cblocks.algo.ts:195
	// assert(188)
	pushint 188
	assert

	// tests/contracts/cblocks.algo.ts:196
	// assert(189)
	pushint 189
	assert

	// tests/contracts/cblocks.algo.ts:197
	// assert(190)
	pushint 190
	assert

	// tests/contracts/cblocks.algo.ts:198
	// assert(191)
	pushint 191
	assert

	// tests/contracts/cblocks.algo.ts:199
	// assert(192)
	pushint 192
	assert

	// tests/contracts/cblocks.algo.ts:200
	// assert(193)
	pushint 193
	assert

	// tests/contracts/cblocks.algo.ts:201
	// assert(194)
	pushint 194
	assert

	// tests/contracts/cblocks.algo.ts:202
	// assert(195)
	pushint 195
	assert

	// tests/contracts/cblocks.algo.ts:203
	// assert(196)
	pushint 196
	assert

	// tests/contracts/cblocks.algo.ts:204
	// assert(197)
	pushint 197
	assert

	// tests/contracts/cblocks.algo.ts:205
	// assert(198)
	pushint 198
	assert

	// tests/contracts/cblocks.algo.ts:206
	// assert(199)
	pushint 199
	assert

	// tests/contracts/cblocks.algo.ts:207
	// assert(200)
	pushint 200
	assert

	// tests/contracts/cblocks.algo.ts:208
	// assert(201)
	pushint 201
	assert

	// tests/contracts/cblocks.algo.ts:209
	// assert(202)
	pushint 202
	assert

	// tests/contracts/cblocks.algo.ts:210
	// assert(203)
	pushint 203
	assert

	// tests/contracts/cblocks.algo.ts:211
	// assert(204)
	pushint 204
	assert

	// tests/contracts/cblocks.algo.ts:212
	// assert(205)
	pushint 205
	assert

	// tests/contracts/cblocks.algo.ts:213
	// assert(206)
	pushint 206
	assert

	// tests/contracts/cblocks.algo.ts:214
	// assert(207)
	pushint 207
	assert

	// tests/contracts/cblocks.algo.ts:215
	// assert(208)
	pushint 208
	assert

	// tests/contracts/cblocks.algo.ts:216
	// assert(209)
	pushint 209
	assert

	// tests/contracts/cblocks.algo.ts:217
	// assert(210)
	pushint 210
	assert

	// tests/contracts/cblocks.algo.ts:218
	// assert(211)
	pushint 211
	assert

	// tests/contracts/cblocks.algo.ts:219
	// assert(212)
	pushint 212
	assert

	// tests/contracts/cblocks.algo.ts:220
	// assert(213)
	pushint 213
	assert

	// tests/contracts/cblocks.algo.ts:221
	// assert(214)
	pushint 214
	assert

	// tests/contracts/cblocks.algo.ts:222
	// assert(215)
	pushint 215
	assert

	// tests/contracts/cblocks.algo.ts:223
	// assert(216)
	pushint 216
	assert

	// tests/contracts/cblocks.algo.ts:224
	// assert(217)
	pushint 217
	assert

	// tests/contracts/cblocks.algo.ts:225
	// assert(218)
	pushint 218
	assert

	// tests/contracts/cblocks.algo.ts:226
	// assert(219)
	pushint 219
	assert

	// tests/contracts/cblocks.algo.ts:227
	// assert(220)
	pushint 220
	assert

	// tests/contracts/cblocks.algo.ts:228
	// assert(221)
	pushint 221
	assert

	// tests/contracts/cblocks.algo.ts:229
	// assert(222)
	pushint 222
	assert

	// tests/contracts/cblocks.algo.ts:230
	// assert(223)
	pushint 223
	assert

	// tests/contracts/cblocks.algo.ts:231
	// assert(224)
	pushint 224
	assert

	// tests/contracts/cblocks.algo.ts:232
	// assert(225)
	pushint 225
	assert

	// tests/contracts/cblocks.algo.ts:233
	// assert(226)
	pushint 226
	assert

	// tests/contracts/cblocks.algo.ts:234
	// assert(227)
	pushint 227
	assert

	// tests/contracts/cblocks.algo.ts:235
	// assert(228)
	pushint 228
	assert

	// tests/contracts/cblocks.algo.ts:236
	// assert(229)
	pushint 229
	assert

	// tests/contracts/cblocks.algo.ts:237
	// assert(230)
	pushint 230
	assert

	// tests/contracts/cblocks.algo.ts:238
	// assert(231)
	pushint 231
	assert

	// tests/contracts/cblocks.algo.ts:239
	// assert(232)
	pushint 232
	assert

	// tests/contracts/cblocks.algo.ts:240
	// assert(233)
	pushint 233
	assert

	// tests/contracts/cblocks.algo.ts:241
	// assert(234)
	pushint 234
	assert

	// tests/contracts/cblocks.algo.ts:242
	// assert(235)
	pushint 235
	assert

	// tests/contracts/cblocks.algo.ts:243
	// assert(236)
	pushint 236
	assert

	// tests/contracts/cblocks.algo.ts:244
	// assert(237)
	pushint 237
	assert

	// tests/contracts/cblocks.algo.ts:245
	// assert(238)
	pushint 238
	assert

	// tests/contracts/cblocks.algo.ts:246
	// assert(239)
	pushint 239
	assert

	// tests/contracts/cblocks.algo.ts:247
	// assert(240)
	pushint 240
	assert

	// tests/contracts/cblocks.algo.ts:248
	// assert(241)
	pushint 241
	assert

	// tests/contracts/cblocks.algo.ts:249
	// assert(242)
	pushint 242
	assert

	// tests/contracts/cblocks.algo.ts:250
	// assert(243)
	pushint 243
	assert

	// tests/contracts/cblocks.algo.ts:251
	// assert(244)
	pushint 244
	assert

	// tests/contracts/cblocks.algo.ts:252
	// assert(245)
	pushint 245
	assert

	// tests/contracts/cblocks.algo.ts:253
	// assert(246)
	pushint 246
	assert

	// tests/contracts/cblocks.algo.ts:254
	// assert(247)
	pushint 247
	assert

	// tests/contracts/cblocks.algo.ts:255
	// assert(248)
	pushint 248
	assert

	// tests/contracts/cblocks.algo.ts:256
	// assert(249)
	pushint 249
	assert

	// tests/contracts/cblocks.algo.ts:257
	// assert(250)
	pushint 250
	assert

	// tests/contracts/cblocks.algo.ts:258
	// assert(251)
	pushint 251
	assert

	// tests/contracts/cblocks.algo.ts:259
	// assert(252)
	pushint 252
	assert

	// tests/contracts/cblocks.algo.ts:260
	// assert(253)
	pushint 253
	assert

	// tests/contracts/cblocks.algo.ts:261
	// assert(254)
	pushint 254
	assert

	// tests/contracts/cblocks.algo.ts:262
	// assert(255)
	pushint 255
	assert

	// tests/contracts/cblocks.algo.ts:263
	// assert(256)
	pushint 256
	assert

	// tests/contracts/cblocks.algo.ts:266
	// return a + b;
	pushint 258
	retsub

*abi_route_createApplication:
	pushint 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0xd14e61db // method "largeIntcblock()uint64"
	txna ApplicationArgs 0
	match *abi_route_largeIntcblock

	// this contract does not implement the given ABI method for call NoOp
	err", + "approval": "#pragma version 10

// This TEAL was generated by TEALScript v0.105.0
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// largeIntcblock()uint64
*abi_route_largeIntcblock:
	// The ABI return prefix
	pushbytes 0x151f7c75

	// execute largeIntcblock()uint64
	callsub largeIntcblock
	itob
	concat
	log
	pushint 1
	return

// largeIntcblock(): uint64
largeIntcblock:
	proto 0 1

	// tests/contracts/cblocks.algo.ts:9
	// assert(2)
	pushint 2
	assert

	// tests/contracts/cblocks.algo.ts:10
	// assert(3)
	pushint 3
	assert

	// tests/contracts/cblocks.algo.ts:11
	// assert(4)
	pushint 4
	assert

	// tests/contracts/cblocks.algo.ts:12
	// assert(5)
	pushint 5
	assert

	// tests/contracts/cblocks.algo.ts:13
	// assert(6)
	pushint 6
	assert

	// tests/contracts/cblocks.algo.ts:14
	// assert(7)
	pushint 7
	assert

	// tests/contracts/cblocks.algo.ts:15
	// assert(8)
	pushint 8
	assert

	// tests/contracts/cblocks.algo.ts:16
	// assert(9)
	pushint 9
	assert

	// tests/contracts/cblocks.algo.ts:17
	// assert(10)
	pushint 10
	assert

	// tests/contracts/cblocks.algo.ts:18
	// assert(11)
	pushint 11
	assert

	// tests/contracts/cblocks.algo.ts:19
	// assert(12)
	pushint 12
	assert

	// tests/contracts/cblocks.algo.ts:20
	// assert(13)
	pushint 13
	assert

	// tests/contracts/cblocks.algo.ts:21
	// assert(14)
	pushint 14
	assert

	// tests/contracts/cblocks.algo.ts:22
	// assert(15)
	pushint 15
	assert

	// tests/contracts/cblocks.algo.ts:23
	// assert(16)
	pushint 16
	assert

	// tests/contracts/cblocks.algo.ts:24
	// assert(17)
	pushint 17
	assert

	// tests/contracts/cblocks.algo.ts:25
	// assert(18)
	pushint 18
	assert

	// tests/contracts/cblocks.algo.ts:26
	// assert(19)
	pushint 19
	assert

	// tests/contracts/cblocks.algo.ts:27
	// assert(20)
	pushint 20
	assert

	// tests/contracts/cblocks.algo.ts:28
	// assert(21)
	pushint 21
	assert

	// tests/contracts/cblocks.algo.ts:29
	// assert(22)
	pushint 22
	assert

	// tests/contracts/cblocks.algo.ts:30
	// assert(23)
	pushint 23
	assert

	// tests/contracts/cblocks.algo.ts:31
	// assert(24)
	pushint 24
	assert

	// tests/contracts/cblocks.algo.ts:32
	// assert(25)
	pushint 25
	assert

	// tests/contracts/cblocks.algo.ts:33
	// assert(26)
	pushint 26
	assert

	// tests/contracts/cblocks.algo.ts:34
	// assert(27)
	pushint 27
	assert

	// tests/contracts/cblocks.algo.ts:35
	// assert(28)
	pushint 28
	assert

	// tests/contracts/cblocks.algo.ts:36
	// assert(29)
	pushint 29
	assert

	// tests/contracts/cblocks.algo.ts:37
	// assert(30)
	pushint 30
	assert

	// tests/contracts/cblocks.algo.ts:38
	// assert(31)
	pushint 31
	assert

	// tests/contracts/cblocks.algo.ts:39
	// assert(32)
	pushint 32
	assert

	// tests/contracts/cblocks.algo.ts:40
	// assert(33)
	pushint 33
	assert

	// tests/contracts/cblocks.algo.ts:41
	// assert(34)
	pushint 34
	assert

	// tests/contracts/cblocks.algo.ts:42
	// assert(35)
	pushint 35
	assert

	// tests/contracts/cblocks.algo.ts:43
	// assert(36)
	pushint 36
	assert

	// tests/contracts/cblocks.algo.ts:44
	// assert(37)
	pushint 37
	assert

	// tests/contracts/cblocks.algo.ts:45
	// assert(38)
	pushint 38
	assert

	// tests/contracts/cblocks.algo.ts:46
	// assert(39)
	pushint 39
	assert

	// tests/contracts/cblocks.algo.ts:47
	// assert(40)
	pushint 40
	assert

	// tests/contracts/cblocks.algo.ts:48
	// assert(41)
	pushint 41
	assert

	// tests/contracts/cblocks.algo.ts:49
	// assert(42)
	pushint 42
	assert

	// tests/contracts/cblocks.algo.ts:50
	// assert(43)
	pushint 43
	assert

	// tests/contracts/cblocks.algo.ts:51
	// assert(44)
	pushint 44
	assert

	// tests/contracts/cblocks.algo.ts:52
	// assert(45)
	pushint 45
	assert

	// tests/contracts/cblocks.algo.ts:53
	// assert(46)
	pushint 46
	assert

	// tests/contracts/cblocks.algo.ts:54
	// assert(47)
	pushint 47
	assert

	// tests/contracts/cblocks.algo.ts:55
	// assert(48)
	pushint 48
	assert

	// tests/contracts/cblocks.algo.ts:56
	// assert(49)
	pushint 49
	assert

	// tests/contracts/cblocks.algo.ts:57
	// assert(50)
	pushint 50
	assert

	// tests/contracts/cblocks.algo.ts:58
	// assert(51)
	pushint 51
	assert

	// tests/contracts/cblocks.algo.ts:59
	// assert(52)
	pushint 52
	assert

	// tests/contracts/cblocks.algo.ts:60
	// assert(53)
	pushint 53
	assert

	// tests/contracts/cblocks.algo.ts:61
	// assert(54)
	pushint 54
	assert

	// tests/contracts/cblocks.algo.ts:62
	// assert(55)
	pushint 55
	assert

	// tests/contracts/cblocks.algo.ts:63
	// assert(56)
	pushint 56
	assert

	// tests/contracts/cblocks.algo.ts:64
	// assert(57)
	pushint 57
	assert

	// tests/contracts/cblocks.algo.ts:65
	// assert(58)
	pushint 58
	assert

	// tests/contracts/cblocks.algo.ts:66
	// assert(59)
	pushint 59
	assert

	// tests/contracts/cblocks.algo.ts:67
	// assert(60)
	pushint 60
	assert

	// tests/contracts/cblocks.algo.ts:68
	// assert(61)
	pushint 61
	assert

	// tests/contracts/cblocks.algo.ts:69
	// assert(62)
	pushint 62
	assert

	// tests/contracts/cblocks.algo.ts:70
	// assert(63)
	pushint 63
	assert

	// tests/contracts/cblocks.algo.ts:71
	// assert(64)
	pushint 64
	assert

	// tests/contracts/cblocks.algo.ts:72
	// assert(65)
	pushint 65
	assert

	// tests/contracts/cblocks.algo.ts:73
	// assert(66)
	pushint 66
	assert

	// tests/contracts/cblocks.algo.ts:74
	// assert(67)
	pushint 67
	assert

	// tests/contracts/cblocks.algo.ts:75
	// assert(68)
	pushint 68
	assert

	// tests/contracts/cblocks.algo.ts:76
	// assert(69)
	pushint 69
	assert

	// tests/contracts/cblocks.algo.ts:77
	// assert(70)
	pushint 70
	assert

	// tests/contracts/cblocks.algo.ts:78
	// assert(71)
	pushint 71
	assert

	// tests/contracts/cblocks.algo.ts:79
	// assert(72)
	pushint 72
	assert

	// tests/contracts/cblocks.algo.ts:80
	// assert(73)
	pushint 73
	assert

	// tests/contracts/cblocks.algo.ts:81
	// assert(74)
	pushint 74
	assert

	// tests/contracts/cblocks.algo.ts:82
	// assert(75)
	pushint 75
	assert

	// tests/contracts/cblocks.algo.ts:83
	// assert(76)
	pushint 76
	assert

	// tests/contracts/cblocks.algo.ts:84
	// assert(77)
	pushint 77
	assert

	// tests/contracts/cblocks.algo.ts:85
	// assert(78)
	pushint 78
	assert

	// tests/contracts/cblocks.algo.ts:86
	// assert(79)
	pushint 79
	assert

	// tests/contracts/cblocks.algo.ts:87
	// assert(80)
	pushint 80
	assert

	// tests/contracts/cblocks.algo.ts:88
	// assert(81)
	pushint 81
	assert

	// tests/contracts/cblocks.algo.ts:89
	// assert(82)
	pushint 82
	assert

	// tests/contracts/cblocks.algo.ts:90
	// assert(83)
	pushint 83
	assert

	// tests/contracts/cblocks.algo.ts:91
	// assert(84)
	pushint 84
	assert

	// tests/contracts/cblocks.algo.ts:92
	// assert(85)
	pushint 85
	assert

	// tests/contracts/cblocks.algo.ts:93
	// assert(86)
	pushint 86
	assert

	// tests/contracts/cblocks.algo.ts:94
	// assert(87)
	pushint 87
	assert

	// tests/contracts/cblocks.algo.ts:95
	// assert(88)
	pushint 88
	assert

	// tests/contracts/cblocks.algo.ts:96
	// assert(89)
	pushint 89
	assert

	// tests/contracts/cblocks.algo.ts:97
	// assert(90)
	pushint 90
	assert

	// tests/contracts/cblocks.algo.ts:98
	// assert(91)
	pushint 91
	assert

	// tests/contracts/cblocks.algo.ts:99
	// assert(92)
	pushint 92
	assert

	// tests/contracts/cblocks.algo.ts:100
	// assert(93)
	pushint 93
	assert

	// tests/contracts/cblocks.algo.ts:101
	// assert(94)
	pushint 94
	assert

	// tests/contracts/cblocks.algo.ts:102
	// assert(95)
	pushint 95
	assert

	// tests/contracts/cblocks.algo.ts:103
	// assert(96)
	pushint 96
	assert

	// tests/contracts/cblocks.algo.ts:104
	// assert(97)
	pushint 97
	assert

	// tests/contracts/cblocks.algo.ts:105
	// assert(98)
	pushint 98
	assert

	// tests/contracts/cblocks.algo.ts:106
	// assert(99)
	pushint 99
	assert

	// tests/contracts/cblocks.algo.ts:107
	// assert(100)
	pushint 100
	assert

	// tests/contracts/cblocks.algo.ts:108
	// assert(101)
	pushint 101
	assert

	// tests/contracts/cblocks.algo.ts:109
	// assert(102)
	pushint 102
	assert

	// tests/contracts/cblocks.algo.ts:110
	// assert(103)
	pushint 103
	assert

	// tests/contracts/cblocks.algo.ts:111
	// assert(104)
	pushint 104
	assert

	// tests/contracts/cblocks.algo.ts:112
	// assert(105)
	pushint 105
	assert

	// tests/contracts/cblocks.algo.ts:113
	// assert(106)
	pushint 106
	assert

	// tests/contracts/cblocks.algo.ts:114
	// assert(107)
	pushint 107
	assert

	// tests/contracts/cblocks.algo.ts:115
	// assert(108)
	pushint 108
	assert

	// tests/contracts/cblocks.algo.ts:116
	// assert(109)
	pushint 109
	assert

	// tests/contracts/cblocks.algo.ts:117
	// assert(110)
	pushint 110
	assert

	// tests/contracts/cblocks.algo.ts:118
	// assert(111)
	pushint 111
	assert

	// tests/contracts/cblocks.algo.ts:119
	// assert(112)
	pushint 112
	assert

	// tests/contracts/cblocks.algo.ts:120
	// assert(113)
	pushint 113
	assert

	// tests/contracts/cblocks.algo.ts:121
	// assert(114)
	pushint 114
	assert

	// tests/contracts/cblocks.algo.ts:122
	// assert(115)
	pushint 115
	assert

	// tests/contracts/cblocks.algo.ts:123
	// assert(116)
	pushint 116
	assert

	// tests/contracts/cblocks.algo.ts:124
	// assert(117)
	pushint 117
	assert

	// tests/contracts/cblocks.algo.ts:125
	// assert(118)
	pushint 118
	assert

	// tests/contracts/cblocks.algo.ts:126
	// assert(119)
	pushint 119
	assert

	// tests/contracts/cblocks.algo.ts:127
	// assert(120)
	pushint 120
	assert

	// tests/contracts/cblocks.algo.ts:128
	// assert(121)
	pushint 121
	assert

	// tests/contracts/cblocks.algo.ts:129
	// assert(122)
	pushint 122
	assert

	// tests/contracts/cblocks.algo.ts:130
	// assert(123)
	pushint 123
	assert

	// tests/contracts/cblocks.algo.ts:131
	// assert(124)
	pushint 124
	assert

	// tests/contracts/cblocks.algo.ts:132
	// assert(125)
	pushint 125
	assert

	// tests/contracts/cblocks.algo.ts:133
	// assert(126)
	pushint 126
	assert

	// tests/contracts/cblocks.algo.ts:134
	// assert(127)
	pushint 127
	assert

	// tests/contracts/cblocks.algo.ts:135
	// assert(128)
	pushint 128
	assert

	// tests/contracts/cblocks.algo.ts:136
	// assert(129)
	pushint 129
	assert

	// tests/contracts/cblocks.algo.ts:137
	// assert(130)
	pushint 130
	assert

	// tests/contracts/cblocks.algo.ts:138
	// assert(131)
	pushint 131
	assert

	// tests/contracts/cblocks.algo.ts:139
	// assert(132)
	pushint 132
	assert

	// tests/contracts/cblocks.algo.ts:140
	// assert(133)
	pushint 133
	assert

	// tests/contracts/cblocks.algo.ts:141
	// assert(134)
	pushint 134
	assert

	// tests/contracts/cblocks.algo.ts:142
	// assert(135)
	pushint 135
	assert

	// tests/contracts/cblocks.algo.ts:143
	// assert(136)
	pushint 136
	assert

	// tests/contracts/cblocks.algo.ts:144
	// assert(137)
	pushint 137
	assert

	// tests/contracts/cblocks.algo.ts:145
	// assert(138)
	pushint 138
	assert

	// tests/contracts/cblocks.algo.ts:146
	// assert(139)
	pushint 139
	assert

	// tests/contracts/cblocks.algo.ts:147
	// assert(140)
	pushint 140
	assert

	// tests/contracts/cblocks.algo.ts:148
	// assert(141)
	pushint 141
	assert

	// tests/contracts/cblocks.algo.ts:149
	// assert(142)
	pushint 142
	assert

	// tests/contracts/cblocks.algo.ts:150
	// assert(143)
	pushint 143
	assert

	// tests/contracts/cblocks.algo.ts:151
	// assert(144)
	pushint 144
	assert

	// tests/contracts/cblocks.algo.ts:152
	// assert(145)
	pushint 145
	assert

	// tests/contracts/cblocks.algo.ts:153
	// assert(146)
	pushint 146
	assert

	// tests/contracts/cblocks.algo.ts:154
	// assert(147)
	pushint 147
	assert

	// tests/contracts/cblocks.algo.ts:155
	// assert(148)
	pushint 148
	assert

	// tests/contracts/cblocks.algo.ts:156
	// assert(149)
	pushint 149
	assert

	// tests/contracts/cblocks.algo.ts:157
	// assert(150)
	pushint 150
	assert

	// tests/contracts/cblocks.algo.ts:158
	// assert(151)
	pushint 151
	assert

	// tests/contracts/cblocks.algo.ts:159
	// assert(152)
	pushint 152
	assert

	// tests/contracts/cblocks.algo.ts:160
	// assert(153)
	pushint 153
	assert

	// tests/contracts/cblocks.algo.ts:161
	// assert(154)
	pushint 154
	assert

	// tests/contracts/cblocks.algo.ts:162
	// assert(155)
	pushint 155
	assert

	// tests/contracts/cblocks.algo.ts:163
	// assert(156)
	pushint 156
	assert

	// tests/contracts/cblocks.algo.ts:164
	// assert(157)
	pushint 157
	assert

	// tests/contracts/cblocks.algo.ts:165
	// assert(158)
	pushint 158
	assert

	// tests/contracts/cblocks.algo.ts:166
	// assert(159)
	pushint 159
	assert

	// tests/contracts/cblocks.algo.ts:167
	// assert(160)
	pushint 160
	assert

	// tests/contracts/cblocks.algo.ts:168
	// assert(161)
	pushint 161
	assert

	// tests/contracts/cblocks.algo.ts:169
	// assert(162)
	pushint 162
	assert

	// tests/contracts/cblocks.algo.ts:170
	// assert(163)
	pushint 163
	assert

	// tests/contracts/cblocks.algo.ts:171
	// assert(164)
	pushint 164
	assert

	// tests/contracts/cblocks.algo.ts:172
	// assert(165)
	pushint 165
	assert

	// tests/contracts/cblocks.algo.ts:173
	// assert(166)
	pushint 166
	assert

	// tests/contracts/cblocks.algo.ts:174
	// assert(167)
	pushint 167
	assert

	// tests/contracts/cblocks.algo.ts:175
	// assert(168)
	pushint 168
	assert

	// tests/contracts/cblocks.algo.ts:176
	// assert(169)
	pushint 169
	assert

	// tests/contracts/cblocks.algo.ts:177
	// assert(170)
	pushint 170
	assert

	// tests/contracts/cblocks.algo.ts:178
	// assert(171)
	pushint 171
	assert

	// tests/contracts/cblocks.algo.ts:179
	// assert(172)
	pushint 172
	assert

	// tests/contracts/cblocks.algo.ts:180
	// assert(173)
	pushint 173
	assert

	// tests/contracts/cblocks.algo.ts:181
	// assert(174)
	pushint 174
	assert

	// tests/contracts/cblocks.algo.ts:182
	// assert(175)
	pushint 175
	assert

	// tests/contracts/cblocks.algo.ts:183
	// assert(176)
	pushint 176
	assert

	// tests/contracts/cblocks.algo.ts:184
	// assert(177)
	pushint 177
	assert

	// tests/contracts/cblocks.algo.ts:185
	// assert(178)
	pushint 178
	assert

	// tests/contracts/cblocks.algo.ts:186
	// assert(179)
	pushint 179
	assert

	// tests/contracts/cblocks.algo.ts:187
	// assert(180)
	pushint 180
	assert

	// tests/contracts/cblocks.algo.ts:188
	// assert(181)
	pushint 181
	assert

	// tests/contracts/cblocks.algo.ts:189
	// assert(182)
	pushint 182
	assert

	// tests/contracts/cblocks.algo.ts:190
	// assert(183)
	pushint 183
	assert

	// tests/contracts/cblocks.algo.ts:191
	// assert(184)
	pushint 184
	assert

	// tests/contracts/cblocks.algo.ts:192
	// assert(185)
	pushint 185
	assert

	// tests/contracts/cblocks.algo.ts:193
	// assert(186)
	pushint 186
	assert

	// tests/contracts/cblocks.algo.ts:194
	// assert(187)
	pushint 187
	assert

	// tests/contracts/cblocks.algo.ts:195
	// assert(188)
	pushint 188
	assert

	// tests/contracts/cblocks.algo.ts:196
	// assert(189)
	pushint 189
	assert

	// tests/contracts/cblocks.algo.ts:197
	// assert(190)
	pushint 190
	assert

	// tests/contracts/cblocks.algo.ts:198
	// assert(191)
	pushint 191
	assert

	// tests/contracts/cblocks.algo.ts:199
	// assert(192)
	pushint 192
	assert

	// tests/contracts/cblocks.algo.ts:200
	// assert(193)
	pushint 193
	assert

	// tests/contracts/cblocks.algo.ts:201
	// assert(194)
	pushint 194
	assert

	// tests/contracts/cblocks.algo.ts:202
	// assert(195)
	pushint 195
	assert

	// tests/contracts/cblocks.algo.ts:203
	// assert(196)
	pushint 196
	assert

	// tests/contracts/cblocks.algo.ts:204
	// assert(197)
	pushint 197
	assert

	// tests/contracts/cblocks.algo.ts:205
	// assert(198)
	pushint 198
	assert

	// tests/contracts/cblocks.algo.ts:206
	// assert(199)
	pushint 199
	assert

	// tests/contracts/cblocks.algo.ts:207
	// assert(200)
	pushint 200
	assert

	// tests/contracts/cblocks.algo.ts:208
	// assert(201)
	pushint 201
	assert

	// tests/contracts/cblocks.algo.ts:209
	// assert(202)
	pushint 202
	assert

	// tests/contracts/cblocks.algo.ts:210
	// assert(203)
	pushint 203
	assert

	// tests/contracts/cblocks.algo.ts:211
	// assert(204)
	pushint 204
	assert

	// tests/contracts/cblocks.algo.ts:212
	// assert(205)
	pushint 205
	assert

	// tests/contracts/cblocks.algo.ts:213
	// assert(206)
	pushint 206
	assert

	// tests/contracts/cblocks.algo.ts:214
	// assert(207)
	pushint 207
	assert

	// tests/contracts/cblocks.algo.ts:215
	// assert(208)
	pushint 208
	assert

	// tests/contracts/cblocks.algo.ts:216
	// assert(209)
	pushint 209
	assert

	// tests/contracts/cblocks.algo.ts:217
	// assert(210)
	pushint 210
	assert

	// tests/contracts/cblocks.algo.ts:218
	// assert(211)
	pushint 211
	assert

	// tests/contracts/cblocks.algo.ts:219
	// assert(212)
	pushint 212
	assert

	// tests/contracts/cblocks.algo.ts:220
	// assert(213)
	pushint 213
	assert

	// tests/contracts/cblocks.algo.ts:221
	// assert(214)
	pushint 214
	assert

	// tests/contracts/cblocks.algo.ts:222
	// assert(215)
	pushint 215
	assert

	// tests/contracts/cblocks.algo.ts:223
	// assert(216)
	pushint 216
	assert

	// tests/contracts/cblocks.algo.ts:224
	// assert(217)
	pushint 217
	assert

	// tests/contracts/cblocks.algo.ts:225
	// assert(218)
	pushint 218
	assert

	// tests/contracts/cblocks.algo.ts:226
	// assert(219)
	pushint 219
	assert

	// tests/contracts/cblocks.algo.ts:227
	// assert(220)
	pushint 220
	assert

	// tests/contracts/cblocks.algo.ts:228
	// assert(221)
	pushint 221
	assert

	// tests/contracts/cblocks.algo.ts:229
	// assert(222)
	pushint 222
	assert

	// tests/contracts/cblocks.algo.ts:230
	// assert(223)
	pushint 223
	assert

	// tests/contracts/cblocks.algo.ts:231
	// assert(224)
	pushint 224
	assert

	// tests/contracts/cblocks.algo.ts:232
	// assert(225)
	pushint 225
	assert

	// tests/contracts/cblocks.algo.ts:233
	// assert(226)
	pushint 226
	assert

	// tests/contracts/cblocks.algo.ts:234
	// assert(227)
	pushint 227
	assert

	// tests/contracts/cblocks.algo.ts:235
	// assert(228)
	pushint 228
	assert

	// tests/contracts/cblocks.algo.ts:236
	// assert(229)
	pushint 229
	assert

	// tests/contracts/cblocks.algo.ts:237
	// assert(230)
	pushint 230
	assert

	// tests/contracts/cblocks.algo.ts:238
	// assert(231)
	pushint 231
	assert

	// tests/contracts/cblocks.algo.ts:239
	// assert(232)
	pushint 232
	assert

	// tests/contracts/cblocks.algo.ts:240
	// assert(233)
	pushint 233
	assert

	// tests/contracts/cblocks.algo.ts:241
	// assert(234)
	pushint 234
	assert

	// tests/contracts/cblocks.algo.ts:242
	// assert(235)
	pushint 235
	assert

	// tests/contracts/cblocks.algo.ts:243
	// assert(236)
	pushint 236
	assert

	// tests/contracts/cblocks.algo.ts:244
	// assert(237)
	pushint 237
	assert

	// tests/contracts/cblocks.algo.ts:245
	// assert(238)
	pushint 238
	assert

	// tests/contracts/cblocks.algo.ts:246
	// assert(239)
	pushint 239
	assert

	// tests/contracts/cblocks.algo.ts:247
	// assert(240)
	pushint 240
	assert

	// tests/contracts/cblocks.algo.ts:248
	// assert(241)
	pushint 241
	assert

	// tests/contracts/cblocks.algo.ts:249
	// assert(242)
	pushint 242
	assert

	// tests/contracts/cblocks.algo.ts:250
	// assert(243)
	pushint 243
	assert

	// tests/contracts/cblocks.algo.ts:251
	// assert(244)
	pushint 244
	assert

	// tests/contracts/cblocks.algo.ts:252
	// assert(245)
	pushint 245
	assert

	// tests/contracts/cblocks.algo.ts:253
	// assert(246)
	pushint 246
	assert

	// tests/contracts/cblocks.algo.ts:254
	// assert(247)
	pushint 247
	assert

	// tests/contracts/cblocks.algo.ts:255
	// assert(248)
	pushint 248
	assert

	// tests/contracts/cblocks.algo.ts:256
	// assert(249)
	pushint 249
	assert

	// tests/contracts/cblocks.algo.ts:257
	// assert(250)
	pushint 250
	assert

	// tests/contracts/cblocks.algo.ts:258
	// assert(251)
	pushint 251
	assert

	// tests/contracts/cblocks.algo.ts:259
	// assert(252)
	pushint 252
	assert

	// tests/contracts/cblocks.algo.ts:260
	// assert(253)
	pushint 253
	assert

	// tests/contracts/cblocks.algo.ts:261
	// assert(254)
	pushint 254
	assert

	// tests/contracts/cblocks.algo.ts:262
	// assert(255)
	pushint 255
	assert

	// tests/contracts/cblocks.algo.ts:263
	// assert(256)
	pushint 256
	assert

	// tests/contracts/cblocks.algo.ts:266
	// return a + b;
	pushint 258
	retsub

*abi_route_createApplication:
	pushint 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0xd14e61db // method "largeIntcblock()uint64"
	txna ApplicationArgs 0
	match *abi_route_largeIntcblock

	// this contract does not implement the given ABI method for call NoOp
	err", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/IntcblockTest.arc56_draft.json b/tests/contracts/artifacts/IntcblockTest.arc56_draft.json index 771bb3edc..6231b29d1 100644 --- a/tests/contracts/artifacts/IntcblockTest.arc56_draft.json +++ b/tests/contracts/artifacts/IntcblockTest.arc56_draft.json @@ -4299,7 +4299,7 @@ } }, "source": { - "approval": "#pragma version 10

// This TEAL was generated by TEALScript v0.104.1
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// largeIntcblock()uint64
*abi_route_largeIntcblock:
	// The ABI return prefix
	pushbytes 0x151f7c75

	// execute largeIntcblock()uint64
	callsub largeIntcblock
	itob
	concat
	log
	pushint 1
	return

// largeIntcblock(): uint64
largeIntcblock:
	proto 0 1

	// tests/contracts/cblocks.algo.ts:9
	// assert(2)
	pushint 2
	assert

	// tests/contracts/cblocks.algo.ts:10
	// assert(3)
	pushint 3
	assert

	// tests/contracts/cblocks.algo.ts:11
	// assert(4)
	pushint 4
	assert

	// tests/contracts/cblocks.algo.ts:12
	// assert(5)
	pushint 5
	assert

	// tests/contracts/cblocks.algo.ts:13
	// assert(6)
	pushint 6
	assert

	// tests/contracts/cblocks.algo.ts:14
	// assert(7)
	pushint 7
	assert

	// tests/contracts/cblocks.algo.ts:15
	// assert(8)
	pushint 8
	assert

	// tests/contracts/cblocks.algo.ts:16
	// assert(9)
	pushint 9
	assert

	// tests/contracts/cblocks.algo.ts:17
	// assert(10)
	pushint 10
	assert

	// tests/contracts/cblocks.algo.ts:18
	// assert(11)
	pushint 11
	assert

	// tests/contracts/cblocks.algo.ts:19
	// assert(12)
	pushint 12
	assert

	// tests/contracts/cblocks.algo.ts:20
	// assert(13)
	pushint 13
	assert

	// tests/contracts/cblocks.algo.ts:21
	// assert(14)
	pushint 14
	assert

	// tests/contracts/cblocks.algo.ts:22
	// assert(15)
	pushint 15
	assert

	// tests/contracts/cblocks.algo.ts:23
	// assert(16)
	pushint 16
	assert

	// tests/contracts/cblocks.algo.ts:24
	// assert(17)
	pushint 17
	assert

	// tests/contracts/cblocks.algo.ts:25
	// assert(18)
	pushint 18
	assert

	// tests/contracts/cblocks.algo.ts:26
	// assert(19)
	pushint 19
	assert

	// tests/contracts/cblocks.algo.ts:27
	// assert(20)
	pushint 20
	assert

	// tests/contracts/cblocks.algo.ts:28
	// assert(21)
	pushint 21
	assert

	// tests/contracts/cblocks.algo.ts:29
	// assert(22)
	pushint 22
	assert

	// tests/contracts/cblocks.algo.ts:30
	// assert(23)
	pushint 23
	assert

	// tests/contracts/cblocks.algo.ts:31
	// assert(24)
	pushint 24
	assert

	// tests/contracts/cblocks.algo.ts:32
	// assert(25)
	pushint 25
	assert

	// tests/contracts/cblocks.algo.ts:33
	// assert(26)
	pushint 26
	assert

	// tests/contracts/cblocks.algo.ts:34
	// assert(27)
	pushint 27
	assert

	// tests/contracts/cblocks.algo.ts:35
	// assert(28)
	pushint 28
	assert

	// tests/contracts/cblocks.algo.ts:36
	// assert(29)
	pushint 29
	assert

	// tests/contracts/cblocks.algo.ts:37
	// assert(30)
	pushint 30
	assert

	// tests/contracts/cblocks.algo.ts:38
	// assert(31)
	pushint 31
	assert

	// tests/contracts/cblocks.algo.ts:39
	// assert(32)
	pushint 32
	assert

	// tests/contracts/cblocks.algo.ts:40
	// assert(33)
	pushint 33
	assert

	// tests/contracts/cblocks.algo.ts:41
	// assert(34)
	pushint 34
	assert

	// tests/contracts/cblocks.algo.ts:42
	// assert(35)
	pushint 35
	assert

	// tests/contracts/cblocks.algo.ts:43
	// assert(36)
	pushint 36
	assert

	// tests/contracts/cblocks.algo.ts:44
	// assert(37)
	pushint 37
	assert

	// tests/contracts/cblocks.algo.ts:45
	// assert(38)
	pushint 38
	assert

	// tests/contracts/cblocks.algo.ts:46
	// assert(39)
	pushint 39
	assert

	// tests/contracts/cblocks.algo.ts:47
	// assert(40)
	pushint 40
	assert

	// tests/contracts/cblocks.algo.ts:48
	// assert(41)
	pushint 41
	assert

	// tests/contracts/cblocks.algo.ts:49
	// assert(42)
	pushint 42
	assert

	// tests/contracts/cblocks.algo.ts:50
	// assert(43)
	pushint 43
	assert

	// tests/contracts/cblocks.algo.ts:51
	// assert(44)
	pushint 44
	assert

	// tests/contracts/cblocks.algo.ts:52
	// assert(45)
	pushint 45
	assert

	// tests/contracts/cblocks.algo.ts:53
	// assert(46)
	pushint 46
	assert

	// tests/contracts/cblocks.algo.ts:54
	// assert(47)
	pushint 47
	assert

	// tests/contracts/cblocks.algo.ts:55
	// assert(48)
	pushint 48
	assert

	// tests/contracts/cblocks.algo.ts:56
	// assert(49)
	pushint 49
	assert

	// tests/contracts/cblocks.algo.ts:57
	// assert(50)
	pushint 50
	assert

	// tests/contracts/cblocks.algo.ts:58
	// assert(51)
	pushint 51
	assert

	// tests/contracts/cblocks.algo.ts:59
	// assert(52)
	pushint 52
	assert

	// tests/contracts/cblocks.algo.ts:60
	// assert(53)
	pushint 53
	assert

	// tests/contracts/cblocks.algo.ts:61
	// assert(54)
	pushint 54
	assert

	// tests/contracts/cblocks.algo.ts:62
	// assert(55)
	pushint 55
	assert

	// tests/contracts/cblocks.algo.ts:63
	// assert(56)
	pushint 56
	assert

	// tests/contracts/cblocks.algo.ts:64
	// assert(57)
	pushint 57
	assert

	// tests/contracts/cblocks.algo.ts:65
	// assert(58)
	pushint 58
	assert

	// tests/contracts/cblocks.algo.ts:66
	// assert(59)
	pushint 59
	assert

	// tests/contracts/cblocks.algo.ts:67
	// assert(60)
	pushint 60
	assert

	// tests/contracts/cblocks.algo.ts:68
	// assert(61)
	pushint 61
	assert

	// tests/contracts/cblocks.algo.ts:69
	// assert(62)
	pushint 62
	assert

	// tests/contracts/cblocks.algo.ts:70
	// assert(63)
	pushint 63
	assert

	// tests/contracts/cblocks.algo.ts:71
	// assert(64)
	pushint 64
	assert

	// tests/contracts/cblocks.algo.ts:72
	// assert(65)
	pushint 65
	assert

	// tests/contracts/cblocks.algo.ts:73
	// assert(66)
	pushint 66
	assert

	// tests/contracts/cblocks.algo.ts:74
	// assert(67)
	pushint 67
	assert

	// tests/contracts/cblocks.algo.ts:75
	// assert(68)
	pushint 68
	assert

	// tests/contracts/cblocks.algo.ts:76
	// assert(69)
	pushint 69
	assert

	// tests/contracts/cblocks.algo.ts:77
	// assert(70)
	pushint 70
	assert

	// tests/contracts/cblocks.algo.ts:78
	// assert(71)
	pushint 71
	assert

	// tests/contracts/cblocks.algo.ts:79
	// assert(72)
	pushint 72
	assert

	// tests/contracts/cblocks.algo.ts:80
	// assert(73)
	pushint 73
	assert

	// tests/contracts/cblocks.algo.ts:81
	// assert(74)
	pushint 74
	assert

	// tests/contracts/cblocks.algo.ts:82
	// assert(75)
	pushint 75
	assert

	// tests/contracts/cblocks.algo.ts:83
	// assert(76)
	pushint 76
	assert

	// tests/contracts/cblocks.algo.ts:84
	// assert(77)
	pushint 77
	assert

	// tests/contracts/cblocks.algo.ts:85
	// assert(78)
	pushint 78
	assert

	// tests/contracts/cblocks.algo.ts:86
	// assert(79)
	pushint 79
	assert

	// tests/contracts/cblocks.algo.ts:87
	// assert(80)
	pushint 80
	assert

	// tests/contracts/cblocks.algo.ts:88
	// assert(81)
	pushint 81
	assert

	// tests/contracts/cblocks.algo.ts:89
	// assert(82)
	pushint 82
	assert

	// tests/contracts/cblocks.algo.ts:90
	// assert(83)
	pushint 83
	assert

	// tests/contracts/cblocks.algo.ts:91
	// assert(84)
	pushint 84
	assert

	// tests/contracts/cblocks.algo.ts:92
	// assert(85)
	pushint 85
	assert

	// tests/contracts/cblocks.algo.ts:93
	// assert(86)
	pushint 86
	assert

	// tests/contracts/cblocks.algo.ts:94
	// assert(87)
	pushint 87
	assert

	// tests/contracts/cblocks.algo.ts:95
	// assert(88)
	pushint 88
	assert

	// tests/contracts/cblocks.algo.ts:96
	// assert(89)
	pushint 89
	assert

	// tests/contracts/cblocks.algo.ts:97
	// assert(90)
	pushint 90
	assert

	// tests/contracts/cblocks.algo.ts:98
	// assert(91)
	pushint 91
	assert

	// tests/contracts/cblocks.algo.ts:99
	// assert(92)
	pushint 92
	assert

	// tests/contracts/cblocks.algo.ts:100
	// assert(93)
	pushint 93
	assert

	// tests/contracts/cblocks.algo.ts:101
	// assert(94)
	pushint 94
	assert

	// tests/contracts/cblocks.algo.ts:102
	// assert(95)
	pushint 95
	assert

	// tests/contracts/cblocks.algo.ts:103
	// assert(96)
	pushint 96
	assert

	// tests/contracts/cblocks.algo.ts:104
	// assert(97)
	pushint 97
	assert

	// tests/contracts/cblocks.algo.ts:105
	// assert(98)
	pushint 98
	assert

	// tests/contracts/cblocks.algo.ts:106
	// assert(99)
	pushint 99
	assert

	// tests/contracts/cblocks.algo.ts:107
	// assert(100)
	pushint 100
	assert

	// tests/contracts/cblocks.algo.ts:108
	// assert(101)
	pushint 101
	assert

	// tests/contracts/cblocks.algo.ts:109
	// assert(102)
	pushint 102
	assert

	// tests/contracts/cblocks.algo.ts:110
	// assert(103)
	pushint 103
	assert

	// tests/contracts/cblocks.algo.ts:111
	// assert(104)
	pushint 104
	assert

	// tests/contracts/cblocks.algo.ts:112
	// assert(105)
	pushint 105
	assert

	// tests/contracts/cblocks.algo.ts:113
	// assert(106)
	pushint 106
	assert

	// tests/contracts/cblocks.algo.ts:114
	// assert(107)
	pushint 107
	assert

	// tests/contracts/cblocks.algo.ts:115
	// assert(108)
	pushint 108
	assert

	// tests/contracts/cblocks.algo.ts:116
	// assert(109)
	pushint 109
	assert

	// tests/contracts/cblocks.algo.ts:117
	// assert(110)
	pushint 110
	assert

	// tests/contracts/cblocks.algo.ts:118
	// assert(111)
	pushint 111
	assert

	// tests/contracts/cblocks.algo.ts:119
	// assert(112)
	pushint 112
	assert

	// tests/contracts/cblocks.algo.ts:120
	// assert(113)
	pushint 113
	assert

	// tests/contracts/cblocks.algo.ts:121
	// assert(114)
	pushint 114
	assert

	// tests/contracts/cblocks.algo.ts:122
	// assert(115)
	pushint 115
	assert

	// tests/contracts/cblocks.algo.ts:123
	// assert(116)
	pushint 116
	assert

	// tests/contracts/cblocks.algo.ts:124
	// assert(117)
	pushint 117
	assert

	// tests/contracts/cblocks.algo.ts:125
	// assert(118)
	pushint 118
	assert

	// tests/contracts/cblocks.algo.ts:126
	// assert(119)
	pushint 119
	assert

	// tests/contracts/cblocks.algo.ts:127
	// assert(120)
	pushint 120
	assert

	// tests/contracts/cblocks.algo.ts:128
	// assert(121)
	pushint 121
	assert

	// tests/contracts/cblocks.algo.ts:129
	// assert(122)
	pushint 122
	assert

	// tests/contracts/cblocks.algo.ts:130
	// assert(123)
	pushint 123
	assert

	// tests/contracts/cblocks.algo.ts:131
	// assert(124)
	pushint 124
	assert

	// tests/contracts/cblocks.algo.ts:132
	// assert(125)
	pushint 125
	assert

	// tests/contracts/cblocks.algo.ts:133
	// assert(126)
	pushint 126
	assert

	// tests/contracts/cblocks.algo.ts:134
	// assert(127)
	pushint 127
	assert

	// tests/contracts/cblocks.algo.ts:135
	// assert(128)
	pushint 128
	assert

	// tests/contracts/cblocks.algo.ts:136
	// assert(129)
	pushint 129
	assert

	// tests/contracts/cblocks.algo.ts:137
	// assert(130)
	pushint 130
	assert

	// tests/contracts/cblocks.algo.ts:138
	// assert(131)
	pushint 131
	assert

	// tests/contracts/cblocks.algo.ts:139
	// assert(132)
	pushint 132
	assert

	// tests/contracts/cblocks.algo.ts:140
	// assert(133)
	pushint 133
	assert

	// tests/contracts/cblocks.algo.ts:141
	// assert(134)
	pushint 134
	assert

	// tests/contracts/cblocks.algo.ts:142
	// assert(135)
	pushint 135
	assert

	// tests/contracts/cblocks.algo.ts:143
	// assert(136)
	pushint 136
	assert

	// tests/contracts/cblocks.algo.ts:144
	// assert(137)
	pushint 137
	assert

	// tests/contracts/cblocks.algo.ts:145
	// assert(138)
	pushint 138
	assert

	// tests/contracts/cblocks.algo.ts:146
	// assert(139)
	pushint 139
	assert

	// tests/contracts/cblocks.algo.ts:147
	// assert(140)
	pushint 140
	assert

	// tests/contracts/cblocks.algo.ts:148
	// assert(141)
	pushint 141
	assert

	// tests/contracts/cblocks.algo.ts:149
	// assert(142)
	pushint 142
	assert

	// tests/contracts/cblocks.algo.ts:150
	// assert(143)
	pushint 143
	assert

	// tests/contracts/cblocks.algo.ts:151
	// assert(144)
	pushint 144
	assert

	// tests/contracts/cblocks.algo.ts:152
	// assert(145)
	pushint 145
	assert

	// tests/contracts/cblocks.algo.ts:153
	// assert(146)
	pushint 146
	assert

	// tests/contracts/cblocks.algo.ts:154
	// assert(147)
	pushint 147
	assert

	// tests/contracts/cblocks.algo.ts:155
	// assert(148)
	pushint 148
	assert

	// tests/contracts/cblocks.algo.ts:156
	// assert(149)
	pushint 149
	assert

	// tests/contracts/cblocks.algo.ts:157
	// assert(150)
	pushint 150
	assert

	// tests/contracts/cblocks.algo.ts:158
	// assert(151)
	pushint 151
	assert

	// tests/contracts/cblocks.algo.ts:159
	// assert(152)
	pushint 152
	assert

	// tests/contracts/cblocks.algo.ts:160
	// assert(153)
	pushint 153
	assert

	// tests/contracts/cblocks.algo.ts:161
	// assert(154)
	pushint 154
	assert

	// tests/contracts/cblocks.algo.ts:162
	// assert(155)
	pushint 155
	assert

	// tests/contracts/cblocks.algo.ts:163
	// assert(156)
	pushint 156
	assert

	// tests/contracts/cblocks.algo.ts:164
	// assert(157)
	pushint 157
	assert

	// tests/contracts/cblocks.algo.ts:165
	// assert(158)
	pushint 158
	assert

	// tests/contracts/cblocks.algo.ts:166
	// assert(159)
	pushint 159
	assert

	// tests/contracts/cblocks.algo.ts:167
	// assert(160)
	pushint 160
	assert

	// tests/contracts/cblocks.algo.ts:168
	// assert(161)
	pushint 161
	assert

	// tests/contracts/cblocks.algo.ts:169
	// assert(162)
	pushint 162
	assert

	// tests/contracts/cblocks.algo.ts:170
	// assert(163)
	pushint 163
	assert

	// tests/contracts/cblocks.algo.ts:171
	// assert(164)
	pushint 164
	assert

	// tests/contracts/cblocks.algo.ts:172
	// assert(165)
	pushint 165
	assert

	// tests/contracts/cblocks.algo.ts:173
	// assert(166)
	pushint 166
	assert

	// tests/contracts/cblocks.algo.ts:174
	// assert(167)
	pushint 167
	assert

	// tests/contracts/cblocks.algo.ts:175
	// assert(168)
	pushint 168
	assert

	// tests/contracts/cblocks.algo.ts:176
	// assert(169)
	pushint 169
	assert

	// tests/contracts/cblocks.algo.ts:177
	// assert(170)
	pushint 170
	assert

	// tests/contracts/cblocks.algo.ts:178
	// assert(171)
	pushint 171
	assert

	// tests/contracts/cblocks.algo.ts:179
	// assert(172)
	pushint 172
	assert

	// tests/contracts/cblocks.algo.ts:180
	// assert(173)
	pushint 173
	assert

	// tests/contracts/cblocks.algo.ts:181
	// assert(174)
	pushint 174
	assert

	// tests/contracts/cblocks.algo.ts:182
	// assert(175)
	pushint 175
	assert

	// tests/contracts/cblocks.algo.ts:183
	// assert(176)
	pushint 176
	assert

	// tests/contracts/cblocks.algo.ts:184
	// assert(177)
	pushint 177
	assert

	// tests/contracts/cblocks.algo.ts:185
	// assert(178)
	pushint 178
	assert

	// tests/contracts/cblocks.algo.ts:186
	// assert(179)
	pushint 179
	assert

	// tests/contracts/cblocks.algo.ts:187
	// assert(180)
	pushint 180
	assert

	// tests/contracts/cblocks.algo.ts:188
	// assert(181)
	pushint 181
	assert

	// tests/contracts/cblocks.algo.ts:189
	// assert(182)
	pushint 182
	assert

	// tests/contracts/cblocks.algo.ts:190
	// assert(183)
	pushint 183
	assert

	// tests/contracts/cblocks.algo.ts:191
	// assert(184)
	pushint 184
	assert

	// tests/contracts/cblocks.algo.ts:192
	// assert(185)
	pushint 185
	assert

	// tests/contracts/cblocks.algo.ts:193
	// assert(186)
	pushint 186
	assert

	// tests/contracts/cblocks.algo.ts:194
	// assert(187)
	pushint 187
	assert

	// tests/contracts/cblocks.algo.ts:195
	// assert(188)
	pushint 188
	assert

	// tests/contracts/cblocks.algo.ts:196
	// assert(189)
	pushint 189
	assert

	// tests/contracts/cblocks.algo.ts:197
	// assert(190)
	pushint 190
	assert

	// tests/contracts/cblocks.algo.ts:198
	// assert(191)
	pushint 191
	assert

	// tests/contracts/cblocks.algo.ts:199
	// assert(192)
	pushint 192
	assert

	// tests/contracts/cblocks.algo.ts:200
	// assert(193)
	pushint 193
	assert

	// tests/contracts/cblocks.algo.ts:201
	// assert(194)
	pushint 194
	assert

	// tests/contracts/cblocks.algo.ts:202
	// assert(195)
	pushint 195
	assert

	// tests/contracts/cblocks.algo.ts:203
	// assert(196)
	pushint 196
	assert

	// tests/contracts/cblocks.algo.ts:204
	// assert(197)
	pushint 197
	assert

	// tests/contracts/cblocks.algo.ts:205
	// assert(198)
	pushint 198
	assert

	// tests/contracts/cblocks.algo.ts:206
	// assert(199)
	pushint 199
	assert

	// tests/contracts/cblocks.algo.ts:207
	// assert(200)
	pushint 200
	assert

	// tests/contracts/cblocks.algo.ts:208
	// assert(201)
	pushint 201
	assert

	// tests/contracts/cblocks.algo.ts:209
	// assert(202)
	pushint 202
	assert

	// tests/contracts/cblocks.algo.ts:210
	// assert(203)
	pushint 203
	assert

	// tests/contracts/cblocks.algo.ts:211
	// assert(204)
	pushint 204
	assert

	// tests/contracts/cblocks.algo.ts:212
	// assert(205)
	pushint 205
	assert

	// tests/contracts/cblocks.algo.ts:213
	// assert(206)
	pushint 206
	assert

	// tests/contracts/cblocks.algo.ts:214
	// assert(207)
	pushint 207
	assert

	// tests/contracts/cblocks.algo.ts:215
	// assert(208)
	pushint 208
	assert

	// tests/contracts/cblocks.algo.ts:216
	// assert(209)
	pushint 209
	assert

	// tests/contracts/cblocks.algo.ts:217
	// assert(210)
	pushint 210
	assert

	// tests/contracts/cblocks.algo.ts:218
	// assert(211)
	pushint 211
	assert

	// tests/contracts/cblocks.algo.ts:219
	// assert(212)
	pushint 212
	assert

	// tests/contracts/cblocks.algo.ts:220
	// assert(213)
	pushint 213
	assert

	// tests/contracts/cblocks.algo.ts:221
	// assert(214)
	pushint 214
	assert

	// tests/contracts/cblocks.algo.ts:222
	// assert(215)
	pushint 215
	assert

	// tests/contracts/cblocks.algo.ts:223
	// assert(216)
	pushint 216
	assert

	// tests/contracts/cblocks.algo.ts:224
	// assert(217)
	pushint 217
	assert

	// tests/contracts/cblocks.algo.ts:225
	// assert(218)
	pushint 218
	assert

	// tests/contracts/cblocks.algo.ts:226
	// assert(219)
	pushint 219
	assert

	// tests/contracts/cblocks.algo.ts:227
	// assert(220)
	pushint 220
	assert

	// tests/contracts/cblocks.algo.ts:228
	// assert(221)
	pushint 221
	assert

	// tests/contracts/cblocks.algo.ts:229
	// assert(222)
	pushint 222
	assert

	// tests/contracts/cblocks.algo.ts:230
	// assert(223)
	pushint 223
	assert

	// tests/contracts/cblocks.algo.ts:231
	// assert(224)
	pushint 224
	assert

	// tests/contracts/cblocks.algo.ts:232
	// assert(225)
	pushint 225
	assert

	// tests/contracts/cblocks.algo.ts:233
	// assert(226)
	pushint 226
	assert

	// tests/contracts/cblocks.algo.ts:234
	// assert(227)
	pushint 227
	assert

	// tests/contracts/cblocks.algo.ts:235
	// assert(228)
	pushint 228
	assert

	// tests/contracts/cblocks.algo.ts:236
	// assert(229)
	pushint 229
	assert

	// tests/contracts/cblocks.algo.ts:237
	// assert(230)
	pushint 230
	assert

	// tests/contracts/cblocks.algo.ts:238
	// assert(231)
	pushint 231
	assert

	// tests/contracts/cblocks.algo.ts:239
	// assert(232)
	pushint 232
	assert

	// tests/contracts/cblocks.algo.ts:240
	// assert(233)
	pushint 233
	assert

	// tests/contracts/cblocks.algo.ts:241
	// assert(234)
	pushint 234
	assert

	// tests/contracts/cblocks.algo.ts:242
	// assert(235)
	pushint 235
	assert

	// tests/contracts/cblocks.algo.ts:243
	// assert(236)
	pushint 236
	assert

	// tests/contracts/cblocks.algo.ts:244
	// assert(237)
	pushint 237
	assert

	// tests/contracts/cblocks.algo.ts:245
	// assert(238)
	pushint 238
	assert

	// tests/contracts/cblocks.algo.ts:246
	// assert(239)
	pushint 239
	assert

	// tests/contracts/cblocks.algo.ts:247
	// assert(240)
	pushint 240
	assert

	// tests/contracts/cblocks.algo.ts:248
	// assert(241)
	pushint 241
	assert

	// tests/contracts/cblocks.algo.ts:249
	// assert(242)
	pushint 242
	assert

	// tests/contracts/cblocks.algo.ts:250
	// assert(243)
	pushint 243
	assert

	// tests/contracts/cblocks.algo.ts:251
	// assert(244)
	pushint 244
	assert

	// tests/contracts/cblocks.algo.ts:252
	// assert(245)
	pushint 245
	assert

	// tests/contracts/cblocks.algo.ts:253
	// assert(246)
	pushint 246
	assert

	// tests/contracts/cblocks.algo.ts:254
	// assert(247)
	pushint 247
	assert

	// tests/contracts/cblocks.algo.ts:255
	// assert(248)
	pushint 248
	assert

	// tests/contracts/cblocks.algo.ts:256
	// assert(249)
	pushint 249
	assert

	// tests/contracts/cblocks.algo.ts:257
	// assert(250)
	pushint 250
	assert

	// tests/contracts/cblocks.algo.ts:258
	// assert(251)
	pushint 251
	assert

	// tests/contracts/cblocks.algo.ts:259
	// assert(252)
	pushint 252
	assert

	// tests/contracts/cblocks.algo.ts:260
	// assert(253)
	pushint 253
	assert

	// tests/contracts/cblocks.algo.ts:261
	// assert(254)
	pushint 254
	assert

	// tests/contracts/cblocks.algo.ts:262
	// assert(255)
	pushint 255
	assert

	// tests/contracts/cblocks.algo.ts:263
	// assert(256)
	pushint 256
	assert

	// tests/contracts/cblocks.algo.ts:266
	// return a + b;
	pushint 258
	retsub

*abi_route_createApplication:
	pushint 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0xd14e61db // method "largeIntcblock()uint64"
	txna ApplicationArgs 0
	match *abi_route_largeIntcblock

	// this contract does not implement the given ABI method for call NoOp
	err", + "approval": "#pragma version 10

// This TEAL was generated by TEALScript v0.105.0
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// largeIntcblock()uint64
*abi_route_largeIntcblock:
	// The ABI return prefix
	pushbytes 0x151f7c75

	// execute largeIntcblock()uint64
	callsub largeIntcblock
	itob
	concat
	log
	pushint 1
	return

// largeIntcblock(): uint64
largeIntcblock:
	proto 0 1

	// tests/contracts/cblocks.algo.ts:9
	// assert(2)
	pushint 2
	assert

	// tests/contracts/cblocks.algo.ts:10
	// assert(3)
	pushint 3
	assert

	// tests/contracts/cblocks.algo.ts:11
	// assert(4)
	pushint 4
	assert

	// tests/contracts/cblocks.algo.ts:12
	// assert(5)
	pushint 5
	assert

	// tests/contracts/cblocks.algo.ts:13
	// assert(6)
	pushint 6
	assert

	// tests/contracts/cblocks.algo.ts:14
	// assert(7)
	pushint 7
	assert

	// tests/contracts/cblocks.algo.ts:15
	// assert(8)
	pushint 8
	assert

	// tests/contracts/cblocks.algo.ts:16
	// assert(9)
	pushint 9
	assert

	// tests/contracts/cblocks.algo.ts:17
	// assert(10)
	pushint 10
	assert

	// tests/contracts/cblocks.algo.ts:18
	// assert(11)
	pushint 11
	assert

	// tests/contracts/cblocks.algo.ts:19
	// assert(12)
	pushint 12
	assert

	// tests/contracts/cblocks.algo.ts:20
	// assert(13)
	pushint 13
	assert

	// tests/contracts/cblocks.algo.ts:21
	// assert(14)
	pushint 14
	assert

	// tests/contracts/cblocks.algo.ts:22
	// assert(15)
	pushint 15
	assert

	// tests/contracts/cblocks.algo.ts:23
	// assert(16)
	pushint 16
	assert

	// tests/contracts/cblocks.algo.ts:24
	// assert(17)
	pushint 17
	assert

	// tests/contracts/cblocks.algo.ts:25
	// assert(18)
	pushint 18
	assert

	// tests/contracts/cblocks.algo.ts:26
	// assert(19)
	pushint 19
	assert

	// tests/contracts/cblocks.algo.ts:27
	// assert(20)
	pushint 20
	assert

	// tests/contracts/cblocks.algo.ts:28
	// assert(21)
	pushint 21
	assert

	// tests/contracts/cblocks.algo.ts:29
	// assert(22)
	pushint 22
	assert

	// tests/contracts/cblocks.algo.ts:30
	// assert(23)
	pushint 23
	assert

	// tests/contracts/cblocks.algo.ts:31
	// assert(24)
	pushint 24
	assert

	// tests/contracts/cblocks.algo.ts:32
	// assert(25)
	pushint 25
	assert

	// tests/contracts/cblocks.algo.ts:33
	// assert(26)
	pushint 26
	assert

	// tests/contracts/cblocks.algo.ts:34
	// assert(27)
	pushint 27
	assert

	// tests/contracts/cblocks.algo.ts:35
	// assert(28)
	pushint 28
	assert

	// tests/contracts/cblocks.algo.ts:36
	// assert(29)
	pushint 29
	assert

	// tests/contracts/cblocks.algo.ts:37
	// assert(30)
	pushint 30
	assert

	// tests/contracts/cblocks.algo.ts:38
	// assert(31)
	pushint 31
	assert

	// tests/contracts/cblocks.algo.ts:39
	// assert(32)
	pushint 32
	assert

	// tests/contracts/cblocks.algo.ts:40
	// assert(33)
	pushint 33
	assert

	// tests/contracts/cblocks.algo.ts:41
	// assert(34)
	pushint 34
	assert

	// tests/contracts/cblocks.algo.ts:42
	// assert(35)
	pushint 35
	assert

	// tests/contracts/cblocks.algo.ts:43
	// assert(36)
	pushint 36
	assert

	// tests/contracts/cblocks.algo.ts:44
	// assert(37)
	pushint 37
	assert

	// tests/contracts/cblocks.algo.ts:45
	// assert(38)
	pushint 38
	assert

	// tests/contracts/cblocks.algo.ts:46
	// assert(39)
	pushint 39
	assert

	// tests/contracts/cblocks.algo.ts:47
	// assert(40)
	pushint 40
	assert

	// tests/contracts/cblocks.algo.ts:48
	// assert(41)
	pushint 41
	assert

	// tests/contracts/cblocks.algo.ts:49
	// assert(42)
	pushint 42
	assert

	// tests/contracts/cblocks.algo.ts:50
	// assert(43)
	pushint 43
	assert

	// tests/contracts/cblocks.algo.ts:51
	// assert(44)
	pushint 44
	assert

	// tests/contracts/cblocks.algo.ts:52
	// assert(45)
	pushint 45
	assert

	// tests/contracts/cblocks.algo.ts:53
	// assert(46)
	pushint 46
	assert

	// tests/contracts/cblocks.algo.ts:54
	// assert(47)
	pushint 47
	assert

	// tests/contracts/cblocks.algo.ts:55
	// assert(48)
	pushint 48
	assert

	// tests/contracts/cblocks.algo.ts:56
	// assert(49)
	pushint 49
	assert

	// tests/contracts/cblocks.algo.ts:57
	// assert(50)
	pushint 50
	assert

	// tests/contracts/cblocks.algo.ts:58
	// assert(51)
	pushint 51
	assert

	// tests/contracts/cblocks.algo.ts:59
	// assert(52)
	pushint 52
	assert

	// tests/contracts/cblocks.algo.ts:60
	// assert(53)
	pushint 53
	assert

	// tests/contracts/cblocks.algo.ts:61
	// assert(54)
	pushint 54
	assert

	// tests/contracts/cblocks.algo.ts:62
	// assert(55)
	pushint 55
	assert

	// tests/contracts/cblocks.algo.ts:63
	// assert(56)
	pushint 56
	assert

	// tests/contracts/cblocks.algo.ts:64
	// assert(57)
	pushint 57
	assert

	// tests/contracts/cblocks.algo.ts:65
	// assert(58)
	pushint 58
	assert

	// tests/contracts/cblocks.algo.ts:66
	// assert(59)
	pushint 59
	assert

	// tests/contracts/cblocks.algo.ts:67
	// assert(60)
	pushint 60
	assert

	// tests/contracts/cblocks.algo.ts:68
	// assert(61)
	pushint 61
	assert

	// tests/contracts/cblocks.algo.ts:69
	// assert(62)
	pushint 62
	assert

	// tests/contracts/cblocks.algo.ts:70
	// assert(63)
	pushint 63
	assert

	// tests/contracts/cblocks.algo.ts:71
	// assert(64)
	pushint 64
	assert

	// tests/contracts/cblocks.algo.ts:72
	// assert(65)
	pushint 65
	assert

	// tests/contracts/cblocks.algo.ts:73
	// assert(66)
	pushint 66
	assert

	// tests/contracts/cblocks.algo.ts:74
	// assert(67)
	pushint 67
	assert

	// tests/contracts/cblocks.algo.ts:75
	// assert(68)
	pushint 68
	assert

	// tests/contracts/cblocks.algo.ts:76
	// assert(69)
	pushint 69
	assert

	// tests/contracts/cblocks.algo.ts:77
	// assert(70)
	pushint 70
	assert

	// tests/contracts/cblocks.algo.ts:78
	// assert(71)
	pushint 71
	assert

	// tests/contracts/cblocks.algo.ts:79
	// assert(72)
	pushint 72
	assert

	// tests/contracts/cblocks.algo.ts:80
	// assert(73)
	pushint 73
	assert

	// tests/contracts/cblocks.algo.ts:81
	// assert(74)
	pushint 74
	assert

	// tests/contracts/cblocks.algo.ts:82
	// assert(75)
	pushint 75
	assert

	// tests/contracts/cblocks.algo.ts:83
	// assert(76)
	pushint 76
	assert

	// tests/contracts/cblocks.algo.ts:84
	// assert(77)
	pushint 77
	assert

	// tests/contracts/cblocks.algo.ts:85
	// assert(78)
	pushint 78
	assert

	// tests/contracts/cblocks.algo.ts:86
	// assert(79)
	pushint 79
	assert

	// tests/contracts/cblocks.algo.ts:87
	// assert(80)
	pushint 80
	assert

	// tests/contracts/cblocks.algo.ts:88
	// assert(81)
	pushint 81
	assert

	// tests/contracts/cblocks.algo.ts:89
	// assert(82)
	pushint 82
	assert

	// tests/contracts/cblocks.algo.ts:90
	// assert(83)
	pushint 83
	assert

	// tests/contracts/cblocks.algo.ts:91
	// assert(84)
	pushint 84
	assert

	// tests/contracts/cblocks.algo.ts:92
	// assert(85)
	pushint 85
	assert

	// tests/contracts/cblocks.algo.ts:93
	// assert(86)
	pushint 86
	assert

	// tests/contracts/cblocks.algo.ts:94
	// assert(87)
	pushint 87
	assert

	// tests/contracts/cblocks.algo.ts:95
	// assert(88)
	pushint 88
	assert

	// tests/contracts/cblocks.algo.ts:96
	// assert(89)
	pushint 89
	assert

	// tests/contracts/cblocks.algo.ts:97
	// assert(90)
	pushint 90
	assert

	// tests/contracts/cblocks.algo.ts:98
	// assert(91)
	pushint 91
	assert

	// tests/contracts/cblocks.algo.ts:99
	// assert(92)
	pushint 92
	assert

	// tests/contracts/cblocks.algo.ts:100
	// assert(93)
	pushint 93
	assert

	// tests/contracts/cblocks.algo.ts:101
	// assert(94)
	pushint 94
	assert

	// tests/contracts/cblocks.algo.ts:102
	// assert(95)
	pushint 95
	assert

	// tests/contracts/cblocks.algo.ts:103
	// assert(96)
	pushint 96
	assert

	// tests/contracts/cblocks.algo.ts:104
	// assert(97)
	pushint 97
	assert

	// tests/contracts/cblocks.algo.ts:105
	// assert(98)
	pushint 98
	assert

	// tests/contracts/cblocks.algo.ts:106
	// assert(99)
	pushint 99
	assert

	// tests/contracts/cblocks.algo.ts:107
	// assert(100)
	pushint 100
	assert

	// tests/contracts/cblocks.algo.ts:108
	// assert(101)
	pushint 101
	assert

	// tests/contracts/cblocks.algo.ts:109
	// assert(102)
	pushint 102
	assert

	// tests/contracts/cblocks.algo.ts:110
	// assert(103)
	pushint 103
	assert

	// tests/contracts/cblocks.algo.ts:111
	// assert(104)
	pushint 104
	assert

	// tests/contracts/cblocks.algo.ts:112
	// assert(105)
	pushint 105
	assert

	// tests/contracts/cblocks.algo.ts:113
	// assert(106)
	pushint 106
	assert

	// tests/contracts/cblocks.algo.ts:114
	// assert(107)
	pushint 107
	assert

	// tests/contracts/cblocks.algo.ts:115
	// assert(108)
	pushint 108
	assert

	// tests/contracts/cblocks.algo.ts:116
	// assert(109)
	pushint 109
	assert

	// tests/contracts/cblocks.algo.ts:117
	// assert(110)
	pushint 110
	assert

	// tests/contracts/cblocks.algo.ts:118
	// assert(111)
	pushint 111
	assert

	// tests/contracts/cblocks.algo.ts:119
	// assert(112)
	pushint 112
	assert

	// tests/contracts/cblocks.algo.ts:120
	// assert(113)
	pushint 113
	assert

	// tests/contracts/cblocks.algo.ts:121
	// assert(114)
	pushint 114
	assert

	// tests/contracts/cblocks.algo.ts:122
	// assert(115)
	pushint 115
	assert

	// tests/contracts/cblocks.algo.ts:123
	// assert(116)
	pushint 116
	assert

	// tests/contracts/cblocks.algo.ts:124
	// assert(117)
	pushint 117
	assert

	// tests/contracts/cblocks.algo.ts:125
	// assert(118)
	pushint 118
	assert

	// tests/contracts/cblocks.algo.ts:126
	// assert(119)
	pushint 119
	assert

	// tests/contracts/cblocks.algo.ts:127
	// assert(120)
	pushint 120
	assert

	// tests/contracts/cblocks.algo.ts:128
	// assert(121)
	pushint 121
	assert

	// tests/contracts/cblocks.algo.ts:129
	// assert(122)
	pushint 122
	assert

	// tests/contracts/cblocks.algo.ts:130
	// assert(123)
	pushint 123
	assert

	// tests/contracts/cblocks.algo.ts:131
	// assert(124)
	pushint 124
	assert

	// tests/contracts/cblocks.algo.ts:132
	// assert(125)
	pushint 125
	assert

	// tests/contracts/cblocks.algo.ts:133
	// assert(126)
	pushint 126
	assert

	// tests/contracts/cblocks.algo.ts:134
	// assert(127)
	pushint 127
	assert

	// tests/contracts/cblocks.algo.ts:135
	// assert(128)
	pushint 128
	assert

	// tests/contracts/cblocks.algo.ts:136
	// assert(129)
	pushint 129
	assert

	// tests/contracts/cblocks.algo.ts:137
	// assert(130)
	pushint 130
	assert

	// tests/contracts/cblocks.algo.ts:138
	// assert(131)
	pushint 131
	assert

	// tests/contracts/cblocks.algo.ts:139
	// assert(132)
	pushint 132
	assert

	// tests/contracts/cblocks.algo.ts:140
	// assert(133)
	pushint 133
	assert

	// tests/contracts/cblocks.algo.ts:141
	// assert(134)
	pushint 134
	assert

	// tests/contracts/cblocks.algo.ts:142
	// assert(135)
	pushint 135
	assert

	// tests/contracts/cblocks.algo.ts:143
	// assert(136)
	pushint 136
	assert

	// tests/contracts/cblocks.algo.ts:144
	// assert(137)
	pushint 137
	assert

	// tests/contracts/cblocks.algo.ts:145
	// assert(138)
	pushint 138
	assert

	// tests/contracts/cblocks.algo.ts:146
	// assert(139)
	pushint 139
	assert

	// tests/contracts/cblocks.algo.ts:147
	// assert(140)
	pushint 140
	assert

	// tests/contracts/cblocks.algo.ts:148
	// assert(141)
	pushint 141
	assert

	// tests/contracts/cblocks.algo.ts:149
	// assert(142)
	pushint 142
	assert

	// tests/contracts/cblocks.algo.ts:150
	// assert(143)
	pushint 143
	assert

	// tests/contracts/cblocks.algo.ts:151
	// assert(144)
	pushint 144
	assert

	// tests/contracts/cblocks.algo.ts:152
	// assert(145)
	pushint 145
	assert

	// tests/contracts/cblocks.algo.ts:153
	// assert(146)
	pushint 146
	assert

	// tests/contracts/cblocks.algo.ts:154
	// assert(147)
	pushint 147
	assert

	// tests/contracts/cblocks.algo.ts:155
	// assert(148)
	pushint 148
	assert

	// tests/contracts/cblocks.algo.ts:156
	// assert(149)
	pushint 149
	assert

	// tests/contracts/cblocks.algo.ts:157
	// assert(150)
	pushint 150
	assert

	// tests/contracts/cblocks.algo.ts:158
	// assert(151)
	pushint 151
	assert

	// tests/contracts/cblocks.algo.ts:159
	// assert(152)
	pushint 152
	assert

	// tests/contracts/cblocks.algo.ts:160
	// assert(153)
	pushint 153
	assert

	// tests/contracts/cblocks.algo.ts:161
	// assert(154)
	pushint 154
	assert

	// tests/contracts/cblocks.algo.ts:162
	// assert(155)
	pushint 155
	assert

	// tests/contracts/cblocks.algo.ts:163
	// assert(156)
	pushint 156
	assert

	// tests/contracts/cblocks.algo.ts:164
	// assert(157)
	pushint 157
	assert

	// tests/contracts/cblocks.algo.ts:165
	// assert(158)
	pushint 158
	assert

	// tests/contracts/cblocks.algo.ts:166
	// assert(159)
	pushint 159
	assert

	// tests/contracts/cblocks.algo.ts:167
	// assert(160)
	pushint 160
	assert

	// tests/contracts/cblocks.algo.ts:168
	// assert(161)
	pushint 161
	assert

	// tests/contracts/cblocks.algo.ts:169
	// assert(162)
	pushint 162
	assert

	// tests/contracts/cblocks.algo.ts:170
	// assert(163)
	pushint 163
	assert

	// tests/contracts/cblocks.algo.ts:171
	// assert(164)
	pushint 164
	assert

	// tests/contracts/cblocks.algo.ts:172
	// assert(165)
	pushint 165
	assert

	// tests/contracts/cblocks.algo.ts:173
	// assert(166)
	pushint 166
	assert

	// tests/contracts/cblocks.algo.ts:174
	// assert(167)
	pushint 167
	assert

	// tests/contracts/cblocks.algo.ts:175
	// assert(168)
	pushint 168
	assert

	// tests/contracts/cblocks.algo.ts:176
	// assert(169)
	pushint 169
	assert

	// tests/contracts/cblocks.algo.ts:177
	// assert(170)
	pushint 170
	assert

	// tests/contracts/cblocks.algo.ts:178
	// assert(171)
	pushint 171
	assert

	// tests/contracts/cblocks.algo.ts:179
	// assert(172)
	pushint 172
	assert

	// tests/contracts/cblocks.algo.ts:180
	// assert(173)
	pushint 173
	assert

	// tests/contracts/cblocks.algo.ts:181
	// assert(174)
	pushint 174
	assert

	// tests/contracts/cblocks.algo.ts:182
	// assert(175)
	pushint 175
	assert

	// tests/contracts/cblocks.algo.ts:183
	// assert(176)
	pushint 176
	assert

	// tests/contracts/cblocks.algo.ts:184
	// assert(177)
	pushint 177
	assert

	// tests/contracts/cblocks.algo.ts:185
	// assert(178)
	pushint 178
	assert

	// tests/contracts/cblocks.algo.ts:186
	// assert(179)
	pushint 179
	assert

	// tests/contracts/cblocks.algo.ts:187
	// assert(180)
	pushint 180
	assert

	// tests/contracts/cblocks.algo.ts:188
	// assert(181)
	pushint 181
	assert

	// tests/contracts/cblocks.algo.ts:189
	// assert(182)
	pushint 182
	assert

	// tests/contracts/cblocks.algo.ts:190
	// assert(183)
	pushint 183
	assert

	// tests/contracts/cblocks.algo.ts:191
	// assert(184)
	pushint 184
	assert

	// tests/contracts/cblocks.algo.ts:192
	// assert(185)
	pushint 185
	assert

	// tests/contracts/cblocks.algo.ts:193
	// assert(186)
	pushint 186
	assert

	// tests/contracts/cblocks.algo.ts:194
	// assert(187)
	pushint 187
	assert

	// tests/contracts/cblocks.algo.ts:195
	// assert(188)
	pushint 188
	assert

	// tests/contracts/cblocks.algo.ts:196
	// assert(189)
	pushint 189
	assert

	// tests/contracts/cblocks.algo.ts:197
	// assert(190)
	pushint 190
	assert

	// tests/contracts/cblocks.algo.ts:198
	// assert(191)
	pushint 191
	assert

	// tests/contracts/cblocks.algo.ts:199
	// assert(192)
	pushint 192
	assert

	// tests/contracts/cblocks.algo.ts:200
	// assert(193)
	pushint 193
	assert

	// tests/contracts/cblocks.algo.ts:201
	// assert(194)
	pushint 194
	assert

	// tests/contracts/cblocks.algo.ts:202
	// assert(195)
	pushint 195
	assert

	// tests/contracts/cblocks.algo.ts:203
	// assert(196)
	pushint 196
	assert

	// tests/contracts/cblocks.algo.ts:204
	// assert(197)
	pushint 197
	assert

	// tests/contracts/cblocks.algo.ts:205
	// assert(198)
	pushint 198
	assert

	// tests/contracts/cblocks.algo.ts:206
	// assert(199)
	pushint 199
	assert

	// tests/contracts/cblocks.algo.ts:207
	// assert(200)
	pushint 200
	assert

	// tests/contracts/cblocks.algo.ts:208
	// assert(201)
	pushint 201
	assert

	// tests/contracts/cblocks.algo.ts:209
	// assert(202)
	pushint 202
	assert

	// tests/contracts/cblocks.algo.ts:210
	// assert(203)
	pushint 203
	assert

	// tests/contracts/cblocks.algo.ts:211
	// assert(204)
	pushint 204
	assert

	// tests/contracts/cblocks.algo.ts:212
	// assert(205)
	pushint 205
	assert

	// tests/contracts/cblocks.algo.ts:213
	// assert(206)
	pushint 206
	assert

	// tests/contracts/cblocks.algo.ts:214
	// assert(207)
	pushint 207
	assert

	// tests/contracts/cblocks.algo.ts:215
	// assert(208)
	pushint 208
	assert

	// tests/contracts/cblocks.algo.ts:216
	// assert(209)
	pushint 209
	assert

	// tests/contracts/cblocks.algo.ts:217
	// assert(210)
	pushint 210
	assert

	// tests/contracts/cblocks.algo.ts:218
	// assert(211)
	pushint 211
	assert

	// tests/contracts/cblocks.algo.ts:219
	// assert(212)
	pushint 212
	assert

	// tests/contracts/cblocks.algo.ts:220
	// assert(213)
	pushint 213
	assert

	// tests/contracts/cblocks.algo.ts:221
	// assert(214)
	pushint 214
	assert

	// tests/contracts/cblocks.algo.ts:222
	// assert(215)
	pushint 215
	assert

	// tests/contracts/cblocks.algo.ts:223
	// assert(216)
	pushint 216
	assert

	// tests/contracts/cblocks.algo.ts:224
	// assert(217)
	pushint 217
	assert

	// tests/contracts/cblocks.algo.ts:225
	// assert(218)
	pushint 218
	assert

	// tests/contracts/cblocks.algo.ts:226
	// assert(219)
	pushint 219
	assert

	// tests/contracts/cblocks.algo.ts:227
	// assert(220)
	pushint 220
	assert

	// tests/contracts/cblocks.algo.ts:228
	// assert(221)
	pushint 221
	assert

	// tests/contracts/cblocks.algo.ts:229
	// assert(222)
	pushint 222
	assert

	// tests/contracts/cblocks.algo.ts:230
	// assert(223)
	pushint 223
	assert

	// tests/contracts/cblocks.algo.ts:231
	// assert(224)
	pushint 224
	assert

	// tests/contracts/cblocks.algo.ts:232
	// assert(225)
	pushint 225
	assert

	// tests/contracts/cblocks.algo.ts:233
	// assert(226)
	pushint 226
	assert

	// tests/contracts/cblocks.algo.ts:234
	// assert(227)
	pushint 227
	assert

	// tests/contracts/cblocks.algo.ts:235
	// assert(228)
	pushint 228
	assert

	// tests/contracts/cblocks.algo.ts:236
	// assert(229)
	pushint 229
	assert

	// tests/contracts/cblocks.algo.ts:237
	// assert(230)
	pushint 230
	assert

	// tests/contracts/cblocks.algo.ts:238
	// assert(231)
	pushint 231
	assert

	// tests/contracts/cblocks.algo.ts:239
	// assert(232)
	pushint 232
	assert

	// tests/contracts/cblocks.algo.ts:240
	// assert(233)
	pushint 233
	assert

	// tests/contracts/cblocks.algo.ts:241
	// assert(234)
	pushint 234
	assert

	// tests/contracts/cblocks.algo.ts:242
	// assert(235)
	pushint 235
	assert

	// tests/contracts/cblocks.algo.ts:243
	// assert(236)
	pushint 236
	assert

	// tests/contracts/cblocks.algo.ts:244
	// assert(237)
	pushint 237
	assert

	// tests/contracts/cblocks.algo.ts:245
	// assert(238)
	pushint 238
	assert

	// tests/contracts/cblocks.algo.ts:246
	// assert(239)
	pushint 239
	assert

	// tests/contracts/cblocks.algo.ts:247
	// assert(240)
	pushint 240
	assert

	// tests/contracts/cblocks.algo.ts:248
	// assert(241)
	pushint 241
	assert

	// tests/contracts/cblocks.algo.ts:249
	// assert(242)
	pushint 242
	assert

	// tests/contracts/cblocks.algo.ts:250
	// assert(243)
	pushint 243
	assert

	// tests/contracts/cblocks.algo.ts:251
	// assert(244)
	pushint 244
	assert

	// tests/contracts/cblocks.algo.ts:252
	// assert(245)
	pushint 245
	assert

	// tests/contracts/cblocks.algo.ts:253
	// assert(246)
	pushint 246
	assert

	// tests/contracts/cblocks.algo.ts:254
	// assert(247)
	pushint 247
	assert

	// tests/contracts/cblocks.algo.ts:255
	// assert(248)
	pushint 248
	assert

	// tests/contracts/cblocks.algo.ts:256
	// assert(249)
	pushint 249
	assert

	// tests/contracts/cblocks.algo.ts:257
	// assert(250)
	pushint 250
	assert

	// tests/contracts/cblocks.algo.ts:258
	// assert(251)
	pushint 251
	assert

	// tests/contracts/cblocks.algo.ts:259
	// assert(252)
	pushint 252
	assert

	// tests/contracts/cblocks.algo.ts:260
	// assert(253)
	pushint 253
	assert

	// tests/contracts/cblocks.algo.ts:261
	// assert(254)
	pushint 254
	assert

	// tests/contracts/cblocks.algo.ts:262
	// assert(255)
	pushint 255
	assert

	// tests/contracts/cblocks.algo.ts:263
	// assert(256)
	pushint 256
	assert

	// tests/contracts/cblocks.algo.ts:266
	// return a + b;
	pushint 258
	retsub

*abi_route_createApplication:
	pushint 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0xd14e61db // method "largeIntcblock()uint64"
	txna ApplicationArgs 0
	match *abi_route_largeIntcblock

	// this contract does not implement the given ABI method for call NoOp
	err", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ItxnsTest.approval.teal b/tests/contracts/artifacts/ItxnsTest.approval.teal index 2887b4d58..7a87d9712 100644 --- a/tests/contracts/artifacts/ItxnsTest.approval.teal +++ b/tests/contracts/artifacts/ItxnsTest.approval.teal @@ -2,7 +2,7 @@ intcblock 1 0 bytecblock 0x6161616161616161616161616161616161616161616161616161616161616161 0x151f7c75 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ItxnsTest.arc32.json b/tests/contracts/artifacts/ItxnsTest.arc32.json index f559c0f55..da5cbb728 100644 --- a/tests/contracts/artifacts/ItxnsTest.arc32.json +++ b/tests/contracts/artifacts/ItxnsTest.arc32.json @@ -84,7 +84,7 @@ } }, "source": { - "approval": "#pragma version 10
intcblock 1 0
bytecblock 0x6161616161616161616161616161616161616161616161616161616161616161 0x151f7c75

// This TEAL was generated by TEALScript v0.104.1
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// payment()void
*abi_route_payment:
	// execute payment()void
	callsub payment
	int 1
	return

// payment(): void
payment:
	proto 0 0

	// tests/contracts/itxns.algo.ts:6
	// sendPayment({
	//       amount: 100,
	//       receiver: this.app.address,
	//       closeRemainderTo: globals.zeroAddress,
	//       sender: this.app.address,
	//       rekeyTo: globals.zeroAddress,
	//       note: 'Hello World!',
	//     })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// tests/contracts/itxns.algo.ts:7
	// amount: 100
	pushint 100
	itxn_field Amount

	// tests/contracts/itxns.algo.ts:8
	// receiver: this.app.address
	global CurrentApplicationAddress
	itxn_field Receiver

	// tests/contracts/itxns.algo.ts:9
	// closeRemainderTo: globals.zeroAddress
	global ZeroAddress
	itxn_field CloseRemainderTo

	// tests/contracts/itxns.algo.ts:10
	// sender: this.app.address
	global CurrentApplicationAddress
	itxn_field Sender

	// tests/contracts/itxns.algo.ts:11
	// rekeyTo: globals.zeroAddress
	global ZeroAddress
	itxn_field RekeyTo

	// tests/contracts/itxns.algo.ts:12
	// note: 'Hello World!'
	pushbytes 0x48656c6c6f20576f726c6421 // "Hello World!"
	itxn_field Note

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// assetCreation()uint64
*abi_route_assetCreation:
	// The ABI return prefix
	byte 0x151f7c75

	// execute assetCreation()uint64
	callsub assetCreation
	itob
	concat
	log
	int 1
	return

// assetCreation(): AssetID
assetCreation:
	proto 0 1

	// tests/contracts/itxns.algo.ts:17
	// return sendAssetCreation({
	//       configAssetName: 'name',
	//       configAssetUnitName: 'unit',
	//       configAssetTotal: 1,
	//       configAssetManager: this.app.address,
	//       configAssetReserve: this.app.address,
	//       configAssetFreeze: this.app.address,
	//       configAssetClawback: this.app.address,
	//       configAssetDefaultFrozen: 0,
	//       configAssetURL: 'url',
	//       configAssetMetadataHash: 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa',
	//     });
	itxn_begin
	pushint 3 // acfg
	itxn_field TypeEnum

	// tests/contracts/itxns.algo.ts:18
	// configAssetName: 'name'
	pushbytes 0x6e616d65 // "name"
	itxn_field ConfigAssetName

	// tests/contracts/itxns.algo.ts:19
	// configAssetUnitName: 'unit'
	pushbytes 0x756e6974 // "unit"
	itxn_field ConfigAssetUnitName

	// tests/contracts/itxns.algo.ts:20
	// configAssetTotal: 1
	int 1
	itxn_field ConfigAssetTotal

	// tests/contracts/itxns.algo.ts:21
	// configAssetManager: this.app.address
	global CurrentApplicationAddress
	itxn_field ConfigAssetManager

	// tests/contracts/itxns.algo.ts:22
	// configAssetReserve: this.app.address
	global CurrentApplicationAddress
	itxn_field ConfigAssetReserve

	// tests/contracts/itxns.algo.ts:23
	// configAssetFreeze: this.app.address
	global CurrentApplicationAddress
	itxn_field ConfigAssetFreeze

	// tests/contracts/itxns.algo.ts:24
	// configAssetClawback: this.app.address
	global CurrentApplicationAddress
	itxn_field ConfigAssetClawback

	// tests/contracts/itxns.algo.ts:25
	// configAssetDefaultFrozen: 0
	int 0
	itxn_field ConfigAssetDefaultFrozen

	// tests/contracts/itxns.algo.ts:26
	// configAssetURL: 'url'
	pushbytes 0x75726c // "url"
	itxn_field ConfigAssetURL

	// tests/contracts/itxns.algo.ts:27
	// configAssetMetadataHash: 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa'
	byte 0x6161616161616161616161616161616161616161616161616161616161616161 // "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
	itxn_field ConfigAssetMetadataHash

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn CreatedAssetID
	retsub

// appCall()void
*abi_route_appCall:
	// execute appCall()void
	callsub appCall
	int 1
	return

// appCall(): void
appCall:
	proto 0 0

	// tests/contracts/itxns.algo.ts:32
	// sendAppCall({
	//       accounts: [this.app.address],
	//       applicationArgs: ['arg1', 'arg2'],
	//       applicationID: this.app,
	//       applications: [this.app],
	//       approvalProgram: 'approval',
	//       assets: [AssetID.zeroIndex],
	//       clearStateProgram: 'clear',
	//       globalNumByteSlice: 1,
	//       globalNumUint: 1,
	//       localNumByteSlice: 1,
	//       localNumUint: 1,
	//       note: 'note',
	//     })
	itxn_begin
	pushint 6 // appl
	itxn_field TypeEnum

	// tests/contracts/itxns.algo.ts:33
	// accounts: [this.app.address]
	global CurrentApplicationAddress
	itxn_field Accounts

	// tests/contracts/itxns.algo.ts:34
	// applicationArgs: ['arg1', 'arg2']
	pushbytes 0x61726731 // "arg1"
	itxn_field ApplicationArgs
	pushbytes 0x61726732 // "arg2"
	itxn_field ApplicationArgs

	// tests/contracts/itxns.algo.ts:35
	// applicationID: this.app
	txna Applications 0
	itxn_field ApplicationID

	// tests/contracts/itxns.algo.ts:36
	// applications: [this.app]
	txna Applications 0
	itxn_field Applications

	// tests/contracts/itxns.algo.ts:37
	// approvalProgram: 'approval'
	pushbytes 0x617070726f76616c // "approval"
	itxn_field ApprovalProgram

	// tests/contracts/itxns.algo.ts:38
	// assets: [AssetID.zeroIndex]
	int 0
	itxn_field Assets

	// tests/contracts/itxns.algo.ts:39
	// clearStateProgram: 'clear'
	pushbytes 0x636c656172 // "clear"
	itxn_field ClearStateProgram

	// tests/contracts/itxns.algo.ts:40
	// globalNumByteSlice: 1
	int 1
	itxn_field GlobalNumByteSlice

	// tests/contracts/itxns.algo.ts:41
	// globalNumUint: 1
	int 1
	itxn_field GlobalNumUint

	// tests/contracts/itxns.algo.ts:42
	// localNumByteSlice: 1
	int 1
	itxn_field LocalNumByteSlice

	// tests/contracts/itxns.algo.ts:43
	// localNumUint: 1
	int 1
	itxn_field LocalNumUint

	// tests/contracts/itxns.algo.ts:44
	// note: 'note'
	pushbytes 0x6e6f7465 // "note"
	itxn_field Note

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// assetConfig()void
*abi_route_assetConfig:
	// execute assetConfig()void
	callsub assetConfig
	int 1
	return

// assetConfig(): void
assetConfig:
	proto 0 0

	// tests/contracts/itxns.algo.ts:49
	// sendAssetConfig({
	//       configAsset: AssetID.zeroIndex,
	//       configAssetManager: this.app.address,
	//       configAssetReserve: this.app.address,
	//       configAssetFreeze: this.app.address,
	//       configAssetClawback: this.app.address,
	//     })
	itxn_begin
	pushint 3 // acfg
	itxn_field TypeEnum

	// tests/contracts/itxns.algo.ts:50
	// configAsset: AssetID.zeroIndex
	int 0
	itxn_field ConfigAsset

	// tests/contracts/itxns.algo.ts:51
	// configAssetManager: this.app.address
	global CurrentApplicationAddress
	itxn_field ConfigAssetManager

	// tests/contracts/itxns.algo.ts:52
	// configAssetReserve: this.app.address
	global CurrentApplicationAddress
	itxn_field ConfigAssetReserve

	// tests/contracts/itxns.algo.ts:53
	// configAssetFreeze: this.app.address
	global CurrentApplicationAddress
	itxn_field ConfigAssetFreeze

	// tests/contracts/itxns.algo.ts:54
	// configAssetClawback: this.app.address
	global CurrentApplicationAddress
	itxn_field ConfigAssetClawback

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// assetFreeze()void
*abi_route_assetFreeze:
	// execute assetFreeze()void
	callsub assetFreeze
	int 1
	return

// assetFreeze(): void
assetFreeze:
	proto 0 0

	// tests/contracts/itxns.algo.ts:59
	// sendAssetFreeze({
	//       freezeAssetFrozen: true,
	//       freezeAssetAccount: this.app.address,
	//       freezeAsset: AssetID.zeroIndex,
	//     })
	itxn_begin
	pushint 5 // afrz
	itxn_field TypeEnum

	// tests/contracts/itxns.algo.ts:60
	// freezeAssetFrozen: true
	int 1
	itxn_field FreezeAssetFrozen

	// tests/contracts/itxns.algo.ts:61
	// freezeAssetAccount: this.app.address
	global CurrentApplicationAddress
	itxn_field FreezeAssetAccount

	// tests/contracts/itxns.algo.ts:62
	// freezeAsset: AssetID.zeroIndex
	int 0
	itxn_field FreezeAsset

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// assetTransfer()void
*abi_route_assetTransfer:
	// execute assetTransfer()void
	callsub assetTransfer
	int 1
	return

// assetTransfer(): void
assetTransfer:
	proto 0 0

	// tests/contracts/itxns.algo.ts:67
	// sendAssetTransfer({
	//       assetAmount: 1,
	//       assetCloseTo: this.app.address,
	//       assetReceiver: this.app.address,
	//       assetSender: this.app.address,
	//       xferAsset: AssetID.zeroIndex,
	//     })
	itxn_begin
	pushint 4 // axfer
	itxn_field TypeEnum

	// tests/contracts/itxns.algo.ts:68
	// assetAmount: 1
	int 1
	itxn_field AssetAmount

	// tests/contracts/itxns.algo.ts:69
	// assetCloseTo: this.app.address
	global CurrentApplicationAddress
	itxn_field AssetCloseTo

	// tests/contracts/itxns.algo.ts:70
	// assetReceiver: this.app.address
	global CurrentApplicationAddress
	itxn_field AssetReceiver

	// tests/contracts/itxns.algo.ts:71
	// assetSender: this.app.address
	global CurrentApplicationAddress
	itxn_field AssetSender

	// tests/contracts/itxns.algo.ts:72
	// xferAsset: AssetID.zeroIndex
	int 0
	itxn_field XferAsset

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// methodCall()uint64
*abi_route_methodCall:
	// The ABI return prefix
	byte 0x151f7c75

	// execute methodCall()uint64
	callsub methodCall
	itob
	concat
	log
	int 1
	return

// methodCall(): AssetID
methodCall:
	proto 0 1

	// tests/contracts/itxns.algo.ts:77
	// return sendMethodCall<[AppID, AssetID], AssetID>({
	//       name: 'method',
	//       methodArgs: [this.app, AssetID.zeroIndex],
	//     });
	itxn_begin
	pushint 6 // appl
	itxn_field TypeEnum
	pushbytes 0xa66d559c // method "method(uint64,uint64)uint64"
	itxn_field ApplicationArgs

	// tests/contracts/itxns.algo.ts:79
	// methodArgs: [this.app, AssetID.zeroIndex]
	txna Applications 0
	itob
	itxn_field ApplicationArgs
	pushbytes 0x0000000000000000
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0
	btoi
	retsub

// onlineKeyRegistration()void
*abi_route_onlineKeyRegistration:
	// execute onlineKeyRegistration()void
	callsub onlineKeyRegistration
	int 1
	return

// onlineKeyRegistration(): void
onlineKeyRegistration:
	proto 0 0

	// tests/contracts/itxns.algo.ts:84
	// sendOnlineKeyRegistration({
	//       selectionPK: 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa',
	//       stateProofPK: 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa',
	//       voteFirst: 1,
	//       voteKeyDilution: 1,
	//       voteLast: 1,
	//       votePK: 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa',
	//     })
	itxn_begin
	pushint 2 // keyreg
	itxn_field TypeEnum

	// tests/contracts/itxns.algo.ts:85
	// selectionPK: 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa'
	byte 0x6161616161616161616161616161616161616161616161616161616161616161 // "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
	itxn_field SelectionPK

	// tests/contracts/itxns.algo.ts:86
	// stateProofPK: 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa'
	byte 0x6161616161616161616161616161616161616161616161616161616161616161 // "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
	itxn_field StateProofPK

	// tests/contracts/itxns.algo.ts:87
	// voteFirst: 1
	int 1
	itxn_field VoteFirst

	// tests/contracts/itxns.algo.ts:88
	// voteKeyDilution: 1
	int 1
	itxn_field VoteKeyDilution

	// tests/contracts/itxns.algo.ts:89
	// voteLast: 1
	int 1
	itxn_field VoteLast

	// tests/contracts/itxns.algo.ts:90
	// votePK: 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa'
	byte 0x6161616161616161616161616161616161616161616161616161616161616161 // "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
	itxn_field VotePK

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// offlineKeyRegistration()void
*abi_route_offlineKeyRegistration:
	// execute offlineKeyRegistration()void
	callsub offlineKeyRegistration
	int 1
	return

// offlineKeyRegistration(): void
offlineKeyRegistration:
	proto 0 0

	// tests/contracts/itxns.algo.ts:95
	// sendOfflineKeyRegistration({})
	itxn_begin
	pushint 2 // keyreg
	itxn_field TypeEnum

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// innerGeneric()void
*abi_route_innerGeneric:
	// execute innerGeneric()void
	callsub innerGeneric
	int 1
	return

// innerGeneric(): void
innerGeneric:
	proto 0 0

	// tests/contracts/itxns.algo.ts:99
	// sendMethodCall<[InnerTxn<InnerAssetCreation>], void>({
	//       name: 'foo',
	//       methodArgs: [{ configAssetTotal: 1 }],
	//     })
	itxn_begin
	pushint 3 // acfg
	itxn_field TypeEnum

	// tests/contracts/itxns.algo.ts:101
	// configAssetTotal: 1
	int 1
	itxn_field ConfigAssetTotal

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee
	itxn_next
	pushint 6 // appl
	itxn_field TypeEnum
	pushbytes 0x090924e8 // method "foo(txn)void"
	itxn_field ApplicationArgs

	// tests/contracts/itxns.algo.ts:101
	// methodArgs: [{ configAssetTotal: 1 }]
	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

*abi_route_createApplication:
	int 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x7a2ecb1c // method "payment()void"
	pushbytes 0xdf9b38ad // method "assetCreation()uint64"
	pushbytes 0x690ce8b6 // method "appCall()void"
	pushbytes 0x8f310534 // method "assetConfig()void"
	pushbytes 0xf834bee8 // method "assetFreeze()void"
	pushbytes 0x1f4418b7 // method "assetTransfer()void"
	pushbytes 0x70adfa23 // method "methodCall()uint64"
	pushbytes 0xe6ec46fc // method "onlineKeyRegistration()void"
	pushbytes 0x1172301a // method "offlineKeyRegistration()void"
	pushbytes 0x7a33897d // method "innerGeneric()void"
	txna ApplicationArgs 0
	match *abi_route_payment *abi_route_assetCreation *abi_route_appCall *abi_route_assetConfig *abi_route_assetFreeze *abi_route_assetTransfer *abi_route_methodCall *abi_route_onlineKeyRegistration *abi_route_offlineKeyRegistration *abi_route_innerGeneric

	// this contract does not implement the given ABI method for call NoOp
	err", + "approval": "#pragma version 10
intcblock 1 0
bytecblock 0x6161616161616161616161616161616161616161616161616161616161616161 0x151f7c75

// This TEAL was generated by TEALScript v0.105.0
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// payment()void
*abi_route_payment:
	// execute payment()void
	callsub payment
	int 1
	return

// payment(): void
payment:
	proto 0 0

	// tests/contracts/itxns.algo.ts:6
	// sendPayment({
	//       amount: 100,
	//       receiver: this.app.address,
	//       closeRemainderTo: globals.zeroAddress,
	//       sender: this.app.address,
	//       rekeyTo: globals.zeroAddress,
	//       note: 'Hello World!',
	//     })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// tests/contracts/itxns.algo.ts:7
	// amount: 100
	pushint 100
	itxn_field Amount

	// tests/contracts/itxns.algo.ts:8
	// receiver: this.app.address
	global CurrentApplicationAddress
	itxn_field Receiver

	// tests/contracts/itxns.algo.ts:9
	// closeRemainderTo: globals.zeroAddress
	global ZeroAddress
	itxn_field CloseRemainderTo

	// tests/contracts/itxns.algo.ts:10
	// sender: this.app.address
	global CurrentApplicationAddress
	itxn_field Sender

	// tests/contracts/itxns.algo.ts:11
	// rekeyTo: globals.zeroAddress
	global ZeroAddress
	itxn_field RekeyTo

	// tests/contracts/itxns.algo.ts:12
	// note: 'Hello World!'
	pushbytes 0x48656c6c6f20576f726c6421 // "Hello World!"
	itxn_field Note

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// assetCreation()uint64
*abi_route_assetCreation:
	// The ABI return prefix
	byte 0x151f7c75

	// execute assetCreation()uint64
	callsub assetCreation
	itob
	concat
	log
	int 1
	return

// assetCreation(): AssetID
assetCreation:
	proto 0 1

	// tests/contracts/itxns.algo.ts:17
	// return sendAssetCreation({
	//       configAssetName: 'name',
	//       configAssetUnitName: 'unit',
	//       configAssetTotal: 1,
	//       configAssetManager: this.app.address,
	//       configAssetReserve: this.app.address,
	//       configAssetFreeze: this.app.address,
	//       configAssetClawback: this.app.address,
	//       configAssetDefaultFrozen: 0,
	//       configAssetURL: 'url',
	//       configAssetMetadataHash: 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa',
	//     });
	itxn_begin
	pushint 3 // acfg
	itxn_field TypeEnum

	// tests/contracts/itxns.algo.ts:18
	// configAssetName: 'name'
	pushbytes 0x6e616d65 // "name"
	itxn_field ConfigAssetName

	// tests/contracts/itxns.algo.ts:19
	// configAssetUnitName: 'unit'
	pushbytes 0x756e6974 // "unit"
	itxn_field ConfigAssetUnitName

	// tests/contracts/itxns.algo.ts:20
	// configAssetTotal: 1
	int 1
	itxn_field ConfigAssetTotal

	// tests/contracts/itxns.algo.ts:21
	// configAssetManager: this.app.address
	global CurrentApplicationAddress
	itxn_field ConfigAssetManager

	// tests/contracts/itxns.algo.ts:22
	// configAssetReserve: this.app.address
	global CurrentApplicationAddress
	itxn_field ConfigAssetReserve

	// tests/contracts/itxns.algo.ts:23
	// configAssetFreeze: this.app.address
	global CurrentApplicationAddress
	itxn_field ConfigAssetFreeze

	// tests/contracts/itxns.algo.ts:24
	// configAssetClawback: this.app.address
	global CurrentApplicationAddress
	itxn_field ConfigAssetClawback

	// tests/contracts/itxns.algo.ts:25
	// configAssetDefaultFrozen: 0
	int 0
	itxn_field ConfigAssetDefaultFrozen

	// tests/contracts/itxns.algo.ts:26
	// configAssetURL: 'url'
	pushbytes 0x75726c // "url"
	itxn_field ConfigAssetURL

	// tests/contracts/itxns.algo.ts:27
	// configAssetMetadataHash: 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa'
	byte 0x6161616161616161616161616161616161616161616161616161616161616161 // "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
	itxn_field ConfigAssetMetadataHash

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn CreatedAssetID
	retsub

// appCall()void
*abi_route_appCall:
	// execute appCall()void
	callsub appCall
	int 1
	return

// appCall(): void
appCall:
	proto 0 0

	// tests/contracts/itxns.algo.ts:32
	// sendAppCall({
	//       accounts: [this.app.address],
	//       applicationArgs: ['arg1', 'arg2'],
	//       applicationID: this.app,
	//       applications: [this.app],
	//       approvalProgram: 'approval',
	//       assets: [AssetID.zeroIndex],
	//       clearStateProgram: 'clear',
	//       globalNumByteSlice: 1,
	//       globalNumUint: 1,
	//       localNumByteSlice: 1,
	//       localNumUint: 1,
	//       note: 'note',
	//     })
	itxn_begin
	pushint 6 // appl
	itxn_field TypeEnum

	// tests/contracts/itxns.algo.ts:33
	// accounts: [this.app.address]
	global CurrentApplicationAddress
	itxn_field Accounts

	// tests/contracts/itxns.algo.ts:34
	// applicationArgs: ['arg1', 'arg2']
	pushbytes 0x61726731 // "arg1"
	itxn_field ApplicationArgs
	pushbytes 0x61726732 // "arg2"
	itxn_field ApplicationArgs

	// tests/contracts/itxns.algo.ts:35
	// applicationID: this.app
	txna Applications 0
	itxn_field ApplicationID

	// tests/contracts/itxns.algo.ts:36
	// applications: [this.app]
	txna Applications 0
	itxn_field Applications

	// tests/contracts/itxns.algo.ts:37
	// approvalProgram: 'approval'
	pushbytes 0x617070726f76616c // "approval"
	itxn_field ApprovalProgram

	// tests/contracts/itxns.algo.ts:38
	// assets: [AssetID.zeroIndex]
	int 0
	itxn_field Assets

	// tests/contracts/itxns.algo.ts:39
	// clearStateProgram: 'clear'
	pushbytes 0x636c656172 // "clear"
	itxn_field ClearStateProgram

	// tests/contracts/itxns.algo.ts:40
	// globalNumByteSlice: 1
	int 1
	itxn_field GlobalNumByteSlice

	// tests/contracts/itxns.algo.ts:41
	// globalNumUint: 1
	int 1
	itxn_field GlobalNumUint

	// tests/contracts/itxns.algo.ts:42
	// localNumByteSlice: 1
	int 1
	itxn_field LocalNumByteSlice

	// tests/contracts/itxns.algo.ts:43
	// localNumUint: 1
	int 1
	itxn_field LocalNumUint

	// tests/contracts/itxns.algo.ts:44
	// note: 'note'
	pushbytes 0x6e6f7465 // "note"
	itxn_field Note

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// assetConfig()void
*abi_route_assetConfig:
	// execute assetConfig()void
	callsub assetConfig
	int 1
	return

// assetConfig(): void
assetConfig:
	proto 0 0

	// tests/contracts/itxns.algo.ts:49
	// sendAssetConfig({
	//       configAsset: AssetID.zeroIndex,
	//       configAssetManager: this.app.address,
	//       configAssetReserve: this.app.address,
	//       configAssetFreeze: this.app.address,
	//       configAssetClawback: this.app.address,
	//     })
	itxn_begin
	pushint 3 // acfg
	itxn_field TypeEnum

	// tests/contracts/itxns.algo.ts:50
	// configAsset: AssetID.zeroIndex
	int 0
	itxn_field ConfigAsset

	// tests/contracts/itxns.algo.ts:51
	// configAssetManager: this.app.address
	global CurrentApplicationAddress
	itxn_field ConfigAssetManager

	// tests/contracts/itxns.algo.ts:52
	// configAssetReserve: this.app.address
	global CurrentApplicationAddress
	itxn_field ConfigAssetReserve

	// tests/contracts/itxns.algo.ts:53
	// configAssetFreeze: this.app.address
	global CurrentApplicationAddress
	itxn_field ConfigAssetFreeze

	// tests/contracts/itxns.algo.ts:54
	// configAssetClawback: this.app.address
	global CurrentApplicationAddress
	itxn_field ConfigAssetClawback

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// assetFreeze()void
*abi_route_assetFreeze:
	// execute assetFreeze()void
	callsub assetFreeze
	int 1
	return

// assetFreeze(): void
assetFreeze:
	proto 0 0

	// tests/contracts/itxns.algo.ts:59
	// sendAssetFreeze({
	//       freezeAssetFrozen: true,
	//       freezeAssetAccount: this.app.address,
	//       freezeAsset: AssetID.zeroIndex,
	//     })
	itxn_begin
	pushint 5 // afrz
	itxn_field TypeEnum

	// tests/contracts/itxns.algo.ts:60
	// freezeAssetFrozen: true
	int 1
	itxn_field FreezeAssetFrozen

	// tests/contracts/itxns.algo.ts:61
	// freezeAssetAccount: this.app.address
	global CurrentApplicationAddress
	itxn_field FreezeAssetAccount

	// tests/contracts/itxns.algo.ts:62
	// freezeAsset: AssetID.zeroIndex
	int 0
	itxn_field FreezeAsset

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// assetTransfer()void
*abi_route_assetTransfer:
	// execute assetTransfer()void
	callsub assetTransfer
	int 1
	return

// assetTransfer(): void
assetTransfer:
	proto 0 0

	// tests/contracts/itxns.algo.ts:67
	// sendAssetTransfer({
	//       assetAmount: 1,
	//       assetCloseTo: this.app.address,
	//       assetReceiver: this.app.address,
	//       assetSender: this.app.address,
	//       xferAsset: AssetID.zeroIndex,
	//     })
	itxn_begin
	pushint 4 // axfer
	itxn_field TypeEnum

	// tests/contracts/itxns.algo.ts:68
	// assetAmount: 1
	int 1
	itxn_field AssetAmount

	// tests/contracts/itxns.algo.ts:69
	// assetCloseTo: this.app.address
	global CurrentApplicationAddress
	itxn_field AssetCloseTo

	// tests/contracts/itxns.algo.ts:70
	// assetReceiver: this.app.address
	global CurrentApplicationAddress
	itxn_field AssetReceiver

	// tests/contracts/itxns.algo.ts:71
	// assetSender: this.app.address
	global CurrentApplicationAddress
	itxn_field AssetSender

	// tests/contracts/itxns.algo.ts:72
	// xferAsset: AssetID.zeroIndex
	int 0
	itxn_field XferAsset

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// methodCall()uint64
*abi_route_methodCall:
	// The ABI return prefix
	byte 0x151f7c75

	// execute methodCall()uint64
	callsub methodCall
	itob
	concat
	log
	int 1
	return

// methodCall(): AssetID
methodCall:
	proto 0 1

	// tests/contracts/itxns.algo.ts:77
	// return sendMethodCall<[AppID, AssetID], AssetID>({
	//       name: 'method',
	//       methodArgs: [this.app, AssetID.zeroIndex],
	//     });
	itxn_begin
	pushint 6 // appl
	itxn_field TypeEnum
	pushbytes 0xa66d559c // method "method(uint64,uint64)uint64"
	itxn_field ApplicationArgs

	// tests/contracts/itxns.algo.ts:79
	// methodArgs: [this.app, AssetID.zeroIndex]
	txna Applications 0
	itob
	itxn_field ApplicationArgs
	pushbytes 0x0000000000000000
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0
	btoi
	retsub

// onlineKeyRegistration()void
*abi_route_onlineKeyRegistration:
	// execute onlineKeyRegistration()void
	callsub onlineKeyRegistration
	int 1
	return

// onlineKeyRegistration(): void
onlineKeyRegistration:
	proto 0 0

	// tests/contracts/itxns.algo.ts:84
	// sendOnlineKeyRegistration({
	//       selectionPK: 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa',
	//       stateProofPK: 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa',
	//       voteFirst: 1,
	//       voteKeyDilution: 1,
	//       voteLast: 1,
	//       votePK: 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa',
	//     })
	itxn_begin
	pushint 2 // keyreg
	itxn_field TypeEnum

	// tests/contracts/itxns.algo.ts:85
	// selectionPK: 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa'
	byte 0x6161616161616161616161616161616161616161616161616161616161616161 // "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
	itxn_field SelectionPK

	// tests/contracts/itxns.algo.ts:86
	// stateProofPK: 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa'
	byte 0x6161616161616161616161616161616161616161616161616161616161616161 // "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
	itxn_field StateProofPK

	// tests/contracts/itxns.algo.ts:87
	// voteFirst: 1
	int 1
	itxn_field VoteFirst

	// tests/contracts/itxns.algo.ts:88
	// voteKeyDilution: 1
	int 1
	itxn_field VoteKeyDilution

	// tests/contracts/itxns.algo.ts:89
	// voteLast: 1
	int 1
	itxn_field VoteLast

	// tests/contracts/itxns.algo.ts:90
	// votePK: 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa'
	byte 0x6161616161616161616161616161616161616161616161616161616161616161 // "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
	itxn_field VotePK

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// offlineKeyRegistration()void
*abi_route_offlineKeyRegistration:
	// execute offlineKeyRegistration()void
	callsub offlineKeyRegistration
	int 1
	return

// offlineKeyRegistration(): void
offlineKeyRegistration:
	proto 0 0

	// tests/contracts/itxns.algo.ts:95
	// sendOfflineKeyRegistration({})
	itxn_begin
	pushint 2 // keyreg
	itxn_field TypeEnum

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// innerGeneric()void
*abi_route_innerGeneric:
	// execute innerGeneric()void
	callsub innerGeneric
	int 1
	return

// innerGeneric(): void
innerGeneric:
	proto 0 0

	// tests/contracts/itxns.algo.ts:99
	// sendMethodCall<[InnerTxn<InnerAssetCreation>], void>({
	//       name: 'foo',
	//       methodArgs: [{ configAssetTotal: 1 }],
	//     })
	itxn_begin
	pushint 3 // acfg
	itxn_field TypeEnum

	// tests/contracts/itxns.algo.ts:101
	// configAssetTotal: 1
	int 1
	itxn_field ConfigAssetTotal

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee
	itxn_next
	pushint 6 // appl
	itxn_field TypeEnum
	pushbytes 0x090924e8 // method "foo(txn)void"
	itxn_field ApplicationArgs

	// tests/contracts/itxns.algo.ts:101
	// methodArgs: [{ configAssetTotal: 1 }]
	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

*abi_route_createApplication:
	int 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x7a2ecb1c // method "payment()void"
	pushbytes 0xdf9b38ad // method "assetCreation()uint64"
	pushbytes 0x690ce8b6 // method "appCall()void"
	pushbytes 0x8f310534 // method "assetConfig()void"
	pushbytes 0xf834bee8 // method "assetFreeze()void"
	pushbytes 0x1f4418b7 // method "assetTransfer()void"
	pushbytes 0x70adfa23 // method "methodCall()uint64"
	pushbytes 0xe6ec46fc // method "onlineKeyRegistration()void"
	pushbytes 0x1172301a // method "offlineKeyRegistration()void"
	pushbytes 0x7a33897d // method "innerGeneric()void"
	txna ApplicationArgs 0
	match *abi_route_payment *abi_route_assetCreation *abi_route_appCall *abi_route_assetConfig *abi_route_assetFreeze *abi_route_assetTransfer *abi_route_methodCall *abi_route_onlineKeyRegistration *abi_route_offlineKeyRegistration *abi_route_innerGeneric

	// this contract does not implement the given ABI method for call NoOp
	err", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/ItxnsTest.arc56_draft.json b/tests/contracts/artifacts/ItxnsTest.arc56_draft.json index 523349628..26800d268 100644 --- a/tests/contracts/artifacts/ItxnsTest.arc56_draft.json +++ b/tests/contracts/artifacts/ItxnsTest.arc56_draft.json @@ -2626,7 +2626,7 @@ } }, "source": { - "approval": "#pragma version 10
intcblock 1 0
bytecblock 0x6161616161616161616161616161616161616161616161616161616161616161 0x151f7c75

// This TEAL was generated by TEALScript v0.104.1
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// payment()void
*abi_route_payment:
	// execute payment()void
	callsub payment
	int 1
	return

// payment(): void
payment:
	proto 0 0

	// tests/contracts/itxns.algo.ts:6
	// sendPayment({
	//       amount: 100,
	//       receiver: this.app.address,
	//       closeRemainderTo: globals.zeroAddress,
	//       sender: this.app.address,
	//       rekeyTo: globals.zeroAddress,
	//       note: 'Hello World!',
	//     })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// tests/contracts/itxns.algo.ts:7
	// amount: 100
	pushint 100
	itxn_field Amount

	// tests/contracts/itxns.algo.ts:8
	// receiver: this.app.address
	global CurrentApplicationAddress
	itxn_field Receiver

	// tests/contracts/itxns.algo.ts:9
	// closeRemainderTo: globals.zeroAddress
	global ZeroAddress
	itxn_field CloseRemainderTo

	// tests/contracts/itxns.algo.ts:10
	// sender: this.app.address
	global CurrentApplicationAddress
	itxn_field Sender

	// tests/contracts/itxns.algo.ts:11
	// rekeyTo: globals.zeroAddress
	global ZeroAddress
	itxn_field RekeyTo

	// tests/contracts/itxns.algo.ts:12
	// note: 'Hello World!'
	pushbytes 0x48656c6c6f20576f726c6421 // "Hello World!"
	itxn_field Note

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// assetCreation()uint64
*abi_route_assetCreation:
	// The ABI return prefix
	byte 0x151f7c75

	// execute assetCreation()uint64
	callsub assetCreation
	itob
	concat
	log
	int 1
	return

// assetCreation(): AssetID
assetCreation:
	proto 0 1

	// tests/contracts/itxns.algo.ts:17
	// return sendAssetCreation({
	//       configAssetName: 'name',
	//       configAssetUnitName: 'unit',
	//       configAssetTotal: 1,
	//       configAssetManager: this.app.address,
	//       configAssetReserve: this.app.address,
	//       configAssetFreeze: this.app.address,
	//       configAssetClawback: this.app.address,
	//       configAssetDefaultFrozen: 0,
	//       configAssetURL: 'url',
	//       configAssetMetadataHash: 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa',
	//     });
	itxn_begin
	pushint 3 // acfg
	itxn_field TypeEnum

	// tests/contracts/itxns.algo.ts:18
	// configAssetName: 'name'
	pushbytes 0x6e616d65 // "name"
	itxn_field ConfigAssetName

	// tests/contracts/itxns.algo.ts:19
	// configAssetUnitName: 'unit'
	pushbytes 0x756e6974 // "unit"
	itxn_field ConfigAssetUnitName

	// tests/contracts/itxns.algo.ts:20
	// configAssetTotal: 1
	int 1
	itxn_field ConfigAssetTotal

	// tests/contracts/itxns.algo.ts:21
	// configAssetManager: this.app.address
	global CurrentApplicationAddress
	itxn_field ConfigAssetManager

	// tests/contracts/itxns.algo.ts:22
	// configAssetReserve: this.app.address
	global CurrentApplicationAddress
	itxn_field ConfigAssetReserve

	// tests/contracts/itxns.algo.ts:23
	// configAssetFreeze: this.app.address
	global CurrentApplicationAddress
	itxn_field ConfigAssetFreeze

	// tests/contracts/itxns.algo.ts:24
	// configAssetClawback: this.app.address
	global CurrentApplicationAddress
	itxn_field ConfigAssetClawback

	// tests/contracts/itxns.algo.ts:25
	// configAssetDefaultFrozen: 0
	int 0
	itxn_field ConfigAssetDefaultFrozen

	// tests/contracts/itxns.algo.ts:26
	// configAssetURL: 'url'
	pushbytes 0x75726c // "url"
	itxn_field ConfigAssetURL

	// tests/contracts/itxns.algo.ts:27
	// configAssetMetadataHash: 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa'
	byte 0x6161616161616161616161616161616161616161616161616161616161616161 // "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
	itxn_field ConfigAssetMetadataHash

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn CreatedAssetID
	retsub

// appCall()void
*abi_route_appCall:
	// execute appCall()void
	callsub appCall
	int 1
	return

// appCall(): void
appCall:
	proto 0 0

	// tests/contracts/itxns.algo.ts:32
	// sendAppCall({
	//       accounts: [this.app.address],
	//       applicationArgs: ['arg1', 'arg2'],
	//       applicationID: this.app,
	//       applications: [this.app],
	//       approvalProgram: 'approval',
	//       assets: [AssetID.zeroIndex],
	//       clearStateProgram: 'clear',
	//       globalNumByteSlice: 1,
	//       globalNumUint: 1,
	//       localNumByteSlice: 1,
	//       localNumUint: 1,
	//       note: 'note',
	//     })
	itxn_begin
	pushint 6 // appl
	itxn_field TypeEnum

	// tests/contracts/itxns.algo.ts:33
	// accounts: [this.app.address]
	global CurrentApplicationAddress
	itxn_field Accounts

	// tests/contracts/itxns.algo.ts:34
	// applicationArgs: ['arg1', 'arg2']
	pushbytes 0x61726731 // "arg1"
	itxn_field ApplicationArgs
	pushbytes 0x61726732 // "arg2"
	itxn_field ApplicationArgs

	// tests/contracts/itxns.algo.ts:35
	// applicationID: this.app
	txna Applications 0
	itxn_field ApplicationID

	// tests/contracts/itxns.algo.ts:36
	// applications: [this.app]
	txna Applications 0
	itxn_field Applications

	// tests/contracts/itxns.algo.ts:37
	// approvalProgram: 'approval'
	pushbytes 0x617070726f76616c // "approval"
	itxn_field ApprovalProgram

	// tests/contracts/itxns.algo.ts:38
	// assets: [AssetID.zeroIndex]
	int 0
	itxn_field Assets

	// tests/contracts/itxns.algo.ts:39
	// clearStateProgram: 'clear'
	pushbytes 0x636c656172 // "clear"
	itxn_field ClearStateProgram

	// tests/contracts/itxns.algo.ts:40
	// globalNumByteSlice: 1
	int 1
	itxn_field GlobalNumByteSlice

	// tests/contracts/itxns.algo.ts:41
	// globalNumUint: 1
	int 1
	itxn_field GlobalNumUint

	// tests/contracts/itxns.algo.ts:42
	// localNumByteSlice: 1
	int 1
	itxn_field LocalNumByteSlice

	// tests/contracts/itxns.algo.ts:43
	// localNumUint: 1
	int 1
	itxn_field LocalNumUint

	// tests/contracts/itxns.algo.ts:44
	// note: 'note'
	pushbytes 0x6e6f7465 // "note"
	itxn_field Note

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// assetConfig()void
*abi_route_assetConfig:
	// execute assetConfig()void
	callsub assetConfig
	int 1
	return

// assetConfig(): void
assetConfig:
	proto 0 0

	// tests/contracts/itxns.algo.ts:49
	// sendAssetConfig({
	//       configAsset: AssetID.zeroIndex,
	//       configAssetManager: this.app.address,
	//       configAssetReserve: this.app.address,
	//       configAssetFreeze: this.app.address,
	//       configAssetClawback: this.app.address,
	//     })
	itxn_begin
	pushint 3 // acfg
	itxn_field TypeEnum

	// tests/contracts/itxns.algo.ts:50
	// configAsset: AssetID.zeroIndex
	int 0
	itxn_field ConfigAsset

	// tests/contracts/itxns.algo.ts:51
	// configAssetManager: this.app.address
	global CurrentApplicationAddress
	itxn_field ConfigAssetManager

	// tests/contracts/itxns.algo.ts:52
	// configAssetReserve: this.app.address
	global CurrentApplicationAddress
	itxn_field ConfigAssetReserve

	// tests/contracts/itxns.algo.ts:53
	// configAssetFreeze: this.app.address
	global CurrentApplicationAddress
	itxn_field ConfigAssetFreeze

	// tests/contracts/itxns.algo.ts:54
	// configAssetClawback: this.app.address
	global CurrentApplicationAddress
	itxn_field ConfigAssetClawback

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// assetFreeze()void
*abi_route_assetFreeze:
	// execute assetFreeze()void
	callsub assetFreeze
	int 1
	return

// assetFreeze(): void
assetFreeze:
	proto 0 0

	// tests/contracts/itxns.algo.ts:59
	// sendAssetFreeze({
	//       freezeAssetFrozen: true,
	//       freezeAssetAccount: this.app.address,
	//       freezeAsset: AssetID.zeroIndex,
	//     })
	itxn_begin
	pushint 5 // afrz
	itxn_field TypeEnum

	// tests/contracts/itxns.algo.ts:60
	// freezeAssetFrozen: true
	int 1
	itxn_field FreezeAssetFrozen

	// tests/contracts/itxns.algo.ts:61
	// freezeAssetAccount: this.app.address
	global CurrentApplicationAddress
	itxn_field FreezeAssetAccount

	// tests/contracts/itxns.algo.ts:62
	// freezeAsset: AssetID.zeroIndex
	int 0
	itxn_field FreezeAsset

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// assetTransfer()void
*abi_route_assetTransfer:
	// execute assetTransfer()void
	callsub assetTransfer
	int 1
	return

// assetTransfer(): void
assetTransfer:
	proto 0 0

	// tests/contracts/itxns.algo.ts:67
	// sendAssetTransfer({
	//       assetAmount: 1,
	//       assetCloseTo: this.app.address,
	//       assetReceiver: this.app.address,
	//       assetSender: this.app.address,
	//       xferAsset: AssetID.zeroIndex,
	//     })
	itxn_begin
	pushint 4 // axfer
	itxn_field TypeEnum

	// tests/contracts/itxns.algo.ts:68
	// assetAmount: 1
	int 1
	itxn_field AssetAmount

	// tests/contracts/itxns.algo.ts:69
	// assetCloseTo: this.app.address
	global CurrentApplicationAddress
	itxn_field AssetCloseTo

	// tests/contracts/itxns.algo.ts:70
	// assetReceiver: this.app.address
	global CurrentApplicationAddress
	itxn_field AssetReceiver

	// tests/contracts/itxns.algo.ts:71
	// assetSender: this.app.address
	global CurrentApplicationAddress
	itxn_field AssetSender

	// tests/contracts/itxns.algo.ts:72
	// xferAsset: AssetID.zeroIndex
	int 0
	itxn_field XferAsset

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// methodCall()uint64
*abi_route_methodCall:
	// The ABI return prefix
	byte 0x151f7c75

	// execute methodCall()uint64
	callsub methodCall
	itob
	concat
	log
	int 1
	return

// methodCall(): AssetID
methodCall:
	proto 0 1

	// tests/contracts/itxns.algo.ts:77
	// return sendMethodCall<[AppID, AssetID], AssetID>({
	//       name: 'method',
	//       methodArgs: [this.app, AssetID.zeroIndex],
	//     });
	itxn_begin
	pushint 6 // appl
	itxn_field TypeEnum
	pushbytes 0xa66d559c // method "method(uint64,uint64)uint64"
	itxn_field ApplicationArgs

	// tests/contracts/itxns.algo.ts:79
	// methodArgs: [this.app, AssetID.zeroIndex]
	txna Applications 0
	itob
	itxn_field ApplicationArgs
	pushbytes 0x0000000000000000
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0
	btoi
	retsub

// onlineKeyRegistration()void
*abi_route_onlineKeyRegistration:
	// execute onlineKeyRegistration()void
	callsub onlineKeyRegistration
	int 1
	return

// onlineKeyRegistration(): void
onlineKeyRegistration:
	proto 0 0

	// tests/contracts/itxns.algo.ts:84
	// sendOnlineKeyRegistration({
	//       selectionPK: 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa',
	//       stateProofPK: 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa',
	//       voteFirst: 1,
	//       voteKeyDilution: 1,
	//       voteLast: 1,
	//       votePK: 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa',
	//     })
	itxn_begin
	pushint 2 // keyreg
	itxn_field TypeEnum

	// tests/contracts/itxns.algo.ts:85
	// selectionPK: 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa'
	byte 0x6161616161616161616161616161616161616161616161616161616161616161 // "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
	itxn_field SelectionPK

	// tests/contracts/itxns.algo.ts:86
	// stateProofPK: 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa'
	byte 0x6161616161616161616161616161616161616161616161616161616161616161 // "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
	itxn_field StateProofPK

	// tests/contracts/itxns.algo.ts:87
	// voteFirst: 1
	int 1
	itxn_field VoteFirst

	// tests/contracts/itxns.algo.ts:88
	// voteKeyDilution: 1
	int 1
	itxn_field VoteKeyDilution

	// tests/contracts/itxns.algo.ts:89
	// voteLast: 1
	int 1
	itxn_field VoteLast

	// tests/contracts/itxns.algo.ts:90
	// votePK: 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa'
	byte 0x6161616161616161616161616161616161616161616161616161616161616161 // "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
	itxn_field VotePK

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// offlineKeyRegistration()void
*abi_route_offlineKeyRegistration:
	// execute offlineKeyRegistration()void
	callsub offlineKeyRegistration
	int 1
	return

// offlineKeyRegistration(): void
offlineKeyRegistration:
	proto 0 0

	// tests/contracts/itxns.algo.ts:95
	// sendOfflineKeyRegistration({})
	itxn_begin
	pushint 2 // keyreg
	itxn_field TypeEnum

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// innerGeneric()void
*abi_route_innerGeneric:
	// execute innerGeneric()void
	callsub innerGeneric
	int 1
	return

// innerGeneric(): void
innerGeneric:
	proto 0 0

	// tests/contracts/itxns.algo.ts:99
	// sendMethodCall<[InnerTxn<InnerAssetCreation>], void>({
	//       name: 'foo',
	//       methodArgs: [{ configAssetTotal: 1 }],
	//     })
	itxn_begin
	pushint 3 // acfg
	itxn_field TypeEnum

	// tests/contracts/itxns.algo.ts:101
	// configAssetTotal: 1
	int 1
	itxn_field ConfigAssetTotal

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee
	itxn_next
	pushint 6 // appl
	itxn_field TypeEnum
	pushbytes 0x090924e8 // method "foo(txn)void"
	itxn_field ApplicationArgs

	// tests/contracts/itxns.algo.ts:101
	// methodArgs: [{ configAssetTotal: 1 }]
	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

*abi_route_createApplication:
	int 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x7a2ecb1c // method "payment()void"
	pushbytes 0xdf9b38ad // method "assetCreation()uint64"
	pushbytes 0x690ce8b6 // method "appCall()void"
	pushbytes 0x8f310534 // method "assetConfig()void"
	pushbytes 0xf834bee8 // method "assetFreeze()void"
	pushbytes 0x1f4418b7 // method "assetTransfer()void"
	pushbytes 0x70adfa23 // method "methodCall()uint64"
	pushbytes 0xe6ec46fc // method "onlineKeyRegistration()void"
	pushbytes 0x1172301a // method "offlineKeyRegistration()void"
	pushbytes 0x7a33897d // method "innerGeneric()void"
	txna ApplicationArgs 0
	match *abi_route_payment *abi_route_assetCreation *abi_route_appCall *abi_route_assetConfig *abi_route_assetFreeze *abi_route_assetTransfer *abi_route_methodCall *abi_route_onlineKeyRegistration *abi_route_offlineKeyRegistration *abi_route_innerGeneric

	// this contract does not implement the given ABI method for call NoOp
	err", + "approval": "#pragma version 10
intcblock 1 0
bytecblock 0x6161616161616161616161616161616161616161616161616161616161616161 0x151f7c75

// This TEAL was generated by TEALScript v0.105.0
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// payment()void
*abi_route_payment:
	// execute payment()void
	callsub payment
	int 1
	return

// payment(): void
payment:
	proto 0 0

	// tests/contracts/itxns.algo.ts:6
	// sendPayment({
	//       amount: 100,
	//       receiver: this.app.address,
	//       closeRemainderTo: globals.zeroAddress,
	//       sender: this.app.address,
	//       rekeyTo: globals.zeroAddress,
	//       note: 'Hello World!',
	//     })
	itxn_begin
	int 1 // pay
	itxn_field TypeEnum

	// tests/contracts/itxns.algo.ts:7
	// amount: 100
	pushint 100
	itxn_field Amount

	// tests/contracts/itxns.algo.ts:8
	// receiver: this.app.address
	global CurrentApplicationAddress
	itxn_field Receiver

	// tests/contracts/itxns.algo.ts:9
	// closeRemainderTo: globals.zeroAddress
	global ZeroAddress
	itxn_field CloseRemainderTo

	// tests/contracts/itxns.algo.ts:10
	// sender: this.app.address
	global CurrentApplicationAddress
	itxn_field Sender

	// tests/contracts/itxns.algo.ts:11
	// rekeyTo: globals.zeroAddress
	global ZeroAddress
	itxn_field RekeyTo

	// tests/contracts/itxns.algo.ts:12
	// note: 'Hello World!'
	pushbytes 0x48656c6c6f20576f726c6421 // "Hello World!"
	itxn_field Note

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// assetCreation()uint64
*abi_route_assetCreation:
	// The ABI return prefix
	byte 0x151f7c75

	// execute assetCreation()uint64
	callsub assetCreation
	itob
	concat
	log
	int 1
	return

// assetCreation(): AssetID
assetCreation:
	proto 0 1

	// tests/contracts/itxns.algo.ts:17
	// return sendAssetCreation({
	//       configAssetName: 'name',
	//       configAssetUnitName: 'unit',
	//       configAssetTotal: 1,
	//       configAssetManager: this.app.address,
	//       configAssetReserve: this.app.address,
	//       configAssetFreeze: this.app.address,
	//       configAssetClawback: this.app.address,
	//       configAssetDefaultFrozen: 0,
	//       configAssetURL: 'url',
	//       configAssetMetadataHash: 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa',
	//     });
	itxn_begin
	pushint 3 // acfg
	itxn_field TypeEnum

	// tests/contracts/itxns.algo.ts:18
	// configAssetName: 'name'
	pushbytes 0x6e616d65 // "name"
	itxn_field ConfigAssetName

	// tests/contracts/itxns.algo.ts:19
	// configAssetUnitName: 'unit'
	pushbytes 0x756e6974 // "unit"
	itxn_field ConfigAssetUnitName

	// tests/contracts/itxns.algo.ts:20
	// configAssetTotal: 1
	int 1
	itxn_field ConfigAssetTotal

	// tests/contracts/itxns.algo.ts:21
	// configAssetManager: this.app.address
	global CurrentApplicationAddress
	itxn_field ConfigAssetManager

	// tests/contracts/itxns.algo.ts:22
	// configAssetReserve: this.app.address
	global CurrentApplicationAddress
	itxn_field ConfigAssetReserve

	// tests/contracts/itxns.algo.ts:23
	// configAssetFreeze: this.app.address
	global CurrentApplicationAddress
	itxn_field ConfigAssetFreeze

	// tests/contracts/itxns.algo.ts:24
	// configAssetClawback: this.app.address
	global CurrentApplicationAddress
	itxn_field ConfigAssetClawback

	// tests/contracts/itxns.algo.ts:25
	// configAssetDefaultFrozen: 0
	int 0
	itxn_field ConfigAssetDefaultFrozen

	// tests/contracts/itxns.algo.ts:26
	// configAssetURL: 'url'
	pushbytes 0x75726c // "url"
	itxn_field ConfigAssetURL

	// tests/contracts/itxns.algo.ts:27
	// configAssetMetadataHash: 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa'
	byte 0x6161616161616161616161616161616161616161616161616161616161616161 // "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
	itxn_field ConfigAssetMetadataHash

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn CreatedAssetID
	retsub

// appCall()void
*abi_route_appCall:
	// execute appCall()void
	callsub appCall
	int 1
	return

// appCall(): void
appCall:
	proto 0 0

	// tests/contracts/itxns.algo.ts:32
	// sendAppCall({
	//       accounts: [this.app.address],
	//       applicationArgs: ['arg1', 'arg2'],
	//       applicationID: this.app,
	//       applications: [this.app],
	//       approvalProgram: 'approval',
	//       assets: [AssetID.zeroIndex],
	//       clearStateProgram: 'clear',
	//       globalNumByteSlice: 1,
	//       globalNumUint: 1,
	//       localNumByteSlice: 1,
	//       localNumUint: 1,
	//       note: 'note',
	//     })
	itxn_begin
	pushint 6 // appl
	itxn_field TypeEnum

	// tests/contracts/itxns.algo.ts:33
	// accounts: [this.app.address]
	global CurrentApplicationAddress
	itxn_field Accounts

	// tests/contracts/itxns.algo.ts:34
	// applicationArgs: ['arg1', 'arg2']
	pushbytes 0x61726731 // "arg1"
	itxn_field ApplicationArgs
	pushbytes 0x61726732 // "arg2"
	itxn_field ApplicationArgs

	// tests/contracts/itxns.algo.ts:35
	// applicationID: this.app
	txna Applications 0
	itxn_field ApplicationID

	// tests/contracts/itxns.algo.ts:36
	// applications: [this.app]
	txna Applications 0
	itxn_field Applications

	// tests/contracts/itxns.algo.ts:37
	// approvalProgram: 'approval'
	pushbytes 0x617070726f76616c // "approval"
	itxn_field ApprovalProgram

	// tests/contracts/itxns.algo.ts:38
	// assets: [AssetID.zeroIndex]
	int 0
	itxn_field Assets

	// tests/contracts/itxns.algo.ts:39
	// clearStateProgram: 'clear'
	pushbytes 0x636c656172 // "clear"
	itxn_field ClearStateProgram

	// tests/contracts/itxns.algo.ts:40
	// globalNumByteSlice: 1
	int 1
	itxn_field GlobalNumByteSlice

	// tests/contracts/itxns.algo.ts:41
	// globalNumUint: 1
	int 1
	itxn_field GlobalNumUint

	// tests/contracts/itxns.algo.ts:42
	// localNumByteSlice: 1
	int 1
	itxn_field LocalNumByteSlice

	// tests/contracts/itxns.algo.ts:43
	// localNumUint: 1
	int 1
	itxn_field LocalNumUint

	// tests/contracts/itxns.algo.ts:44
	// note: 'note'
	pushbytes 0x6e6f7465 // "note"
	itxn_field Note

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// assetConfig()void
*abi_route_assetConfig:
	// execute assetConfig()void
	callsub assetConfig
	int 1
	return

// assetConfig(): void
assetConfig:
	proto 0 0

	// tests/contracts/itxns.algo.ts:49
	// sendAssetConfig({
	//       configAsset: AssetID.zeroIndex,
	//       configAssetManager: this.app.address,
	//       configAssetReserve: this.app.address,
	//       configAssetFreeze: this.app.address,
	//       configAssetClawback: this.app.address,
	//     })
	itxn_begin
	pushint 3 // acfg
	itxn_field TypeEnum

	// tests/contracts/itxns.algo.ts:50
	// configAsset: AssetID.zeroIndex
	int 0
	itxn_field ConfigAsset

	// tests/contracts/itxns.algo.ts:51
	// configAssetManager: this.app.address
	global CurrentApplicationAddress
	itxn_field ConfigAssetManager

	// tests/contracts/itxns.algo.ts:52
	// configAssetReserve: this.app.address
	global CurrentApplicationAddress
	itxn_field ConfigAssetReserve

	// tests/contracts/itxns.algo.ts:53
	// configAssetFreeze: this.app.address
	global CurrentApplicationAddress
	itxn_field ConfigAssetFreeze

	// tests/contracts/itxns.algo.ts:54
	// configAssetClawback: this.app.address
	global CurrentApplicationAddress
	itxn_field ConfigAssetClawback

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// assetFreeze()void
*abi_route_assetFreeze:
	// execute assetFreeze()void
	callsub assetFreeze
	int 1
	return

// assetFreeze(): void
assetFreeze:
	proto 0 0

	// tests/contracts/itxns.algo.ts:59
	// sendAssetFreeze({
	//       freezeAssetFrozen: true,
	//       freezeAssetAccount: this.app.address,
	//       freezeAsset: AssetID.zeroIndex,
	//     })
	itxn_begin
	pushint 5 // afrz
	itxn_field TypeEnum

	// tests/contracts/itxns.algo.ts:60
	// freezeAssetFrozen: true
	int 1
	itxn_field FreezeAssetFrozen

	// tests/contracts/itxns.algo.ts:61
	// freezeAssetAccount: this.app.address
	global CurrentApplicationAddress
	itxn_field FreezeAssetAccount

	// tests/contracts/itxns.algo.ts:62
	// freezeAsset: AssetID.zeroIndex
	int 0
	itxn_field FreezeAsset

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// assetTransfer()void
*abi_route_assetTransfer:
	// execute assetTransfer()void
	callsub assetTransfer
	int 1
	return

// assetTransfer(): void
assetTransfer:
	proto 0 0

	// tests/contracts/itxns.algo.ts:67
	// sendAssetTransfer({
	//       assetAmount: 1,
	//       assetCloseTo: this.app.address,
	//       assetReceiver: this.app.address,
	//       assetSender: this.app.address,
	//       xferAsset: AssetID.zeroIndex,
	//     })
	itxn_begin
	pushint 4 // axfer
	itxn_field TypeEnum

	// tests/contracts/itxns.algo.ts:68
	// assetAmount: 1
	int 1
	itxn_field AssetAmount

	// tests/contracts/itxns.algo.ts:69
	// assetCloseTo: this.app.address
	global CurrentApplicationAddress
	itxn_field AssetCloseTo

	// tests/contracts/itxns.algo.ts:70
	// assetReceiver: this.app.address
	global CurrentApplicationAddress
	itxn_field AssetReceiver

	// tests/contracts/itxns.algo.ts:71
	// assetSender: this.app.address
	global CurrentApplicationAddress
	itxn_field AssetSender

	// tests/contracts/itxns.algo.ts:72
	// xferAsset: AssetID.zeroIndex
	int 0
	itxn_field XferAsset

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// methodCall()uint64
*abi_route_methodCall:
	// The ABI return prefix
	byte 0x151f7c75

	// execute methodCall()uint64
	callsub methodCall
	itob
	concat
	log
	int 1
	return

// methodCall(): AssetID
methodCall:
	proto 0 1

	// tests/contracts/itxns.algo.ts:77
	// return sendMethodCall<[AppID, AssetID], AssetID>({
	//       name: 'method',
	//       methodArgs: [this.app, AssetID.zeroIndex],
	//     });
	itxn_begin
	pushint 6 // appl
	itxn_field TypeEnum
	pushbytes 0xa66d559c // method "method(uint64,uint64)uint64"
	itxn_field ApplicationArgs

	// tests/contracts/itxns.algo.ts:79
	// methodArgs: [this.app, AssetID.zeroIndex]
	txna Applications 0
	itob
	itxn_field ApplicationArgs
	pushbytes 0x0000000000000000
	itxn_field ApplicationArgs

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	itxn NumLogs
	int 1
	-
	itxnas Logs
	extract 4 0
	btoi
	retsub

// onlineKeyRegistration()void
*abi_route_onlineKeyRegistration:
	// execute onlineKeyRegistration()void
	callsub onlineKeyRegistration
	int 1
	return

// onlineKeyRegistration(): void
onlineKeyRegistration:
	proto 0 0

	// tests/contracts/itxns.algo.ts:84
	// sendOnlineKeyRegistration({
	//       selectionPK: 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa',
	//       stateProofPK: 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa',
	//       voteFirst: 1,
	//       voteKeyDilution: 1,
	//       voteLast: 1,
	//       votePK: 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa',
	//     })
	itxn_begin
	pushint 2 // keyreg
	itxn_field TypeEnum

	// tests/contracts/itxns.algo.ts:85
	// selectionPK: 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa'
	byte 0x6161616161616161616161616161616161616161616161616161616161616161 // "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
	itxn_field SelectionPK

	// tests/contracts/itxns.algo.ts:86
	// stateProofPK: 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa'
	byte 0x6161616161616161616161616161616161616161616161616161616161616161 // "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
	itxn_field StateProofPK

	// tests/contracts/itxns.algo.ts:87
	// voteFirst: 1
	int 1
	itxn_field VoteFirst

	// tests/contracts/itxns.algo.ts:88
	// voteKeyDilution: 1
	int 1
	itxn_field VoteKeyDilution

	// tests/contracts/itxns.algo.ts:89
	// voteLast: 1
	int 1
	itxn_field VoteLast

	// tests/contracts/itxns.algo.ts:90
	// votePK: 'aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa'
	byte 0x6161616161616161616161616161616161616161616161616161616161616161 // "aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa"
	itxn_field VotePK

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// offlineKeyRegistration()void
*abi_route_offlineKeyRegistration:
	// execute offlineKeyRegistration()void
	callsub offlineKeyRegistration
	int 1
	return

// offlineKeyRegistration(): void
offlineKeyRegistration:
	proto 0 0

	// tests/contracts/itxns.algo.ts:95
	// sendOfflineKeyRegistration({})
	itxn_begin
	pushint 2 // keyreg
	itxn_field TypeEnum

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

// innerGeneric()void
*abi_route_innerGeneric:
	// execute innerGeneric()void
	callsub innerGeneric
	int 1
	return

// innerGeneric(): void
innerGeneric:
	proto 0 0

	// tests/contracts/itxns.algo.ts:99
	// sendMethodCall<[InnerTxn<InnerAssetCreation>], void>({
	//       name: 'foo',
	//       methodArgs: [{ configAssetTotal: 1 }],
	//     })
	itxn_begin
	pushint 3 // acfg
	itxn_field TypeEnum

	// tests/contracts/itxns.algo.ts:101
	// configAssetTotal: 1
	int 1
	itxn_field ConfigAssetTotal

	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee
	itxn_next
	pushint 6 // appl
	itxn_field TypeEnum
	pushbytes 0x090924e8 // method "foo(txn)void"
	itxn_field ApplicationArgs

	// tests/contracts/itxns.algo.ts:101
	// methodArgs: [{ configAssetTotal: 1 }]
	// Fee field not set, defaulting to 0
	int 0
	itxn_field Fee

	// Submit inner transaction
	itxn_submit
	retsub

*abi_route_createApplication:
	int 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x7a2ecb1c // method "payment()void"
	pushbytes 0xdf9b38ad // method "assetCreation()uint64"
	pushbytes 0x690ce8b6 // method "appCall()void"
	pushbytes 0x8f310534 // method "assetConfig()void"
	pushbytes 0xf834bee8 // method "assetFreeze()void"
	pushbytes 0x1f4418b7 // method "assetTransfer()void"
	pushbytes 0x70adfa23 // method "methodCall()uint64"
	pushbytes 0xe6ec46fc // method "onlineKeyRegistration()void"
	pushbytes 0x1172301a // method "offlineKeyRegistration()void"
	pushbytes 0x7a33897d // method "innerGeneric()void"
	txna ApplicationArgs 0
	match *abi_route_payment *abi_route_assetCreation *abi_route_appCall *abi_route_assetConfig *abi_route_assetFreeze *abi_route_assetTransfer *abi_route_methodCall *abi_route_onlineKeyRegistration *abi_route_offlineKeyRegistration *abi_route_innerGeneric

	// this contract does not implement the given ABI method for call NoOp
	err", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/LoopsTest.approval.teal b/tests/contracts/artifacts/LoopsTest.approval.teal index 3082afdc5..5a4b7e92e 100644 --- a/tests/contracts/artifacts/LoopsTest.approval.teal +++ b/tests/contracts/artifacts/LoopsTest.approval.teal @@ -2,7 +2,7 @@ intcblock 1 0 10 bytecblock 0x151f7c75 0x -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/LoopsTest.arc32.json b/tests/contracts/artifacts/LoopsTest.arc32.json index 4b0f775b1..59ae7cdbc 100644 --- a/tests/contracts/artifacts/LoopsTest.arc32.json +++ b/tests/contracts/artifacts/LoopsTest.arc32.json @@ -79,7 +79,7 @@ } }, "source": { - "approval": "#pragma version 10
intcblock 1 0 10
bytecblock 0x151f7c75 0x

// This TEAL was generated by TEALScript v0.104.1
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// whileLoop()uint64
*abi_route_whileLoop:
	// The ABI return prefix
	byte 0x151f7c75

	// execute whileLoop()uint64
	callsub whileLoop
	itob
	concat
	log
	int 1
	return

// whileLoop(): uint64
whileLoop:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/loops.algo.ts:7
	// i = 0
	int 0
	frame_bury 0 // i: uint64

*while_0:

*while_0_continue:
	// tests/contracts/loops.algo.ts:9
	// i < 10
	frame_dig 0 // i: uint64
	int 10
	<
	bz *while_0_end

	// tests/contracts/loops.algo.ts:10
	// i = i + 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64
	b *while_0

*while_0_end:
	// tests/contracts/loops.algo.ts:13
	// return i;
	frame_dig 0 // i: uint64

	// set the subroutine return value
	frame_bury 0
	retsub

// forLoop()uint64
*abi_route_forLoop:
	// The ABI return prefix
	byte 0x151f7c75

	// execute forLoop()uint64
	callsub forLoop
	itob
	concat
	log
	int 1
	return

// forLoop(): uint64
forLoop:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// tests/contracts/loops.algo.ts:17
	// i = 0
	int 0
	frame_bury 0 // i: uint64

	// tests/contracts/loops.algo.ts:19
	// for (let j = 0; j < 10; j = j + 1)
	int 0
	frame_bury 1 // j: uint64

*for_0:
	// tests/contracts/loops.algo.ts:19
	// j < 10
	frame_dig 1 // j: uint64
	int 10
	<
	bz *for_0_end

	// tests/contracts/loops.algo.ts:20
	// i = i + 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64

*for_0_continue:
	// tests/contracts/loops.algo.ts:19
	// j = j + 1
	frame_dig 1 // j: uint64
	int 1
	+
	frame_bury 1 // j: uint64
	b *for_0

*for_0_end:
	// tests/contracts/loops.algo.ts:23
	// return i;
	frame_dig 0 // i: uint64

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 1
	retsub

// doWhileLoop()uint64
*abi_route_doWhileLoop:
	// The ABI return prefix
	byte 0x151f7c75

	// execute doWhileLoop()uint64
	callsub doWhileLoop
	itob
	concat
	log
	int 1
	return

// doWhileLoop(): uint64
doWhileLoop:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/loops.algo.ts:27
	// i = 0
	int 0
	frame_bury 0 // i: uint64

*do_while_0_statement:
	// tests/contracts/loops.algo.ts:30
	// i = i + 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64

*do_while_0:

*do_while_0_continue:
	// tests/contracts/loops.algo.ts:31
	// i < 10
	frame_dig 0 // i: uint64
	int 10
	<
	bnz *do_while_0_statement

*do_while_0_end:
	// tests/contracts/loops.algo.ts:33
	// return i;
	frame_dig 0 // i: uint64

	// set the subroutine return value
	frame_bury 0
	retsub

// breakWhileLoop()uint64
*abi_route_breakWhileLoop:
	// The ABI return prefix
	byte 0x151f7c75

	// execute breakWhileLoop()uint64
	callsub breakWhileLoop
	itob
	concat
	log
	int 1
	return

// breakWhileLoop(): uint64
breakWhileLoop:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/loops.algo.ts:37
	// i = 0
	int 0
	frame_bury 0 // i: uint64

*while_1:

*while_1_continue:
	// tests/contracts/loops.algo.ts:39
	// i < 10
	frame_dig 0 // i: uint64
	int 10
	<
	bz *while_1_end

	// tests/contracts/loops.algo.ts:40
	// i = i + 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64

	// *if0_condition
	// tests/contracts/loops.algo.ts:41
	// i === 5
	frame_dig 0 // i: uint64
	pushint 5
	==
	bz *if0_end

	// *if0_consequent
	b *while_1_end

*if0_end:
	b *while_1

*while_1_end:
	// tests/contracts/loops.algo.ts:44
	// return i;
	frame_dig 0 // i: uint64

	// set the subroutine return value
	frame_bury 0
	retsub

// continueWhileLoop()uint64
*abi_route_continueWhileLoop:
	// The ABI return prefix
	byte 0x151f7c75

	// execute continueWhileLoop()uint64
	callsub continueWhileLoop
	itob
	concat
	log
	int 1
	return

// continueWhileLoop(): uint64
continueWhileLoop:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/loops.algo.ts:48
	// i = 0
	int 0
	frame_bury 0 // i: uint64

*while_2:

*while_2_continue:
	// tests/contracts/loops.algo.ts:50
	// i < 10
	frame_dig 0 // i: uint64
	int 10
	<
	bz *while_2_end

	// *if1_condition
	// tests/contracts/loops.algo.ts:51
	// i === 5
	frame_dig 0 // i: uint64
	pushint 5
	==
	bz *if1_end

	// *if1_consequent
	// tests/contracts/loops.algo.ts:52
	// i = 1337
	pushint 1337
	frame_bury 0 // i: uint64
	b *while_2_continue

*if1_end:
	// tests/contracts/loops.algo.ts:55
	// i = i + 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64
	b *while_2

*while_2_end:
	// tests/contracts/loops.algo.ts:58
	// return i;
	frame_dig 0 // i: uint64

	// set the subroutine return value
	frame_bury 0
	retsub

// breakForLoop()uint64
*abi_route_breakForLoop:
	// The ABI return prefix
	byte 0x151f7c75

	// execute breakForLoop()uint64
	callsub breakForLoop
	itob
	concat
	log
	int 1
	return

// breakForLoop(): uint64
breakForLoop:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// tests/contracts/loops.algo.ts:62
	// i = 0
	int 0
	frame_bury 0 // i: uint64

	// tests/contracts/loops.algo.ts:64
	// for (let j = 0; j < 10; j = j + 1)
	int 0
	frame_bury 1 // j: uint64

*for_1:
	// tests/contracts/loops.algo.ts:64
	// j < 10
	frame_dig 1 // j: uint64
	int 10
	<
	bz *for_1_end

	// tests/contracts/loops.algo.ts:65
	// i = i + 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64

	// *if2_condition
	// tests/contracts/loops.algo.ts:66
	// i === 5
	frame_dig 0 // i: uint64
	pushint 5
	==
	bz *if2_end

	// *if2_consequent
	b *for_1_end

*if2_end:

*for_1_continue:
	// tests/contracts/loops.algo.ts:64
	// j = j + 1
	frame_dig 1 // j: uint64
	int 1
	+
	frame_bury 1 // j: uint64
	b *for_1

*for_1_end:
	// tests/contracts/loops.algo.ts:69
	// return i;
	frame_dig 0 // i: uint64

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 1
	retsub

// continueForLoop()uint64
*abi_route_continueForLoop:
	// The ABI return prefix
	byte 0x151f7c75

	// execute continueForLoop()uint64
	callsub continueForLoop
	itob
	concat
	log
	int 1
	return

// continueForLoop(): uint64
continueForLoop:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// tests/contracts/loops.algo.ts:73
	// i = 0
	int 0
	frame_bury 0 // i: uint64

	// tests/contracts/loops.algo.ts:75
	// for (let j = 0; j < 10; j = j + 1)
	int 0
	frame_bury 1 // j: uint64

*for_2:
	// tests/contracts/loops.algo.ts:75
	// j < 10
	frame_dig 1 // j: uint64
	int 10
	<
	bz *for_2_end

	// *if3_condition
	// tests/contracts/loops.algo.ts:76
	// i === 5
	frame_dig 0 // i: uint64
	pushint 5
	==
	bz *if3_end

	// *if3_consequent
	// tests/contracts/loops.algo.ts:77
	// i = 1337
	pushint 1337
	frame_bury 0 // i: uint64
	b *for_2_continue

*if3_end:
	// tests/contracts/loops.algo.ts:80
	// i = i + 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64

*for_2_continue:
	// tests/contracts/loops.algo.ts:75
	// j = j + 1
	frame_dig 1 // j: uint64
	int 1
	+
	frame_bury 1 // j: uint64
	b *for_2

*for_2_end:
	// tests/contracts/loops.algo.ts:83
	// return i;
	frame_dig 0 // i: uint64

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 1
	retsub

// breakDoWhileLoop()uint64
*abi_route_breakDoWhileLoop:
	// The ABI return prefix
	byte 0x151f7c75

	// execute breakDoWhileLoop()uint64
	callsub breakDoWhileLoop
	itob
	concat
	log
	int 1
	return

// breakDoWhileLoop(): uint64
breakDoWhileLoop:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/loops.algo.ts:87
	// i = 0
	int 0
	frame_bury 0 // i: uint64

*do_while_1_statement:
	// tests/contracts/loops.algo.ts:90
	// i = i + 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64

	// *if4_condition
	// tests/contracts/loops.algo.ts:91
	// i === 5
	frame_dig 0 // i: uint64
	pushint 5
	==
	bz *if4_end

	// *if4_consequent
	b *do_while_1_end

*if4_end:

*do_while_1:

*do_while_1_continue:
	// tests/contracts/loops.algo.ts:92
	// i < 10
	frame_dig 0 // i: uint64
	int 10
	<
	bnz *do_while_1_statement

*do_while_1_end:
	// tests/contracts/loops.algo.ts:94
	// return i;
	frame_dig 0 // i: uint64

	// set the subroutine return value
	frame_bury 0
	retsub

// continueDoWhileLoop()uint64
*abi_route_continueDoWhileLoop:
	// The ABI return prefix
	byte 0x151f7c75

	// execute continueDoWhileLoop()uint64
	callsub continueDoWhileLoop
	itob
	concat
	log
	int 1
	return

// continueDoWhileLoop(): uint64
continueDoWhileLoop:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/loops.algo.ts:98
	// i = 0
	int 0
	frame_bury 0 // i: uint64

*do_while_2_statement:
	// *if5_condition
	// tests/contracts/loops.algo.ts:101
	// i === 5
	frame_dig 0 // i: uint64
	pushint 5
	==
	bz *if5_end

	// *if5_consequent
	// tests/contracts/loops.algo.ts:102
	// i = 1337
	pushint 1337
	frame_bury 0 // i: uint64
	b *do_while_2_continue

*if5_end:
	// tests/contracts/loops.algo.ts:105
	// i = i + 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64

*do_while_2:

*do_while_2_continue:
	// tests/contracts/loops.algo.ts:106
	// i < 10
	frame_dig 0 // i: uint64
	int 10
	<
	bnz *do_while_2_statement

*do_while_2_end:
	// tests/contracts/loops.algo.ts:108
	// return i;
	frame_dig 0 // i: uint64

	// set the subroutine return value
	frame_bury 0
	retsub

*abi_route_createApplication:
	int 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0xe164bbd9 // method "whileLoop()uint64"
	pushbytes 0x5b3ed9f6 // method "forLoop()uint64"
	pushbytes 0x1d861a3d // method "doWhileLoop()uint64"
	pushbytes 0x821fe829 // method "breakWhileLoop()uint64"
	pushbytes 0x8d15280a // method "continueWhileLoop()uint64"
	pushbytes 0x6897cf5e // method "breakForLoop()uint64"
	pushbytes 0x99cbacab // method "continueForLoop()uint64"
	pushbytes 0x86d5edd3 // method "breakDoWhileLoop()uint64"
	pushbytes 0xe01d9d42 // method "continueDoWhileLoop()uint64"
	txna ApplicationArgs 0
	match *abi_route_whileLoop *abi_route_forLoop *abi_route_doWhileLoop *abi_route_breakWhileLoop *abi_route_continueWhileLoop *abi_route_breakForLoop *abi_route_continueForLoop *abi_route_breakDoWhileLoop *abi_route_continueDoWhileLoop

	// this contract does not implement the given ABI method for call NoOp
	err", + "approval": "#pragma version 10
intcblock 1 0 10
bytecblock 0x151f7c75 0x

// This TEAL was generated by TEALScript v0.105.0
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// whileLoop()uint64
*abi_route_whileLoop:
	// The ABI return prefix
	byte 0x151f7c75

	// execute whileLoop()uint64
	callsub whileLoop
	itob
	concat
	log
	int 1
	return

// whileLoop(): uint64
whileLoop:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/loops.algo.ts:7
	// i = 0
	int 0
	frame_bury 0 // i: uint64

*while_0:

*while_0_continue:
	// tests/contracts/loops.algo.ts:9
	// i < 10
	frame_dig 0 // i: uint64
	int 10
	<
	bz *while_0_end

	// tests/contracts/loops.algo.ts:10
	// i = i + 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64
	b *while_0

*while_0_end:
	// tests/contracts/loops.algo.ts:13
	// return i;
	frame_dig 0 // i: uint64

	// set the subroutine return value
	frame_bury 0
	retsub

// forLoop()uint64
*abi_route_forLoop:
	// The ABI return prefix
	byte 0x151f7c75

	// execute forLoop()uint64
	callsub forLoop
	itob
	concat
	log
	int 1
	return

// forLoop(): uint64
forLoop:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// tests/contracts/loops.algo.ts:17
	// i = 0
	int 0
	frame_bury 0 // i: uint64

	// tests/contracts/loops.algo.ts:19
	// for (let j = 0; j < 10; j = j + 1)
	int 0
	frame_bury 1 // j: uint64

*for_0:
	// tests/contracts/loops.algo.ts:19
	// j < 10
	frame_dig 1 // j: uint64
	int 10
	<
	bz *for_0_end

	// tests/contracts/loops.algo.ts:20
	// i = i + 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64

*for_0_continue:
	// tests/contracts/loops.algo.ts:19
	// j = j + 1
	frame_dig 1 // j: uint64
	int 1
	+
	frame_bury 1 // j: uint64
	b *for_0

*for_0_end:
	// tests/contracts/loops.algo.ts:23
	// return i;
	frame_dig 0 // i: uint64

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 1
	retsub

// doWhileLoop()uint64
*abi_route_doWhileLoop:
	// The ABI return prefix
	byte 0x151f7c75

	// execute doWhileLoop()uint64
	callsub doWhileLoop
	itob
	concat
	log
	int 1
	return

// doWhileLoop(): uint64
doWhileLoop:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/loops.algo.ts:27
	// i = 0
	int 0
	frame_bury 0 // i: uint64

*do_while_0_statement:
	// tests/contracts/loops.algo.ts:30
	// i = i + 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64

*do_while_0:

*do_while_0_continue:
	// tests/contracts/loops.algo.ts:31
	// i < 10
	frame_dig 0 // i: uint64
	int 10
	<
	bnz *do_while_0_statement

*do_while_0_end:
	// tests/contracts/loops.algo.ts:33
	// return i;
	frame_dig 0 // i: uint64

	// set the subroutine return value
	frame_bury 0
	retsub

// breakWhileLoop()uint64
*abi_route_breakWhileLoop:
	// The ABI return prefix
	byte 0x151f7c75

	// execute breakWhileLoop()uint64
	callsub breakWhileLoop
	itob
	concat
	log
	int 1
	return

// breakWhileLoop(): uint64
breakWhileLoop:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/loops.algo.ts:37
	// i = 0
	int 0
	frame_bury 0 // i: uint64

*while_1:

*while_1_continue:
	// tests/contracts/loops.algo.ts:39
	// i < 10
	frame_dig 0 // i: uint64
	int 10
	<
	bz *while_1_end

	// tests/contracts/loops.algo.ts:40
	// i = i + 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64

	// *if0_condition
	// tests/contracts/loops.algo.ts:41
	// i === 5
	frame_dig 0 // i: uint64
	pushint 5
	==
	bz *if0_end

	// *if0_consequent
	b *while_1_end

*if0_end:
	b *while_1

*while_1_end:
	// tests/contracts/loops.algo.ts:44
	// return i;
	frame_dig 0 // i: uint64

	// set the subroutine return value
	frame_bury 0
	retsub

// continueWhileLoop()uint64
*abi_route_continueWhileLoop:
	// The ABI return prefix
	byte 0x151f7c75

	// execute continueWhileLoop()uint64
	callsub continueWhileLoop
	itob
	concat
	log
	int 1
	return

// continueWhileLoop(): uint64
continueWhileLoop:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/loops.algo.ts:48
	// i = 0
	int 0
	frame_bury 0 // i: uint64

*while_2:

*while_2_continue:
	// tests/contracts/loops.algo.ts:50
	// i < 10
	frame_dig 0 // i: uint64
	int 10
	<
	bz *while_2_end

	// *if1_condition
	// tests/contracts/loops.algo.ts:51
	// i === 5
	frame_dig 0 // i: uint64
	pushint 5
	==
	bz *if1_end

	// *if1_consequent
	// tests/contracts/loops.algo.ts:52
	// i = 1337
	pushint 1337
	frame_bury 0 // i: uint64
	b *while_2_continue

*if1_end:
	// tests/contracts/loops.algo.ts:55
	// i = i + 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64
	b *while_2

*while_2_end:
	// tests/contracts/loops.algo.ts:58
	// return i;
	frame_dig 0 // i: uint64

	// set the subroutine return value
	frame_bury 0
	retsub

// breakForLoop()uint64
*abi_route_breakForLoop:
	// The ABI return prefix
	byte 0x151f7c75

	// execute breakForLoop()uint64
	callsub breakForLoop
	itob
	concat
	log
	int 1
	return

// breakForLoop(): uint64
breakForLoop:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// tests/contracts/loops.algo.ts:62
	// i = 0
	int 0
	frame_bury 0 // i: uint64

	// tests/contracts/loops.algo.ts:64
	// for (let j = 0; j < 10; j = j + 1)
	int 0
	frame_bury 1 // j: uint64

*for_1:
	// tests/contracts/loops.algo.ts:64
	// j < 10
	frame_dig 1 // j: uint64
	int 10
	<
	bz *for_1_end

	// tests/contracts/loops.algo.ts:65
	// i = i + 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64

	// *if2_condition
	// tests/contracts/loops.algo.ts:66
	// i === 5
	frame_dig 0 // i: uint64
	pushint 5
	==
	bz *if2_end

	// *if2_consequent
	b *for_1_end

*if2_end:

*for_1_continue:
	// tests/contracts/loops.algo.ts:64
	// j = j + 1
	frame_dig 1 // j: uint64
	int 1
	+
	frame_bury 1 // j: uint64
	b *for_1

*for_1_end:
	// tests/contracts/loops.algo.ts:69
	// return i;
	frame_dig 0 // i: uint64

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 1
	retsub

// continueForLoop()uint64
*abi_route_continueForLoop:
	// The ABI return prefix
	byte 0x151f7c75

	// execute continueForLoop()uint64
	callsub continueForLoop
	itob
	concat
	log
	int 1
	return

// continueForLoop(): uint64
continueForLoop:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// tests/contracts/loops.algo.ts:73
	// i = 0
	int 0
	frame_bury 0 // i: uint64

	// tests/contracts/loops.algo.ts:75
	// for (let j = 0; j < 10; j = j + 1)
	int 0
	frame_bury 1 // j: uint64

*for_2:
	// tests/contracts/loops.algo.ts:75
	// j < 10
	frame_dig 1 // j: uint64
	int 10
	<
	bz *for_2_end

	// *if3_condition
	// tests/contracts/loops.algo.ts:76
	// i === 5
	frame_dig 0 // i: uint64
	pushint 5
	==
	bz *if3_end

	// *if3_consequent
	// tests/contracts/loops.algo.ts:77
	// i = 1337
	pushint 1337
	frame_bury 0 // i: uint64
	b *for_2_continue

*if3_end:
	// tests/contracts/loops.algo.ts:80
	// i = i + 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64

*for_2_continue:
	// tests/contracts/loops.algo.ts:75
	// j = j + 1
	frame_dig 1 // j: uint64
	int 1
	+
	frame_bury 1 // j: uint64
	b *for_2

*for_2_end:
	// tests/contracts/loops.algo.ts:83
	// return i;
	frame_dig 0 // i: uint64

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 1
	retsub

// breakDoWhileLoop()uint64
*abi_route_breakDoWhileLoop:
	// The ABI return prefix
	byte 0x151f7c75

	// execute breakDoWhileLoop()uint64
	callsub breakDoWhileLoop
	itob
	concat
	log
	int 1
	return

// breakDoWhileLoop(): uint64
breakDoWhileLoop:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/loops.algo.ts:87
	// i = 0
	int 0
	frame_bury 0 // i: uint64

*do_while_1_statement:
	// tests/contracts/loops.algo.ts:90
	// i = i + 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64

	// *if4_condition
	// tests/contracts/loops.algo.ts:91
	// i === 5
	frame_dig 0 // i: uint64
	pushint 5
	==
	bz *if4_end

	// *if4_consequent
	b *do_while_1_end

*if4_end:

*do_while_1:

*do_while_1_continue:
	// tests/contracts/loops.algo.ts:92
	// i < 10
	frame_dig 0 // i: uint64
	int 10
	<
	bnz *do_while_1_statement

*do_while_1_end:
	// tests/contracts/loops.algo.ts:94
	// return i;
	frame_dig 0 // i: uint64

	// set the subroutine return value
	frame_bury 0
	retsub

// continueDoWhileLoop()uint64
*abi_route_continueDoWhileLoop:
	// The ABI return prefix
	byte 0x151f7c75

	// execute continueDoWhileLoop()uint64
	callsub continueDoWhileLoop
	itob
	concat
	log
	int 1
	return

// continueDoWhileLoop(): uint64
continueDoWhileLoop:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/loops.algo.ts:98
	// i = 0
	int 0
	frame_bury 0 // i: uint64

*do_while_2_statement:
	// *if5_condition
	// tests/contracts/loops.algo.ts:101
	// i === 5
	frame_dig 0 // i: uint64
	pushint 5
	==
	bz *if5_end

	// *if5_consequent
	// tests/contracts/loops.algo.ts:102
	// i = 1337
	pushint 1337
	frame_bury 0 // i: uint64
	b *do_while_2_continue

*if5_end:
	// tests/contracts/loops.algo.ts:105
	// i = i + 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64

*do_while_2:

*do_while_2_continue:
	// tests/contracts/loops.algo.ts:106
	// i < 10
	frame_dig 0 // i: uint64
	int 10
	<
	bnz *do_while_2_statement

*do_while_2_end:
	// tests/contracts/loops.algo.ts:108
	// return i;
	frame_dig 0 // i: uint64

	// set the subroutine return value
	frame_bury 0
	retsub

*abi_route_createApplication:
	int 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0xe164bbd9 // method "whileLoop()uint64"
	pushbytes 0x5b3ed9f6 // method "forLoop()uint64"
	pushbytes 0x1d861a3d // method "doWhileLoop()uint64"
	pushbytes 0x821fe829 // method "breakWhileLoop()uint64"
	pushbytes 0x8d15280a // method "continueWhileLoop()uint64"
	pushbytes 0x6897cf5e // method "breakForLoop()uint64"
	pushbytes 0x99cbacab // method "continueForLoop()uint64"
	pushbytes 0x86d5edd3 // method "breakDoWhileLoop()uint64"
	pushbytes 0xe01d9d42 // method "continueDoWhileLoop()uint64"
	txna ApplicationArgs 0
	match *abi_route_whileLoop *abi_route_forLoop *abi_route_doWhileLoop *abi_route_breakWhileLoop *abi_route_continueWhileLoop *abi_route_breakForLoop *abi_route_continueForLoop *abi_route_breakDoWhileLoop *abi_route_continueDoWhileLoop

	// this contract does not implement the given ABI method for call NoOp
	err", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/LoopsTest.arc56_draft.json b/tests/contracts/artifacts/LoopsTest.arc56_draft.json index 3e9329193..d7eeb42e0 100644 --- a/tests/contracts/artifacts/LoopsTest.arc56_draft.json +++ b/tests/contracts/artifacts/LoopsTest.arc56_draft.json @@ -2619,7 +2619,7 @@ } }, "source": { - "approval": "#pragma version 10
intcblock 1 0 10
bytecblock 0x151f7c75 0x

// This TEAL was generated by TEALScript v0.104.1
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// whileLoop()uint64
*abi_route_whileLoop:
	// The ABI return prefix
	byte 0x151f7c75

	// execute whileLoop()uint64
	callsub whileLoop
	itob
	concat
	log
	int 1
	return

// whileLoop(): uint64
whileLoop:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/loops.algo.ts:7
	// i = 0
	int 0
	frame_bury 0 // i: uint64

*while_0:

*while_0_continue:
	// tests/contracts/loops.algo.ts:9
	// i < 10
	frame_dig 0 // i: uint64
	int 10
	<
	bz *while_0_end

	// tests/contracts/loops.algo.ts:10
	// i = i + 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64
	b *while_0

*while_0_end:
	// tests/contracts/loops.algo.ts:13
	// return i;
	frame_dig 0 // i: uint64

	// set the subroutine return value
	frame_bury 0
	retsub

// forLoop()uint64
*abi_route_forLoop:
	// The ABI return prefix
	byte 0x151f7c75

	// execute forLoop()uint64
	callsub forLoop
	itob
	concat
	log
	int 1
	return

// forLoop(): uint64
forLoop:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// tests/contracts/loops.algo.ts:17
	// i = 0
	int 0
	frame_bury 0 // i: uint64

	// tests/contracts/loops.algo.ts:19
	// for (let j = 0; j < 10; j = j + 1)
	int 0
	frame_bury 1 // j: uint64

*for_0:
	// tests/contracts/loops.algo.ts:19
	// j < 10
	frame_dig 1 // j: uint64
	int 10
	<
	bz *for_0_end

	// tests/contracts/loops.algo.ts:20
	// i = i + 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64

*for_0_continue:
	// tests/contracts/loops.algo.ts:19
	// j = j + 1
	frame_dig 1 // j: uint64
	int 1
	+
	frame_bury 1 // j: uint64
	b *for_0

*for_0_end:
	// tests/contracts/loops.algo.ts:23
	// return i;
	frame_dig 0 // i: uint64

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 1
	retsub

// doWhileLoop()uint64
*abi_route_doWhileLoop:
	// The ABI return prefix
	byte 0x151f7c75

	// execute doWhileLoop()uint64
	callsub doWhileLoop
	itob
	concat
	log
	int 1
	return

// doWhileLoop(): uint64
doWhileLoop:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/loops.algo.ts:27
	// i = 0
	int 0
	frame_bury 0 // i: uint64

*do_while_0_statement:
	// tests/contracts/loops.algo.ts:30
	// i = i + 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64

*do_while_0:

*do_while_0_continue:
	// tests/contracts/loops.algo.ts:31
	// i < 10
	frame_dig 0 // i: uint64
	int 10
	<
	bnz *do_while_0_statement

*do_while_0_end:
	// tests/contracts/loops.algo.ts:33
	// return i;
	frame_dig 0 // i: uint64

	// set the subroutine return value
	frame_bury 0
	retsub

// breakWhileLoop()uint64
*abi_route_breakWhileLoop:
	// The ABI return prefix
	byte 0x151f7c75

	// execute breakWhileLoop()uint64
	callsub breakWhileLoop
	itob
	concat
	log
	int 1
	return

// breakWhileLoop(): uint64
breakWhileLoop:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/loops.algo.ts:37
	// i = 0
	int 0
	frame_bury 0 // i: uint64

*while_1:

*while_1_continue:
	// tests/contracts/loops.algo.ts:39
	// i < 10
	frame_dig 0 // i: uint64
	int 10
	<
	bz *while_1_end

	// tests/contracts/loops.algo.ts:40
	// i = i + 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64

	// *if0_condition
	// tests/contracts/loops.algo.ts:41
	// i === 5
	frame_dig 0 // i: uint64
	pushint 5
	==
	bz *if0_end

	// *if0_consequent
	b *while_1_end

*if0_end:
	b *while_1

*while_1_end:
	// tests/contracts/loops.algo.ts:44
	// return i;
	frame_dig 0 // i: uint64

	// set the subroutine return value
	frame_bury 0
	retsub

// continueWhileLoop()uint64
*abi_route_continueWhileLoop:
	// The ABI return prefix
	byte 0x151f7c75

	// execute continueWhileLoop()uint64
	callsub continueWhileLoop
	itob
	concat
	log
	int 1
	return

// continueWhileLoop(): uint64
continueWhileLoop:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/loops.algo.ts:48
	// i = 0
	int 0
	frame_bury 0 // i: uint64

*while_2:

*while_2_continue:
	// tests/contracts/loops.algo.ts:50
	// i < 10
	frame_dig 0 // i: uint64
	int 10
	<
	bz *while_2_end

	// *if1_condition
	// tests/contracts/loops.algo.ts:51
	// i === 5
	frame_dig 0 // i: uint64
	pushint 5
	==
	bz *if1_end

	// *if1_consequent
	// tests/contracts/loops.algo.ts:52
	// i = 1337
	pushint 1337
	frame_bury 0 // i: uint64
	b *while_2_continue

*if1_end:
	// tests/contracts/loops.algo.ts:55
	// i = i + 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64
	b *while_2

*while_2_end:
	// tests/contracts/loops.algo.ts:58
	// return i;
	frame_dig 0 // i: uint64

	// set the subroutine return value
	frame_bury 0
	retsub

// breakForLoop()uint64
*abi_route_breakForLoop:
	// The ABI return prefix
	byte 0x151f7c75

	// execute breakForLoop()uint64
	callsub breakForLoop
	itob
	concat
	log
	int 1
	return

// breakForLoop(): uint64
breakForLoop:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// tests/contracts/loops.algo.ts:62
	// i = 0
	int 0
	frame_bury 0 // i: uint64

	// tests/contracts/loops.algo.ts:64
	// for (let j = 0; j < 10; j = j + 1)
	int 0
	frame_bury 1 // j: uint64

*for_1:
	// tests/contracts/loops.algo.ts:64
	// j < 10
	frame_dig 1 // j: uint64
	int 10
	<
	bz *for_1_end

	// tests/contracts/loops.algo.ts:65
	// i = i + 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64

	// *if2_condition
	// tests/contracts/loops.algo.ts:66
	// i === 5
	frame_dig 0 // i: uint64
	pushint 5
	==
	bz *if2_end

	// *if2_consequent
	b *for_1_end

*if2_end:

*for_1_continue:
	// tests/contracts/loops.algo.ts:64
	// j = j + 1
	frame_dig 1 // j: uint64
	int 1
	+
	frame_bury 1 // j: uint64
	b *for_1

*for_1_end:
	// tests/contracts/loops.algo.ts:69
	// return i;
	frame_dig 0 // i: uint64

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 1
	retsub

// continueForLoop()uint64
*abi_route_continueForLoop:
	// The ABI return prefix
	byte 0x151f7c75

	// execute continueForLoop()uint64
	callsub continueForLoop
	itob
	concat
	log
	int 1
	return

// continueForLoop(): uint64
continueForLoop:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// tests/contracts/loops.algo.ts:73
	// i = 0
	int 0
	frame_bury 0 // i: uint64

	// tests/contracts/loops.algo.ts:75
	// for (let j = 0; j < 10; j = j + 1)
	int 0
	frame_bury 1 // j: uint64

*for_2:
	// tests/contracts/loops.algo.ts:75
	// j < 10
	frame_dig 1 // j: uint64
	int 10
	<
	bz *for_2_end

	// *if3_condition
	// tests/contracts/loops.algo.ts:76
	// i === 5
	frame_dig 0 // i: uint64
	pushint 5
	==
	bz *if3_end

	// *if3_consequent
	// tests/contracts/loops.algo.ts:77
	// i = 1337
	pushint 1337
	frame_bury 0 // i: uint64
	b *for_2_continue

*if3_end:
	// tests/contracts/loops.algo.ts:80
	// i = i + 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64

*for_2_continue:
	// tests/contracts/loops.algo.ts:75
	// j = j + 1
	frame_dig 1 // j: uint64
	int 1
	+
	frame_bury 1 // j: uint64
	b *for_2

*for_2_end:
	// tests/contracts/loops.algo.ts:83
	// return i;
	frame_dig 0 // i: uint64

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 1
	retsub

// breakDoWhileLoop()uint64
*abi_route_breakDoWhileLoop:
	// The ABI return prefix
	byte 0x151f7c75

	// execute breakDoWhileLoop()uint64
	callsub breakDoWhileLoop
	itob
	concat
	log
	int 1
	return

// breakDoWhileLoop(): uint64
breakDoWhileLoop:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/loops.algo.ts:87
	// i = 0
	int 0
	frame_bury 0 // i: uint64

*do_while_1_statement:
	// tests/contracts/loops.algo.ts:90
	// i = i + 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64

	// *if4_condition
	// tests/contracts/loops.algo.ts:91
	// i === 5
	frame_dig 0 // i: uint64
	pushint 5
	==
	bz *if4_end

	// *if4_consequent
	b *do_while_1_end

*if4_end:

*do_while_1:

*do_while_1_continue:
	// tests/contracts/loops.algo.ts:92
	// i < 10
	frame_dig 0 // i: uint64
	int 10
	<
	bnz *do_while_1_statement

*do_while_1_end:
	// tests/contracts/loops.algo.ts:94
	// return i;
	frame_dig 0 // i: uint64

	// set the subroutine return value
	frame_bury 0
	retsub

// continueDoWhileLoop()uint64
*abi_route_continueDoWhileLoop:
	// The ABI return prefix
	byte 0x151f7c75

	// execute continueDoWhileLoop()uint64
	callsub continueDoWhileLoop
	itob
	concat
	log
	int 1
	return

// continueDoWhileLoop(): uint64
continueDoWhileLoop:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/loops.algo.ts:98
	// i = 0
	int 0
	frame_bury 0 // i: uint64

*do_while_2_statement:
	// *if5_condition
	// tests/contracts/loops.algo.ts:101
	// i === 5
	frame_dig 0 // i: uint64
	pushint 5
	==
	bz *if5_end

	// *if5_consequent
	// tests/contracts/loops.algo.ts:102
	// i = 1337
	pushint 1337
	frame_bury 0 // i: uint64
	b *do_while_2_continue

*if5_end:
	// tests/contracts/loops.algo.ts:105
	// i = i + 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64

*do_while_2:

*do_while_2_continue:
	// tests/contracts/loops.algo.ts:106
	// i < 10
	frame_dig 0 // i: uint64
	int 10
	<
	bnz *do_while_2_statement

*do_while_2_end:
	// tests/contracts/loops.algo.ts:108
	// return i;
	frame_dig 0 // i: uint64

	// set the subroutine return value
	frame_bury 0
	retsub

*abi_route_createApplication:
	int 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0xe164bbd9 // method "whileLoop()uint64"
	pushbytes 0x5b3ed9f6 // method "forLoop()uint64"
	pushbytes 0x1d861a3d // method "doWhileLoop()uint64"
	pushbytes 0x821fe829 // method "breakWhileLoop()uint64"
	pushbytes 0x8d15280a // method "continueWhileLoop()uint64"
	pushbytes 0x6897cf5e // method "breakForLoop()uint64"
	pushbytes 0x99cbacab // method "continueForLoop()uint64"
	pushbytes 0x86d5edd3 // method "breakDoWhileLoop()uint64"
	pushbytes 0xe01d9d42 // method "continueDoWhileLoop()uint64"
	txna ApplicationArgs 0
	match *abi_route_whileLoop *abi_route_forLoop *abi_route_doWhileLoop *abi_route_breakWhileLoop *abi_route_continueWhileLoop *abi_route_breakForLoop *abi_route_continueForLoop *abi_route_breakDoWhileLoop *abi_route_continueDoWhileLoop

	// this contract does not implement the given ABI method for call NoOp
	err", + "approval": "#pragma version 10
intcblock 1 0 10
bytecblock 0x151f7c75 0x

// This TEAL was generated by TEALScript v0.105.0
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// whileLoop()uint64
*abi_route_whileLoop:
	// The ABI return prefix
	byte 0x151f7c75

	// execute whileLoop()uint64
	callsub whileLoop
	itob
	concat
	log
	int 1
	return

// whileLoop(): uint64
whileLoop:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/loops.algo.ts:7
	// i = 0
	int 0
	frame_bury 0 // i: uint64

*while_0:

*while_0_continue:
	// tests/contracts/loops.algo.ts:9
	// i < 10
	frame_dig 0 // i: uint64
	int 10
	<
	bz *while_0_end

	// tests/contracts/loops.algo.ts:10
	// i = i + 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64
	b *while_0

*while_0_end:
	// tests/contracts/loops.algo.ts:13
	// return i;
	frame_dig 0 // i: uint64

	// set the subroutine return value
	frame_bury 0
	retsub

// forLoop()uint64
*abi_route_forLoop:
	// The ABI return prefix
	byte 0x151f7c75

	// execute forLoop()uint64
	callsub forLoop
	itob
	concat
	log
	int 1
	return

// forLoop(): uint64
forLoop:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// tests/contracts/loops.algo.ts:17
	// i = 0
	int 0
	frame_bury 0 // i: uint64

	// tests/contracts/loops.algo.ts:19
	// for (let j = 0; j < 10; j = j + 1)
	int 0
	frame_bury 1 // j: uint64

*for_0:
	// tests/contracts/loops.algo.ts:19
	// j < 10
	frame_dig 1 // j: uint64
	int 10
	<
	bz *for_0_end

	// tests/contracts/loops.algo.ts:20
	// i = i + 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64

*for_0_continue:
	// tests/contracts/loops.algo.ts:19
	// j = j + 1
	frame_dig 1 // j: uint64
	int 1
	+
	frame_bury 1 // j: uint64
	b *for_0

*for_0_end:
	// tests/contracts/loops.algo.ts:23
	// return i;
	frame_dig 0 // i: uint64

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 1
	retsub

// doWhileLoop()uint64
*abi_route_doWhileLoop:
	// The ABI return prefix
	byte 0x151f7c75

	// execute doWhileLoop()uint64
	callsub doWhileLoop
	itob
	concat
	log
	int 1
	return

// doWhileLoop(): uint64
doWhileLoop:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/loops.algo.ts:27
	// i = 0
	int 0
	frame_bury 0 // i: uint64

*do_while_0_statement:
	// tests/contracts/loops.algo.ts:30
	// i = i + 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64

*do_while_0:

*do_while_0_continue:
	// tests/contracts/loops.algo.ts:31
	// i < 10
	frame_dig 0 // i: uint64
	int 10
	<
	bnz *do_while_0_statement

*do_while_0_end:
	// tests/contracts/loops.algo.ts:33
	// return i;
	frame_dig 0 // i: uint64

	// set the subroutine return value
	frame_bury 0
	retsub

// breakWhileLoop()uint64
*abi_route_breakWhileLoop:
	// The ABI return prefix
	byte 0x151f7c75

	// execute breakWhileLoop()uint64
	callsub breakWhileLoop
	itob
	concat
	log
	int 1
	return

// breakWhileLoop(): uint64
breakWhileLoop:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/loops.algo.ts:37
	// i = 0
	int 0
	frame_bury 0 // i: uint64

*while_1:

*while_1_continue:
	// tests/contracts/loops.algo.ts:39
	// i < 10
	frame_dig 0 // i: uint64
	int 10
	<
	bz *while_1_end

	// tests/contracts/loops.algo.ts:40
	// i = i + 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64

	// *if0_condition
	// tests/contracts/loops.algo.ts:41
	// i === 5
	frame_dig 0 // i: uint64
	pushint 5
	==
	bz *if0_end

	// *if0_consequent
	b *while_1_end

*if0_end:
	b *while_1

*while_1_end:
	// tests/contracts/loops.algo.ts:44
	// return i;
	frame_dig 0 // i: uint64

	// set the subroutine return value
	frame_bury 0
	retsub

// continueWhileLoop()uint64
*abi_route_continueWhileLoop:
	// The ABI return prefix
	byte 0x151f7c75

	// execute continueWhileLoop()uint64
	callsub continueWhileLoop
	itob
	concat
	log
	int 1
	return

// continueWhileLoop(): uint64
continueWhileLoop:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/loops.algo.ts:48
	// i = 0
	int 0
	frame_bury 0 // i: uint64

*while_2:

*while_2_continue:
	// tests/contracts/loops.algo.ts:50
	// i < 10
	frame_dig 0 // i: uint64
	int 10
	<
	bz *while_2_end

	// *if1_condition
	// tests/contracts/loops.algo.ts:51
	// i === 5
	frame_dig 0 // i: uint64
	pushint 5
	==
	bz *if1_end

	// *if1_consequent
	// tests/contracts/loops.algo.ts:52
	// i = 1337
	pushint 1337
	frame_bury 0 // i: uint64
	b *while_2_continue

*if1_end:
	// tests/contracts/loops.algo.ts:55
	// i = i + 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64
	b *while_2

*while_2_end:
	// tests/contracts/loops.algo.ts:58
	// return i;
	frame_dig 0 // i: uint64

	// set the subroutine return value
	frame_bury 0
	retsub

// breakForLoop()uint64
*abi_route_breakForLoop:
	// The ABI return prefix
	byte 0x151f7c75

	// execute breakForLoop()uint64
	callsub breakForLoop
	itob
	concat
	log
	int 1
	return

// breakForLoop(): uint64
breakForLoop:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// tests/contracts/loops.algo.ts:62
	// i = 0
	int 0
	frame_bury 0 // i: uint64

	// tests/contracts/loops.algo.ts:64
	// for (let j = 0; j < 10; j = j + 1)
	int 0
	frame_bury 1 // j: uint64

*for_1:
	// tests/contracts/loops.algo.ts:64
	// j < 10
	frame_dig 1 // j: uint64
	int 10
	<
	bz *for_1_end

	// tests/contracts/loops.algo.ts:65
	// i = i + 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64

	// *if2_condition
	// tests/contracts/loops.algo.ts:66
	// i === 5
	frame_dig 0 // i: uint64
	pushint 5
	==
	bz *if2_end

	// *if2_consequent
	b *for_1_end

*if2_end:

*for_1_continue:
	// tests/contracts/loops.algo.ts:64
	// j = j + 1
	frame_dig 1 // j: uint64
	int 1
	+
	frame_bury 1 // j: uint64
	b *for_1

*for_1_end:
	// tests/contracts/loops.algo.ts:69
	// return i;
	frame_dig 0 // i: uint64

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 1
	retsub

// continueForLoop()uint64
*abi_route_continueForLoop:
	// The ABI return prefix
	byte 0x151f7c75

	// execute continueForLoop()uint64
	callsub continueForLoop
	itob
	concat
	log
	int 1
	return

// continueForLoop(): uint64
continueForLoop:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// tests/contracts/loops.algo.ts:73
	// i = 0
	int 0
	frame_bury 0 // i: uint64

	// tests/contracts/loops.algo.ts:75
	// for (let j = 0; j < 10; j = j + 1)
	int 0
	frame_bury 1 // j: uint64

*for_2:
	// tests/contracts/loops.algo.ts:75
	// j < 10
	frame_dig 1 // j: uint64
	int 10
	<
	bz *for_2_end

	// *if3_condition
	// tests/contracts/loops.algo.ts:76
	// i === 5
	frame_dig 0 // i: uint64
	pushint 5
	==
	bz *if3_end

	// *if3_consequent
	// tests/contracts/loops.algo.ts:77
	// i = 1337
	pushint 1337
	frame_bury 0 // i: uint64
	b *for_2_continue

*if3_end:
	// tests/contracts/loops.algo.ts:80
	// i = i + 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64

*for_2_continue:
	// tests/contracts/loops.algo.ts:75
	// j = j + 1
	frame_dig 1 // j: uint64
	int 1
	+
	frame_bury 1 // j: uint64
	b *for_2

*for_2_end:
	// tests/contracts/loops.algo.ts:83
	// return i;
	frame_dig 0 // i: uint64

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 1
	retsub

// breakDoWhileLoop()uint64
*abi_route_breakDoWhileLoop:
	// The ABI return prefix
	byte 0x151f7c75

	// execute breakDoWhileLoop()uint64
	callsub breakDoWhileLoop
	itob
	concat
	log
	int 1
	return

// breakDoWhileLoop(): uint64
breakDoWhileLoop:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/loops.algo.ts:87
	// i = 0
	int 0
	frame_bury 0 // i: uint64

*do_while_1_statement:
	// tests/contracts/loops.algo.ts:90
	// i = i + 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64

	// *if4_condition
	// tests/contracts/loops.algo.ts:91
	// i === 5
	frame_dig 0 // i: uint64
	pushint 5
	==
	bz *if4_end

	// *if4_consequent
	b *do_while_1_end

*if4_end:

*do_while_1:

*do_while_1_continue:
	// tests/contracts/loops.algo.ts:92
	// i < 10
	frame_dig 0 // i: uint64
	int 10
	<
	bnz *do_while_1_statement

*do_while_1_end:
	// tests/contracts/loops.algo.ts:94
	// return i;
	frame_dig 0 // i: uint64

	// set the subroutine return value
	frame_bury 0
	retsub

// continueDoWhileLoop()uint64
*abi_route_continueDoWhileLoop:
	// The ABI return prefix
	byte 0x151f7c75

	// execute continueDoWhileLoop()uint64
	callsub continueDoWhileLoop
	itob
	concat
	log
	int 1
	return

// continueDoWhileLoop(): uint64
continueDoWhileLoop:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/loops.algo.ts:98
	// i = 0
	int 0
	frame_bury 0 // i: uint64

*do_while_2_statement:
	// *if5_condition
	// tests/contracts/loops.algo.ts:101
	// i === 5
	frame_dig 0 // i: uint64
	pushint 5
	==
	bz *if5_end

	// *if5_consequent
	// tests/contracts/loops.algo.ts:102
	// i = 1337
	pushint 1337
	frame_bury 0 // i: uint64
	b *do_while_2_continue

*if5_end:
	// tests/contracts/loops.algo.ts:105
	// i = i + 1
	frame_dig 0 // i: uint64
	int 1
	+
	frame_bury 0 // i: uint64

*do_while_2:

*do_while_2_continue:
	// tests/contracts/loops.algo.ts:106
	// i < 10
	frame_dig 0 // i: uint64
	int 10
	<
	bnz *do_while_2_statement

*do_while_2_end:
	// tests/contracts/loops.algo.ts:108
	// return i;
	frame_dig 0 // i: uint64

	// set the subroutine return value
	frame_bury 0
	retsub

*abi_route_createApplication:
	int 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0xe164bbd9 // method "whileLoop()uint64"
	pushbytes 0x5b3ed9f6 // method "forLoop()uint64"
	pushbytes 0x1d861a3d // method "doWhileLoop()uint64"
	pushbytes 0x821fe829 // method "breakWhileLoop()uint64"
	pushbytes 0x8d15280a // method "continueWhileLoop()uint64"
	pushbytes 0x6897cf5e // method "breakForLoop()uint64"
	pushbytes 0x99cbacab // method "continueForLoop()uint64"
	pushbytes 0x86d5edd3 // method "breakDoWhileLoop()uint64"
	pushbytes 0xe01d9d42 // method "continueDoWhileLoop()uint64"
	txna ApplicationArgs 0
	match *abi_route_whileLoop *abi_route_forLoop *abi_route_doWhileLoop *abi_route_breakWhileLoop *abi_route_continueWhileLoop *abi_route_breakForLoop *abi_route_continueForLoop *abi_route_breakDoWhileLoop *abi_route_continueDoWhileLoop

	// this contract does not implement the given ABI method for call NoOp
	err", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/LsigWithArgs.lsig.teal b/tests/contracts/artifacts/LsigWithArgs.lsig.teal index 641cf9a49..06a727bf7 100644 --- a/tests/contracts/artifacts/LsigWithArgs.lsig.teal +++ b/tests/contracts/artifacts/LsigWithArgs.lsig.teal @@ -1,7 +1,7 @@ #pragma version 10 //#pragma mode logicsig -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // The address of this logic signature is HTZL6FOAXBW7MXZ354G5XRU3U2B6YKXKJ2U3FW5QKPEBNG2QPLBCDKEEFA diff --git a/tests/contracts/artifacts/LsigWithPrivateMethod.lsig.teal b/tests/contracts/artifacts/LsigWithPrivateMethod.lsig.teal index 1bd422625..f7fc4796e 100644 --- a/tests/contracts/artifacts/LsigWithPrivateMethod.lsig.teal +++ b/tests/contracts/artifacts/LsigWithPrivateMethod.lsig.teal @@ -1,7 +1,7 @@ #pragma version 10 //#pragma mode logicsig -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // The address of this logic signature is XHCDBSJV2RSI57VXF3Q6RVCZAEQ53K5EMO3ORFRYM2FVX3OLCNYWYWJ3YA diff --git a/tests/contracts/artifacts/MathTest.approval.teal b/tests/contracts/artifacts/MathTest.approval.teal index cf4585dff..b397565f6 100644 --- a/tests/contracts/artifacts/MathTest.approval.teal +++ b/tests/contracts/artifacts/MathTest.approval.teal @@ -2,7 +2,7 @@ intcblock 1 32 256 18446744073709551615 bytecblock 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF 0x151f7c75 0x0000000000000000000000000000000000000000000000000000000000000001 0x00000000000000000000000000000000000000000000000000000000000003e8 0x626f784b6579 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF 0x 0x674b6579 0xFFFFFFFFFFFFFFFF -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/MathTest.arc32.json b/tests/contracts/artifacts/MathTest.arc32.json index 8f5aaa870..3d47ec8b1 100644 --- a/tests/contracts/artifacts/MathTest.arc32.json +++ b/tests/contracts/artifacts/MathTest.arc32.json @@ -249,7 +249,7 @@ } }, "source": { - "approval": "#pragma version 10
intcblock 1 32 256 18446744073709551615
bytecblock 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF 0x151f7c75 0x0000000000000000000000000000000000000000000000000000000000000001 0x00000000000000000000000000000000000000000000000000000000000003e8 0x626f784b6579 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF 0x 0x674b6579 0xFFFFFFFFFFFFFFFF

// This TEAL was generated by TEALScript v0.104.1
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// u64plus(uint64,uint64)uint64
*abi_route_u64plus:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute u64plus(uint64,uint64)uint64
	callsub u64plus
	itob
	concat
	log
	int 1
	return

// u64plus(a: uint64, b: uint64): uint64
u64plus:
	proto 2 1

	// tests/contracts/math.algo.ts:8
	// return a + b;
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	+
	retsub

// u64minus(uint64,uint64)uint64
*abi_route_u64minus:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute u64minus(uint64,uint64)uint64
	callsub u64minus
	itob
	concat
	log
	int 1
	return

// u64minus(a: uint64, b: uint64): uint64
u64minus:
	proto 2 1

	// tests/contracts/math.algo.ts:12
	// return a - b;
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	-
	retsub

// u64mul(uint64,uint64)uint64
*abi_route_u64mul:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute u64mul(uint64,uint64)uint64
	callsub u64mul
	itob
	concat
	log
	int 1
	return

// u64mul(a: uint64, b: uint64): uint64
u64mul:
	proto 2 1

	// tests/contracts/math.algo.ts:16
	// return a * b;
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	*
	retsub

// u64div(uint64,uint64)uint64
*abi_route_u64div:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute u64div(uint64,uint64)uint64
	callsub u64div
	itob
	concat
	log
	int 1
	return

// u64div(a: uint64, b: uint64): uint64
u64div:
	proto 2 1

	// tests/contracts/math.algo.ts:20
	// return a / b;
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	/
	retsub

// u256plus(uint256,uint256)uint256
*abi_route_u256plus:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint256
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (b) for u256plus must be a uint256
	assert

	// a: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (a) for u256plus must be a uint256
	assert

	// execute u256plus(uint256,uint256)uint256
	callsub u256plus
	dup
	bitlen
	int 256
	<=

	// u256plus return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// u256plus(a: uint256, b: uint256): uint256
u256plus:
	proto 2 1

	// tests/contracts/math.algo.ts:24
	// return <uint256>(a + b);
	frame_dig -1 // a: uint256
	frame_dig -2 // b: uint256
	b+
	retsub

// u256minus(uint256,uint256)uint256
*abi_route_u256minus:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint256
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (b) for u256minus must be a uint256
	assert

	// a: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (a) for u256minus must be a uint256
	assert

	// execute u256minus(uint256,uint256)uint256
	callsub u256minus
	dup
	bitlen
	int 256
	<=

	// u256minus return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// u256minus(a: uint256, b: uint256): uint256
u256minus:
	proto 2 1

	// tests/contracts/math.algo.ts:28
	// return <uint256>(a - b);
	frame_dig -1 // a: uint256
	frame_dig -2 // b: uint256
	b-
	retsub

// u256mul(uint256,uint256)uint256
*abi_route_u256mul:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint256
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (b) for u256mul must be a uint256
	assert

	// a: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (a) for u256mul must be a uint256
	assert

	// execute u256mul(uint256,uint256)uint256
	callsub u256mul
	dup
	bitlen
	int 256
	<=

	// u256mul return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// u256mul(a: uint256, b: uint256): uint256
u256mul:
	proto 2 1

	// tests/contracts/math.algo.ts:32
	// return <uint256>(a * b);
	frame_dig -1 // a: uint256
	frame_dig -2 // b: uint256
	b*
	retsub

// u256div(uint256,uint256)uint256
*abi_route_u256div:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint256
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (b) for u256div must be a uint256
	assert

	// a: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (a) for u256div must be a uint256
	assert

	// execute u256div(uint256,uint256)uint256
	callsub u256div
	dup
	bitlen
	int 256
	<=

	// u256div return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// u256div(a: uint256, b: uint256): uint256
u256div:
	proto 2 1

	// tests/contracts/math.algo.ts:36
	// return <uint256>(a / b);
	frame_dig -1 // a: uint256
	frame_dig -2 // b: uint256
	b/
	retsub

// u64Return256(uint64,uint64)uint256
*abi_route_u64Return256:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute u64Return256(uint64,uint64)uint256
	callsub u64Return256
	dup
	bitlen
	int 256
	<=

	// u64Return256 return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// u64Return256(a: uint64, b: uint64): uint256
u64Return256:
	proto 2 1

	// tests/contracts/math.algo.ts:40
	// return <uint256>(a + b);
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	+
	itob
	retsub

// maxU64()uint64
*abi_route_maxU64:
	// The ABI return prefix
	byte 0x151f7c75

	// execute maxU64()uint64
	callsub maxU64
	itob
	concat
	log
	int 1
	return

// maxU64(): uint64
maxU64:
	proto 0 1

	// tests/contracts/math.algo.ts:44
	// return Uint<64>('18446744073709551615');
	int 18446744073709551615
	retsub

// exponent(uint64,uint64)uint64
*abi_route_exponent:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute exponent(uint64,uint64)uint64
	callsub exponent
	itob
	concat
	log
	int 1
	return

// exponent(a: uint64, b: uint64): uint64
exponent:
	proto 2 1

	// tests/contracts/math.algo.ts:48
	// return a ** b;
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	exp
	retsub

// variableTypeHint(uint8,uint8)uint16
*abi_route_variableTypeHint:
	// The ABI return prefix
	byte 0x151f7c75

	// y: uint8
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 0 (y) for variableTypeHint must be a uint8
	assert
	btoi

	// x: uint8
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 1 (x) for variableTypeHint must be a uint8
	assert
	btoi

	// execute variableTypeHint(uint8,uint8)uint16
	callsub variableTypeHint
	itob
	dup
	bitlen
	pushint 16
	<=

	// variableTypeHint return value overflowed 16 bits
	assert
	extract 6 2
	concat
	log
	int 1
	return

// variableTypeHint(x: uint<8>, y: uint<8>): uint16
variableTypeHint:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/math.algo.ts:52
	// z = <uint16>(x + y)
	frame_dig -1 // x: uint<8>
	frame_dig -2 // y: uint<8>
	+
	frame_bury 0 // z: unsafe uint16

	// tests/contracts/math.algo.ts:54
	// return z;
	frame_dig 0 // z: unsafe uint16

	// set the subroutine return value
	frame_bury 0
	retsub

// uint8plus(uint8,uint8)uint8
*abi_route_uint8plus:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint8
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 0 (b) for uint8plus must be a uint8
	assert
	btoi

	// a: uint8
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 1 (a) for uint8plus must be a uint8
	assert
	btoi

	// execute uint8plus(uint8,uint8)uint8
	callsub uint8plus
	itob
	dup
	bitlen
	pushint 8
	<=

	// uint8plus return value overflowed 8 bits
	assert
	extract 7 1
	concat
	log
	int 1
	return

// uint8plus(a: uint<8>, b: uint<8>): uint<8>
uint8plus:
	proto 2 1

	// tests/contracts/math.algo.ts:58
	// return a + b;
	frame_dig -1 // a: uint<8>
	frame_dig -2 // b: uint<8>
	+
	retsub

// uint8exp(uint8,uint8)uint8
*abi_route_uint8exp:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint8
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 0 (b) for uint8exp must be a uint8
	assert
	btoi

	// a: uint8
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 1 (a) for uint8exp must be a uint8
	assert
	btoi

	// execute uint8exp(uint8,uint8)uint8
	callsub uint8exp
	itob
	dup
	bitlen
	pushint 8
	<=

	// uint8exp return value overflowed 8 bits
	assert
	extract 7 1
	concat
	log
	int 1
	return

// uint8exp(a: uint<8>, b: uint<8>): uint<8>
uint8exp:
	proto 2 1

	// tests/contracts/math.algo.ts:62
	// return a ** b;
	frame_dig -1 // a: uint<8>
	frame_dig -2 // b: uint<8>
	exp
	retsub

// plusEquals(uint64,uint64)uint64
*abi_route_plusEquals:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute plusEquals(uint64,uint64)uint64
	callsub plusEquals
	itob
	concat
	log
	int 1
	return

// plusEquals(a: uint64, b: uint64): uint64
plusEquals:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/math.algo.ts:66
	// x = a
	frame_dig -1 // a: uint64
	frame_bury 0 // x: uint64

	// tests/contracts/math.algo.ts:68
	// x += b
	frame_dig 0 // x: uint64
	frame_dig -2 // b: uint64
	+
	frame_bury 0 // x: uint64

	// tests/contracts/math.algo.ts:70
	// return x;
	frame_dig 0 // x: uint64

	// set the subroutine return value
	frame_bury 0
	retsub

// plusEqualsFromGlobal(uint64,uint64)uint64
*abi_route_plusEqualsFromGlobal:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute plusEqualsFromGlobal(uint64,uint64)uint64
	callsub plusEqualsFromGlobal
	itob
	concat
	log
	int 1
	return

// plusEqualsFromGlobal(a: uint64, b: uint64): uint64
plusEqualsFromGlobal:
	proto 2 1

	// tests/contracts/math.algo.ts:74
	// this.gKey.value = a
	byte 0x674b6579 // "gKey"
	frame_dig -1 // a: uint64
	app_global_put

	// tests/contracts/math.algo.ts:76
	// this.gKey.value += b
	byte 0x674b6579 // "gKey"
	app_global_get
	frame_dig -2 // b: uint64
	+
	byte 0x674b6579 // "gKey"
	swap
	app_global_put

	// tests/contracts/math.algo.ts:78
	// return this.gKey.value;
	byte 0x674b6579 // "gKey"
	app_global_get
	retsub

// boxTest()uint256
*abi_route_boxTest:
	// The ABI return prefix
	byte 0x151f7c75

	// execute boxTest()uint256
	callsub boxTest
	dup
	bitlen
	int 256
	<=

	// boxTest return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// boxTest(): uint256
boxTest:
	proto 0 1

	// tests/contracts/math.algo.ts:84
	// this.boxKey.value = <uint256>1
	byte 0x626f784b6579 // "boxKey"
	byte 0x0000000000000000000000000000000000000000000000000000000000000001
	box_put

	// tests/contracts/math.algo.ts:85
	// this.boxKey.value += 1
	byte 0x626f784b6579 // "boxKey"
	box_get

	// box value does not exist: this.boxKey.value
	assert
	byte 0x0000000000000000000000000000000000000000000000000000000000000001
	b+
	byte 0x626f784b6579 // "boxKey"
	dup
	bitlen
	int 256
	<=

	// this.boxKey.value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	swap
	box_put

	// tests/contracts/math.algo.ts:87
	// return this.boxKey.value;
	byte 0x626f784b6579 // "boxKey"
	box_get

	// box value does not exist: this.boxKey.value
	assert
	retsub

// foo(x: uint256): uint256
foo:
	proto 1 1

	// tests/contracts/math.algo.ts:91
	// return x;
	frame_dig -1 // x: uint256
	retsub

// unsafeMethodArgs(uint256,uint256)uint256
*abi_route_unsafeMethodArgs:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint256
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (b) for unsafeMethodArgs must be a uint256
	assert

	// a: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (a) for unsafeMethodArgs must be a uint256
	assert

	// execute unsafeMethodArgs(uint256,uint256)uint256
	callsub unsafeMethodArgs
	dup
	bitlen
	int 256
	<=

	// unsafeMethodArgs return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// unsafeMethodArgs(a: uint256, b: uint256): uint256
unsafeMethodArgs:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/math.algo.ts:95
	// c = a + b
	frame_dig -1 // a: uint256
	frame_dig -2 // b: uint256
	b+
	frame_bury 0 // c: unsafe uint256

	// tests/contracts/math.algo.ts:97
	// return this.foo(c);
	frame_dig 0 // c: unsafe uint256
	dup
	bitlen
	int 256
	<=

	// c overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	callsub foo

	// set the subroutine return value
	frame_bury 0
	retsub

// uint256ComparisonType(uint256,uint256)void
*abi_route_uint256ComparisonType:
	// b: uint256
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (b) for uint256ComparisonType must be a uint256
	assert

	// a: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (a) for uint256ComparisonType must be a uint256
	assert

	// execute uint256ComparisonType(uint256,uint256)void
	callsub uint256ComparisonType
	int 1
	return

// uint256ComparisonType(a: uint256, b: uint256): void
uint256ComparisonType:
	proto 2 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/math.algo.ts:101
	// senderBalanceAfter = a - b
	frame_dig -1 // a: uint256
	frame_dig -2 // b: uint256
	b-
	frame_bury 0 // senderBalanceAfter: unsafe uint256

	// *if0_condition
	// tests/contracts/math.algo.ts:102
	// senderBalanceAfter > <uint256>0
	frame_dig 0 // senderBalanceAfter: unsafe uint256
	pushbytes 0x0000000000000000000000000000000000000000000000000000000000000000
	b>
	bz *if0_else

	// *if0_consequent
	// tests/contracts/math.algo.ts:103
	// log('nonZero')
	pushbytes 0x6e6f6e5a65726f // "nonZero"
	log
	b *if0_end

*if0_else:
	// tests/contracts/math.algo.ts:105
	// log('zero')
	pushbytes 0x7a65726f // "zero"
	log

*if0_end:
	retsub

// squareRoot256(uint256,uint256)uint256
*abi_route_squareRoot256:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint256
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (b) for squareRoot256 must be a uint256
	assert

	// a: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (a) for squareRoot256 must be a uint256
	assert

	// execute squareRoot256(uint256,uint256)uint256
	callsub squareRoot256
	dup
	bitlen
	int 256
	<=

	// squareRoot256 return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// squareRoot256(a: uint256, b: uint256): uint256
squareRoot256:
	proto 2 1

	// tests/contracts/math.algo.ts:110
	// return sqrt(a * b);
	frame_dig -1 // a: uint256
	frame_dig -2 // b: uint256
	b*
	bsqrt
	retsub

// squareRoot64(uint64,uint64)uint64
*abi_route_squareRoot64:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute squareRoot64(uint64,uint64)uint64
	callsub squareRoot64
	itob
	concat
	log
	int 1
	return

// squareRoot64(a: uint64, b: uint64): uint64
squareRoot64:
	proto 2 1

	// tests/contracts/math.algo.ts:114
	// return sqrt(a * b);
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	*
	sqrt
	retsub

// addressToBigInt(address)bool
*abi_route_addressToBigInt:
	// The ABI return prefix
	byte 0x151f7c75

	// addr: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (addr) for addressToBigInt must be a address
	assert

	// execute addressToBigInt(address)bool
	callsub addressToBigInt
	pushbytes 0x00
	pushint 0
	uncover 2
	setbit
	concat
	log
	int 1
	return

// addressToBigInt(addr: Address): boolean
addressToBigInt:
	proto 1 1

	// tests/contracts/math.algo.ts:118
	// return btobigint(addr) > btobigint(this.txn.sender);
	frame_dig -1 // addr: Address
	txn Sender
	b>
	retsub

// u8Tou64()uint64
*abi_route_u8Tou64:
	// The ABI return prefix
	byte 0x151f7c75

	// execute u8Tou64()uint64
	callsub u8Tou64
	itob
	concat
	log
	int 1
	return

// u8Tou64(): uint64
u8Tou64:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/math.algo.ts:122
	// x: uint8 = 7
	pushint 7
	frame_bury 0 // x: uint8

	// tests/contracts/math.algo.ts:123
	// return <uint64>x;
	frame_dig 0 // x: uint8

	// set the subroutine return value
	frame_bury 0
	retsub

// privateFuncName(x: uint8, y: uint64): void
privateFuncName:
	proto 2 0

	// tests/contracts/math.algo.ts:127
	// assert(<uint8>y > x)
	frame_dig -2 // y: uint64
	frame_dig -1 // x: uint8
	>
	assert
	retsub

// funcName(uint256)void
*abi_route_funcName:
	// x: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (x) for funcName must be a uint256
	assert

	// execute funcName(uint256)void
	callsub funcName
	int 1
	return

// funcName(x: uint256): void
funcName:
	proto 1 0

	// tests/contracts/math.algo.ts:131
	// this.privateFuncName(<uint8>x, 1337)
	pushint 1337
	frame_dig -1 // x: uint256
	dup
	bitlen
	pushint 8
	<=

	// <uint8>x overflowed 8 bits
	assert
	extract 31 1
	btoi
	callsub privateFuncName
	retsub

// bigintPlus(uint64,uint64)uint64
*abi_route_bigintPlus:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute bigintPlus(uint64,uint64)uint64
	callsub bigintPlus
	itob
	concat
	log
	int 1
	return

// bigintPlus(a: uint64, b: uint64): uint64
bigintPlus:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// tests/contracts/math.algo.ts:135
	// x = itob(a)
	frame_dig -1 // a: uint64
	itob
	frame_bury 0 // x: byte[]

	// tests/contracts/math.algo.ts:136
	// y = itob(b)
	frame_dig -2 // b: uint64
	itob
	frame_bury 1 // y: byte[]

	// tests/contracts/math.algo.ts:137
	// return (btobigint(x) + btobigint(y)) as uint64;
	frame_dig 0 // x: byte[]
	frame_dig 1 // y: byte[]
	b+
	dup
	bitlen
	pushint 64
	<=

	// (btobigint(x) + btobigint(y)) as uint64 overflowed 64 bits
	assert
	byte 0xFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	pushint 8
	-
	swap
	substring3
	btoi

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 1
	retsub

// bitwiseOr(uint64,uint64)uint64
*abi_route_bitwiseOr:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute bitwiseOr(uint64,uint64)uint64
	callsub bitwiseOr
	itob
	concat
	log
	int 1
	return

// bitwiseOr(a: uint64, b: uint64): uint64
bitwiseOr:
	proto 2 1

	// tests/contracts/math.algo.ts:141
	// return a | b;
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	|
	retsub

// bitwiseAnd(uint64,uint64)uint64
*abi_route_bitwiseAnd:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute bitwiseAnd(uint64,uint64)uint64
	callsub bitwiseAnd
	itob
	concat
	log
	int 1
	return

// bitwiseAnd(a: uint64, b: uint64): uint64
bitwiseAnd:
	proto 2 1

	// tests/contracts/math.algo.ts:145
	// return a & b;
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	&
	retsub

// bitwiseXor(uint64,uint64)uint64
*abi_route_bitwiseXor:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute bitwiseXor(uint64,uint64)uint64
	callsub bitwiseXor
	itob
	concat
	log
	int 1
	return

// bitwiseXor(a: uint64, b: uint64): uint64
bitwiseXor:
	proto 2 1

	// tests/contracts/math.algo.ts:149
	// return a ^ b;
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	^
	retsub

// bitwiseOrU256(uint256,uint256)uint256
*abi_route_bitwiseOrU256:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint256
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (b) for bitwiseOrU256 must be a uint256
	assert

	// a: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (a) for bitwiseOrU256 must be a uint256
	assert

	// execute bitwiseOrU256(uint256,uint256)uint256
	callsub bitwiseOrU256
	dup
	bitlen
	int 256
	<=

	// bitwiseOrU256 return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// bitwiseOrU256(a: uint256, b: uint256): uint256
bitwiseOrU256:
	proto 2 1

	// tests/contracts/math.algo.ts:153
	// return a | b;
	frame_dig -1 // a: uint256
	frame_dig -2 // b: uint256
	b|
	retsub

// bitwiseAndU256(uint256,uint256)uint256
*abi_route_bitwiseAndU256:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint256
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (b) for bitwiseAndU256 must be a uint256
	assert

	// a: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (a) for bitwiseAndU256 must be a uint256
	assert

	// execute bitwiseAndU256(uint256,uint256)uint256
	callsub bitwiseAndU256
	dup
	bitlen
	int 256
	<=

	// bitwiseAndU256 return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// bitwiseAndU256(a: uint256, b: uint256): uint256
bitwiseAndU256:
	proto 2 1

	// tests/contracts/math.algo.ts:157
	// return a & b;
	frame_dig -1 // a: uint256
	frame_dig -2 // b: uint256
	b&
	retsub

// bitwiseXorU256(uint256,uint256)uint256
*abi_route_bitwiseXorU256:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint256
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (b) for bitwiseXorU256 must be a uint256
	assert

	// a: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (a) for bitwiseXorU256 must be a uint256
	assert

	// execute bitwiseXorU256(uint256,uint256)uint256
	callsub bitwiseXorU256
	dup
	bitlen
	int 256
	<=

	// bitwiseXorU256 return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// bitwiseXorU256(a: uint256, b: uint256): uint256
bitwiseXorU256:
	proto 2 1

	// tests/contracts/math.algo.ts:161
	// return a ^ b;
	frame_dig -1 // a: uint256
	frame_dig -2 // b: uint256
	b^
	retsub

// bitwiseNot(uint64)uint64
*abi_route_bitwiseNot:
	// The ABI return prefix
	byte 0x151f7c75

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute bitwiseNot(uint64)uint64
	callsub bitwiseNot
	itob
	concat
	log
	int 1
	return

// bitwiseNot(a: uint64): uint64
bitwiseNot:
	proto 1 1

	// tests/contracts/math.algo.ts:165
	// return ~a;
	frame_dig -1 // a: uint64
	~
	retsub

// bitwiseNotU256(uint256)uint256
*abi_route_bitwiseNotU256:
	// The ABI return prefix
	byte 0x151f7c75

	// a: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for bitwiseNotU256 must be a uint256
	assert

	// execute bitwiseNotU256(uint256)uint256
	callsub bitwiseNotU256
	dup
	bitlen
	int 256
	<=

	// bitwiseNotU256 return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// bitwiseNotU256(a: uint256): uint256
bitwiseNotU256:
	proto 1 1

	// tests/contracts/math.algo.ts:169
	// return ~a;
	frame_dig -1 // a: uint256
	b~
	retsub

// mulw(uint64,uint64)uint64
*abi_route_mulw:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute mulw(uint64,uint64)uint64
	callsub mulw
	itob
	concat
	log
	int 1
	return

// mulw(a: uint64, b: uint64): uint64
mulw:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// tests/contracts/math.algo.ts:173
	// p = mulw(a, b)
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	mulw
	frame_bury 0 // p low: uint64
	frame_bury 1 // p high: uint64

	// tests/contracts/math.algo.ts:177
	// return p2.low;
	frame_dig 0 // p low: uint64

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 1
	retsub

// addw(uint64,uint64)uint64
*abi_route_addw:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute addw(uint64,uint64)uint64
	callsub addw
	itob
	concat
	log
	int 1
	return

// addw(a: uint64, b: uint64): uint64
addw:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// tests/contracts/math.algo.ts:181
	// p = addw(a, b)
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	addw
	frame_bury 0 // p low: uint64
	frame_bury 1 // p high: uint64

	// tests/contracts/math.algo.ts:185
	// return p2.low;
	frame_dig 0 // p low: uint64

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 1
	retsub

// expw(uint64,uint64)uint64
*abi_route_expw:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute expw(uint64,uint64)uint64
	callsub expw
	itob
	concat
	log
	int 1
	return

// expw(a: uint64, b: uint64): uint64
expw:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// tests/contracts/math.algo.ts:189
	// p = expw(a, b)
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	expw
	frame_bury 0 // p low: uint64
	frame_bury 1 // p high: uint64

	// tests/contracts/math.algo.ts:193
	// return p2.low;
	frame_dig 0 // p low: uint64

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 1
	retsub

// divw(uint64,uint64)uint64
*abi_route_divw:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute divw(uint64,uint64)uint64
	callsub divw
	itob
	concat
	log
	int 1
	return

// divw(a: uint64, b: uint64): uint64
divw:
	proto 2 1

	// tests/contracts/math.algo.ts:197
	// return divw(0, a, b);
	pushint 0
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	divw
	retsub

// divmodw(uint64,uint64)uint64
*abi_route_divmodw:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute divmodw(uint64,uint64)uint64
	callsub divmodw
	itob
	concat
	log
	int 1
	return

// divmodw(a: uint64, b: uint64): uint64
divmodw:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 3

	// tests/contracts/math.algo.ts:201
	// p = divmodw(0, a, 0, b)
	pushint 0
	frame_dig -1 // a: uint64
	pushint 0
	frame_dig -2 // b: uint64
	divmodw
	frame_bury 0 // p remainderLow: uint64
	frame_bury 1 // p remainderHigh: uint64
	frame_bury 2 // p quotientLow: uint64
	frame_bury 3 // p quotientHigh: uint64

	// tests/contracts/math.algo.ts:205
	// return p2.quotientLow;
	frame_dig 2 // p quotientLow: uint64

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 3
	retsub

// unsafeVariables()uint64
*abi_route_unsafeVariables:
	// The ABI return prefix
	byte 0x151f7c75

	// execute unsafeVariables()uint64
	callsub unsafeVariables
	itob
	concat
	log
	int 1
	return

// unsafeVariables(): uint64
unsafeVariables:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// tests/contracts/math.algo.ts:209
	// A = <uint256>250000000
	pushbytes 0x000000000000000000000000000000000000000000000000000000000ee6b280
	frame_bury 0 // A: unsafe uint256

	// tests/contracts/math.algo.ts:210
	// B = <uint256>1000
	byte 0x00000000000000000000000000000000000000000000000000000000000003e8
	frame_bury 1 // B: uint256

	// tests/contracts/math.algo.ts:212
	// A = A / B
	frame_dig 0 // A: unsafe uint256
	byte 0x00000000000000000000000000000000000000000000000000000000000003e8 // B: uint256
	b/
	frame_bury 0 // A: unsafe uint256

	// tests/contracts/math.algo.ts:214
	// c = A as uint64
	frame_dig 0 // A: unsafe uint256
	dup
	bitlen
	pushint 64
	<=

	// A as uint64 overflowed 64 bits
	assert
	byte 0xFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	pushint 8
	-
	swap
	substring3
	btoi
	frame_bury 2 // c: uint64

	// tests/contracts/math.algo.ts:216
	// return c;
	frame_dig 2 // c: uint64

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 2
	retsub

// foobar(uint128)uint128
*abi_route_foobar:
	// The ABI return prefix
	byte 0x151f7c75

	// x: uint128
	txna ApplicationArgs 1
	dup
	len
	pushint 16
	==

	// argument 0 (x) for foobar must be a uint128
	assert

	// execute foobar(uint128)uint128
	callsub foobar
	dup
	bitlen
	pushint 128
	<=

	// foobar return value overflowed 128 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	pushint 16
	-
	swap
	substring3
	concat
	log
	int 1
	return

// foobar(x: uint128): uint128
foobar:
	proto 1 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/math.algo.ts:220
	// avgStake: uint128 = x / (30000 as uint128)
	frame_dig -1 // x: uint128
	pushbytes 0x00000000000000000000000000007530
	b/
	dup
	bitlen
	pushint 128
	<=

	// x / (30000 as uint128) overflowed 128 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	pushint 16
	-
	swap
	substring3
	frame_bury 0 // avgStake: uint128

	// tests/contracts/math.algo.ts:222
	// return avgStake;
	frame_dig 0 // avgStake: uint128

	// set the subroutine return value
	frame_bury 0
	retsub

// uintFromHex()uint256
*abi_route_uintFromHex:
	// The ABI return prefix
	byte 0x151f7c75

	// execute uintFromHex()uint256
	callsub uintFromHex
	dup
	bitlen
	int 256
	<=

	// uintFromHex return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// uintFromHex(): uint256
uintFromHex:
	proto 0 1

	// tests/contracts/math.algo.ts:226
	// return Uint<256>('0xFF');
	pushbytes 0x00000000000000000000000000000000000000000000000000000000000000ff
	retsub

// wideRatioTest()uint64
*abi_route_wideRatioTest:
	// The ABI return prefix
	byte 0x151f7c75

	// execute wideRatioTest()uint64
	callsub wideRatioTest
	itob
	concat
	log
	int 1
	return

// wideRatioTest(): uint64
wideRatioTest:
	proto 0 1

	// tests/contracts/math.algo.ts:230
	// return wideRatio([Uint<64>('18446744073709551615'), 2, 3, 4, 5], [2, 3, 4, 5]);
	int 18446744073709551615
	pushint 2
	mulw
	pushint 3
	uncover 2
	dig 1
	*
	cover 2
	mulw
	cover 2
	+
	swap
	pushint 4
	uncover 2
	dig 1
	*
	cover 2
	mulw
	cover 2
	+
	swap
	pushint 5
	uncover 2
	dig 1
	*
	cover 2
	mulw
	cover 2
	+
	swap
	pushint 2
	pushint 3
	mulw
	pushint 4
	uncover 2
	dig 1
	*
	cover 2
	mulw
	cover 2
	+
	swap
	pushint 5
	uncover 2
	dig 1
	*
	cover 2
	mulw
	cover 2
	+
	swap
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	retsub

*abi_route_createApplication:
	int 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x3ce6f1af // method "u64plus(uint64,uint64)uint64"
	pushbytes 0x0031a186 // method "u64minus(uint64,uint64)uint64"
	pushbytes 0xe52e4394 // method "u64mul(uint64,uint64)uint64"
	pushbytes 0x950d4789 // method "u64div(uint64,uint64)uint64"
	pushbytes 0x65bdda6e // method "u256plus(uint256,uint256)uint256"
	pushbytes 0x0a6ad284 // method "u256minus(uint256,uint256)uint256"
	pushbytes 0xf044bf24 // method "u256mul(uint256,uint256)uint256"
	pushbytes 0xc48f8c05 // method "u256div(uint256,uint256)uint256"
	pushbytes 0xf2e1d632 // method "u64Return256(uint64,uint64)uint256"
	pushbytes 0x38b1a39e // method "maxU64()uint64"
	pushbytes 0x6c136f1d // method "exponent(uint64,uint64)uint64"
	pushbytes 0x22da2502 // method "variableTypeHint(uint8,uint8)uint16"
	pushbytes 0xa2fead6c // method "uint8plus(uint8,uint8)uint8"
	pushbytes 0xd2256f7a // method "uint8exp(uint8,uint8)uint8"
	pushbytes 0xc17d624e // method "plusEquals(uint64,uint64)uint64"
	pushbytes 0x5cab0438 // method "plusEqualsFromGlobal(uint64,uint64)uint64"
	pushbytes 0x58989ccd // method "boxTest()uint256"
	pushbytes 0x4830b4de // method "unsafeMethodArgs(uint256,uint256)uint256"
	pushbytes 0xe1c55ce5 // method "uint256ComparisonType(uint256,uint256)void"
	pushbytes 0x7d1d426e // method "squareRoot256(uint256,uint256)uint256"
	pushbytes 0x1c2981f1 // method "squareRoot64(uint64,uint64)uint64"
	pushbytes 0xb7ca04b9 // method "addressToBigInt(address)bool"
	pushbytes 0xbb952338 // method "u8Tou64()uint64"
	pushbytes 0x0128e27b // method "funcName(uint256)void"
	pushbytes 0xf916cdb3 // method "bigintPlus(uint64,uint64)uint64"
	pushbytes 0x52737545 // method "bitwiseOr(uint64,uint64)uint64"
	pushbytes 0x79c1adc0 // method "bitwiseAnd(uint64,uint64)uint64"
	pushbytes 0x22474abc // method "bitwiseXor(uint64,uint64)uint64"
	pushbytes 0x0593fdf8 // method "bitwiseOrU256(uint256,uint256)uint256"
	pushbytes 0x06fb9337 // method "bitwiseAndU256(uint256,uint256)uint256"
	pushbytes 0x26493d78 // method "bitwiseXorU256(uint256,uint256)uint256"
	pushbytes 0xe9c22eea // method "bitwiseNot(uint64)uint64"
	pushbytes 0xede3e9bc // method "bitwiseNotU256(uint256)uint256"
	pushbytes 0x2e4a2164 // method "mulw(uint64,uint64)uint64"
	pushbytes 0x50134b5a // method "addw(uint64,uint64)uint64"
	pushbytes 0xf53aff9b // method "expw(uint64,uint64)uint64"
	pushbytes 0xcaf7110d // method "divw(uint64,uint64)uint64"
	pushbytes 0xbed0e386 // method "divmodw(uint64,uint64)uint64"
	pushbytes 0x274d7705 // method "unsafeVariables()uint64"
	pushbytes 0x92465d08 // method "foobar(uint128)uint128"
	pushbytes 0xf01facce // method "uintFromHex()uint256"
	pushbytes 0x5ac8a0a0 // method "wideRatioTest()uint64"
	txna ApplicationArgs 0
	match *abi_route_u64plus *abi_route_u64minus *abi_route_u64mul *abi_route_u64div *abi_route_u256plus *abi_route_u256minus *abi_route_u256mul *abi_route_u256div *abi_route_u64Return256 *abi_route_maxU64 *abi_route_exponent *abi_route_variableTypeHint *abi_route_uint8plus *abi_route_uint8exp *abi_route_plusEquals *abi_route_plusEqualsFromGlobal *abi_route_boxTest *abi_route_unsafeMethodArgs *abi_route_uint256ComparisonType *abi_route_squareRoot256 *abi_route_squareRoot64 *abi_route_addressToBigInt *abi_route_u8Tou64 *abi_route_funcName *abi_route_bigintPlus *abi_route_bitwiseOr *abi_route_bitwiseAnd *abi_route_bitwiseXor *abi_route_bitwiseOrU256 *abi_route_bitwiseAndU256 *abi_route_bitwiseXorU256 *abi_route_bitwiseNot *abi_route_bitwiseNotU256 *abi_route_mulw *abi_route_addw *abi_route_expw *abi_route_divw *abi_route_divmodw *abi_route_unsafeVariables *abi_route_foobar *abi_route_uintFromHex *abi_route_wideRatioTest

	// this contract does not implement the given ABI method for call NoOp
	err", + "approval": "#pragma version 10
intcblock 1 32 256 18446744073709551615
bytecblock 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF 0x151f7c75 0x0000000000000000000000000000000000000000000000000000000000000001 0x00000000000000000000000000000000000000000000000000000000000003e8 0x626f784b6579 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF 0x 0x674b6579 0xFFFFFFFFFFFFFFFF

// This TEAL was generated by TEALScript v0.105.0
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// u64plus(uint64,uint64)uint64
*abi_route_u64plus:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute u64plus(uint64,uint64)uint64
	callsub u64plus
	itob
	concat
	log
	int 1
	return

// u64plus(a: uint64, b: uint64): uint64
u64plus:
	proto 2 1

	// tests/contracts/math.algo.ts:8
	// return a + b;
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	+
	retsub

// u64minus(uint64,uint64)uint64
*abi_route_u64minus:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute u64minus(uint64,uint64)uint64
	callsub u64minus
	itob
	concat
	log
	int 1
	return

// u64minus(a: uint64, b: uint64): uint64
u64minus:
	proto 2 1

	// tests/contracts/math.algo.ts:12
	// return a - b;
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	-
	retsub

// u64mul(uint64,uint64)uint64
*abi_route_u64mul:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute u64mul(uint64,uint64)uint64
	callsub u64mul
	itob
	concat
	log
	int 1
	return

// u64mul(a: uint64, b: uint64): uint64
u64mul:
	proto 2 1

	// tests/contracts/math.algo.ts:16
	// return a * b;
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	*
	retsub

// u64div(uint64,uint64)uint64
*abi_route_u64div:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute u64div(uint64,uint64)uint64
	callsub u64div
	itob
	concat
	log
	int 1
	return

// u64div(a: uint64, b: uint64): uint64
u64div:
	proto 2 1

	// tests/contracts/math.algo.ts:20
	// return a / b;
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	/
	retsub

// u256plus(uint256,uint256)uint256
*abi_route_u256plus:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint256
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (b) for u256plus must be a uint256
	assert

	// a: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (a) for u256plus must be a uint256
	assert

	// execute u256plus(uint256,uint256)uint256
	callsub u256plus
	dup
	bitlen
	int 256
	<=

	// u256plus return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// u256plus(a: uint256, b: uint256): uint256
u256plus:
	proto 2 1

	// tests/contracts/math.algo.ts:24
	// return <uint256>(a + b);
	frame_dig -1 // a: uint256
	frame_dig -2 // b: uint256
	b+
	retsub

// u256minus(uint256,uint256)uint256
*abi_route_u256minus:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint256
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (b) for u256minus must be a uint256
	assert

	// a: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (a) for u256minus must be a uint256
	assert

	// execute u256minus(uint256,uint256)uint256
	callsub u256minus
	dup
	bitlen
	int 256
	<=

	// u256minus return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// u256minus(a: uint256, b: uint256): uint256
u256minus:
	proto 2 1

	// tests/contracts/math.algo.ts:28
	// return <uint256>(a - b);
	frame_dig -1 // a: uint256
	frame_dig -2 // b: uint256
	b-
	retsub

// u256mul(uint256,uint256)uint256
*abi_route_u256mul:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint256
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (b) for u256mul must be a uint256
	assert

	// a: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (a) for u256mul must be a uint256
	assert

	// execute u256mul(uint256,uint256)uint256
	callsub u256mul
	dup
	bitlen
	int 256
	<=

	// u256mul return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// u256mul(a: uint256, b: uint256): uint256
u256mul:
	proto 2 1

	// tests/contracts/math.algo.ts:32
	// return <uint256>(a * b);
	frame_dig -1 // a: uint256
	frame_dig -2 // b: uint256
	b*
	retsub

// u256div(uint256,uint256)uint256
*abi_route_u256div:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint256
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (b) for u256div must be a uint256
	assert

	// a: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (a) for u256div must be a uint256
	assert

	// execute u256div(uint256,uint256)uint256
	callsub u256div
	dup
	bitlen
	int 256
	<=

	// u256div return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// u256div(a: uint256, b: uint256): uint256
u256div:
	proto 2 1

	// tests/contracts/math.algo.ts:36
	// return <uint256>(a / b);
	frame_dig -1 // a: uint256
	frame_dig -2 // b: uint256
	b/
	retsub

// u64Return256(uint64,uint64)uint256
*abi_route_u64Return256:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute u64Return256(uint64,uint64)uint256
	callsub u64Return256
	dup
	bitlen
	int 256
	<=

	// u64Return256 return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// u64Return256(a: uint64, b: uint64): uint256
u64Return256:
	proto 2 1

	// tests/contracts/math.algo.ts:40
	// return <uint256>(a + b);
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	+
	itob
	retsub

// maxU64()uint64
*abi_route_maxU64:
	// The ABI return prefix
	byte 0x151f7c75

	// execute maxU64()uint64
	callsub maxU64
	itob
	concat
	log
	int 1
	return

// maxU64(): uint64
maxU64:
	proto 0 1

	// tests/contracts/math.algo.ts:44
	// return Uint<64>('18446744073709551615');
	int 18446744073709551615
	retsub

// exponent(uint64,uint64)uint64
*abi_route_exponent:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute exponent(uint64,uint64)uint64
	callsub exponent
	itob
	concat
	log
	int 1
	return

// exponent(a: uint64, b: uint64): uint64
exponent:
	proto 2 1

	// tests/contracts/math.algo.ts:48
	// return a ** b;
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	exp
	retsub

// variableTypeHint(uint8,uint8)uint16
*abi_route_variableTypeHint:
	// The ABI return prefix
	byte 0x151f7c75

	// y: uint8
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 0 (y) for variableTypeHint must be a uint8
	assert
	btoi

	// x: uint8
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 1 (x) for variableTypeHint must be a uint8
	assert
	btoi

	// execute variableTypeHint(uint8,uint8)uint16
	callsub variableTypeHint
	itob
	dup
	bitlen
	pushint 16
	<=

	// variableTypeHint return value overflowed 16 bits
	assert
	extract 6 2
	concat
	log
	int 1
	return

// variableTypeHint(x: uint<8>, y: uint<8>): uint16
variableTypeHint:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/math.algo.ts:52
	// z = <uint16>(x + y)
	frame_dig -1 // x: uint<8>
	frame_dig -2 // y: uint<8>
	+
	frame_bury 0 // z: unsafe uint16

	// tests/contracts/math.algo.ts:54
	// return z;
	frame_dig 0 // z: unsafe uint16

	// set the subroutine return value
	frame_bury 0
	retsub

// uint8plus(uint8,uint8)uint8
*abi_route_uint8plus:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint8
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 0 (b) for uint8plus must be a uint8
	assert
	btoi

	// a: uint8
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 1 (a) for uint8plus must be a uint8
	assert
	btoi

	// execute uint8plus(uint8,uint8)uint8
	callsub uint8plus
	itob
	dup
	bitlen
	pushint 8
	<=

	// uint8plus return value overflowed 8 bits
	assert
	extract 7 1
	concat
	log
	int 1
	return

// uint8plus(a: uint<8>, b: uint<8>): uint<8>
uint8plus:
	proto 2 1

	// tests/contracts/math.algo.ts:58
	// return a + b;
	frame_dig -1 // a: uint<8>
	frame_dig -2 // b: uint<8>
	+
	retsub

// uint8exp(uint8,uint8)uint8
*abi_route_uint8exp:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint8
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 0 (b) for uint8exp must be a uint8
	assert
	btoi

	// a: uint8
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 1 (a) for uint8exp must be a uint8
	assert
	btoi

	// execute uint8exp(uint8,uint8)uint8
	callsub uint8exp
	itob
	dup
	bitlen
	pushint 8
	<=

	// uint8exp return value overflowed 8 bits
	assert
	extract 7 1
	concat
	log
	int 1
	return

// uint8exp(a: uint<8>, b: uint<8>): uint<8>
uint8exp:
	proto 2 1

	// tests/contracts/math.algo.ts:62
	// return a ** b;
	frame_dig -1 // a: uint<8>
	frame_dig -2 // b: uint<8>
	exp
	retsub

// plusEquals(uint64,uint64)uint64
*abi_route_plusEquals:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute plusEquals(uint64,uint64)uint64
	callsub plusEquals
	itob
	concat
	log
	int 1
	return

// plusEquals(a: uint64, b: uint64): uint64
plusEquals:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/math.algo.ts:66
	// x = a
	frame_dig -1 // a: uint64
	frame_bury 0 // x: uint64

	// tests/contracts/math.algo.ts:68
	// x += b
	frame_dig 0 // x: uint64
	frame_dig -2 // b: uint64
	+
	frame_bury 0 // x: uint64

	// tests/contracts/math.algo.ts:70
	// return x;
	frame_dig 0 // x: uint64

	// set the subroutine return value
	frame_bury 0
	retsub

// plusEqualsFromGlobal(uint64,uint64)uint64
*abi_route_plusEqualsFromGlobal:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute plusEqualsFromGlobal(uint64,uint64)uint64
	callsub plusEqualsFromGlobal
	itob
	concat
	log
	int 1
	return

// plusEqualsFromGlobal(a: uint64, b: uint64): uint64
plusEqualsFromGlobal:
	proto 2 1

	// tests/contracts/math.algo.ts:74
	// this.gKey.value = a
	byte 0x674b6579 // "gKey"
	frame_dig -1 // a: uint64
	app_global_put

	// tests/contracts/math.algo.ts:76
	// this.gKey.value += b
	byte 0x674b6579 // "gKey"
	app_global_get
	frame_dig -2 // b: uint64
	+
	byte 0x674b6579 // "gKey"
	swap
	app_global_put

	// tests/contracts/math.algo.ts:78
	// return this.gKey.value;
	byte 0x674b6579 // "gKey"
	app_global_get
	retsub

// boxTest()uint256
*abi_route_boxTest:
	// The ABI return prefix
	byte 0x151f7c75

	// execute boxTest()uint256
	callsub boxTest
	dup
	bitlen
	int 256
	<=

	// boxTest return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// boxTest(): uint256
boxTest:
	proto 0 1

	// tests/contracts/math.algo.ts:84
	// this.boxKey.value = <uint256>1
	byte 0x626f784b6579 // "boxKey"
	byte 0x0000000000000000000000000000000000000000000000000000000000000001
	box_put

	// tests/contracts/math.algo.ts:85
	// this.boxKey.value += 1
	byte 0x626f784b6579 // "boxKey"
	box_get

	// box value does not exist: this.boxKey.value
	assert
	byte 0x0000000000000000000000000000000000000000000000000000000000000001
	b+
	byte 0x626f784b6579 // "boxKey"
	dup
	bitlen
	int 256
	<=

	// this.boxKey.value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	swap
	box_put

	// tests/contracts/math.algo.ts:87
	// return this.boxKey.value;
	byte 0x626f784b6579 // "boxKey"
	box_get

	// box value does not exist: this.boxKey.value
	assert
	retsub

// foo(x: uint256): uint256
foo:
	proto 1 1

	// tests/contracts/math.algo.ts:91
	// return x;
	frame_dig -1 // x: uint256
	retsub

// unsafeMethodArgs(uint256,uint256)uint256
*abi_route_unsafeMethodArgs:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint256
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (b) for unsafeMethodArgs must be a uint256
	assert

	// a: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (a) for unsafeMethodArgs must be a uint256
	assert

	// execute unsafeMethodArgs(uint256,uint256)uint256
	callsub unsafeMethodArgs
	dup
	bitlen
	int 256
	<=

	// unsafeMethodArgs return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// unsafeMethodArgs(a: uint256, b: uint256): uint256
unsafeMethodArgs:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/math.algo.ts:95
	// c = a + b
	frame_dig -1 // a: uint256
	frame_dig -2 // b: uint256
	b+
	frame_bury 0 // c: unsafe uint256

	// tests/contracts/math.algo.ts:97
	// return this.foo(c);
	frame_dig 0 // c: unsafe uint256
	dup
	bitlen
	int 256
	<=

	// c overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	callsub foo

	// set the subroutine return value
	frame_bury 0
	retsub

// uint256ComparisonType(uint256,uint256)void
*abi_route_uint256ComparisonType:
	// b: uint256
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (b) for uint256ComparisonType must be a uint256
	assert

	// a: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (a) for uint256ComparisonType must be a uint256
	assert

	// execute uint256ComparisonType(uint256,uint256)void
	callsub uint256ComparisonType
	int 1
	return

// uint256ComparisonType(a: uint256, b: uint256): void
uint256ComparisonType:
	proto 2 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/math.algo.ts:101
	// senderBalanceAfter = a - b
	frame_dig -1 // a: uint256
	frame_dig -2 // b: uint256
	b-
	frame_bury 0 // senderBalanceAfter: unsafe uint256

	// *if0_condition
	// tests/contracts/math.algo.ts:102
	// senderBalanceAfter > <uint256>0
	frame_dig 0 // senderBalanceAfter: unsafe uint256
	pushbytes 0x0000000000000000000000000000000000000000000000000000000000000000
	b>
	bz *if0_else

	// *if0_consequent
	// tests/contracts/math.algo.ts:103
	// log('nonZero')
	pushbytes 0x6e6f6e5a65726f // "nonZero"
	log
	b *if0_end

*if0_else:
	// tests/contracts/math.algo.ts:105
	// log('zero')
	pushbytes 0x7a65726f // "zero"
	log

*if0_end:
	retsub

// squareRoot256(uint256,uint256)uint256
*abi_route_squareRoot256:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint256
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (b) for squareRoot256 must be a uint256
	assert

	// a: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (a) for squareRoot256 must be a uint256
	assert

	// execute squareRoot256(uint256,uint256)uint256
	callsub squareRoot256
	dup
	bitlen
	int 256
	<=

	// squareRoot256 return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// squareRoot256(a: uint256, b: uint256): uint256
squareRoot256:
	proto 2 1

	// tests/contracts/math.algo.ts:110
	// return sqrt(a * b);
	frame_dig -1 // a: uint256
	frame_dig -2 // b: uint256
	b*
	bsqrt
	retsub

// squareRoot64(uint64,uint64)uint64
*abi_route_squareRoot64:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute squareRoot64(uint64,uint64)uint64
	callsub squareRoot64
	itob
	concat
	log
	int 1
	return

// squareRoot64(a: uint64, b: uint64): uint64
squareRoot64:
	proto 2 1

	// tests/contracts/math.algo.ts:114
	// return sqrt(a * b);
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	*
	sqrt
	retsub

// addressToBigInt(address)bool
*abi_route_addressToBigInt:
	// The ABI return prefix
	byte 0x151f7c75

	// addr: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (addr) for addressToBigInt must be a address
	assert

	// execute addressToBigInt(address)bool
	callsub addressToBigInt
	pushbytes 0x00
	pushint 0
	uncover 2
	setbit
	concat
	log
	int 1
	return

// addressToBigInt(addr: Address): boolean
addressToBigInt:
	proto 1 1

	// tests/contracts/math.algo.ts:118
	// return btobigint(addr) > btobigint(this.txn.sender);
	frame_dig -1 // addr: Address
	txn Sender
	b>
	retsub

// u8Tou64()uint64
*abi_route_u8Tou64:
	// The ABI return prefix
	byte 0x151f7c75

	// execute u8Tou64()uint64
	callsub u8Tou64
	itob
	concat
	log
	int 1
	return

// u8Tou64(): uint64
u8Tou64:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/math.algo.ts:122
	// x: uint8 = 7
	pushint 7
	frame_bury 0 // x: uint8

	// tests/contracts/math.algo.ts:123
	// return <uint64>x;
	frame_dig 0 // x: uint8

	// set the subroutine return value
	frame_bury 0
	retsub

// privateFuncName(x: uint8, y: uint64): void
privateFuncName:
	proto 2 0

	// tests/contracts/math.algo.ts:127
	// assert(<uint8>y > x)
	frame_dig -2 // y: uint64
	frame_dig -1 // x: uint8
	>
	assert
	retsub

// funcName(uint256)void
*abi_route_funcName:
	// x: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (x) for funcName must be a uint256
	assert

	// execute funcName(uint256)void
	callsub funcName
	int 1
	return

// funcName(x: uint256): void
funcName:
	proto 1 0

	// tests/contracts/math.algo.ts:131
	// this.privateFuncName(<uint8>x, 1337)
	pushint 1337
	frame_dig -1 // x: uint256
	dup
	bitlen
	pushint 8
	<=

	// <uint8>x overflowed 8 bits
	assert
	extract 31 1
	btoi
	callsub privateFuncName
	retsub

// bigintPlus(uint64,uint64)uint64
*abi_route_bigintPlus:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute bigintPlus(uint64,uint64)uint64
	callsub bigintPlus
	itob
	concat
	log
	int 1
	return

// bigintPlus(a: uint64, b: uint64): uint64
bigintPlus:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// tests/contracts/math.algo.ts:135
	// x = itob(a)
	frame_dig -1 // a: uint64
	itob
	frame_bury 0 // x: byte[]

	// tests/contracts/math.algo.ts:136
	// y = itob(b)
	frame_dig -2 // b: uint64
	itob
	frame_bury 1 // y: byte[]

	// tests/contracts/math.algo.ts:137
	// return (btobigint(x) + btobigint(y)) as uint64;
	frame_dig 0 // x: byte[]
	frame_dig 1 // y: byte[]
	b+
	dup
	bitlen
	pushint 64
	<=

	// (btobigint(x) + btobigint(y)) as uint64 overflowed 64 bits
	assert
	byte 0xFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	pushint 8
	-
	swap
	substring3
	btoi

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 1
	retsub

// bitwiseOr(uint64,uint64)uint64
*abi_route_bitwiseOr:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute bitwiseOr(uint64,uint64)uint64
	callsub bitwiseOr
	itob
	concat
	log
	int 1
	return

// bitwiseOr(a: uint64, b: uint64): uint64
bitwiseOr:
	proto 2 1

	// tests/contracts/math.algo.ts:141
	// return a | b;
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	|
	retsub

// bitwiseAnd(uint64,uint64)uint64
*abi_route_bitwiseAnd:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute bitwiseAnd(uint64,uint64)uint64
	callsub bitwiseAnd
	itob
	concat
	log
	int 1
	return

// bitwiseAnd(a: uint64, b: uint64): uint64
bitwiseAnd:
	proto 2 1

	// tests/contracts/math.algo.ts:145
	// return a & b;
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	&
	retsub

// bitwiseXor(uint64,uint64)uint64
*abi_route_bitwiseXor:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute bitwiseXor(uint64,uint64)uint64
	callsub bitwiseXor
	itob
	concat
	log
	int 1
	return

// bitwiseXor(a: uint64, b: uint64): uint64
bitwiseXor:
	proto 2 1

	// tests/contracts/math.algo.ts:149
	// return a ^ b;
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	^
	retsub

// bitwiseOrU256(uint256,uint256)uint256
*abi_route_bitwiseOrU256:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint256
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (b) for bitwiseOrU256 must be a uint256
	assert

	// a: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (a) for bitwiseOrU256 must be a uint256
	assert

	// execute bitwiseOrU256(uint256,uint256)uint256
	callsub bitwiseOrU256
	dup
	bitlen
	int 256
	<=

	// bitwiseOrU256 return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// bitwiseOrU256(a: uint256, b: uint256): uint256
bitwiseOrU256:
	proto 2 1

	// tests/contracts/math.algo.ts:153
	// return a | b;
	frame_dig -1 // a: uint256
	frame_dig -2 // b: uint256
	b|
	retsub

// bitwiseAndU256(uint256,uint256)uint256
*abi_route_bitwiseAndU256:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint256
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (b) for bitwiseAndU256 must be a uint256
	assert

	// a: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (a) for bitwiseAndU256 must be a uint256
	assert

	// execute bitwiseAndU256(uint256,uint256)uint256
	callsub bitwiseAndU256
	dup
	bitlen
	int 256
	<=

	// bitwiseAndU256 return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// bitwiseAndU256(a: uint256, b: uint256): uint256
bitwiseAndU256:
	proto 2 1

	// tests/contracts/math.algo.ts:157
	// return a & b;
	frame_dig -1 // a: uint256
	frame_dig -2 // b: uint256
	b&
	retsub

// bitwiseXorU256(uint256,uint256)uint256
*abi_route_bitwiseXorU256:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint256
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (b) for bitwiseXorU256 must be a uint256
	assert

	// a: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (a) for bitwiseXorU256 must be a uint256
	assert

	// execute bitwiseXorU256(uint256,uint256)uint256
	callsub bitwiseXorU256
	dup
	bitlen
	int 256
	<=

	// bitwiseXorU256 return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// bitwiseXorU256(a: uint256, b: uint256): uint256
bitwiseXorU256:
	proto 2 1

	// tests/contracts/math.algo.ts:161
	// return a ^ b;
	frame_dig -1 // a: uint256
	frame_dig -2 // b: uint256
	b^
	retsub

// bitwiseNot(uint64)uint64
*abi_route_bitwiseNot:
	// The ABI return prefix
	byte 0x151f7c75

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute bitwiseNot(uint64)uint64
	callsub bitwiseNot
	itob
	concat
	log
	int 1
	return

// bitwiseNot(a: uint64): uint64
bitwiseNot:
	proto 1 1

	// tests/contracts/math.algo.ts:165
	// return ~a;
	frame_dig -1 // a: uint64
	~
	retsub

// bitwiseNotU256(uint256)uint256
*abi_route_bitwiseNotU256:
	// The ABI return prefix
	byte 0x151f7c75

	// a: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for bitwiseNotU256 must be a uint256
	assert

	// execute bitwiseNotU256(uint256)uint256
	callsub bitwiseNotU256
	dup
	bitlen
	int 256
	<=

	// bitwiseNotU256 return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// bitwiseNotU256(a: uint256): uint256
bitwiseNotU256:
	proto 1 1

	// tests/contracts/math.algo.ts:169
	// return ~a;
	frame_dig -1 // a: uint256
	b~
	retsub

// mulw(uint64,uint64)uint64
*abi_route_mulw:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute mulw(uint64,uint64)uint64
	callsub mulw
	itob
	concat
	log
	int 1
	return

// mulw(a: uint64, b: uint64): uint64
mulw:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// tests/contracts/math.algo.ts:173
	// p = mulw(a, b)
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	mulw
	frame_bury 0 // p low: uint64
	frame_bury 1 // p high: uint64

	// tests/contracts/math.algo.ts:177
	// return p2.low;
	frame_dig 0 // p low: uint64

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 1
	retsub

// addw(uint64,uint64)uint64
*abi_route_addw:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute addw(uint64,uint64)uint64
	callsub addw
	itob
	concat
	log
	int 1
	return

// addw(a: uint64, b: uint64): uint64
addw:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// tests/contracts/math.algo.ts:181
	// p = addw(a, b)
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	addw
	frame_bury 0 // p low: uint64
	frame_bury 1 // p high: uint64

	// tests/contracts/math.algo.ts:185
	// return p2.low;
	frame_dig 0 // p low: uint64

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 1
	retsub

// expw(uint64,uint64)uint64
*abi_route_expw:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute expw(uint64,uint64)uint64
	callsub expw
	itob
	concat
	log
	int 1
	return

// expw(a: uint64, b: uint64): uint64
expw:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// tests/contracts/math.algo.ts:189
	// p = expw(a, b)
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	expw
	frame_bury 0 // p low: uint64
	frame_bury 1 // p high: uint64

	// tests/contracts/math.algo.ts:193
	// return p2.low;
	frame_dig 0 // p low: uint64

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 1
	retsub

// divw(uint64,uint64)uint64
*abi_route_divw:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute divw(uint64,uint64)uint64
	callsub divw
	itob
	concat
	log
	int 1
	return

// divw(a: uint64, b: uint64): uint64
divw:
	proto 2 1

	// tests/contracts/math.algo.ts:197
	// return divw(0, a, b);
	pushint 0
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	divw
	retsub

// divmodw(uint64,uint64)uint64
*abi_route_divmodw:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute divmodw(uint64,uint64)uint64
	callsub divmodw
	itob
	concat
	log
	int 1
	return

// divmodw(a: uint64, b: uint64): uint64
divmodw:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 3

	// tests/contracts/math.algo.ts:201
	// p = divmodw(0, a, 0, b)
	pushint 0
	frame_dig -1 // a: uint64
	pushint 0
	frame_dig -2 // b: uint64
	divmodw
	frame_bury 0 // p remainderLow: uint64
	frame_bury 1 // p remainderHigh: uint64
	frame_bury 2 // p quotientLow: uint64
	frame_bury 3 // p quotientHigh: uint64

	// tests/contracts/math.algo.ts:205
	// return p2.quotientLow;
	frame_dig 2 // p quotientLow: uint64

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 3
	retsub

// unsafeVariables()uint64
*abi_route_unsafeVariables:
	// The ABI return prefix
	byte 0x151f7c75

	// execute unsafeVariables()uint64
	callsub unsafeVariables
	itob
	concat
	log
	int 1
	return

// unsafeVariables(): uint64
unsafeVariables:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// tests/contracts/math.algo.ts:209
	// A = <uint256>250000000
	pushbytes 0x000000000000000000000000000000000000000000000000000000000ee6b280
	frame_bury 0 // A: unsafe uint256

	// tests/contracts/math.algo.ts:210
	// B = <uint256>1000
	byte 0x00000000000000000000000000000000000000000000000000000000000003e8
	frame_bury 1 // B: uint256

	// tests/contracts/math.algo.ts:212
	// A = A / B
	frame_dig 0 // A: unsafe uint256
	byte 0x00000000000000000000000000000000000000000000000000000000000003e8 // B: uint256
	b/
	frame_bury 0 // A: unsafe uint256

	// tests/contracts/math.algo.ts:214
	// c = A as uint64
	frame_dig 0 // A: unsafe uint256
	dup
	bitlen
	pushint 64
	<=

	// A as uint64 overflowed 64 bits
	assert
	byte 0xFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	pushint 8
	-
	swap
	substring3
	btoi
	frame_bury 2 // c: uint64

	// tests/contracts/math.algo.ts:216
	// return c;
	frame_dig 2 // c: uint64

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 2
	retsub

// foobar(uint128)uint128
*abi_route_foobar:
	// The ABI return prefix
	byte 0x151f7c75

	// x: uint128
	txna ApplicationArgs 1
	dup
	len
	pushint 16
	==

	// argument 0 (x) for foobar must be a uint128
	assert

	// execute foobar(uint128)uint128
	callsub foobar
	dup
	bitlen
	pushint 128
	<=

	// foobar return value overflowed 128 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	pushint 16
	-
	swap
	substring3
	concat
	log
	int 1
	return

// foobar(x: uint128): uint128
foobar:
	proto 1 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/math.algo.ts:220
	// avgStake: uint128 = x / (30000 as uint128)
	frame_dig -1 // x: uint128
	pushbytes 0x00000000000000000000000000007530
	b/
	dup
	bitlen
	pushint 128
	<=

	// x / (30000 as uint128) overflowed 128 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	pushint 16
	-
	swap
	substring3
	frame_bury 0 // avgStake: uint128

	// tests/contracts/math.algo.ts:222
	// return avgStake;
	frame_dig 0 // avgStake: uint128

	// set the subroutine return value
	frame_bury 0
	retsub

// uintFromHex()uint256
*abi_route_uintFromHex:
	// The ABI return prefix
	byte 0x151f7c75

	// execute uintFromHex()uint256
	callsub uintFromHex
	dup
	bitlen
	int 256
	<=

	// uintFromHex return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// uintFromHex(): uint256
uintFromHex:
	proto 0 1

	// tests/contracts/math.algo.ts:226
	// return Uint<256>('0xFF');
	pushbytes 0x00000000000000000000000000000000000000000000000000000000000000ff
	retsub

// wideRatioTest()uint64
*abi_route_wideRatioTest:
	// The ABI return prefix
	byte 0x151f7c75

	// execute wideRatioTest()uint64
	callsub wideRatioTest
	itob
	concat
	log
	int 1
	return

// wideRatioTest(): uint64
wideRatioTest:
	proto 0 1

	// tests/contracts/math.algo.ts:230
	// return wideRatio([Uint<64>('18446744073709551615'), 2, 3, 4, 5], [2, 3, 4, 5]);
	int 18446744073709551615
	pushint 2
	mulw
	pushint 3
	uncover 2
	dig 1
	*
	cover 2
	mulw
	cover 2
	+
	swap
	pushint 4
	uncover 2
	dig 1
	*
	cover 2
	mulw
	cover 2
	+
	swap
	pushint 5
	uncover 2
	dig 1
	*
	cover 2
	mulw
	cover 2
	+
	swap
	pushint 2
	pushint 3
	mulw
	pushint 4
	uncover 2
	dig 1
	*
	cover 2
	mulw
	cover 2
	+
	swap
	pushint 5
	uncover 2
	dig 1
	*
	cover 2
	mulw
	cover 2
	+
	swap
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	retsub

*abi_route_createApplication:
	int 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x3ce6f1af // method "u64plus(uint64,uint64)uint64"
	pushbytes 0x0031a186 // method "u64minus(uint64,uint64)uint64"
	pushbytes 0xe52e4394 // method "u64mul(uint64,uint64)uint64"
	pushbytes 0x950d4789 // method "u64div(uint64,uint64)uint64"
	pushbytes 0x65bdda6e // method "u256plus(uint256,uint256)uint256"
	pushbytes 0x0a6ad284 // method "u256minus(uint256,uint256)uint256"
	pushbytes 0xf044bf24 // method "u256mul(uint256,uint256)uint256"
	pushbytes 0xc48f8c05 // method "u256div(uint256,uint256)uint256"
	pushbytes 0xf2e1d632 // method "u64Return256(uint64,uint64)uint256"
	pushbytes 0x38b1a39e // method "maxU64()uint64"
	pushbytes 0x6c136f1d // method "exponent(uint64,uint64)uint64"
	pushbytes 0x22da2502 // method "variableTypeHint(uint8,uint8)uint16"
	pushbytes 0xa2fead6c // method "uint8plus(uint8,uint8)uint8"
	pushbytes 0xd2256f7a // method "uint8exp(uint8,uint8)uint8"
	pushbytes 0xc17d624e // method "plusEquals(uint64,uint64)uint64"
	pushbytes 0x5cab0438 // method "plusEqualsFromGlobal(uint64,uint64)uint64"
	pushbytes 0x58989ccd // method "boxTest()uint256"
	pushbytes 0x4830b4de // method "unsafeMethodArgs(uint256,uint256)uint256"
	pushbytes 0xe1c55ce5 // method "uint256ComparisonType(uint256,uint256)void"
	pushbytes 0x7d1d426e // method "squareRoot256(uint256,uint256)uint256"
	pushbytes 0x1c2981f1 // method "squareRoot64(uint64,uint64)uint64"
	pushbytes 0xb7ca04b9 // method "addressToBigInt(address)bool"
	pushbytes 0xbb952338 // method "u8Tou64()uint64"
	pushbytes 0x0128e27b // method "funcName(uint256)void"
	pushbytes 0xf916cdb3 // method "bigintPlus(uint64,uint64)uint64"
	pushbytes 0x52737545 // method "bitwiseOr(uint64,uint64)uint64"
	pushbytes 0x79c1adc0 // method "bitwiseAnd(uint64,uint64)uint64"
	pushbytes 0x22474abc // method "bitwiseXor(uint64,uint64)uint64"
	pushbytes 0x0593fdf8 // method "bitwiseOrU256(uint256,uint256)uint256"
	pushbytes 0x06fb9337 // method "bitwiseAndU256(uint256,uint256)uint256"
	pushbytes 0x26493d78 // method "bitwiseXorU256(uint256,uint256)uint256"
	pushbytes 0xe9c22eea // method "bitwiseNot(uint64)uint64"
	pushbytes 0xede3e9bc // method "bitwiseNotU256(uint256)uint256"
	pushbytes 0x2e4a2164 // method "mulw(uint64,uint64)uint64"
	pushbytes 0x50134b5a // method "addw(uint64,uint64)uint64"
	pushbytes 0xf53aff9b // method "expw(uint64,uint64)uint64"
	pushbytes 0xcaf7110d // method "divw(uint64,uint64)uint64"
	pushbytes 0xbed0e386 // method "divmodw(uint64,uint64)uint64"
	pushbytes 0x274d7705 // method "unsafeVariables()uint64"
	pushbytes 0x92465d08 // method "foobar(uint128)uint128"
	pushbytes 0xf01facce // method "uintFromHex()uint256"
	pushbytes 0x5ac8a0a0 // method "wideRatioTest()uint64"
	txna ApplicationArgs 0
	match *abi_route_u64plus *abi_route_u64minus *abi_route_u64mul *abi_route_u64div *abi_route_u256plus *abi_route_u256minus *abi_route_u256mul *abi_route_u256div *abi_route_u64Return256 *abi_route_maxU64 *abi_route_exponent *abi_route_variableTypeHint *abi_route_uint8plus *abi_route_uint8exp *abi_route_plusEquals *abi_route_plusEqualsFromGlobal *abi_route_boxTest *abi_route_unsafeMethodArgs *abi_route_uint256ComparisonType *abi_route_squareRoot256 *abi_route_squareRoot64 *abi_route_addressToBigInt *abi_route_u8Tou64 *abi_route_funcName *abi_route_bigintPlus *abi_route_bitwiseOr *abi_route_bitwiseAnd *abi_route_bitwiseXor *abi_route_bitwiseOrU256 *abi_route_bitwiseAndU256 *abi_route_bitwiseXorU256 *abi_route_bitwiseNot *abi_route_bitwiseNotU256 *abi_route_mulw *abi_route_addw *abi_route_expw *abi_route_divw *abi_route_divmodw *abi_route_unsafeVariables *abi_route_foobar *abi_route_uintFromHex *abi_route_wideRatioTest

	// this contract does not implement the given ABI method for call NoOp
	err", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/MathTest.arc56_draft.json b/tests/contracts/artifacts/MathTest.arc56_draft.json index 5ebfcb2e9..94dcd21c9 100644 --- a/tests/contracts/artifacts/MathTest.arc56_draft.json +++ b/tests/contracts/artifacts/MathTest.arc56_draft.json @@ -12052,7 +12052,7 @@ } }, "source": { - "approval": "#pragma version 10
intcblock 1 32 256 18446744073709551615
bytecblock 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF 0x151f7c75 0x0000000000000000000000000000000000000000000000000000000000000001 0x00000000000000000000000000000000000000000000000000000000000003e8 0x626f784b6579 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF 0x 0x674b6579 0xFFFFFFFFFFFFFFFF

// This TEAL was generated by TEALScript v0.104.1
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// u64plus(uint64,uint64)uint64
*abi_route_u64plus:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute u64plus(uint64,uint64)uint64
	callsub u64plus
	itob
	concat
	log
	int 1
	return

// u64plus(a: uint64, b: uint64): uint64
u64plus:
	proto 2 1

	// tests/contracts/math.algo.ts:8
	// return a + b;
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	+
	retsub

// u64minus(uint64,uint64)uint64
*abi_route_u64minus:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute u64minus(uint64,uint64)uint64
	callsub u64minus
	itob
	concat
	log
	int 1
	return

// u64minus(a: uint64, b: uint64): uint64
u64minus:
	proto 2 1

	// tests/contracts/math.algo.ts:12
	// return a - b;
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	-
	retsub

// u64mul(uint64,uint64)uint64
*abi_route_u64mul:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute u64mul(uint64,uint64)uint64
	callsub u64mul
	itob
	concat
	log
	int 1
	return

// u64mul(a: uint64, b: uint64): uint64
u64mul:
	proto 2 1

	// tests/contracts/math.algo.ts:16
	// return a * b;
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	*
	retsub

// u64div(uint64,uint64)uint64
*abi_route_u64div:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute u64div(uint64,uint64)uint64
	callsub u64div
	itob
	concat
	log
	int 1
	return

// u64div(a: uint64, b: uint64): uint64
u64div:
	proto 2 1

	// tests/contracts/math.algo.ts:20
	// return a / b;
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	/
	retsub

// u256plus(uint256,uint256)uint256
*abi_route_u256plus:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint256
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (b) for u256plus must be a uint256
	assert

	// a: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (a) for u256plus must be a uint256
	assert

	// execute u256plus(uint256,uint256)uint256
	callsub u256plus
	dup
	bitlen
	int 256
	<=

	// u256plus return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// u256plus(a: uint256, b: uint256): uint256
u256plus:
	proto 2 1

	// tests/contracts/math.algo.ts:24
	// return <uint256>(a + b);
	frame_dig -1 // a: uint256
	frame_dig -2 // b: uint256
	b+
	retsub

// u256minus(uint256,uint256)uint256
*abi_route_u256minus:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint256
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (b) for u256minus must be a uint256
	assert

	// a: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (a) for u256minus must be a uint256
	assert

	// execute u256minus(uint256,uint256)uint256
	callsub u256minus
	dup
	bitlen
	int 256
	<=

	// u256minus return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// u256minus(a: uint256, b: uint256): uint256
u256minus:
	proto 2 1

	// tests/contracts/math.algo.ts:28
	// return <uint256>(a - b);
	frame_dig -1 // a: uint256
	frame_dig -2 // b: uint256
	b-
	retsub

// u256mul(uint256,uint256)uint256
*abi_route_u256mul:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint256
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (b) for u256mul must be a uint256
	assert

	// a: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (a) for u256mul must be a uint256
	assert

	// execute u256mul(uint256,uint256)uint256
	callsub u256mul
	dup
	bitlen
	int 256
	<=

	// u256mul return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// u256mul(a: uint256, b: uint256): uint256
u256mul:
	proto 2 1

	// tests/contracts/math.algo.ts:32
	// return <uint256>(a * b);
	frame_dig -1 // a: uint256
	frame_dig -2 // b: uint256
	b*
	retsub

// u256div(uint256,uint256)uint256
*abi_route_u256div:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint256
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (b) for u256div must be a uint256
	assert

	// a: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (a) for u256div must be a uint256
	assert

	// execute u256div(uint256,uint256)uint256
	callsub u256div
	dup
	bitlen
	int 256
	<=

	// u256div return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// u256div(a: uint256, b: uint256): uint256
u256div:
	proto 2 1

	// tests/contracts/math.algo.ts:36
	// return <uint256>(a / b);
	frame_dig -1 // a: uint256
	frame_dig -2 // b: uint256
	b/
	retsub

// u64Return256(uint64,uint64)uint256
*abi_route_u64Return256:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute u64Return256(uint64,uint64)uint256
	callsub u64Return256
	dup
	bitlen
	int 256
	<=

	// u64Return256 return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// u64Return256(a: uint64, b: uint64): uint256
u64Return256:
	proto 2 1

	// tests/contracts/math.algo.ts:40
	// return <uint256>(a + b);
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	+
	itob
	retsub

// maxU64()uint64
*abi_route_maxU64:
	// The ABI return prefix
	byte 0x151f7c75

	// execute maxU64()uint64
	callsub maxU64
	itob
	concat
	log
	int 1
	return

// maxU64(): uint64
maxU64:
	proto 0 1

	// tests/contracts/math.algo.ts:44
	// return Uint<64>('18446744073709551615');
	int 18446744073709551615
	retsub

// exponent(uint64,uint64)uint64
*abi_route_exponent:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute exponent(uint64,uint64)uint64
	callsub exponent
	itob
	concat
	log
	int 1
	return

// exponent(a: uint64, b: uint64): uint64
exponent:
	proto 2 1

	// tests/contracts/math.algo.ts:48
	// return a ** b;
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	exp
	retsub

// variableTypeHint(uint8,uint8)uint16
*abi_route_variableTypeHint:
	// The ABI return prefix
	byte 0x151f7c75

	// y: uint8
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 0 (y) for variableTypeHint must be a uint8
	assert
	btoi

	// x: uint8
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 1 (x) for variableTypeHint must be a uint8
	assert
	btoi

	// execute variableTypeHint(uint8,uint8)uint16
	callsub variableTypeHint
	itob
	dup
	bitlen
	pushint 16
	<=

	// variableTypeHint return value overflowed 16 bits
	assert
	extract 6 2
	concat
	log
	int 1
	return

// variableTypeHint(x: uint<8>, y: uint<8>): uint16
variableTypeHint:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/math.algo.ts:52
	// z = <uint16>(x + y)
	frame_dig -1 // x: uint<8>
	frame_dig -2 // y: uint<8>
	+
	frame_bury 0 // z: unsafe uint16

	// tests/contracts/math.algo.ts:54
	// return z;
	frame_dig 0 // z: unsafe uint16

	// set the subroutine return value
	frame_bury 0
	retsub

// uint8plus(uint8,uint8)uint8
*abi_route_uint8plus:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint8
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 0 (b) for uint8plus must be a uint8
	assert
	btoi

	// a: uint8
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 1 (a) for uint8plus must be a uint8
	assert
	btoi

	// execute uint8plus(uint8,uint8)uint8
	callsub uint8plus
	itob
	dup
	bitlen
	pushint 8
	<=

	// uint8plus return value overflowed 8 bits
	assert
	extract 7 1
	concat
	log
	int 1
	return

// uint8plus(a: uint<8>, b: uint<8>): uint<8>
uint8plus:
	proto 2 1

	// tests/contracts/math.algo.ts:58
	// return a + b;
	frame_dig -1 // a: uint<8>
	frame_dig -2 // b: uint<8>
	+
	retsub

// uint8exp(uint8,uint8)uint8
*abi_route_uint8exp:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint8
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 0 (b) for uint8exp must be a uint8
	assert
	btoi

	// a: uint8
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 1 (a) for uint8exp must be a uint8
	assert
	btoi

	// execute uint8exp(uint8,uint8)uint8
	callsub uint8exp
	itob
	dup
	bitlen
	pushint 8
	<=

	// uint8exp return value overflowed 8 bits
	assert
	extract 7 1
	concat
	log
	int 1
	return

// uint8exp(a: uint<8>, b: uint<8>): uint<8>
uint8exp:
	proto 2 1

	// tests/contracts/math.algo.ts:62
	// return a ** b;
	frame_dig -1 // a: uint<8>
	frame_dig -2 // b: uint<8>
	exp
	retsub

// plusEquals(uint64,uint64)uint64
*abi_route_plusEquals:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute plusEquals(uint64,uint64)uint64
	callsub plusEquals
	itob
	concat
	log
	int 1
	return

// plusEquals(a: uint64, b: uint64): uint64
plusEquals:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/math.algo.ts:66
	// x = a
	frame_dig -1 // a: uint64
	frame_bury 0 // x: uint64

	// tests/contracts/math.algo.ts:68
	// x += b
	frame_dig 0 // x: uint64
	frame_dig -2 // b: uint64
	+
	frame_bury 0 // x: uint64

	// tests/contracts/math.algo.ts:70
	// return x;
	frame_dig 0 // x: uint64

	// set the subroutine return value
	frame_bury 0
	retsub

// plusEqualsFromGlobal(uint64,uint64)uint64
*abi_route_plusEqualsFromGlobal:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute plusEqualsFromGlobal(uint64,uint64)uint64
	callsub plusEqualsFromGlobal
	itob
	concat
	log
	int 1
	return

// plusEqualsFromGlobal(a: uint64, b: uint64): uint64
plusEqualsFromGlobal:
	proto 2 1

	// tests/contracts/math.algo.ts:74
	// this.gKey.value = a
	byte 0x674b6579 // "gKey"
	frame_dig -1 // a: uint64
	app_global_put

	// tests/contracts/math.algo.ts:76
	// this.gKey.value += b
	byte 0x674b6579 // "gKey"
	app_global_get
	frame_dig -2 // b: uint64
	+
	byte 0x674b6579 // "gKey"
	swap
	app_global_put

	// tests/contracts/math.algo.ts:78
	// return this.gKey.value;
	byte 0x674b6579 // "gKey"
	app_global_get
	retsub

// boxTest()uint256
*abi_route_boxTest:
	// The ABI return prefix
	byte 0x151f7c75

	// execute boxTest()uint256
	callsub boxTest
	dup
	bitlen
	int 256
	<=

	// boxTest return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// boxTest(): uint256
boxTest:
	proto 0 1

	// tests/contracts/math.algo.ts:84
	// this.boxKey.value = <uint256>1
	byte 0x626f784b6579 // "boxKey"
	byte 0x0000000000000000000000000000000000000000000000000000000000000001
	box_put

	// tests/contracts/math.algo.ts:85
	// this.boxKey.value += 1
	byte 0x626f784b6579 // "boxKey"
	box_get

	// box value does not exist: this.boxKey.value
	assert
	byte 0x0000000000000000000000000000000000000000000000000000000000000001
	b+
	byte 0x626f784b6579 // "boxKey"
	dup
	bitlen
	int 256
	<=

	// this.boxKey.value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	swap
	box_put

	// tests/contracts/math.algo.ts:87
	// return this.boxKey.value;
	byte 0x626f784b6579 // "boxKey"
	box_get

	// box value does not exist: this.boxKey.value
	assert
	retsub

// foo(x: uint256): uint256
foo:
	proto 1 1

	// tests/contracts/math.algo.ts:91
	// return x;
	frame_dig -1 // x: uint256
	retsub

// unsafeMethodArgs(uint256,uint256)uint256
*abi_route_unsafeMethodArgs:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint256
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (b) for unsafeMethodArgs must be a uint256
	assert

	// a: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (a) for unsafeMethodArgs must be a uint256
	assert

	// execute unsafeMethodArgs(uint256,uint256)uint256
	callsub unsafeMethodArgs
	dup
	bitlen
	int 256
	<=

	// unsafeMethodArgs return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// unsafeMethodArgs(a: uint256, b: uint256): uint256
unsafeMethodArgs:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/math.algo.ts:95
	// c = a + b
	frame_dig -1 // a: uint256
	frame_dig -2 // b: uint256
	b+
	frame_bury 0 // c: unsafe uint256

	// tests/contracts/math.algo.ts:97
	// return this.foo(c);
	frame_dig 0 // c: unsafe uint256
	dup
	bitlen
	int 256
	<=

	// c overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	callsub foo

	// set the subroutine return value
	frame_bury 0
	retsub

// uint256ComparisonType(uint256,uint256)void
*abi_route_uint256ComparisonType:
	// b: uint256
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (b) for uint256ComparisonType must be a uint256
	assert

	// a: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (a) for uint256ComparisonType must be a uint256
	assert

	// execute uint256ComparisonType(uint256,uint256)void
	callsub uint256ComparisonType
	int 1
	return

// uint256ComparisonType(a: uint256, b: uint256): void
uint256ComparisonType:
	proto 2 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/math.algo.ts:101
	// senderBalanceAfter = a - b
	frame_dig -1 // a: uint256
	frame_dig -2 // b: uint256
	b-
	frame_bury 0 // senderBalanceAfter: unsafe uint256

	// *if0_condition
	// tests/contracts/math.algo.ts:102
	// senderBalanceAfter > <uint256>0
	frame_dig 0 // senderBalanceAfter: unsafe uint256
	pushbytes 0x0000000000000000000000000000000000000000000000000000000000000000
	b>
	bz *if0_else

	// *if0_consequent
	// tests/contracts/math.algo.ts:103
	// log('nonZero')
	pushbytes 0x6e6f6e5a65726f // "nonZero"
	log
	b *if0_end

*if0_else:
	// tests/contracts/math.algo.ts:105
	// log('zero')
	pushbytes 0x7a65726f // "zero"
	log

*if0_end:
	retsub

// squareRoot256(uint256,uint256)uint256
*abi_route_squareRoot256:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint256
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (b) for squareRoot256 must be a uint256
	assert

	// a: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (a) for squareRoot256 must be a uint256
	assert

	// execute squareRoot256(uint256,uint256)uint256
	callsub squareRoot256
	dup
	bitlen
	int 256
	<=

	// squareRoot256 return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// squareRoot256(a: uint256, b: uint256): uint256
squareRoot256:
	proto 2 1

	// tests/contracts/math.algo.ts:110
	// return sqrt(a * b);
	frame_dig -1 // a: uint256
	frame_dig -2 // b: uint256
	b*
	bsqrt
	retsub

// squareRoot64(uint64,uint64)uint64
*abi_route_squareRoot64:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute squareRoot64(uint64,uint64)uint64
	callsub squareRoot64
	itob
	concat
	log
	int 1
	return

// squareRoot64(a: uint64, b: uint64): uint64
squareRoot64:
	proto 2 1

	// tests/contracts/math.algo.ts:114
	// return sqrt(a * b);
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	*
	sqrt
	retsub

// addressToBigInt(address)bool
*abi_route_addressToBigInt:
	// The ABI return prefix
	byte 0x151f7c75

	// addr: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (addr) for addressToBigInt must be a address
	assert

	// execute addressToBigInt(address)bool
	callsub addressToBigInt
	pushbytes 0x00
	pushint 0
	uncover 2
	setbit
	concat
	log
	int 1
	return

// addressToBigInt(addr: Address): boolean
addressToBigInt:
	proto 1 1

	// tests/contracts/math.algo.ts:118
	// return btobigint(addr) > btobigint(this.txn.sender);
	frame_dig -1 // addr: Address
	txn Sender
	b>
	retsub

// u8Tou64()uint64
*abi_route_u8Tou64:
	// The ABI return prefix
	byte 0x151f7c75

	// execute u8Tou64()uint64
	callsub u8Tou64
	itob
	concat
	log
	int 1
	return

// u8Tou64(): uint64
u8Tou64:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/math.algo.ts:122
	// x: uint8 = 7
	pushint 7
	frame_bury 0 // x: uint8

	// tests/contracts/math.algo.ts:123
	// return <uint64>x;
	frame_dig 0 // x: uint8

	// set the subroutine return value
	frame_bury 0
	retsub

// privateFuncName(x: uint8, y: uint64): void
privateFuncName:
	proto 2 0

	// tests/contracts/math.algo.ts:127
	// assert(<uint8>y > x)
	frame_dig -2 // y: uint64
	frame_dig -1 // x: uint8
	>
	assert
	retsub

// funcName(uint256)void
*abi_route_funcName:
	// x: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (x) for funcName must be a uint256
	assert

	// execute funcName(uint256)void
	callsub funcName
	int 1
	return

// funcName(x: uint256): void
funcName:
	proto 1 0

	// tests/contracts/math.algo.ts:131
	// this.privateFuncName(<uint8>x, 1337)
	pushint 1337
	frame_dig -1 // x: uint256
	dup
	bitlen
	pushint 8
	<=

	// <uint8>x overflowed 8 bits
	assert
	extract 31 1
	btoi
	callsub privateFuncName
	retsub

// bigintPlus(uint64,uint64)uint64
*abi_route_bigintPlus:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute bigintPlus(uint64,uint64)uint64
	callsub bigintPlus
	itob
	concat
	log
	int 1
	return

// bigintPlus(a: uint64, b: uint64): uint64
bigintPlus:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// tests/contracts/math.algo.ts:135
	// x = itob(a)
	frame_dig -1 // a: uint64
	itob
	frame_bury 0 // x: byte[]

	// tests/contracts/math.algo.ts:136
	// y = itob(b)
	frame_dig -2 // b: uint64
	itob
	frame_bury 1 // y: byte[]

	// tests/contracts/math.algo.ts:137
	// return (btobigint(x) + btobigint(y)) as uint64;
	frame_dig 0 // x: byte[]
	frame_dig 1 // y: byte[]
	b+
	dup
	bitlen
	pushint 64
	<=

	// (btobigint(x) + btobigint(y)) as uint64 overflowed 64 bits
	assert
	byte 0xFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	pushint 8
	-
	swap
	substring3
	btoi

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 1
	retsub

// bitwiseOr(uint64,uint64)uint64
*abi_route_bitwiseOr:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute bitwiseOr(uint64,uint64)uint64
	callsub bitwiseOr
	itob
	concat
	log
	int 1
	return

// bitwiseOr(a: uint64, b: uint64): uint64
bitwiseOr:
	proto 2 1

	// tests/contracts/math.algo.ts:141
	// return a | b;
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	|
	retsub

// bitwiseAnd(uint64,uint64)uint64
*abi_route_bitwiseAnd:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute bitwiseAnd(uint64,uint64)uint64
	callsub bitwiseAnd
	itob
	concat
	log
	int 1
	return

// bitwiseAnd(a: uint64, b: uint64): uint64
bitwiseAnd:
	proto 2 1

	// tests/contracts/math.algo.ts:145
	// return a & b;
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	&
	retsub

// bitwiseXor(uint64,uint64)uint64
*abi_route_bitwiseXor:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute bitwiseXor(uint64,uint64)uint64
	callsub bitwiseXor
	itob
	concat
	log
	int 1
	return

// bitwiseXor(a: uint64, b: uint64): uint64
bitwiseXor:
	proto 2 1

	// tests/contracts/math.algo.ts:149
	// return a ^ b;
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	^
	retsub

// bitwiseOrU256(uint256,uint256)uint256
*abi_route_bitwiseOrU256:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint256
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (b) for bitwiseOrU256 must be a uint256
	assert

	// a: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (a) for bitwiseOrU256 must be a uint256
	assert

	// execute bitwiseOrU256(uint256,uint256)uint256
	callsub bitwiseOrU256
	dup
	bitlen
	int 256
	<=

	// bitwiseOrU256 return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// bitwiseOrU256(a: uint256, b: uint256): uint256
bitwiseOrU256:
	proto 2 1

	// tests/contracts/math.algo.ts:153
	// return a | b;
	frame_dig -1 // a: uint256
	frame_dig -2 // b: uint256
	b|
	retsub

// bitwiseAndU256(uint256,uint256)uint256
*abi_route_bitwiseAndU256:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint256
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (b) for bitwiseAndU256 must be a uint256
	assert

	// a: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (a) for bitwiseAndU256 must be a uint256
	assert

	// execute bitwiseAndU256(uint256,uint256)uint256
	callsub bitwiseAndU256
	dup
	bitlen
	int 256
	<=

	// bitwiseAndU256 return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// bitwiseAndU256(a: uint256, b: uint256): uint256
bitwiseAndU256:
	proto 2 1

	// tests/contracts/math.algo.ts:157
	// return a & b;
	frame_dig -1 // a: uint256
	frame_dig -2 // b: uint256
	b&
	retsub

// bitwiseXorU256(uint256,uint256)uint256
*abi_route_bitwiseXorU256:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint256
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (b) for bitwiseXorU256 must be a uint256
	assert

	// a: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (a) for bitwiseXorU256 must be a uint256
	assert

	// execute bitwiseXorU256(uint256,uint256)uint256
	callsub bitwiseXorU256
	dup
	bitlen
	int 256
	<=

	// bitwiseXorU256 return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// bitwiseXorU256(a: uint256, b: uint256): uint256
bitwiseXorU256:
	proto 2 1

	// tests/contracts/math.algo.ts:161
	// return a ^ b;
	frame_dig -1 // a: uint256
	frame_dig -2 // b: uint256
	b^
	retsub

// bitwiseNot(uint64)uint64
*abi_route_bitwiseNot:
	// The ABI return prefix
	byte 0x151f7c75

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute bitwiseNot(uint64)uint64
	callsub bitwiseNot
	itob
	concat
	log
	int 1
	return

// bitwiseNot(a: uint64): uint64
bitwiseNot:
	proto 1 1

	// tests/contracts/math.algo.ts:165
	// return ~a;
	frame_dig -1 // a: uint64
	~
	retsub

// bitwiseNotU256(uint256)uint256
*abi_route_bitwiseNotU256:
	// The ABI return prefix
	byte 0x151f7c75

	// a: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for bitwiseNotU256 must be a uint256
	assert

	// execute bitwiseNotU256(uint256)uint256
	callsub bitwiseNotU256
	dup
	bitlen
	int 256
	<=

	// bitwiseNotU256 return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// bitwiseNotU256(a: uint256): uint256
bitwiseNotU256:
	proto 1 1

	// tests/contracts/math.algo.ts:169
	// return ~a;
	frame_dig -1 // a: uint256
	b~
	retsub

// mulw(uint64,uint64)uint64
*abi_route_mulw:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute mulw(uint64,uint64)uint64
	callsub mulw
	itob
	concat
	log
	int 1
	return

// mulw(a: uint64, b: uint64): uint64
mulw:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// tests/contracts/math.algo.ts:173
	// p = mulw(a, b)
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	mulw
	frame_bury 0 // p low: uint64
	frame_bury 1 // p high: uint64

	// tests/contracts/math.algo.ts:177
	// return p2.low;
	frame_dig 0 // p low: uint64

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 1
	retsub

// addw(uint64,uint64)uint64
*abi_route_addw:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute addw(uint64,uint64)uint64
	callsub addw
	itob
	concat
	log
	int 1
	return

// addw(a: uint64, b: uint64): uint64
addw:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// tests/contracts/math.algo.ts:181
	// p = addw(a, b)
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	addw
	frame_bury 0 // p low: uint64
	frame_bury 1 // p high: uint64

	// tests/contracts/math.algo.ts:185
	// return p2.low;
	frame_dig 0 // p low: uint64

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 1
	retsub

// expw(uint64,uint64)uint64
*abi_route_expw:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute expw(uint64,uint64)uint64
	callsub expw
	itob
	concat
	log
	int 1
	return

// expw(a: uint64, b: uint64): uint64
expw:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// tests/contracts/math.algo.ts:189
	// p = expw(a, b)
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	expw
	frame_bury 0 // p low: uint64
	frame_bury 1 // p high: uint64

	// tests/contracts/math.algo.ts:193
	// return p2.low;
	frame_dig 0 // p low: uint64

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 1
	retsub

// divw(uint64,uint64)uint64
*abi_route_divw:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute divw(uint64,uint64)uint64
	callsub divw
	itob
	concat
	log
	int 1
	return

// divw(a: uint64, b: uint64): uint64
divw:
	proto 2 1

	// tests/contracts/math.algo.ts:197
	// return divw(0, a, b);
	pushint 0
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	divw
	retsub

// divmodw(uint64,uint64)uint64
*abi_route_divmodw:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute divmodw(uint64,uint64)uint64
	callsub divmodw
	itob
	concat
	log
	int 1
	return

// divmodw(a: uint64, b: uint64): uint64
divmodw:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 3

	// tests/contracts/math.algo.ts:201
	// p = divmodw(0, a, 0, b)
	pushint 0
	frame_dig -1 // a: uint64
	pushint 0
	frame_dig -2 // b: uint64
	divmodw
	frame_bury 0 // p remainderLow: uint64
	frame_bury 1 // p remainderHigh: uint64
	frame_bury 2 // p quotientLow: uint64
	frame_bury 3 // p quotientHigh: uint64

	// tests/contracts/math.algo.ts:205
	// return p2.quotientLow;
	frame_dig 2 // p quotientLow: uint64

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 3
	retsub

// unsafeVariables()uint64
*abi_route_unsafeVariables:
	// The ABI return prefix
	byte 0x151f7c75

	// execute unsafeVariables()uint64
	callsub unsafeVariables
	itob
	concat
	log
	int 1
	return

// unsafeVariables(): uint64
unsafeVariables:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// tests/contracts/math.algo.ts:209
	// A = <uint256>250000000
	pushbytes 0x000000000000000000000000000000000000000000000000000000000ee6b280
	frame_bury 0 // A: unsafe uint256

	// tests/contracts/math.algo.ts:210
	// B = <uint256>1000
	byte 0x00000000000000000000000000000000000000000000000000000000000003e8
	frame_bury 1 // B: uint256

	// tests/contracts/math.algo.ts:212
	// A = A / B
	frame_dig 0 // A: unsafe uint256
	byte 0x00000000000000000000000000000000000000000000000000000000000003e8 // B: uint256
	b/
	frame_bury 0 // A: unsafe uint256

	// tests/contracts/math.algo.ts:214
	// c = A as uint64
	frame_dig 0 // A: unsafe uint256
	dup
	bitlen
	pushint 64
	<=

	// A as uint64 overflowed 64 bits
	assert
	byte 0xFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	pushint 8
	-
	swap
	substring3
	btoi
	frame_bury 2 // c: uint64

	// tests/contracts/math.algo.ts:216
	// return c;
	frame_dig 2 // c: uint64

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 2
	retsub

// foobar(uint128)uint128
*abi_route_foobar:
	// The ABI return prefix
	byte 0x151f7c75

	// x: uint128
	txna ApplicationArgs 1
	dup
	len
	pushint 16
	==

	// argument 0 (x) for foobar must be a uint128
	assert

	// execute foobar(uint128)uint128
	callsub foobar
	dup
	bitlen
	pushint 128
	<=

	// foobar return value overflowed 128 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	pushint 16
	-
	swap
	substring3
	concat
	log
	int 1
	return

// foobar(x: uint128): uint128
foobar:
	proto 1 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/math.algo.ts:220
	// avgStake: uint128 = x / (30000 as uint128)
	frame_dig -1 // x: uint128
	pushbytes 0x00000000000000000000000000007530
	b/
	dup
	bitlen
	pushint 128
	<=

	// x / (30000 as uint128) overflowed 128 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	pushint 16
	-
	swap
	substring3
	frame_bury 0 // avgStake: uint128

	// tests/contracts/math.algo.ts:222
	// return avgStake;
	frame_dig 0 // avgStake: uint128

	// set the subroutine return value
	frame_bury 0
	retsub

// uintFromHex()uint256
*abi_route_uintFromHex:
	// The ABI return prefix
	byte 0x151f7c75

	// execute uintFromHex()uint256
	callsub uintFromHex
	dup
	bitlen
	int 256
	<=

	// uintFromHex return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// uintFromHex(): uint256
uintFromHex:
	proto 0 1

	// tests/contracts/math.algo.ts:226
	// return Uint<256>('0xFF');
	pushbytes 0x00000000000000000000000000000000000000000000000000000000000000ff
	retsub

// wideRatioTest()uint64
*abi_route_wideRatioTest:
	// The ABI return prefix
	byte 0x151f7c75

	// execute wideRatioTest()uint64
	callsub wideRatioTest
	itob
	concat
	log
	int 1
	return

// wideRatioTest(): uint64
wideRatioTest:
	proto 0 1

	// tests/contracts/math.algo.ts:230
	// return wideRatio([Uint<64>('18446744073709551615'), 2, 3, 4, 5], [2, 3, 4, 5]);
	int 18446744073709551615
	pushint 2
	mulw
	pushint 3
	uncover 2
	dig 1
	*
	cover 2
	mulw
	cover 2
	+
	swap
	pushint 4
	uncover 2
	dig 1
	*
	cover 2
	mulw
	cover 2
	+
	swap
	pushint 5
	uncover 2
	dig 1
	*
	cover 2
	mulw
	cover 2
	+
	swap
	pushint 2
	pushint 3
	mulw
	pushint 4
	uncover 2
	dig 1
	*
	cover 2
	mulw
	cover 2
	+
	swap
	pushint 5
	uncover 2
	dig 1
	*
	cover 2
	mulw
	cover 2
	+
	swap
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	retsub

*abi_route_createApplication:
	int 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x3ce6f1af // method "u64plus(uint64,uint64)uint64"
	pushbytes 0x0031a186 // method "u64minus(uint64,uint64)uint64"
	pushbytes 0xe52e4394 // method "u64mul(uint64,uint64)uint64"
	pushbytes 0x950d4789 // method "u64div(uint64,uint64)uint64"
	pushbytes 0x65bdda6e // method "u256plus(uint256,uint256)uint256"
	pushbytes 0x0a6ad284 // method "u256minus(uint256,uint256)uint256"
	pushbytes 0xf044bf24 // method "u256mul(uint256,uint256)uint256"
	pushbytes 0xc48f8c05 // method "u256div(uint256,uint256)uint256"
	pushbytes 0xf2e1d632 // method "u64Return256(uint64,uint64)uint256"
	pushbytes 0x38b1a39e // method "maxU64()uint64"
	pushbytes 0x6c136f1d // method "exponent(uint64,uint64)uint64"
	pushbytes 0x22da2502 // method "variableTypeHint(uint8,uint8)uint16"
	pushbytes 0xa2fead6c // method "uint8plus(uint8,uint8)uint8"
	pushbytes 0xd2256f7a // method "uint8exp(uint8,uint8)uint8"
	pushbytes 0xc17d624e // method "plusEquals(uint64,uint64)uint64"
	pushbytes 0x5cab0438 // method "plusEqualsFromGlobal(uint64,uint64)uint64"
	pushbytes 0x58989ccd // method "boxTest()uint256"
	pushbytes 0x4830b4de // method "unsafeMethodArgs(uint256,uint256)uint256"
	pushbytes 0xe1c55ce5 // method "uint256ComparisonType(uint256,uint256)void"
	pushbytes 0x7d1d426e // method "squareRoot256(uint256,uint256)uint256"
	pushbytes 0x1c2981f1 // method "squareRoot64(uint64,uint64)uint64"
	pushbytes 0xb7ca04b9 // method "addressToBigInt(address)bool"
	pushbytes 0xbb952338 // method "u8Tou64()uint64"
	pushbytes 0x0128e27b // method "funcName(uint256)void"
	pushbytes 0xf916cdb3 // method "bigintPlus(uint64,uint64)uint64"
	pushbytes 0x52737545 // method "bitwiseOr(uint64,uint64)uint64"
	pushbytes 0x79c1adc0 // method "bitwiseAnd(uint64,uint64)uint64"
	pushbytes 0x22474abc // method "bitwiseXor(uint64,uint64)uint64"
	pushbytes 0x0593fdf8 // method "bitwiseOrU256(uint256,uint256)uint256"
	pushbytes 0x06fb9337 // method "bitwiseAndU256(uint256,uint256)uint256"
	pushbytes 0x26493d78 // method "bitwiseXorU256(uint256,uint256)uint256"
	pushbytes 0xe9c22eea // method "bitwiseNot(uint64)uint64"
	pushbytes 0xede3e9bc // method "bitwiseNotU256(uint256)uint256"
	pushbytes 0x2e4a2164 // method "mulw(uint64,uint64)uint64"
	pushbytes 0x50134b5a // method "addw(uint64,uint64)uint64"
	pushbytes 0xf53aff9b // method "expw(uint64,uint64)uint64"
	pushbytes 0xcaf7110d // method "divw(uint64,uint64)uint64"
	pushbytes 0xbed0e386 // method "divmodw(uint64,uint64)uint64"
	pushbytes 0x274d7705 // method "unsafeVariables()uint64"
	pushbytes 0x92465d08 // method "foobar(uint128)uint128"
	pushbytes 0xf01facce // method "uintFromHex()uint256"
	pushbytes 0x5ac8a0a0 // method "wideRatioTest()uint64"
	txna ApplicationArgs 0
	match *abi_route_u64plus *abi_route_u64minus *abi_route_u64mul *abi_route_u64div *abi_route_u256plus *abi_route_u256minus *abi_route_u256mul *abi_route_u256div *abi_route_u64Return256 *abi_route_maxU64 *abi_route_exponent *abi_route_variableTypeHint *abi_route_uint8plus *abi_route_uint8exp *abi_route_plusEquals *abi_route_plusEqualsFromGlobal *abi_route_boxTest *abi_route_unsafeMethodArgs *abi_route_uint256ComparisonType *abi_route_squareRoot256 *abi_route_squareRoot64 *abi_route_addressToBigInt *abi_route_u8Tou64 *abi_route_funcName *abi_route_bigintPlus *abi_route_bitwiseOr *abi_route_bitwiseAnd *abi_route_bitwiseXor *abi_route_bitwiseOrU256 *abi_route_bitwiseAndU256 *abi_route_bitwiseXorU256 *abi_route_bitwiseNot *abi_route_bitwiseNotU256 *abi_route_mulw *abi_route_addw *abi_route_expw *abi_route_divw *abi_route_divmodw *abi_route_unsafeVariables *abi_route_foobar *abi_route_uintFromHex *abi_route_wideRatioTest

	// this contract does not implement the given ABI method for call NoOp
	err", + "approval": "#pragma version 10
intcblock 1 32 256 18446744073709551615
bytecblock 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF 0x151f7c75 0x0000000000000000000000000000000000000000000000000000000000000001 0x00000000000000000000000000000000000000000000000000000000000003e8 0x626f784b6579 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF 0x 0x674b6579 0xFFFFFFFFFFFFFFFF

// This TEAL was generated by TEALScript v0.105.0
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// u64plus(uint64,uint64)uint64
*abi_route_u64plus:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute u64plus(uint64,uint64)uint64
	callsub u64plus
	itob
	concat
	log
	int 1
	return

// u64plus(a: uint64, b: uint64): uint64
u64plus:
	proto 2 1

	// tests/contracts/math.algo.ts:8
	// return a + b;
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	+
	retsub

// u64minus(uint64,uint64)uint64
*abi_route_u64minus:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute u64minus(uint64,uint64)uint64
	callsub u64minus
	itob
	concat
	log
	int 1
	return

// u64minus(a: uint64, b: uint64): uint64
u64minus:
	proto 2 1

	// tests/contracts/math.algo.ts:12
	// return a - b;
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	-
	retsub

// u64mul(uint64,uint64)uint64
*abi_route_u64mul:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute u64mul(uint64,uint64)uint64
	callsub u64mul
	itob
	concat
	log
	int 1
	return

// u64mul(a: uint64, b: uint64): uint64
u64mul:
	proto 2 1

	// tests/contracts/math.algo.ts:16
	// return a * b;
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	*
	retsub

// u64div(uint64,uint64)uint64
*abi_route_u64div:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute u64div(uint64,uint64)uint64
	callsub u64div
	itob
	concat
	log
	int 1
	return

// u64div(a: uint64, b: uint64): uint64
u64div:
	proto 2 1

	// tests/contracts/math.algo.ts:20
	// return a / b;
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	/
	retsub

// u256plus(uint256,uint256)uint256
*abi_route_u256plus:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint256
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (b) for u256plus must be a uint256
	assert

	// a: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (a) for u256plus must be a uint256
	assert

	// execute u256plus(uint256,uint256)uint256
	callsub u256plus
	dup
	bitlen
	int 256
	<=

	// u256plus return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// u256plus(a: uint256, b: uint256): uint256
u256plus:
	proto 2 1

	// tests/contracts/math.algo.ts:24
	// return <uint256>(a + b);
	frame_dig -1 // a: uint256
	frame_dig -2 // b: uint256
	b+
	retsub

// u256minus(uint256,uint256)uint256
*abi_route_u256minus:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint256
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (b) for u256minus must be a uint256
	assert

	// a: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (a) for u256minus must be a uint256
	assert

	// execute u256minus(uint256,uint256)uint256
	callsub u256minus
	dup
	bitlen
	int 256
	<=

	// u256minus return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// u256minus(a: uint256, b: uint256): uint256
u256minus:
	proto 2 1

	// tests/contracts/math.algo.ts:28
	// return <uint256>(a - b);
	frame_dig -1 // a: uint256
	frame_dig -2 // b: uint256
	b-
	retsub

// u256mul(uint256,uint256)uint256
*abi_route_u256mul:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint256
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (b) for u256mul must be a uint256
	assert

	// a: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (a) for u256mul must be a uint256
	assert

	// execute u256mul(uint256,uint256)uint256
	callsub u256mul
	dup
	bitlen
	int 256
	<=

	// u256mul return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// u256mul(a: uint256, b: uint256): uint256
u256mul:
	proto 2 1

	// tests/contracts/math.algo.ts:32
	// return <uint256>(a * b);
	frame_dig -1 // a: uint256
	frame_dig -2 // b: uint256
	b*
	retsub

// u256div(uint256,uint256)uint256
*abi_route_u256div:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint256
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (b) for u256div must be a uint256
	assert

	// a: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (a) for u256div must be a uint256
	assert

	// execute u256div(uint256,uint256)uint256
	callsub u256div
	dup
	bitlen
	int 256
	<=

	// u256div return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// u256div(a: uint256, b: uint256): uint256
u256div:
	proto 2 1

	// tests/contracts/math.algo.ts:36
	// return <uint256>(a / b);
	frame_dig -1 // a: uint256
	frame_dig -2 // b: uint256
	b/
	retsub

// u64Return256(uint64,uint64)uint256
*abi_route_u64Return256:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute u64Return256(uint64,uint64)uint256
	callsub u64Return256
	dup
	bitlen
	int 256
	<=

	// u64Return256 return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// u64Return256(a: uint64, b: uint64): uint256
u64Return256:
	proto 2 1

	// tests/contracts/math.algo.ts:40
	// return <uint256>(a + b);
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	+
	itob
	retsub

// maxU64()uint64
*abi_route_maxU64:
	// The ABI return prefix
	byte 0x151f7c75

	// execute maxU64()uint64
	callsub maxU64
	itob
	concat
	log
	int 1
	return

// maxU64(): uint64
maxU64:
	proto 0 1

	// tests/contracts/math.algo.ts:44
	// return Uint<64>('18446744073709551615');
	int 18446744073709551615
	retsub

// exponent(uint64,uint64)uint64
*abi_route_exponent:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute exponent(uint64,uint64)uint64
	callsub exponent
	itob
	concat
	log
	int 1
	return

// exponent(a: uint64, b: uint64): uint64
exponent:
	proto 2 1

	// tests/contracts/math.algo.ts:48
	// return a ** b;
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	exp
	retsub

// variableTypeHint(uint8,uint8)uint16
*abi_route_variableTypeHint:
	// The ABI return prefix
	byte 0x151f7c75

	// y: uint8
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 0 (y) for variableTypeHint must be a uint8
	assert
	btoi

	// x: uint8
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 1 (x) for variableTypeHint must be a uint8
	assert
	btoi

	// execute variableTypeHint(uint8,uint8)uint16
	callsub variableTypeHint
	itob
	dup
	bitlen
	pushint 16
	<=

	// variableTypeHint return value overflowed 16 bits
	assert
	extract 6 2
	concat
	log
	int 1
	return

// variableTypeHint(x: uint<8>, y: uint<8>): uint16
variableTypeHint:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/math.algo.ts:52
	// z = <uint16>(x + y)
	frame_dig -1 // x: uint<8>
	frame_dig -2 // y: uint<8>
	+
	frame_bury 0 // z: unsafe uint16

	// tests/contracts/math.algo.ts:54
	// return z;
	frame_dig 0 // z: unsafe uint16

	// set the subroutine return value
	frame_bury 0
	retsub

// uint8plus(uint8,uint8)uint8
*abi_route_uint8plus:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint8
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 0 (b) for uint8plus must be a uint8
	assert
	btoi

	// a: uint8
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 1 (a) for uint8plus must be a uint8
	assert
	btoi

	// execute uint8plus(uint8,uint8)uint8
	callsub uint8plus
	itob
	dup
	bitlen
	pushint 8
	<=

	// uint8plus return value overflowed 8 bits
	assert
	extract 7 1
	concat
	log
	int 1
	return

// uint8plus(a: uint<8>, b: uint<8>): uint<8>
uint8plus:
	proto 2 1

	// tests/contracts/math.algo.ts:58
	// return a + b;
	frame_dig -1 // a: uint<8>
	frame_dig -2 // b: uint<8>
	+
	retsub

// uint8exp(uint8,uint8)uint8
*abi_route_uint8exp:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint8
	txna ApplicationArgs 2
	dup
	len
	int 1
	==

	// argument 0 (b) for uint8exp must be a uint8
	assert
	btoi

	// a: uint8
	txna ApplicationArgs 1
	dup
	len
	int 1
	==

	// argument 1 (a) for uint8exp must be a uint8
	assert
	btoi

	// execute uint8exp(uint8,uint8)uint8
	callsub uint8exp
	itob
	dup
	bitlen
	pushint 8
	<=

	// uint8exp return value overflowed 8 bits
	assert
	extract 7 1
	concat
	log
	int 1
	return

// uint8exp(a: uint<8>, b: uint<8>): uint<8>
uint8exp:
	proto 2 1

	// tests/contracts/math.algo.ts:62
	// return a ** b;
	frame_dig -1 // a: uint<8>
	frame_dig -2 // b: uint<8>
	exp
	retsub

// plusEquals(uint64,uint64)uint64
*abi_route_plusEquals:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute plusEquals(uint64,uint64)uint64
	callsub plusEquals
	itob
	concat
	log
	int 1
	return

// plusEquals(a: uint64, b: uint64): uint64
plusEquals:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/math.algo.ts:66
	// x = a
	frame_dig -1 // a: uint64
	frame_bury 0 // x: uint64

	// tests/contracts/math.algo.ts:68
	// x += b
	frame_dig 0 // x: uint64
	frame_dig -2 // b: uint64
	+
	frame_bury 0 // x: uint64

	// tests/contracts/math.algo.ts:70
	// return x;
	frame_dig 0 // x: uint64

	// set the subroutine return value
	frame_bury 0
	retsub

// plusEqualsFromGlobal(uint64,uint64)uint64
*abi_route_plusEqualsFromGlobal:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute plusEqualsFromGlobal(uint64,uint64)uint64
	callsub plusEqualsFromGlobal
	itob
	concat
	log
	int 1
	return

// plusEqualsFromGlobal(a: uint64, b: uint64): uint64
plusEqualsFromGlobal:
	proto 2 1

	// tests/contracts/math.algo.ts:74
	// this.gKey.value = a
	byte 0x674b6579 // "gKey"
	frame_dig -1 // a: uint64
	app_global_put

	// tests/contracts/math.algo.ts:76
	// this.gKey.value += b
	byte 0x674b6579 // "gKey"
	app_global_get
	frame_dig -2 // b: uint64
	+
	byte 0x674b6579 // "gKey"
	swap
	app_global_put

	// tests/contracts/math.algo.ts:78
	// return this.gKey.value;
	byte 0x674b6579 // "gKey"
	app_global_get
	retsub

// boxTest()uint256
*abi_route_boxTest:
	// The ABI return prefix
	byte 0x151f7c75

	// execute boxTest()uint256
	callsub boxTest
	dup
	bitlen
	int 256
	<=

	// boxTest return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// boxTest(): uint256
boxTest:
	proto 0 1

	// tests/contracts/math.algo.ts:84
	// this.boxKey.value = <uint256>1
	byte 0x626f784b6579 // "boxKey"
	byte 0x0000000000000000000000000000000000000000000000000000000000000001
	box_put

	// tests/contracts/math.algo.ts:85
	// this.boxKey.value += 1
	byte 0x626f784b6579 // "boxKey"
	box_get

	// box value does not exist: this.boxKey.value
	assert
	byte 0x0000000000000000000000000000000000000000000000000000000000000001
	b+
	byte 0x626f784b6579 // "boxKey"
	dup
	bitlen
	int 256
	<=

	// this.boxKey.value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	swap
	box_put

	// tests/contracts/math.algo.ts:87
	// return this.boxKey.value;
	byte 0x626f784b6579 // "boxKey"
	box_get

	// box value does not exist: this.boxKey.value
	assert
	retsub

// foo(x: uint256): uint256
foo:
	proto 1 1

	// tests/contracts/math.algo.ts:91
	// return x;
	frame_dig -1 // x: uint256
	retsub

// unsafeMethodArgs(uint256,uint256)uint256
*abi_route_unsafeMethodArgs:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint256
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (b) for unsafeMethodArgs must be a uint256
	assert

	// a: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (a) for unsafeMethodArgs must be a uint256
	assert

	// execute unsafeMethodArgs(uint256,uint256)uint256
	callsub unsafeMethodArgs
	dup
	bitlen
	int 256
	<=

	// unsafeMethodArgs return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// unsafeMethodArgs(a: uint256, b: uint256): uint256
unsafeMethodArgs:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/math.algo.ts:95
	// c = a + b
	frame_dig -1 // a: uint256
	frame_dig -2 // b: uint256
	b+
	frame_bury 0 // c: unsafe uint256

	// tests/contracts/math.algo.ts:97
	// return this.foo(c);
	frame_dig 0 // c: unsafe uint256
	dup
	bitlen
	int 256
	<=

	// c overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	callsub foo

	// set the subroutine return value
	frame_bury 0
	retsub

// uint256ComparisonType(uint256,uint256)void
*abi_route_uint256ComparisonType:
	// b: uint256
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (b) for uint256ComparisonType must be a uint256
	assert

	// a: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (a) for uint256ComparisonType must be a uint256
	assert

	// execute uint256ComparisonType(uint256,uint256)void
	callsub uint256ComparisonType
	int 1
	return

// uint256ComparisonType(a: uint256, b: uint256): void
uint256ComparisonType:
	proto 2 0

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/math.algo.ts:101
	// senderBalanceAfter = a - b
	frame_dig -1 // a: uint256
	frame_dig -2 // b: uint256
	b-
	frame_bury 0 // senderBalanceAfter: unsafe uint256

	// *if0_condition
	// tests/contracts/math.algo.ts:102
	// senderBalanceAfter > <uint256>0
	frame_dig 0 // senderBalanceAfter: unsafe uint256
	pushbytes 0x0000000000000000000000000000000000000000000000000000000000000000
	b>
	bz *if0_else

	// *if0_consequent
	// tests/contracts/math.algo.ts:103
	// log('nonZero')
	pushbytes 0x6e6f6e5a65726f // "nonZero"
	log
	b *if0_end

*if0_else:
	// tests/contracts/math.algo.ts:105
	// log('zero')
	pushbytes 0x7a65726f // "zero"
	log

*if0_end:
	retsub

// squareRoot256(uint256,uint256)uint256
*abi_route_squareRoot256:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint256
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (b) for squareRoot256 must be a uint256
	assert

	// a: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (a) for squareRoot256 must be a uint256
	assert

	// execute squareRoot256(uint256,uint256)uint256
	callsub squareRoot256
	dup
	bitlen
	int 256
	<=

	// squareRoot256 return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// squareRoot256(a: uint256, b: uint256): uint256
squareRoot256:
	proto 2 1

	// tests/contracts/math.algo.ts:110
	// return sqrt(a * b);
	frame_dig -1 // a: uint256
	frame_dig -2 // b: uint256
	b*
	bsqrt
	retsub

// squareRoot64(uint64,uint64)uint64
*abi_route_squareRoot64:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute squareRoot64(uint64,uint64)uint64
	callsub squareRoot64
	itob
	concat
	log
	int 1
	return

// squareRoot64(a: uint64, b: uint64): uint64
squareRoot64:
	proto 2 1

	// tests/contracts/math.algo.ts:114
	// return sqrt(a * b);
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	*
	sqrt
	retsub

// addressToBigInt(address)bool
*abi_route_addressToBigInt:
	// The ABI return prefix
	byte 0x151f7c75

	// addr: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (addr) for addressToBigInt must be a address
	assert

	// execute addressToBigInt(address)bool
	callsub addressToBigInt
	pushbytes 0x00
	pushint 0
	uncover 2
	setbit
	concat
	log
	int 1
	return

// addressToBigInt(addr: Address): boolean
addressToBigInt:
	proto 1 1

	// tests/contracts/math.algo.ts:118
	// return btobigint(addr) > btobigint(this.txn.sender);
	frame_dig -1 // addr: Address
	txn Sender
	b>
	retsub

// u8Tou64()uint64
*abi_route_u8Tou64:
	// The ABI return prefix
	byte 0x151f7c75

	// execute u8Tou64()uint64
	callsub u8Tou64
	itob
	concat
	log
	int 1
	return

// u8Tou64(): uint64
u8Tou64:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/math.algo.ts:122
	// x: uint8 = 7
	pushint 7
	frame_bury 0 // x: uint8

	// tests/contracts/math.algo.ts:123
	// return <uint64>x;
	frame_dig 0 // x: uint8

	// set the subroutine return value
	frame_bury 0
	retsub

// privateFuncName(x: uint8, y: uint64): void
privateFuncName:
	proto 2 0

	// tests/contracts/math.algo.ts:127
	// assert(<uint8>y > x)
	frame_dig -2 // y: uint64
	frame_dig -1 // x: uint8
	>
	assert
	retsub

// funcName(uint256)void
*abi_route_funcName:
	// x: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (x) for funcName must be a uint256
	assert

	// execute funcName(uint256)void
	callsub funcName
	int 1
	return

// funcName(x: uint256): void
funcName:
	proto 1 0

	// tests/contracts/math.algo.ts:131
	// this.privateFuncName(<uint8>x, 1337)
	pushint 1337
	frame_dig -1 // x: uint256
	dup
	bitlen
	pushint 8
	<=

	// <uint8>x overflowed 8 bits
	assert
	extract 31 1
	btoi
	callsub privateFuncName
	retsub

// bigintPlus(uint64,uint64)uint64
*abi_route_bigintPlus:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute bigintPlus(uint64,uint64)uint64
	callsub bigintPlus
	itob
	concat
	log
	int 1
	return

// bigintPlus(a: uint64, b: uint64): uint64
bigintPlus:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// tests/contracts/math.algo.ts:135
	// x = itob(a)
	frame_dig -1 // a: uint64
	itob
	frame_bury 0 // x: byte[]

	// tests/contracts/math.algo.ts:136
	// y = itob(b)
	frame_dig -2 // b: uint64
	itob
	frame_bury 1 // y: byte[]

	// tests/contracts/math.algo.ts:137
	// return (btobigint(x) + btobigint(y)) as uint64;
	frame_dig 0 // x: byte[]
	frame_dig 1 // y: byte[]
	b+
	dup
	bitlen
	pushint 64
	<=

	// (btobigint(x) + btobigint(y)) as uint64 overflowed 64 bits
	assert
	byte 0xFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	pushint 8
	-
	swap
	substring3
	btoi

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 1
	retsub

// bitwiseOr(uint64,uint64)uint64
*abi_route_bitwiseOr:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute bitwiseOr(uint64,uint64)uint64
	callsub bitwiseOr
	itob
	concat
	log
	int 1
	return

// bitwiseOr(a: uint64, b: uint64): uint64
bitwiseOr:
	proto 2 1

	// tests/contracts/math.algo.ts:141
	// return a | b;
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	|
	retsub

// bitwiseAnd(uint64,uint64)uint64
*abi_route_bitwiseAnd:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute bitwiseAnd(uint64,uint64)uint64
	callsub bitwiseAnd
	itob
	concat
	log
	int 1
	return

// bitwiseAnd(a: uint64, b: uint64): uint64
bitwiseAnd:
	proto 2 1

	// tests/contracts/math.algo.ts:145
	// return a & b;
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	&
	retsub

// bitwiseXor(uint64,uint64)uint64
*abi_route_bitwiseXor:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute bitwiseXor(uint64,uint64)uint64
	callsub bitwiseXor
	itob
	concat
	log
	int 1
	return

// bitwiseXor(a: uint64, b: uint64): uint64
bitwiseXor:
	proto 2 1

	// tests/contracts/math.algo.ts:149
	// return a ^ b;
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	^
	retsub

// bitwiseOrU256(uint256,uint256)uint256
*abi_route_bitwiseOrU256:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint256
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (b) for bitwiseOrU256 must be a uint256
	assert

	// a: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (a) for bitwiseOrU256 must be a uint256
	assert

	// execute bitwiseOrU256(uint256,uint256)uint256
	callsub bitwiseOrU256
	dup
	bitlen
	int 256
	<=

	// bitwiseOrU256 return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// bitwiseOrU256(a: uint256, b: uint256): uint256
bitwiseOrU256:
	proto 2 1

	// tests/contracts/math.algo.ts:153
	// return a | b;
	frame_dig -1 // a: uint256
	frame_dig -2 // b: uint256
	b|
	retsub

// bitwiseAndU256(uint256,uint256)uint256
*abi_route_bitwiseAndU256:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint256
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (b) for bitwiseAndU256 must be a uint256
	assert

	// a: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (a) for bitwiseAndU256 must be a uint256
	assert

	// execute bitwiseAndU256(uint256,uint256)uint256
	callsub bitwiseAndU256
	dup
	bitlen
	int 256
	<=

	// bitwiseAndU256 return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// bitwiseAndU256(a: uint256, b: uint256): uint256
bitwiseAndU256:
	proto 2 1

	// tests/contracts/math.algo.ts:157
	// return a & b;
	frame_dig -1 // a: uint256
	frame_dig -2 // b: uint256
	b&
	retsub

// bitwiseXorU256(uint256,uint256)uint256
*abi_route_bitwiseXorU256:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint256
	txna ApplicationArgs 2
	dup
	len
	int 32
	==

	// argument 0 (b) for bitwiseXorU256 must be a uint256
	assert

	// a: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 1 (a) for bitwiseXorU256 must be a uint256
	assert

	// execute bitwiseXorU256(uint256,uint256)uint256
	callsub bitwiseXorU256
	dup
	bitlen
	int 256
	<=

	// bitwiseXorU256 return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// bitwiseXorU256(a: uint256, b: uint256): uint256
bitwiseXorU256:
	proto 2 1

	// tests/contracts/math.algo.ts:161
	// return a ^ b;
	frame_dig -1 // a: uint256
	frame_dig -2 // b: uint256
	b^
	retsub

// bitwiseNot(uint64)uint64
*abi_route_bitwiseNot:
	// The ABI return prefix
	byte 0x151f7c75

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute bitwiseNot(uint64)uint64
	callsub bitwiseNot
	itob
	concat
	log
	int 1
	return

// bitwiseNot(a: uint64): uint64
bitwiseNot:
	proto 1 1

	// tests/contracts/math.algo.ts:165
	// return ~a;
	frame_dig -1 // a: uint64
	~
	retsub

// bitwiseNotU256(uint256)uint256
*abi_route_bitwiseNotU256:
	// The ABI return prefix
	byte 0x151f7c75

	// a: uint256
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for bitwiseNotU256 must be a uint256
	assert

	// execute bitwiseNotU256(uint256)uint256
	callsub bitwiseNotU256
	dup
	bitlen
	int 256
	<=

	// bitwiseNotU256 return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// bitwiseNotU256(a: uint256): uint256
bitwiseNotU256:
	proto 1 1

	// tests/contracts/math.algo.ts:169
	// return ~a;
	frame_dig -1 // a: uint256
	b~
	retsub

// mulw(uint64,uint64)uint64
*abi_route_mulw:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute mulw(uint64,uint64)uint64
	callsub mulw
	itob
	concat
	log
	int 1
	return

// mulw(a: uint64, b: uint64): uint64
mulw:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// tests/contracts/math.algo.ts:173
	// p = mulw(a, b)
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	mulw
	frame_bury 0 // p low: uint64
	frame_bury 1 // p high: uint64

	// tests/contracts/math.algo.ts:177
	// return p2.low;
	frame_dig 0 // p low: uint64

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 1
	retsub

// addw(uint64,uint64)uint64
*abi_route_addw:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute addw(uint64,uint64)uint64
	callsub addw
	itob
	concat
	log
	int 1
	return

// addw(a: uint64, b: uint64): uint64
addw:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// tests/contracts/math.algo.ts:181
	// p = addw(a, b)
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	addw
	frame_bury 0 // p low: uint64
	frame_bury 1 // p high: uint64

	// tests/contracts/math.algo.ts:185
	// return p2.low;
	frame_dig 0 // p low: uint64

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 1
	retsub

// expw(uint64,uint64)uint64
*abi_route_expw:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute expw(uint64,uint64)uint64
	callsub expw
	itob
	concat
	log
	int 1
	return

// expw(a: uint64, b: uint64): uint64
expw:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dup

	// tests/contracts/math.algo.ts:189
	// p = expw(a, b)
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	expw
	frame_bury 0 // p low: uint64
	frame_bury 1 // p high: uint64

	// tests/contracts/math.algo.ts:193
	// return p2.low;
	frame_dig 0 // p low: uint64

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 1
	retsub

// divw(uint64,uint64)uint64
*abi_route_divw:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute divw(uint64,uint64)uint64
	callsub divw
	itob
	concat
	log
	int 1
	return

// divw(a: uint64, b: uint64): uint64
divw:
	proto 2 1

	// tests/contracts/math.algo.ts:197
	// return divw(0, a, b);
	pushint 0
	frame_dig -1 // a: uint64
	frame_dig -2 // b: uint64
	divw
	retsub

// divmodw(uint64,uint64)uint64
*abi_route_divmodw:
	// The ABI return prefix
	byte 0x151f7c75

	// b: uint64
	txna ApplicationArgs 2
	btoi

	// a: uint64
	txna ApplicationArgs 1
	btoi

	// execute divmodw(uint64,uint64)uint64
	callsub divmodw
	itob
	concat
	log
	int 1
	return

// divmodw(a: uint64, b: uint64): uint64
divmodw:
	proto 2 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 3

	// tests/contracts/math.algo.ts:201
	// p = divmodw(0, a, 0, b)
	pushint 0
	frame_dig -1 // a: uint64
	pushint 0
	frame_dig -2 // b: uint64
	divmodw
	frame_bury 0 // p remainderLow: uint64
	frame_bury 1 // p remainderHigh: uint64
	frame_bury 2 // p quotientLow: uint64
	frame_bury 3 // p quotientHigh: uint64

	// tests/contracts/math.algo.ts:205
	// return p2.quotientLow;
	frame_dig 2 // p quotientLow: uint64

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 3
	retsub

// unsafeVariables()uint64
*abi_route_unsafeVariables:
	// The ABI return prefix
	byte 0x151f7c75

	// execute unsafeVariables()uint64
	callsub unsafeVariables
	itob
	concat
	log
	int 1
	return

// unsafeVariables(): uint64
unsafeVariables:
	proto 0 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x
	dupn 2

	// tests/contracts/math.algo.ts:209
	// A = <uint256>250000000
	pushbytes 0x000000000000000000000000000000000000000000000000000000000ee6b280
	frame_bury 0 // A: unsafe uint256

	// tests/contracts/math.algo.ts:210
	// B = <uint256>1000
	byte 0x00000000000000000000000000000000000000000000000000000000000003e8
	frame_bury 1 // B: uint256

	// tests/contracts/math.algo.ts:212
	// A = A / B
	frame_dig 0 // A: unsafe uint256
	byte 0x00000000000000000000000000000000000000000000000000000000000003e8 // B: uint256
	b/
	frame_bury 0 // A: unsafe uint256

	// tests/contracts/math.algo.ts:214
	// c = A as uint64
	frame_dig 0 // A: unsafe uint256
	dup
	bitlen
	pushint 64
	<=

	// A as uint64 overflowed 64 bits
	assert
	byte 0xFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	pushint 8
	-
	swap
	substring3
	btoi
	frame_bury 2 // c: uint64

	// tests/contracts/math.algo.ts:216
	// return c;
	frame_dig 2 // c: uint64

	// set the subroutine return value
	frame_bury 0

	// pop all local variables from the stack
	popn 2
	retsub

// foobar(uint128)uint128
*abi_route_foobar:
	// The ABI return prefix
	byte 0x151f7c75

	// x: uint128
	txna ApplicationArgs 1
	dup
	len
	pushint 16
	==

	// argument 0 (x) for foobar must be a uint128
	assert

	// execute foobar(uint128)uint128
	callsub foobar
	dup
	bitlen
	pushint 128
	<=

	// foobar return value overflowed 128 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	pushint 16
	-
	swap
	substring3
	concat
	log
	int 1
	return

// foobar(x: uint128): uint128
foobar:
	proto 1 1

	// Push empty bytes after the frame pointer to reserve space for local variables
	byte 0x

	// tests/contracts/math.algo.ts:220
	// avgStake: uint128 = x / (30000 as uint128)
	frame_dig -1 // x: uint128
	pushbytes 0x00000000000000000000000000007530
	b/
	dup
	bitlen
	pushint 128
	<=

	// x / (30000 as uint128) overflowed 128 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	pushint 16
	-
	swap
	substring3
	frame_bury 0 // avgStake: uint128

	// tests/contracts/math.algo.ts:222
	// return avgStake;
	frame_dig 0 // avgStake: uint128

	// set the subroutine return value
	frame_bury 0
	retsub

// uintFromHex()uint256
*abi_route_uintFromHex:
	// The ABI return prefix
	byte 0x151f7c75

	// execute uintFromHex()uint256
	callsub uintFromHex
	dup
	bitlen
	int 256
	<=

	// uintFromHex return value overflowed 256 bits
	assert
	byte 0xFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFFF
	b&
	dup
	len
	dup
	int 32
	-
	swap
	substring3
	concat
	log
	int 1
	return

// uintFromHex(): uint256
uintFromHex:
	proto 0 1

	// tests/contracts/math.algo.ts:226
	// return Uint<256>('0xFF');
	pushbytes 0x00000000000000000000000000000000000000000000000000000000000000ff
	retsub

// wideRatioTest()uint64
*abi_route_wideRatioTest:
	// The ABI return prefix
	byte 0x151f7c75

	// execute wideRatioTest()uint64
	callsub wideRatioTest
	itob
	concat
	log
	int 1
	return

// wideRatioTest(): uint64
wideRatioTest:
	proto 0 1

	// tests/contracts/math.algo.ts:230
	// return wideRatio([Uint<64>('18446744073709551615'), 2, 3, 4, 5], [2, 3, 4, 5]);
	int 18446744073709551615
	pushint 2
	mulw
	pushint 3
	uncover 2
	dig 1
	*
	cover 2
	mulw
	cover 2
	+
	swap
	pushint 4
	uncover 2
	dig 1
	*
	cover 2
	mulw
	cover 2
	+
	swap
	pushint 5
	uncover 2
	dig 1
	*
	cover 2
	mulw
	cover 2
	+
	swap
	pushint 2
	pushint 3
	mulw
	pushint 4
	uncover 2
	dig 1
	*
	cover 2
	mulw
	cover 2
	+
	swap
	pushint 5
	uncover 2
	dig 1
	*
	cover 2
	mulw
	cover 2
	+
	swap
	divmodw
	pop
	pop
	swap
	!

	// wideRatio failed
	assert
	retsub

*abi_route_createApplication:
	int 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x3ce6f1af // method "u64plus(uint64,uint64)uint64"
	pushbytes 0x0031a186 // method "u64minus(uint64,uint64)uint64"
	pushbytes 0xe52e4394 // method "u64mul(uint64,uint64)uint64"
	pushbytes 0x950d4789 // method "u64div(uint64,uint64)uint64"
	pushbytes 0x65bdda6e // method "u256plus(uint256,uint256)uint256"
	pushbytes 0x0a6ad284 // method "u256minus(uint256,uint256)uint256"
	pushbytes 0xf044bf24 // method "u256mul(uint256,uint256)uint256"
	pushbytes 0xc48f8c05 // method "u256div(uint256,uint256)uint256"
	pushbytes 0xf2e1d632 // method "u64Return256(uint64,uint64)uint256"
	pushbytes 0x38b1a39e // method "maxU64()uint64"
	pushbytes 0x6c136f1d // method "exponent(uint64,uint64)uint64"
	pushbytes 0x22da2502 // method "variableTypeHint(uint8,uint8)uint16"
	pushbytes 0xa2fead6c // method "uint8plus(uint8,uint8)uint8"
	pushbytes 0xd2256f7a // method "uint8exp(uint8,uint8)uint8"
	pushbytes 0xc17d624e // method "plusEquals(uint64,uint64)uint64"
	pushbytes 0x5cab0438 // method "plusEqualsFromGlobal(uint64,uint64)uint64"
	pushbytes 0x58989ccd // method "boxTest()uint256"
	pushbytes 0x4830b4de // method "unsafeMethodArgs(uint256,uint256)uint256"
	pushbytes 0xe1c55ce5 // method "uint256ComparisonType(uint256,uint256)void"
	pushbytes 0x7d1d426e // method "squareRoot256(uint256,uint256)uint256"
	pushbytes 0x1c2981f1 // method "squareRoot64(uint64,uint64)uint64"
	pushbytes 0xb7ca04b9 // method "addressToBigInt(address)bool"
	pushbytes 0xbb952338 // method "u8Tou64()uint64"
	pushbytes 0x0128e27b // method "funcName(uint256)void"
	pushbytes 0xf916cdb3 // method "bigintPlus(uint64,uint64)uint64"
	pushbytes 0x52737545 // method "bitwiseOr(uint64,uint64)uint64"
	pushbytes 0x79c1adc0 // method "bitwiseAnd(uint64,uint64)uint64"
	pushbytes 0x22474abc // method "bitwiseXor(uint64,uint64)uint64"
	pushbytes 0x0593fdf8 // method "bitwiseOrU256(uint256,uint256)uint256"
	pushbytes 0x06fb9337 // method "bitwiseAndU256(uint256,uint256)uint256"
	pushbytes 0x26493d78 // method "bitwiseXorU256(uint256,uint256)uint256"
	pushbytes 0xe9c22eea // method "bitwiseNot(uint64)uint64"
	pushbytes 0xede3e9bc // method "bitwiseNotU256(uint256)uint256"
	pushbytes 0x2e4a2164 // method "mulw(uint64,uint64)uint64"
	pushbytes 0x50134b5a // method "addw(uint64,uint64)uint64"
	pushbytes 0xf53aff9b // method "expw(uint64,uint64)uint64"
	pushbytes 0xcaf7110d // method "divw(uint64,uint64)uint64"
	pushbytes 0xbed0e386 // method "divmodw(uint64,uint64)uint64"
	pushbytes 0x274d7705 // method "unsafeVariables()uint64"
	pushbytes 0x92465d08 // method "foobar(uint128)uint128"
	pushbytes 0xf01facce // method "uintFromHex()uint256"
	pushbytes 0x5ac8a0a0 // method "wideRatioTest()uint64"
	txna ApplicationArgs 0
	match *abi_route_u64plus *abi_route_u64minus *abi_route_u64mul *abi_route_u64div *abi_route_u256plus *abi_route_u256minus *abi_route_u256mul *abi_route_u256div *abi_route_u64Return256 *abi_route_maxU64 *abi_route_exponent *abi_route_variableTypeHint *abi_route_uint8plus *abi_route_uint8exp *abi_route_plusEquals *abi_route_plusEqualsFromGlobal *abi_route_boxTest *abi_route_unsafeMethodArgs *abi_route_uint256ComparisonType *abi_route_squareRoot256 *abi_route_squareRoot64 *abi_route_addressToBigInt *abi_route_u8Tou64 *abi_route_funcName *abi_route_bigintPlus *abi_route_bitwiseOr *abi_route_bitwiseAnd *abi_route_bitwiseXor *abi_route_bitwiseOrU256 *abi_route_bitwiseAndU256 *abi_route_bitwiseXorU256 *abi_route_bitwiseNot *abi_route_bitwiseNotU256 *abi_route_mulw *abi_route_addw *abi_route_expw *abi_route_divw *abi_route_divmodw *abi_route_unsafeVariables *abi_route_foobar *abi_route_uintFromHex *abi_route_wideRatioTest

	// this contract does not implement the given ABI method for call NoOp
	err", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/MultiInheritance.approval.teal b/tests/contracts/artifacts/MultiInheritance.approval.teal index 0ff9340ae..f6d6e2157 100644 --- a/tests/contracts/artifacts/MultiInheritance.approval.teal +++ b/tests/contracts/artifacts/MultiInheritance.approval.teal @@ -1,7 +1,7 @@ #pragma version 10 bytecblock 0x61 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/MultiInheritance.arc32.json b/tests/contracts/artifacts/MultiInheritance.arc32.json index 781e92391..18f611723 100644 --- a/tests/contracts/artifacts/MultiInheritance.arc32.json +++ b/tests/contracts/artifacts/MultiInheritance.arc32.json @@ -63,7 +63,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2MQoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDQuMQovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIGEoKXZvaWQKKmFiaV9yb3V0ZV9hOgoJLy8gZXhlY3V0ZSBhKCl2b2lkCgljYWxsc3ViIGEKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBhKCk6IHZvaWQKYToKCXByb3RvIDAgMAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS5hbGdvLnRzOjE2CgkvLyB0aGlzLmFLZXkudmFsdWUgPSAxMzM3CglieXRlIDB4NjEgLy8gImEiCglwdXNoaW50IDEzMzcKCWFwcF9nbG9iYWxfcHV0CglyZXRzdWIKCi8vIGIoKXZvaWQKKmFiaV9yb3V0ZV9iOgoJLy8gZXhlY3V0ZSBiKCl2b2lkCgljYWxsc3ViIGIKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBiKCk6IHZvaWQKYjoKCXByb3RvIDAgMAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS5hbGdvLnRzOjI0CgkvLyBhc3NlcnQodGhpcy5hS2V5LnZhbHVlID09PSAxMzM3KQoJYnl0ZSAweDYxIC8vICJhIgoJYXBwX2dsb2JhbF9nZXQKCXB1c2hpbnQgMTMzNwoJPT0KCWFzc2VydAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS5hbGdvLnRzOjI1CgkvLyB0aGlzLmJLZXkudmFsdWUgPSA0MgoJcHVzaGJ5dGVzIDB4NjIgLy8gImIiCglwdXNoaW50IDQyCglhcHBfZ2xvYmFsX3B1dAoJcmV0c3ViCgovLyBiMigpdm9pZAoqYWJpX3JvdXRlX2IyOgoJLy8gZXhlY3V0ZSBiMigpdm9pZAoJY2FsbHN1YiBiMgoJcHVzaGludCAxCglyZXR1cm4KCi8vIGIyKCk6IHZvaWQKYjI6Cglwcm90byAwIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czo4OAoJLy8gbG9nKCdiMicpCglwdXNoYnl0ZXMgMHg2MjMyIC8vICJiMiIKCWxvZwoJcmV0c3ViCgovLyBmb28oKXZvaWQKKmFiaV9yb3V0ZV9mb286CgkvLyBleGVjdXRlIGZvbygpdm9pZAoJY2FsbHN1YiBmb28KCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBmb28oKTogdm9pZApmb286Cglwcm90byAwIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czo5NAoJLy8gbG9nKEIyLmFwcHJvdmFsUHJvZ3JhbSgpKQoJcHVzaGJ5dGVzIDB4MGEzMTE4MTQ4MTA2MGIzMTE5MDg4ZDBjMDAzMjAwMDAwMDAwMDAwMDAwMDAwMDAwMDAyNDAwMDAwMDAwMDAwMDAwMDAwMDAwMDA4ODAwMDM4MTAxNDM4YTAwMDA4MDAxNjE4MWI5MGE2Nzg5ODgwMDAzODEwMTQzOGEwMDAwODAwMjYyMzJiMDg5ODEwMTQzODAwNGI4NDQ3YjM2MzYxYTAwOGUwMWZmZjAwMDgwMDQxZTdhYWQxYzgwMDQ0NDNiMzMxOTM2MWEwMDhlMDJmZmJhZmZjYjAwCglsb2cKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MWU3YWFkMWMgLy8gbWV0aG9kICJhKCl2b2lkIgoJcHVzaGJ5dGVzIDB4M2FjOTBiMDggLy8gbWV0aG9kICJiKCl2b2lkIgoJcHVzaGJ5dGVzIDB4NDQzYjMzMTkgLy8gbWV0aG9kICJiMigpdm9pZCIKCXB1c2hieXRlcyAweDg0NDY3YWZmIC8vIG1ldGhvZCAiZm9vKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9hICphYmlfcm91dGVfYiAqYWJpX3JvdXRlX2IyICphYmlfcm91dGVfZm9vCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2MQoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDUuMAovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIGEoKXZvaWQKKmFiaV9yb3V0ZV9hOgoJLy8gZXhlY3V0ZSBhKCl2b2lkCgljYWxsc3ViIGEKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBhKCk6IHZvaWQKYToKCXByb3RvIDAgMAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS5hbGdvLnRzOjE2CgkvLyB0aGlzLmFLZXkudmFsdWUgPSAxMzM3CglieXRlIDB4NjEgLy8gImEiCglwdXNoaW50IDEzMzcKCWFwcF9nbG9iYWxfcHV0CglyZXRzdWIKCi8vIGIoKXZvaWQKKmFiaV9yb3V0ZV9iOgoJLy8gZXhlY3V0ZSBiKCl2b2lkCgljYWxsc3ViIGIKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBiKCk6IHZvaWQKYjoKCXByb3RvIDAgMAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS5hbGdvLnRzOjI0CgkvLyBhc3NlcnQodGhpcy5hS2V5LnZhbHVlID09PSAxMzM3KQoJYnl0ZSAweDYxIC8vICJhIgoJYXBwX2dsb2JhbF9nZXQKCXB1c2hpbnQgMTMzNwoJPT0KCWFzc2VydAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS5hbGdvLnRzOjI1CgkvLyB0aGlzLmJLZXkudmFsdWUgPSA0MgoJcHVzaGJ5dGVzIDB4NjIgLy8gImIiCglwdXNoaW50IDQyCglhcHBfZ2xvYmFsX3B1dAoJcmV0c3ViCgovLyBiMigpdm9pZAoqYWJpX3JvdXRlX2IyOgoJLy8gZXhlY3V0ZSBiMigpdm9pZAoJY2FsbHN1YiBiMgoJcHVzaGludCAxCglyZXR1cm4KCi8vIGIyKCk6IHZvaWQKYjI6Cglwcm90byAwIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czo4OAoJLy8gbG9nKCdiMicpCglwdXNoYnl0ZXMgMHg2MjMyIC8vICJiMiIKCWxvZwoJcmV0c3ViCgovLyBmb28oKXZvaWQKKmFiaV9yb3V0ZV9mb286CgkvLyBleGVjdXRlIGZvbygpdm9pZAoJY2FsbHN1YiBmb28KCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBmb28oKTogdm9pZApmb286Cglwcm90byAwIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czo5NAoJLy8gbG9nKEIyLmFwcHJvdmFsUHJvZ3JhbSgpKQoJcHVzaGJ5dGVzIDB4MGEzMTE4MTQ4MTA2MGIzMTE5MDg4ZDBjMDAzMjAwMDAwMDAwMDAwMDAwMDAwMDAwMDAyNDAwMDAwMDAwMDAwMDAwMDAwMDAwMDA4ODAwMDM4MTAxNDM4YTAwMDA4MDAxNjE4MWI5MGE2Nzg5ODgwMDAzODEwMTQzOGEwMDAwODAwMjYyMzJiMDg5ODEwMTQzODAwNGI4NDQ3YjM2MzYxYTAwOGUwMWZmZjAwMDgwMDQxZTdhYWQxYzgwMDQ0NDNiMzMxOTM2MWEwMDhlMDJmZmJhZmZjYjAwCglsb2cKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MWU3YWFkMWMgLy8gbWV0aG9kICJhKCl2b2lkIgoJcHVzaGJ5dGVzIDB4M2FjOTBiMDggLy8gbWV0aG9kICJiKCl2b2lkIgoJcHVzaGJ5dGVzIDB4NDQzYjMzMTkgLy8gbWV0aG9kICJiMigpdm9pZCIKCXB1c2hieXRlcyAweDg0NDY3YWZmIC8vIG1ldGhvZCAiZm9vKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9hICphYmlfcm91dGVfYiAqYWJpX3JvdXRlX2IyICphYmlfcm91dGVfZm9vCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/MultiInheritance.arc56_draft.json b/tests/contracts/artifacts/MultiInheritance.arc56_draft.json index 22d4ff858..e0020bbdc 100644 --- a/tests/contracts/artifacts/MultiInheritance.arc56_draft.json +++ b/tests/contracts/artifacts/MultiInheritance.arc56_draft.json @@ -747,7 +747,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2MQoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDQuMQovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIGEoKXZvaWQKKmFiaV9yb3V0ZV9hOgoJLy8gZXhlY3V0ZSBhKCl2b2lkCgljYWxsc3ViIGEKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBhKCk6IHZvaWQKYToKCXByb3RvIDAgMAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS5hbGdvLnRzOjE2CgkvLyB0aGlzLmFLZXkudmFsdWUgPSAxMzM3CglieXRlIDB4NjEgLy8gImEiCglwdXNoaW50IDEzMzcKCWFwcF9nbG9iYWxfcHV0CglyZXRzdWIKCi8vIGIoKXZvaWQKKmFiaV9yb3V0ZV9iOgoJLy8gZXhlY3V0ZSBiKCl2b2lkCgljYWxsc3ViIGIKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBiKCk6IHZvaWQKYjoKCXByb3RvIDAgMAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS5hbGdvLnRzOjI0CgkvLyBhc3NlcnQodGhpcy5hS2V5LnZhbHVlID09PSAxMzM3KQoJYnl0ZSAweDYxIC8vICJhIgoJYXBwX2dsb2JhbF9nZXQKCXB1c2hpbnQgMTMzNwoJPT0KCWFzc2VydAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS5hbGdvLnRzOjI1CgkvLyB0aGlzLmJLZXkudmFsdWUgPSA0MgoJcHVzaGJ5dGVzIDB4NjIgLy8gImIiCglwdXNoaW50IDQyCglhcHBfZ2xvYmFsX3B1dAoJcmV0c3ViCgovLyBiMigpdm9pZAoqYWJpX3JvdXRlX2IyOgoJLy8gZXhlY3V0ZSBiMigpdm9pZAoJY2FsbHN1YiBiMgoJcHVzaGludCAxCglyZXR1cm4KCi8vIGIyKCk6IHZvaWQKYjI6Cglwcm90byAwIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czo4OAoJLy8gbG9nKCdiMicpCglwdXNoYnl0ZXMgMHg2MjMyIC8vICJiMiIKCWxvZwoJcmV0c3ViCgovLyBmb28oKXZvaWQKKmFiaV9yb3V0ZV9mb286CgkvLyBleGVjdXRlIGZvbygpdm9pZAoJY2FsbHN1YiBmb28KCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBmb28oKTogdm9pZApmb286Cglwcm90byAwIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czo5NAoJLy8gbG9nKEIyLmFwcHJvdmFsUHJvZ3JhbSgpKQoJcHVzaGJ5dGVzIDB4MGEzMTE4MTQ4MTA2MGIzMTE5MDg4ZDBjMDAzMjAwMDAwMDAwMDAwMDAwMDAwMDAwMDAyNDAwMDAwMDAwMDAwMDAwMDAwMDAwMDA4ODAwMDM4MTAxNDM4YTAwMDA4MDAxNjE4MWI5MGE2Nzg5ODgwMDAzODEwMTQzOGEwMDAwODAwMjYyMzJiMDg5ODEwMTQzODAwNGI4NDQ3YjM2MzYxYTAwOGUwMWZmZjAwMDgwMDQxZTdhYWQxYzgwMDQ0NDNiMzMxOTM2MWEwMDhlMDJmZmJhZmZjYjAwCglsb2cKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MWU3YWFkMWMgLy8gbWV0aG9kICJhKCl2b2lkIgoJcHVzaGJ5dGVzIDB4M2FjOTBiMDggLy8gbWV0aG9kICJiKCl2b2lkIgoJcHVzaGJ5dGVzIDB4NDQzYjMzMTkgLy8gbWV0aG9kICJiMigpdm9pZCIKCXB1c2hieXRlcyAweDg0NDY3YWZmIC8vIG1ldGhvZCAiZm9vKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9hICphYmlfcm91dGVfYiAqYWJpX3JvdXRlX2IyICphYmlfcm91dGVfZm9vCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmJ5dGVjYmxvY2sgMHg2MQoKLy8gVGhpcyBURUFMIHdhcyBnZW5lcmF0ZWQgYnkgVEVBTFNjcmlwdCB2MC4xMDUuMAovLyBodHRwczovL2dpdGh1Yi5jb20vYWxnb3JhbmRmb3VuZGF0aW9uL1RFQUxTY3JpcHQKCi8vIFRoaXMgY29udHJhY3QgaXMgY29tcGxpYW50IHdpdGggYW5kL29yIGltcGxlbWVudHMgdGhlIGZvbGxvd2luZyBBUkNzOiBbIEFSQzQgXQoKLy8gVGhlIGZvbGxvd2luZyB0ZW4gbGluZXMgb2YgVEVBTCBoYW5kbGUgaW5pdGlhbCBwcm9ncmFtIGZsb3cKLy8gVGhpcyBwYXR0ZXJuIGlzIHVzZWQgdG8gbWFrZSBpdCBlYXN5IGZvciBhbnlvbmUgdG8gcGFyc2UgdGhlIHN0YXJ0IG9mIHRoZSBwcm9ncmFtIGFuZCBkZXRlcm1pbmUgaWYgYSBzcGVjaWZpYyBhY3Rpb24gaXMgYWxsb3dlZAovLyBIZXJlLCBhY3Rpb24gcmVmZXJzIHRvIHRoZSBPbkNvbXBsZXRlIGluIGNvbWJpbmF0aW9uIHdpdGggd2hldGhlciB0aGUgYXBwIGlzIGJlaW5nIGNyZWF0ZWQgb3IgY2FsbGVkCi8vIEV2ZXJ5IHBvc3NpYmxlIGFjdGlvbiBmb3IgdGhpcyBjb250cmFjdCBpcyByZXByZXNlbnRlZCBpbiB0aGUgc3dpdGNoIHN0YXRlbWVudAovLyBJZiB0aGUgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGUgY29udHJhY3QsIGl0cyByZXNwZWN0aXZlIGJyYW5jaCB3aWxsIGJlICIqTk9UX0lNUExFTUVOVEVEIiB3aGljaCBqdXN0IGNvbnRhaW5zICJlcnIiCnR4biBBcHBsaWNhdGlvbklECiEKcHVzaGludCA2CioKdHhuIE9uQ29tcGxldGlvbgorCnN3aXRjaCAqY2FsbF9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqY3JlYXRlX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVECgoqTk9UX0lNUExFTUVOVEVEOgoJLy8gVGhlIHJlcXVlc3RlZCBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoaXMgY29udHJhY3QuIEFyZSB5b3UgdXNpbmcgdGhlIGNvcnJlY3QgT25Db21wbGV0ZT8gRGlkIHlvdSBzZXQgeW91ciBhcHAgSUQ/CgllcnIKCi8vIGEoKXZvaWQKKmFiaV9yb3V0ZV9hOgoJLy8gZXhlY3V0ZSBhKCl2b2lkCgljYWxsc3ViIGEKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBhKCk6IHZvaWQKYToKCXByb3RvIDAgMAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS5hbGdvLnRzOjE2CgkvLyB0aGlzLmFLZXkudmFsdWUgPSAxMzM3CglieXRlIDB4NjEgLy8gImEiCglwdXNoaW50IDEzMzcKCWFwcF9nbG9iYWxfcHV0CglyZXRzdWIKCi8vIGIoKXZvaWQKKmFiaV9yb3V0ZV9iOgoJLy8gZXhlY3V0ZSBiKCl2b2lkCgljYWxsc3ViIGIKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBiKCk6IHZvaWQKYjoKCXByb3RvIDAgMAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS5hbGdvLnRzOjI0CgkvLyBhc3NlcnQodGhpcy5hS2V5LnZhbHVlID09PSAxMzM3KQoJYnl0ZSAweDYxIC8vICJhIgoJYXBwX2dsb2JhbF9nZXQKCXB1c2hpbnQgMTMzNwoJPT0KCWFzc2VydAoKCS8vIHRlc3RzL2NvbnRyYWN0cy9pbmhlcml0YW5jZS5hbGdvLnRzOjI1CgkvLyB0aGlzLmJLZXkudmFsdWUgPSA0MgoJcHVzaGJ5dGVzIDB4NjIgLy8gImIiCglwdXNoaW50IDQyCglhcHBfZ2xvYmFsX3B1dAoJcmV0c3ViCgovLyBiMigpdm9pZAoqYWJpX3JvdXRlX2IyOgoJLy8gZXhlY3V0ZSBiMigpdm9pZAoJY2FsbHN1YiBiMgoJcHVzaGludCAxCglyZXR1cm4KCi8vIGIyKCk6IHZvaWQKYjI6Cglwcm90byAwIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czo4OAoJLy8gbG9nKCdiMicpCglwdXNoYnl0ZXMgMHg2MjMyIC8vICJiMiIKCWxvZwoJcmV0c3ViCgovLyBmb28oKXZvaWQKKmFiaV9yb3V0ZV9mb286CgkvLyBleGVjdXRlIGZvbygpdm9pZAoJY2FsbHN1YiBmb28KCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBmb28oKTogdm9pZApmb286Cglwcm90byAwIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvaW5oZXJpdGFuY2UuYWxnby50czo5NAoJLy8gbG9nKEIyLmFwcHJvdmFsUHJvZ3JhbSgpKQoJcHVzaGJ5dGVzIDB4MGEzMTE4MTQ4MTA2MGIzMTE5MDg4ZDBjMDAzMjAwMDAwMDAwMDAwMDAwMDAwMDAwMDAyNDAwMDAwMDAwMDAwMDAwMDAwMDAwMDA4ODAwMDM4MTAxNDM4YTAwMDA4MDAxNjE4MWI5MGE2Nzg5ODgwMDAzODEwMTQzOGEwMDAwODAwMjYyMzJiMDg5ODEwMTQzODAwNGI4NDQ3YjM2MzYxYTAwOGUwMWZmZjAwMDgwMDQxZTdhYWQxYzgwMDQ0NDNiMzMxOTM2MWEwMDhlMDJmZmJhZmZjYjAwCglsb2cKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4MWU3YWFkMWMgLy8gbWV0aG9kICJhKCl2b2lkIgoJcHVzaGJ5dGVzIDB4M2FjOTBiMDggLy8gbWV0aG9kICJiKCl2b2lkIgoJcHVzaGJ5dGVzIDB4NDQzYjMzMTkgLy8gbWV0aG9kICJiMigpdm9pZCIKCXB1c2hieXRlcyAweDg0NDY3YWZmIC8vIG1ldGhvZCAiZm9vKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9hICphYmlfcm91dGVfYiAqYWJpX3JvdXRlX2IyICphYmlfcm91dGVfZm9vCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/MultiInheritanceProgram.approval.teal b/tests/contracts/artifacts/MultiInheritanceProgram.approval.teal index e05d95d86..527013870 100644 --- a/tests/contracts/artifacts/MultiInheritanceProgram.approval.teal +++ b/tests/contracts/artifacts/MultiInheritanceProgram.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/MultiInheritanceProgram.arc32.json b/tests/contracts/artifacts/MultiInheritanceProgram.arc32.json index 7a05a6004..02979d805 100644 --- a/tests/contracts/artifacts/MultiInheritanceProgram.arc32.json +++ b/tests/contracts/artifacts/MultiInheritanceProgram.arc32.json @@ -39,7 +39,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcHJvZygpdm9pZAoqYWJpX3JvdXRlX3Byb2c6CgkvLyBleGVjdXRlIHByb2coKXZvaWQKCWNhbGxzdWIgcHJvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHByb2coKTogdm9pZApwcm9nOgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6MTAwCgkvLyBsb2coTXVsdGlJbmhlcml0YW5jZS5hcHByb3ZhbFByb2dyYW0oKSkKCXB1c2hieXRlcyAweDBhMjYwMTAxNjEzMTE4MTQ4MTA2MGIzMTE5MDg4ZDBjMDBjNDAwMDAwMDAwMDAwMDAwMDAwMDAwMDBiNjAwMDAwMDAwMDAwMDAwMDAwMDAwMDA4ODAwMDM4MTAxNDM4YTAwMDA4MDAxNjE4MWI5MGE2Nzg5ODgwMDAzODEwMTQzOGEwMDAwODAwMTYxNjQ4MWI5MGExMjQ0ODAwMTYyODEyYTY3ODk4ODAwMDM4MTAxNDM4YTAwMDA4MDAyNjIzMmIwODk4ODAwMDM4MTAxNDM4YTAwMDA4MDZjMGEzMTE4MTQ4MTA2MGIzMTE5MDg4ZDBjMDAzMjAwMDAwMDAwMDAwMDAwMDAwMDAwMDAyNDAwMDAwMDAwMDAwMDAwMDAwMDAwMDA4ODAwMDM4MTAxNDM4YTAwMDA4MDAxNjE4MWI5MGE2Nzg5ODgwMDAzODEwMTQzOGEwMDAwODAwMjYyMzJiMDg5ODEwMTQzODAwNGI4NDQ3YjM2MzYxYTAwOGUwMWZmZjAwMDgwMDQxZTdhYWQxYzgwMDQ0NDNiMzMxOTM2MWEwMDhlMDJmZmJhZmZjYjAwYjA4OTgxMDE0MzgwMDRiODQ0N2IzNjM2MWEwMDhlMDFmZmYwMDA4MDA0MWU3YWFkMWM4MDA0M2FjOTBiMDg4MDA0NDQzYjMzMTk4MDA0ODQ0NjdhZmYzNjFhMDA4ZTA0ZmYxOGZmMjlmZjQyZmY1MTAwCglsb2cKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ODFkNzliZWYgLy8gbWV0aG9kICJwcm9nKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9wcm9nCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcHJvZygpdm9pZAoqYWJpX3JvdXRlX3Byb2c6CgkvLyBleGVjdXRlIHByb2coKXZvaWQKCWNhbGxzdWIgcHJvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHByb2coKTogdm9pZApwcm9nOgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6MTAwCgkvLyBsb2coTXVsdGlJbmhlcml0YW5jZS5hcHByb3ZhbFByb2dyYW0oKSkKCXB1c2hieXRlcyAweDBhMjYwMTAxNjEzMTE4MTQ4MTA2MGIzMTE5MDg4ZDBjMDBjNDAwMDAwMDAwMDAwMDAwMDAwMDAwMDBiNjAwMDAwMDAwMDAwMDAwMDAwMDAwMDA4ODAwMDM4MTAxNDM4YTAwMDA4MDAxNjE4MWI5MGE2Nzg5ODgwMDAzODEwMTQzOGEwMDAwODAwMTYxNjQ4MWI5MGExMjQ0ODAwMTYyODEyYTY3ODk4ODAwMDM4MTAxNDM4YTAwMDA4MDAyNjIzMmIwODk4ODAwMDM4MTAxNDM4YTAwMDA4MDZjMGEzMTE4MTQ4MTA2MGIzMTE5MDg4ZDBjMDAzMjAwMDAwMDAwMDAwMDAwMDAwMDAwMDAyNDAwMDAwMDAwMDAwMDAwMDAwMDAwMDA4ODAwMDM4MTAxNDM4YTAwMDA4MDAxNjE4MWI5MGE2Nzg5ODgwMDAzODEwMTQzOGEwMDAwODAwMjYyMzJiMDg5ODEwMTQzODAwNGI4NDQ3YjM2MzYxYTAwOGUwMWZmZjAwMDgwMDQxZTdhYWQxYzgwMDQ0NDNiMzMxOTM2MWEwMDhlMDJmZmJhZmZjYjAwYjA4OTgxMDE0MzgwMDRiODQ0N2IzNjM2MWEwMDhlMDFmZmYwMDA4MDA0MWU3YWFkMWM4MDA0M2FjOTBiMDg4MDA0NDQzYjMzMTk4MDA0ODQ0NjdhZmYzNjFhMDA4ZTA0ZmYxOGZmMjlmZjQyZmY1MTAwCglsb2cKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ODFkNzliZWYgLy8gbWV0aG9kICJwcm9nKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9wcm9nCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/MultiInheritanceProgram.arc56_draft.json b/tests/contracts/artifacts/MultiInheritanceProgram.arc56_draft.json index ed729c355..a30fdc8f2 100644 --- a/tests/contracts/artifacts/MultiInheritanceProgram.arc56_draft.json +++ b/tests/contracts/artifacts/MultiInheritanceProgram.arc56_draft.json @@ -587,7 +587,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcHJvZygpdm9pZAoqYWJpX3JvdXRlX3Byb2c6CgkvLyBleGVjdXRlIHByb2coKXZvaWQKCWNhbGxzdWIgcHJvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHByb2coKTogdm9pZApwcm9nOgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6MTAwCgkvLyBsb2coTXVsdGlJbmhlcml0YW5jZS5hcHByb3ZhbFByb2dyYW0oKSkKCXB1c2hieXRlcyAweDBhMjYwMTAxNjEzMTE4MTQ4MTA2MGIzMTE5MDg4ZDBjMDBjNDAwMDAwMDAwMDAwMDAwMDAwMDAwMDBiNjAwMDAwMDAwMDAwMDAwMDAwMDAwMDA4ODAwMDM4MTAxNDM4YTAwMDA4MDAxNjE4MWI5MGE2Nzg5ODgwMDAzODEwMTQzOGEwMDAwODAwMTYxNjQ4MWI5MGExMjQ0ODAwMTYyODEyYTY3ODk4ODAwMDM4MTAxNDM4YTAwMDA4MDAyNjIzMmIwODk4ODAwMDM4MTAxNDM4YTAwMDA4MDZjMGEzMTE4MTQ4MTA2MGIzMTE5MDg4ZDBjMDAzMjAwMDAwMDAwMDAwMDAwMDAwMDAwMDAyNDAwMDAwMDAwMDAwMDAwMDAwMDAwMDA4ODAwMDM4MTAxNDM4YTAwMDA4MDAxNjE4MWI5MGE2Nzg5ODgwMDAzODEwMTQzOGEwMDAwODAwMjYyMzJiMDg5ODEwMTQzODAwNGI4NDQ3YjM2MzYxYTAwOGUwMWZmZjAwMDgwMDQxZTdhYWQxYzgwMDQ0NDNiMzMxOTM2MWEwMDhlMDJmZmJhZmZjYjAwYjA4OTgxMDE0MzgwMDRiODQ0N2IzNjM2MWEwMDhlMDFmZmYwMDA4MDA0MWU3YWFkMWM4MDA0M2FjOTBiMDg4MDA0NDQzYjMzMTk4MDA0ODQ0NjdhZmYzNjFhMDA4ZTA0ZmYxOGZmMjlmZjQyZmY1MTAwCglsb2cKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ODFkNzliZWYgLy8gbWV0aG9kICJwcm9nKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9wcm9nCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gcHJvZygpdm9pZAoqYWJpX3JvdXRlX3Byb2c6CgkvLyBleGVjdXRlIHByb2coKXZvaWQKCWNhbGxzdWIgcHJvZwoJcHVzaGludCAxCglyZXR1cm4KCi8vIHByb2coKTogdm9pZApwcm9nOgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2luaGVyaXRhbmNlLmFsZ28udHM6MTAwCgkvLyBsb2coTXVsdGlJbmhlcml0YW5jZS5hcHByb3ZhbFByb2dyYW0oKSkKCXB1c2hieXRlcyAweDBhMjYwMTAxNjEzMTE4MTQ4MTA2MGIzMTE5MDg4ZDBjMDBjNDAwMDAwMDAwMDAwMDAwMDAwMDAwMDBiNjAwMDAwMDAwMDAwMDAwMDAwMDAwMDA4ODAwMDM4MTAxNDM4YTAwMDA4MDAxNjE4MWI5MGE2Nzg5ODgwMDAzODEwMTQzOGEwMDAwODAwMTYxNjQ4MWI5MGExMjQ0ODAwMTYyODEyYTY3ODk4ODAwMDM4MTAxNDM4YTAwMDA4MDAyNjIzMmIwODk4ODAwMDM4MTAxNDM4YTAwMDA4MDZjMGEzMTE4MTQ4MTA2MGIzMTE5MDg4ZDBjMDAzMjAwMDAwMDAwMDAwMDAwMDAwMDAwMDAyNDAwMDAwMDAwMDAwMDAwMDAwMDAwMDA4ODAwMDM4MTAxNDM4YTAwMDA4MDAxNjE4MWI5MGE2Nzg5ODgwMDAzODEwMTQzOGEwMDAwODAwMjYyMzJiMDg5ODEwMTQzODAwNGI4NDQ3YjM2MzYxYTAwOGUwMWZmZjAwMDgwMDQxZTdhYWQxYzgwMDQ0NDNiMzMxOTM2MWEwMDhlMDJmZmJhZmZjYjAwYjA4OTgxMDE0MzgwMDRiODQ0N2IzNjM2MWEwMDhlMDFmZmYwMDA4MDA0MWU3YWFkMWM4MDA0M2FjOTBiMDg4MDA0NDQzYjMzMTk4MDA0ODQ0NjdhZmYzNjFhMDA4ZTA0ZmYxOGZmMjlmZjQyZmY1MTAwCglsb2cKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4ODFkNzliZWYgLy8gbWV0aG9kICJwcm9nKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9wcm9nCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/ProgramVersion.approval.teal b/tests/contracts/artifacts/ProgramVersion.approval.teal index 17717430c..ba464f5f6 100644 --- a/tests/contracts/artifacts/ProgramVersion.approval.teal +++ b/tests/contracts/artifacts/ProgramVersion.approval.teal @@ -1,6 +1,6 @@ #pragma version 8 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/ProgramVersion.arc32.json b/tests/contracts/artifacts/ProgramVersion.arc32.json index a3b15d55d..a46727abd 100644 --- a/tests/contracts/artifacts/ProgramVersion.arc32.json +++ b/tests/contracts/artifacts/ProgramVersion.arc32.json @@ -34,7 +34,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDg=" }, "contract": { diff --git a/tests/contracts/artifacts/ProgramVersion.arc56_draft.json b/tests/contracts/artifacts/ProgramVersion.arc56_draft.json index c13725044..df48d79ea 100644 --- a/tests/contracts/artifacts/ProgramVersion.arc56_draft.json +++ b/tests/contracts/artifacts/ProgramVersion.arc56_draft.json @@ -205,7 +205,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnI=", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDgKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgdGVuIGxpbmVzIG9mIFRFQUwgaGFuZGxlIGluaXRpYWwgcHJvZ3JhbSBmbG93Ci8vIFRoaXMgcGF0dGVybiBpcyB1c2VkIHRvIG1ha2UgaXQgZWFzeSBmb3IgYW55b25lIHRvIHBhcnNlIHRoZSBzdGFydCBvZiB0aGUgcHJvZ3JhbSBhbmQgZGV0ZXJtaW5lIGlmIGEgc3BlY2lmaWMgYWN0aW9uIGlzIGFsbG93ZWQKLy8gSGVyZSwgYWN0aW9uIHJlZmVycyB0byB0aGUgT25Db21wbGV0ZSBpbiBjb21iaW5hdGlvbiB3aXRoIHdoZXRoZXIgdGhlIGFwcCBpcyBiZWluZyBjcmVhdGVkIG9yIGNhbGxlZAovLyBFdmVyeSBwb3NzaWJsZSBhY3Rpb24gZm9yIHRoaXMgY29udHJhY3QgaXMgcmVwcmVzZW50ZWQgaW4gdGhlIHN3aXRjaCBzdGF0ZW1lbnQKLy8gSWYgdGhlIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhlIGNvbnRyYWN0LCBpdHMgcmVzcGVjdGl2ZSBicmFuY2ggd2lsbCBiZSAiKk5PVF9JTVBMRU1FTlRFRCIgd2hpY2gganVzdCBjb250YWlucyAiZXJyIgp0eG4gQXBwbGljYXRpb25JRAohCnB1c2hpbnQgNgoqCnR4biBPbkNvbXBsZXRpb24KKwpzd2l0Y2ggKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKmNyZWF0ZV9Ob09wICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRAoKKk5PVF9JTVBMRU1FTlRFRDoKCS8vIFRoZSByZXF1ZXN0ZWQgYWN0aW9uIGlzIG5vdCBpbXBsZW1lbnRlZCBpbiB0aGlzIGNvbnRyYWN0LiBBcmUgeW91IHVzaW5nIHRoZSBjb3JyZWN0IE9uQ29tcGxldGU/IERpZCB5b3Ugc2V0IHlvdXIgYXBwIElEPwoJZXJyCgoqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uOgoJcHVzaGludCAxCglyZXR1cm4KCipjcmVhdGVfTm9PcDoKCXB1c2hieXRlcyAweGI4NDQ3YjM2IC8vIG1ldGhvZCAiY3JlYXRlQXBwbGljYXRpb24oKXZvaWQiCgl0eG5hIEFwcGxpY2F0aW9uQXJncyAwCgltYXRjaCAqYWJpX3JvdXRlX2NyZWF0ZUFwcGxpY2F0aW9uCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNyZWF0ZSBOb09wCgllcnI=", "clear": "I3ByYWdtYSB2ZXJzaW9uIDg=" }, "byteCode": { diff --git a/tests/contracts/artifacts/SchemaContract.approval.teal b/tests/contracts/artifacts/SchemaContract.approval.teal index ee2fda28c..f8eda6915 100644 --- a/tests/contracts/artifacts/SchemaContract.approval.teal +++ b/tests/contracts/artifacts/SchemaContract.approval.teal @@ -1,6 +1,6 @@ #pragma version 10 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/SchemaContract.arc32.json b/tests/contracts/artifacts/SchemaContract.arc32.json index a2ce9ddb3..ee5310079 100644 --- a/tests/contracts/artifacts/SchemaContract.arc32.json +++ b/tests/contracts/artifacts/SchemaContract.arc32.json @@ -34,7 +34,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/SchemaContract.arc56_draft.json b/tests/contracts/artifacts/SchemaContract.arc56_draft.json index dd355e719..32ce5f854 100644 --- a/tests/contracts/artifacts/SchemaContract.arc56_draft.json +++ b/tests/contracts/artifacts/SchemaContract.arc56_draft.json @@ -223,7 +223,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNC4xCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCgovLyBUaGlzIFRFQUwgd2FzIGdlbmVyYXRlZCBieSBURUFMU2NyaXB0IHYwLjEwNS4wCi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9hbGdvcmFuZGZvdW5kYXRpb24vVEVBTFNjcmlwdAoKLy8gVGhpcyBjb250cmFjdCBpcyBjb21wbGlhbnQgd2l0aCBhbmQvb3IgaW1wbGVtZW50cyB0aGUgZm9sbG93aW5nIEFSQ3M6IFsgQVJDNCBdCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/StorageTest.approval.teal b/tests/contracts/artifacts/StorageTest.approval.teal index 36417fa11..55742d474 100644 --- a/tests/contracts/artifacts/StorageTest.approval.teal +++ b/tests/contracts/artifacts/StorageTest.approval.teal @@ -2,7 +2,7 @@ intcblock 1 32 1024 bytecblock 0x666f6f 0x6c617267655374617469634172726179496e426f78 0x626172 0x151f7c75 0x616263 0x01c8 -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/StorageTest.arc32.json b/tests/contracts/artifacts/StorageTest.arc32.json index 6f9072b1e..f317585d5 100644 --- a/tests/contracts/artifacts/StorageTest.arc32.json +++ b/tests/contracts/artifacts/StorageTest.arc32.json @@ -249,7 +249,7 @@ } }, "source": { - "approval": "#pragma version 10
intcblock 1 32 1024
bytecblock 0x666f6f 0x6c617267655374617469634172726179496e426f78 0x626172 0x151f7c75 0x616263 0x01c8

// This TEAL was generated by TEALScript v0.104.1
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// prefix()void
*abi_route_prefix:
	// execute prefix()void
	callsub prefix
	int 1
	return

// prefix(): void
prefix:
	proto 0 0

	// tests/contracts/storage.algo.ts:26
	// this.boxMapWithPrefix('oo').value = 'bar'
	byte 0x666f6f
	dup
	box_del
	pop
	byte 0x626172 // "bar"
	box_put

	// tests/contracts/storage.algo.ts:27
	// this.globalMapWithPrefix('oo').value = 'bar'
	byte 0x666f6f
	byte 0x626172 // "bar"
	app_global_put

	// tests/contracts/storage.algo.ts:28
	// this.localMapWithPrefix(this.txn.sender, 'oo').value = 'bar'
	txn Sender
	byte 0x666f6f
	byte 0x626172 // "bar"
	app_local_put
	retsub

// globalKeyPut()void
*abi_route_globalKeyPut:
	// execute globalKeyPut()void
	callsub globalKeyPut
	int 1
	return

// globalKeyPut(): void
globalKeyPut:
	proto 0 0

	// tests/contracts/storage.algo.ts:32
	// this.globalKey.value = 'bar'
	byte 0x666f6f // "foo"
	byte 0x626172 // "bar"
	app_global_put
	retsub

// globalKeyGet()void
*abi_route_globalKeyGet:
	// execute globalKeyGet()void
	callsub globalKeyGet
	int 1
	return

// globalKeyGet(): void
globalKeyGet:
	proto 0 0

	// tests/contracts/storage.algo.ts:36
	// assert(this.globalKey.value === 'bar')
	byte 0x666f6f // "foo"
	app_global_get
	byte 0x626172 // "bar"
	==
	assert
	retsub

// globalKeyDelete()void
*abi_route_globalKeyDelete:
	// execute globalKeyDelete()void
	callsub globalKeyDelete
	int 1
	return

// globalKeyDelete(): void
globalKeyDelete:
	proto 0 0

	// tests/contracts/storage.algo.ts:40
	// this.globalKey.delete()
	byte 0x666f6f // "foo"
	app_global_del
	retsub

// globalKeyExists()void
*abi_route_globalKeyExists:
	// execute globalKeyExists()void
	callsub globalKeyExists
	int 1
	return

// globalKeyExists(): void
globalKeyExists:
	proto 0 0

	// tests/contracts/storage.algo.ts:44
	// assert(this.globalKey.exists)
	txna Applications 0
	byte 0x666f6f // "foo"
	app_global_get_ex
	swap
	pop
	assert
	retsub

// localKeyPut(address)void
*abi_route_localKeyPut:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for localKeyPut must be a address
	assert

	// execute localKeyPut(address)void
	callsub localKeyPut
	int 1
	return

// localKeyPut(a: Address): void
localKeyPut:
	proto 1 0

	// tests/contracts/storage.algo.ts:48
	// this.localKey(a).value = 'bar'
	frame_dig -1 // a: Address
	byte 0x666f6f // "foo"
	byte 0x626172 // "bar"
	app_local_put
	retsub

// localKeyGet(address)void
*abi_route_localKeyGet:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for localKeyGet must be a address
	assert

	// execute localKeyGet(address)void
	callsub localKeyGet
	int 1
	return

// localKeyGet(a: Address): void
localKeyGet:
	proto 1 0

	// tests/contracts/storage.algo.ts:52
	// assert(this.localKey(a).value === 'bar')
	frame_dig -1 // a: Address
	byte 0x666f6f // "foo"
	app_local_get
	byte 0x626172 // "bar"
	==
	assert
	retsub

// localKeyDelete(address)void
*abi_route_localKeyDelete:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for localKeyDelete must be a address
	assert

	// execute localKeyDelete(address)void
	callsub localKeyDelete
	int 1
	return

// localKeyDelete(a: Address): void
localKeyDelete:
	proto 1 0

	// tests/contracts/storage.algo.ts:56
	// this.localKey(a).delete()
	frame_dig -1 // a: Address
	byte 0x666f6f // "foo"
	app_local_del
	retsub

// localKeyExists(address)void
*abi_route_localKeyExists:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for localKeyExists must be a address
	assert

	// execute localKeyExists(address)void
	callsub localKeyExists
	int 1
	return

// localKeyExists(a: Address): void
localKeyExists:
	proto 1 0

	// tests/contracts/storage.algo.ts:60
	// assert(this.localKey(a).exists)
	frame_dig -1 // a: Address
	txna Applications 0
	byte 0x666f6f // "foo"
	app_local_get_ex
	swap
	pop
	assert
	retsub

// boxKeyPut()void
*abi_route_boxKeyPut:
	// execute boxKeyPut()void
	callsub boxKeyPut
	int 1
	return

// boxKeyPut(): void
boxKeyPut:
	proto 0 0

	// tests/contracts/storage.algo.ts:64
	// this.boxKey.value = 'bar'
	byte 0x666f6f // "foo"
	byte 0x626172 // "bar"
	box_put
	retsub

// boxKeyGet()void
*abi_route_boxKeyGet:
	// execute boxKeyGet()void
	callsub boxKeyGet
	int 1
	return

// boxKeyGet(): void
boxKeyGet:
	proto 0 0

	// tests/contracts/storage.algo.ts:68
	// assert(this.boxKey.value === 'bar')
	byte 0x666f6f // "foo"
	box_get

	// box value does not exist: this.boxKey.value
	assert
	byte 0x626172 // "bar"
	==
	assert
	retsub

// boxKeyDelete()void
*abi_route_boxKeyDelete:
	// execute boxKeyDelete()void
	callsub boxKeyDelete
	int 1
	return

// boxKeyDelete(): void
boxKeyDelete:
	proto 0 0

	// tests/contracts/storage.algo.ts:72
	// this.boxKey.delete()
	byte 0x666f6f // "foo"
	box_del
	retsub

// boxKeyExists()void
*abi_route_boxKeyExists:
	// execute boxKeyExists()void
	callsub boxKeyExists
	int 1
	return

// boxKeyExists(): void
boxKeyExists:
	proto 0 0

	// tests/contracts/storage.algo.ts:76
	// assert(this.boxKey.exists)
	byte 0x666f6f // "foo"
	box_len
	swap
	pop
	assert
	retsub

// globalMapPut()void
*abi_route_globalMapPut:
	// execute globalMapPut()void
	callsub globalMapPut
	int 1
	return

// globalMapPut(): void
globalMapPut:
	proto 0 0

	// tests/contracts/storage.algo.ts:80
	// this.globalMap('foo').value = 'bar'
	byte 0x666f6f // "foo"
	byte 0x626172 // "bar"
	app_global_put
	retsub

// globalMapGet()void
*abi_route_globalMapGet:
	// execute globalMapGet()void
	callsub globalMapGet
	int 1
	return

// globalMapGet(): void
globalMapGet:
	proto 0 0

	// tests/contracts/storage.algo.ts:84
	// assert(this.globalMap('foo').value === 'bar')
	byte 0x666f6f // "foo"
	app_global_get
	byte 0x626172 // "bar"
	==
	assert
	retsub

// globalMapDelete()void
*abi_route_globalMapDelete:
	// execute globalMapDelete()void
	callsub globalMapDelete
	int 1
	return

// globalMapDelete(): void
globalMapDelete:
	proto 0 0

	// tests/contracts/storage.algo.ts:88
	// this.globalMap('foo').delete()
	byte 0x666f6f // "foo"
	app_global_del
	retsub

// globalMapExists()void
*abi_route_globalMapExists:
	// execute globalMapExists()void
	callsub globalMapExists
	int 1
	return

// globalMapExists(): void
globalMapExists:
	proto 0 0

	// tests/contracts/storage.algo.ts:92
	// assert(this.globalMap('foo').exists)
	txna Applications 0
	byte 0x666f6f // "foo"
	app_global_get_ex
	swap
	pop
	assert
	retsub

// localMapPut(address)void
*abi_route_localMapPut:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for localMapPut must be a address
	assert

	// execute localMapPut(address)void
	callsub localMapPut
	int 1
	return

// localMapPut(a: Address): void
localMapPut:
	proto 1 0

	// tests/contracts/storage.algo.ts:96
	// this.localMap(a, 'foo').value = 'bar'
	frame_dig -1 // a: Address
	byte 0x666f6f // "foo"
	byte 0x626172 // "bar"
	app_local_put
	retsub

// localMapGet(address)void
*abi_route_localMapGet:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for localMapGet must be a address
	assert

	// execute localMapGet(address)void
	callsub localMapGet
	int 1
	return

// localMapGet(a: Address): void
localMapGet:
	proto 1 0

	// tests/contracts/storage.algo.ts:100
	// assert(this.localMap(a, 'foo').value === 'bar')
	frame_dig -1 // a: Address
	byte 0x666f6f // "foo"
	app_local_get
	byte 0x626172 // "bar"
	==
	assert
	retsub

// localMapDelete(address)void
*abi_route_localMapDelete:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for localMapDelete must be a address
	assert

	// execute localMapDelete(address)void
	callsub localMapDelete
	int 1
	return

// localMapDelete(a: Address): void
localMapDelete:
	proto 1 0

	// tests/contracts/storage.algo.ts:104
	// this.localMap(a, 'foo').delete()
	frame_dig -1 // a: Address
	byte 0x666f6f // "foo"
	app_local_del
	retsub

// localMapExists(address)void
*abi_route_localMapExists:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for localMapExists must be a address
	assert

	// execute localMapExists(address)void
	callsub localMapExists
	int 1
	return

// localMapExists(a: Address): void
localMapExists:
	proto 1 0

	// tests/contracts/storage.algo.ts:108
	// assert(this.localMap(a, 'foo').exists)
	frame_dig -1 // a: Address
	txna Applications 0
	byte 0x666f6f // "foo"
	app_local_get_ex
	swap
	pop
	assert
	retsub

// boxMapPut()void
*abi_route_boxMapPut:
	// execute boxMapPut()void
	callsub boxMapPut
	int 1
	return

// boxMapPut(): void
boxMapPut:
	proto 0 0

	// tests/contracts/storage.algo.ts:112
	// this.boxMap('foo').value = 'bar'
	byte 0x666f6f // "foo"
	byte 0x626172 // "bar"
	box_put
	retsub

// boxMapGet()void
*abi_route_boxMapGet:
	// execute boxMapGet()void
	callsub boxMapGet
	int 1
	return

// boxMapGet(): void
boxMapGet:
	proto 0 0

	// tests/contracts/storage.algo.ts:116
	// assert(this.boxMap('foo').value === 'bar')
	byte 0x666f6f // "foo"
	box_get

	// box value does not exist: this.boxMap('foo').value
	assert
	byte 0x626172 // "bar"
	==
	assert
	retsub

// boxMapDelete()void
*abi_route_boxMapDelete:
	// execute boxMapDelete()void
	callsub boxMapDelete
	int 1
	return

// boxMapDelete(): void
boxMapDelete:
	proto 0 0

	// tests/contracts/storage.algo.ts:120
	// this.boxMap('foo').delete()
	byte 0x666f6f // "foo"
	box_del
	retsub

// boxMapExists()void
*abi_route_boxMapExists:
	// execute boxMapExists()void
	callsub boxMapExists
	int 1
	return

// boxMapExists(): void
boxMapExists:
	proto 0 0

	// tests/contracts/storage.algo.ts:124
	// assert(this.boxMap('foo').exists)
	byte 0x666f6f // "foo"
	box_len
	swap
	pop
	assert
	retsub

// boxKeyCreate()void
*abi_route_boxKeyCreate:
	// execute boxKeyCreate()void
	callsub boxKeyCreate
	int 1
	return

// boxKeyCreate(): void
boxKeyCreate:
	proto 0 0

	// tests/contracts/storage.algo.ts:128
	// this.boxKey.create(1024)
	byte 0x666f6f // "foo"
	int 1024
	box_create
	pop
	retsub

// boxMapCreate()void
*abi_route_boxMapCreate:
	// execute boxMapCreate()void
	callsub boxMapCreate
	int 1
	return

// boxMapCreate(): void
boxMapCreate:
	proto 0 0

	// tests/contracts/storage.algo.ts:132
	// this.boxMap('bar').create(1024)
	byte 0x626172 // "bar"
	int 1024
	box_create
	pop
	retsub

// boxKeyLength()uint64
*abi_route_boxKeyLength:
	// The ABI return prefix
	byte 0x151f7c75

	// execute boxKeyLength()uint64
	callsub boxKeyLength
	itob
	concat
	log
	int 1
	return

// boxKeyLength(): uint64
boxKeyLength:
	proto 0 1

	// tests/contracts/storage.algo.ts:136
	// return this.boxKey.size;
	byte 0x666f6f // "foo"
	box_len

	// box value does not exist: this.boxKey.size
	assert
	retsub

// boxMapLength()uint64
*abi_route_boxMapLength:
	// The ABI return prefix
	byte 0x151f7c75

	// execute boxMapLength()uint64
	callsub boxMapLength
	itob
	concat
	log
	int 1
	return

// boxMapLength(): uint64
boxMapLength:
	proto 0 1

	// tests/contracts/storage.algo.ts:140
	// return this.boxMap('bar').size;
	byte 0x626172 // "bar"
	box_len

	// box value does not exist: this.boxMap('bar').size
	assert
	retsub

// boxKeyReplace()void
*abi_route_boxKeyReplace:
	// execute boxKeyReplace()void
	callsub boxKeyReplace
	int 1
	return

// boxKeyReplace(): void
boxKeyReplace:
	proto 0 0

	// tests/contracts/storage.algo.ts:144
	// this.boxKey.replace(0, 'abc')
	byte 0x666f6f // "foo"
	pushint 0
	byte 0x616263 // "abc"
	box_replace
	retsub

// boxMapReplace()void
*abi_route_boxMapReplace:
	// execute boxMapReplace()void
	callsub boxMapReplace
	int 1
	return

// boxMapReplace(): void
boxMapReplace:
	proto 0 0

	// tests/contracts/storage.algo.ts:148
	// this.boxMap('bar').replace(0, 'abc')
	byte 0x626172 // "bar"
	pushint 0
	byte 0x616263 // "abc"
	box_replace
	retsub

// boxKeyExtract()string
*abi_route_boxKeyExtract:
	// The ABI return prefix
	byte 0x151f7c75

	// execute boxKeyExtract()string
	callsub boxKeyExtract
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// boxKeyExtract(): string
boxKeyExtract:
	proto 0 1

	// tests/contracts/storage.algo.ts:152
	// return this.boxKey.extract(0, 3);
	byte 0x666f6f // "foo"
	pushint 0
	pushint 3
	box_extract
	retsub

// boxMapExtract()string
*abi_route_boxMapExtract:
	// The ABI return prefix
	byte 0x151f7c75

	// execute boxMapExtract()string
	callsub boxMapExtract
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// boxMapExtract(): string
boxMapExtract:
	proto 0 1

	// tests/contracts/storage.algo.ts:156
	// return this.boxMap('bar').extract(0, 3);
	byte 0x626172 // "bar"
	pushint 0
	pushint 3
	box_extract
	retsub

// isOptedIn()bool
*abi_route_isOptedIn:
	// The ABI return prefix
	byte 0x151f7c75

	// execute isOptedIn()bool
	callsub isOptedIn
	pushbytes 0x00
	pushint 0
	uncover 2
	setbit
	concat
	log
	int 1
	return

// isOptedIn(): boolean
isOptedIn:
	proto 0 1

	// tests/contracts/storage.algo.ts:160
	// return this.txn.sender.isOptedInToApp(this.app);
	txn Sender
	txna Applications 0
	app_opted_in
	retsub

// exGlobal()void
*abi_route_exGlobal:
	// execute exGlobal()void
	callsub exGlobal
	int 1
	return

// exGlobal(): void
exGlobal:
	proto 0 0

	// tests/contracts/storage.algo.ts:164
	// log(this.app.globalState('foo') as bytes)
	txna Applications 0
	byte 0x666f6f // "foo"
	app_global_get_ex

	// global state value does not exist: this.app.globalState('foo')
	assert
	log
	retsub

// exLocal()void
*abi_route_exLocal:
	// execute exLocal()void
	callsub exLocal
	int 1
	return

// exLocal(): void
exLocal:
	proto 0 0

	// tests/contracts/storage.algo.ts:168
	// log(this.app.localState(this.txn.sender, 'foo') as bytes)
	txn Sender
	txna Applications 0
	byte 0x666f6f // "foo"
	app_local_get_ex

	// local state value does not exist: this.app.localState(this.txn.sender, 'foo')
	assert
	log
	retsub

// accessStaticValueInLargeBox()uint16
*abi_route_accessStaticValueInLargeBox:
	// The ABI return prefix
	byte 0x151f7c75

	// execute accessStaticValueInLargeBox()uint16
	callsub accessStaticValueInLargeBox
	itob
	dup
	bitlen
	pushint 16
	<=

	// accessStaticValueInLargeBox return value overflowed 16 bits
	assert
	extract 6 2
	concat
	log
	int 1
	return

// accessStaticValueInLargeBox(): uint16
accessStaticValueInLargeBox:
	proto 0 1

	// tests/contracts/storage.algo.ts:172
	// this.largeStaticArrayInBox.create()
	byte 0x6c617267655374617469634172726179496e426f78 // "largeStaticArrayInBox"
	pushint 8000
	box_create
	pop

	// tests/contracts/storage.algo.ts:173
	// this.largeStaticArrayInBox.value[123] = 456
	byte 0x6c617267655374617469634172726179496e426f78 // "largeStaticArrayInBox"
	pushint 246
	byte 0x01c8
	box_replace

	// tests/contracts/storage.algo.ts:175
	// return this.largeStaticArrayInBox.value[123];
	byte 0x6c617267655374617469634172726179496e426f78 // "largeStaticArrayInBox"
	pushint 246
	pushint 2
	box_extract
	btoi
	retsub

// dynamicAccessStaticValueInLargeBox(uint64)uint16
*abi_route_dynamicAccessStaticValueInLargeBox:
	// The ABI return prefix
	byte 0x151f7c75

	// i: uint64
	txna ApplicationArgs 1
	btoi

	// execute dynamicAccessStaticValueInLargeBox(uint64)uint16
	callsub dynamicAccessStaticValueInLargeBox
	itob
	dup
	bitlen
	pushint 16
	<=

	// dynamicAccessStaticValueInLargeBox return value overflowed 16 bits
	assert
	extract 6 2
	concat
	log
	int 1
	return

// dynamicAccessStaticValueInLargeBox(i: uint64): uint16
dynamicAccessStaticValueInLargeBox:
	proto 1 1

	// tests/contracts/storage.algo.ts:179
	// this.largeStaticArrayInBox.create()
	byte 0x6c617267655374617469634172726179496e426f78 // "largeStaticArrayInBox"
	pushint 8000
	box_create
	pop

	// tests/contracts/storage.algo.ts:180
	// this.largeStaticArrayInBox.value[i] = 456
	frame_dig -1 // i: uint64
	pushint 2
	* // acc * typeLength
	byte 0x01c8
	byte 0x6c617267655374617469634172726179496e426f78 // "largeStaticArrayInBox"
	cover 2
	box_replace

	// tests/contracts/storage.algo.ts:184
	// return a[i];
	frame_dig -1 // i: uint64
	pushint 2
	* // acc * typeLength
	pushint 2
	byte 0x6c617267655374617469634172726179496e426f78 // "largeStaticArrayInBox"
	cover 2
	box_extract
	btoi
	retsub

// boxResize()void
*abi_route_boxResize:
	// execute boxResize()void
	callsub boxResize
	int 1
	return

// boxResize(): void
boxResize:
	proto 0 0

	// tests/contracts/storage.algo.ts:188
	// this.boxKey.resize(1024)
	byte 0x666f6f // "foo"
	int 1024
	box_resize

	// tests/contracts/storage.algo.ts:189
	// this.boxMap('bar').resize(1024)
	byte 0x626172 // "bar"
	int 1024
	box_resize
	retsub

// boxSplice()void
*abi_route_boxSplice:
	// execute boxSplice()void
	callsub boxSplice
	int 1
	return

// boxSplice(): void
boxSplice:
	proto 0 0

	// tests/contracts/storage.algo.ts:193
	// this.boxKey.splice(0, 1, 'abc')
	byte 0x666f6f // "foo"
	pushint 0
	int 1
	byte 0x616263 // "abc"
	box_splice

	// tests/contracts/storage.algo.ts:194
	// this.boxMap('bar').splice(0, 1, 'abc')
	byte 0x626172 // "bar"
	pushint 0
	int 1
	byte 0x616263 // "abc"
	box_splice
	retsub

// exStateExists()void
*abi_route_exStateExists:
	// execute exStateExists()void
	callsub exStateExists
	int 1
	return

// exStateExists(): void
exStateExists:
	proto 0 0

	// tests/contracts/storage.algo.ts:198
	// assert(this.app.globalStateExists('foo'))
	txna Applications 0
	byte 0x666f6f // "foo"
	app_global_get_ex
	swap
	pop
	assert

	// tests/contracts/storage.algo.ts:199
	// assert(this.app.localStateExists(this.txn.sender, 'foo'))
	txn Sender
	txna Applications 0
	byte 0x666f6f // "foo"
	app_local_get_ex
	swap
	pop
	assert
	retsub

*abi_route_createApplication:
	int 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x5b02ba87 // method "prefix()void"
	pushbytes 0x47826307 // method "globalKeyPut()void"
	pushbytes 0xd387cd2c // method "globalKeyGet()void"
	pushbytes 0x2f78db03 // method "globalKeyDelete()void"
	pushbytes 0xd8181a9a // method "globalKeyExists()void"
	pushbytes 0xecb06998 // method "localKeyPut(address)void"
	pushbytes 0x56dace1d // method "localKeyGet(address)void"
	pushbytes 0x768c8c68 // method "localKeyDelete(address)void"
	pushbytes 0xbc0ea6bb // method "localKeyExists(address)void"
	pushbytes 0xcf48ae4d // method "boxKeyPut()void"
	pushbytes 0xe9dab493 // method "boxKeyGet()void"
	pushbytes 0x090fdfd6 // method "boxKeyDelete()void"
	pushbytes 0x5ff9d0dd // method "boxKeyExists()void"
	pushbytes 0x17c8206a // method "globalMapPut()void"
	pushbytes 0xcd868bf2 // method "globalMapGet()void"
	pushbytes 0xb55de20c // method "globalMapDelete()void"
	pushbytes 0xc97d8d24 // method "globalMapExists()void"
	pushbytes 0xfc83803c // method "localMapPut(address)void"
	pushbytes 0x9875355d // method "localMapGet(address)void"
	pushbytes 0x742a6e83 // method "localMapDelete(address)void"
	pushbytes 0x88235265 // method "localMapExists(address)void"
	pushbytes 0x84e5681c // method "boxMapPut()void"
	pushbytes 0xae3ce7ee // method "boxMapGet()void"
	pushbytes 0xb9e0ed3d // method "boxMapDelete()void"
	pushbytes 0x652bd5d6 // method "boxMapExists()void"
	pushbytes 0xd36ee315 // method "boxKeyCreate()void"
	pushbytes 0x1029bd07 // method "boxMapCreate()void"
	pushbytes 0xa747b62f // method "boxKeyLength()uint64"
	pushbytes 0x5a1eefbe // method "boxMapLength()uint64"
	pushbytes 0x1337dd60 // method "boxKeyReplace()void"
	pushbytes 0x424ef95a // method "boxMapReplace()void"
	pushbytes 0x88c1c309 // method "boxKeyExtract()string"
	pushbytes 0x43635643 // method "boxMapExtract()string"
	pushbytes 0xab42554e // method "isOptedIn()bool"
	pushbytes 0x0167b7a2 // method "exGlobal()void"
	pushbytes 0xaad51755 // method "exLocal()void"
	pushbytes 0x1b41ce22 // method "accessStaticValueInLargeBox()uint16"
	pushbytes 0xf5da1a55 // method "dynamicAccessStaticValueInLargeBox(uint64)uint16"
	pushbytes 0xbc5c18fd // method "boxResize()void"
	pushbytes 0x25a92329 // method "boxSplice()void"
	pushbytes 0x4ed8699b // method "exStateExists()void"
	txna ApplicationArgs 0
	match *abi_route_prefix *abi_route_globalKeyPut *abi_route_globalKeyGet *abi_route_globalKeyDelete *abi_route_globalKeyExists *abi_route_localKeyPut *abi_route_localKeyGet *abi_route_localKeyDelete *abi_route_localKeyExists *abi_route_boxKeyPut *abi_route_boxKeyGet *abi_route_boxKeyDelete *abi_route_boxKeyExists *abi_route_globalMapPut *abi_route_globalMapGet *abi_route_globalMapDelete *abi_route_globalMapExists *abi_route_localMapPut *abi_route_localMapGet *abi_route_localMapDelete *abi_route_localMapExists *abi_route_boxMapPut *abi_route_boxMapGet *abi_route_boxMapDelete *abi_route_boxMapExists *abi_route_boxKeyCreate *abi_route_boxMapCreate *abi_route_boxKeyLength *abi_route_boxMapLength *abi_route_boxKeyReplace *abi_route_boxMapReplace *abi_route_boxKeyExtract *abi_route_boxMapExtract *abi_route_isOptedIn *abi_route_exGlobal *abi_route_exLocal *abi_route_accessStaticValueInLargeBox *abi_route_dynamicAccessStaticValueInLargeBox *abi_route_boxResize *abi_route_boxSplice *abi_route_exStateExists

	// this contract does not implement the given ABI method for call NoOp
	err", + "approval": "#pragma version 10
intcblock 1 32 1024
bytecblock 0x666f6f 0x6c617267655374617469634172726179496e426f78 0x626172 0x151f7c75 0x616263 0x01c8

// This TEAL was generated by TEALScript v0.105.0
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// prefix()void
*abi_route_prefix:
	// execute prefix()void
	callsub prefix
	int 1
	return

// prefix(): void
prefix:
	proto 0 0

	// tests/contracts/storage.algo.ts:26
	// this.boxMapWithPrefix('oo').value = 'bar'
	byte 0x666f6f
	dup
	box_del
	pop
	byte 0x626172 // "bar"
	box_put

	// tests/contracts/storage.algo.ts:27
	// this.globalMapWithPrefix('oo').value = 'bar'
	byte 0x666f6f
	byte 0x626172 // "bar"
	app_global_put

	// tests/contracts/storage.algo.ts:28
	// this.localMapWithPrefix(this.txn.sender, 'oo').value = 'bar'
	txn Sender
	byte 0x666f6f
	byte 0x626172 // "bar"
	app_local_put
	retsub

// globalKeyPut()void
*abi_route_globalKeyPut:
	// execute globalKeyPut()void
	callsub globalKeyPut
	int 1
	return

// globalKeyPut(): void
globalKeyPut:
	proto 0 0

	// tests/contracts/storage.algo.ts:32
	// this.globalKey.value = 'bar'
	byte 0x666f6f // "foo"
	byte 0x626172 // "bar"
	app_global_put
	retsub

// globalKeyGet()void
*abi_route_globalKeyGet:
	// execute globalKeyGet()void
	callsub globalKeyGet
	int 1
	return

// globalKeyGet(): void
globalKeyGet:
	proto 0 0

	// tests/contracts/storage.algo.ts:36
	// assert(this.globalKey.value === 'bar')
	byte 0x666f6f // "foo"
	app_global_get
	byte 0x626172 // "bar"
	==
	assert
	retsub

// globalKeyDelete()void
*abi_route_globalKeyDelete:
	// execute globalKeyDelete()void
	callsub globalKeyDelete
	int 1
	return

// globalKeyDelete(): void
globalKeyDelete:
	proto 0 0

	// tests/contracts/storage.algo.ts:40
	// this.globalKey.delete()
	byte 0x666f6f // "foo"
	app_global_del
	retsub

// globalKeyExists()void
*abi_route_globalKeyExists:
	// execute globalKeyExists()void
	callsub globalKeyExists
	int 1
	return

// globalKeyExists(): void
globalKeyExists:
	proto 0 0

	// tests/contracts/storage.algo.ts:44
	// assert(this.globalKey.exists)
	txna Applications 0
	byte 0x666f6f // "foo"
	app_global_get_ex
	swap
	pop
	assert
	retsub

// localKeyPut(address)void
*abi_route_localKeyPut:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for localKeyPut must be a address
	assert

	// execute localKeyPut(address)void
	callsub localKeyPut
	int 1
	return

// localKeyPut(a: Address): void
localKeyPut:
	proto 1 0

	// tests/contracts/storage.algo.ts:48
	// this.localKey(a).value = 'bar'
	frame_dig -1 // a: Address
	byte 0x666f6f // "foo"
	byte 0x626172 // "bar"
	app_local_put
	retsub

// localKeyGet(address)void
*abi_route_localKeyGet:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for localKeyGet must be a address
	assert

	// execute localKeyGet(address)void
	callsub localKeyGet
	int 1
	return

// localKeyGet(a: Address): void
localKeyGet:
	proto 1 0

	// tests/contracts/storage.algo.ts:52
	// assert(this.localKey(a).value === 'bar')
	frame_dig -1 // a: Address
	byte 0x666f6f // "foo"
	app_local_get
	byte 0x626172 // "bar"
	==
	assert
	retsub

// localKeyDelete(address)void
*abi_route_localKeyDelete:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for localKeyDelete must be a address
	assert

	// execute localKeyDelete(address)void
	callsub localKeyDelete
	int 1
	return

// localKeyDelete(a: Address): void
localKeyDelete:
	proto 1 0

	// tests/contracts/storage.algo.ts:56
	// this.localKey(a).delete()
	frame_dig -1 // a: Address
	byte 0x666f6f // "foo"
	app_local_del
	retsub

// localKeyExists(address)void
*abi_route_localKeyExists:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for localKeyExists must be a address
	assert

	// execute localKeyExists(address)void
	callsub localKeyExists
	int 1
	return

// localKeyExists(a: Address): void
localKeyExists:
	proto 1 0

	// tests/contracts/storage.algo.ts:60
	// assert(this.localKey(a).exists)
	frame_dig -1 // a: Address
	txna Applications 0
	byte 0x666f6f // "foo"
	app_local_get_ex
	swap
	pop
	assert
	retsub

// boxKeyPut()void
*abi_route_boxKeyPut:
	// execute boxKeyPut()void
	callsub boxKeyPut
	int 1
	return

// boxKeyPut(): void
boxKeyPut:
	proto 0 0

	// tests/contracts/storage.algo.ts:64
	// this.boxKey.value = 'bar'
	byte 0x666f6f // "foo"
	byte 0x626172 // "bar"
	box_put
	retsub

// boxKeyGet()void
*abi_route_boxKeyGet:
	// execute boxKeyGet()void
	callsub boxKeyGet
	int 1
	return

// boxKeyGet(): void
boxKeyGet:
	proto 0 0

	// tests/contracts/storage.algo.ts:68
	// assert(this.boxKey.value === 'bar')
	byte 0x666f6f // "foo"
	box_get

	// box value does not exist: this.boxKey.value
	assert
	byte 0x626172 // "bar"
	==
	assert
	retsub

// boxKeyDelete()void
*abi_route_boxKeyDelete:
	// execute boxKeyDelete()void
	callsub boxKeyDelete
	int 1
	return

// boxKeyDelete(): void
boxKeyDelete:
	proto 0 0

	// tests/contracts/storage.algo.ts:72
	// this.boxKey.delete()
	byte 0x666f6f // "foo"
	box_del
	retsub

// boxKeyExists()void
*abi_route_boxKeyExists:
	// execute boxKeyExists()void
	callsub boxKeyExists
	int 1
	return

// boxKeyExists(): void
boxKeyExists:
	proto 0 0

	// tests/contracts/storage.algo.ts:76
	// assert(this.boxKey.exists)
	byte 0x666f6f // "foo"
	box_len
	swap
	pop
	assert
	retsub

// globalMapPut()void
*abi_route_globalMapPut:
	// execute globalMapPut()void
	callsub globalMapPut
	int 1
	return

// globalMapPut(): void
globalMapPut:
	proto 0 0

	// tests/contracts/storage.algo.ts:80
	// this.globalMap('foo').value = 'bar'
	byte 0x666f6f // "foo"
	byte 0x626172 // "bar"
	app_global_put
	retsub

// globalMapGet()void
*abi_route_globalMapGet:
	// execute globalMapGet()void
	callsub globalMapGet
	int 1
	return

// globalMapGet(): void
globalMapGet:
	proto 0 0

	// tests/contracts/storage.algo.ts:84
	// assert(this.globalMap('foo').value === 'bar')
	byte 0x666f6f // "foo"
	app_global_get
	byte 0x626172 // "bar"
	==
	assert
	retsub

// globalMapDelete()void
*abi_route_globalMapDelete:
	// execute globalMapDelete()void
	callsub globalMapDelete
	int 1
	return

// globalMapDelete(): void
globalMapDelete:
	proto 0 0

	// tests/contracts/storage.algo.ts:88
	// this.globalMap('foo').delete()
	byte 0x666f6f // "foo"
	app_global_del
	retsub

// globalMapExists()void
*abi_route_globalMapExists:
	// execute globalMapExists()void
	callsub globalMapExists
	int 1
	return

// globalMapExists(): void
globalMapExists:
	proto 0 0

	// tests/contracts/storage.algo.ts:92
	// assert(this.globalMap('foo').exists)
	txna Applications 0
	byte 0x666f6f // "foo"
	app_global_get_ex
	swap
	pop
	assert
	retsub

// localMapPut(address)void
*abi_route_localMapPut:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for localMapPut must be a address
	assert

	// execute localMapPut(address)void
	callsub localMapPut
	int 1
	return

// localMapPut(a: Address): void
localMapPut:
	proto 1 0

	// tests/contracts/storage.algo.ts:96
	// this.localMap(a, 'foo').value = 'bar'
	frame_dig -1 // a: Address
	byte 0x666f6f // "foo"
	byte 0x626172 // "bar"
	app_local_put
	retsub

// localMapGet(address)void
*abi_route_localMapGet:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for localMapGet must be a address
	assert

	// execute localMapGet(address)void
	callsub localMapGet
	int 1
	return

// localMapGet(a: Address): void
localMapGet:
	proto 1 0

	// tests/contracts/storage.algo.ts:100
	// assert(this.localMap(a, 'foo').value === 'bar')
	frame_dig -1 // a: Address
	byte 0x666f6f // "foo"
	app_local_get
	byte 0x626172 // "bar"
	==
	assert
	retsub

// localMapDelete(address)void
*abi_route_localMapDelete:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for localMapDelete must be a address
	assert

	// execute localMapDelete(address)void
	callsub localMapDelete
	int 1
	return

// localMapDelete(a: Address): void
localMapDelete:
	proto 1 0

	// tests/contracts/storage.algo.ts:104
	// this.localMap(a, 'foo').delete()
	frame_dig -1 // a: Address
	byte 0x666f6f // "foo"
	app_local_del
	retsub

// localMapExists(address)void
*abi_route_localMapExists:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for localMapExists must be a address
	assert

	// execute localMapExists(address)void
	callsub localMapExists
	int 1
	return

// localMapExists(a: Address): void
localMapExists:
	proto 1 0

	// tests/contracts/storage.algo.ts:108
	// assert(this.localMap(a, 'foo').exists)
	frame_dig -1 // a: Address
	txna Applications 0
	byte 0x666f6f // "foo"
	app_local_get_ex
	swap
	pop
	assert
	retsub

// boxMapPut()void
*abi_route_boxMapPut:
	// execute boxMapPut()void
	callsub boxMapPut
	int 1
	return

// boxMapPut(): void
boxMapPut:
	proto 0 0

	// tests/contracts/storage.algo.ts:112
	// this.boxMap('foo').value = 'bar'
	byte 0x666f6f // "foo"
	byte 0x626172 // "bar"
	box_put
	retsub

// boxMapGet()void
*abi_route_boxMapGet:
	// execute boxMapGet()void
	callsub boxMapGet
	int 1
	return

// boxMapGet(): void
boxMapGet:
	proto 0 0

	// tests/contracts/storage.algo.ts:116
	// assert(this.boxMap('foo').value === 'bar')
	byte 0x666f6f // "foo"
	box_get

	// box value does not exist: this.boxMap('foo').value
	assert
	byte 0x626172 // "bar"
	==
	assert
	retsub

// boxMapDelete()void
*abi_route_boxMapDelete:
	// execute boxMapDelete()void
	callsub boxMapDelete
	int 1
	return

// boxMapDelete(): void
boxMapDelete:
	proto 0 0

	// tests/contracts/storage.algo.ts:120
	// this.boxMap('foo').delete()
	byte 0x666f6f // "foo"
	box_del
	retsub

// boxMapExists()void
*abi_route_boxMapExists:
	// execute boxMapExists()void
	callsub boxMapExists
	int 1
	return

// boxMapExists(): void
boxMapExists:
	proto 0 0

	// tests/contracts/storage.algo.ts:124
	// assert(this.boxMap('foo').exists)
	byte 0x666f6f // "foo"
	box_len
	swap
	pop
	assert
	retsub

// boxKeyCreate()void
*abi_route_boxKeyCreate:
	// execute boxKeyCreate()void
	callsub boxKeyCreate
	int 1
	return

// boxKeyCreate(): void
boxKeyCreate:
	proto 0 0

	// tests/contracts/storage.algo.ts:128
	// this.boxKey.create(1024)
	byte 0x666f6f // "foo"
	int 1024
	box_create
	pop
	retsub

// boxMapCreate()void
*abi_route_boxMapCreate:
	// execute boxMapCreate()void
	callsub boxMapCreate
	int 1
	return

// boxMapCreate(): void
boxMapCreate:
	proto 0 0

	// tests/contracts/storage.algo.ts:132
	// this.boxMap('bar').create(1024)
	byte 0x626172 // "bar"
	int 1024
	box_create
	pop
	retsub

// boxKeyLength()uint64
*abi_route_boxKeyLength:
	// The ABI return prefix
	byte 0x151f7c75

	// execute boxKeyLength()uint64
	callsub boxKeyLength
	itob
	concat
	log
	int 1
	return

// boxKeyLength(): uint64
boxKeyLength:
	proto 0 1

	// tests/contracts/storage.algo.ts:136
	// return this.boxKey.size;
	byte 0x666f6f // "foo"
	box_len

	// box value does not exist: this.boxKey.size
	assert
	retsub

// boxMapLength()uint64
*abi_route_boxMapLength:
	// The ABI return prefix
	byte 0x151f7c75

	// execute boxMapLength()uint64
	callsub boxMapLength
	itob
	concat
	log
	int 1
	return

// boxMapLength(): uint64
boxMapLength:
	proto 0 1

	// tests/contracts/storage.algo.ts:140
	// return this.boxMap('bar').size;
	byte 0x626172 // "bar"
	box_len

	// box value does not exist: this.boxMap('bar').size
	assert
	retsub

// boxKeyReplace()void
*abi_route_boxKeyReplace:
	// execute boxKeyReplace()void
	callsub boxKeyReplace
	int 1
	return

// boxKeyReplace(): void
boxKeyReplace:
	proto 0 0

	// tests/contracts/storage.algo.ts:144
	// this.boxKey.replace(0, 'abc')
	byte 0x666f6f // "foo"
	pushint 0
	byte 0x616263 // "abc"
	box_replace
	retsub

// boxMapReplace()void
*abi_route_boxMapReplace:
	// execute boxMapReplace()void
	callsub boxMapReplace
	int 1
	return

// boxMapReplace(): void
boxMapReplace:
	proto 0 0

	// tests/contracts/storage.algo.ts:148
	// this.boxMap('bar').replace(0, 'abc')
	byte 0x626172 // "bar"
	pushint 0
	byte 0x616263 // "abc"
	box_replace
	retsub

// boxKeyExtract()string
*abi_route_boxKeyExtract:
	// The ABI return prefix
	byte 0x151f7c75

	// execute boxKeyExtract()string
	callsub boxKeyExtract
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// boxKeyExtract(): string
boxKeyExtract:
	proto 0 1

	// tests/contracts/storage.algo.ts:152
	// return this.boxKey.extract(0, 3);
	byte 0x666f6f // "foo"
	pushint 0
	pushint 3
	box_extract
	retsub

// boxMapExtract()string
*abi_route_boxMapExtract:
	// The ABI return prefix
	byte 0x151f7c75

	// execute boxMapExtract()string
	callsub boxMapExtract
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// boxMapExtract(): string
boxMapExtract:
	proto 0 1

	// tests/contracts/storage.algo.ts:156
	// return this.boxMap('bar').extract(0, 3);
	byte 0x626172 // "bar"
	pushint 0
	pushint 3
	box_extract
	retsub

// isOptedIn()bool
*abi_route_isOptedIn:
	// The ABI return prefix
	byte 0x151f7c75

	// execute isOptedIn()bool
	callsub isOptedIn
	pushbytes 0x00
	pushint 0
	uncover 2
	setbit
	concat
	log
	int 1
	return

// isOptedIn(): boolean
isOptedIn:
	proto 0 1

	// tests/contracts/storage.algo.ts:160
	// return this.txn.sender.isOptedInToApp(this.app);
	txn Sender
	txna Applications 0
	app_opted_in
	retsub

// exGlobal()void
*abi_route_exGlobal:
	// execute exGlobal()void
	callsub exGlobal
	int 1
	return

// exGlobal(): void
exGlobal:
	proto 0 0

	// tests/contracts/storage.algo.ts:164
	// log(this.app.globalState('foo') as bytes)
	txna Applications 0
	byte 0x666f6f // "foo"
	app_global_get_ex

	// global state value does not exist: this.app.globalState('foo')
	assert
	log
	retsub

// exLocal()void
*abi_route_exLocal:
	// execute exLocal()void
	callsub exLocal
	int 1
	return

// exLocal(): void
exLocal:
	proto 0 0

	// tests/contracts/storage.algo.ts:168
	// log(this.app.localState(this.txn.sender, 'foo') as bytes)
	txn Sender
	txna Applications 0
	byte 0x666f6f // "foo"
	app_local_get_ex

	// local state value does not exist: this.app.localState(this.txn.sender, 'foo')
	assert
	log
	retsub

// accessStaticValueInLargeBox()uint16
*abi_route_accessStaticValueInLargeBox:
	// The ABI return prefix
	byte 0x151f7c75

	// execute accessStaticValueInLargeBox()uint16
	callsub accessStaticValueInLargeBox
	itob
	dup
	bitlen
	pushint 16
	<=

	// accessStaticValueInLargeBox return value overflowed 16 bits
	assert
	extract 6 2
	concat
	log
	int 1
	return

// accessStaticValueInLargeBox(): uint16
accessStaticValueInLargeBox:
	proto 0 1

	// tests/contracts/storage.algo.ts:172
	// this.largeStaticArrayInBox.create()
	byte 0x6c617267655374617469634172726179496e426f78 // "largeStaticArrayInBox"
	pushint 8000
	box_create
	pop

	// tests/contracts/storage.algo.ts:173
	// this.largeStaticArrayInBox.value[123] = 456
	byte 0x6c617267655374617469634172726179496e426f78 // "largeStaticArrayInBox"
	pushint 246
	byte 0x01c8
	box_replace

	// tests/contracts/storage.algo.ts:175
	// return this.largeStaticArrayInBox.value[123];
	byte 0x6c617267655374617469634172726179496e426f78 // "largeStaticArrayInBox"
	pushint 246
	pushint 2
	box_extract
	btoi
	retsub

// dynamicAccessStaticValueInLargeBox(uint64)uint16
*abi_route_dynamicAccessStaticValueInLargeBox:
	// The ABI return prefix
	byte 0x151f7c75

	// i: uint64
	txna ApplicationArgs 1
	btoi

	// execute dynamicAccessStaticValueInLargeBox(uint64)uint16
	callsub dynamicAccessStaticValueInLargeBox
	itob
	dup
	bitlen
	pushint 16
	<=

	// dynamicAccessStaticValueInLargeBox return value overflowed 16 bits
	assert
	extract 6 2
	concat
	log
	int 1
	return

// dynamicAccessStaticValueInLargeBox(i: uint64): uint16
dynamicAccessStaticValueInLargeBox:
	proto 1 1

	// tests/contracts/storage.algo.ts:179
	// this.largeStaticArrayInBox.create()
	byte 0x6c617267655374617469634172726179496e426f78 // "largeStaticArrayInBox"
	pushint 8000
	box_create
	pop

	// tests/contracts/storage.algo.ts:180
	// this.largeStaticArrayInBox.value[i] = 456
	frame_dig -1 // i: uint64
	pushint 2
	* // acc * typeLength
	byte 0x01c8
	byte 0x6c617267655374617469634172726179496e426f78 // "largeStaticArrayInBox"
	cover 2
	box_replace

	// tests/contracts/storage.algo.ts:184
	// return a[i];
	frame_dig -1 // i: uint64
	pushint 2
	* // acc * typeLength
	pushint 2
	byte 0x6c617267655374617469634172726179496e426f78 // "largeStaticArrayInBox"
	cover 2
	box_extract
	btoi
	retsub

// boxResize()void
*abi_route_boxResize:
	// execute boxResize()void
	callsub boxResize
	int 1
	return

// boxResize(): void
boxResize:
	proto 0 0

	// tests/contracts/storage.algo.ts:188
	// this.boxKey.resize(1024)
	byte 0x666f6f // "foo"
	int 1024
	box_resize

	// tests/contracts/storage.algo.ts:189
	// this.boxMap('bar').resize(1024)
	byte 0x626172 // "bar"
	int 1024
	box_resize
	retsub

// boxSplice()void
*abi_route_boxSplice:
	// execute boxSplice()void
	callsub boxSplice
	int 1
	return

// boxSplice(): void
boxSplice:
	proto 0 0

	// tests/contracts/storage.algo.ts:193
	// this.boxKey.splice(0, 1, 'abc')
	byte 0x666f6f // "foo"
	pushint 0
	int 1
	byte 0x616263 // "abc"
	box_splice

	// tests/contracts/storage.algo.ts:194
	// this.boxMap('bar').splice(0, 1, 'abc')
	byte 0x626172 // "bar"
	pushint 0
	int 1
	byte 0x616263 // "abc"
	box_splice
	retsub

// exStateExists()void
*abi_route_exStateExists:
	// execute exStateExists()void
	callsub exStateExists
	int 1
	return

// exStateExists(): void
exStateExists:
	proto 0 0

	// tests/contracts/storage.algo.ts:198
	// assert(this.app.globalStateExists('foo'))
	txna Applications 0
	byte 0x666f6f // "foo"
	app_global_get_ex
	swap
	pop
	assert

	// tests/contracts/storage.algo.ts:199
	// assert(this.app.localStateExists(this.txn.sender, 'foo'))
	txn Sender
	txna Applications 0
	byte 0x666f6f // "foo"
	app_local_get_ex
	swap
	pop
	assert
	retsub

*abi_route_createApplication:
	int 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x5b02ba87 // method "prefix()void"
	pushbytes 0x47826307 // method "globalKeyPut()void"
	pushbytes 0xd387cd2c // method "globalKeyGet()void"
	pushbytes 0x2f78db03 // method "globalKeyDelete()void"
	pushbytes 0xd8181a9a // method "globalKeyExists()void"
	pushbytes 0xecb06998 // method "localKeyPut(address)void"
	pushbytes 0x56dace1d // method "localKeyGet(address)void"
	pushbytes 0x768c8c68 // method "localKeyDelete(address)void"
	pushbytes 0xbc0ea6bb // method "localKeyExists(address)void"
	pushbytes 0xcf48ae4d // method "boxKeyPut()void"
	pushbytes 0xe9dab493 // method "boxKeyGet()void"
	pushbytes 0x090fdfd6 // method "boxKeyDelete()void"
	pushbytes 0x5ff9d0dd // method "boxKeyExists()void"
	pushbytes 0x17c8206a // method "globalMapPut()void"
	pushbytes 0xcd868bf2 // method "globalMapGet()void"
	pushbytes 0xb55de20c // method "globalMapDelete()void"
	pushbytes 0xc97d8d24 // method "globalMapExists()void"
	pushbytes 0xfc83803c // method "localMapPut(address)void"
	pushbytes 0x9875355d // method "localMapGet(address)void"
	pushbytes 0x742a6e83 // method "localMapDelete(address)void"
	pushbytes 0x88235265 // method "localMapExists(address)void"
	pushbytes 0x84e5681c // method "boxMapPut()void"
	pushbytes 0xae3ce7ee // method "boxMapGet()void"
	pushbytes 0xb9e0ed3d // method "boxMapDelete()void"
	pushbytes 0x652bd5d6 // method "boxMapExists()void"
	pushbytes 0xd36ee315 // method "boxKeyCreate()void"
	pushbytes 0x1029bd07 // method "boxMapCreate()void"
	pushbytes 0xa747b62f // method "boxKeyLength()uint64"
	pushbytes 0x5a1eefbe // method "boxMapLength()uint64"
	pushbytes 0x1337dd60 // method "boxKeyReplace()void"
	pushbytes 0x424ef95a // method "boxMapReplace()void"
	pushbytes 0x88c1c309 // method "boxKeyExtract()string"
	pushbytes 0x43635643 // method "boxMapExtract()string"
	pushbytes 0xab42554e // method "isOptedIn()bool"
	pushbytes 0x0167b7a2 // method "exGlobal()void"
	pushbytes 0xaad51755 // method "exLocal()void"
	pushbytes 0x1b41ce22 // method "accessStaticValueInLargeBox()uint16"
	pushbytes 0xf5da1a55 // method "dynamicAccessStaticValueInLargeBox(uint64)uint16"
	pushbytes 0xbc5c18fd // method "boxResize()void"
	pushbytes 0x25a92329 // method "boxSplice()void"
	pushbytes 0x4ed8699b // method "exStateExists()void"
	txna ApplicationArgs 0
	match *abi_route_prefix *abi_route_globalKeyPut *abi_route_globalKeyGet *abi_route_globalKeyDelete *abi_route_globalKeyExists *abi_route_localKeyPut *abi_route_localKeyGet *abi_route_localKeyDelete *abi_route_localKeyExists *abi_route_boxKeyPut *abi_route_boxKeyGet *abi_route_boxKeyDelete *abi_route_boxKeyExists *abi_route_globalMapPut *abi_route_globalMapGet *abi_route_globalMapDelete *abi_route_globalMapExists *abi_route_localMapPut *abi_route_localMapGet *abi_route_localMapDelete *abi_route_localMapExists *abi_route_boxMapPut *abi_route_boxMapGet *abi_route_boxMapDelete *abi_route_boxMapExists *abi_route_boxKeyCreate *abi_route_boxMapCreate *abi_route_boxKeyLength *abi_route_boxMapLength *abi_route_boxKeyReplace *abi_route_boxMapReplace *abi_route_boxKeyExtract *abi_route_boxMapExtract *abi_route_isOptedIn *abi_route_exGlobal *abi_route_exLocal *abi_route_accessStaticValueInLargeBox *abi_route_dynamicAccessStaticValueInLargeBox *abi_route_boxResize *abi_route_boxSplice *abi_route_exStateExists

	// this contract does not implement the given ABI method for call NoOp
	err", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/StorageTest.arc56_draft.json b/tests/contracts/artifacts/StorageTest.arc56_draft.json index 22756b967..d21c46c14 100644 --- a/tests/contracts/artifacts/StorageTest.arc56_draft.json +++ b/tests/contracts/artifacts/StorageTest.arc56_draft.json @@ -5953,7 +5953,7 @@ } }, "source": { - "approval": "#pragma version 10
intcblock 1 32 1024
bytecblock 0x666f6f 0x6c617267655374617469634172726179496e426f78 0x626172 0x151f7c75 0x616263 0x01c8

// This TEAL was generated by TEALScript v0.104.1
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// prefix()void
*abi_route_prefix:
	// execute prefix()void
	callsub prefix
	int 1
	return

// prefix(): void
prefix:
	proto 0 0

	// tests/contracts/storage.algo.ts:26
	// this.boxMapWithPrefix('oo').value = 'bar'
	byte 0x666f6f
	dup
	box_del
	pop
	byte 0x626172 // "bar"
	box_put

	// tests/contracts/storage.algo.ts:27
	// this.globalMapWithPrefix('oo').value = 'bar'
	byte 0x666f6f
	byte 0x626172 // "bar"
	app_global_put

	// tests/contracts/storage.algo.ts:28
	// this.localMapWithPrefix(this.txn.sender, 'oo').value = 'bar'
	txn Sender
	byte 0x666f6f
	byte 0x626172 // "bar"
	app_local_put
	retsub

// globalKeyPut()void
*abi_route_globalKeyPut:
	// execute globalKeyPut()void
	callsub globalKeyPut
	int 1
	return

// globalKeyPut(): void
globalKeyPut:
	proto 0 0

	// tests/contracts/storage.algo.ts:32
	// this.globalKey.value = 'bar'
	byte 0x666f6f // "foo"
	byte 0x626172 // "bar"
	app_global_put
	retsub

// globalKeyGet()void
*abi_route_globalKeyGet:
	// execute globalKeyGet()void
	callsub globalKeyGet
	int 1
	return

// globalKeyGet(): void
globalKeyGet:
	proto 0 0

	// tests/contracts/storage.algo.ts:36
	// assert(this.globalKey.value === 'bar')
	byte 0x666f6f // "foo"
	app_global_get
	byte 0x626172 // "bar"
	==
	assert
	retsub

// globalKeyDelete()void
*abi_route_globalKeyDelete:
	// execute globalKeyDelete()void
	callsub globalKeyDelete
	int 1
	return

// globalKeyDelete(): void
globalKeyDelete:
	proto 0 0

	// tests/contracts/storage.algo.ts:40
	// this.globalKey.delete()
	byte 0x666f6f // "foo"
	app_global_del
	retsub

// globalKeyExists()void
*abi_route_globalKeyExists:
	// execute globalKeyExists()void
	callsub globalKeyExists
	int 1
	return

// globalKeyExists(): void
globalKeyExists:
	proto 0 0

	// tests/contracts/storage.algo.ts:44
	// assert(this.globalKey.exists)
	txna Applications 0
	byte 0x666f6f // "foo"
	app_global_get_ex
	swap
	pop
	assert
	retsub

// localKeyPut(address)void
*abi_route_localKeyPut:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for localKeyPut must be a address
	assert

	// execute localKeyPut(address)void
	callsub localKeyPut
	int 1
	return

// localKeyPut(a: Address): void
localKeyPut:
	proto 1 0

	// tests/contracts/storage.algo.ts:48
	// this.localKey(a).value = 'bar'
	frame_dig -1 // a: Address
	byte 0x666f6f // "foo"
	byte 0x626172 // "bar"
	app_local_put
	retsub

// localKeyGet(address)void
*abi_route_localKeyGet:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for localKeyGet must be a address
	assert

	// execute localKeyGet(address)void
	callsub localKeyGet
	int 1
	return

// localKeyGet(a: Address): void
localKeyGet:
	proto 1 0

	// tests/contracts/storage.algo.ts:52
	// assert(this.localKey(a).value === 'bar')
	frame_dig -1 // a: Address
	byte 0x666f6f // "foo"
	app_local_get
	byte 0x626172 // "bar"
	==
	assert
	retsub

// localKeyDelete(address)void
*abi_route_localKeyDelete:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for localKeyDelete must be a address
	assert

	// execute localKeyDelete(address)void
	callsub localKeyDelete
	int 1
	return

// localKeyDelete(a: Address): void
localKeyDelete:
	proto 1 0

	// tests/contracts/storage.algo.ts:56
	// this.localKey(a).delete()
	frame_dig -1 // a: Address
	byte 0x666f6f // "foo"
	app_local_del
	retsub

// localKeyExists(address)void
*abi_route_localKeyExists:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for localKeyExists must be a address
	assert

	// execute localKeyExists(address)void
	callsub localKeyExists
	int 1
	return

// localKeyExists(a: Address): void
localKeyExists:
	proto 1 0

	// tests/contracts/storage.algo.ts:60
	// assert(this.localKey(a).exists)
	frame_dig -1 // a: Address
	txna Applications 0
	byte 0x666f6f // "foo"
	app_local_get_ex
	swap
	pop
	assert
	retsub

// boxKeyPut()void
*abi_route_boxKeyPut:
	// execute boxKeyPut()void
	callsub boxKeyPut
	int 1
	return

// boxKeyPut(): void
boxKeyPut:
	proto 0 0

	// tests/contracts/storage.algo.ts:64
	// this.boxKey.value = 'bar'
	byte 0x666f6f // "foo"
	byte 0x626172 // "bar"
	box_put
	retsub

// boxKeyGet()void
*abi_route_boxKeyGet:
	// execute boxKeyGet()void
	callsub boxKeyGet
	int 1
	return

// boxKeyGet(): void
boxKeyGet:
	proto 0 0

	// tests/contracts/storage.algo.ts:68
	// assert(this.boxKey.value === 'bar')
	byte 0x666f6f // "foo"
	box_get

	// box value does not exist: this.boxKey.value
	assert
	byte 0x626172 // "bar"
	==
	assert
	retsub

// boxKeyDelete()void
*abi_route_boxKeyDelete:
	// execute boxKeyDelete()void
	callsub boxKeyDelete
	int 1
	return

// boxKeyDelete(): void
boxKeyDelete:
	proto 0 0

	// tests/contracts/storage.algo.ts:72
	// this.boxKey.delete()
	byte 0x666f6f // "foo"
	box_del
	retsub

// boxKeyExists()void
*abi_route_boxKeyExists:
	// execute boxKeyExists()void
	callsub boxKeyExists
	int 1
	return

// boxKeyExists(): void
boxKeyExists:
	proto 0 0

	// tests/contracts/storage.algo.ts:76
	// assert(this.boxKey.exists)
	byte 0x666f6f // "foo"
	box_len
	swap
	pop
	assert
	retsub

// globalMapPut()void
*abi_route_globalMapPut:
	// execute globalMapPut()void
	callsub globalMapPut
	int 1
	return

// globalMapPut(): void
globalMapPut:
	proto 0 0

	// tests/contracts/storage.algo.ts:80
	// this.globalMap('foo').value = 'bar'
	byte 0x666f6f // "foo"
	byte 0x626172 // "bar"
	app_global_put
	retsub

// globalMapGet()void
*abi_route_globalMapGet:
	// execute globalMapGet()void
	callsub globalMapGet
	int 1
	return

// globalMapGet(): void
globalMapGet:
	proto 0 0

	// tests/contracts/storage.algo.ts:84
	// assert(this.globalMap('foo').value === 'bar')
	byte 0x666f6f // "foo"
	app_global_get
	byte 0x626172 // "bar"
	==
	assert
	retsub

// globalMapDelete()void
*abi_route_globalMapDelete:
	// execute globalMapDelete()void
	callsub globalMapDelete
	int 1
	return

// globalMapDelete(): void
globalMapDelete:
	proto 0 0

	// tests/contracts/storage.algo.ts:88
	// this.globalMap('foo').delete()
	byte 0x666f6f // "foo"
	app_global_del
	retsub

// globalMapExists()void
*abi_route_globalMapExists:
	// execute globalMapExists()void
	callsub globalMapExists
	int 1
	return

// globalMapExists(): void
globalMapExists:
	proto 0 0

	// tests/contracts/storage.algo.ts:92
	// assert(this.globalMap('foo').exists)
	txna Applications 0
	byte 0x666f6f // "foo"
	app_global_get_ex
	swap
	pop
	assert
	retsub

// localMapPut(address)void
*abi_route_localMapPut:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for localMapPut must be a address
	assert

	// execute localMapPut(address)void
	callsub localMapPut
	int 1
	return

// localMapPut(a: Address): void
localMapPut:
	proto 1 0

	// tests/contracts/storage.algo.ts:96
	// this.localMap(a, 'foo').value = 'bar'
	frame_dig -1 // a: Address
	byte 0x666f6f // "foo"
	byte 0x626172 // "bar"
	app_local_put
	retsub

// localMapGet(address)void
*abi_route_localMapGet:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for localMapGet must be a address
	assert

	// execute localMapGet(address)void
	callsub localMapGet
	int 1
	return

// localMapGet(a: Address): void
localMapGet:
	proto 1 0

	// tests/contracts/storage.algo.ts:100
	// assert(this.localMap(a, 'foo').value === 'bar')
	frame_dig -1 // a: Address
	byte 0x666f6f // "foo"
	app_local_get
	byte 0x626172 // "bar"
	==
	assert
	retsub

// localMapDelete(address)void
*abi_route_localMapDelete:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for localMapDelete must be a address
	assert

	// execute localMapDelete(address)void
	callsub localMapDelete
	int 1
	return

// localMapDelete(a: Address): void
localMapDelete:
	proto 1 0

	// tests/contracts/storage.algo.ts:104
	// this.localMap(a, 'foo').delete()
	frame_dig -1 // a: Address
	byte 0x666f6f // "foo"
	app_local_del
	retsub

// localMapExists(address)void
*abi_route_localMapExists:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for localMapExists must be a address
	assert

	// execute localMapExists(address)void
	callsub localMapExists
	int 1
	return

// localMapExists(a: Address): void
localMapExists:
	proto 1 0

	// tests/contracts/storage.algo.ts:108
	// assert(this.localMap(a, 'foo').exists)
	frame_dig -1 // a: Address
	txna Applications 0
	byte 0x666f6f // "foo"
	app_local_get_ex
	swap
	pop
	assert
	retsub

// boxMapPut()void
*abi_route_boxMapPut:
	// execute boxMapPut()void
	callsub boxMapPut
	int 1
	return

// boxMapPut(): void
boxMapPut:
	proto 0 0

	// tests/contracts/storage.algo.ts:112
	// this.boxMap('foo').value = 'bar'
	byte 0x666f6f // "foo"
	byte 0x626172 // "bar"
	box_put
	retsub

// boxMapGet()void
*abi_route_boxMapGet:
	// execute boxMapGet()void
	callsub boxMapGet
	int 1
	return

// boxMapGet(): void
boxMapGet:
	proto 0 0

	// tests/contracts/storage.algo.ts:116
	// assert(this.boxMap('foo').value === 'bar')
	byte 0x666f6f // "foo"
	box_get

	// box value does not exist: this.boxMap('foo').value
	assert
	byte 0x626172 // "bar"
	==
	assert
	retsub

// boxMapDelete()void
*abi_route_boxMapDelete:
	// execute boxMapDelete()void
	callsub boxMapDelete
	int 1
	return

// boxMapDelete(): void
boxMapDelete:
	proto 0 0

	// tests/contracts/storage.algo.ts:120
	// this.boxMap('foo').delete()
	byte 0x666f6f // "foo"
	box_del
	retsub

// boxMapExists()void
*abi_route_boxMapExists:
	// execute boxMapExists()void
	callsub boxMapExists
	int 1
	return

// boxMapExists(): void
boxMapExists:
	proto 0 0

	// tests/contracts/storage.algo.ts:124
	// assert(this.boxMap('foo').exists)
	byte 0x666f6f // "foo"
	box_len
	swap
	pop
	assert
	retsub

// boxKeyCreate()void
*abi_route_boxKeyCreate:
	// execute boxKeyCreate()void
	callsub boxKeyCreate
	int 1
	return

// boxKeyCreate(): void
boxKeyCreate:
	proto 0 0

	// tests/contracts/storage.algo.ts:128
	// this.boxKey.create(1024)
	byte 0x666f6f // "foo"
	int 1024
	box_create
	pop
	retsub

// boxMapCreate()void
*abi_route_boxMapCreate:
	// execute boxMapCreate()void
	callsub boxMapCreate
	int 1
	return

// boxMapCreate(): void
boxMapCreate:
	proto 0 0

	// tests/contracts/storage.algo.ts:132
	// this.boxMap('bar').create(1024)
	byte 0x626172 // "bar"
	int 1024
	box_create
	pop
	retsub

// boxKeyLength()uint64
*abi_route_boxKeyLength:
	// The ABI return prefix
	byte 0x151f7c75

	// execute boxKeyLength()uint64
	callsub boxKeyLength
	itob
	concat
	log
	int 1
	return

// boxKeyLength(): uint64
boxKeyLength:
	proto 0 1

	// tests/contracts/storage.algo.ts:136
	// return this.boxKey.size;
	byte 0x666f6f // "foo"
	box_len

	// box value does not exist: this.boxKey.size
	assert
	retsub

// boxMapLength()uint64
*abi_route_boxMapLength:
	// The ABI return prefix
	byte 0x151f7c75

	// execute boxMapLength()uint64
	callsub boxMapLength
	itob
	concat
	log
	int 1
	return

// boxMapLength(): uint64
boxMapLength:
	proto 0 1

	// tests/contracts/storage.algo.ts:140
	// return this.boxMap('bar').size;
	byte 0x626172 // "bar"
	box_len

	// box value does not exist: this.boxMap('bar').size
	assert
	retsub

// boxKeyReplace()void
*abi_route_boxKeyReplace:
	// execute boxKeyReplace()void
	callsub boxKeyReplace
	int 1
	return

// boxKeyReplace(): void
boxKeyReplace:
	proto 0 0

	// tests/contracts/storage.algo.ts:144
	// this.boxKey.replace(0, 'abc')
	byte 0x666f6f // "foo"
	pushint 0
	byte 0x616263 // "abc"
	box_replace
	retsub

// boxMapReplace()void
*abi_route_boxMapReplace:
	// execute boxMapReplace()void
	callsub boxMapReplace
	int 1
	return

// boxMapReplace(): void
boxMapReplace:
	proto 0 0

	// tests/contracts/storage.algo.ts:148
	// this.boxMap('bar').replace(0, 'abc')
	byte 0x626172 // "bar"
	pushint 0
	byte 0x616263 // "abc"
	box_replace
	retsub

// boxKeyExtract()string
*abi_route_boxKeyExtract:
	// The ABI return prefix
	byte 0x151f7c75

	// execute boxKeyExtract()string
	callsub boxKeyExtract
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// boxKeyExtract(): string
boxKeyExtract:
	proto 0 1

	// tests/contracts/storage.algo.ts:152
	// return this.boxKey.extract(0, 3);
	byte 0x666f6f // "foo"
	pushint 0
	pushint 3
	box_extract
	retsub

// boxMapExtract()string
*abi_route_boxMapExtract:
	// The ABI return prefix
	byte 0x151f7c75

	// execute boxMapExtract()string
	callsub boxMapExtract
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// boxMapExtract(): string
boxMapExtract:
	proto 0 1

	// tests/contracts/storage.algo.ts:156
	// return this.boxMap('bar').extract(0, 3);
	byte 0x626172 // "bar"
	pushint 0
	pushint 3
	box_extract
	retsub

// isOptedIn()bool
*abi_route_isOptedIn:
	// The ABI return prefix
	byte 0x151f7c75

	// execute isOptedIn()bool
	callsub isOptedIn
	pushbytes 0x00
	pushint 0
	uncover 2
	setbit
	concat
	log
	int 1
	return

// isOptedIn(): boolean
isOptedIn:
	proto 0 1

	// tests/contracts/storage.algo.ts:160
	// return this.txn.sender.isOptedInToApp(this.app);
	txn Sender
	txna Applications 0
	app_opted_in
	retsub

// exGlobal()void
*abi_route_exGlobal:
	// execute exGlobal()void
	callsub exGlobal
	int 1
	return

// exGlobal(): void
exGlobal:
	proto 0 0

	// tests/contracts/storage.algo.ts:164
	// log(this.app.globalState('foo') as bytes)
	txna Applications 0
	byte 0x666f6f // "foo"
	app_global_get_ex

	// global state value does not exist: this.app.globalState('foo')
	assert
	log
	retsub

// exLocal()void
*abi_route_exLocal:
	// execute exLocal()void
	callsub exLocal
	int 1
	return

// exLocal(): void
exLocal:
	proto 0 0

	// tests/contracts/storage.algo.ts:168
	// log(this.app.localState(this.txn.sender, 'foo') as bytes)
	txn Sender
	txna Applications 0
	byte 0x666f6f // "foo"
	app_local_get_ex

	// local state value does not exist: this.app.localState(this.txn.sender, 'foo')
	assert
	log
	retsub

// accessStaticValueInLargeBox()uint16
*abi_route_accessStaticValueInLargeBox:
	// The ABI return prefix
	byte 0x151f7c75

	// execute accessStaticValueInLargeBox()uint16
	callsub accessStaticValueInLargeBox
	itob
	dup
	bitlen
	pushint 16
	<=

	// accessStaticValueInLargeBox return value overflowed 16 bits
	assert
	extract 6 2
	concat
	log
	int 1
	return

// accessStaticValueInLargeBox(): uint16
accessStaticValueInLargeBox:
	proto 0 1

	// tests/contracts/storage.algo.ts:172
	// this.largeStaticArrayInBox.create()
	byte 0x6c617267655374617469634172726179496e426f78 // "largeStaticArrayInBox"
	pushint 8000
	box_create
	pop

	// tests/contracts/storage.algo.ts:173
	// this.largeStaticArrayInBox.value[123] = 456
	byte 0x6c617267655374617469634172726179496e426f78 // "largeStaticArrayInBox"
	pushint 246
	byte 0x01c8
	box_replace

	// tests/contracts/storage.algo.ts:175
	// return this.largeStaticArrayInBox.value[123];
	byte 0x6c617267655374617469634172726179496e426f78 // "largeStaticArrayInBox"
	pushint 246
	pushint 2
	box_extract
	btoi
	retsub

// dynamicAccessStaticValueInLargeBox(uint64)uint16
*abi_route_dynamicAccessStaticValueInLargeBox:
	// The ABI return prefix
	byte 0x151f7c75

	// i: uint64
	txna ApplicationArgs 1
	btoi

	// execute dynamicAccessStaticValueInLargeBox(uint64)uint16
	callsub dynamicAccessStaticValueInLargeBox
	itob
	dup
	bitlen
	pushint 16
	<=

	// dynamicAccessStaticValueInLargeBox return value overflowed 16 bits
	assert
	extract 6 2
	concat
	log
	int 1
	return

// dynamicAccessStaticValueInLargeBox(i: uint64): uint16
dynamicAccessStaticValueInLargeBox:
	proto 1 1

	// tests/contracts/storage.algo.ts:179
	// this.largeStaticArrayInBox.create()
	byte 0x6c617267655374617469634172726179496e426f78 // "largeStaticArrayInBox"
	pushint 8000
	box_create
	pop

	// tests/contracts/storage.algo.ts:180
	// this.largeStaticArrayInBox.value[i] = 456
	frame_dig -1 // i: uint64
	pushint 2
	* // acc * typeLength
	byte 0x01c8
	byte 0x6c617267655374617469634172726179496e426f78 // "largeStaticArrayInBox"
	cover 2
	box_replace

	// tests/contracts/storage.algo.ts:184
	// return a[i];
	frame_dig -1 // i: uint64
	pushint 2
	* // acc * typeLength
	pushint 2
	byte 0x6c617267655374617469634172726179496e426f78 // "largeStaticArrayInBox"
	cover 2
	box_extract
	btoi
	retsub

// boxResize()void
*abi_route_boxResize:
	// execute boxResize()void
	callsub boxResize
	int 1
	return

// boxResize(): void
boxResize:
	proto 0 0

	// tests/contracts/storage.algo.ts:188
	// this.boxKey.resize(1024)
	byte 0x666f6f // "foo"
	int 1024
	box_resize

	// tests/contracts/storage.algo.ts:189
	// this.boxMap('bar').resize(1024)
	byte 0x626172 // "bar"
	int 1024
	box_resize
	retsub

// boxSplice()void
*abi_route_boxSplice:
	// execute boxSplice()void
	callsub boxSplice
	int 1
	return

// boxSplice(): void
boxSplice:
	proto 0 0

	// tests/contracts/storage.algo.ts:193
	// this.boxKey.splice(0, 1, 'abc')
	byte 0x666f6f // "foo"
	pushint 0
	int 1
	byte 0x616263 // "abc"
	box_splice

	// tests/contracts/storage.algo.ts:194
	// this.boxMap('bar').splice(0, 1, 'abc')
	byte 0x626172 // "bar"
	pushint 0
	int 1
	byte 0x616263 // "abc"
	box_splice
	retsub

// exStateExists()void
*abi_route_exStateExists:
	// execute exStateExists()void
	callsub exStateExists
	int 1
	return

// exStateExists(): void
exStateExists:
	proto 0 0

	// tests/contracts/storage.algo.ts:198
	// assert(this.app.globalStateExists('foo'))
	txna Applications 0
	byte 0x666f6f // "foo"
	app_global_get_ex
	swap
	pop
	assert

	// tests/contracts/storage.algo.ts:199
	// assert(this.app.localStateExists(this.txn.sender, 'foo'))
	txn Sender
	txna Applications 0
	byte 0x666f6f // "foo"
	app_local_get_ex
	swap
	pop
	assert
	retsub

*abi_route_createApplication:
	int 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x5b02ba87 // method "prefix()void"
	pushbytes 0x47826307 // method "globalKeyPut()void"
	pushbytes 0xd387cd2c // method "globalKeyGet()void"
	pushbytes 0x2f78db03 // method "globalKeyDelete()void"
	pushbytes 0xd8181a9a // method "globalKeyExists()void"
	pushbytes 0xecb06998 // method "localKeyPut(address)void"
	pushbytes 0x56dace1d // method "localKeyGet(address)void"
	pushbytes 0x768c8c68 // method "localKeyDelete(address)void"
	pushbytes 0xbc0ea6bb // method "localKeyExists(address)void"
	pushbytes 0xcf48ae4d // method "boxKeyPut()void"
	pushbytes 0xe9dab493 // method "boxKeyGet()void"
	pushbytes 0x090fdfd6 // method "boxKeyDelete()void"
	pushbytes 0x5ff9d0dd // method "boxKeyExists()void"
	pushbytes 0x17c8206a // method "globalMapPut()void"
	pushbytes 0xcd868bf2 // method "globalMapGet()void"
	pushbytes 0xb55de20c // method "globalMapDelete()void"
	pushbytes 0xc97d8d24 // method "globalMapExists()void"
	pushbytes 0xfc83803c // method "localMapPut(address)void"
	pushbytes 0x9875355d // method "localMapGet(address)void"
	pushbytes 0x742a6e83 // method "localMapDelete(address)void"
	pushbytes 0x88235265 // method "localMapExists(address)void"
	pushbytes 0x84e5681c // method "boxMapPut()void"
	pushbytes 0xae3ce7ee // method "boxMapGet()void"
	pushbytes 0xb9e0ed3d // method "boxMapDelete()void"
	pushbytes 0x652bd5d6 // method "boxMapExists()void"
	pushbytes 0xd36ee315 // method "boxKeyCreate()void"
	pushbytes 0x1029bd07 // method "boxMapCreate()void"
	pushbytes 0xa747b62f // method "boxKeyLength()uint64"
	pushbytes 0x5a1eefbe // method "boxMapLength()uint64"
	pushbytes 0x1337dd60 // method "boxKeyReplace()void"
	pushbytes 0x424ef95a // method "boxMapReplace()void"
	pushbytes 0x88c1c309 // method "boxKeyExtract()string"
	pushbytes 0x43635643 // method "boxMapExtract()string"
	pushbytes 0xab42554e // method "isOptedIn()bool"
	pushbytes 0x0167b7a2 // method "exGlobal()void"
	pushbytes 0xaad51755 // method "exLocal()void"
	pushbytes 0x1b41ce22 // method "accessStaticValueInLargeBox()uint16"
	pushbytes 0xf5da1a55 // method "dynamicAccessStaticValueInLargeBox(uint64)uint16"
	pushbytes 0xbc5c18fd // method "boxResize()void"
	pushbytes 0x25a92329 // method "boxSplice()void"
	pushbytes 0x4ed8699b // method "exStateExists()void"
	txna ApplicationArgs 0
	match *abi_route_prefix *abi_route_globalKeyPut *abi_route_globalKeyGet *abi_route_globalKeyDelete *abi_route_globalKeyExists *abi_route_localKeyPut *abi_route_localKeyGet *abi_route_localKeyDelete *abi_route_localKeyExists *abi_route_boxKeyPut *abi_route_boxKeyGet *abi_route_boxKeyDelete *abi_route_boxKeyExists *abi_route_globalMapPut *abi_route_globalMapGet *abi_route_globalMapDelete *abi_route_globalMapExists *abi_route_localMapPut *abi_route_localMapGet *abi_route_localMapDelete *abi_route_localMapExists *abi_route_boxMapPut *abi_route_boxMapGet *abi_route_boxMapDelete *abi_route_boxMapExists *abi_route_boxKeyCreate *abi_route_boxMapCreate *abi_route_boxKeyLength *abi_route_boxMapLength *abi_route_boxKeyReplace *abi_route_boxMapReplace *abi_route_boxKeyExtract *abi_route_boxMapExtract *abi_route_isOptedIn *abi_route_exGlobal *abi_route_exLocal *abi_route_accessStaticValueInLargeBox *abi_route_dynamicAccessStaticValueInLargeBox *abi_route_boxResize *abi_route_boxSplice *abi_route_exStateExists

	// this contract does not implement the given ABI method for call NoOp
	err", + "approval": "#pragma version 10
intcblock 1 32 1024
bytecblock 0x666f6f 0x6c617267655374617469634172726179496e426f78 0x626172 0x151f7c75 0x616263 0x01c8

// This TEAL was generated by TEALScript v0.105.0
// https://github.com/algorandfoundation/TEALScript

// This contract is compliant with and/or implements the following ARCs: [ ARC4 ]

// The following ten lines of TEAL handle initial program flow
// This pattern is used to make it easy for anyone to parse the start of the program and determine if a specific action is allowed
// Here, action refers to the OnComplete in combination with whether the app is being created or called
// Every possible action for this contract is represented in the switch statement
// If the action is not implemented in the contract, its respective branch will be "*NOT_IMPLEMENTED" which just contains "err"
txn ApplicationID
!
pushint 6
*
txn OnCompletion
+
switch *call_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *create_NoOp *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED *NOT_IMPLEMENTED

*NOT_IMPLEMENTED:
	// The requested action is not implemented in this contract. Are you using the correct OnComplete? Did you set your app ID?
	err

// prefix()void
*abi_route_prefix:
	// execute prefix()void
	callsub prefix
	int 1
	return

// prefix(): void
prefix:
	proto 0 0

	// tests/contracts/storage.algo.ts:26
	// this.boxMapWithPrefix('oo').value = 'bar'
	byte 0x666f6f
	dup
	box_del
	pop
	byte 0x626172 // "bar"
	box_put

	// tests/contracts/storage.algo.ts:27
	// this.globalMapWithPrefix('oo').value = 'bar'
	byte 0x666f6f
	byte 0x626172 // "bar"
	app_global_put

	// tests/contracts/storage.algo.ts:28
	// this.localMapWithPrefix(this.txn.sender, 'oo').value = 'bar'
	txn Sender
	byte 0x666f6f
	byte 0x626172 // "bar"
	app_local_put
	retsub

// globalKeyPut()void
*abi_route_globalKeyPut:
	// execute globalKeyPut()void
	callsub globalKeyPut
	int 1
	return

// globalKeyPut(): void
globalKeyPut:
	proto 0 0

	// tests/contracts/storage.algo.ts:32
	// this.globalKey.value = 'bar'
	byte 0x666f6f // "foo"
	byte 0x626172 // "bar"
	app_global_put
	retsub

// globalKeyGet()void
*abi_route_globalKeyGet:
	// execute globalKeyGet()void
	callsub globalKeyGet
	int 1
	return

// globalKeyGet(): void
globalKeyGet:
	proto 0 0

	// tests/contracts/storage.algo.ts:36
	// assert(this.globalKey.value === 'bar')
	byte 0x666f6f // "foo"
	app_global_get
	byte 0x626172 // "bar"
	==
	assert
	retsub

// globalKeyDelete()void
*abi_route_globalKeyDelete:
	// execute globalKeyDelete()void
	callsub globalKeyDelete
	int 1
	return

// globalKeyDelete(): void
globalKeyDelete:
	proto 0 0

	// tests/contracts/storage.algo.ts:40
	// this.globalKey.delete()
	byte 0x666f6f // "foo"
	app_global_del
	retsub

// globalKeyExists()void
*abi_route_globalKeyExists:
	// execute globalKeyExists()void
	callsub globalKeyExists
	int 1
	return

// globalKeyExists(): void
globalKeyExists:
	proto 0 0

	// tests/contracts/storage.algo.ts:44
	// assert(this.globalKey.exists)
	txna Applications 0
	byte 0x666f6f // "foo"
	app_global_get_ex
	swap
	pop
	assert
	retsub

// localKeyPut(address)void
*abi_route_localKeyPut:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for localKeyPut must be a address
	assert

	// execute localKeyPut(address)void
	callsub localKeyPut
	int 1
	return

// localKeyPut(a: Address): void
localKeyPut:
	proto 1 0

	// tests/contracts/storage.algo.ts:48
	// this.localKey(a).value = 'bar'
	frame_dig -1 // a: Address
	byte 0x666f6f // "foo"
	byte 0x626172 // "bar"
	app_local_put
	retsub

// localKeyGet(address)void
*abi_route_localKeyGet:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for localKeyGet must be a address
	assert

	// execute localKeyGet(address)void
	callsub localKeyGet
	int 1
	return

// localKeyGet(a: Address): void
localKeyGet:
	proto 1 0

	// tests/contracts/storage.algo.ts:52
	// assert(this.localKey(a).value === 'bar')
	frame_dig -1 // a: Address
	byte 0x666f6f // "foo"
	app_local_get
	byte 0x626172 // "bar"
	==
	assert
	retsub

// localKeyDelete(address)void
*abi_route_localKeyDelete:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for localKeyDelete must be a address
	assert

	// execute localKeyDelete(address)void
	callsub localKeyDelete
	int 1
	return

// localKeyDelete(a: Address): void
localKeyDelete:
	proto 1 0

	// tests/contracts/storage.algo.ts:56
	// this.localKey(a).delete()
	frame_dig -1 // a: Address
	byte 0x666f6f // "foo"
	app_local_del
	retsub

// localKeyExists(address)void
*abi_route_localKeyExists:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for localKeyExists must be a address
	assert

	// execute localKeyExists(address)void
	callsub localKeyExists
	int 1
	return

// localKeyExists(a: Address): void
localKeyExists:
	proto 1 0

	// tests/contracts/storage.algo.ts:60
	// assert(this.localKey(a).exists)
	frame_dig -1 // a: Address
	txna Applications 0
	byte 0x666f6f // "foo"
	app_local_get_ex
	swap
	pop
	assert
	retsub

// boxKeyPut()void
*abi_route_boxKeyPut:
	// execute boxKeyPut()void
	callsub boxKeyPut
	int 1
	return

// boxKeyPut(): void
boxKeyPut:
	proto 0 0

	// tests/contracts/storage.algo.ts:64
	// this.boxKey.value = 'bar'
	byte 0x666f6f // "foo"
	byte 0x626172 // "bar"
	box_put
	retsub

// boxKeyGet()void
*abi_route_boxKeyGet:
	// execute boxKeyGet()void
	callsub boxKeyGet
	int 1
	return

// boxKeyGet(): void
boxKeyGet:
	proto 0 0

	// tests/contracts/storage.algo.ts:68
	// assert(this.boxKey.value === 'bar')
	byte 0x666f6f // "foo"
	box_get

	// box value does not exist: this.boxKey.value
	assert
	byte 0x626172 // "bar"
	==
	assert
	retsub

// boxKeyDelete()void
*abi_route_boxKeyDelete:
	// execute boxKeyDelete()void
	callsub boxKeyDelete
	int 1
	return

// boxKeyDelete(): void
boxKeyDelete:
	proto 0 0

	// tests/contracts/storage.algo.ts:72
	// this.boxKey.delete()
	byte 0x666f6f // "foo"
	box_del
	retsub

// boxKeyExists()void
*abi_route_boxKeyExists:
	// execute boxKeyExists()void
	callsub boxKeyExists
	int 1
	return

// boxKeyExists(): void
boxKeyExists:
	proto 0 0

	// tests/contracts/storage.algo.ts:76
	// assert(this.boxKey.exists)
	byte 0x666f6f // "foo"
	box_len
	swap
	pop
	assert
	retsub

// globalMapPut()void
*abi_route_globalMapPut:
	// execute globalMapPut()void
	callsub globalMapPut
	int 1
	return

// globalMapPut(): void
globalMapPut:
	proto 0 0

	// tests/contracts/storage.algo.ts:80
	// this.globalMap('foo').value = 'bar'
	byte 0x666f6f // "foo"
	byte 0x626172 // "bar"
	app_global_put
	retsub

// globalMapGet()void
*abi_route_globalMapGet:
	// execute globalMapGet()void
	callsub globalMapGet
	int 1
	return

// globalMapGet(): void
globalMapGet:
	proto 0 0

	// tests/contracts/storage.algo.ts:84
	// assert(this.globalMap('foo').value === 'bar')
	byte 0x666f6f // "foo"
	app_global_get
	byte 0x626172 // "bar"
	==
	assert
	retsub

// globalMapDelete()void
*abi_route_globalMapDelete:
	// execute globalMapDelete()void
	callsub globalMapDelete
	int 1
	return

// globalMapDelete(): void
globalMapDelete:
	proto 0 0

	// tests/contracts/storage.algo.ts:88
	// this.globalMap('foo').delete()
	byte 0x666f6f // "foo"
	app_global_del
	retsub

// globalMapExists()void
*abi_route_globalMapExists:
	// execute globalMapExists()void
	callsub globalMapExists
	int 1
	return

// globalMapExists(): void
globalMapExists:
	proto 0 0

	// tests/contracts/storage.algo.ts:92
	// assert(this.globalMap('foo').exists)
	txna Applications 0
	byte 0x666f6f // "foo"
	app_global_get_ex
	swap
	pop
	assert
	retsub

// localMapPut(address)void
*abi_route_localMapPut:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for localMapPut must be a address
	assert

	// execute localMapPut(address)void
	callsub localMapPut
	int 1
	return

// localMapPut(a: Address): void
localMapPut:
	proto 1 0

	// tests/contracts/storage.algo.ts:96
	// this.localMap(a, 'foo').value = 'bar'
	frame_dig -1 // a: Address
	byte 0x666f6f // "foo"
	byte 0x626172 // "bar"
	app_local_put
	retsub

// localMapGet(address)void
*abi_route_localMapGet:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for localMapGet must be a address
	assert

	// execute localMapGet(address)void
	callsub localMapGet
	int 1
	return

// localMapGet(a: Address): void
localMapGet:
	proto 1 0

	// tests/contracts/storage.algo.ts:100
	// assert(this.localMap(a, 'foo').value === 'bar')
	frame_dig -1 // a: Address
	byte 0x666f6f // "foo"
	app_local_get
	byte 0x626172 // "bar"
	==
	assert
	retsub

// localMapDelete(address)void
*abi_route_localMapDelete:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for localMapDelete must be a address
	assert

	// execute localMapDelete(address)void
	callsub localMapDelete
	int 1
	return

// localMapDelete(a: Address): void
localMapDelete:
	proto 1 0

	// tests/contracts/storage.algo.ts:104
	// this.localMap(a, 'foo').delete()
	frame_dig -1 // a: Address
	byte 0x666f6f // "foo"
	app_local_del
	retsub

// localMapExists(address)void
*abi_route_localMapExists:
	// a: address
	txna ApplicationArgs 1
	dup
	len
	int 32
	==

	// argument 0 (a) for localMapExists must be a address
	assert

	// execute localMapExists(address)void
	callsub localMapExists
	int 1
	return

// localMapExists(a: Address): void
localMapExists:
	proto 1 0

	// tests/contracts/storage.algo.ts:108
	// assert(this.localMap(a, 'foo').exists)
	frame_dig -1 // a: Address
	txna Applications 0
	byte 0x666f6f // "foo"
	app_local_get_ex
	swap
	pop
	assert
	retsub

// boxMapPut()void
*abi_route_boxMapPut:
	// execute boxMapPut()void
	callsub boxMapPut
	int 1
	return

// boxMapPut(): void
boxMapPut:
	proto 0 0

	// tests/contracts/storage.algo.ts:112
	// this.boxMap('foo').value = 'bar'
	byte 0x666f6f // "foo"
	byte 0x626172 // "bar"
	box_put
	retsub

// boxMapGet()void
*abi_route_boxMapGet:
	// execute boxMapGet()void
	callsub boxMapGet
	int 1
	return

// boxMapGet(): void
boxMapGet:
	proto 0 0

	// tests/contracts/storage.algo.ts:116
	// assert(this.boxMap('foo').value === 'bar')
	byte 0x666f6f // "foo"
	box_get

	// box value does not exist: this.boxMap('foo').value
	assert
	byte 0x626172 // "bar"
	==
	assert
	retsub

// boxMapDelete()void
*abi_route_boxMapDelete:
	// execute boxMapDelete()void
	callsub boxMapDelete
	int 1
	return

// boxMapDelete(): void
boxMapDelete:
	proto 0 0

	// tests/contracts/storage.algo.ts:120
	// this.boxMap('foo').delete()
	byte 0x666f6f // "foo"
	box_del
	retsub

// boxMapExists()void
*abi_route_boxMapExists:
	// execute boxMapExists()void
	callsub boxMapExists
	int 1
	return

// boxMapExists(): void
boxMapExists:
	proto 0 0

	// tests/contracts/storage.algo.ts:124
	// assert(this.boxMap('foo').exists)
	byte 0x666f6f // "foo"
	box_len
	swap
	pop
	assert
	retsub

// boxKeyCreate()void
*abi_route_boxKeyCreate:
	// execute boxKeyCreate()void
	callsub boxKeyCreate
	int 1
	return

// boxKeyCreate(): void
boxKeyCreate:
	proto 0 0

	// tests/contracts/storage.algo.ts:128
	// this.boxKey.create(1024)
	byte 0x666f6f // "foo"
	int 1024
	box_create
	pop
	retsub

// boxMapCreate()void
*abi_route_boxMapCreate:
	// execute boxMapCreate()void
	callsub boxMapCreate
	int 1
	return

// boxMapCreate(): void
boxMapCreate:
	proto 0 0

	// tests/contracts/storage.algo.ts:132
	// this.boxMap('bar').create(1024)
	byte 0x626172 // "bar"
	int 1024
	box_create
	pop
	retsub

// boxKeyLength()uint64
*abi_route_boxKeyLength:
	// The ABI return prefix
	byte 0x151f7c75

	// execute boxKeyLength()uint64
	callsub boxKeyLength
	itob
	concat
	log
	int 1
	return

// boxKeyLength(): uint64
boxKeyLength:
	proto 0 1

	// tests/contracts/storage.algo.ts:136
	// return this.boxKey.size;
	byte 0x666f6f // "foo"
	box_len

	// box value does not exist: this.boxKey.size
	assert
	retsub

// boxMapLength()uint64
*abi_route_boxMapLength:
	// The ABI return prefix
	byte 0x151f7c75

	// execute boxMapLength()uint64
	callsub boxMapLength
	itob
	concat
	log
	int 1
	return

// boxMapLength(): uint64
boxMapLength:
	proto 0 1

	// tests/contracts/storage.algo.ts:140
	// return this.boxMap('bar').size;
	byte 0x626172 // "bar"
	box_len

	// box value does not exist: this.boxMap('bar').size
	assert
	retsub

// boxKeyReplace()void
*abi_route_boxKeyReplace:
	// execute boxKeyReplace()void
	callsub boxKeyReplace
	int 1
	return

// boxKeyReplace(): void
boxKeyReplace:
	proto 0 0

	// tests/contracts/storage.algo.ts:144
	// this.boxKey.replace(0, 'abc')
	byte 0x666f6f // "foo"
	pushint 0
	byte 0x616263 // "abc"
	box_replace
	retsub

// boxMapReplace()void
*abi_route_boxMapReplace:
	// execute boxMapReplace()void
	callsub boxMapReplace
	int 1
	return

// boxMapReplace(): void
boxMapReplace:
	proto 0 0

	// tests/contracts/storage.algo.ts:148
	// this.boxMap('bar').replace(0, 'abc')
	byte 0x626172 // "bar"
	pushint 0
	byte 0x616263 // "abc"
	box_replace
	retsub

// boxKeyExtract()string
*abi_route_boxKeyExtract:
	// The ABI return prefix
	byte 0x151f7c75

	// execute boxKeyExtract()string
	callsub boxKeyExtract
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// boxKeyExtract(): string
boxKeyExtract:
	proto 0 1

	// tests/contracts/storage.algo.ts:152
	// return this.boxKey.extract(0, 3);
	byte 0x666f6f // "foo"
	pushint 0
	pushint 3
	box_extract
	retsub

// boxMapExtract()string
*abi_route_boxMapExtract:
	// The ABI return prefix
	byte 0x151f7c75

	// execute boxMapExtract()string
	callsub boxMapExtract
	dup
	len
	itob
	extract 6 2
	swap
	concat
	concat
	log
	int 1
	return

// boxMapExtract(): string
boxMapExtract:
	proto 0 1

	// tests/contracts/storage.algo.ts:156
	// return this.boxMap('bar').extract(0, 3);
	byte 0x626172 // "bar"
	pushint 0
	pushint 3
	box_extract
	retsub

// isOptedIn()bool
*abi_route_isOptedIn:
	// The ABI return prefix
	byte 0x151f7c75

	// execute isOptedIn()bool
	callsub isOptedIn
	pushbytes 0x00
	pushint 0
	uncover 2
	setbit
	concat
	log
	int 1
	return

// isOptedIn(): boolean
isOptedIn:
	proto 0 1

	// tests/contracts/storage.algo.ts:160
	// return this.txn.sender.isOptedInToApp(this.app);
	txn Sender
	txna Applications 0
	app_opted_in
	retsub

// exGlobal()void
*abi_route_exGlobal:
	// execute exGlobal()void
	callsub exGlobal
	int 1
	return

// exGlobal(): void
exGlobal:
	proto 0 0

	// tests/contracts/storage.algo.ts:164
	// log(this.app.globalState('foo') as bytes)
	txna Applications 0
	byte 0x666f6f // "foo"
	app_global_get_ex

	// global state value does not exist: this.app.globalState('foo')
	assert
	log
	retsub

// exLocal()void
*abi_route_exLocal:
	// execute exLocal()void
	callsub exLocal
	int 1
	return

// exLocal(): void
exLocal:
	proto 0 0

	// tests/contracts/storage.algo.ts:168
	// log(this.app.localState(this.txn.sender, 'foo') as bytes)
	txn Sender
	txna Applications 0
	byte 0x666f6f // "foo"
	app_local_get_ex

	// local state value does not exist: this.app.localState(this.txn.sender, 'foo')
	assert
	log
	retsub

// accessStaticValueInLargeBox()uint16
*abi_route_accessStaticValueInLargeBox:
	// The ABI return prefix
	byte 0x151f7c75

	// execute accessStaticValueInLargeBox()uint16
	callsub accessStaticValueInLargeBox
	itob
	dup
	bitlen
	pushint 16
	<=

	// accessStaticValueInLargeBox return value overflowed 16 bits
	assert
	extract 6 2
	concat
	log
	int 1
	return

// accessStaticValueInLargeBox(): uint16
accessStaticValueInLargeBox:
	proto 0 1

	// tests/contracts/storage.algo.ts:172
	// this.largeStaticArrayInBox.create()
	byte 0x6c617267655374617469634172726179496e426f78 // "largeStaticArrayInBox"
	pushint 8000
	box_create
	pop

	// tests/contracts/storage.algo.ts:173
	// this.largeStaticArrayInBox.value[123] = 456
	byte 0x6c617267655374617469634172726179496e426f78 // "largeStaticArrayInBox"
	pushint 246
	byte 0x01c8
	box_replace

	// tests/contracts/storage.algo.ts:175
	// return this.largeStaticArrayInBox.value[123];
	byte 0x6c617267655374617469634172726179496e426f78 // "largeStaticArrayInBox"
	pushint 246
	pushint 2
	box_extract
	btoi
	retsub

// dynamicAccessStaticValueInLargeBox(uint64)uint16
*abi_route_dynamicAccessStaticValueInLargeBox:
	// The ABI return prefix
	byte 0x151f7c75

	// i: uint64
	txna ApplicationArgs 1
	btoi

	// execute dynamicAccessStaticValueInLargeBox(uint64)uint16
	callsub dynamicAccessStaticValueInLargeBox
	itob
	dup
	bitlen
	pushint 16
	<=

	// dynamicAccessStaticValueInLargeBox return value overflowed 16 bits
	assert
	extract 6 2
	concat
	log
	int 1
	return

// dynamicAccessStaticValueInLargeBox(i: uint64): uint16
dynamicAccessStaticValueInLargeBox:
	proto 1 1

	// tests/contracts/storage.algo.ts:179
	// this.largeStaticArrayInBox.create()
	byte 0x6c617267655374617469634172726179496e426f78 // "largeStaticArrayInBox"
	pushint 8000
	box_create
	pop

	// tests/contracts/storage.algo.ts:180
	// this.largeStaticArrayInBox.value[i] = 456
	frame_dig -1 // i: uint64
	pushint 2
	* // acc * typeLength
	byte 0x01c8
	byte 0x6c617267655374617469634172726179496e426f78 // "largeStaticArrayInBox"
	cover 2
	box_replace

	// tests/contracts/storage.algo.ts:184
	// return a[i];
	frame_dig -1 // i: uint64
	pushint 2
	* // acc * typeLength
	pushint 2
	byte 0x6c617267655374617469634172726179496e426f78 // "largeStaticArrayInBox"
	cover 2
	box_extract
	btoi
	retsub

// boxResize()void
*abi_route_boxResize:
	// execute boxResize()void
	callsub boxResize
	int 1
	return

// boxResize(): void
boxResize:
	proto 0 0

	// tests/contracts/storage.algo.ts:188
	// this.boxKey.resize(1024)
	byte 0x666f6f // "foo"
	int 1024
	box_resize

	// tests/contracts/storage.algo.ts:189
	// this.boxMap('bar').resize(1024)
	byte 0x626172 // "bar"
	int 1024
	box_resize
	retsub

// boxSplice()void
*abi_route_boxSplice:
	// execute boxSplice()void
	callsub boxSplice
	int 1
	return

// boxSplice(): void
boxSplice:
	proto 0 0

	// tests/contracts/storage.algo.ts:193
	// this.boxKey.splice(0, 1, 'abc')
	byte 0x666f6f // "foo"
	pushint 0
	int 1
	byte 0x616263 // "abc"
	box_splice

	// tests/contracts/storage.algo.ts:194
	// this.boxMap('bar').splice(0, 1, 'abc')
	byte 0x626172 // "bar"
	pushint 0
	int 1
	byte 0x616263 // "abc"
	box_splice
	retsub

// exStateExists()void
*abi_route_exStateExists:
	// execute exStateExists()void
	callsub exStateExists
	int 1
	return

// exStateExists(): void
exStateExists:
	proto 0 0

	// tests/contracts/storage.algo.ts:198
	// assert(this.app.globalStateExists('foo'))
	txna Applications 0
	byte 0x666f6f // "foo"
	app_global_get_ex
	swap
	pop
	assert

	// tests/contracts/storage.algo.ts:199
	// assert(this.app.localStateExists(this.txn.sender, 'foo'))
	txn Sender
	txna Applications 0
	byte 0x666f6f // "foo"
	app_local_get_ex
	swap
	pop
	assert
	retsub

*abi_route_createApplication:
	int 1
	return

*create_NoOp:
	pushbytes 0xb8447b36 // method "createApplication()void"
	txna ApplicationArgs 0
	match *abi_route_createApplication

	// this contract does not implement the given ABI method for create NoOp
	err

*call_NoOp:
	pushbytes 0x5b02ba87 // method "prefix()void"
	pushbytes 0x47826307 // method "globalKeyPut()void"
	pushbytes 0xd387cd2c // method "globalKeyGet()void"
	pushbytes 0x2f78db03 // method "globalKeyDelete()void"
	pushbytes 0xd8181a9a // method "globalKeyExists()void"
	pushbytes 0xecb06998 // method "localKeyPut(address)void"
	pushbytes 0x56dace1d // method "localKeyGet(address)void"
	pushbytes 0x768c8c68 // method "localKeyDelete(address)void"
	pushbytes 0xbc0ea6bb // method "localKeyExists(address)void"
	pushbytes 0xcf48ae4d // method "boxKeyPut()void"
	pushbytes 0xe9dab493 // method "boxKeyGet()void"
	pushbytes 0x090fdfd6 // method "boxKeyDelete()void"
	pushbytes 0x5ff9d0dd // method "boxKeyExists()void"
	pushbytes 0x17c8206a // method "globalMapPut()void"
	pushbytes 0xcd868bf2 // method "globalMapGet()void"
	pushbytes 0xb55de20c // method "globalMapDelete()void"
	pushbytes 0xc97d8d24 // method "globalMapExists()void"
	pushbytes 0xfc83803c // method "localMapPut(address)void"
	pushbytes 0x9875355d // method "localMapGet(address)void"
	pushbytes 0x742a6e83 // method "localMapDelete(address)void"
	pushbytes 0x88235265 // method "localMapExists(address)void"
	pushbytes 0x84e5681c // method "boxMapPut()void"
	pushbytes 0xae3ce7ee // method "boxMapGet()void"
	pushbytes 0xb9e0ed3d // method "boxMapDelete()void"
	pushbytes 0x652bd5d6 // method "boxMapExists()void"
	pushbytes 0xd36ee315 // method "boxKeyCreate()void"
	pushbytes 0x1029bd07 // method "boxMapCreate()void"
	pushbytes 0xa747b62f // method "boxKeyLength()uint64"
	pushbytes 0x5a1eefbe // method "boxMapLength()uint64"
	pushbytes 0x1337dd60 // method "boxKeyReplace()void"
	pushbytes 0x424ef95a // method "boxMapReplace()void"
	pushbytes 0x88c1c309 // method "boxKeyExtract()string"
	pushbytes 0x43635643 // method "boxMapExtract()string"
	pushbytes 0xab42554e // method "isOptedIn()bool"
	pushbytes 0x0167b7a2 // method "exGlobal()void"
	pushbytes 0xaad51755 // method "exLocal()void"
	pushbytes 0x1b41ce22 // method "accessStaticValueInLargeBox()uint16"
	pushbytes 0xf5da1a55 // method "dynamicAccessStaticValueInLargeBox(uint64)uint16"
	pushbytes 0xbc5c18fd // method "boxResize()void"
	pushbytes 0x25a92329 // method "boxSplice()void"
	pushbytes 0x4ed8699b // method "exStateExists()void"
	txna ApplicationArgs 0
	match *abi_route_prefix *abi_route_globalKeyPut *abi_route_globalKeyGet *abi_route_globalKeyDelete *abi_route_globalKeyExists *abi_route_localKeyPut *abi_route_localKeyGet *abi_route_localKeyDelete *abi_route_localKeyExists *abi_route_boxKeyPut *abi_route_boxKeyGet *abi_route_boxKeyDelete *abi_route_boxKeyExists *abi_route_globalMapPut *abi_route_globalMapGet *abi_route_globalMapDelete *abi_route_globalMapExists *abi_route_localMapPut *abi_route_localMapGet *abi_route_localMapDelete *abi_route_localMapExists *abi_route_boxMapPut *abi_route_boxMapGet *abi_route_boxMapDelete *abi_route_boxMapExists *abi_route_boxKeyCreate *abi_route_boxMapCreate *abi_route_boxKeyLength *abi_route_boxMapLength *abi_route_boxKeyReplace *abi_route_boxMapReplace *abi_route_boxKeyExtract *abi_route_boxMapExtract *abi_route_isOptedIn *abi_route_exGlobal *abi_route_exLocal *abi_route_accessStaticValueInLargeBox *abi_route_dynamicAccessStaticValueInLargeBox *abi_route_boxResize *abi_route_boxSplice *abi_route_exStateExists

	// this contract does not implement the given ABI method for call NoOp
	err", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "byteCode": { diff --git a/tests/contracts/artifacts/Templates.approval.teal b/tests/contracts/artifacts/Templates.approval.teal index 2ed100205..199604377 100644 --- a/tests/contracts/artifacts/Templates.approval.teal +++ b/tests/contracts/artifacts/Templates.approval.teal @@ -2,7 +2,7 @@ intcblock TMPL_uint64TmplVar bytecblock TMPL_bytes64TmplVar TMPL_bytes32TmplVar TMPL_bytesTmplVar -// This TEAL was generated by TEALScript v0.104.1 +// This TEAL was generated by TEALScript v0.105.0 // https://github.com/algorandfoundation/TEALScript // This contract is compliant with and/or implements the following ARCs: [ ARC4 ] diff --git a/tests/contracts/artifacts/Templates.arc32.json b/tests/contracts/artifacts/Templates.arc32.json index 196c6dd97..c08fad7d3 100644 --- a/tests/contracts/artifacts/Templates.arc32.json +++ b/tests/contracts/artifacts/Templates.arc32.json @@ -54,7 +54,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmludGNibG9jayBUTVBMX3VpbnQ2NFRtcGxWYXIKYnl0ZWNibG9jayBUTVBMX2J5dGVzNjRUbXBsVmFyIFRNUExfYnl0ZXMzMlRtcGxWYXIgVE1QTF9ieXRlc1RtcGxWYXIKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgbGluZXMgb2YgVEVBTCBhcmUgdXNlZCB0byBpbml0aWFsaXplIHRlbXBsYXRlIHZhcmlhYmxlcyBpbiBzY3JhdGNoIHNsb3RzCmJ5dGVjIDAgLy8gVE1QTF9ieXRlczY0VG1wbFZhcgpieXRlYyAxIC8vIFRNUExfYnl0ZXMzMlRtcGxWYXIKaW50YyAwIC8vIFRNUExfdWludDY0VG1wbFZhcgpieXRlYyAyIC8vIFRNUExfYnl0ZXNUbXBsVmFyCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdG1wbCgpdm9pZAoqYWJpX3JvdXRlX3RtcGw6CgkvLyBleGVjdXRlIHRtcGwoKXZvaWQKCWNhbGxzdWIgdG1wbAoJcHVzaGludCAxCglyZXR1cm4KCi8vIHRtcGwoKTogdm9pZAp0bXBsOgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2dlbmVyYWwuYWxnby50czozNAoJLy8gbG9nKHRoaXMuYnl0ZXNUbXBsVmFyKQoJYnl0ZWMgMiAvLyBUTVBMX2J5dGVzVG1wbFZhcgoJbG9nCgoJLy8gdGVzdHMvY29udHJhY3RzL2dlbmVyYWwuYWxnby50czozNQoJLy8gYXNzZXJ0KHRoaXMudWludDY0VG1wbFZhcikKCWludGMgMCAvLyBUTVBMX3VpbnQ2NFRtcGxWYXIKCWFzc2VydAoJcmV0c3ViCgovLyBzcGVjaWZpY0xlbmd0aFRlbXBsYXRlVmFyKCl2b2lkCiphYmlfcm91dGVfc3BlY2lmaWNMZW5ndGhUZW1wbGF0ZVZhcjoKCS8vIGV4ZWN1dGUgc3BlY2lmaWNMZW5ndGhUZW1wbGF0ZVZhcigpdm9pZAoJY2FsbHN1YiBzcGVjaWZpY0xlbmd0aFRlbXBsYXRlVmFyCglwdXNoaW50IDEKCXJldHVybgoKLy8gc3BlY2lmaWNMZW5ndGhUZW1wbGF0ZVZhcigpOiB2b2lkCnNwZWNpZmljTGVuZ3RoVGVtcGxhdGVWYXI6Cglwcm90byAwIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvZ2VuZXJhbC5hbGdvLnRzOjM5CgkvLyBlZDI1NTE5VmVyaWZ5QmFyZSh0aGlzLmJ5dGVzVG1wbFZhciwgdGhpcy5ieXRlczY0VG1wbFZhciwgdGhpcy5ieXRlczMyVG1wbFZhcikKCWJ5dGVjIDIgLy8gVE1QTF9ieXRlc1RtcGxWYXIKCWJ5dGVjIDAgLy8gVE1QTF9ieXRlczY0VG1wbFZhcgoJYnl0ZWMgMSAvLyBUTVBMX2J5dGVzMzJUbXBsVmFyCgllZDI1NTE5dmVyaWZ5X2JhcmUKCXJldHN1YgoKLy8gdGhyb3dFcnJvcigpdm9pZAoqYWJpX3JvdXRlX3Rocm93RXJyb3I6CgkvLyBleGVjdXRlIHRocm93RXJyb3IoKXZvaWQKCWNhbGxzdWIgdGhyb3dFcnJvcgoJcHVzaGludCAxCglyZXR1cm4KCi8vIHRocm93RXJyb3IoKTogdm9pZAp0aHJvd0Vycm9yOgoJcHJvdG8gMCAwCgoJLy8gdGhpcyBpcyBhbiBlcnJvcgoJZXJyCglyZXRzdWIKCi8vIGl0b2JUZW1wbGF0ZVZhcigpYnl0ZVtdCiphYmlfcm91dGVfaXRvYlRlbXBsYXRlVmFyOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgaXRvYlRlbXBsYXRlVmFyKClieXRlW10KCWNhbGxzdWIgaXRvYlRlbXBsYXRlVmFyCglkdXAKCWxlbgoJaXRvYgoJZXh0cmFjdCA2IDIKCXN3YXAKCWNvbmNhdAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBpdG9iVGVtcGxhdGVWYXIoKTogYnl0ZXMKaXRvYlRlbXBsYXRlVmFyOgoJcHJvdG8gMCAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2dlbmVyYWwuYWxnby50czo0NwoJLy8gcmV0dXJuIGl0b2IodGhpcy51aW50NjRUbXBsVmFyKTsKCWludGMgMCAvLyBUTVBMX3VpbnQ2NFRtcGxWYXIKCWl0b2IKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4OWE3MWQyYjQgLy8gbWV0aG9kICJ0bXBsKCl2b2lkIgoJcHVzaGJ5dGVzIDB4ZGY0ZDVjM2IgLy8gbWV0aG9kICJzcGVjaWZpY0xlbmd0aFRlbXBsYXRlVmFyKCl2b2lkIgoJcHVzaGJ5dGVzIDB4M2Q4NzBkODcgLy8gbWV0aG9kICJ0aHJvd0Vycm9yKCl2b2lkIgoJcHVzaGJ5dGVzIDB4YmMwYjE3MDYgLy8gbWV0aG9kICJpdG9iVGVtcGxhdGVWYXIoKWJ5dGVbXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfdG1wbCAqYWJpX3JvdXRlX3NwZWNpZmljTGVuZ3RoVGVtcGxhdGVWYXIgKmFiaV9yb3V0ZV90aHJvd0Vycm9yICphYmlfcm91dGVfaXRvYlRlbXBsYXRlVmFyCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmludGNibG9jayBUTVBMX3VpbnQ2NFRtcGxWYXIKYnl0ZWNibG9jayBUTVBMX2J5dGVzNjRUbXBsVmFyIFRNUExfYnl0ZXMzMlRtcGxWYXIgVE1QTF9ieXRlc1RtcGxWYXIKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgbGluZXMgb2YgVEVBTCBhcmUgdXNlZCB0byBpbml0aWFsaXplIHRlbXBsYXRlIHZhcmlhYmxlcyBpbiBzY3JhdGNoIHNsb3RzCmJ5dGVjIDAgLy8gVE1QTF9ieXRlczY0VG1wbFZhcgpieXRlYyAxIC8vIFRNUExfYnl0ZXMzMlRtcGxWYXIKaW50YyAwIC8vIFRNUExfdWludDY0VG1wbFZhcgpieXRlYyAyIC8vIFRNUExfYnl0ZXNUbXBsVmFyCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdG1wbCgpdm9pZAoqYWJpX3JvdXRlX3RtcGw6CgkvLyBleGVjdXRlIHRtcGwoKXZvaWQKCWNhbGxzdWIgdG1wbAoJcHVzaGludCAxCglyZXR1cm4KCi8vIHRtcGwoKTogdm9pZAp0bXBsOgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2dlbmVyYWwuYWxnby50czozNAoJLy8gbG9nKHRoaXMuYnl0ZXNUbXBsVmFyKQoJYnl0ZWMgMiAvLyBUTVBMX2J5dGVzVG1wbFZhcgoJbG9nCgoJLy8gdGVzdHMvY29udHJhY3RzL2dlbmVyYWwuYWxnby50czozNQoJLy8gYXNzZXJ0KHRoaXMudWludDY0VG1wbFZhcikKCWludGMgMCAvLyBUTVBMX3VpbnQ2NFRtcGxWYXIKCWFzc2VydAoJcmV0c3ViCgovLyBzcGVjaWZpY0xlbmd0aFRlbXBsYXRlVmFyKCl2b2lkCiphYmlfcm91dGVfc3BlY2lmaWNMZW5ndGhUZW1wbGF0ZVZhcjoKCS8vIGV4ZWN1dGUgc3BlY2lmaWNMZW5ndGhUZW1wbGF0ZVZhcigpdm9pZAoJY2FsbHN1YiBzcGVjaWZpY0xlbmd0aFRlbXBsYXRlVmFyCglwdXNoaW50IDEKCXJldHVybgoKLy8gc3BlY2lmaWNMZW5ndGhUZW1wbGF0ZVZhcigpOiB2b2lkCnNwZWNpZmljTGVuZ3RoVGVtcGxhdGVWYXI6Cglwcm90byAwIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvZ2VuZXJhbC5hbGdvLnRzOjM5CgkvLyBlZDI1NTE5VmVyaWZ5QmFyZSh0aGlzLmJ5dGVzVG1wbFZhciwgdGhpcy5ieXRlczY0VG1wbFZhciwgdGhpcy5ieXRlczMyVG1wbFZhcikKCWJ5dGVjIDIgLy8gVE1QTF9ieXRlc1RtcGxWYXIKCWJ5dGVjIDAgLy8gVE1QTF9ieXRlczY0VG1wbFZhcgoJYnl0ZWMgMSAvLyBUTVBMX2J5dGVzMzJUbXBsVmFyCgllZDI1NTE5dmVyaWZ5X2JhcmUKCXJldHN1YgoKLy8gdGhyb3dFcnJvcigpdm9pZAoqYWJpX3JvdXRlX3Rocm93RXJyb3I6CgkvLyBleGVjdXRlIHRocm93RXJyb3IoKXZvaWQKCWNhbGxzdWIgdGhyb3dFcnJvcgoJcHVzaGludCAxCglyZXR1cm4KCi8vIHRocm93RXJyb3IoKTogdm9pZAp0aHJvd0Vycm9yOgoJcHJvdG8gMCAwCgoJLy8gdGhpcyBpcyBhbiBlcnJvcgoJZXJyCglyZXRzdWIKCi8vIGl0b2JUZW1wbGF0ZVZhcigpYnl0ZVtdCiphYmlfcm91dGVfaXRvYlRlbXBsYXRlVmFyOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgaXRvYlRlbXBsYXRlVmFyKClieXRlW10KCWNhbGxzdWIgaXRvYlRlbXBsYXRlVmFyCglkdXAKCWxlbgoJaXRvYgoJZXh0cmFjdCA2IDIKCXN3YXAKCWNvbmNhdAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBpdG9iVGVtcGxhdGVWYXIoKTogYnl0ZXMKaXRvYlRlbXBsYXRlVmFyOgoJcHJvdG8gMCAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2dlbmVyYWwuYWxnby50czo0NwoJLy8gcmV0dXJuIGl0b2IodGhpcy51aW50NjRUbXBsVmFyKTsKCWludGMgMCAvLyBUTVBMX3VpbnQ2NFRtcGxWYXIKCWl0b2IKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4OWE3MWQyYjQgLy8gbWV0aG9kICJ0bXBsKCl2b2lkIgoJcHVzaGJ5dGVzIDB4ZGY0ZDVjM2IgLy8gbWV0aG9kICJzcGVjaWZpY0xlbmd0aFRlbXBsYXRlVmFyKCl2b2lkIgoJcHVzaGJ5dGVzIDB4M2Q4NzBkODcgLy8gbWV0aG9kICJ0aHJvd0Vycm9yKCl2b2lkIgoJcHVzaGJ5dGVzIDB4YmMwYjE3MDYgLy8gbWV0aG9kICJpdG9iVGVtcGxhdGVWYXIoKWJ5dGVbXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfdG1wbCAqYWJpX3JvdXRlX3NwZWNpZmljTGVuZ3RoVGVtcGxhdGVWYXIgKmFiaV9yb3V0ZV90aHJvd0Vycm9yICphYmlfcm91dGVfaXRvYlRlbXBsYXRlVmFyCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "contract": { diff --git a/tests/contracts/artifacts/Templates.arc56_draft.json b/tests/contracts/artifacts/Templates.arc56_draft.json index 72a5f3930..71440604c 100644 --- a/tests/contracts/artifacts/Templates.arc56_draft.json +++ b/tests/contracts/artifacts/Templates.arc56_draft.json @@ -667,7 +667,7 @@ } }, "source": { - "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmludGNibG9jayBUTVBMX3VpbnQ2NFRtcGxWYXIKYnl0ZWNibG9jayBUTVBMX2J5dGVzNjRUbXBsVmFyIFRNUExfYnl0ZXMzMlRtcGxWYXIgVE1QTF9ieXRlc1RtcGxWYXIKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA0LjEKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgbGluZXMgb2YgVEVBTCBhcmUgdXNlZCB0byBpbml0aWFsaXplIHRlbXBsYXRlIHZhcmlhYmxlcyBpbiBzY3JhdGNoIHNsb3RzCmJ5dGVjIDAgLy8gVE1QTF9ieXRlczY0VG1wbFZhcgpieXRlYyAxIC8vIFRNUExfYnl0ZXMzMlRtcGxWYXIKaW50YyAwIC8vIFRNUExfdWludDY0VG1wbFZhcgpieXRlYyAyIC8vIFRNUExfYnl0ZXNUbXBsVmFyCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdG1wbCgpdm9pZAoqYWJpX3JvdXRlX3RtcGw6CgkvLyBleGVjdXRlIHRtcGwoKXZvaWQKCWNhbGxzdWIgdG1wbAoJcHVzaGludCAxCglyZXR1cm4KCi8vIHRtcGwoKTogdm9pZAp0bXBsOgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2dlbmVyYWwuYWxnby50czozNAoJLy8gbG9nKHRoaXMuYnl0ZXNUbXBsVmFyKQoJYnl0ZWMgMiAvLyBUTVBMX2J5dGVzVG1wbFZhcgoJbG9nCgoJLy8gdGVzdHMvY29udHJhY3RzL2dlbmVyYWwuYWxnby50czozNQoJLy8gYXNzZXJ0KHRoaXMudWludDY0VG1wbFZhcikKCWludGMgMCAvLyBUTVBMX3VpbnQ2NFRtcGxWYXIKCWFzc2VydAoJcmV0c3ViCgovLyBzcGVjaWZpY0xlbmd0aFRlbXBsYXRlVmFyKCl2b2lkCiphYmlfcm91dGVfc3BlY2lmaWNMZW5ndGhUZW1wbGF0ZVZhcjoKCS8vIGV4ZWN1dGUgc3BlY2lmaWNMZW5ndGhUZW1wbGF0ZVZhcigpdm9pZAoJY2FsbHN1YiBzcGVjaWZpY0xlbmd0aFRlbXBsYXRlVmFyCglwdXNoaW50IDEKCXJldHVybgoKLy8gc3BlY2lmaWNMZW5ndGhUZW1wbGF0ZVZhcigpOiB2b2lkCnNwZWNpZmljTGVuZ3RoVGVtcGxhdGVWYXI6Cglwcm90byAwIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvZ2VuZXJhbC5hbGdvLnRzOjM5CgkvLyBlZDI1NTE5VmVyaWZ5QmFyZSh0aGlzLmJ5dGVzVG1wbFZhciwgdGhpcy5ieXRlczY0VG1wbFZhciwgdGhpcy5ieXRlczMyVG1wbFZhcikKCWJ5dGVjIDIgLy8gVE1QTF9ieXRlc1RtcGxWYXIKCWJ5dGVjIDAgLy8gVE1QTF9ieXRlczY0VG1wbFZhcgoJYnl0ZWMgMSAvLyBUTVBMX2J5dGVzMzJUbXBsVmFyCgllZDI1NTE5dmVyaWZ5X2JhcmUKCXJldHN1YgoKLy8gdGhyb3dFcnJvcigpdm9pZAoqYWJpX3JvdXRlX3Rocm93RXJyb3I6CgkvLyBleGVjdXRlIHRocm93RXJyb3IoKXZvaWQKCWNhbGxzdWIgdGhyb3dFcnJvcgoJcHVzaGludCAxCglyZXR1cm4KCi8vIHRocm93RXJyb3IoKTogdm9pZAp0aHJvd0Vycm9yOgoJcHJvdG8gMCAwCgoJLy8gdGhpcyBpcyBhbiBlcnJvcgoJZXJyCglyZXRzdWIKCi8vIGl0b2JUZW1wbGF0ZVZhcigpYnl0ZVtdCiphYmlfcm91dGVfaXRvYlRlbXBsYXRlVmFyOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgaXRvYlRlbXBsYXRlVmFyKClieXRlW10KCWNhbGxzdWIgaXRvYlRlbXBsYXRlVmFyCglkdXAKCWxlbgoJaXRvYgoJZXh0cmFjdCA2IDIKCXN3YXAKCWNvbmNhdAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBpdG9iVGVtcGxhdGVWYXIoKTogYnl0ZXMKaXRvYlRlbXBsYXRlVmFyOgoJcHJvdG8gMCAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2dlbmVyYWwuYWxnby50czo0NwoJLy8gcmV0dXJuIGl0b2IodGhpcy51aW50NjRUbXBsVmFyKTsKCWludGMgMCAvLyBUTVBMX3VpbnQ2NFRtcGxWYXIKCWl0b2IKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4OWE3MWQyYjQgLy8gbWV0aG9kICJ0bXBsKCl2b2lkIgoJcHVzaGJ5dGVzIDB4ZGY0ZDVjM2IgLy8gbWV0aG9kICJzcGVjaWZpY0xlbmd0aFRlbXBsYXRlVmFyKCl2b2lkIgoJcHVzaGJ5dGVzIDB4M2Q4NzBkODcgLy8gbWV0aG9kICJ0aHJvd0Vycm9yKCl2b2lkIgoJcHVzaGJ5dGVzIDB4YmMwYjE3MDYgLy8gbWV0aG9kICJpdG9iVGVtcGxhdGVWYXIoKWJ5dGVbXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfdG1wbCAqYWJpX3JvdXRlX3NwZWNpZmljTGVuZ3RoVGVtcGxhdGVWYXIgKmFiaV9yb3V0ZV90aHJvd0Vycm9yICphYmlfcm91dGVfaXRvYlRlbXBsYXRlVmFyCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", + "approval": "I3ByYWdtYSB2ZXJzaW9uIDEwCmludGNibG9jayBUTVBMX3VpbnQ2NFRtcGxWYXIKYnl0ZWNibG9jayBUTVBMX2J5dGVzNjRUbXBsVmFyIFRNUExfYnl0ZXMzMlRtcGxWYXIgVE1QTF9ieXRlc1RtcGxWYXIKCi8vIFRoaXMgVEVBTCB3YXMgZ2VuZXJhdGVkIGJ5IFRFQUxTY3JpcHQgdjAuMTA1LjAKLy8gaHR0cHM6Ly9naXRodWIuY29tL2FsZ29yYW5kZm91bmRhdGlvbi9URUFMU2NyaXB0CgovLyBUaGlzIGNvbnRyYWN0IGlzIGNvbXBsaWFudCB3aXRoIGFuZC9vciBpbXBsZW1lbnRzIHRoZSBmb2xsb3dpbmcgQVJDczogWyBBUkM0IF0KCi8vIFRoZSBmb2xsb3dpbmcgbGluZXMgb2YgVEVBTCBhcmUgdXNlZCB0byBpbml0aWFsaXplIHRlbXBsYXRlIHZhcmlhYmxlcyBpbiBzY3JhdGNoIHNsb3RzCmJ5dGVjIDAgLy8gVE1QTF9ieXRlczY0VG1wbFZhcgpieXRlYyAxIC8vIFRNUExfYnl0ZXMzMlRtcGxWYXIKaW50YyAwIC8vIFRNUExfdWludDY0VG1wbFZhcgpieXRlYyAyIC8vIFRNUExfYnl0ZXNUbXBsVmFyCgovLyBUaGUgZm9sbG93aW5nIHRlbiBsaW5lcyBvZiBURUFMIGhhbmRsZSBpbml0aWFsIHByb2dyYW0gZmxvdwovLyBUaGlzIHBhdHRlcm4gaXMgdXNlZCB0byBtYWtlIGl0IGVhc3kgZm9yIGFueW9uZSB0byBwYXJzZSB0aGUgc3RhcnQgb2YgdGhlIHByb2dyYW0gYW5kIGRldGVybWluZSBpZiBhIHNwZWNpZmljIGFjdGlvbiBpcyBhbGxvd2VkCi8vIEhlcmUsIGFjdGlvbiByZWZlcnMgdG8gdGhlIE9uQ29tcGxldGUgaW4gY29tYmluYXRpb24gd2l0aCB3aGV0aGVyIHRoZSBhcHAgaXMgYmVpbmcgY3JlYXRlZCBvciBjYWxsZWQKLy8gRXZlcnkgcG9zc2libGUgYWN0aW9uIGZvciB0aGlzIGNvbnRyYWN0IGlzIHJlcHJlc2VudGVkIGluIHRoZSBzd2l0Y2ggc3RhdGVtZW50Ci8vIElmIHRoZSBhY3Rpb24gaXMgbm90IGltcGxlbWVudGVkIGluIHRoZSBjb250cmFjdCwgaXRzIHJlc3BlY3RpdmUgYnJhbmNoIHdpbGwgYmUgIipOT1RfSU1QTEVNRU5URUQiIHdoaWNoIGp1c3QgY29udGFpbnMgImVyciIKdHhuIEFwcGxpY2F0aW9uSUQKIQpwdXNoaW50IDYKKgp0eG4gT25Db21wbGV0aW9uCisKc3dpdGNoICpjYWxsX05vT3AgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpjcmVhdGVfTm9PcCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQgKk5PVF9JTVBMRU1FTlRFRCAqTk9UX0lNUExFTUVOVEVEICpOT1RfSU1QTEVNRU5URUQKCipOT1RfSU1QTEVNRU5URUQ6CgkvLyBUaGUgcmVxdWVzdGVkIGFjdGlvbiBpcyBub3QgaW1wbGVtZW50ZWQgaW4gdGhpcyBjb250cmFjdC4gQXJlIHlvdSB1c2luZyB0aGUgY29ycmVjdCBPbkNvbXBsZXRlPyBEaWQgeW91IHNldCB5b3VyIGFwcCBJRD8KCWVycgoKLy8gdG1wbCgpdm9pZAoqYWJpX3JvdXRlX3RtcGw6CgkvLyBleGVjdXRlIHRtcGwoKXZvaWQKCWNhbGxzdWIgdG1wbAoJcHVzaGludCAxCglyZXR1cm4KCi8vIHRtcGwoKTogdm9pZAp0bXBsOgoJcHJvdG8gMCAwCgoJLy8gdGVzdHMvY29udHJhY3RzL2dlbmVyYWwuYWxnby50czozNAoJLy8gbG9nKHRoaXMuYnl0ZXNUbXBsVmFyKQoJYnl0ZWMgMiAvLyBUTVBMX2J5dGVzVG1wbFZhcgoJbG9nCgoJLy8gdGVzdHMvY29udHJhY3RzL2dlbmVyYWwuYWxnby50czozNQoJLy8gYXNzZXJ0KHRoaXMudWludDY0VG1wbFZhcikKCWludGMgMCAvLyBUTVBMX3VpbnQ2NFRtcGxWYXIKCWFzc2VydAoJcmV0c3ViCgovLyBzcGVjaWZpY0xlbmd0aFRlbXBsYXRlVmFyKCl2b2lkCiphYmlfcm91dGVfc3BlY2lmaWNMZW5ndGhUZW1wbGF0ZVZhcjoKCS8vIGV4ZWN1dGUgc3BlY2lmaWNMZW5ndGhUZW1wbGF0ZVZhcigpdm9pZAoJY2FsbHN1YiBzcGVjaWZpY0xlbmd0aFRlbXBsYXRlVmFyCglwdXNoaW50IDEKCXJldHVybgoKLy8gc3BlY2lmaWNMZW5ndGhUZW1wbGF0ZVZhcigpOiB2b2lkCnNwZWNpZmljTGVuZ3RoVGVtcGxhdGVWYXI6Cglwcm90byAwIDAKCgkvLyB0ZXN0cy9jb250cmFjdHMvZ2VuZXJhbC5hbGdvLnRzOjM5CgkvLyBlZDI1NTE5VmVyaWZ5QmFyZSh0aGlzLmJ5dGVzVG1wbFZhciwgdGhpcy5ieXRlczY0VG1wbFZhciwgdGhpcy5ieXRlczMyVG1wbFZhcikKCWJ5dGVjIDIgLy8gVE1QTF9ieXRlc1RtcGxWYXIKCWJ5dGVjIDAgLy8gVE1QTF9ieXRlczY0VG1wbFZhcgoJYnl0ZWMgMSAvLyBUTVBMX2J5dGVzMzJUbXBsVmFyCgllZDI1NTE5dmVyaWZ5X2JhcmUKCXJldHN1YgoKLy8gdGhyb3dFcnJvcigpdm9pZAoqYWJpX3JvdXRlX3Rocm93RXJyb3I6CgkvLyBleGVjdXRlIHRocm93RXJyb3IoKXZvaWQKCWNhbGxzdWIgdGhyb3dFcnJvcgoJcHVzaGludCAxCglyZXR1cm4KCi8vIHRocm93RXJyb3IoKTogdm9pZAp0aHJvd0Vycm9yOgoJcHJvdG8gMCAwCgoJLy8gdGhpcyBpcyBhbiBlcnJvcgoJZXJyCglyZXRzdWIKCi8vIGl0b2JUZW1wbGF0ZVZhcigpYnl0ZVtdCiphYmlfcm91dGVfaXRvYlRlbXBsYXRlVmFyOgoJLy8gVGhlIEFCSSByZXR1cm4gcHJlZml4CglwdXNoYnl0ZXMgMHgxNTFmN2M3NQoKCS8vIGV4ZWN1dGUgaXRvYlRlbXBsYXRlVmFyKClieXRlW10KCWNhbGxzdWIgaXRvYlRlbXBsYXRlVmFyCglkdXAKCWxlbgoJaXRvYgoJZXh0cmFjdCA2IDIKCXN3YXAKCWNvbmNhdAoJY29uY2F0Cglsb2cKCXB1c2hpbnQgMQoJcmV0dXJuCgovLyBpdG9iVGVtcGxhdGVWYXIoKTogYnl0ZXMKaXRvYlRlbXBsYXRlVmFyOgoJcHJvdG8gMCAxCgoJLy8gdGVzdHMvY29udHJhY3RzL2dlbmVyYWwuYWxnby50czo0NwoJLy8gcmV0dXJuIGl0b2IodGhpcy51aW50NjRUbXBsVmFyKTsKCWludGMgMCAvLyBUTVBMX3VpbnQ2NFRtcGxWYXIKCWl0b2IKCXJldHN1YgoKKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbjoKCXB1c2hpbnQgMQoJcmV0dXJuCgoqY3JlYXRlX05vT3A6CglwdXNoYnl0ZXMgMHhiODQ0N2IzNiAvLyBtZXRob2QgImNyZWF0ZUFwcGxpY2F0aW9uKCl2b2lkIgoJdHhuYSBBcHBsaWNhdGlvbkFyZ3MgMAoJbWF0Y2ggKmFiaV9yb3V0ZV9jcmVhdGVBcHBsaWNhdGlvbgoKCS8vIHRoaXMgY29udHJhY3QgZG9lcyBub3QgaW1wbGVtZW50IHRoZSBnaXZlbiBBQkkgbWV0aG9kIGZvciBjcmVhdGUgTm9PcAoJZXJyCgoqY2FsbF9Ob09wOgoJcHVzaGJ5dGVzIDB4OWE3MWQyYjQgLy8gbWV0aG9kICJ0bXBsKCl2b2lkIgoJcHVzaGJ5dGVzIDB4ZGY0ZDVjM2IgLy8gbWV0aG9kICJzcGVjaWZpY0xlbmd0aFRlbXBsYXRlVmFyKCl2b2lkIgoJcHVzaGJ5dGVzIDB4M2Q4NzBkODcgLy8gbWV0aG9kICJ0aHJvd0Vycm9yKCl2b2lkIgoJcHVzaGJ5dGVzIDB4YmMwYjE3MDYgLy8gbWV0aG9kICJpdG9iVGVtcGxhdGVWYXIoKWJ5dGVbXSIKCXR4bmEgQXBwbGljYXRpb25BcmdzIDAKCW1hdGNoICphYmlfcm91dGVfdG1wbCAqYWJpX3JvdXRlX3NwZWNpZmljTGVuZ3RoVGVtcGxhdGVWYXIgKmFiaV9yb3V0ZV90aHJvd0Vycm9yICphYmlfcm91dGVfaXRvYlRlbXBsYXRlVmFyCgoJLy8gdGhpcyBjb250cmFjdCBkb2VzIG5vdCBpbXBsZW1lbnQgdGhlIGdpdmVuIEFCSSBtZXRob2QgZm9yIGNhbGwgTm9PcAoJZXJy", "clear": "I3ByYWdtYSB2ZXJzaW9uIDEw" }, "templateVariables": {